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

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 (340) hide show
  1. package/dist/lib/browser/MarkdownSettings-YCTZJL5V.mjs +32 -0
  2. package/dist/lib/browser/MarkdownSettings-YCTZJL5V.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-5T3SYJIP.mjs +158 -0
  6. package/dist/lib/browser/chunk-5T3SYJIP.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-FG2ZL4PE.mjs +121 -0
  8. package/dist/lib/browser/chunk-FG2ZL4PE.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  10. package/dist/lib/browser/chunk-J5LGTIGS.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-VSHCHZS4.mjs +30 -0
  14. package/dist/lib/browser/create-VSHCHZS4.mjs.map +7 -0
  15. package/dist/lib/browser/create-markdown-6LRG62W3.mjs +22 -0
  16. package/dist/lib/browser/create-markdown-6LRG62W3.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +569 -140
  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-TKTPEN3D.mjs +21 -0
  21. package/dist/lib/browser/open-TKTPEN3D.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-HWERBJKN.mjs +49 -0
  25. package/dist/lib/browser/scroll-to-anchor-HWERBJKN.mjs.map +7 -0
  26. package/dist/lib/browser/set-view-mode-Z7HGT7TY.mjs +26 -0
  27. package/dist/lib/browser/set-view-mode-Z7HGT7TY.mjs.map +7 -0
  28. package/dist/lib/browser/translations.mjs +43 -0
  29. package/dist/lib/browser/translations.mjs.map +7 -0
  30. package/dist/lib/browser/types/index.mjs +11 -5
  31. package/dist/lib/browser/update-markdown-EJSHQRSC.mjs +45 -0
  32. package/dist/lib/browser/update-markdown-EJSHQRSC.mjs.map +7 -0
  33. package/dist/lib/node-esm/MarkdownSettings-LE66LODL.mjs +33 -0
  34. package/dist/lib/node-esm/MarkdownSettings-LE66LODL.mjs.map +7 -0
  35. package/dist/lib/node-esm/blueprints/index.mjs +52 -0
  36. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-43GF7QLH.mjs +159 -0
  38. package/dist/lib/node-esm/chunk-43GF7QLH.mjs.map +7 -0
  39. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  40. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  41. package/dist/lib/node-esm/chunk-IHC6DFTK.mjs +122 -0
  42. package/dist/lib/node-esm/chunk-IHC6DFTK.mjs.map +7 -0
  43. package/dist/lib/node-esm/cli/index.mjs +40 -0
  44. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  45. package/dist/lib/node-esm/create-PDW42WOY.mjs +31 -0
  46. package/dist/lib/node-esm/create-PDW42WOY.mjs.map +7 -0
  47. package/dist/lib/node-esm/create-markdown-BBPZPLQN.mjs +23 -0
  48. package/dist/lib/node-esm/create-markdown-BBPZPLQN.mjs.map +7 -0
  49. package/dist/lib/node-esm/index.mjs +569 -140
  50. package/dist/lib/node-esm/index.mjs.map +4 -4
  51. package/dist/lib/node-esm/meta.json +1 -1
  52. package/dist/lib/node-esm/open-B6GFN5DR.mjs +22 -0
  53. package/dist/lib/node-esm/open-B6GFN5DR.mjs.map +7 -0
  54. package/dist/lib/node-esm/operations/index.mjs +15 -0
  55. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  56. package/dist/lib/node-esm/scroll-to-anchor-CWEWWIS7.mjs +50 -0
  57. package/dist/lib/node-esm/scroll-to-anchor-CWEWWIS7.mjs.map +7 -0
  58. package/dist/lib/node-esm/set-view-mode-OMNNTSNM.mjs +27 -0
  59. package/dist/lib/node-esm/set-view-mode-OMNNTSNM.mjs.map +7 -0
  60. package/dist/lib/node-esm/translations.mjs +44 -0
  61. package/dist/lib/node-esm/translations.mjs.map +7 -0
  62. package/dist/lib/node-esm/types/index.mjs +11 -5
  63. package/dist/lib/node-esm/update-markdown-TAEAHVD2.mjs +46 -0
  64. package/dist/lib/node-esm/update-markdown-TAEAHVD2.mjs.map +7 -0
  65. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  66. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  67. package/dist/types/src/blueprints/index.d.ts +2 -0
  68. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  69. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  70. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  71. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  72. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  74. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -9
  76. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -0
  78. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/index.d.ts +9 -15
  80. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  81. package/dist/types/src/capabilities/node.d.ts +4 -0
  82. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  83. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  84. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  85. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  86. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/settings.d.ts +4 -2
  88. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/state.d.ts +4 -9
  90. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  91. package/dist/types/src/cli/index.d.ts +2 -0
  92. package/dist/types/src/cli/index.d.ts.map +1 -0
  93. package/dist/types/src/cli/plugin.d.ts +3 -0
  94. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  95. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  96. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +52 -21
  98. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  99. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
  100. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  101. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +33 -0
  102. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  103. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +13 -0
  104. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  105. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  106. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  107. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  108. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  109. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  110. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  111. package/dist/types/src/components/index.d.ts +3 -3
  112. package/dist/types/src/components/index.d.ts.map +1 -1
  113. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  114. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  115. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  116. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  117. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts +15 -0
  118. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts.map +1 -0
  119. package/dist/types/src/containers/MarkdownCard/index.d.ts +3 -0
  120. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  121. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  122. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  123. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  124. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  125. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  126. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  127. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  128. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  129. package/dist/types/src/containers/index.d.ts +6 -0
  130. package/dist/types/src/containers/index.d.ts.map +1 -0
  131. package/dist/types/src/hooks/index.d.ts +3 -1
  132. package/dist/types/src/hooks/index.d.ts.map +1 -1
  133. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  134. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  135. package/dist/types/src/hooks/useExtensions.d.ts +25 -0
  136. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  137. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  138. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  139. package/dist/types/src/index.d.ts +3 -3
  140. package/dist/types/src/index.d.ts.map +1 -1
  141. package/dist/types/src/meta.d.ts +2 -3
  142. package/dist/types/src/meta.d.ts.map +1 -1
  143. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  144. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  145. package/dist/types/src/operations/create.d.ts +5 -0
  146. package/dist/types/src/operations/create.d.ts.map +1 -0
  147. package/dist/types/src/operations/create.test.d.ts +2 -0
  148. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  149. package/dist/types/src/operations/definitions.d.ts +64 -0
  150. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  151. package/dist/types/src/operations/index.d.ts +4 -0
  152. package/dist/types/src/operations/index.d.ts.map +1 -0
  153. package/dist/types/src/operations/open.d.ts +5 -0
  154. package/dist/types/src/operations/open.d.ts.map +1 -0
  155. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  156. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  157. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  158. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  159. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  160. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  161. package/dist/types/src/operations/update.test.d.ts +2 -0
  162. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  163. package/dist/types/src/testing.d.ts +6 -0
  164. package/dist/types/src/testing.d.ts.map +1 -0
  165. package/dist/types/src/translations.d.ts +74 -32
  166. package/dist/types/src/translations.d.ts.map +1 -1
  167. package/dist/types/src/types/Markdown.d.ts +31 -30
  168. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  169. package/dist/types/src/types/Settings.d.ts +17 -0
  170. package/dist/types/src/types/Settings.d.ts.map +1 -0
  171. package/dist/types/src/types/capabilities.d.ts +34 -0
  172. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  173. package/dist/types/src/types/events.d.ts +5 -0
  174. package/dist/types/src/types/events.d.ts.map +1 -0
  175. package/dist/types/src/types/index.d.ts +4 -2
  176. package/dist/types/src/types/index.d.ts.map +1 -1
  177. package/dist/types/src/types/types.d.ts +3 -2
  178. package/dist/types/src/types/types.d.ts.map +1 -1
  179. package/dist/types/src/util.d.ts +7 -4
  180. package/dist/types/src/util.d.ts.map +1 -1
  181. package/dist/types/src/util.test.d.ts +2 -0
  182. package/dist/types/src/util.test.d.ts.map +1 -0
  183. package/dist/types/tsconfig.tsbuildinfo +1 -1
  184. package/package.json +118 -63
  185. package/src/MarkdownPlugin.tsx +91 -102
  186. package/src/blueprints/index.ts +5 -0
  187. package/src/blueprints/markdown-blueprint.ts +43 -0
  188. package/src/capabilities/anchor-sort.ts +29 -22
  189. package/src/capabilities/app-graph-serializer.ts +52 -42
  190. package/src/capabilities/artifact-definition.ts +87 -96
  191. package/src/capabilities/blueprint-definition.ts +17 -0
  192. package/src/capabilities/index.ts +12 -9
  193. package/src/capabilities/node.ts +11 -0
  194. package/src/capabilities/operation-handler.ts +16 -0
  195. package/src/capabilities/react-surface.tsx +116 -104
  196. package/src/capabilities/settings.ts +30 -18
  197. package/src/capabilities/state.ts +41 -25
  198. package/src/cli/index.ts +5 -0
  199. package/src/cli/plugin.ts +39 -0
  200. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  201. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +64 -38
  202. package/src/components/MarkdownEditor/MarkdownEditor.tsx +251 -267
  203. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +170 -0
  204. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -0
  205. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  206. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -92
  207. package/src/components/MarkdownSettings/index.ts +1 -1
  208. package/src/components/index.ts +4 -5
  209. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +68 -0
  210. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  211. package/src/containers/MarkdownCard/MarkdownEditableCard.tsx +42 -0
  212. package/src/containers/MarkdownCard/index.ts +6 -0
  213. package/src/containers/MarkdownCard/snippet.ts +54 -0
  214. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  215. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  216. package/src/containers/MarkdownContainer/index.ts +6 -0
  217. package/src/containers/index.ts +13 -0
  218. package/src/hooks/index.ts +3 -1
  219. package/src/hooks/useEditorMenuOptions.ts +68 -0
  220. package/src/hooks/useExtensions.tsx +262 -0
  221. package/src/hooks/useLinkQuery.ts +108 -0
  222. package/src/index.ts +4 -3
  223. package/src/meta.ts +6 -9
  224. package/src/operations/create-markdown.ts +20 -0
  225. package/src/operations/create.conversations.json +1 -0
  226. package/src/operations/create.test.ts +98 -0
  227. package/src/operations/create.ts +27 -0
  228. package/src/operations/definitions.ts +120 -0
  229. package/src/operations/index.ts +16 -0
  230. package/src/operations/open.ts +25 -0
  231. package/src/operations/scroll-to-anchor.ts +39 -0
  232. package/src/operations/set-view-mode.ts +24 -0
  233. package/src/operations/update-markdown.ts +51 -0
  234. package/src/operations/update.conversations.json +1 -0
  235. package/src/operations/update.test.ts +215 -0
  236. package/src/testing.ts +27 -0
  237. package/src/translations.ts +26 -31
  238. package/src/types/Markdown.ts +26 -31
  239. package/src/types/Settings.ts +65 -0
  240. package/src/types/capabilities.ts +51 -0
  241. package/src/types/events.ts +14 -0
  242. package/src/types/index.ts +5 -2
  243. package/src/types/types.ts +8 -3
  244. package/src/util.test.ts +44 -0
  245. package/src/util.tsx +83 -8
  246. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs +0 -80
  247. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs.map +0 -7
  248. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs +0 -780
  249. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs.map +0 -7
  250. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs +0 -32
  251. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs.map +0 -7
  252. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs +0 -52
  253. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs.map +0 -7
  254. package/dist/lib/browser/chunk-IKPZHFTW.mjs +0 -30
  255. package/dist/lib/browser/chunk-IKPZHFTW.mjs.map +0 -7
  256. package/dist/lib/browser/chunk-JHH7VL52.mjs +0 -18
  257. package/dist/lib/browser/chunk-JHH7VL52.mjs.map +0 -7
  258. package/dist/lib/browser/chunk-JMBQG2ZC.mjs +0 -50
  259. package/dist/lib/browser/chunk-JMBQG2ZC.mjs.map +0 -7
  260. package/dist/lib/browser/chunk-JTIGSUMB.mjs +0 -80
  261. package/dist/lib/browser/chunk-JTIGSUMB.mjs.map +0 -7
  262. package/dist/lib/browser/chunk-LMJPXTPL.mjs +0 -16
  263. package/dist/lib/browser/chunk-LMJPXTPL.mjs.map +0 -7
  264. package/dist/lib/browser/chunk-MVL4K3OD.mjs +0 -52
  265. package/dist/lib/browser/chunk-MVL4K3OD.mjs.map +0 -7
  266. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs +0 -60
  267. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs.map +0 -7
  268. package/dist/lib/browser/react-surface-NL3BZR6H.mjs +0 -208
  269. package/dist/lib/browser/react-surface-NL3BZR6H.mjs.map +0 -7
  270. package/dist/lib/browser/settings-Z7ZV7SLC.mjs +0 -28
  271. package/dist/lib/browser/settings-Z7ZV7SLC.mjs.map +0 -7
  272. package/dist/lib/browser/state-ORTZIEJU.mjs +0 -37
  273. package/dist/lib/browser/state-ORTZIEJU.mjs.map +0 -7
  274. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs +0 -81
  275. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs.map +0 -7
  276. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs +0 -781
  277. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs.map +0 -7
  278. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs +0 -33
  279. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs.map +0 -7
  280. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs +0 -53
  281. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs.map +0 -7
  282. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs +0 -17
  283. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs.map +0 -7
  284. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs +0 -31
  285. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs.map +0 -7
  286. package/dist/lib/node-esm/chunk-H6TITL7A.mjs +0 -20
  287. package/dist/lib/node-esm/chunk-H6TITL7A.mjs.map +0 -7
  288. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs +0 -51
  289. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs.map +0 -7
  290. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs +0 -81
  291. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs.map +0 -7
  292. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs +0 -53
  293. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs.map +0 -7
  294. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs +0 -61
  295. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs.map +0 -7
  296. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs +0 -209
  297. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs.map +0 -7
  298. package/dist/lib/node-esm/settings-UCXEWBCT.mjs +0 -29
  299. package/dist/lib/node-esm/settings-UCXEWBCT.mjs.map +0 -7
  300. package/dist/lib/node-esm/state-47WSZG54.mjs +0 -38
  301. package/dist/lib/node-esm/state-47WSZG54.mjs.map +0 -7
  302. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  303. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  304. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  305. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  306. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -7
  307. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  308. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -42
  309. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  310. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  311. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  312. package/dist/types/src/components/MarkdownContainer.d.ts +0 -18
  313. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  314. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -9
  315. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  316. package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
  317. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  318. package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
  319. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  320. package/dist/types/src/events.d.ts +0 -4
  321. package/dist/types/src/events.d.ts.map +0 -1
  322. package/dist/types/src/extensions.d.ts +0 -24
  323. package/dist/types/src/extensions.d.ts.map +0 -1
  324. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  325. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  326. package/dist/types/src/types/MarkdownAction.d.ts +0 -42
  327. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  328. package/src/capabilities/capabilities.ts +0 -21
  329. package/src/capabilities/intent-resolver.ts +0 -58
  330. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -79
  331. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -75
  332. package/src/components/MarkdownCard/index.ts +0 -9
  333. package/src/components/MarkdownContainer.stories.tsx +0 -100
  334. package/src/components/MarkdownContainer.tsx +0 -255
  335. package/src/components/Suggestions.stories.tsx +0 -221
  336. package/src/components/Toolbar.stories.tsx +0 -112
  337. package/src/events.ts +0 -11
  338. package/src/extensions.tsx +0 -328
  339. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  340. 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
