@dxos/plugin-kanban 0.8.4-main.fd6878d → 0.9.0

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 (275) hide show
  1. package/LICENSE +102 -5
  2. package/PLUGIN.mdl +398 -0
  3. package/README.md +1 -1
  4. package/dist/lib/neutral/KanbanArticle-T4CPKAZH.mjs +132 -0
  5. package/dist/lib/neutral/KanbanArticle-T4CPKAZH.mjs.map +7 -0
  6. package/dist/lib/neutral/KanbanPlugin.mjs +44 -0
  7. package/dist/lib/neutral/KanbanPlugin.mjs.map +7 -0
  8. package/dist/lib/neutral/KanbanPlugin.node.mjs +27 -0
  9. package/dist/lib/neutral/KanbanPlugin.node.mjs.map +7 -0
  10. package/dist/lib/neutral/KanbanPlugin.workerd.mjs +21 -0
  11. package/dist/lib/neutral/KanbanPlugin.workerd.mjs.map +7 -0
  12. package/dist/lib/neutral/KanbanSettings-5WOS4CUE.mjs +83 -0
  13. package/dist/lib/neutral/KanbanSettings-5WOS4CUE.mjs.map +7 -0
  14. package/dist/lib/neutral/blueprint-definition-6DV3Q5MC.mjs +15 -0
  15. package/dist/lib/neutral/blueprint-definition-6DV3Q5MC.mjs.map +7 -0
  16. package/dist/lib/neutral/blueprints/index.mjs +8 -0
  17. package/dist/lib/neutral/capabilities/index.mjs +17 -0
  18. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  19. package/dist/lib/neutral/chunk-6ZHHQWO5.mjs +39 -0
  20. package/dist/lib/neutral/chunk-6ZHHQWO5.mjs.map +7 -0
  21. package/dist/lib/neutral/chunk-DAKIZO46.mjs +246 -0
  22. package/dist/lib/neutral/chunk-DAKIZO46.mjs.map +7 -0
  23. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  24. package/dist/lib/neutral/chunk-M5ISZWZU.mjs +8 -0
  25. package/dist/lib/neutral/chunk-M5ISZWZU.mjs.map +7 -0
  26. package/dist/lib/neutral/chunk-ZTQW5KQS.mjs +26 -0
  27. package/dist/lib/neutral/chunk-ZTQW5KQS.mjs.map +7 -0
  28. package/dist/lib/neutral/components/index.mjs +243 -0
  29. package/dist/lib/neutral/components/index.mjs.map +7 -0
  30. package/dist/lib/neutral/containers/index.mjs +11 -0
  31. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  32. package/dist/lib/neutral/create-object-DKBSI46K.mjs +40 -0
  33. package/dist/lib/neutral/create-object-DKBSI46K.mjs.map +7 -0
  34. package/dist/lib/neutral/delete-card-VNAV3CZV.mjs +24 -0
  35. package/dist/lib/neutral/delete-card-VNAV3CZV.mjs.map +7 -0
  36. package/dist/lib/neutral/delete-card-field-XHOLGS6L.mjs +39 -0
  37. package/dist/lib/neutral/delete-card-field-XHOLGS6L.mjs.map +7 -0
  38. package/dist/lib/neutral/hooks/index.mjs +431 -0
  39. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  40. package/dist/lib/neutral/index.mjs +34 -0
  41. package/dist/lib/neutral/index.mjs.map +7 -0
  42. package/dist/lib/neutral/meta.json +1 -0
  43. package/dist/lib/neutral/meta.mjs +8 -0
  44. package/dist/lib/neutral/meta.mjs.map +7 -0
  45. package/dist/lib/neutral/operation-handler-B7IW6MXU.mjs +13 -0
  46. package/dist/lib/neutral/operation-handler-B7IW6MXU.mjs.map +7 -0
  47. package/dist/lib/neutral/operations/index.mjs +8 -0
  48. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  49. package/dist/lib/neutral/plugin.mjs +16 -0
  50. package/dist/lib/neutral/plugin.mjs.map +7 -0
  51. package/dist/lib/neutral/react-surface-VZEVEJL5.mjs +91 -0
  52. package/dist/lib/neutral/react-surface-VZEVEJL5.mjs.map +7 -0
  53. package/dist/lib/neutral/restore-card-EKVEPATL.mjs +21 -0
  54. package/dist/lib/neutral/restore-card-EKVEPATL.mjs.map +7 -0
  55. package/dist/lib/neutral/restore-card-field-TQCTGGNO.mjs +37 -0
  56. package/dist/lib/neutral/restore-card-field-TQCTGGNO.mjs.map +7 -0
  57. package/dist/lib/neutral/testing/index.mjs +62 -0
  58. package/dist/lib/neutral/testing/index.mjs.map +7 -0
  59. package/dist/lib/neutral/translations.mjs +44 -0
  60. package/dist/lib/neutral/translations.mjs.map +7 -0
  61. package/dist/lib/neutral/types/index.mjs +22 -0
  62. package/dist/lib/neutral/types/index.mjs.map +7 -0
  63. package/dist/lib/neutral/undo-mappings-6CHW6BOF.mjs +42 -0
  64. package/dist/lib/neutral/undo-mappings-6CHW6BOF.mjs.map +7 -0
  65. package/dist/types/src/KanbanPlugin.d.ts +3 -1
  66. package/dist/types/src/KanbanPlugin.d.ts.map +1 -1
  67. package/dist/types/src/KanbanPlugin.node.d.ts +4 -0
  68. package/dist/types/src/KanbanPlugin.node.d.ts.map +1 -0
  69. package/dist/types/src/KanbanPlugin.test.d.ts +2 -0
  70. package/dist/types/src/KanbanPlugin.test.d.ts.map +1 -0
  71. package/dist/types/src/KanbanPlugin.workerd.d.ts +4 -0
  72. package/dist/types/src/KanbanPlugin.workerd.d.ts.map +1 -0
  73. package/dist/types/src/blueprints/index.d.ts +2 -0
  74. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  75. package/dist/types/src/blueprints/kanban-blueprint.d.ts +4 -0
  76. package/dist/types/src/blueprints/kanban-blueprint.d.ts.map +1 -0
  77. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -2
  78. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  79. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  80. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  81. package/dist/types/src/capabilities/create-object.d.ts +11 -0
  82. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  83. package/dist/types/src/capabilities/index.d.ts +13 -2
  84. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  86. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  87. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  88. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/undo-mappings.d.ts +5 -0
  90. package/dist/types/src/capabilities/undo-mappings.d.ts.map +1 -0
  91. package/dist/types/src/components/KanbanBoard/KanbanBoard.d.ts +37 -0
  92. package/dist/types/src/components/KanbanBoard/KanbanBoard.d.ts.map +1 -0
  93. package/dist/types/src/components/KanbanBoard/KanbanBoard.stories.d.ts +72 -0
  94. package/dist/types/src/components/KanbanBoard/KanbanBoard.stories.d.ts.map +1 -0
  95. package/dist/types/src/components/KanbanBoard/KanbanCard.d.ts +9 -0
  96. package/dist/types/src/components/KanbanBoard/KanbanCard.d.ts.map +1 -0
  97. package/dist/types/src/components/KanbanBoard/KanbanColumn.d.ts +8 -0
  98. package/dist/types/src/components/KanbanBoard/KanbanColumn.d.ts.map +1 -0
  99. package/dist/types/src/components/KanbanBoard/context.d.ts +38 -0
  100. package/dist/types/src/components/KanbanBoard/context.d.ts.map +1 -0
  101. package/dist/types/src/components/KanbanBoard/index.d.ts +2 -0
  102. package/dist/types/src/components/KanbanBoard/index.d.ts.map +1 -0
  103. package/dist/types/src/components/index.d.ts +1 -2
  104. package/dist/types/src/components/index.d.ts.map +1 -1
  105. package/dist/types/src/containers/KanbanArticle/KanbanArticle.d.ts +6 -0
  106. package/dist/types/src/containers/KanbanArticle/KanbanArticle.d.ts.map +1 -0
  107. package/dist/types/src/containers/KanbanArticle/KanbanArticle.stories.d.ts +79 -0
  108. package/dist/types/src/containers/KanbanArticle/KanbanArticle.stories.d.ts.map +1 -0
  109. package/dist/types/src/containers/KanbanArticle/index.d.ts +2 -0
  110. package/dist/types/src/containers/KanbanArticle/index.d.ts.map +1 -0
  111. package/dist/types/src/containers/KanbanSettings/KanbanSettings.d.ts +13 -0
  112. package/dist/types/src/containers/KanbanSettings/KanbanSettings.d.ts.map +1 -0
  113. package/dist/types/src/containers/KanbanSettings/index.d.ts +2 -0
  114. package/dist/types/src/containers/KanbanSettings/index.d.ts.map +1 -0
  115. package/dist/types/src/containers/index.d.ts +4 -0
  116. package/dist/types/src/containers/index.d.ts.map +1 -0
  117. package/dist/types/src/hooks/index.d.ts +7 -0
  118. package/dist/types/src/hooks/index.d.ts.map +1 -0
  119. package/dist/types/src/hooks/useEchoChangeCallback.d.ts +13 -0
  120. package/dist/types/src/hooks/useEchoChangeCallback.d.ts.map +1 -0
  121. package/dist/types/src/hooks/useItemsProjection.d.ts +10 -0
  122. package/dist/types/src/hooks/useItemsProjection.d.ts.map +1 -0
  123. package/dist/types/src/hooks/useKanbanBoardModel.browser.test.d.ts +2 -0
  124. package/dist/types/src/hooks/useKanbanBoardModel.browser.test.d.ts.map +1 -0
  125. package/dist/types/src/hooks/useKanbanBoardModel.d.ts +16 -0
  126. package/dist/types/src/hooks/useKanbanBoardModel.d.ts.map +1 -0
  127. package/dist/types/src/hooks/useKanbanColumnEventHandler.d.ts +22 -0
  128. package/dist/types/src/hooks/useKanbanColumnEventHandler.d.ts.map +1 -0
  129. package/dist/types/src/hooks/useKanbanItemEventHandler.d.ts +19 -0
  130. package/dist/types/src/hooks/useKanbanItemEventHandler.d.ts.map +1 -0
  131. package/dist/types/src/hooks/useProjectionModel.d.ts +15 -0
  132. package/dist/types/src/hooks/useProjectionModel.d.ts.map +1 -0
  133. package/dist/types/src/index.d.ts +3 -1
  134. package/dist/types/src/index.d.ts.map +1 -1
  135. package/dist/types/src/meta.d.ts +2 -3
  136. package/dist/types/src/meta.d.ts.map +1 -1
  137. package/dist/types/src/operations/delete-card-field.d.ts +5 -0
  138. package/dist/types/src/operations/delete-card-field.d.ts.map +1 -0
  139. package/dist/types/src/operations/delete-card.d.ts +5 -0
  140. package/dist/types/src/operations/delete-card.d.ts.map +1 -0
  141. package/dist/types/src/operations/index.d.ts +3 -0
  142. package/dist/types/src/operations/index.d.ts.map +1 -0
  143. package/dist/types/src/operations/restore-card-field.d.ts +5 -0
  144. package/dist/types/src/operations/restore-card-field.d.ts.map +1 -0
  145. package/dist/types/src/operations/restore-card.d.ts +5 -0
  146. package/dist/types/src/operations/restore-card.d.ts.map +1 -0
  147. package/dist/types/src/playwright/board-manager.d.ts +5 -0
  148. package/dist/types/src/playwright/board-manager.d.ts.map +1 -0
  149. package/dist/types/src/playwright/playwright.config.d.ts +3 -0
  150. package/dist/types/src/playwright/playwright.config.d.ts.map +1 -0
  151. package/dist/types/src/playwright/smoke.spec.d.ts +2 -0
  152. package/dist/types/src/playwright/smoke.spec.d.ts.map +1 -0
  153. package/dist/types/src/plugin.d.ts +4 -0
  154. package/dist/types/src/plugin.d.ts.map +1 -0
  155. package/dist/types/src/testing/KanbanCardTileSimple.d.ts +7 -0
  156. package/dist/types/src/testing/KanbanCardTileSimple.d.ts.map +1 -0
  157. package/dist/types/src/testing/index.d.ts +2 -0
  158. package/dist/types/src/testing/index.d.ts.map +1 -0
  159. package/dist/types/src/translations.d.ts +50 -22
  160. package/dist/types/src/translations.d.ts.map +1 -1
  161. package/dist/types/src/types/Kanban.d.ts +94 -0
  162. package/dist/types/src/types/Kanban.d.ts.map +1 -0
  163. package/dist/types/src/types/KanbanOperation.d.ts +52 -0
  164. package/dist/types/src/types/KanbanOperation.d.ts.map +1 -0
  165. package/dist/types/src/types/constants.d.ts +6 -0
  166. package/dist/types/src/types/constants.d.ts.map +1 -0
  167. package/dist/types/src/types/index.d.ts +3 -1
  168. package/dist/types/src/types/index.d.ts.map +1 -1
  169. package/dist/types/src/types/schema.d.ts +18 -95
  170. package/dist/types/src/types/schema.d.ts.map +1 -1
  171. package/dist/types/src/types/types.d.ts +28 -0
  172. package/dist/types/src/types/types.d.ts.map +1 -1
  173. package/dist/types/src/util/arrangement.d.ts +72 -0
  174. package/dist/types/src/util/arrangement.d.ts.map +1 -0
  175. package/dist/types/src/util/arrangement.test.d.ts +2 -0
  176. package/dist/types/src/util/arrangement.test.d.ts.map +1 -0
  177. package/dist/types/src/util/index.d.ts +2 -0
  178. package/dist/types/src/util/index.d.ts.map +1 -0
  179. package/dist/types/tsconfig.tsbuildinfo +1 -1
  180. package/package.json +127 -55
  181. package/src/KanbanPlugin.node.ts +21 -0
  182. package/src/KanbanPlugin.test.ts +31 -0
  183. package/src/KanbanPlugin.tsx +24 -52
  184. package/src/KanbanPlugin.workerd.ts +18 -0
  185. package/src/blueprints/index.ts +5 -0
  186. package/src/blueprints/kanban-blueprint.ts +27 -0
  187. package/src/capabilities/artifact-definition.ts +119 -114
  188. package/src/capabilities/blueprint-definition.ts +19 -0
  189. package/src/capabilities/create-object.ts +40 -0
  190. package/src/capabilities/index.ts +16 -3
  191. package/src/capabilities/operation-handler.ts +14 -0
  192. package/src/capabilities/react-surface.tsx +90 -69
  193. package/src/capabilities/undo-mappings.ts +34 -0
  194. package/src/components/KanbanBoard/KanbanBoard.stories.tsx +145 -0
  195. package/src/components/KanbanBoard/KanbanBoard.tsx +164 -0
  196. package/src/components/KanbanBoard/KanbanCard.tsx +101 -0
  197. package/src/components/KanbanBoard/KanbanColumn.tsx +72 -0
  198. package/src/components/KanbanBoard/context.ts +54 -0
  199. package/src/components/KanbanBoard/index.ts +5 -0
  200. package/src/components/index.ts +1 -2
  201. package/src/containers/KanbanArticle/KanbanArticle.stories.tsx +277 -0
  202. package/src/containers/KanbanArticle/KanbanArticle.tsx +179 -0
  203. package/src/containers/KanbanArticle/index.ts +5 -0
  204. package/src/containers/KanbanSettings/KanbanSettings.tsx +94 -0
  205. package/src/containers/KanbanSettings/index.ts +5 -0
  206. package/src/containers/index.ts +8 -0
  207. package/src/hooks/index.ts +10 -0
  208. package/src/hooks/useEchoChangeCallback.ts +30 -0
  209. package/src/hooks/useItemsProjection.ts +44 -0
  210. package/src/hooks/useKanbanBoardModel.browser.test.ts +230 -0
  211. package/src/hooks/useKanbanBoardModel.ts +156 -0
  212. package/src/hooks/useKanbanColumnEventHandler.ts +106 -0
  213. package/src/hooks/useKanbanItemEventHandler.ts +133 -0
  214. package/src/hooks/useProjectionModel.ts +58 -0
  215. package/src/index.ts +3 -2
  216. package/src/meta.ts +27 -8
  217. package/src/operations/delete-card-field.ts +42 -0
  218. package/src/operations/delete-card.ts +23 -0
  219. package/src/operations/index.ts +10 -0
  220. package/src/operations/restore-card-field.ts +36 -0
  221. package/src/operations/restore-card.ts +21 -0
  222. package/src/playwright/board-manager.ts +13 -0
  223. package/src/playwright/playwright.config.ts +19 -0
  224. package/src/playwright/smoke.spec.ts +107 -0
  225. package/src/plugin.ts +11 -0
  226. package/src/testing/KanbanCardTileSimple.tsx +82 -0
  227. package/src/testing/index.ts +5 -0
  228. package/src/translations.ts +28 -20
  229. package/src/types/Kanban.ts +134 -0
  230. package/src/types/KanbanOperation.ts +79 -0
  231. package/src/types/constants.ts +9 -0
  232. package/src/types/index.ts +4 -1
  233. package/src/types/schema.ts +33 -45
  234. package/src/types/types.ts +35 -0
  235. package/src/util/arrangement.test.ts +217 -0
  236. package/src/util/arrangement.ts +177 -0
  237. package/src/util/index.ts +5 -0
  238. package/src/vite-env.d.ts +10 -0
  239. package/dist/lib/browser/chunk-5BR6HNHI.mjs +0 -108
  240. package/dist/lib/browser/chunk-5BR6HNHI.mjs.map +0 -7
  241. package/dist/lib/browser/index.mjs +0 -99
  242. package/dist/lib/browser/index.mjs.map +0 -7
  243. package/dist/lib/browser/intent-resolver-65UVYRI2.mjs +0 -111
  244. package/dist/lib/browser/intent-resolver-65UVYRI2.mjs.map +0 -7
  245. package/dist/lib/browser/meta.json +0 -1
  246. package/dist/lib/browser/react-surface-KX5U6PJ2.mjs +0 -256
  247. package/dist/lib/browser/react-surface-KX5U6PJ2.mjs.map +0 -7
  248. package/dist/lib/browser/types/index.mjs +0 -13
  249. package/dist/lib/node-esm/chunk-WLFZKRIJ.mjs +0 -110
  250. package/dist/lib/node-esm/chunk-WLFZKRIJ.mjs.map +0 -7
  251. package/dist/lib/node-esm/index.mjs +0 -100
  252. package/dist/lib/node-esm/index.mjs.map +0 -7
  253. package/dist/lib/node-esm/intent-resolver-R3MYQATZ.mjs +0 -112
  254. package/dist/lib/node-esm/intent-resolver-R3MYQATZ.mjs.map +0 -7
  255. package/dist/lib/node-esm/meta.json +0 -1
  256. package/dist/lib/node-esm/react-surface-BAMERRU5.mjs +0 -257
  257. package/dist/lib/node-esm/react-surface-BAMERRU5.mjs.map +0 -7
  258. package/dist/lib/node-esm/types/index.mjs +0 -14
  259. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  260. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  261. package/dist/types/src/components/KanbanContainer.d.ts +0 -7
  262. package/dist/types/src/components/KanbanContainer.d.ts.map +0 -1
  263. package/dist/types/src/components/KanbanContainer.stories.d.ts +0 -10
  264. package/dist/types/src/components/KanbanContainer.stories.d.ts.map +0 -1
  265. package/dist/types/src/components/KanbanViewEditor.d.ts +0 -8
  266. package/dist/types/src/components/KanbanViewEditor.d.ts.map +0 -1
  267. package/dist/types/src/types/kanban.d.ts +0 -11
  268. package/dist/types/src/types/kanban.d.ts.map +0 -1
  269. package/src/capabilities/intent-resolver.ts +0 -70
  270. package/src/components/KanbanContainer.stories.tsx +0 -189
  271. package/src/components/KanbanContainer.tsx +0 -95
  272. package/src/components/KanbanViewEditor.tsx +0 -60
  273. package/src/types/kanban.ts +0 -29
  274. /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
  275. /package/dist/lib/{node-esm/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
@@ -1,189 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type Meta, type StoryObj } from '@storybook/react-vite';
8
- import React, { useCallback, useEffect, useState } from 'react';
9
-
10
- import { IntentPlugin, SettingsPlugin } from '@dxos/app-framework';
11
- import { withPluginManager } from '@dxos/app-framework/testing';
12
- import { Obj, Type } from '@dxos/echo';
13
- import { invariant } from '@dxos/invariant';
14
- import { ClientPlugin } from '@dxos/plugin-client';
15
- import { PreviewPlugin } from '@dxos/plugin-preview';
16
- import { useGlobalFilteredObjects } from '@dxos/plugin-search';
17
- import { SpacePlugin } from '@dxos/plugin-space';
18
- import { StorybookLayoutPlugin } from '@dxos/plugin-storybook-layout';
19
- import { ThemePlugin } from '@dxos/plugin-theme';
20
- import { faker } from '@dxos/random';
21
- import { useClient } from '@dxos/react-client';
22
- import { Filter, useQuery, useSchema, useSpaces } from '@dxos/react-client/echo';
23
- import { ViewEditor } from '@dxos/react-ui-form';
24
- import { Kanban, KanbanView, useKanbanModel } from '@dxos/react-ui-kanban';
25
- import { SyntaxHighlighter } from '@dxos/react-ui-syntax-highlighter';
26
- import { defaultTx } from '@dxos/react-ui-theme';
27
- import { DataType, ProjectionModel } from '@dxos/schema';
28
- import { withLayout } from '@dxos/storybook-utils';
29
-
30
- import { translations } from '../translations';
31
- import { createKanban } from '../types';
32
-
33
- faker.seed(0);
34
-
35
- //
36
- // Story components.
37
- //
38
-
39
- const rollOrg = () => ({
40
- name: faker.commerce.productName(),
41
- description: faker.lorem.paragraph(),
42
- image: faker.image.url(),
43
- website: faker.internet.url(),
44
- status: faker.helpers.arrayElement(DataType.OrganizationStatusOptions).id as DataType.Organization['status'],
45
- });
46
-
47
- const StorybookKanban = () => {
48
- const client = useClient();
49
- const spaces = useSpaces();
50
- const space = spaces[spaces.length - 1];
51
- const views = useQuery(space, Filter.type(DataType.View));
52
- const [view, setView] = useState<DataType.View>();
53
- const [projection, setProjection] = useState<ProjectionModel>();
54
- const schema = useSchema(client, space, view?.query.typename);
55
-
56
- useEffect(() => {
57
- if (views.length && !view) {
58
- const view = views[0];
59
- setView(view);
60
- }
61
- }, [views]);
62
-
63
- useEffect(() => {
64
- if (view?.projection && schema) {
65
- const jsonSchema = Type.toJsonSchema(schema);
66
- setProjection(new ProjectionModel(jsonSchema, view.projection));
67
- }
68
- // TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?
69
- // @dmaretskyi? Once resolved, update in multiple places (e.g., storybooks).
70
- }, [view?.projection, schema, JSON.stringify(schema ? Type.toJsonSchema(schema) : {})]);
71
-
72
- const objects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());
73
- const filteredObjects = useGlobalFilteredObjects(objects);
74
-
75
- const model = useKanbanModel({
76
- view,
77
- schema,
78
- projection,
79
- items: filteredObjects,
80
- });
81
-
82
- const handleAddCard = useCallback(
83
- (columnValue: string | undefined) => {
84
- const path = model?.columnFieldPath;
85
- if (space && schema && path) {
86
- const card = Obj.make(schema, {
87
- ...rollOrg(),
88
- [path]: columnValue,
89
- });
90
-
91
- space.db.add(card);
92
- return card.id;
93
- }
94
- },
95
- [space, schema, model],
96
- );
97
-
98
- const handleRemoveCard = useCallback((card: { id: string }) => space.db.remove(card), [space]);
99
-
100
- const handleTypenameChanged = useCallback(
101
- (typename: string) => {
102
- invariant(schema);
103
- invariant(Type.isMutable(schema));
104
- invariant(view);
105
-
106
- schema.updateTypename(typename);
107
- view.query.typename = typename;
108
- },
109
- [view, schema],
110
- );
111
-
112
- if (!schema || !view) {
113
- return null;
114
- }
115
-
116
- return (
117
- <div className='grow grid grid-cols-[1fr_350px]'>
118
- {model ? <Kanban model={model} onAddCard={handleAddCard} onRemoveCard={handleRemoveCard} /> : <div />}
119
- <div className='flex flex-col bs-full border-is border-separator overflow-y-auto'>
120
- <ViewEditor
121
- registry={space?.db.schemaRegistry}
122
- schema={schema}
123
- view={view}
124
- onTypenameChanged={handleTypenameChanged}
125
- onDelete={(fieldId: string) => {
126
- console.log('[ViewEditor]', 'onDelete', fieldId);
127
- }}
128
- />
129
- <SyntaxHighlighter language='json' className='w-full text-xs'>
130
- {JSON.stringify({ view, schema }, null, 2)}
131
- </SyntaxHighlighter>
132
- </div>
133
- </div>
134
- );
135
- };
136
-
137
- type StoryProps = {
138
- rows?: number;
139
- };
140
-
141
- //
142
- // Story definitions.
143
- //
144
-
145
- const meta: Meta<StoryProps> = {
146
- title: 'plugins/plugin-kanban/Kanban',
147
- component: StorybookKanban,
148
- render: () => <StorybookKanban />,
149
- parameters: { translations },
150
- decorators: [
151
- withLayout({ fullscreen: true }),
152
- withPluginManager({
153
- plugins: [
154
- ThemePlugin({ tx: defaultTx }),
155
- ClientPlugin({
156
- types: [DataType.Organization, DataType.Person, DataType.View, KanbanView],
157
- onClientInitialized: async ({ client }) => {
158
- await client.halo.createIdentity();
159
- const space = await client.spaces.create();
160
- await space.waitUntilReady();
161
- const { view } = await createKanban({
162
- client,
163
- space,
164
- typename: DataType.Organization.typename,
165
- initialPivotColumn: 'status',
166
- });
167
- space.db.add(view);
168
-
169
- // TODO(burdon): Replace with sdk/schema/testing.
170
- Array.from({ length: 80 }).map(() => {
171
- return space.db.add(Obj.make(DataType.Organization, rollOrg()));
172
- });
173
- },
174
- }),
175
- StorybookLayoutPlugin(),
176
- PreviewPlugin(),
177
- SpacePlugin(),
178
- IntentPlugin(),
179
- SettingsPlugin(),
180
- ],
181
- }),
182
- ],
183
- };
184
-
185
- export default meta;
186
-
187
- type Story = StoryObj<StoryProps>;
188
-
189
- export const Default: Story = {};
@@ -1,95 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import React, { useCallback, useEffect, useMemo, useState } from 'react';
6
-
7
- import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
8
- import { Filter, Obj, Type } from '@dxos/echo';
9
- import { EchoSchema, type TypedObject } from '@dxos/echo-schema';
10
- import { useGlobalFilteredObjects } from '@dxos/plugin-search';
11
- import { useClient } from '@dxos/react-client';
12
- import { getSpace, useQuery } from '@dxos/react-client/echo';
13
- import { Kanban, useKanbanModel } from '@dxos/react-ui-kanban';
14
- import { StackItem } from '@dxos/react-ui-stack';
15
- import { type DataType, ProjectionModel } from '@dxos/schema';
16
-
17
- import { KanbanAction } from '../types';
18
-
19
- export const KanbanContainer = ({ view }: { view: DataType.View; role: string }) => {
20
- const client = useClient();
21
- const [cardSchema, setCardSchema] = useState<TypedObject<any, any>>();
22
- const [projection, setProjection] = useState<ProjectionModel>();
23
- const space = getSpace(view);
24
- const { dispatchPromise: dispatch } = useIntentDispatcher();
25
-
26
- const jsonSchema = useMemo(() => {
27
- if (!cardSchema) {
28
- return undefined;
29
- }
30
- return cardSchema instanceof EchoSchema ? cardSchema.jsonSchema : Type.toJsonSchema(cardSchema);
31
- }, [cardSchema]);
32
-
33
- useEffect(() => {
34
- const typename = view.query.typename;
35
- const staticSchema = client.graph.schemaRegistry.schemas.find((schema) => Type.getTypename(schema) === typename);
36
- if (staticSchema) {
37
- setCardSchema(() => staticSchema as TypedObject<any, any>);
38
- }
39
- if (!staticSchema && typename && space) {
40
- const query = space.db.schemaRegistry.query({ typename });
41
- const unsubscribe = query.subscribe(
42
- () => {
43
- const [schema] = query.results;
44
- if (schema) {
45
- setCardSchema(schema);
46
- }
47
- },
48
- { fire: true },
49
- );
50
- return unsubscribe;
51
- }
52
- }, [view.query.typename, space]);
53
-
54
- useEffect(() => {
55
- if (jsonSchema) {
56
- setProjection(new ProjectionModel(jsonSchema, view.projection));
57
- }
58
- // TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?
59
- }, [view.projection, JSON.stringify(jsonSchema)]);
60
-
61
- const objects = useQuery(space, cardSchema ? Filter.type(cardSchema) : Filter.nothing());
62
- const filteredObjects = useGlobalFilteredObjects(objects);
63
-
64
- const model = useKanbanModel({
65
- view,
66
- schema: cardSchema,
67
- projection,
68
- items: filteredObjects,
69
- });
70
-
71
- const handleAddCard = useCallback(
72
- (columnValue: string | undefined) => {
73
- const path = model?.columnFieldPath;
74
- if (space && cardSchema && path) {
75
- const card = Obj.make(cardSchema, { [path]: columnValue });
76
- space.db.add(card);
77
- return card.id;
78
- }
79
- },
80
- [space, cardSchema, model],
81
- );
82
-
83
- const handleRemoveCard = useCallback(
84
- (card: { id: string }) => {
85
- void dispatch(createIntent(KanbanAction.DeleteCard, { card }));
86
- },
87
- [dispatch],
88
- );
89
-
90
- return (
91
- <StackItem.Content>
92
- {model && <Kanban model={model} onAddCard={handleAddCard} onRemoveCard={handleRemoveCard} />}
93
- </StackItem.Content>
94
- );
95
- };
@@ -1,60 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import React, { useCallback, useMemo } from 'react';
6
-
7
- import { Type } from '@dxos/echo';
8
- import { EchoSchema, FormatEnum } from '@dxos/echo-schema';
9
- import { useClient } from '@dxos/react-client';
10
- import { getSpace, useSchema } from '@dxos/react-client/echo';
11
- import { type CustomInputMap, Form, SelectInput } from '@dxos/react-ui-form';
12
- import { KanbanSettingsSchema, type KanbanView } from '@dxos/react-ui-kanban';
13
- import { type DataType, ProjectionModel } from '@dxos/schema';
14
-
15
- type KanbanViewEditorProps = { view: DataType.View };
16
-
17
- export const KanbanViewEditor = ({ view }: KanbanViewEditorProps) => {
18
- const client = useClient();
19
- const space = getSpace(view);
20
- const kanban = view.presentation.target as KanbanView;
21
- const currentTypename = useMemo(() => view.query.typename, [view.query.typename]);
22
- const schema = useSchema(client, space, currentTypename);
23
-
24
- const projection = useMemo(() => {
25
- if (schema) {
26
- const jsonSchema = schema instanceof EchoSchema ? schema.jsonSchema : Type.toJsonSchema(schema);
27
- return new ProjectionModel(jsonSchema, view.projection);
28
- }
29
- }, [view.projection, JSON.stringify(schema)]);
30
-
31
- const fieldProjections = projection?.getFieldProjections() || [];
32
- const selectFields = fieldProjections
33
- .filter((field) => field.props.format === FormatEnum.SingleSelect)
34
- .map(({ field }) => ({ value: field.id, label: field.path }));
35
-
36
- const handleSave = useCallback(
37
- (values: Partial<{ columnFieldId: string }>) => {
38
- kanban.columnFieldId = values.columnFieldId;
39
- },
40
- [kanban],
41
- );
42
-
43
- const initialValues = useMemo(() => ({ columnFieldId: kanban.columnFieldId }), [kanban.columnFieldId]);
44
- const custom: CustomInputMap = useMemo(
45
- () => ({ columnFieldId: (props) => <SelectInput {...props} options={selectFields} /> }),
46
- [selectFields],
47
- );
48
-
49
- return (
50
- <Form
51
- Custom={custom}
52
- schema={KanbanSettingsSchema}
53
- values={initialValues}
54
- onSave={handleSave}
55
- autoSave
56
- outerSpacing={false}
57
- classNames='pbs-inputSpacingBlock'
58
- />
59
- );
60
- };
@@ -1,29 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { Obj } from '@dxos/echo';
6
- import { type JsonSchemaType } from '@dxos/echo-schema';
7
- import { KanbanView } from '@dxos/react-ui-kanban';
8
- import { type CreateViewFromSpaceProps, type DataType, ProjectionModel, createViewFromSpace } from '@dxos/schema';
9
-
10
- type InitializeKanbanProps = Omit<CreateViewFromSpaceProps, 'presentation'> & {
11
- initialPivotColumn?: string;
12
- };
13
-
14
- export const createKanban = async ({
15
- initialPivotColumn,
16
- ...props
17
- }: InitializeKanbanProps): Promise<{ jsonSchema: JsonSchemaType; view: DataType.View }> => {
18
- const kanban = Obj.make(KanbanView, { columnFieldId: undefined });
19
- const { jsonSchema, view } = await createViewFromSpace({ ...props, presentation: kanban });
20
- if (initialPivotColumn) {
21
- const projection = new ProjectionModel(jsonSchema, view.projection);
22
- const fieldId = projection.getFieldId(initialPivotColumn);
23
- if (fieldId) {
24
- kanban.columnFieldId = fieldId;
25
- }
26
- }
27
-
28
- return { jsonSchema, view };
29
- };