@dxos/plugin-markdown 0.8.4-main.f5c0578 → 0.8.4-main.fcfe5033a5

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 (333) hide show
  1. package/dist/lib/browser/MarkdownSettings-62YSRY7L.mjs +32 -0
  2. package/dist/lib/browser/MarkdownSettings-62YSRY7L.mjs.map +7 -0
  3. package/dist/lib/browser/blueprints/index.mjs +51 -0
  4. package/dist/lib/browser/blueprints/index.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-4KOZEH2H.mjs +121 -0
  6. package/dist/lib/browser/chunk-4KOZEH2H.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  8. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-QFPZONKP.mjs +158 -0
  10. package/dist/lib/browser/chunk-QFPZONKP.mjs.map +7 -0
  11. package/dist/lib/browser/cli/index.mjs +39 -0
  12. package/dist/lib/browser/cli/index.mjs.map +7 -0
  13. package/dist/lib/browser/create-YL5ELZWP.mjs +30 -0
  14. package/dist/lib/browser/create-YL5ELZWP.mjs.map +7 -0
  15. package/dist/lib/browser/create-markdown-LU5IDKMH.mjs +22 -0
  16. package/dist/lib/browser/create-markdown-LU5IDKMH.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +612 -138
  18. package/dist/lib/browser/index.mjs.map +4 -4
  19. package/dist/lib/browser/meta.json +1 -1
  20. package/dist/lib/browser/open-AFSOZZ6G.mjs +21 -0
  21. package/dist/lib/browser/open-AFSOZZ6G.mjs.map +7 -0
  22. package/dist/lib/browser/operations/index.mjs +14 -0
  23. package/dist/lib/browser/operations/index.mjs.map +7 -0
  24. package/dist/lib/browser/scroll-to-anchor-IPXV32A6.mjs +49 -0
  25. package/dist/lib/browser/scroll-to-anchor-IPXV32A6.mjs.map +7 -0
  26. package/dist/lib/browser/set-view-mode-2QWB24RR.mjs +26 -0
  27. package/dist/lib/browser/set-view-mode-2QWB24RR.mjs.map +7 -0
  28. package/dist/lib/browser/types/index.mjs +11 -5
  29. package/dist/lib/browser/update-HZNVYBMO.mjs +45 -0
  30. package/dist/lib/browser/update-HZNVYBMO.mjs.map +7 -0
  31. package/dist/lib/node-esm/MarkdownSettings-QMPISOEU.mjs +33 -0
  32. package/dist/lib/node-esm/MarkdownSettings-QMPISOEU.mjs.map +7 -0
  33. package/dist/lib/node-esm/blueprints/index.mjs +52 -0
  34. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  35. package/dist/lib/node-esm/chunk-3OPDJJJH.mjs +122 -0
  36. package/dist/lib/node-esm/chunk-3OPDJJJH.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  38. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  39. package/dist/lib/node-esm/chunk-JUGS6RKO.mjs +159 -0
  40. package/dist/lib/node-esm/chunk-JUGS6RKO.mjs.map +7 -0
  41. package/dist/lib/node-esm/cli/index.mjs +40 -0
  42. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  43. package/dist/lib/node-esm/create-SMQAIM3V.mjs +31 -0
  44. package/dist/lib/node-esm/create-SMQAIM3V.mjs.map +7 -0
  45. package/dist/lib/node-esm/create-markdown-X2OASYKG.mjs +23 -0
  46. package/dist/lib/node-esm/create-markdown-X2OASYKG.mjs.map +7 -0
  47. package/dist/lib/node-esm/index.mjs +612 -138
  48. package/dist/lib/node-esm/index.mjs.map +4 -4
  49. package/dist/lib/node-esm/meta.json +1 -1
  50. package/dist/lib/node-esm/open-SRWLLOKE.mjs +22 -0
  51. package/dist/lib/node-esm/open-SRWLLOKE.mjs.map +7 -0
  52. package/dist/lib/node-esm/operations/index.mjs +15 -0
  53. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  54. package/dist/lib/node-esm/scroll-to-anchor-M76GXKYQ.mjs +50 -0
  55. package/dist/lib/node-esm/scroll-to-anchor-M76GXKYQ.mjs.map +7 -0
  56. package/dist/lib/node-esm/set-view-mode-6BB6KIDS.mjs +27 -0
  57. package/dist/lib/node-esm/set-view-mode-6BB6KIDS.mjs.map +7 -0
  58. package/dist/lib/node-esm/types/index.mjs +11 -5
  59. package/dist/lib/node-esm/update-4CELTLXK.mjs +46 -0
  60. package/dist/lib/node-esm/update-4CELTLXK.mjs.map +7 -0
  61. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  62. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  63. package/dist/types/src/blueprints/index.d.ts +2 -0
  64. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  65. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  66. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  67. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  68. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  70. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  71. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -9
  72. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  74. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  75. package/dist/types/src/capabilities/index.d.ts +9 -15
  76. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/node.d.ts +4 -0
  78. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  80. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  81. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  82. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/settings.d.ts +4 -2
  84. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/state.d.ts +4 -9
  86. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  87. package/dist/types/src/cli/index.d.ts +2 -0
  88. package/dist/types/src/cli/index.d.ts.map +1 -0
  89. package/dist/types/src/cli/plugin.d.ts +3 -0
  90. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  91. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  92. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  93. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +44 -21
  94. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  95. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
  96. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +32 -0
  98. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  99. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +13 -0
  100. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  101. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  102. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  103. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  104. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  105. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  106. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  107. package/dist/types/src/components/index.d.ts +3 -3
  108. package/dist/types/src/components/index.d.ts.map +1 -1
  109. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  110. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  111. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  112. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  113. package/dist/types/src/containers/MarkdownCard/index.d.ts +2 -0
  114. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  115. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  116. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  117. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  118. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  119. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +77 -0
  120. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  121. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  122. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  123. package/dist/types/src/containers/index.d.ts +5 -0
  124. package/dist/types/src/containers/index.d.ts.map +1 -0
  125. package/dist/types/src/hooks/index.d.ts +3 -1
  126. package/dist/types/src/hooks/index.d.ts.map +1 -1
  127. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  128. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  129. package/dist/types/src/hooks/useExtensions.d.ts +24 -0
  130. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  131. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  132. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  133. package/dist/types/src/index.d.ts +3 -2
  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/create-markdown.d.ts +5 -0
  138. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  139. package/dist/types/src/operations/create.d.ts +5 -0
  140. package/dist/types/src/operations/create.d.ts.map +1 -0
  141. package/dist/types/src/operations/create.test.d.ts +2 -0
  142. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  143. package/dist/types/src/operations/definitions.d.ts +64 -0
  144. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  145. package/dist/types/src/operations/index.d.ts +4 -0
  146. package/dist/types/src/operations/index.d.ts.map +1 -0
  147. package/dist/types/src/operations/open.d.ts +5 -0
  148. package/dist/types/src/operations/open.d.ts.map +1 -0
  149. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  150. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  151. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  152. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  153. package/dist/types/src/operations/update.d.ts +5 -0
  154. package/dist/types/src/operations/update.d.ts.map +1 -0
  155. package/dist/types/src/operations/update.test.d.ts +2 -0
  156. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  157. package/dist/types/src/testing.d.ts +6 -0
  158. package/dist/types/src/testing.d.ts.map +1 -0
  159. package/dist/types/src/translations.d.ts +53 -30
  160. package/dist/types/src/translations.d.ts.map +1 -1
  161. package/dist/types/src/types/Markdown.d.ts +31 -30
  162. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  163. package/dist/types/src/types/Settings.d.ts +17 -0
  164. package/dist/types/src/types/Settings.d.ts.map +1 -0
  165. package/dist/types/src/types/capabilities.d.ts +33 -0
  166. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  167. package/dist/types/src/types/events.d.ts +5 -0
  168. package/dist/types/src/types/events.d.ts.map +1 -0
  169. package/dist/types/src/types/index.d.ts +4 -2
  170. package/dist/types/src/types/index.d.ts.map +1 -1
  171. package/dist/types/src/types/types.d.ts +2 -2
  172. package/dist/types/src/types/types.d.ts.map +1 -1
  173. package/dist/types/src/util.d.ts +7 -4
  174. package/dist/types/src/util.d.ts.map +1 -1
  175. package/dist/types/src/util.test.d.ts +2 -0
  176. package/dist/types/src/util.test.d.ts.map +1 -0
  177. package/dist/types/tsconfig.tsbuildinfo +1 -1
  178. package/package.json +122 -56
  179. package/src/MarkdownPlugin.tsx +89 -100
  180. package/src/blueprints/index.ts +5 -0
  181. package/src/blueprints/markdown-blueprint.ts +44 -0
  182. package/src/capabilities/anchor-sort.ts +29 -22
  183. package/src/capabilities/app-graph-serializer.ts +55 -44
  184. package/src/capabilities/artifact-definition.ts +86 -95
  185. package/src/capabilities/blueprint-definition.ts +17 -0
  186. package/src/capabilities/index.ts +12 -9
  187. package/src/capabilities/node.ts +11 -0
  188. package/src/capabilities/operation-handler.ts +16 -0
  189. package/src/capabilities/react-surface.tsx +110 -104
  190. package/src/capabilities/settings.ts +30 -18
  191. package/src/capabilities/state.ts +41 -25
  192. package/src/cli/index.ts +5 -0
  193. package/src/cli/plugin.ts +39 -0
  194. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  195. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +63 -38
  196. package/src/components/MarkdownEditor/MarkdownEditor.tsx +251 -267
  197. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +170 -0
  198. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -0
  199. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +39 -0
  200. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -92
  201. package/src/components/MarkdownSettings/index.ts +1 -1
  202. package/src/components/index.ts +4 -5
  203. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +67 -0
  204. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  205. package/src/containers/MarkdownCard/index.ts +5 -0
  206. package/src/containers/MarkdownCard/snippet.ts +52 -0
  207. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  208. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +145 -0
  209. package/src/containers/MarkdownContainer/index.ts +6 -0
  210. package/src/containers/index.ts +10 -0
  211. package/src/hooks/index.ts +3 -1
  212. package/src/hooks/useEditorMenuOptions.ts +68 -0
  213. package/src/hooks/useExtensions.tsx +264 -0
  214. package/src/hooks/useLinkQuery.ts +108 -0
  215. package/src/index.ts +4 -2
  216. package/src/meta.ts +6 -9
  217. package/src/operations/create-markdown.ts +20 -0
  218. package/src/operations/create.conversations.json +1 -0
  219. package/src/operations/create.test.ts +98 -0
  220. package/src/operations/create.ts +27 -0
  221. package/src/operations/definitions.ts +120 -0
  222. package/src/operations/index.ts +16 -0
  223. package/src/operations/open.ts +25 -0
  224. package/src/operations/scroll-to-anchor.ts +39 -0
  225. package/src/operations/set-view-mode.ts +24 -0
  226. package/src/operations/update.conversations.json +1 -0
  227. package/src/operations/update.test.ts +215 -0
  228. package/src/operations/update.ts +51 -0
  229. package/src/testing.ts +27 -0
  230. package/src/translations.ts +26 -31
  231. package/src/types/Markdown.ts +26 -31
  232. package/src/types/Settings.ts +65 -0
  233. package/src/types/capabilities.ts +50 -0
  234. package/src/types/events.ts +14 -0
  235. package/src/types/index.ts +5 -2
  236. package/src/types/types.ts +4 -2
  237. package/src/util.test.ts +44 -0
  238. package/src/util.tsx +83 -8
  239. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs +0 -80
  240. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs.map +0 -7
  241. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs +0 -780
  242. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs.map +0 -7
  243. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs +0 -32
  244. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs.map +0 -7
  245. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs +0 -52
  246. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs.map +0 -7
  247. package/dist/lib/browser/chunk-IKPZHFTW.mjs +0 -30
  248. package/dist/lib/browser/chunk-IKPZHFTW.mjs.map +0 -7
  249. package/dist/lib/browser/chunk-JHH7VL52.mjs +0 -18
  250. package/dist/lib/browser/chunk-JHH7VL52.mjs.map +0 -7
  251. package/dist/lib/browser/chunk-JMBQG2ZC.mjs +0 -50
  252. package/dist/lib/browser/chunk-JMBQG2ZC.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-JTIGSUMB.mjs +0 -80
  254. package/dist/lib/browser/chunk-JTIGSUMB.mjs.map +0 -7
  255. package/dist/lib/browser/chunk-LMJPXTPL.mjs +0 -16
  256. package/dist/lib/browser/chunk-LMJPXTPL.mjs.map +0 -7
  257. package/dist/lib/browser/chunk-MVL4K3OD.mjs +0 -52
  258. package/dist/lib/browser/chunk-MVL4K3OD.mjs.map +0 -7
  259. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs +0 -60
  260. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs.map +0 -7
  261. package/dist/lib/browser/react-surface-NL3BZR6H.mjs +0 -208
  262. package/dist/lib/browser/react-surface-NL3BZR6H.mjs.map +0 -7
  263. package/dist/lib/browser/settings-Z7ZV7SLC.mjs +0 -28
  264. package/dist/lib/browser/settings-Z7ZV7SLC.mjs.map +0 -7
  265. package/dist/lib/browser/state-ORTZIEJU.mjs +0 -37
  266. package/dist/lib/browser/state-ORTZIEJU.mjs.map +0 -7
  267. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs +0 -81
  268. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs.map +0 -7
  269. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs +0 -781
  270. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs.map +0 -7
  271. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs +0 -33
  272. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs.map +0 -7
  273. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs +0 -53
  274. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs.map +0 -7
  275. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs +0 -17
  276. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs.map +0 -7
  277. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs +0 -31
  278. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs.map +0 -7
  279. package/dist/lib/node-esm/chunk-H6TITL7A.mjs +0 -20
  280. package/dist/lib/node-esm/chunk-H6TITL7A.mjs.map +0 -7
  281. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs +0 -51
  282. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs.map +0 -7
  283. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs +0 -81
  284. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs.map +0 -7
  285. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs +0 -53
  286. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs.map +0 -7
  287. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs +0 -61
  288. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs.map +0 -7
  289. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs +0 -209
  290. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs.map +0 -7
  291. package/dist/lib/node-esm/settings-UCXEWBCT.mjs +0 -29
  292. package/dist/lib/node-esm/settings-UCXEWBCT.mjs.map +0 -7
  293. package/dist/lib/node-esm/state-47WSZG54.mjs +0 -38
  294. package/dist/lib/node-esm/state-47WSZG54.mjs.map +0 -7
  295. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  296. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  297. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  298. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  299. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -7
  300. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  301. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -42
  302. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  303. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  304. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  305. package/dist/types/src/components/MarkdownContainer.d.ts +0 -18
  306. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  307. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -9
  308. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  309. package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
  310. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  311. package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
  312. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  313. package/dist/types/src/events.d.ts +0 -4
  314. package/dist/types/src/events.d.ts.map +0 -1
  315. package/dist/types/src/extensions.d.ts +0 -24
  316. package/dist/types/src/extensions.d.ts.map +0 -1
  317. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  318. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  319. package/dist/types/src/types/MarkdownAction.d.ts +0 -42
  320. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  321. package/src/capabilities/capabilities.ts +0 -21
  322. package/src/capabilities/intent-resolver.ts +0 -58
  323. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -79
  324. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -75
  325. package/src/components/MarkdownCard/index.ts +0 -9
  326. package/src/components/MarkdownContainer.stories.tsx +0 -100
  327. package/src/components/MarkdownContainer.tsx +0 -255
  328. package/src/components/Suggestions.stories.tsx +0 -221
  329. package/src/components/Toolbar.stories.tsx +0 -112
  330. package/src/events.ts +0 -11
  331. package/src/extensions.tsx +0 -328
  332. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  333. package/src/types/MarkdownAction.ts +0 -31
