@dxos/plugin-markdown 0.8.4-main.7996785055 → 0.8.4-main.8baae0fced

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (421) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/neutral/EditableMarkdownCard-LXBXN3OW.mjs +32 -0
  4. package/dist/lib/neutral/EditableMarkdownCard-LXBXN3OW.mjs.map +7 -0
  5. package/dist/lib/{node-esm/MarkdownContainer-25WFZLCC.mjs → neutral/MarkdownArticle-Z4QRU3WD.mjs} +25 -25
  6. package/dist/lib/neutral/MarkdownArticle-Z4QRU3WD.mjs.map +7 -0
  7. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs +102 -0
  8. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs.map +7 -0
  9. package/dist/lib/neutral/MarkdownPlugin.mjs +58 -0
  10. package/dist/lib/neutral/MarkdownPlugin.mjs.map +7 -0
  11. package/dist/lib/neutral/MarkdownPlugin.node.mjs +25 -0
  12. package/dist/lib/neutral/MarkdownPlugin.node.mjs.map +7 -0
  13. package/dist/lib/neutral/MarkdownPlugin.workerd.mjs +23 -0
  14. package/dist/lib/neutral/MarkdownPlugin.workerd.mjs.map +7 -0
  15. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs +32 -0
  16. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs.map +7 -0
  17. package/dist/lib/{browser/anchor-sort-PSCEA6EJ.mjs → neutral/anchor-sort-L4VCKDO6.mjs} +5 -7
  18. package/dist/lib/neutral/anchor-sort-L4VCKDO6.mjs.map +7 -0
  19. package/dist/lib/{browser/app-graph-serializer-DAVFEX7R.mjs → neutral/app-graph-serializer-YI72EEVM.mjs} +11 -19
  20. package/dist/lib/neutral/app-graph-serializer-YI72EEVM.mjs.map +7 -0
  21. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs +15 -0
  22. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs.map +7 -0
  23. package/dist/lib/{browser → neutral}/blueprints/index.mjs +2 -4
  24. package/dist/lib/neutral/capabilities/index.mjs +25 -0
  25. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  26. package/dist/lib/neutral/capabilities/node.mjs +11 -0
  27. package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
  28. package/dist/lib/neutral/chunk-5JWFZVBC.mjs +8 -0
  29. package/dist/lib/neutral/chunk-5JWFZVBC.mjs.map +7 -0
  30. package/dist/lib/{browser/chunk-RYZHVXZ5.mjs → neutral/chunk-ISCL3BB2.mjs} +3 -8
  31. package/dist/lib/neutral/chunk-ISCL3BB2.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  33. package/dist/lib/neutral/chunk-KDN4GKG2.mjs +98 -0
  34. package/dist/lib/neutral/chunk-KDN4GKG2.mjs.map +7 -0
  35. package/dist/lib/{browser/chunk-ZN75YHSV.mjs → neutral/chunk-LXNSKCPD.mjs} +8 -14
  36. package/dist/lib/neutral/chunk-LXNSKCPD.mjs.map +7 -0
  37. package/dist/lib/neutral/chunk-SOLAMEK3.mjs +276 -0
  38. package/dist/lib/neutral/chunk-SOLAMEK3.mjs.map +7 -0
  39. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs +30 -0
  40. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs.map +7 -0
  41. package/dist/lib/neutral/components/index.mjs +370 -0
  42. package/dist/lib/neutral/components/index.mjs.map +7 -0
  43. package/dist/lib/neutral/containers/index.mjs +13 -0
  44. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  45. package/dist/lib/{browser/create-QD27F6E7.mjs → neutral/create-3PGJ2NEK.mjs} +6 -8
  46. package/dist/lib/neutral/create-3PGJ2NEK.mjs.map +7 -0
  47. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs +20 -0
  48. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs.map +7 -0
  49. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs +27 -0
  50. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs.map +7 -0
  51. package/dist/lib/neutral/hooks/index.mjs +321 -0
  52. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  53. package/dist/lib/neutral/index.mjs +42 -0
  54. package/dist/lib/neutral/meta.json +1 -0
  55. package/dist/lib/neutral/meta.mjs +8 -0
  56. package/dist/lib/{browser/open-YDABYPCA.mjs → neutral/open-WCYGBLAG.mjs} +6 -7
  57. package/dist/lib/neutral/open-WCYGBLAG.mjs.map +7 -0
  58. package/dist/lib/{browser/operation-handler-W3QXMMMQ.mjs → neutral/operation-handler-2ARMPBGZ.mjs} +4 -8
  59. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs.map +7 -0
  60. package/dist/lib/neutral/operations/index.mjs +8 -0
  61. package/dist/lib/neutral/plugin.mjs +16 -0
  62. package/dist/lib/neutral/plugin.mjs.map +7 -0
  63. package/dist/lib/{browser/react-surface-N7FV3PXH.mjs → neutral/react-surface-SG4YNXBS.mjs} +33 -34
  64. package/dist/lib/neutral/react-surface-SG4YNXBS.mjs.map +7 -0
  65. package/dist/lib/{browser/scroll-to-anchor-3CGV3XI7.mjs → neutral/scroll-to-anchor-6FIOKVKT.mjs} +8 -10
  66. package/dist/lib/neutral/scroll-to-anchor-6FIOKVKT.mjs.map +7 -0
  67. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs +24 -0
  68. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs.map +7 -0
  69. package/dist/lib/{browser/settings-3UMXG4TP.mjs → neutral/settings-TDGDLCUR.mjs} +7 -11
  70. package/dist/lib/neutral/settings-TDGDLCUR.mjs.map +7 -0
  71. package/dist/lib/{browser/state-IYKJ6EV3.mjs → neutral/state-5COCF5PN.mjs} +6 -10
  72. package/dist/lib/neutral/state-5COCF5PN.mjs.map +7 -0
  73. package/dist/lib/neutral/testing.mjs +19 -0
  74. package/dist/lib/neutral/testing.mjs.map +7 -0
  75. package/dist/lib/neutral/translations.mjs +43 -0
  76. package/dist/lib/neutral/translations.mjs.map +7 -0
  77. package/dist/lib/neutral/types/index.mjs +16 -0
  78. package/dist/lib/{browser/update-WKAMI4AD.mjs → neutral/update-markdown-5EDRD3SH.mjs} +9 -10
  79. package/dist/lib/neutral/update-markdown-5EDRD3SH.mjs.map +7 -0
  80. package/dist/types/src/MarkdownPlugin.d.ts +1 -0
  81. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  82. package/dist/types/src/{cli/plugin.d.ts → MarkdownPlugin.node.d.ts} +2 -1
  83. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  84. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  85. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  86. package/dist/types/src/MarkdownPlugin.workerd.d.ts +4 -0
  87. package/dist/types/src/MarkdownPlugin.workerd.d.ts.map +1 -0
  88. package/dist/types/src/blueprints/markdown-blueprint.d.ts +2 -2
  89. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  90. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  91. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  92. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
  93. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  94. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  95. package/dist/types/src/capabilities/comment-config.d.ts +12 -0
  96. package/dist/types/src/capabilities/comment-config.d.ts.map +1 -0
  97. package/dist/types/src/capabilities/create-object.d.ts +11 -0
  98. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  99. package/dist/types/src/capabilities/index.d.ts +22 -7
  100. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  101. package/dist/types/src/capabilities/node.d.ts +10 -0
  102. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  103. package/dist/types/src/capabilities/{operation-handler/operation-handler.d.ts → operation-handler.d.ts} +1 -1
  104. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  105. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/{settings/settings.d.ts → settings.d.ts} +1 -2
  107. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  108. package/dist/types/src/capabilities/state.d.ts +6 -0
  109. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  110. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +29 -23
  111. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  112. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +2 -2
  113. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  114. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +2 -1
  115. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  116. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +2 -6
  117. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  118. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +6 -0
  119. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -0
  120. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  121. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  122. package/dist/types/src/components/MarkdownSettings/index.d.ts +2 -0
  123. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -0
  124. package/dist/types/src/components/index.d.ts +2 -0
  125. package/dist/types/src/components/index.d.ts.map +1 -1
  126. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts +15 -0
  127. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts.map +1 -0
  128. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts +3 -0
  129. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts.map +1 -0
  130. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.d.ts +36 -0
  131. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.d.ts.map +1 -0
  132. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.stories.d.ts +97 -0
  133. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.stories.d.ts.map +1 -0
  134. package/dist/types/src/containers/MarkdownArticle/index.d.ts +3 -0
  135. package/dist/types/src/containers/MarkdownArticle/index.d.ts.map +1 -0
  136. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +1 -1
  137. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  138. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +1 -1
  139. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  140. package/dist/types/src/containers/MarkdownCard/index.d.ts +1 -2
  141. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -1
  142. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +7 -5
  143. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -1
  144. package/dist/types/src/containers/index.d.ts +3 -3
  145. package/dist/types/src/containers/index.d.ts.map +1 -1
  146. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  147. package/dist/types/src/hooks/useExtensions.d.ts +4 -2
  148. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  149. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  150. package/dist/types/src/index.d.ts +2 -3
  151. package/dist/types/src/index.d.ts.map +1 -1
  152. package/dist/types/src/meta.d.ts.map +1 -1
  153. package/dist/types/src/operations/create-markdown.d.ts +3 -3
  154. package/dist/types/src/operations/create-markdown.d.ts.map +1 -1
  155. package/dist/types/src/operations/create.d.ts +3 -3
  156. package/dist/types/src/operations/create.d.ts.map +1 -1
  157. package/dist/types/src/operations/index.d.ts +1 -2
  158. package/dist/types/src/operations/index.d.ts.map +1 -1
  159. package/dist/types/src/operations/open.d.ts +3 -3
  160. package/dist/types/src/operations/open.d.ts.map +1 -1
  161. package/dist/types/src/operations/scroll-to-anchor.d.ts +3 -3
  162. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -1
  163. package/dist/types/src/operations/set-view-mode.d.ts +3 -3
  164. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -1
  165. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  166. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  167. package/dist/types/src/plugin.d.ts +4 -0
  168. package/dist/types/src/plugin.d.ts.map +1 -0
  169. package/dist/types/src/testing.d.ts +1 -0
  170. package/dist/types/src/testing.d.ts.map +1 -1
  171. package/dist/types/src/translations.d.ts +70 -63
  172. package/dist/types/src/translations.d.ts.map +1 -1
  173. package/dist/types/src/types/Markdown.d.ts +15 -15
  174. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  175. package/dist/types/src/types/MarkdownCapabilities.d.ts +32 -0
  176. package/dist/types/src/types/MarkdownCapabilities.d.ts.map +1 -0
  177. package/dist/types/src/types/MarkdownEvents.d.ts +3 -0
  178. package/dist/types/src/types/MarkdownEvents.d.ts.map +1 -0
  179. package/dist/types/src/{operations/definitions.d.ts → types/MarkdownOperation.d.ts} +6 -3
  180. package/dist/types/src/types/MarkdownOperation.d.ts.map +1 -0
  181. package/dist/types/src/types/Settings.d.ts +17 -0
  182. package/dist/types/src/types/Settings.d.ts.map +1 -0
  183. package/dist/types/src/types/index.d.ts +5 -3
  184. package/dist/types/src/types/index.d.ts.map +1 -1
  185. package/dist/types/src/types/types.d.ts +1 -0
  186. package/dist/types/src/types/types.d.ts.map +1 -1
  187. package/dist/types/src/util.d.ts +2 -2
  188. package/dist/types/src/util.d.ts.map +1 -1
  189. package/dist/types/tsconfig.tsbuildinfo +1 -1
  190. package/package.json +123 -90
  191. package/src/MarkdownPlugin.node.ts +20 -0
  192. package/src/MarkdownPlugin.test.ts +26 -0
  193. package/src/MarkdownPlugin.tsx +12 -55
  194. package/src/MarkdownPlugin.workerd.ts +19 -0
  195. package/src/blueprints/markdown-blueprint.ts +8 -9
  196. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +1 -1
  197. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +6 -7
  198. package/src/capabilities/{artifact-definition/artifact-definition.ts → artifact-definition.ts} +5 -6
  199. package/src/capabilities/{blueprint-definition/blueprint-definition.ts → blueprint-definition.ts} +3 -1
  200. package/src/capabilities/comment-config.ts +32 -0
  201. package/src/capabilities/create-object.ts +30 -0
  202. package/src/capabilities/index.ts +16 -7
  203. package/src/capabilities/{operation-handler/index.ts → node.ts} +3 -1
  204. package/src/capabilities/{operation-handler/operation-handler.ts → operation-handler.ts} +2 -2
  205. package/src/capabilities/react-surface.tsx +127 -0
  206. package/src/capabilities/{settings/settings.ts → settings.ts} +2 -2
  207. package/src/capabilities/{state/state.ts → state.ts} +5 -5
  208. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +24 -19
  209. package/src/components/MarkdownEditor/MarkdownEditor.tsx +100 -87
  210. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +10 -14
  211. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +6 -17
  212. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  213. package/src/components/MarkdownSettings/MarkdownSettings.tsx +35 -0
  214. package/src/components/MarkdownSettings/index.ts +5 -0
  215. package/src/components/index.ts +4 -0
  216. package/src/containers/EditableMarkdownCard/EditableMarkdownCard.tsx +42 -0
  217. package/src/containers/EditableMarkdownCard/index.ts +6 -0
  218. package/src/containers/{MarkdownContainer/MarkdownContainer.stories.tsx → MarkdownArticle/MarkdownArticle.stories.tsx} +15 -13
  219. package/src/containers/{MarkdownContainer/MarkdownContainer.tsx → MarkdownArticle/MarkdownArticle.tsx} +38 -26
  220. package/src/containers/MarkdownArticle/index.ts +6 -0
  221. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +10 -10
  222. package/src/containers/MarkdownCard/MarkdownCard.tsx +25 -15
  223. package/src/containers/MarkdownCard/index.ts +1 -3
  224. package/src/containers/MarkdownCard/snippet.ts +27 -48
  225. package/src/containers/index.ts +3 -3
  226. package/src/hooks/useEditorMenuOptions.ts +2 -2
  227. package/src/hooks/useExtensions.tsx +14 -13
  228. package/src/hooks/useLinkQuery.ts +33 -27
  229. package/src/index.ts +2 -6
  230. package/src/meta.ts +5 -1
  231. package/src/operations/create-markdown.ts +3 -5
  232. package/src/operations/create.conversations.json +1 -1
  233. package/src/operations/create.test.ts +25 -22
  234. package/src/operations/create.ts +3 -4
  235. package/src/operations/index.ts +2 -4
  236. package/src/operations/open.ts +3 -3
  237. package/src/operations/scroll-to-anchor.ts +3 -5
  238. package/src/operations/set-view-mode.ts +3 -5
  239. package/src/operations/{update.ts → update-markdown.ts} +3 -3
  240. package/src/operations/update.conversations.json +1 -1
  241. package/src/operations/update.test.ts +45 -48
  242. package/src/plugin.ts +11 -0
  243. package/src/testing.ts +8 -3
  244. package/src/translations.ts +25 -38
  245. package/src/types/Markdown.ts +11 -21
  246. package/src/types/MarkdownCapabilities.ts +51 -0
  247. package/src/types/MarkdownEvents.ts +14 -0
  248. package/src/{operations/definitions.ts → types/MarkdownOperation.ts} +6 -3
  249. package/src/types/Settings.ts +65 -0
  250. package/src/types/index.ts +6 -4
  251. package/src/types/types.ts +4 -1
  252. package/src/util.tsx +4 -4
  253. package/dist/lib/browser/MarkdownCard-ZHQBD4AV.mjs +0 -122
  254. package/dist/lib/browser/MarkdownCard-ZHQBD4AV.mjs.map +0 -7
  255. package/dist/lib/browser/MarkdownContainer-XEUOYBPA.mjs +0 -125
  256. package/dist/lib/browser/MarkdownContainer-XEUOYBPA.mjs.map +0 -7
  257. package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs +0 -106
  258. package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs.map +0 -7
  259. package/dist/lib/browser/anchor-sort-PSCEA6EJ.mjs.map +0 -7
  260. package/dist/lib/browser/app-graph-serializer-DAVFEX7R.mjs.map +0 -7
  261. package/dist/lib/browser/blueprint-definition-LHVNOMJT.mjs +0 -19
  262. package/dist/lib/browser/blueprint-definition-LHVNOMJT.mjs.map +0 -7
  263. package/dist/lib/browser/chunk-5VT6IW5B.mjs +0 -84
  264. package/dist/lib/browser/chunk-5VT6IW5B.mjs.map +0 -7
  265. package/dist/lib/browser/chunk-CJSWKCKU.mjs +0 -60
  266. package/dist/lib/browser/chunk-CJSWKCKU.mjs.map +0 -7
  267. package/dist/lib/browser/chunk-G6BRWY3G.mjs +0 -158
  268. package/dist/lib/browser/chunk-G6BRWY3G.mjs.map +0 -7
  269. package/dist/lib/browser/chunk-M2XFCKXA.mjs +0 -8
  270. package/dist/lib/browser/chunk-M2XFCKXA.mjs.map +0 -7
  271. package/dist/lib/browser/chunk-RYZHVXZ5.mjs.map +0 -7
  272. package/dist/lib/browser/chunk-XWYF5LFE.mjs +0 -8
  273. package/dist/lib/browser/chunk-XWYF5LFE.mjs.map +0 -7
  274. package/dist/lib/browser/chunk-YALLVET2.mjs +0 -757
  275. package/dist/lib/browser/chunk-YALLVET2.mjs.map +0 -7
  276. package/dist/lib/browser/chunk-ZN75YHSV.mjs.map +0 -7
  277. package/dist/lib/browser/cli/index.mjs +0 -44
  278. package/dist/lib/browser/cli/index.mjs.map +0 -7
  279. package/dist/lib/browser/create-QD27F6E7.mjs.map +0 -7
  280. package/dist/lib/browser/create-markdown-LEAJPLHT.mjs +0 -22
  281. package/dist/lib/browser/create-markdown-LEAJPLHT.mjs.map +0 -7
  282. package/dist/lib/browser/index.mjs +0 -164
  283. package/dist/lib/browser/index.mjs.map +0 -7
  284. package/dist/lib/browser/meta.json +0 -1
  285. package/dist/lib/browser/open-YDABYPCA.mjs.map +0 -7
  286. package/dist/lib/browser/operation-handler-W3QXMMMQ.mjs.map +0 -7
  287. package/dist/lib/browser/operations/index.mjs +0 -13
  288. package/dist/lib/browser/react-surface-N7FV3PXH.mjs.map +0 -7
  289. package/dist/lib/browser/scroll-to-anchor-3CGV3XI7.mjs.map +0 -7
  290. package/dist/lib/browser/set-view-mode-XLD3RXW4.mjs +0 -26
  291. package/dist/lib/browser/set-view-mode-XLD3RXW4.mjs.map +0 -7
  292. package/dist/lib/browser/settings-3UMXG4TP.mjs.map +0 -7
  293. package/dist/lib/browser/state-IYKJ6EV3.mjs.map +0 -7
  294. package/dist/lib/browser/types/index.mjs +0 -14
  295. package/dist/lib/browser/update-WKAMI4AD.mjs.map +0 -7
  296. package/dist/lib/node-esm/MarkdownCard-VB3NHVX4.mjs +0 -123
  297. package/dist/lib/node-esm/MarkdownCard-VB3NHVX4.mjs.map +0 -7
  298. package/dist/lib/node-esm/MarkdownContainer-25WFZLCC.mjs.map +0 -7
  299. package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs +0 -107
  300. package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs.map +0 -7
  301. package/dist/lib/node-esm/anchor-sort-6GD4SGQL.mjs +0 -35
  302. package/dist/lib/node-esm/anchor-sort-6GD4SGQL.mjs.map +0 -7
  303. package/dist/lib/node-esm/app-graph-serializer-JURUUUBI.mjs +0 -64
  304. package/dist/lib/node-esm/app-graph-serializer-JURUUUBI.mjs.map +0 -7
  305. package/dist/lib/node-esm/blueprint-definition-3LUZEJ4Z.mjs +0 -20
  306. package/dist/lib/node-esm/blueprint-definition-3LUZEJ4Z.mjs.map +0 -7
  307. package/dist/lib/node-esm/blueprints/index.mjs +0 -11
  308. package/dist/lib/node-esm/chunk-6LHNAAMP.mjs +0 -159
  309. package/dist/lib/node-esm/chunk-6LHNAAMP.mjs.map +0 -7
  310. package/dist/lib/node-esm/chunk-CRUJMQR2.mjs +0 -758
  311. package/dist/lib/node-esm/chunk-CRUJMQR2.mjs.map +0 -7
  312. package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs +0 -29
  313. package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs.map +0 -7
  314. package/dist/lib/node-esm/chunk-EPNCYA73.mjs +0 -85
  315. package/dist/lib/node-esm/chunk-EPNCYA73.mjs.map +0 -7
  316. package/dist/lib/node-esm/chunk-FC3GPLJG.mjs +0 -61
  317. package/dist/lib/node-esm/chunk-FC3GPLJG.mjs.map +0 -7
  318. package/dist/lib/node-esm/chunk-G6W4DJBM.mjs +0 -51
  319. package/dist/lib/node-esm/chunk-G6W4DJBM.mjs.map +0 -7
  320. package/dist/lib/node-esm/chunk-JLOCBILO.mjs +0 -10
  321. package/dist/lib/node-esm/chunk-JLOCBILO.mjs.map +0 -7
  322. package/dist/lib/node-esm/chunk-YWQQYV76.mjs +0 -10
  323. package/dist/lib/node-esm/chunk-YWQQYV76.mjs.map +0 -7
  324. package/dist/lib/node-esm/cli/index.mjs +0 -45
  325. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  326. package/dist/lib/node-esm/create-X7H4LYI5.mjs +0 -31
  327. package/dist/lib/node-esm/create-X7H4LYI5.mjs.map +0 -7
  328. package/dist/lib/node-esm/create-markdown-7POKQDVQ.mjs +0 -23
  329. package/dist/lib/node-esm/create-markdown-7POKQDVQ.mjs.map +0 -7
  330. package/dist/lib/node-esm/index.mjs +0 -165
  331. package/dist/lib/node-esm/index.mjs.map +0 -7
  332. package/dist/lib/node-esm/meta.json +0 -1
  333. package/dist/lib/node-esm/open-FZVFWXC7.mjs +0 -22
  334. package/dist/lib/node-esm/open-FZVFWXC7.mjs.map +0 -7
  335. package/dist/lib/node-esm/operation-handler-TP26H7QE.mjs +0 -18
  336. package/dist/lib/node-esm/operation-handler-TP26H7QE.mjs.map +0 -7
  337. package/dist/lib/node-esm/operations/index.mjs +0 -14
  338. package/dist/lib/node-esm/react-surface-XSKLSF6A.mjs +0 -121
  339. package/dist/lib/node-esm/react-surface-XSKLSF6A.mjs.map +0 -7
  340. package/dist/lib/node-esm/scroll-to-anchor-KWBJLM5Q.mjs +0 -50
  341. package/dist/lib/node-esm/scroll-to-anchor-KWBJLM5Q.mjs.map +0 -7
  342. package/dist/lib/node-esm/set-view-mode-FFEKYLU3.mjs +0 -27
  343. package/dist/lib/node-esm/set-view-mode-FFEKYLU3.mjs.map +0 -7
  344. package/dist/lib/node-esm/settings-UAN22O42.mjs +0 -39
  345. package/dist/lib/node-esm/settings-UAN22O42.mjs.map +0 -7
  346. package/dist/lib/node-esm/state-62IBFPTK.mjs +0 -49
  347. package/dist/lib/node-esm/state-62IBFPTK.mjs.map +0 -7
  348. package/dist/lib/node-esm/types/index.mjs +0 -15
  349. package/dist/lib/node-esm/update-WPEFBY4M.mjs +0 -46
  350. package/dist/lib/node-esm/update-WPEFBY4M.mjs.map +0 -7
  351. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  352. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  353. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  354. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  355. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  356. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  357. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  358. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  359. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  360. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -6
  361. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  362. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  363. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  364. package/dist/types/src/capabilities/operation-handler/index.d.ts +0 -4
  365. package/dist/types/src/capabilities/operation-handler/index.d.ts.map +0 -1
  366. package/dist/types/src/capabilities/operation-handler/operation-handler.d.ts.map +0 -1
  367. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  368. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  369. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  370. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  371. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  372. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  373. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  374. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  375. package/dist/types/src/capabilities/state/state.d.ts +0 -6
  376. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  377. package/dist/types/src/cli/index.d.ts +0 -2
  378. package/dist/types/src/cli/index.d.ts.map +0 -1
  379. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  380. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +0 -30
  381. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +0 -1
  382. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +0 -89
  383. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +0 -1
  384. package/dist/types/src/containers/MarkdownContainer/index.d.ts +0 -3
  385. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +0 -1
  386. package/dist/types/src/containers/MarkdownSettings/MarkdownSettings.d.ts +0 -8
  387. package/dist/types/src/containers/MarkdownSettings/MarkdownSettings.d.ts.map +0 -1
  388. package/dist/types/src/containers/MarkdownSettings/index.d.ts +0 -3
  389. package/dist/types/src/containers/MarkdownSettings/index.d.ts.map +0 -1
  390. package/dist/types/src/operations/definitions.d.ts.map +0 -1
  391. package/dist/types/src/operations/update.d.ts +0 -5
  392. package/dist/types/src/operations/update.d.ts.map +0 -1
  393. package/dist/types/src/types/capabilities.d.ts +0 -34
  394. package/dist/types/src/types/capabilities.d.ts.map +0 -1
  395. package/dist/types/src/types/events.d.ts +0 -5
  396. package/dist/types/src/types/events.d.ts.map +0 -1
  397. package/src/capabilities/anchor-sort/index.ts +0 -7
  398. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  399. package/src/capabilities/artifact-definition/index.ts +0 -7
  400. package/src/capabilities/blueprint-definition/index.ts +0 -7
  401. package/src/capabilities/react-surface/index.ts +0 -7
  402. package/src/capabilities/react-surface/react-surface.tsx +0 -120
  403. package/src/capabilities/settings/index.ts +0 -7
  404. package/src/capabilities/state/index.ts +0 -7
  405. package/src/cli/index.ts +0 -5
  406. package/src/cli/plugin.ts +0 -40
  407. package/src/containers/MarkdownContainer/index.ts +0 -6
  408. package/src/containers/MarkdownSettings/MarkdownSettings.tsx +0 -122
  409. package/src/containers/MarkdownSettings/index.ts +0 -7
  410. package/src/types/capabilities.ts +0 -50
  411. package/src/types/events.ts +0 -14
  412. /package/dist/lib/{browser → neutral}/blueprints/index.mjs.map +0 -0
  413. /package/dist/lib/{browser/operations/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  414. /package/dist/lib/{browser/types → neutral}/index.mjs.map +0 -0
  415. /package/dist/lib/{node-esm/blueprints/index.mjs.map → neutral/meta.mjs.map} +0 -0
  416. /package/dist/lib/{node-esm → neutral}/operations/index.mjs.map +0 -0
  417. /package/dist/lib/{node-esm → neutral}/types/index.mjs.map +0 -0
  418. /package/dist/types/src/capabilities/{anchor-sort/anchor-sort.d.ts → anchor-sort.d.ts} +0 -0
  419. /package/dist/types/src/capabilities/{app-graph-serializer/app-graph-serializer.d.ts → app-graph-serializer.d.ts} +0 -0
  420. /package/dist/types/src/capabilities/{artifact-definition/artifact-definition.d.ts → artifact-definition.d.ts} +0 -0
  421. /package/dist/types/src/capabilities/{react-surface/react-surface.d.ts → react-surface.d.ts} +0 -0
@@ -3,7 +3,9 @@
3
3
  //
4
4
 
5
5
  import { Capability } from '@dxos/app-framework';
6
- import { OperationHandlerSet } from '@dxos/operation';
6
+ import { OperationHandlerSet } from '@dxos/compute';
7
+
8
+ export const CreateObject = Capability.lazy('CreateObject', () => import('./create-object'));
7
9
 
8
10
  export const OperationHandler = Capability.lazy<OperationHandlerSet.OperationHandlerSet>(
9
11
  'OperationHandler',
@@ -5,9 +5,9 @@
5
5
  import * as Effect from 'effect/Effect';
6
6
 
7
7
  import { Capabilities, Capability } from '@dxos/app-framework';
8
- import type { OperationHandlerSet } from '@dxos/operation';
8
+ import type { OperationHandlerSet } from '@dxos/compute';
9
9
 
10
- import { MarkdownOperationHandlerSet } from '../../operations';
10
+ import { MarkdownOperationHandlerSet } from '#operations';
11
11
 
12
12
  export default Capability.makeModule<OperationHandlerSet.OperationHandlerSet>(
13
13
  Effect.fnUntraced(function* () {
@@ -0,0 +1,127 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import React, { forwardRef, useCallback, useMemo } from 'react';
7
+
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';
17
+ import { Obj } from '@dxos/echo';
18
+ import { AttentionCapabilities } from '@dxos/plugin-attention';
19
+ import { Text } from '@dxos/schema';
20
+ import { type EditorViewMode } from '@dxos/ui-editor/types';
21
+
22
+ import { MarkdownSettings } from '#components';
23
+ import { MarkdownCard, EditableMarkdownCard, MarkdownArticle, type MarkdownArticleProps } from '#containers';
24
+ import { meta } from '#meta';
25
+ import { Markdown, MarkdownCapabilities } from '#types';
26
+
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: 'first',
80
+ filter: AppSurface.object(AppSurface.Card, [Markdown.Document, Text.Text], (data) => data.editable === true),
81
+ component: ({ data }) => <EditableMarkdownCard 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
+ );
91
+
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]);
105
+
106
+ const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';
107
+ const handleViewModeChange = useCallback<NonNullable<MarkdownArticleProps['onViewModeChange']>>(
108
+ (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),
109
+ [id, setState],
110
+ );
111
+
112
+ return (
113
+ <MarkdownArticle
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
+ });
@@ -8,8 +8,8 @@ import { Capability } from '@dxos/app-framework';
8
8
  import { AppCapabilities } from '@dxos/app-toolkit';
9
9
  import { createKvsStore } from '@dxos/effect';
10
10
 
11
- import { meta } from '../../meta';
12
- import { Markdown, MarkdownCapabilities } from '../../types';
11
+ import { meta } from '#meta';
12
+ import { Markdown, MarkdownCapabilities } from '#types';
13
13
 
14
14
  export default Capability.makeModule(() =>
15
15
  Effect.sync(() => {
@@ -8,11 +8,11 @@ import { Capability } from '@dxos/app-framework';
8
8
  import { createKvsStore } from '@dxos/effect';
9
9
  import { createEditorStateStore } from '@dxos/ui-editor';
10
10
 
11
- import { meta } from '../../meta';
12
- import { type EditorViewEntry, type EditorViewRegistry, MarkdownCapabilities, MarkdownStateSchema } from '../../types';
11
+ import { meta } from '#meta';
12
+ import { MarkdownCapabilities } from '#types';
13
13
 
14
- const createEditorViewRegistry = (): EditorViewRegistry => {
15
- const views = new Map<string, EditorViewEntry>();
14
+ const createEditorViewRegistry = (): MarkdownCapabilities.EditorViewRegistry => {
15
+ const views = new Map<string, MarkdownCapabilities.EditorViewEntry>();
16
16
  return {
17
17
  register: (attendableId, view, documentId) => {
18
18
  views.set(attendableId, { view, documentId });
@@ -29,7 +29,7 @@ export default Capability.makeModule(
29
29
  // Persisted state using KVS store.
30
30
  const stateAtom = createKvsStore({
31
31
  key: `${meta.id}.state`,
32
- schema: MarkdownStateSchema,
32
+ schema: MarkdownCapabilities.StateSchema,
33
33
  defaultValue: () => ({ viewMode: {} }),
34
34
  });
35
35
 
@@ -8,25 +8,26 @@ import React from 'react';
8
8
 
9
9
  import { withPluginManager } from '@dxos/app-framework/testing';
10
10
  import { Filter, Obj } from '@dxos/echo';
11
- import { ClientPlugin } from '@dxos/plugin-client';
11
+ import { ClientPlugin } from '@dxos/plugin-client/testing';
12
12
  import { initializeIdentity } from '@dxos/plugin-client/testing';
13
13
  import { corePlugins } from '@dxos/plugin-testing';
14
- import { useQuery, useSpace } from '@dxos/react-client/echo';
14
+ import { useQuery, useSpaces } from '@dxos/react-client/echo';
15
15
  import { Panel } from '@dxos/react-ui';
16
- import { Loading, withLayout } from '@dxos/react-ui/testing';
17
16
  import { AttendableContainer } from '@dxos/react-ui-attention';
18
- import { translations as editorTranslations } from '@dxos/react-ui-editor';
17
+ import { Editor } from '@dxos/react-ui-editor';
18
+ import { translations as editorTranslations } from '@dxos/react-ui-editor/translations';
19
+ import { Loading, withLayout } from '@dxos/react-ui/testing';
19
20
  import { Text } from '@dxos/schema';
20
21
 
21
- import { translations } from '../../translations';
22
- import { Markdown } from '../../types';
22
+ import { translations } from '#translations';
23
+ import { Markdown } from '#types';
23
24
 
24
- import { MarkdownEditor, type MarkdownEditorRootProps } from './MarkdownEditor';
25
+ import { MarkdownEditor, MarkdownEditorProvider, type MarkdownEditorProviderProps } from './MarkdownEditor';
25
26
 
26
- type DefaultStoryProps = Omit<MarkdownEditorRootProps, 'id' | 'extensions'>;
27
+ type DefaultStoryProps = Omit<MarkdownEditorProviderProps, 'id' | 'extensions' | 'children'>;
27
28
 
28
29
  const DefaultStory = (props: DefaultStoryProps) => {
29
- const space = useSpace();
30
+ const [space] = useSpaces();
30
31
  const [doc] = useQuery(space?.db, Filter.type(Markdown.Document));
31
32
  const id = doc && Obj.getDXN(doc).toString();
32
33
  if (!id) {
@@ -35,16 +36,20 @@ const DefaultStory = (props: DefaultStoryProps) => {
35
36
 
36
37
  return (
37
38
  <AttendableContainer id={id} tabIndex={0} classNames='dx-container'>
38
- <MarkdownEditor.Root id={id} object={doc} {...props}>
39
- <Panel.Root>
40
- <Panel.Toolbar asChild>
41
- <MarkdownEditor.Toolbar />
42
- </Panel.Toolbar>
43
- <Panel.Content asChild>
44
- <MarkdownEditor.Content />
45
- </Panel.Content>
46
- </Panel.Root>
47
- </MarkdownEditor.Root>
39
+ <MarkdownEditorProvider id={id} object={doc} {...props}>
40
+ {(editorRootProps) => (
41
+ <Editor.Root {...editorRootProps}>
42
+ <Panel.Root>
43
+ <Panel.Toolbar asChild>
44
+ <MarkdownEditor.Toolbar />
45
+ </Panel.Toolbar>
46
+ <Panel.Content asChild>
47
+ <MarkdownEditor.Content />
48
+ </Panel.Content>
49
+ </Panel.Root>
50
+ </Editor.Root>
51
+ )}
52
+ </MarkdownEditorProvider>
48
53
  </AttendableContainer>
49
54
  );
50
55
  };
@@ -6,20 +6,20 @@ import { type Extension } from '@codemirror/state';
6
6
  import { type EditorView } from '@codemirror/view';
7
7
  import { type Atom } from '@effect-atom/atom-react';
8
8
  import { createContext } from '@radix-ui/react-context';
9
- import React, { type PropsWithChildren, useMemo, useState } from 'react';
9
+ import React, { type ReactNode, useCallback, useMemo, useState } from 'react';
10
10
  import { createPortal } from 'react-dom';
11
11
 
12
12
  import { Surface } from '@dxos/app-framework/ui';
13
+ import { AppSurface } from '@dxos/app-toolkit/ui';
13
14
  import { Obj } from '@dxos/echo';
14
15
  import { DXN } from '@dxos/keys';
15
16
  import { useClient } from '@dxos/react-client';
16
17
  import { type ThemedClassName } from '@dxos/react-ui';
17
18
  import {
18
- EditorMenuProvider,
19
+ type EditorRootProps,
19
20
  type EditorToolbarState,
20
- type UseEditorMenu,
21
- useEditorMenu,
22
- useEditorToolbar,
21
+ createEditorController,
22
+ useEditorContext,
23
23
  } from '@dxos/react-ui-editor';
24
24
  import { type PreviewBlock, type PreviewOptions } from '@dxos/ui-editor';
25
25
  import { composable, composableProps } from '@dxos/ui-theme';
@@ -31,7 +31,7 @@ import {
31
31
  type UseEditorMenuOptionsProps,
32
32
  useEditorMenuOptions,
33
33
  useExtensions,
34
- } from '../../hooks';
34
+ } from '#hooks';
35
35
 
36
36
  import {
37
37
  MarkdownEditorContent as NaturalMarkdownEditorContent,
@@ -49,34 +49,34 @@ import {
49
49
  type MarkdownEditorContextValue = {
50
50
  id: string;
51
51
  attendableId?: string;
52
- setEditorView: (view: EditorView) => void;
53
- extensions: Extension[];
54
52
  previewBlocks: PreviewBlock[];
55
- toolbarState: Atom.Writable<EditorToolbarState>;
56
- popoverMenu: Omit<UseEditorMenu, 'extension'>;
57
- } & (Pick<ExtensionsOptions, 'compact' | 'viewMode'> &
58
- Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange'>);
53
+ } & Pick<ExtensionsOptions, 'compact' | 'viewMode'> &
54
+ Pick<NaturalMarkdownToolbarProps, 'onAction' | 'onFileUpload' | 'onViewModeChange'>;
59
55
 
60
56
  const [MarkdownEditorContextProvider, useMarkdownEditorContext] =
61
57
  createContext<MarkdownEditorContextValue>('MarkdownEditor.Context');
62
58
 
59
+ /**
60
+ * Props to spread onto `Editor.Root` from `MarkdownEditorProvider`'s render callback.
61
+ */
62
+ export type MarkdownEditorEditorRootProps = Omit<EditorRootProps, 'children'>;
63
+
63
64
  //
64
- // MarkdownEditor.Root
65
+ // MarkdownEditorProvider
65
66
  //
66
67
 
67
- type MarkdownEditorRootProps = PropsWithChildren<
68
- {
69
- object?: DocumentType;
70
- extensions?: Extension[];
71
- } & Pick<
72
- MarkdownEditorContextValue,
73
- 'id' | 'attendableId' | 'viewMode' | 'compact' | 'onAction' | 'onFileUpload' | 'onViewModeChange'
74
- > &
75
- Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &
76
- Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings' | 'onSelectObject'>
77
- >;
78
-
79
- const MarkdownEditorRoot = ({
68
+ export type MarkdownEditorProviderProps = {
69
+ object?: DocumentType;
70
+ extensions?: Extension[];
71
+ children: (editorRootProps: MarkdownEditorEditorRootProps) => ReactNode;
72
+ } & Pick<
73
+ MarkdownEditorContextValue,
74
+ 'id' | 'attendableId' | 'viewMode' | 'compact' | 'onAction' | 'onFileUpload' | 'onViewModeChange'
75
+ > &
76
+ Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &
77
+ Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings' | 'onSelectObject'>;
78
+
79
+ export const MarkdownEditorProvider = ({
80
80
  children,
81
81
  id,
82
82
  attendableId,
@@ -90,10 +90,10 @@ const MarkdownEditorRoot = ({
90
90
  slashCommandGroups,
91
91
  onLinkQuery,
92
92
  onSelectObject,
93
- ...props
94
- }: MarkdownEditorRootProps) => {
95
- const [editorView, setEditorView] = useState<EditorView>();
96
-
93
+ onAction,
94
+ onFileUpload,
95
+ onViewModeChange,
96
+ }: MarkdownEditorProviderProps) => {
97
97
  // Preview blocks.
98
98
  const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);
99
99
  const previewOptions = useMemo<PreviewOptions>(
@@ -109,14 +109,10 @@ const MarkdownEditorRoot = ({
109
109
  [object],
110
110
  );
111
111
 
112
- // Toolbar state.
113
- const toolbarState = useEditorToolbar({ viewMode });
114
-
115
- // Context menu.
116
- const menuOptions = useEditorMenuOptions({ editorView, slashCommandGroups, onLinkQuery });
117
- const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
112
+ // Context menu options (Editor.Root calls useEditorMenu with these props).
113
+ const menuOptions = useEditorMenuOptions({ slashCommandGroups, onLinkQuery });
118
114
 
119
- // Extensions.
115
+ // Core markdown extensions (popover/menu extension is added by Editor.Root).
120
116
  const coreExtensions = useExtensions({
121
117
  id,
122
118
  object,
@@ -130,67 +126,85 @@ const MarkdownEditorRoot = ({
130
126
  });
131
127
 
132
128
  const extensions = useMemo(
133
- () => [coreExtensions, menuExtension, extensionsProp].filter(isNonNullable),
134
- [coreExtensions, menuExtension, extensionsProp],
129
+ () => [coreExtensions, extensionsProp].filter(isNonNullable).flat(),
130
+ [coreExtensions, extensionsProp],
131
+ );
132
+
133
+ const editorRootProps = useMemo<MarkdownEditorEditorRootProps>(
134
+ () => ({
135
+ extensions,
136
+ viewMode,
137
+ getMenu: menuOptions.getMenu,
138
+ trigger: menuOptions.trigger,
139
+ placeholder: menuOptions.placeholder,
140
+ ...(menuOptions.filter !== undefined ? { filter: menuOptions.filter } : {}),
141
+ ...(menuOptions.triggerKey !== undefined ? { triggerKey: menuOptions.triggerKey } : {}),
142
+ }),
143
+ [extensions, viewMode, menuOptions],
144
+ );
145
+
146
+ const markdownContextValue = useMemo<MarkdownEditorContextValue>(
147
+ () => ({
148
+ id,
149
+ attendableId,
150
+ compact,
151
+ viewMode,
152
+ previewBlocks,
153
+ onAction,
154
+ onFileUpload,
155
+ onViewModeChange,
156
+ }),
157
+ [id, attendableId, compact, viewMode, previewBlocks, onAction, onFileUpload, onViewModeChange],
135
158
  );
136
159
 
137
160
  return (
138
- <MarkdownEditorContextProvider
139
- id={id}
140
- attendableId={attendableId}
141
- compact={compact}
142
- editorView={editorView}
143
- setEditorView={setEditorView}
144
- extensions={extensions}
145
- previewBlocks={previewBlocks}
146
- toolbarState={toolbarState}
147
- popoverMenu={menuProps}
148
- viewMode={viewMode}
149
- {...props}
150
- >
151
- {children}
152
- </MarkdownEditorContextProvider>
161
+ <MarkdownEditorContextProvider {...markdownContextValue}>{children(editorRootProps)}</MarkdownEditorContextProvider>
153
162
  );
154
163
  };
155
164
 
156
- MarkdownEditorRoot.displayName = 'MarkdownEditor.Root';
165
+ MarkdownEditorProvider.displayName = 'MarkdownEditor.Provider';
157
166
 
158
167
  //
159
- // MarkdownEditor.Main
168
+ // MarkdownEditor.Content
160
169
  //
161
170
 
162
171
  const MARKDOWN_EDITOR_CONTENT_NAME = 'MarkdownEditor.Content';
163
172
 
164
173
  type MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;
165
174
 
166
- const MarkdownEditorContent = composable<HTMLDivElement, MarkdownEditorContentProps>(({ ...props }, _forwardedRef) => {
167
- const {
168
- id,
169
- attendableId,
170
- compact,
171
- editorView,
172
- setEditorView,
173
- viewMode,
174
- toolbarState,
175
- extensions,
176
- popoverMenu: { groupsRef, ...menuProps },
177
- } = useMarkdownEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
175
+ const MarkdownEditorContent = composable<HTMLDivElement, MarkdownEditorContentProps>(
176
+ ({ compact: compactProp, ...props }, _forwardedRef) => {
177
+ const {
178
+ id,
179
+ attendableId,
180
+ compact = compactProp,
181
+ viewMode,
182
+ onFileUpload,
183
+ } = useMarkdownEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
184
+ const { extensions, setController, state } = useEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
185
+
186
+ const handleRef = useCallback(
187
+ (view: EditorView | null) => {
188
+ setController(createEditorController(view));
189
+ },
190
+ [setController],
191
+ );
178
192
 
179
- return (
180
- <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>
193
+ return (
181
194
  <NaturalMarkdownEditorContent
182
195
  {...composableProps(props)}
183
196
  id={id}
184
197
  attendableId={attendableId}
185
198
  compact={compact}
186
199
  viewMode={viewMode}
187
- toolbarState={toolbarState}
200
+ toolbarState={state as Atom.Writable<EditorToolbarState>}
188
201
  extensions={extensions}
189
- ref={setEditorView}
202
+ onFileUpload={onFileUpload}
203
+ ref={handleRef}
190
204
  />
191
- </EditorMenuProvider>
192
- );
193
- });
205
+ );
206
+ },
207
+ );
194
208
 
195
209
  MarkdownEditorContent.displayName = MARKDOWN_EDITOR_CONTENT_NAME;
196
210
 
@@ -201,19 +215,20 @@ MarkdownEditorContent.displayName = MARKDOWN_EDITOR_CONTENT_NAME;
201
215
  const MARKDOWN_EDITOR_TOOLBAR_NAME = 'MarkdownEditor.Toolbar';
202
216
 
203
217
  type MarkdownEditorToolbarProps = ThemedClassName<
204
- Omit<NaturalMarkdownToolbarProps, 'state' | 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'id'>
218
+ Omit<NaturalMarkdownToolbarProps, 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'id'>
205
219
  >;
206
220
 
207
221
  const MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {
208
- const { id, attendableId, editorView, toolbarState, onAction, onFileUpload, onViewModeChange } =
222
+ const { id, attendableId, onAction, onFileUpload, onViewModeChange } =
209
223
  useMarkdownEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
210
224
 
225
+ const { controller } = useEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
226
+
211
227
  return (
212
228
  <NaturalMarkdownToolbar
213
229
  {...props}
214
230
  id={attendableId ?? id}
215
- editorView={editorView}
216
- state={toolbarState}
231
+ editorView={controller?.view ?? undefined}
217
232
  onAction={onAction}
218
233
  onFileUpload={onFileUpload}
219
234
  onViewModeChange={onViewModeChange}
@@ -251,23 +266,21 @@ const PreviewBlock = ({ el, link }: PreviewBlock) => {
251
266
  const subject = client.graph.makeRef(dxn).target;
252
267
  const data = useMemo(() => ({ subject }), [subject]);
253
268
 
254
- return createPortal(<Surface.Surface role='card--content' data={data} limit={1} />, el);
269
+ return createPortal(<Surface.Surface type={AppSurface.Card} data={data} limit={1} />, el);
255
270
  };
256
271
 
257
272
  //
258
273
  // MarkdownEditor
259
274
  //
260
275
 
276
+ /** @private */
261
277
  export const MarkdownEditor = {
262
- Root: MarkdownEditorRoot,
263
278
  Content: MarkdownEditorContent,
264
279
  Toolbar: MarkdownEditorToolbar,
265
280
  Blocks: MarkdownEditorBlocks,
266
281
  };
267
282
 
268
- export type {
269
- MarkdownEditorRootProps,
270
- MarkdownEditorContentProps,
271
- MarkdownEditorToolbarProps,
272
- MarkdownEditorBlocksProps,
273
- };
283
+ export type { MarkdownEditorContentProps, MarkdownEditorToolbarProps, MarkdownEditorBlocksProps };
284
+
285
+ /** @deprecated Use `MarkdownEditorProviderProps`. */
286
+ export type MarkdownEditorRootProps = MarkdownEditorProviderProps;
@@ -17,9 +17,8 @@ import {
17
17
  import {
18
18
  type EditorSelectionState,
19
19
  type EditorStateStore,
20
- type EditorViewMode,
21
20
  type ThemeExtensionsOptions,
22
- compactSlots,
21
+ mobileSlots,
23
22
  createBasicExtensions,
24
23
  createMarkdownExtensions,
25
24
  createThemeExtensions,
@@ -27,13 +26,14 @@ import {
27
26
  documentSlots,
28
27
  formattingListener,
29
28
  processEditorPayload,
30
- stackItemContentEditorClassNames,
29
+ editorClassNames,
31
30
  } from '@dxos/ui-editor';
31
+ import { type EditorViewMode } from '@dxos/ui-editor/types';
32
32
  import { mx } from '@dxos/ui-theme';
33
33
  import { isTruthy } from '@dxos/util';
34
34
 
35
- import { meta } from '../../meta';
36
- import { MarkdownCapabilities } from '../../types';
35
+ import { meta } from '#meta';
36
+ import { MarkdownCapabilities } from '#types';
37
37
 
38
38
  import { type MarkdownEditorToolbarProps } from './MarkdownEditorToolbar';
39
39
 
@@ -52,6 +52,7 @@ export type MarkdownEditorContentProps = ThemedClassName<{
52
52
  Pick<MarkdownEditorToolbarProps, 'onFileUpload'> &
53
53
  Pick<ThemeExtensionsOptions, 'slots'>;
54
54
 
55
+ // TODO(burdon): Move controller to Root.
55
56
  export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEditorContentProps>(
56
57
  (
57
58
  {
@@ -87,8 +88,6 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
87
88
  // Restore last selection and scroll point.
88
89
  const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);
89
90
 
90
- console.log(slots, compact, compactSlots);
91
-
92
91
  const {
93
92
  parentRef,
94
93
  view: editorView,
@@ -99,21 +98,19 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
99
98
  id,
100
99
  scrollTo,
101
100
  selection,
102
- // TODO(wittjosiah): Autofocus based on layout is racy.
103
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
104
101
  selectionEnd: true,
105
102
  }),
106
103
  initialValue,
107
104
  extensions: [
108
105
  createBasicExtensions({
109
106
  readOnly: viewMode === 'readonly',
110
- placeholder: t('editor placeholder'),
107
+ placeholder: t('editor.placeholder'),
111
108
  scrollPastEnd: !compact,
112
109
  search: true,
113
110
  }),
114
111
  createThemeExtensions({
115
112
  themeMode,
116
- slots: slots ?? (compact ? compactSlots : documentSlots),
113
+ slots: slots ?? (compact ? mobileSlots : documentSlots),
117
114
  syntaxHighlighting: true,
118
115
  }),
119
116
  createMarkdownExtensions(),
@@ -133,7 +130,7 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
133
130
  extensions,
134
131
  ].filter(isTruthy),
135
132
  }),
136
- [id, viewMode, themeMode, extensions],
133
+ [id, viewMode, themeMode, extensions, compact],
137
134
  );
138
135
 
139
136
  useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);
@@ -151,10 +148,9 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
151
148
  return (
152
149
  <div
153
150
  {...focusAttributes}
154
- role='none'
151
+ className={mx(editorClassNames(role), classNames)}
155
152
  data-testid='composer.markdownRoot'
156
153
  data-popover-collision-boundary={true}
157
- className={mx(stackItemContentEditorClassNames(role), classNames)}
158
154
  ref={parentRef}
159
155
  />
160
156
  );