Skip to main content

Working with data

Initial data loading

When setting up Kanban, it's possible to pass in starting data for columns, cards, rows, and links.

const columns = [ // data for columns
{
label: "Backlog",
id: "backlog"
},
{
label: "In progress",
id: "inprogress"
},
{
label: "Testing",
id: "testing"
},
{...}
];

const cards = [ // data for cards
{
id: 1,
label: "Integration with React",
priority: 1,
color: "#65D3B3",
description: "Some description...",

start_date: new Date("01/05/2021"),
end_date: new Date("01/15/2021"),

progress: 25,
users: [1,2,3,4],
sprint: "1.0",
column: "backlog",
type: "feature",
css: "red",
votes: [4,6,9],
comments: [
{
id: 1,
userId: 9,
cardId: 6,
text: "Greetings, fellow colleagues. I would like to share my insights on this task. I reckon we should deal with at least half of the points in the plan without further delays.",
date: new Date(),
},{...}
]
},
{
id: 2,
label: "Archive the cards/boards ",
priority: 2,
color: "#FFC975",

start_date: new Date("01/05/2021"),
end_date: new Date("01/15/2021"),

sprint: "1.0",
column: "backlog",
type: "feature"
},
{
label: "Searching and filtering",
priority: 1,
color: "#65D3B3",

start_date: new Date("01/05/2021"),

sprint: "1.2",
column: "backlog",
type: "task"
},
{
label: "Set the tasks priorities",
priority: 2,
color: "#58C3FE",

sprint: "1.2",
column: "inprogress",
type: "feature"
},
{...}
];

const rows = [ // data for rows
{
label: "Feature",
id: "feature"
},
{
label: "Task",
id: "task",
collapsed: true
},
{...}
];

const links = [
{
id: "link_1",
masterId: 1,
slaveId: 2,
relation: "relatesTo",
},
{...}
];

// initializing Kanban with the initial data for columns, cards and rows
new kanban.Kanban("#root", {
columns,
cards,
rows,
links
});

Loading data from local source

To bring in data for columns, rows, and cards from a local source, the parse() method is available. Just pass an object containing the needed data.

const board = new kanban.Kanban("#root", {});

// loading data into Kanban
board.parse({ columns, cards, rows });

Syncing Kanban data with Gantt and Scheduler

Here's an example showing how to sync Kanban data with other DHTMLX widgets, like Gantt and Scheduler:

Getting Kanban data

There are a few methods for accessing Kanban data:

  • getAreaCards() - returns an array with data objects for all cards in a specific column (and row)
  • getCard() - returns a data object for a card by its ID
  • serialize() - serializes Kanban data into JSON

Getting Kanban state

To access the state of Kanban, these methods are handy:

Exporting Kanban data

For exporting Kanban data, you can use:

Adding new items

New cards, columns, and rows can be created with these methods:

Updating items

If you need to update cards, columns, or rows, these methods come in handy:

Deleting items

Cards, columns, and rows can be deleted with the following methods:

Moving items

To change the position of cards, columns, or rows, try these:

Example

Here's a snippet that shows how to use the Kanban API to manage data: