@firecms/core 3.0.1 → 3.1.0-canary.7d91b7c

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 (185) hide show
  1. package/README.md +1 -1
  2. package/dist/components/AIIcon.d.ts +16 -0
  3. package/dist/components/EntityCollectionTable/EntityCollectionRowActions.d.ts +7 -1
  4. package/dist/components/EntityCollectionTable/EntityCollectionTable.d.ts +1 -1
  5. package/dist/components/EntityCollectionTable/EntityCollectionTableProps.d.ts +14 -0
  6. package/dist/components/EntityCollectionTable/PropertyTableCell.d.ts +6 -0
  7. package/dist/components/EntityCollectionTable/internal/CollectionTableToolbar.d.ts +5 -4
  8. package/dist/components/EntityCollectionTable/internal/EntityTableCell.d.ts +6 -0
  9. package/dist/components/EntityCollectionTable/internal/popup_field/useDraggable.d.ts +2 -2
  10. package/dist/components/EntityCollectionView/Board.d.ts +2 -0
  11. package/dist/components/EntityCollectionView/BoardColumn.d.ts +42 -0
  12. package/dist/components/EntityCollectionView/BoardColumnTitle.d.ts +9 -0
  13. package/dist/components/EntityCollectionView/BoardSortableList.d.ts +14 -0
  14. package/dist/components/EntityCollectionView/EntityBoardCard.d.ts +26 -0
  15. package/dist/components/EntityCollectionView/EntityCard.d.ts +19 -0
  16. package/dist/components/EntityCollectionView/EntityCollectionBoardView.d.ts +20 -0
  17. package/dist/components/EntityCollectionView/EntityCollectionCardView.d.ts +31 -0
  18. package/dist/components/EntityCollectionView/EntityCollectionViewActions.d.ts +2 -2
  19. package/dist/components/EntityCollectionView/EntityCollectionViewStartActions.d.ts +7 -3
  20. package/dist/components/EntityCollectionView/FiltersDialog.d.ts +14 -0
  21. package/dist/components/EntityCollectionView/ViewModeToggle.d.ts +44 -0
  22. package/dist/components/EntityCollectionView/board_types.d.ts +105 -0
  23. package/dist/components/EntityCollectionView/useBoardDataController.d.ts +60 -0
  24. package/dist/components/ErrorBoundary.d.ts +1 -1
  25. package/dist/components/SelectableTable/SelectableTable.d.ts +5 -1
  26. package/dist/components/SelectableTable/filters/DateTimeFilterField.d.ts +2 -1
  27. package/dist/components/VirtualTable/VirtualTableCell.d.ts +6 -0
  28. package/dist/components/VirtualTable/VirtualTableHeader.d.ts +3 -1
  29. package/dist/components/VirtualTable/VirtualTableHeaderRow.d.ts +1 -1
  30. package/dist/components/VirtualTable/VirtualTableProps.d.ts +11 -0
  31. package/dist/components/VirtualTable/fields/VirtualTableDateField.d.ts +1 -0
  32. package/dist/components/VirtualTable/types.d.ts +2 -0
  33. package/dist/components/index.d.ts +3 -0
  34. package/dist/contexts/index.d.ts +10 -0
  35. package/dist/core/DrawerNavigationGroup.d.ts +45 -0
  36. package/dist/core/index.d.ts +1 -0
  37. package/dist/form/components/ErrorFocus.d.ts +1 -1
  38. package/dist/form/validation.d.ts +3 -2
  39. package/dist/hooks/useBreadcrumbsController.d.ts +16 -0
  40. package/dist/hooks/useCollapsedGroups.d.ts +4 -1
  41. package/dist/index.es.js +5266 -1578
  42. package/dist/index.es.js.map +1 -1
  43. package/dist/index.umd.js +5260 -1573
  44. package/dist/index.umd.js.map +1 -1
  45. package/dist/internal/useRestoreScroll.d.ts +1 -1
  46. package/dist/preview/PropertyPreviewProps.d.ts +5 -0
  47. package/dist/preview/components/DatePreview.d.ts +13 -3
  48. package/dist/preview/components/ImagePreview.d.ts +5 -1
  49. package/dist/preview/components/StorageThumbnail.d.ts +2 -1
  50. package/dist/preview/components/UrlComponentPreview.d.ts +2 -1
  51. package/dist/preview/property_previews/ArrayOfStorageComponentsPreview.d.ts +1 -1
  52. package/dist/preview/property_previews/ArrayOfStringsPreview.d.ts +1 -1
  53. package/dist/preview/property_previews/SkeletonPropertyComponent.d.ts +1 -1
  54. package/dist/types/analytics.d.ts +1 -1
  55. package/dist/types/collections.d.ts +50 -2
  56. package/dist/types/datasource.d.ts +0 -1
  57. package/dist/types/plugins.d.ts +62 -1
  58. package/dist/types/properties.d.ts +259 -4
  59. package/dist/util/__tests__/conditions.test.d.ts +1 -0
  60. package/dist/util/__tests__/objects.test.d.ts +1 -0
  61. package/dist/util/conditions.d.ts +26 -0
  62. package/dist/util/entities.d.ts +2 -3
  63. package/dist/util/index.d.ts +2 -1
  64. package/dist/util/property_utils.d.ts +2 -1
  65. package/dist/util/resolutions.d.ts +3 -3
  66. package/package.json +14 -11
  67. package/src/app/Scaffold.tsx +14 -15
  68. package/src/components/AIIcon.tsx +39 -0
  69. package/src/components/ArrayContainer.tsx +1 -4
  70. package/src/components/ClearFilterSortButton.tsx +19 -16
  71. package/src/components/ConfirmationDialog.tsx +0 -2
  72. package/src/components/DeleteEntityDialog.tsx +2 -4
  73. package/src/components/EntityCollectionTable/EntityCollectionRowActions.tsx +74 -41
  74. package/src/components/EntityCollectionTable/EntityCollectionTable.tsx +130 -79
  75. package/src/components/EntityCollectionTable/EntityCollectionTableProps.tsx +121 -104
  76. package/src/components/EntityCollectionTable/PropertyTableCell.tsx +132 -103
  77. package/src/components/EntityCollectionTable/internal/CollectionTableToolbar.tsx +20 -42
  78. package/src/components/EntityCollectionTable/internal/EntityTableCell.tsx +90 -49
  79. package/src/components/EntityCollectionTable/internal/EntityTableCellActions.tsx +1 -1
  80. package/src/components/EntityCollectionTable/internal/popup_field/useDraggable.tsx +11 -11
  81. package/src/components/EntityCollectionView/Board.tsx +324 -0
  82. package/src/components/EntityCollectionView/BoardColumn.tsx +158 -0
  83. package/src/components/EntityCollectionView/BoardColumnTitle.tsx +45 -0
  84. package/src/components/EntityCollectionView/BoardSortableList.tsx +172 -0
  85. package/src/components/EntityCollectionView/EntityBoardCard.tsx +212 -0
  86. package/src/components/EntityCollectionView/EntityCard.tsx +235 -0
  87. package/src/components/EntityCollectionView/EntityCollectionBoardView.tsx +733 -0
  88. package/src/components/EntityCollectionView/EntityCollectionCardView.tsx +244 -0
  89. package/src/components/EntityCollectionView/EntityCollectionView.tsx +519 -203
  90. package/src/components/EntityCollectionView/EntityCollectionViewActions.tsx +31 -19
  91. package/src/components/EntityCollectionView/EntityCollectionViewStartActions.tsx +84 -15
  92. package/src/components/EntityCollectionView/FiltersDialog.tsx +249 -0
  93. package/src/components/EntityCollectionView/ViewModeToggle.tsx +199 -0
  94. package/src/components/EntityCollectionView/board_types.ts +113 -0
  95. package/src/components/EntityCollectionView/useBoardDataController.tsx +490 -0
  96. package/src/components/ErrorTooltip.tsx +2 -1
  97. package/src/components/HomePage/DefaultHomePage.tsx +47 -10
  98. package/src/components/HomePage/HomePageDnD.tsx +56 -41
  99. package/src/components/HomePage/NavigationCard.tsx +20 -18
  100. package/src/components/HomePage/NavigationGroup.tsx +17 -16
  101. package/src/components/HomePage/RenameGroupDialog.tsx +0 -2
  102. package/src/components/HomePage/SmallNavigationCard.tsx +10 -9
  103. package/src/components/ReferenceTable/ReferenceSelectionTable.tsx +3 -10
  104. package/src/components/ReferenceWidget.tsx +2 -4
  105. package/src/components/SelectableTable/SelectableTable.tsx +75 -67
  106. package/src/components/SelectableTable/filters/BooleanFilterField.tsx +7 -6
  107. package/src/components/SelectableTable/filters/DateTimeFilterField.tsx +39 -40
  108. package/src/components/SelectableTable/filters/ReferenceFilterField.tsx +38 -38
  109. package/src/components/SelectableTable/filters/StringNumberFilterField.tsx +49 -58
  110. package/src/components/UnsavedChangesDialog.tsx +0 -2
  111. package/src/components/UserDisplay.tsx +4 -4
  112. package/src/components/VirtualTable/VirtualTable.tsx +272 -118
  113. package/src/components/VirtualTable/VirtualTableCell.tsx +18 -2
  114. package/src/components/VirtualTable/VirtualTableHeader.tsx +59 -50
  115. package/src/components/VirtualTable/VirtualTableHeaderRow.tsx +158 -42
  116. package/src/components/VirtualTable/VirtualTableProps.tsx +14 -1
  117. package/src/components/VirtualTable/VirtualTableRow.tsx +1 -1
  118. package/src/components/VirtualTable/fields/VirtualTableDateField.tsx +3 -0
  119. package/src/components/VirtualTable/fields/VirtualTableSelect.tsx +19 -6
  120. package/src/components/VirtualTable/types.tsx +2 -0
  121. package/src/components/common/useColumnsIds.tsx +95 -3
  122. package/src/components/index.tsx +4 -0
  123. package/src/contexts/BreacrumbsContext.tsx +15 -8
  124. package/src/contexts/index.ts +10 -0
  125. package/src/core/DefaultAppBar.tsx +40 -27
  126. package/src/core/DefaultDrawer.tsx +42 -56
  127. package/src/core/DrawerNavigationGroup.tsx +118 -0
  128. package/src/core/DrawerNavigationItem.tsx +4 -3
  129. package/src/core/EntityEditView.tsx +41 -43
  130. package/src/core/EntitySidePanel.tsx +28 -26
  131. package/src/core/SideDialogs.tsx +4 -2
  132. package/src/core/field_configs.tsx +14 -9
  133. package/src/core/index.tsx +1 -0
  134. package/src/form/EntityForm.tsx +69 -60
  135. package/src/form/PropertyFieldBinding.tsx +61 -46
  136. package/src/form/components/ErrorFocus.tsx +3 -3
  137. package/src/form/components/StorageItemPreview.tsx +2 -1
  138. package/src/form/field_bindings/ArrayOfReferencesFieldBinding.tsx +0 -1
  139. package/src/form/field_bindings/DateTimeFieldBinding.tsx +17 -16
  140. package/src/form/field_bindings/KeyValueFieldBinding.tsx +0 -1
  141. package/src/form/field_bindings/MapFieldBinding.tsx +69 -67
  142. package/src/form/field_bindings/MarkdownEditorFieldBinding.tsx +22 -18
  143. package/src/form/field_bindings/StorageUploadFieldBinding.tsx +83 -83
  144. package/src/form/field_bindings/TextFieldBinding.tsx +71 -35
  145. package/src/form/validation.ts +245 -160
  146. package/src/hooks/useBreadcrumbsController.tsx +18 -0
  147. package/src/hooks/useBuildNavigationController.tsx +46 -23
  148. package/src/hooks/useCollapsedGroups.ts +12 -4
  149. package/src/hooks/useValidateAuthenticator.tsx +1 -1
  150. package/src/internal/useBuildDataSource.ts +68 -34
  151. package/src/internal/useBuildSideDialogsController.tsx +11 -8
  152. package/src/internal/useBuildSideEntityController.tsx +2 -4
  153. package/src/internal/useRestoreScroll.tsx +26 -14
  154. package/src/preview/PropertyPreview.tsx +41 -32
  155. package/src/preview/PropertyPreviewProps.tsx +6 -0
  156. package/src/preview/components/DatePreview.tsx +72 -4
  157. package/src/preview/components/EmptyValue.tsx +1 -1
  158. package/src/preview/components/ImagePreview.tsx +37 -21
  159. package/src/preview/components/StorageThumbnail.tsx +16 -12
  160. package/src/preview/components/UrlComponentPreview.tsx +28 -25
  161. package/src/preview/property_previews/ArrayOfStorageComponentsPreview.tsx +9 -7
  162. package/src/preview/property_previews/ArrayOfStringsPreview.tsx +11 -9
  163. package/src/preview/property_previews/ArrayPropertyPreview.tsx +26 -24
  164. package/src/preview/property_previews/SkeletonPropertyComponent.tsx +61 -56
  165. package/src/routes/CustomCMSRoute.tsx +1 -0
  166. package/src/routes/FireCMSRoute.tsx +26 -13
  167. package/src/types/analytics.ts +10 -0
  168. package/src/types/collections.ts +57 -3
  169. package/src/types/datasource.ts +54 -56
  170. package/src/types/plugins.tsx +69 -1
  171. package/src/types/properties.ts +347 -27
  172. package/src/util/__tests__/conditions.test.ts +506 -0
  173. package/src/util/__tests__/objects.test.ts +196 -0
  174. package/src/util/callbacks.ts +6 -3
  175. package/src/util/collections.ts +51 -6
  176. package/src/util/conditions.ts +339 -0
  177. package/src/util/entities.ts +29 -30
  178. package/src/util/entity_cache.ts +2 -1
  179. package/src/util/index.ts +2 -1
  180. package/src/util/join_collections.ts +10 -8
  181. package/src/util/objects.ts +31 -13
  182. package/src/util/{references.ts → previews.ts} +16 -2
  183. package/src/util/property_utils.tsx +37 -11
  184. package/src/util/resolutions.ts +62 -58
  185. /package/dist/util/{references.d.ts → previews.d.ts} +0 -0
