cards
Description
Optional. An array of objects containing the cards data
Usage
cards?: [
{
id?: string | number,
label?: string,
description?: string,
progress?: number,
start_date?: Date,
end_date?: Date,
attached?: [
{
id: string | number,
url?: string,
previewURL?: string,
coverURL?: string,
name?: string,
isCover?: boolean
}, {...}
],
color?: string,
users?: array | string | number,
// users?: array - for multiple users, if you use the "multiselect" editor type to assign users
// users?: string | number - for a single user, if you use the "combo" or "select" editor type to assign a user
priority?: string | number,
css?: string,
votes?: array,
comments?: [
{
id: string | number,
userId: string | number,
cardId: string | number,
text?: string,
date?: Date,
},{...}
],
[custom_key: string]?: any
},
{...} // other cards data
];
Parameters
For each card you can specify the following parameters (data):
id
- (optional) a card ID. It is used for managing the card via the corresponding methodslabel
- (optional) a card label. It is displayed in the Label fielddescription
- (optional)a card description. It is displayed in the Description fieldprogress
- (optional) a progress bar value. You can specify the value in the range from 0 to 100 points. It is displayed in the Progress bar fieldstart_date
- (optional) a start Date object (do not specify a string date). It is displayed in the Start date fieldend_date
- (optional) an end Date object (do not specify a string date). It is displayed in the End date fieldattached
- (optional) an array of objects with data of the attached file(s). It is displayed in the Attachment field. For each object you can specify the following parameters:id
- (required) an ID of the attached fileurl
- (optional) a path to the file to be attachedpreviewURL
- (optional) a path to the preview imagecoverURL
- (optional) a path to the image to be set as a covername
- (optional) a file nameisCover
- (optional) enables a cover image. If true, the cover image will be downloaded via the "coverURL" url
color
- (optional) a valid HEX color code. It is the color of the card top lineusers
- (optional) an array with IDs for multiple assigned users or string | number for a single assigned user. To specify the assigned users, you need to define an array with users data in the cardShape.users property. The users are displayed in the Users field
info
users?: array
- specify array with users IDs, if you use the multiselect editor type to assign multiple users
users?: string | number
- specify a single ID, if you use the combo or select editor types to assign a single user
priority
- (optional) a card priority ID. To specify the card priority, you need to define an array with priorities data in the cardShape.priority property. It is displayed in the Priority fieldcss
- (optional) defines css styles for a separate cardvotes
- (optional) an array of user IDscomments
- (optional) an array of objects with data of comments. For each comment's object you can specify the following parameters:id
- (required) an ID of the commentuserId
- (required) an ID of a user that posted the commentcardId
- (required) an ID of the card that the comment belongs totext
- (optional) a text of the comment. It also can contain html markupdate
- (optional) a Date object (do not specify a string date). The date when the comment was posted. It is not updated after editing
custom_key
- (optional) a custom key of the card. You can specify the custom keys to place the card into column and row. See the columnKey and rowKey properties
info
If you want to load new data for cards dynamically, you can use the parse() method!
Example
const cards = [
{
id: 1,
label: "Integration with React",
description: "Some description",
progress: 25,
start_date: new Date("02/24/2022"),
end_date: new Date("02/24/2023"),
attached: [
{
id: 234,
url: "../assets/img-1.jpg",
previewURL: "../assets/img-1.jpg",
coverURL: "../assets/img-1.jpg",
name: "img-1.jpg",
isCover: true
}, {...} // other attached files data
],
color: "#65D3B3",
users: [1,2],
votes: [3,6,8],
comments: [
{
id: 1,
userId: 1,
cardId: 1,
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(),
}, {...}
],
priority: 1,
// custom field to place the card into the "feature" row
// the rowKey config needs to be set to the "type" value
type: "feature",
// custom field to place the card into the "backlog" column
// the columnKey config needs to be set to the "stage" value
stage: "backlog",
css: "red",
},{...} // other cards data
];
new kanban.Kanban("#root", {
columns,
cards,
// other parameters
});
Change log: The css, comments and votes parameters were added in v1.4
Related articles:
Related sample: Kanban. Styling cards