@progress/kendo-react-taskboard 5.3.0-dev.202205041411

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/LICENSE.md +11 -0
  2. package/NOTICE.txt +111 -0
  3. package/README.md +41 -0
  4. package/about.md +3 -0
  5. package/dist/cdn/js/kendo-react-taskboard.js +1 -0
  6. package/dist/es/TaskBoard.d.ts +145 -0
  7. package/dist/es/TaskBoard.js +267 -0
  8. package/dist/es/TaskBoardAddCard.d.ts +32 -0
  9. package/dist/es/TaskBoardAddCard.js +16 -0
  10. package/dist/es/TaskBoardCardBase.d.ts +56 -0
  11. package/dist/es/TaskBoardCardBase.js +87 -0
  12. package/dist/es/TaskBoardColumnBase.d.ts +72 -0
  13. package/dist/es/TaskBoardColumnBase.js +90 -0
  14. package/dist/es/TaskBoardConfirmDialog.d.ts +37 -0
  15. package/dist/es/TaskBoardConfirmDialog.js +24 -0
  16. package/dist/es/TaskBoardEditCard.d.ts +20 -0
  17. package/dist/es/TaskBoardEditCard.js +16 -0
  18. package/dist/es/TaskBoardTaskEditPane.d.ts +93 -0
  19. package/dist/es/TaskBoardTaskEditPane.js +36 -0
  20. package/dist/es/TaskBoardToolbar.d.ts +26 -0
  21. package/dist/es/TaskBoardToolbar.js +17 -0
  22. package/dist/es/card/Card.d.ts +140 -0
  23. package/dist/es/card/Card.js +33 -0
  24. package/dist/es/card/CardBody.d.ts +22 -0
  25. package/dist/es/card/CardBody.js +9 -0
  26. package/dist/es/card/CardHeader.d.ts +56 -0
  27. package/dist/es/card/CardHeader.js +18 -0
  28. package/dist/es/card/PreviewDialog.d.ts +50 -0
  29. package/dist/es/card/PreviewDialog.js +25 -0
  30. package/dist/es/column/Column.d.ts +168 -0
  31. package/dist/es/column/Column.js +34 -0
  32. package/dist/es/column/ColumnBody.d.ts +46 -0
  33. package/dist/es/column/ColumnBody.js +9 -0
  34. package/dist/es/column/ColumnHeader.d.ts +55 -0
  35. package/dist/es/column/ColumnHeader.js +18 -0
  36. package/dist/es/constants.d.ts +20 -0
  37. package/dist/es/constants.js +20 -0
  38. package/dist/es/hooks/taskEditing.d.ts +18 -0
  39. package/dist/es/hooks/taskEditing.js +32 -0
  40. package/dist/es/main.d.ts +14 -0
  41. package/dist/es/main.js +14 -0
  42. package/dist/es/messages/index.d.ts +150 -0
  43. package/dist/es/messages/index.js +151 -0
  44. package/dist/es/package-metadata.d.ts +5 -0
  45. package/dist/es/package-metadata.js +11 -0
  46. package/dist/es/utils.d.ts +25 -0
  47. package/dist/es/utils.js +80 -0
  48. package/dist/npm/TaskBoard.d.ts +145 -0
  49. package/dist/npm/TaskBoard.js +269 -0
  50. package/dist/npm/TaskBoardAddCard.d.ts +32 -0
  51. package/dist/npm/TaskBoardAddCard.js +18 -0
  52. package/dist/npm/TaskBoardCardBase.d.ts +56 -0
  53. package/dist/npm/TaskBoardCardBase.js +89 -0
  54. package/dist/npm/TaskBoardColumnBase.d.ts +72 -0
  55. package/dist/npm/TaskBoardColumnBase.js +92 -0
  56. package/dist/npm/TaskBoardConfirmDialog.d.ts +37 -0
  57. package/dist/npm/TaskBoardConfirmDialog.js +26 -0
  58. package/dist/npm/TaskBoardEditCard.d.ts +20 -0
  59. package/dist/npm/TaskBoardEditCard.js +18 -0
  60. package/dist/npm/TaskBoardTaskEditPane.d.ts +93 -0
  61. package/dist/npm/TaskBoardTaskEditPane.js +38 -0
  62. package/dist/npm/TaskBoardToolbar.d.ts +26 -0
  63. package/dist/npm/TaskBoardToolbar.js +19 -0
  64. package/dist/npm/card/Card.d.ts +140 -0
  65. package/dist/npm/card/Card.js +35 -0
  66. package/dist/npm/card/CardBody.d.ts +22 -0
  67. package/dist/npm/card/CardBody.js +11 -0
  68. package/dist/npm/card/CardHeader.d.ts +56 -0
  69. package/dist/npm/card/CardHeader.js +20 -0
  70. package/dist/npm/card/PreviewDialog.d.ts +50 -0
  71. package/dist/npm/card/PreviewDialog.js +27 -0
  72. package/dist/npm/column/Column.d.ts +168 -0
  73. package/dist/npm/column/Column.js +36 -0
  74. package/dist/npm/column/ColumnBody.d.ts +46 -0
  75. package/dist/npm/column/ColumnBody.js +11 -0
  76. package/dist/npm/column/ColumnHeader.d.ts +55 -0
  77. package/dist/npm/column/ColumnHeader.js +20 -0
  78. package/dist/npm/constants.d.ts +20 -0
  79. package/dist/npm/constants.js +22 -0
  80. package/dist/npm/hooks/taskEditing.d.ts +18 -0
  81. package/dist/npm/hooks/taskEditing.js +34 -0
  82. package/dist/npm/main.d.ts +14 -0
  83. package/dist/npm/main.js +30 -0
  84. package/dist/npm/messages/index.d.ts +150 -0
  85. package/dist/npm/messages/index.js +153 -0
  86. package/dist/npm/package-metadata.d.ts +5 -0
  87. package/dist/npm/package-metadata.js +13 -0
  88. package/dist/npm/utils.d.ts +25 -0
  89. package/dist/npm/utils.js +82 -0
  90. package/dist/systemjs/kendo-react-taskboard.js +1 -0
  91. package/package.json +76 -0