@@ -5,115 +5,106 @@
5
5
  // ISSUE(burdon): defineArtifact
6
6
  // @ts-nocheck
7
7
 
8
- import { Schema, pipe } from 'effect';
8
+ import * as Effect from 'effect/Effect';
9
+ import * as Schema from 'effect/Schema';
9
10
 
10
11
  import { ToolResult, createTool } from '@dxos/ai';
11
- import { Capabilities, type PromiseIntentDispatcher, chain, contributes, createIntent } from '@dxos/app-framework';
12
+ import { Capabilities, Capability } from '@dxos/app-framework';
12
13
  import { ArtifactId, createArtifactElement } from '@dxos/assistant';
13
14
  import { defineArtifact } from '@dxos/blueprints';
14
15
  import { Obj } from '@dxos/echo';
15
16
  import { assertArgument, invariant } from '@dxos/invariant';
16
- import { SpaceAction } from '@dxos/plugin-space/types';
17
- import { Filter, type Space, fullyQualifiedId } from '@dxos/react-client/echo';
17
+ import { SpaceOperation } from '@dxos/plugin-space/operations';
18
+ import { Filter } from '@dxos/react-client/echo';
18
19
 
19
- import { meta } from '../meta';
20
- import { Markdown, MarkdownAction } from '../types';
20
+ import { meta } from '#meta';
21
+ import { Markdown } from '#types';
21
22
 