@@ -0,0 +1,199 @@
1
+ import React, { useMemo } from "react";
2
+ import { CollectionSize, ViewMode } from "../../types";
3
+ import {
4
+ AppsIcon,
5
+ Button,
6
+ ListIcon,
7
+ Popover,
8
+ Select,
9
+ SelectItem,
10
+ ToggleButtonGroup,
11
+ ToggleButtonOption,
12
+ ViewColumnIcon,
13
+ ViewKanbanIcon
14
+ } from "@firecms/ui";
15
+
16
+ export type KanbanPropertyOption = {
17
+ key: string;
18
+ label: string;
19
+ };
20
+
21
+ export type ViewModeToggleProps = {
22
+ viewMode?: ViewMode;
23
+ onViewModeChange?: (mode: ViewMode) => void;
24
+ /**
25
+ * Which view modes are enabled for this collection.
26
+ * Only these modes will appear in the toggle.
27
+ * Defaults to all three: ["table", "cards", "kanban"].
28
+ */
29
+ enabledViews?: ViewMode[];
30
+ /**
31
+ * Current size for card/table views
32
+ */
33
+ size?: CollectionSize;
34
+ /**
35
+ * Callback when size changes
36
+ */
37
+ onSizeChanged?: (size: CollectionSize) => void;
38
+ /**
39
+ * Controlled open state for the popover
40
+ */
41
+ open?: boolean;
42
+ /**
43
+ * Callback when popover open state changes
44
+ */
45
+ onOpenChange?: (open: boolean) => void;
46
+ /**
47
+ * Available properties that can be used for kanban columns (enum properties)
48
+ */
49
+ kanbanPropertyOptions?: KanbanPropertyOption[];
50
+ /**
51
+ * Currently selected property for kanban columns
52
+ */
53
+ selectedKanbanProperty?: string;
54
+ /**
55
+ * Callback when the kanban column property changes
56
+ */
57
+ onKanbanPropertyChange?: (property: string) => void;
58
+ }
59
+
60
+ const ALL_VIEW_MODES: ViewMode[] = ["table", "cards", "kanban"];
61
+
62
+ export function ViewModeToggle({
63
+ viewMode = "table",
64
+ onViewModeChange,
65
+ enabledViews = ALL_VIEW_MODES,
66
+ size,
67
+ onSizeChanged,
68
+ open,
69
+ onOpenChange,
70
+ kanbanPropertyOptions,
71
+ selectedKanbanProperty,
72
+ onKanbanPropertyChange
73
+ }: ViewModeToggleProps) {
74
+
75
+ if (!onViewModeChange) {
76
+ return null;
77
+ }
78
+
79
+ // Get icon for current view mode
80
+ const getViewModeIcon = () => {
81
+ if (viewMode === "kanban") return <ViewKanbanIcon size="small" />;
82
+ if (viewMode === "cards") return <AppsIcon size="small" />;
83
+ return <ListIcon size="small" />;
84
+ };
85
+
86
+ const getViewModeName = () => {
87
+ if (viewMode === "kanban") return "Board";
88
+ if (viewMode === "cards") return "Cards";
89
+ return "List";
90
+ };
91
+
92
+ const showSizeSelector = size && onSizeChanged && (viewMode === "table" || viewMode === "cards");
93
+ const showKanbanPropertySelector = viewMode === "kanban" &&
94
+ kanbanPropertyOptions &&
95
+ kanbanPropertyOptions.length > 0 &&
96
+ onKanbanPropertyChange;
97
+
98
+ // Build toggle options based on enabledViews
99
+ const viewModeOptions: ToggleButtonOption<ViewMode>[] = useMemo(() => {
100
+ const allOptions: ToggleButtonOption<ViewMode>[] = [
101
+ {
102
+ value: "table",
103
+ label: "List",
104
+ icon: <ListIcon size="small" />
105
+ },
106
+ {
107
+ value: "cards",
108
+ label: "Cards",
109
+ icon: <AppsIcon size="small" />
110
+ },
111
+ {
112
+ value: "kanban",
113
+ label: "Board",
114
+ icon: <ViewKanbanIcon size="small" />
115
+ }
116
+ ];
117
+
118
+ return allOptions.filter(option => enabledViews.includes(option.value));
119
+ }, [enabledViews]);
120
+
121
+ // Don't render if only one view is enabled
122
+ if (viewModeOptions.length <= 1 && !showSizeSelector) {
123
+ return null;
124
+ }
125
+
126
+ return (
127
+ <Popover
128
+ open={open}
129
+ onOpenChange={onOpenChange}
130
+ modal={true}
131
+ trigger={
132
+ <Button size="small">
133
+ {getViewModeIcon()}
134
+ <span className="ml-1 text-sm">{getViewModeName()}</span>
135
+ </Button>
136
+ }
137
+ >
138
+ <div className="p-3 flex flex-col gap-3 min-w-[240px]">
139
+ {/* View mode toggle using ToggleButtonGroup */}
140
+ {viewModeOptions.length > 1 && (
141
+ <ToggleButtonGroup
142
+ value={viewMode}
143
+ onValueChange={onViewModeChange}
144
+ options={viewModeOptions}
145
+ />
146
+ )}
147
+
148
+ {/* Size selector */}
149
+ {showSizeSelector && (
150
+ <div className="flex flex-row items-center justify-between gap-2">
151
+ <div className="flex items-center gap-2 text-sm text-surface-600 dark:text-surface-300">
152
+ <ViewColumnIcon size="small" />
153
+ <span>Size</span>
154
+ </div>
155
+ <Select
156
+ value={size}
157
+ size="small"
158
+ className="w-20"
159
+ onValueChange={(v) => onSizeChanged?.(v as CollectionSize)}
160
+ renderValue={(v) => <span className="font-medium">{v.toUpperCase()}</span>}
161
+ >
162
+ {["xs", "s", "m", "l", "xl"].map((s) => (
163
+ <SelectItem key={s} value={s} className="font-medium text-center">
164
+ {s.toUpperCase()}
165
+ </SelectItem>
166
+ ))}
167
+ </Select>
168
+ </div>
169
+ )}
170
+
171
+ {/* Kanban column property selector */}
172
+ {showKanbanPropertySelector && (
173
+ <div className="flex flex-row items-center justify-between gap-2">
174
+ <div className="flex items-center gap-2 text-sm text-surface-600 dark:text-surface-300">
175
+ <ViewKanbanIcon size="small" />
176
+ <span>Group by</span>
177
+ </div>
178
+ <Select
179
+ value={selectedKanbanProperty}
180
+ size="small"
181
+ className="w-32"
182
+ onValueChange={(v) => onKanbanPropertyChange?.(v)}
183
+ renderValue={(v) => {
184
+ const option = kanbanPropertyOptions?.find(o => o.key === v);
185
+ return <span className="font-medium truncate">{option?.label ?? v}</span>;
186
+ }}
187
+ >
188
+ {kanbanPropertyOptions?.map((option) => (
189
+ <SelectItem key={option.key} value={option.key}>
190
+ {option.label}
191
+ </SelectItem>
192
+ ))}
193
+ </Select>
194
+ </div>
195
+ )}
196
+ </div>
197
+ </Popover>
198
+ );
199
+ }
@@ -0,0 +1,113 @@
1
+ import { CSSProperties } from "react";
2
+ import { ChipColorKey, ChipColorScheme } from "@firecms/ui";
3
+ import { Entity } from "../../types";
4
+
5
+ /**
6
+ * Item wrapper for entities in the Board component
7
+ */
8
+ export interface BoardItem<M extends Record<string, any> = any> {
9
+ id: string;
10
+ entity: Entity<M>;
11
+ }
12
+
13
+ /**
14
+ * Map of column keys to arrays of board items
15
+ */
16
+ export interface BoardItemMap<M extends Record<string, any> = any> {
17
+ [columnKey: string]: BoardItem<M>[];
18
+ }
19
+
20
+ /**
21
+ * Props passed to custom item render components
22
+ */
23
+ export interface BoardItemViewProps<M extends Record<string, any> = any> {
24
+ item: BoardItem<M>;
25
+ isDragging: boolean;
26
+ isClone?: boolean;
27
+ isGroupedOver?: boolean;
28
+ style?: CSSProperties;
29
+ index?: number;
30
+ }
31
+
32
+ /**
33
+ * Per-column loading state
34
+ */
35
+ export interface ColumnLoadingState {
36
+ [columnKey: string]: {
37
+ loading: boolean;
38
+ hasMore: boolean;
39
+ itemCount: number;
40
+ /** Total count of entities in column (may differ from itemCount if some lack orderProperty) */
41
+ totalCount?: number;
42
+ };
43
+ }
44
+
45
+ /**
46
+ * Props for the Board component
47
+ */
48
+ export interface BoardProps<M extends Record<string, any>, COLUMN extends string> {
49
+ /**
50
+ * Array of board items (entities wrapped with id)
51
+ */
52
+ data: BoardItem<M>[];
53
+ /**
54
+ * Array of column keys/identifiers
55
+ */
56
+ columns: COLUMN[];
57
+ /**
58
+ * Labels for each column (optional, uses column key if not provided)
59
+ */
60
+ columnLabels?: Record<COLUMN, string>;
61
+ /**
62
+ * Colors for each column from enum values (optional)
63
+ */
64
+ columnColors?: Record<COLUMN, ChipColorKey | ChipColorScheme | undefined>;
65
+ /**
66
+ * CSS class name for the board container
67
+ */
68
+ className?: string;
69
+ /**
70
+ * Function to determine which column an item belongs to
71
+ */
72
+ assignColumn: (item: BoardItem<M>) => COLUMN;
73
+ /**
74
+ * Whether column reordering is allowed.
75
+ * Set to true only when a plugin provides persistence for column order.
76
+ */
77
+ allowColumnReorder?: boolean;
78
+ /**
79
+ * Callback when columns are reordered
80
+ */
81
+ onColumnReorder?: (columns: COLUMN[]) => void;
82
+ /**
83
+ * Callback when items are reordered or moved between columns
84
+ */
85
+ onItemsReorder?: (
86
+ items: BoardItem<M>[],
87
+ moveInfo?: {
88
+ itemId: string;
89
+ sourceColumn: COLUMN;
90
+ targetColumn: COLUMN;
91
+ }
92
+ ) => void;
93
+ /**
94
+ * Component to render individual items
95
+ */
96
+ ItemComponent: React.ComponentType<BoardItemViewProps<M>>;
97
+ /**
98
+ * Per-column loading state for pagination
99
+ */
100
+ columnLoadingState?: ColumnLoadingState;
101
+ /**
102
+ * Callback to load more items for a column
103
+ */
104
+ onLoadMoreColumn?: (column: COLUMN) => void;
105
+ /**
106
+ * Callback to add a new item to a specific column
107
+ */
108
+ onAddItemToColumn?: (column: COLUMN) => void;
109
+ /**
110
+ * Optional component to render at the end of the board for adding new columns
111
+ */
112
+ AddColumnComponent?: React.ReactNode;
113
+ }