- import { defineArtifact } from '@dxos/blueprints';
14
+ import { defineArtifact } from '@dxos/compute';
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/compute';
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/compute';
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/compute';
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,126 @@
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/types';
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, MarkdownEditableCard, 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.editable',
79
+ position: 'hoist',
80
+ filter: AppSurface.object(AppSurface.Card, [Markdown.Document, Text.Text], (data) => data.editable === true),
81
+ component: ({ data }) => <MarkdownEditableCard subject={data.subject} />,
82
+ }),
83
+ Surface.create({
84
+ id: 'surface.preview',
85
+ filter: AppSurface.object(AppSurface.Card, [Markdown.Document, Text.Text], (data) => data.editable !== true),
86
+ component: ({ data }) => <MarkdownCard {...data} />,
87
+ }),
88
+ ]),
89
+ ),
90
+ );
20
91
 
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));
92
+ /**
93
+ * Common wrapper.
94
+ */
95
+ const Container = forwardRef<
96
+ HTMLDivElement,
97
+ AppSurface.ObjectArticleProps<Markdown.Document | Text.Text, { id: string }>
98
+ >(({ id, attendableId, subject, role }, forwardedRef) => {
99
+ const selectionManager = useCapability(AttentionCapabilities.Selection);
100
+ const settings = useAtomCapability(MarkdownCapabilities.Settings);
101
+ const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
102
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
103
+ const extensions = useCapability(MarkdownCapabilities.Extensions);
104
+ const extensionProviders = useMemo(() => extensions.flat(), [extensions]);
34
105
 
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);
106
+ const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';
107
+ const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(
108
+ (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),
109
+ [id, setState],
110
+ );
60
111
 
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
- ]);
112
+ return (
113
+ <MarkdownContainer
114
+ role={role}
115
+ subject={subject}
116
+ id={id}
117
+ attendableId={attendableId}
118
+ settings={settings}
119
+ selectionManager={selectionManager}
120
+ extensionProviders={extensionProviders}
121
+ editorStateStore={editorState}
122
+ viewMode={viewMode}
123
+ onViewModeChange={handleViewModeChange}
124
+ ref={forwardedRef}
125
+ />
126
+ );
127
+ });
@@ -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';