@@ -0,0 +1,50 @@
1
+ import * as React from 'react';
2
+ import { TaskBoardPriority } from '../TaskBoard';
3
+ /**
4
+ * Represents the props of the TaskBoardPreviewDialog component.
5
+ */
6
+ export interface TaskBoardPreviewDialogProps {
7
+ /**
8
+ * The rendered title.
9
+ */
10
+ title: React.ReactNode;
11
+ /**
12
+ * The rendered description.
13
+ */
14
+ description: React.ReactNode;
15
+ /**
16
+ * Represents the priority label of the TaskBoardPreviewDialog.
17
+ */
18
+ priorityLabel: React.ReactNode;
19
+ /**
20
+ * Determines the delete node.
21
+ */
22
+ delete: React.ReactNode;
23
+ /**
24
+ * Determines the edit node.
25
+ */
26
+ edit: React.ReactNode;
27
+ /**
28
+ * Represents the priority of the task board.
29
+ */
30
+ priority: TaskBoardPriority;
31
+ /**
32
+ * Fires when task preview pane is shown.
33
+ */
34
+ onShowTaskPreviewPane: () => void;
35
+ /**
36
+ * Fires when task is deleted.
37
+ */
38
+ onDeleteTask: () => void;
39
+ /**
40
+ * Fires when task is edited.
41
+ */
42
+ onTaskEdit: () => void;
43
+ }
44
+ /**
45
+ * Represents the TaskBoardPreviewDialog component.
46
+ */
47
+ export declare const TaskBoardPreviewDialog: {
48
+ (props: TaskBoardPreviewDialogProps): JSX.Element;
49
+ displayName: string;
50
+ };
@@ -0,0 +1,25 @@
1
+ import * as React from 'react';
2
+ import { Button } from '@progress/kendo-react-buttons';
3
+ /**
4
+ * Represents the TaskBoardPreviewDialog component.
5
+ */
6
+ export var TaskBoardPreviewDialog = function (props) {
7
+ return (React.createElement("div", { className: "k-taskboard-pane k-taskboard-preview-pane" },
8
+ React.createElement("div", { className: 'k-taskboard-pane-header' },
9
+ React.createElement("div", { className: 'k-taskboard-pane-header-text' }, props.title),
10
+ React.createElement("span", { className: "k-spacer" }),
11
+ React.createElement("div", { className: "k-taskboard-pane-header-actions" },
12
+ React.createElement(Button, { icon: 'close', fillMode: "flat", onClick: props.onShowTaskPreviewPane }))),
13
+ React.createElement("div", { className: "k-taskboard-pane-content" },
14
+ React.createElement("p", null, props.description),
15
+ React.createElement("p", null,
16
+ props.priorityLabel,
17
+ "\u00A0",
18
+ React.createElement("span", { style: { backgroundColor: props.priority.color } }, "\u00A0"),
19
+ "\u00A0",
20
+ props.priority.priority)),
21
+ React.createElement("div", { className: "k-taskboard-pane-actions k-actions k-hstack k-justify-content-end" },
22
+ React.createElement(Button, { onClick: props.onDeleteTask }, props.delete),
23
+ React.createElement(Button, { themeColor: 'primary', onClick: props.onTaskEdit }, props.edit))));
24
+ };
25
+ TaskBoardPreviewDialog.displayName = 'KendoReactTaskBoardPreviewDialog';
@@ -0,0 +1,168 @@
1
+ import * as React from 'react';
2
+ import { InputChangeEvent } from '@progress/kendo-react-inputs';
3
+ import { TaskBoardAddCardProps } from './../TaskBoardAddCard';
4
+ import { TaskBoardEditCardProps } from './../TaskBoardEditCard';
5
+ import { TaskBoardConfirmDialogProps } from './../TaskBoardConfirmDialog';
6
+ import { TaskBoardCardProps } from './../card/Card';
7
+ import { TaskBoardColumnHeaderProps } from './ColumnHeader';
8
+ import { TaskBoardColumnBodyProps } from './ColumnBody';
9
+ import { TaskBoardColumnModel, TaskBoardPriority, TaskBoardTaskModel } from '../TaskBoard';
10
+ /**
11
+ * Represents the props of the TaskBoardColumn component
12
+ */
13
+ export interface TaskBoardColumnProps {
14
+ /**
15
+ * The column of the TaskBoard.
16
+ */
17
+ column: TaskBoardColumnModel;
18
+ /**
19
+ * The tasks of the TaskBoard.
20
+ */
21
+ tasks: TaskBoardTaskModel[];
22
+ /**
23
+ * The priorities that are set in the TaskBoard.
24
+ */
25
+ priorities: TaskBoardPriority[];
26
+ /**
27
+ * The styles for the TaskBoard.
28
+ */
29
+ style?: React.CSSProperties;
30
+ /**
31
+ * Specifies the `tabIndex` that will be added to the TaskBoard Column element.
32
+ */
33
+ tabIndex?: number;
34
+ /**
35
+ * Represents the reference of the element.
36
+ */
37
+ elementRef?: React.RefObject<HTMLDivElement>;
38
+ /**
39
+ * Represents the reference of the drag target.
40
+ */
41
+ dragTargetRef?: React.RefObject<{
42
+ width: number;
43
+ height: number;
44
+ }>;
45
+ /**
46
+ * Determines the visibility of the add card.
47
+ */
48
+ showAddCard: boolean;
49
+ /**
50
+ * Determines the visibility of the edit card.
51
+ */
52
+ showEditCard: boolean;
53
+ /**
54
+ * Determines the visibility of the column confirm/delete.
55
+ */
56
+ showColumnConfirmDelete: boolean;
57
+ /**
58
+ * Specifies the edited task.
59
+ */
60
+ editedTask?: TaskBoardTaskModel;
61
+ /**
62
+ * Specifies the confirm dialog message
63
+ */
64
+ confirmDialogMessage: React.ReactNode;
65
+ /**
66
+ * Specifies the confirm dialog confirm button node.
67
+ */
68
+ confirmDialogConfirmButton: React.ReactNode;
69
+ /**
70
+ * Specifies the cancel dialog confirm button node.
71
+ */
72
+ confirmDialogCancelButton: React.ReactNode;
73
+ /**
74
+ * Specifies the confirm dialog title.
75
+ */
76
+ confirmDialogTitle: string;
77
+ /**
78
+ * Specifies the edit button title.
79
+ */
80
+ editButtonTitle: string;
81
+ /**
82
+ * Specifies the add button title.
83
+ */
84
+ addButtonTitle: string;
85
+ /**
86
+ * Specifies the close button title.
87
+ */
88
+ closeButtonTitle: string;
89
+ /**
90
+ * Determines the children nodes.
91
+ */
92
+ children: React.ReactNode;
93
+ /**
94
+ * Fire on task creation.
95
+ */
96
+ onTaskCreate: (task: TaskBoardTaskModel) => void;
97
+ /**
98
+ * Fires when task is edited.
99
+ */
100
+ onTaskEdit: (task: TaskBoardTaskModel, prevTask: TaskBoardTaskModel) => void;
101
+ /**
102
+ * Fires when task is deleted.
103
+ */
104
+ onTaskDelete: (task: TaskBoardTaskModel) => void;
105
+ /**
106
+ * Fires when title is changed.
107
+ */
108
+ onTitleChange?: (event: InputChangeEvent) => void;
109
+ /**
110
+ * Fires when column enters edit.
111
+ */
112
+ onColumnEnterEdit: () => void;
113
+ /**
114
+ * Fires when column exits edit.
115
+ */
116
+ onColumnExitEdit: () => void;
117
+ /**
118
+ * Fires on confirmation of column deletion.
119
+ */
120
+ onColumnConfirmDelete: () => void;
121
+ /**
122
+ * Fires when the add card dialog is shown.
123
+ */
124
+ onShowAddCardDialog: () => void;
125
+ /**
126
+ * Fires when the edit card pane is shown.
127
+ */
128
+ onShowEditCardPane: (task: TaskBoardTaskModel) => void;
129
+ /**
130
+ * Fires on column deletion.
131
+ */
132
+ onColumnDelete: () => void;
133
+ /**
134
+ * Fires when the dialog is closed.
135
+ */
136
+ onCloseDialog: () => void;
137
+ /**
138
+ * Represents the TaskBoardCard component.
139
+ */
140
+ card: React.ComponentType<TaskBoardCardProps>;
141
+ /**
142
+ * Represents the TaskBoardColumnHeader component.
143
+ */
144
+ header: React.ComponentType<TaskBoardColumnHeaderProps>;
145
+ /**
146
+ * Represents the TaskBoardColumnBody component.
147
+ */
148
+ body: React.ComponentType<TaskBoardColumnBodyProps>;
149
+ /**
150
+ * Represents the TaskBoardConfirmDialog component.
151
+ */
152
+ confirmDialog: React.ComponentType<TaskBoardConfirmDialogProps>;
153
+ /**
154
+ * Represents the TaskBoardEditCard component.
155
+ */
156
+ editCardDialog: React.ComponentType<TaskBoardEditCardProps>;
157
+ /**
158
+ * Represents the TaskBoardAddCard component.
159
+ */
160
+ addCardDialog: React.ComponentType<TaskBoardAddCardProps>;
161
+ }
162
+ /**
163
+ * Represents the TaskBoardColumn component.
164
+ */
165
+ export declare const TaskBoardColumn: {
166
+ (props: TaskBoardColumnProps): JSX.Element;
167
+ displayName: string;
168
+ };
@@ -0,0 +1,34 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import * as React from 'react';
13
+ import { classNames } from '@progress/kendo-react-common';
14
+ import { TASKBOARD_COLUMN, TASKBOARD_ITEM_ID, TASKBOARD_ITEM_TYPE } from './../constants';
15
+ import { TaskBoardTaskEditPane } from '../TaskBoardTaskEditPane';
16
+ /**
17
+ * Represents the TaskBoardColumn component.
18
+ */
19
+ export var TaskBoardColumn = function (props) {
20
+ var _a;
21
+ return (React.createElement(React.Fragment, null,
22
+ React.createElement("div", __assign({ ref: props.elementRef, style: props.style, className: classNames('k-taskboard-column', {
23
+ 'k-taskboard-column-edit': props.column.edit
24
+ }), tabIndex: props.tabIndex }, (_a = {},
25
+ _a[TASKBOARD_ITEM_TYPE] = TASKBOARD_COLUMN,
26
+ _a[TASKBOARD_ITEM_ID] = props.column.id,
27
+ _a)),
28
+ React.createElement(props.header, { column: props.column, tasks: props.tasks, onTitleChange: props.onTitleChange, onColumnExitEdit: props.onColumnExitEdit, editButtonTitle: props.editButtonTitle, onColumnEnterEdit: props.onColumnEnterEdit, addButtonTitle: props.addButtonTitle, onShowAddCardDialog: props.onShowAddCardDialog, closeButtonTitle: props.closeButtonTitle, onColumnDelete: props.onColumnDelete }),
29
+ React.createElement(props.body, { column: props.column, tasks: props.tasks, card: props.card, onTaskDelete: props.onTaskDelete, onShowEditCardPane: props.onShowEditCardPane, dragTargetRef: props.dragTargetRef }, props.children)),
30
+ props.showAddCard && (React.createElement(props.addCardDialog, { onClose: props.onCloseDialog, onSave: props.onTaskCreate, priorities: props.priorities, editPane: TaskBoardTaskEditPane })),
31
+ props.showEditCard && props.editedTask && (React.createElement(props.editCardDialog, { onClose: props.onCloseDialog, onSave: props.onTaskEdit, task: props.editedTask, priorities: props.priorities, editPane: TaskBoardTaskEditPane })),
32
+ props.showColumnConfirmDelete && (React.createElement(props.confirmDialog, { onClose: props.onColumnDelete, onConfirm: props.onColumnConfirmDelete, dialogMessage: props.confirmDialogMessage, dialogTitle: props.confirmDialogTitle, dialogConfirmButton: props.confirmDialogConfirmButton, dialogCancelButton: props.confirmDialogCancelButton }))));
33
+ };
34
+ TaskBoardColumn.displayName = 'KendoReactTaskBoardColumn';
@@ -0,0 +1,46 @@
1
+ import * as React from 'react';
2
+ import { TaskBoardCardProps } from '../card/Card';
3
+ import { TaskBoardColumnModel, TaskBoardTaskModel } from '../TaskBoard';
4
+ /**
5
+ * Represents the props of the TaskBoardColumnBody component
6
+ */
7
+ export interface TaskBoardColumnBodyProps {
8
+ /**
9
+ * The rendered column.
10
+ */
11
+ column: TaskBoardColumnModel;
12
+ /**
13
+ * The rendered tasks.
14
+ */
15
+ tasks: TaskBoardTaskModel[];
16
+ /**
17
+ * Determines the children nodes.
18
+ */
19
+ children: React.ReactNode;
20
+ /**
21
+ * Represents the drag target reference.
22
+ */
23
+ dragTargetRef?: React.RefObject<{
24
+ width: number;
25
+ height: number;
26
+ }>;
27
+ /**
28
+ * The event that is fired when a task is deleted.
29
+ */
30
+ onTaskDelete: (task: TaskBoardTaskModel) => void;
31
+ /**
32
+ * The event that is fired when a task is edited.
33
+ */
34
+ onShowEditCardPane: (task: TaskBoardTaskModel) => void;
35
+ /**
36
+ * Represents the TaskBoardCard component.
37
+ */
38
+ card: React.ComponentType<TaskBoardCardProps>;
39
+ }
40
+ /**
41
+ * Represents the TaskBoardColumnBody component.
42
+ */
43
+ export declare const TaskBoardColumnBody: {
44
+ (props: TaskBoardColumnBodyProps): JSX.Element;
45
+ displayName: string;
46
+ };
@@ -0,0 +1,9 @@
1
+ import * as React from 'react';
2
+ /**
3
+ * Represents the TaskBoardColumnBody component.
4
+ */
5
+ export var TaskBoardColumnBody = function (props) {
6
+ return (React.createElement("div", { className: 'k-taskboard-column-cards-container' },
7
+ React.createElement("div", { className: 'k-taskboard-column-cards' }, props.children)));
8
+ };
9
+ TaskBoardColumnBody.displayName = 'KendoReactTaskBoardColumnBody';
@@ -0,0 +1,55 @@
1
+ /// <reference types="react" />
2
+ import { InputChangeEvent } from '@progress/kendo-react-inputs';
3
+ import { TaskBoardColumnModel, TaskBoardTaskModel } from '../TaskBoard';
4
+ /**
5
+ * Represents the props of the TaskBoardColumnHeader component.
6
+ */
7
+ export interface TaskBoardColumnHeaderProps {
8
+ /**
9
+ * The rendered column.
10
+ */
11
+ column: TaskBoardColumnModel;
12
+ /**
13
+ * The rendered tasks.
14
+ */
15
+ tasks: TaskBoardTaskModel[];
16
+ /**
17
+ * The title of the editButton.
18
+ */
19
+ editButtonTitle: string;
20
+ /**
21
+ * The title of the addButton.
22
+ */
23
+ addButtonTitle: string;
24
+ /**
25
+ * The title of the closeButton.
26
+ */
27
+ closeButtonTitle: string;
28
+ /**
29
+ * The event that is fired when the title is changed.
30
+ */
31
+ onTitleChange?: (event: InputChangeEvent) => void;
32
+ /**
33
+ * The event that is fired when a column enters edit mode.
34
+ */
35
+ onColumnEnterEdit: () => void;
36
+ /**
37
+ * The event that is fired when a column exits edit mode.
38
+ */
39
+ onColumnExitEdit: () => void;
40
+ /**
41
+ * The event that is fired when a add card dialog is shown.
42
+ */
43
+ onShowAddCardDialog: () => void;
44
+ /**
45
+ * The event that is fired when a column is deleted.
46
+ */
47
+ onColumnDelete: () => void;
48
+ }
49
+ /**
50
+ * Represents the TaskBoardColumnHeader component.
51
+ */
52
+ export declare const TaskBoardColumnHeader: {
53
+ (props: TaskBoardColumnHeaderProps): JSX.Element;
54
+ displayName: string;
55
+ };
@@ -0,0 +1,18 @@
1
+ import * as React from 'react';
2
+ import { Button } from '@progress/kendo-react-buttons';
3
+ import { Input } from '@progress/kendo-react-inputs';
4
+ import { classNames } from '@progress/kendo-react-common';
5
+ /**
6
+ * Represents the TaskBoardColumnHeader component.
7
+ */
8
+ export var TaskBoardColumnHeader = function (props) {
9
+ var _a = props.column, edit = _a.edit, title = _a.title;
10
+ return (React.createElement("div", { className: 'k-taskboard-column-header' },
11
+ React.createElement("div", { className: 'k-taskboard-column-header-text k-text-ellipsis' }, edit ? (React.createElement(Input, { value: title, onChange: props.onTitleChange, onBlur: props.onColumnExitEdit, autoFocus: true })) : title),
12
+ React.createElement("span", { className: 'k-spacer' }),
13
+ React.createElement("div", { className: classNames('k-taskboard-column-header-actions', { 'k-disabled': edit }) },
14
+ React.createElement(Button, { fillMode: "flat", icon: "edit", title: props.editButtonTitle, onClick: props.onColumnEnterEdit }),
15
+ React.createElement(Button, { fillMode: "flat", icon: "add", title: props.addButtonTitle, onClick: props.onShowAddCardDialog }),
16
+ React.createElement(Button, { fillMode: "flat", icon: "close", title: props.closeButtonTitle, onClick: props.onColumnDelete }))));
17
+ };
18
+ TaskBoardColumnHeader.displayName = 'KendoReactTaskBoardColumnHeader';
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @hidden
3
+ */
4
+ export declare const TASKBOARD_ITEM_TYPE = "data-taskboard-type";
5
+ /**
6
+ * @hidden
7
+ */
8
+ export declare const TASKBOARD_ITEM_ID = "data-taskboard-id";
9
+ /**
10
+ * @hidden
11
+ */
12
+ export declare const TASKBOARD_PLACEHOLDER = "data-taskboard-placeholder";
13
+ /**
14
+ * @hidden
15
+ */
16
+ export declare const TASKBOARD_COLUMN = "column";
17
+ /**
18
+ * @hidden
19
+ */
20
+ export declare const TASKBOARD_TASK = "task";
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @hidden
3
+ */
4
+ export var TASKBOARD_ITEM_TYPE = 'data-taskboard-type';
5
+ /**
6
+ * @hidden
7
+ */
8
+ export var TASKBOARD_ITEM_ID = 'data-taskboard-id';
9
+ /**
10
+ * @hidden
11
+ */
12
+ export var TASKBOARD_PLACEHOLDER = 'data-taskboard-placeholder';
13
+ /**
14
+ * @hidden
15
+ */
16
+ export var TASKBOARD_COLUMN = 'column';
17
+ /**
18
+ * @hidden
19
+ */
20
+ export var TASKBOARD_TASK = 'task';
@@ -0,0 +1,18 @@
1
+ import { DropDownListChangeEvent } from '@progress/kendo-react-dropdowns';
2
+ import { InputChangeEvent } from '@progress/kendo-react-inputs';
3
+ import { TaskBoardPriority, TaskBoardTaskModel } from '../TaskBoard';
4
+ export interface TaskEditingResult {
5
+ onTitleChange: (event: InputChangeEvent) => void;
6
+ title: string;
7
+ onDescriptionChange: (event: InputChangeEvent) => void;
8
+ description: string;
9
+ onPriorityChange: (event: DropDownListChangeEvent) => void;
10
+ priority: TaskBoardPriority;
11
+ onSave: () => void;
12
+ }
13
+ export interface TaskEditingProps {
14
+ task?: TaskBoardTaskModel;
15
+ priorities: TaskBoardPriority[];
16
+ onSave: (task: TaskBoardTaskModel, prevTask: TaskBoardTaskModel | undefined) => void;
17
+ }
18
+ export declare const useTaskEditing: ({ onSave, task, priorities }: TaskEditingProps) => TaskEditingResult;
@@ -0,0 +1,32 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import * as React from 'react';
13
+ export var useTaskEditing = function (_a) {
14
+ var onSave = _a.onSave, task = _a.task, priorities = _a.priorities;
15
+ var _b = React.useState(task ? task.title : ''), title = _b[0], setTitle = _b[1];
16
+ var _c = React.useState(task ? task.description : ''), description = _c[0], setDescription = _c[1];
17
+ var _d = React.useState(task ? task.priority : priorities[0]), priority = _d[0], setPriority = _d[1];
18
+ var onTitleChange = React.useCallback(function (event) {
19
+ setTitle(event.value);
20
+ }, []);
21
+ var onDescriptionChange = React.useCallback(function (event) {
22
+ setDescription(event.value);
23
+ }, []);
24
+ var onPriorityChange = React.useCallback(function (event) {
25
+ setPriority(event.target.value);
26
+ }, []);
27
+ var onSaveIn = React.useCallback(function () {
28
+ var nextTask = __assign({ id: undefined, status: '' }, (task || {}), { title: title, description: description, priority: priority });
29
+ onSave.call(undefined, nextTask, task);
30
+ }, [onSave, task, title, description, priority]);
31
+ return { onTitleChange: onTitleChange, title: title, onDescriptionChange: onDescriptionChange, description: description, onPriorityChange: onPriorityChange, priority: priority, onSave: onSaveIn };
32
+ };
@@ -0,0 +1,14 @@
1
+ export { TaskBoard, TaskBoardProps, TaskBoardHandle, TaskBoardChangeEvent, TaskBoardColumnModel, TaskBoardTaskModel, TaskBoardPriority } from './TaskBoard';
2
+ export { TaskBoardToolbar, TaskBoardToolbarProps } from './TaskBoardToolbar';
3
+ export { TaskBoardCard, TaskBoardCardProps } from './card/Card';
4
+ export { TaskBoardCardHeader, TaskBoardCardHeaderProps } from './card/CardHeader';
5
+ export { TaskBoardCardBody, TaskBoardCardBodyProps } from './card/CardBody';
6
+ export { TaskBoardColumn, TaskBoardColumnProps } from './column/Column';
7
+ export { TaskBoardColumnHeader, TaskBoardColumnHeaderProps } from './column/ColumnHeader';
8
+ export { TaskBoardColumnBody, TaskBoardColumnBodyProps } from './column/ColumnBody';
9
+ export { TaskBoardConfirmDialog, TaskBoardConfirmDialogProps } from './TaskBoardConfirmDialog';
10
+ export { TaskBoardPreviewDialog, TaskBoardPreviewDialogProps } from './card/PreviewDialog';
11
+ export { TaskBoardAddCard, TaskBoardAddCardProps } from './TaskBoardAddCard';
12
+ export { TaskBoardEditCard, TaskBoardEditCardProps } from './TaskBoardEditCard';
13
+ export { TaskBoardTaskEditPane, TaskBoardTaskEditPaneProps } from './TaskBoardTaskEditPane';
14
+ export { useTaskEditing, TaskEditingProps, TaskEditingResult } from './hooks/taskEditing';
@@ -0,0 +1,14 @@
1
+ export { TaskBoard } from './TaskBoard';
2
+ export { TaskBoardToolbar } from './TaskBoardToolbar';
3
+ export { TaskBoardCard } from './card/Card';
4
+ export { TaskBoardCardHeader } from './card/CardHeader';
5
+ export { TaskBoardCardBody } from './card/CardBody';
6
+ export { TaskBoardColumn } from './column/Column';
7
+ export { TaskBoardColumnHeader } from './column/ColumnHeader';
8
+ export { TaskBoardColumnBody } from './column/ColumnBody';
9
+ export { TaskBoardConfirmDialog } from './TaskBoardConfirmDialog';
10
+ export { TaskBoardPreviewDialog } from './card/PreviewDialog';
11
+ export { TaskBoardAddCard } from './TaskBoardAddCard';
12
+ export { TaskBoardEditCard } from './TaskBoardEditCard';
13
+ export { TaskBoardTaskEditPane } from './TaskBoardTaskEditPane';
14
+ export { useTaskEditing } from './hooks/taskEditing';