@dxos/plugin-kanban 0.8.4-main.7ace549 → 0.8.4-main.8baae0fced

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