22
- // TODO(burdon): Factor out.
23
- declare global {
24
- interface ToolContextExtensions {
25
- space?: Space;
26
- dispatch?: PromiseIntentDispatcher;
27
- }
28
- }
29
-
30
- export default () => {
31
- const definition = defineArtifact({
32
- id: `artifact:${meta.id}`, // TODO(burdon): meta.id/artifact?
33
- name: meta.name,
34
- instructions: `
35
- - The markdown plugin allows you to work with text documents in the current space.
36
- - Use these tools to interact with documents, including listing available documents and retrieving their content.
37
- - Documents are stored in Markdown format.
23
+ export default Capability.makeModule(() =>
24
+ Effect.sync(() => {
25
+ const definition = defineArtifact({
26
+ id: `artifact:${meta.id}`, // TODO(burdon): meta.id/artifact?
27
+ name: meta.name,
28
+ instructions: `
29
+ The markdown plugin allows you to work with text documents in the current space.
30
+ Use these tools to interact with documents, including listing available documents and retrieving their content.
31
+ Documents are stored in Markdown format.
38
32
  `,
39
- schema: Markdown.Document,
40
- tools: [
41
- createTool(meta.id, {
42
- name: 'create',
43
- description: 'Create a new markdown document',
44
- caption: 'Creating document...',
45
- schema: Schema.Struct({
46
- name: Schema.optional(Schema.String).annotations({
47
- description: 'Optional name for the document.',
48
- }),
49
- content: Schema.String.annotations({
50
- description: 'The content of the document.',
33
+ schema: Markdown.Document,
34
+ tools: [
35
+ createTool(meta.id, {
36
+ name: 'create',
37
+ description: 'Create a new markdown document',
38
+ caption: 'Creating document...',
39
+ schema: Schema.Struct({
40
+ name: Schema.optional(Schema.String).annotations({
41
+ description: 'Optional name for the document.',
42
+ }),
43
+ content: Schema.String.annotations({
44
+ description: 'The content of the document.',
45
+ }),
51
46
  }),
52
- }),
53
- execute: async ({ name, content }, { extensions }) => {
54
- invariant(extensions?.space, 'No space');
55
- invariant(extensions?.dispatch, 'No intent dispatcher');
47
+ execute: async ({ name, content }, { extensions }) => {
48
+ invariant(extensions?.space, 'No space');
49
+ invariant(extensions?.invoke, 'No operation invoker');
56
50
 
57
- const intent = pipe(
58
- createIntent(MarkdownAction.Create, {
59
- spaceId: extensions.space.id,
60
- name,
61
- content,
62
- }),
63
- chain(SpaceAction.AddObject, { target: extensions.space }),
64
- );
51
+ const document = Markdown.make({ name, content });
65
52
 
66
- const { data, error } = await extensions.dispatch(intent);
67
- if (!data || error) {
68
- return ToolResult.Error(error?.message ?? 'Failed to create document');
69
- }
53
+ const { error } = await extensions.invoke(SpaceOperation.AddObject, {
54
+ target: extensions.space,
55
+ object: document,
56
+ });
57
+ if (error) {
58
+ return ToolResult.Error(error?.message ?? 'Failed to add document to space');
59
+ }
70
60
 
71
- return ToolResult.Success(createArtifactElement(data.id));
72
- },
73
- }),
74
- createTool(meta.id, {
75
- name: 'list',
76
- description: 'List all markdown documents in the current space.',
77
- caption: 'Listing markdown documents...',
78
- schema: Schema.Struct({}),
79
- execute: async (_input, { extensions }) => {
80
- invariant(extensions?.space, 'No space');
81
- const space = extensions.space;
82
- const { objects: documents } = await space.db.query(Filter.type(Markdown.Document)).run();
83
- const documentInfo = documents.map((doc) => {
84
- invariant(Obj.instanceOf(Markdown.Document, doc));
85
- return {
86
- id: fullyQualifiedId(doc),
87
- name: doc.name || doc.fallbackName || 'Unnamed Document',
88
- // TODO(ZaymonFC): Include updatedAt?
89
- };
90
- });
61
+ return ToolResult.Success(createArtifactElement(document.id));
62
+ },
63
+ }),
64
+ createTool(meta.id, {
65
+ name: 'list',
66
+ description: 'List all markdown documents in the current space.',
67
+ caption: 'Listing markdown documents...',
68
+ schema: Schema.Struct({}),
69
+ execute: async (_input, { extensions }) => {
70
+ invariant(extensions?.space, 'No space');
71
+ const space = extensions.space;
72
+ const { objects: documents } = await space.db.query(Filter.type(Markdown.Document)).run();
73
+ const documentInfo = documents.map((doc) => {
74
+ invariant(Obj.instanceOf(Markdown.Document, doc));
75
+ return {
76
+ id: Obj.getDXN(doc).toString(),
77
+ name: doc.name || doc.fallbackName || 'Unnamed Document',
78
+ // TODO(ZaymonFC): Include updatedAt?
79
+ };
80
+ });
91
81
 
92
- return ToolResult.Success(documentInfo);
93
- },
94
- }),
95
- createTool(meta.id, {
96
- name: 'inspect',
97
- description: 'Read the content of a markdown document.',
98
- caption: 'Inspecting markdown document...',
99
- schema: Schema.Struct({
100
- id: ArtifactId,
82
+ return ToolResult.Success(documentInfo);
83
+ },
101
84
  }),
102
- execute: async ({ id }, { extensions }) => {
103
- invariant(extensions?.space, 'No space');
104
- const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();
105
- assertArgument(Obj.instanceOf(Markdown.Document, document), 'Invalid type');
85
+ createTool(meta.id, {
86
+ name: 'inspect',
87
+ description: 'Read the content of a markdown document.',
88
+ caption: 'Inspecting markdown document...',
89
+ schema: Schema.Struct({
90
+ id: ArtifactId,
91
+ }),
92
+ execute: async ({ id }, { extensions }) => {
93
+ invariant(extensions?.space, 'No space');
94
+ const document = await extensions.space.db.query(Filter.id(ArtifactId.toDXN(id).toString())).first();
95
+ assertArgument(Obj.instanceOf(Markdown.Document, document), 'document', 'Invalid type');
106
96
 
107
- const { content } = await document.content?.load();
108
- return ToolResult.Success({
109
- id: fullyQualifiedId(document),
110
- name: document.name || document.fallbackName || 'Unnamed Document',
111
- content,
112
- });
113
- },
114
- }),
115
- ],
116
- });
97
+ const { content } = await document.content?.load();
98
+ return ToolResult.Success({
99
+ id: Obj.getDXN(document).toString(),
100
+ name: document.name || document.fallbackName || 'Unnamed Document',
101
+ content,
102
+ });
103
+ },
104
+ }),
105
+ ],
106
+ });
117
107
 
118
- return contributes(Capabilities.ArtifactDefinition, definition);
119
- };
108
+ return Capability.contributes(Capabilities.ArtifactDefinition, definition);
109
+ }),
110
+ );
@@ -0,0 +1,17 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { AppCapabilities } from '@dxos/app-toolkit';
9
+
10
+ import { MarkdownBlueprint } from '#blueprints';
11
+
12
+ const blueprintDefinition = Capability.makeModule<
13
+ [],
14
+ Capability.Capability<typeof AppCapabilities.BlueprintDefinition>[]
15
+ >(() => Effect.succeed([Capability.contributes(AppCapabilities.BlueprintDefinition, MarkdownBlueprint)]));
16
+
17
+ export default blueprintDefinition;
@@ -2,13 +2,16 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from '@dxos/app-framework';
5
+ import { Capability } from '@dxos/app-framework';
6
+ import { OperationHandlerSet } from '@dxos/operation';
6
7
 
7
- export const AnchorSort = lazy(() => import('./anchor-sort'));
8
- export const AppGraphSerializer = lazy(() => import('./app-graph-serializer'));
9
- export const IntentResolver = lazy(() => import('./intent-resolver'));
10
- export const ReactSurface = lazy(() => import('./react-surface'));
11
- export const MarkdownSettings = lazy(() => import('./settings'));
12
- export const MarkdownState = lazy(() => import('./state'));
13
-
14
- export * from './capabilities';
8
+ export const AnchorSort = Capability.lazy('AnchorSort', () => import('./anchor-sort'));
9
+ export const AppGraphSerializer = Capability.lazy('AppGraphSerializer', () => import('./app-graph-serializer'));
10
+ export const BlueprintDefinition = Capability.lazy('BlueprintDefinition', () => import('./blueprint-definition'));
11
+ export const OperationHandler = Capability.lazy<OperationHandlerSet.OperationHandlerSet>(
12
+ 'OperationHandler',
13
+ () => import('./operation-handler'),
14
+ );
15
+ export const ReactSurface = Capability.lazy('ReactSurface', () => import('./react-surface'));
16
+ export const MarkdownSettings = Capability.lazy('MarkdownSettings', () => import('./settings'));
17
+ export const MarkdownState = Capability.lazy('MarkdownState', () => import('./state'));
@@ -0,0 +1,11 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { Capability } from '@dxos/app-framework';
6
+ import { OperationHandlerSet } from '@dxos/operation';
7
+
8
+ export const OperationHandler = Capability.lazy<OperationHandlerSet.OperationHandlerSet>(
9
+ 'OperationHandler',
10
+ () => import('./operation-handler'),
11
+ );
@@ -0,0 +1,16 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capabilities, Capability } from '@dxos/app-framework';
8
+ import type { OperationHandlerSet } from '@dxos/operation';
9
+
10
+ import { MarkdownOperationHandlerSet } from '#operations';
11
+
12
+ export default Capability.makeModule<OperationHandlerSet.OperationHandlerSet>(
13
+ Effect.fnUntraced(function* () {
14
+ return Capability.contributes(Capabilities.OperationHandler, MarkdownOperationHandlerSet);
15
+ }),
16
+ );
@@ -2,114 +2,120 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import React from 'react';
5
+ import * as Effect from 'effect/Effect';
6
+ import React, { forwardRef, useCallback, useMemo } from 'react';
6
7
 
7
- import { Capabilities, contributes, createSurface, useCapability } from '@dxos/app-framework';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import {
10
+ Surface,
11
+ useAtomCapability,
12
+ useAtomCapabilityState,
13
+ useCapability,
14
+ useSettingsState,
15
+ } from '@dxos/app-framework/ui';
16
+ import { AppSurface } from '@dxos/app-toolkit/ui';
8
17
  import { Obj } from '@dxos/echo';
9
- import { SettingsStore } from '@dxos/local-storage';
10
- import { AttentionCapabilities } from '@dxos/plugin-attention';
11
- import { fullyQualifiedId } from '@dxos/react-client/echo';
12
- import { DataType } from '@dxos/schema';
18
+ import { AttentionCapabilities } from '@dxos/plugin-attention/types';
19
+ import { Text } from '@dxos/schema';
20
+ import { type EditorViewMode } from '@dxos/ui-editor';
13
21
 
14
- import { MarkdownCard, MarkdownContainer, MarkdownSettings } from '../components';
15
- import { meta } from '../meta';
16
- import { Markdown } from '../types';
17
- import { isEditorModel } from '../util';
22
+ import { MarkdownSettings } from '#components';
23
+ import { MarkdownCard, MarkdownContainer, type MarkdownContainerProps } from '#containers';
24
+ import { meta } from '#meta';
25
+ import { Markdown, MarkdownCapabilities } from '#types';
18
26
 
19
- import { MarkdownCapabilities } from './capabilities';
27
+ export default Capability.makeModule(() =>
28
+ Effect.succeed(
29
+ Capability.contributes(Capabilities.ReactSurface, [
30
+ Surface.create({
31
+ id: 'surface.document',
32
+ // TODO(wittjosiah): Split into multiple surfaces if this filter proves too strict for non-article roles.
33
+ role: ['article', 'section', 'tabpanel'],
34
+ filter: (data): data is { subject: Markdown.Document; attendableId: string; variant: undefined } =>
35
+ typeof data.attendableId === 'string' && Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
36
+ component: ({ data, role, ref }) => {
37
+ return (
38
+ <Container
39
+ id={Obj.getDXN(data.subject).toString()}
40
+ attendableId={data.attendableId}
41
+ subject={data.subject}
42
+ role={role}
43
+ ref={ref}
44
+ />
45
+ );
46
+ },
47
+ }),
48
+ Surface.create({
49
+ id: 'surface.text',
50
+ // TODO(wittjosiah): Split into multiple surfaces if this filter proves too strict for non-article roles.
51
+ // TODO(burdon): Why is attendableId required? See EventArticle.tsx
52
+ filter: AppSurface.oneOf(
53
+ AppSurface.object(AppSurface.Article, Text.Text),
54
+ AppSurface.object(AppSurface.Section, Text.Text),
55
+ AppSurface.object(AppSurface.Tabpanel, Text.Text),
56
+ ),
57
+ component: ({ data, role, ref }) => {
58
+ return (
59
+ <Container
60
+ id={Obj.getDXN(data.subject).toString()}
61
+ attendableId={data.attendableId}
62
+ subject={data.subject}
63
+ role={role}
64
+ ref={ref}
65
+ />
66
+ );
67
+ },
68
+ }),
69
+ Surface.create({
70
+ id: 'surface.plugin-settings',
71
+ filter: AppSurface.settings(AppSurface.Article, meta.id),
72
+ component: ({ data: { subject } }) => {
73
+ const { settings, updateSettings } = useSettingsState<Markdown.Settings>(subject.atom);
74
+ return <MarkdownSettings settings={settings} onSettingsChange={updateSettings} />;
75
+ },
76
+ }),
77
+ Surface.create({
78
+ id: 'surface.preview',
79
+ filter: AppSurface.object(AppSurface.Card, [Markdown.Document, Text.Text]),
80
+ component: ({ data }) => <MarkdownCard {...data} />,
81
+ }),
82
+ ]),
83
+ ),
84
+ );
20
85
 
21
- export default () =>
22
- contributes(Capabilities.ReactSurface, [
23
- createSurface({
24
- id: `${meta.id}/surface/document`,
25
- role: ['article', 'section', 'tabpanel'],
26
- filter: (data): data is { subject: Markdown.Document; variant: undefined } =>
27
- Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
28
- component: ({ data, role }) => {
29
- const selectionManager = useCapability(AttentionCapabilities.Selection);
30
- const settingsStore = useCapability(Capabilities.SettingsStore);
31
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
32
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
33
- const viewMode = getViewMode(fullyQualifiedId(data.subject));
86
+ /**
87
+ * Common wrapper.
88
+ */
89
+ const Container = forwardRef<
90
+ HTMLDivElement,
91
+ AppSurface.ObjectArticleProps<Markdown.Document | Text.Text, { id: string }>
92
+ >(({ id, attendableId, subject, role }, forwardedRef) => {
93
+ const selectionManager = useCapability(AttentionCapabilities.Selection);
94
+ const settings = useAtomCapability(MarkdownCapabilities.Settings);
95
+ const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
96
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
97
+ const extensions = useCapability(MarkdownCapabilities.Extensions);
98
+ const extensionProviders = useMemo(() => extensions.flat(), [extensions]);
34
99
 
35
- return (
36
- <MarkdownContainer
37
- id={fullyQualifiedId(data.subject)}
38
- object={data.subject}
39
- role={role}
40
- settings={settings}
41
- selectionManager={selectionManager}
42
- extensionProviders={state.extensionProviders}
43
- viewMode={viewMode}
44
- editorStateStore={editorState}
45
- onViewModeChange={setViewMode}
46
- />
47
- );
48
- },
49
- }),
50
- createSurface({
51
- id: `${meta.id}/surface/text`,
52
- role: ['article', 'section', 'tabpanel'],
53
- filter: (data): data is { id: string; subject: DataType.Text } =>
54
- typeof data.id === 'string' && Obj.instanceOf(DataType.Text, data.subject),
55
- component: ({ data, role }) => {
56
- const selectionManager = useCapability(AttentionCapabilities.Selection);
57
- const settingsStore = useCapability(Capabilities.SettingsStore);
58
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
59
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
100
+ const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';
101
+ const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(
102
+ (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),
103
+ [id, setState],
104
+ );
60
105
 
61
- return (
62
- <MarkdownContainer
63
- id={data.id}
64
- object={data.subject}
65
- role={role}
66
- settings={settings}
67
- selectionManager={selectionManager}
68
- extensionProviders={state.extensionProviders}
69
- viewMode={getViewMode(data.id)}
70
- editorStateStore={editorState}
71
- onViewModeChange={setViewMode}
72
- />
73
- );
74
- },
75
- }),
76
- createSurface({
77
- id: `${meta.id}/surface/editor`,
78
- role: ['article', 'section'],
79
- filter: (data): data is { subject: { id: string; text: string } } => isEditorModel(data.subject),
80
- component: ({ data, role }) => {
81
- const selectionManager = useCapability(AttentionCapabilities.Selection);
82
- const settingsStore = useCapability(Capabilities.SettingsStore);
83
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
84
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
85
-
86
- return (
87
- <MarkdownContainer
88
- id={data.subject.id}
89
- object={data.subject}
90
- role={role}
91
- settings={settings}
92
- selectionManager={selectionManager}
93
- extensionProviders={state.extensionProviders}
94
- viewMode={getViewMode(data.subject.id)}
95
- editorStateStore={editorState}
96
- onViewModeChange={setViewMode}
97
- />
98
- );
99
- },
100
- }),
101
- createSurface({
102
- id: `${meta.id}/surface/plugin-settings`,
103
- role: 'article',
104
- filter: (data): data is { subject: SettingsStore<Markdown.Settings> } =>
105
- data.subject instanceof SettingsStore && data.subject.prefix === meta.id,
106
- component: ({ data: { subject } }) => <MarkdownSettings settings={subject.value} />,
107
- }),
108
- createSurface({
109
- id: `${meta.id}/surface/preview`,
110
- role: ['card--popover', 'card--intrinsic', 'card--extrinsic', 'card--transclusion', 'card'],
111
- filter: (data): data is { subject: Markdown.Document | DataType.Text } =>
112
- Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(DataType.Text, data.subject),
113
- component: ({ data, role }) => <MarkdownCard {...data} role={role} />,
114
- }),
115
- ]);
106
+ return (
107
+ <MarkdownContainer
108
+ role={role}
109
+ subject={subject}
110
+ id={id}
111
+ attendableId={attendableId}
112
+ settings={settings}
113
+ selectionManager={selectionManager}
114
+ extensionProviders={extensionProviders}
115
+ editorStateStore={editorState}
116
+ viewMode={viewMode}
117
+ onViewModeChange={handleViewModeChange}
118
+ ref={forwardedRef}
119
+ />
120
+ );
121
+ });
@@ -2,24 +2,36 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, contributes } from '@dxos/app-framework';
6
- import { live } from '@dxos/live-object';
5
+ import * as Effect from 'effect/Effect';
7
6
 
8
- import { meta } from '../meta';
9
- import { Markdown } from '../types';
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { AppCapabilities } from '@dxos/app-toolkit';
9
+ import { createKvsStore } from '@dxos/effect';
10
10
 
11
- export default () => {
12
- const settings = live<Markdown.Settings>({
13
- defaultViewMode: 'preview',
14
- toolbar: true,
15
- numberedHeadings: true,
16
- folding: true,
17
- experimental: false,
18
- });
11
+ import { meta } from '#meta';
12
+ import { Markdown, MarkdownCapabilities } from '#types';
19
13
 
20
- return contributes(Capabilities.Settings, {
21
- prefix: meta.id,
22
- schema: Markdown.Settings,
23
- value: settings,
24
- });
25
- };
14
+ export default Capability.makeModule(() =>
15
+ Effect.sync(() => {
16
+ const settingsAtom = createKvsStore({
17
+ key: meta.id,
18
+ schema: Markdown.Settings,
19
+ defaultValue: () => ({
20
+ defaultViewMode: 'preview' as const,
21
+ toolbar: true,
22
+ numberedHeadings: true,
23
+ folding: true,
24
+ experimental: false,
25
+ }),
26
+ });
27
+
28
+ return [
29
+ Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),
30
+ Capability.contributes(AppCapabilities.Settings, {
31
+ prefix: meta.id,
32
+ schema: Markdown.Settings,
33
+ atom: settingsAtom,
34
+ }),
35
+ ];
36
+ }),
37
+ );
@@ -2,30 +2,46 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';
6
- import { LocalStorageStore } from '@dxos/local-storage';
7
- import { type EditorViewMode, createEditorStateStore } from '@dxos/react-ui-editor';
8
-
9
- import { meta } from '../meta';
10
- import { type Markdown, type MarkdownPluginState } from '../types';
11
-
12
- import { MarkdownCapabilities } from './capabilities';
13
-
14
- export default (context: PluginContext) => {
15
- const state = new LocalStorageStore<MarkdownPluginState>(meta.id, { extensionProviders: [], viewMode: {} });
16
- state.prop({ key: 'viewMode', type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>() });
17
-
18
- // TODO(wittjosiah): Fold into state.
19
- const editorState = createEditorStateStore(`${meta.id}/editor`);
20
-
21
- const getViewMode = (id: string) => {
22
- const defaultViewMode = context.getCapability(Capabilities.SettingsStore).getStore<Markdown.Settings>(meta.id)!
23
- .value.defaultViewMode;
24
- return (id && state.values.viewMode[id]) || defaultViewMode;
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { createKvsStore } from '@dxos/effect';
9
+ import { createEditorStateStore } from '@dxos/ui-editor';
10
+
11
+ import { meta } from '#meta';
12
+ import { type EditorViewEntry, type EditorViewRegistry, MarkdownCapabilities, MarkdownStateSchema } from '#types';
13
+
14
+ const createEditorViewRegistry = (): EditorViewRegistry => {
15
+ const views = new Map<string, EditorViewEntry>();
16
+ return {
17
+ register: (attendableId, view, documentId) => {
18
+ views.set(attendableId, { view, documentId });
19
+ },
20
+ unregister: (attendableId) => {
21
+ views.delete(attendableId);
22
+ },
23
+ get: (attendableId) => views.get(attendableId),
25
24
  };
26
-
27
- const setViewMode = (id: string, viewMode: EditorViewMode) => (state.values.viewMode[id] = viewMode);
28
-
29
- // Return object with methods.
30
- return contributes(MarkdownCapabilities.State, { state: state.values, editorState, getViewMode, setViewMode });
31
25
  };
26
+
27
+ export default Capability.makeModule(
28
+ Effect.fnUntraced(function* () {
29
+ // Persisted state using KVS store.
30
+ const stateAtom = createKvsStore({
31
+ key: `${meta.id}.state`,
32
+ schema: MarkdownStateSchema,
33
+ defaultValue: () => ({ viewMode: {} }),
34
+ });
35
+
36
+ // TODO(wittjosiah): Fold into state.
37
+ const editorState = createEditorStateStore(`${meta.id}.editor`);
38
+
39
+ const editorViews = createEditorViewRegistry();
40
+
41
+ return [
42
+ Capability.contributes(MarkdownCapabilities.State, stateAtom),
43
+ Capability.contributes(MarkdownCapabilities.EditorState, editorState),
44
+ Capability.contributes(MarkdownCapabilities.EditorViews, editorViews),
45
+ ];
46
+ }),
47
+ );
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './plugin';