@dxos/plugin-markdown 0.8.4-main.9735255 → 0.8.4-main.abd8ff62ef

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 (379) hide show
  1. package/dist/lib/browser/blueprints/index.mjs +46 -4
  2. package/dist/lib/browser/blueprints/index.mjs.map +4 -4
  3. package/dist/lib/browser/chunk-DNSKDWUL.mjs +156 -0
  4. package/dist/lib/browser/chunk-DNSKDWUL.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-SW6IK2GJ.mjs +124 -0
  6. package/dist/lib/browser/chunk-SW6IK2GJ.mjs.map +7 -0
  7. package/dist/lib/browser/create-SRADQOTE.mjs +29 -0
  8. package/dist/lib/browser/create-SRADQOTE.mjs.map +7 -0
  9. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs +21 -0
  10. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +109 -126
  12. package/dist/lib/browser/index.mjs.map +4 -4
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/open-ANTKMST5.mjs +20 -0
  15. package/dist/lib/browser/open-ANTKMST5.mjs.map +7 -0
  16. package/dist/lib/browser/operations/index.mjs +13 -0
  17. package/dist/lib/browser/operations/index.mjs.map +7 -0
  18. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs +48 -0
  19. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs.map +7 -0
  20. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs +25 -0
  21. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs.map +7 -0
  22. package/dist/lib/browser/types/index.mjs +5 -7
  23. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs +44 -0
  24. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs.map +7 -0
  25. package/dist/lib/node-esm/blueprints/index.mjs +46 -4
  26. package/dist/lib/node-esm/blueprints/index.mjs.map +4 -4
  27. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs +157 -0
  28. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs.map +7 -0
  29. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs +125 -0
  30. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs.map +7 -0
  31. package/dist/lib/node-esm/create-6JGQPPQ6.mjs +30 -0
  32. package/dist/lib/node-esm/create-6JGQPPQ6.mjs.map +7 -0
  33. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs +22 -0
  34. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs.map +7 -0
  35. package/dist/lib/node-esm/index.mjs +109 -126
  36. package/dist/lib/node-esm/index.mjs.map +4 -4
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/open-GB6HNBHS.mjs +21 -0
  39. package/dist/lib/node-esm/open-GB6HNBHS.mjs.map +7 -0
  40. package/dist/lib/node-esm/operations/index.mjs +14 -0
  41. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  42. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs +49 -0
  43. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs.map +7 -0
  44. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs +26 -0
  45. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs.map +7 -0
  46. package/dist/lib/node-esm/types/index.mjs +5 -7
  47. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs +45 -0
  48. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs.map +7 -0
  49. package/dist/types/src/MarkdownPlugin.d.ts +1 -0
  50. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  51. package/dist/types/src/{cli/plugin.d.ts → MarkdownPlugin.node.d.ts} +2 -1
  52. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  53. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  54. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  55. package/dist/types/src/blueprints/index.d.ts +1 -1
  56. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  57. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  58. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  59. package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
  60. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  61. package/dist/types/src/capabilities/app-graph-serializer.d.ts +5 -0
  62. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  63. package/dist/types/src/capabilities/artifact-definition.d.ts +5 -0
  64. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
  65. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  66. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  67. package/dist/types/src/capabilities/index.d.ts +9 -7
  68. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/node.d.ts +4 -0
  70. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  71. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  72. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  73. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  74. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  75. package/dist/types/src/capabilities/settings.d.ts +6 -0
  76. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  77. package/dist/types/src/capabilities/state.d.ts +6 -0
  78. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  79. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
  80. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  81. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +33 -22
  82. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  83. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +3 -3
  84. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +6 -3
  86. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  87. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +7 -6
  88. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  89. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -6
  90. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  91. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  92. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  94. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  95. package/dist/types/src/components/index.d.ts +3 -8
  96. package/dist/types/src/components/index.d.ts.map +1 -1
  97. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +1 -1
  98. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  99. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +1 -1
  100. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  101. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts +15 -0
  102. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts.map +1 -0
  103. package/dist/types/src/containers/MarkdownCard/index.d.ts +3 -0
  104. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  105. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  106. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  107. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  108. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  109. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  110. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  111. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  112. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  113. package/dist/types/src/containers/index.d.ts +6 -0
  114. package/dist/types/src/containers/index.d.ts.map +1 -0
  115. package/dist/types/src/hooks/index.d.ts +0 -1
  116. package/dist/types/src/hooks/index.d.ts.map +1 -1
  117. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  118. package/dist/types/src/hooks/useExtensions.d.ts +10 -6
  119. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  120. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  121. package/dist/types/src/index.d.ts +2 -1
  122. package/dist/types/src/index.d.ts.map +1 -1
  123. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  124. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  125. package/dist/types/src/operations/create.d.ts +5 -0
  126. package/dist/types/src/operations/create.d.ts.map +1 -0
  127. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  128. package/dist/types/src/operations/definitions.d.ts +64 -0
  129. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  130. package/dist/types/src/operations/index.d.ts +4 -0
  131. package/dist/types/src/operations/index.d.ts.map +1 -0
  132. package/dist/types/src/operations/open.d.ts +5 -0
  133. package/dist/types/src/operations/open.d.ts.map +1 -0
  134. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  135. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  136. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  137. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  138. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  139. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  140. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  141. package/dist/types/src/testing.d.ts.map +1 -1
  142. package/dist/types/src/translations.d.ts +74 -37
  143. package/dist/types/src/translations.d.ts.map +1 -1
  144. package/dist/types/src/types/Markdown.d.ts +15 -16
  145. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  146. package/dist/types/src/types/Settings.d.ts +17 -0
  147. package/dist/types/src/types/Settings.d.ts.map +1 -0
  148. package/dist/types/src/types/capabilities.d.ts +15 -3
  149. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  150. package/dist/types/src/types/events.d.ts.map +1 -1
  151. package/dist/types/src/types/index.d.ts +2 -3
  152. package/dist/types/src/types/index.d.ts.map +1 -1
  153. package/dist/types/src/types/types.d.ts +1 -0
  154. package/dist/types/src/types/types.d.ts.map +1 -1
  155. package/dist/types/src/util.d.ts +2 -2
  156. package/dist/types/src/util.d.ts.map +1 -1
  157. package/dist/types/tsconfig.tsbuildinfo +1 -1
  158. package/package.json +94 -75
  159. package/src/MarkdownPlugin.node.ts +41 -0
  160. package/src/MarkdownPlugin.test.ts +26 -0
  161. package/src/MarkdownPlugin.tsx +52 -45
  162. package/src/blueprints/index.ts +1 -1
  163. package/src/blueprints/markdown-blueprint.ts +14 -9
  164. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +4 -3
  165. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +14 -9
  166. package/src/capabilities/{artifact-definition/artifact-definition.ts → artifact-definition.ts} +6 -6
  167. package/src/capabilities/blueprint-definition.ts +19 -0
  168. package/src/capabilities/index.ts +14 -7
  169. package/src/capabilities/node.ts +11 -0
  170. package/src/capabilities/operation-handler.ts +16 -0
  171. package/src/capabilities/react-surface.tsx +127 -0
  172. package/src/capabilities/{settings/settings.ts → settings.ts} +5 -4
  173. package/src/capabilities/state.ts +47 -0
  174. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  175. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +39 -34
  176. package/src/components/MarkdownEditor/MarkdownEditor.tsx +139 -102
  177. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +26 -18
  178. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +37 -56
  179. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  180. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -109
  181. package/src/components/MarkdownSettings/index.ts +1 -1
  182. package/src/components/index.ts +4 -12
  183. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +22 -12
  184. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  185. package/src/containers/MarkdownCard/MarkdownEditableCard.tsx +42 -0
  186. package/src/containers/MarkdownCard/index.ts +6 -0
  187. package/src/containers/MarkdownCard/snippet.ts +54 -0
  188. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +36 -24
  189. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  190. package/src/containers/MarkdownContainer/index.ts +6 -0
  191. package/src/containers/index.ts +13 -0
  192. package/src/hooks/index.ts +0 -1
  193. package/src/hooks/useEditorMenuOptions.ts +3 -3
  194. package/src/hooks/useExtensions.tsx +86 -98
  195. package/src/hooks/useLinkQuery.ts +31 -6
  196. package/src/index.ts +5 -1
  197. package/src/meta.ts +1 -1
  198. package/src/operations/create-markdown.ts +20 -0
  199. package/src/operations/create.conversations.json +1 -0
  200. package/src/operations/create.test.ts +97 -0
  201. package/src/operations/create.ts +27 -0
  202. package/src/operations/definitions.ts +120 -0
  203. package/src/operations/index.ts +16 -0
  204. package/src/operations/open.ts +25 -0
  205. package/src/operations/scroll-to-anchor.ts +39 -0
  206. package/src/operations/set-view-mode.ts +24 -0
  207. package/src/operations/update-markdown.ts +51 -0
  208. package/src/operations/update.conversations.json +1 -0
  209. package/src/operations/update.test.ts +214 -0
  210. package/src/testing.ts +2 -2
  211. package/src/translations.ts +26 -36
  212. package/src/types/Markdown.ts +18 -25
  213. package/src/types/Settings.ts +65 -0
  214. package/src/types/capabilities.ts +19 -6
  215. package/src/types/events.ts +5 -4
  216. package/src/types/index.ts +3 -4
  217. package/src/types/types.ts +4 -1
  218. package/src/util.tsx +5 -5
  219. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs +0 -12
  220. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs.map +0 -7
  221. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
  222. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs.map +0 -7
  223. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs +0 -32
  224. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
  225. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs +0 -58
  226. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
  227. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
  228. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
  229. package/dist/lib/browser/chunk-BX73DASG.mjs +0 -702
  230. package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-CUGDX7KA.mjs +0 -8
  232. package/dist/lib/browser/chunk-CUGDX7KA.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
  234. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-JOXYQLKH.mjs +0 -55
  236. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
  237. package/dist/lib/browser/chunk-KDKXFKDN.mjs +0 -104
  238. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
  239. package/dist/lib/browser/chunk-LMO5UVKL.mjs +0 -167
  240. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
  241. package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
  242. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
  243. package/dist/lib/browser/chunk-WIPSLZ6L.mjs +0 -60
  244. package/dist/lib/browser/chunk-WIPSLZ6L.mjs.map +0 -7
  245. package/dist/lib/browser/cli/index.mjs +0 -32
  246. package/dist/lib/browser/cli/index.mjs.map +0 -7
  247. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs +0 -53
  248. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
  249. package/dist/lib/browser/react-surface-SRPLD3ED.mjs +0 -213
  250. package/dist/lib/browser/react-surface-SRPLD3ED.mjs.map +0 -7
  251. package/dist/lib/browser/settings-JY5JE7MI.mjs +0 -35
  252. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
  253. package/dist/lib/browser/state-QE7VSJWJ.mjs +0 -29
  254. package/dist/lib/browser/state-QE7VSJWJ.mjs.map +0 -7
  255. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs +0 -13
  256. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs.map +0 -7
  257. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
  258. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
  259. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs +0 -33
  260. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
  261. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs +0 -59
  262. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
  263. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
  264. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs +0 -105
  266. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
  267. package/dist/lib/node-esm/chunk-44VJC3QF.mjs +0 -56
  268. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
  269. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs +0 -703
  270. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
  271. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
  272. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
  273. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs +0 -168
  274. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
  275. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs +0 -61
  276. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs.map +0 -7
  277. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
  278. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
  279. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs +0 -10
  280. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs.map +0 -7
  281. package/dist/lib/node-esm/cli/index.mjs +0 -33
  282. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  283. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs +0 -54
  284. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
  285. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs +0 -214
  286. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs.map +0 -7
  287. package/dist/lib/node-esm/settings-4UGMPIRY.mjs +0 -36
  288. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
  289. package/dist/lib/node-esm/state-LXE5XIN4.mjs +0 -30
  290. package/dist/lib/node-esm/state-LXE5XIN4.mjs.map +0 -7
  291. package/dist/types/src/blueprints/functions/create.d.ts +0 -8
  292. package/dist/types/src/blueprints/functions/create.d.ts.map +0 -1
  293. package/dist/types/src/blueprints/functions/create.test.d.ts.map +0 -1
  294. package/dist/types/src/blueprints/functions/index.d.ts +0 -4
  295. package/dist/types/src/blueprints/functions/index.d.ts.map +0 -1
  296. package/dist/types/src/blueprints/functions/open.d.ts +0 -7
  297. package/dist/types/src/blueprints/functions/open.d.ts.map +0 -1
  298. package/dist/types/src/blueprints/functions/update.d.ts +0 -6
  299. package/dist/types/src/blueprints/functions/update.d.ts.map +0 -1
  300. package/dist/types/src/blueprints/functions/update.test.d.ts.map +0 -1
  301. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +0 -5
  302. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  303. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  304. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  305. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +0 -5
  306. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  307. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  308. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  309. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +0 -5
  310. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  311. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  312. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -10
  314. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  316. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  317. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  318. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  319. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  320. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  321. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  322. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  323. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  324. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  325. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  326. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  327. package/dist/types/src/capabilities/settings/settings.d.ts +0 -6
  328. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  329. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  330. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  331. package/dist/types/src/capabilities/state/state.d.ts +0 -5
  332. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  333. package/dist/types/src/cli/index.d.ts +0 -2
  334. package/dist/types/src/cli/index.d.ts.map +0 -1
  335. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  336. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  337. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  338. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  339. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  340. package/dist/types/src/components/MarkdownContainer.d.ts +0 -28
  341. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  342. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -59
  343. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  344. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  345. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  346. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  347. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  348. package/dist/types/src/types/MarkdownAction.d.ts +0 -66
  349. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  350. package/src/blueprints/functions/create.conversations.json +0 -1
  351. package/src/blueprints/functions/create.test.ts +0 -125
  352. package/src/blueprints/functions/create.ts +0 -34
  353. package/src/blueprints/functions/index.ts +0 -7
  354. package/src/blueprints/functions/open.ts +0 -33
  355. package/src/blueprints/functions/update.conversations.json +0 -1
  356. package/src/blueprints/functions/update.test.ts +0 -149
  357. package/src/blueprints/functions/update.ts +0 -38
  358. package/src/capabilities/anchor-sort/index.ts +0 -7
  359. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  360. package/src/capabilities/artifact-definition/index.ts +0 -7
  361. package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -25
  362. package/src/capabilities/blueprint-definition/index.ts +0 -7
  363. package/src/capabilities/operation-resolver/index.ts +0 -7
  364. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -45
  365. package/src/capabilities/react-surface/index.ts +0 -7
  366. package/src/capabilities/react-surface/react-surface.tsx +0 -100
  367. package/src/capabilities/settings/index.ts +0 -7
  368. package/src/capabilities/state/index.ts +0 -7
  369. package/src/capabilities/state/state.ts +0 -31
  370. package/src/cli/index.ts +0 -5
  371. package/src/cli/plugin.ts +0 -29
  372. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -64
  373. package/src/components/MarkdownCard/index.ts +0 -9
  374. package/src/components/MarkdownContainer.tsx +0 -111
  375. package/src/components/Suggestions.stories.tsx +0 -215
  376. package/src/hooks/useSelectCurrentThread.tsx +0 -61
  377. package/src/types/MarkdownAction.ts +0 -59
  378. /package/dist/types/src/{blueprints/functions → operations}/create.test.d.ts +0 -0
  379. /package/dist/types/src/{blueprints/functions → operations}/update.test.d.ts +0 -0
@@ -6,20 +6,23 @@ 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
- import { Surface } from '@dxos/app-framework/react';
12
+ import { Surface } from '@dxos/app-framework/ui';
13
+ import { AppSurface } from '@dxos/app-toolkit/ui';
14
+ import { Obj } from '@dxos/echo';
13
15
  import { DXN } from '@dxos/keys';
14
16
  import { useClient } from '@dxos/react-client';
17
+ import { type ThemedClassName } from '@dxos/react-ui';
15
18
  import {
16
- EditorMenuProvider,
19
+ type EditorRootProps,
17
20
  type EditorToolbarState,
18
- type UseEditorMenu,
19
- useEditorMenu,
20
- useEditorToolbar,
21
+ createEditorController,
22
+ useEditorContext,
21
23
  } from '@dxos/react-ui-editor';
22
24
  import { type PreviewBlock, type PreviewOptions } from '@dxos/ui-editor';
25
+ import { composable, composableProps } from '@dxos/ui-theme';
23
26
  import { isNonNullable } from '@dxos/util';
24
27
 
25
28
  import {
@@ -28,7 +31,7 @@ import {
28
31
  type UseEditorMenuOptionsProps,
29
32
  useEditorMenuOptions,
30
33
  useExtensions,
31
- } from '../../hooks';
34
+ } from '#hooks';
32
35
 
33
36
  import {
34
37
  MarkdownEditorContent as NaturalMarkdownEditorContent,
@@ -45,198 +48,232 @@ import {
45
48
 
46
49
  type MarkdownEditorContextValue = {
47
50
  id: string;
48
- setEditorView: (view: EditorView) => void;
49
- extensions: Extension[];
51
+ attendableId?: string;
50
52
  previewBlocks: PreviewBlock[];
51
- toolbarState: Atom.Writable<EditorToolbarState>;
52
- popoverMenu: Omit<UseEditorMenu, 'extension'>;
53
- } & (Pick<ExtensionsOptions, 'viewMode'> &
54
- Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange'>);
53
+ } & Pick<ExtensionsOptions, 'compact' | 'viewMode'> &
54
+ Pick<NaturalMarkdownToolbarProps, 'onAction' | 'onFileUpload' | 'onViewModeChange'>;
55
55
 
56
56
  const [MarkdownEditorContextProvider, useMarkdownEditorContext] =
57
57
  createContext<MarkdownEditorContextValue>('MarkdownEditor.Context');
58
58
 
59
+ /**
60
+ * Props to spread onto `Editor.Root` from `MarkdownEditorProvider`'s render callback.
61
+ */
62
+ export type MarkdownEditorEditorRootProps = Omit<EditorRootProps, 'children'>;
63
+
59
64
  //
60
- // MarkdownEditor.Root
65
+ // MarkdownEditorProvider
61
66
  //
62
67
 
63
- type MarkdownEditorRootProps = PropsWithChildren<
64
- {
65
- object?: DocumentType;
66
- extensions?: Extension[];
67
- } & Pick<MarkdownEditorContextValue, 'id' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'viewMode'> &
68
- Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &
69
- Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings'>
70
- >;
71
-
72
- 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 = ({
73
80
  children,
74
81
  id,
82
+ attendableId,
75
83
  object,
76
- editorStateStore,
77
- selectionManager,
78
84
  settings,
85
+ compact,
79
86
  viewMode,
87
+ selectionManager,
88
+ editorStateStore,
80
89
  extensions: extensionsProp,
81
90
  slashCommandGroups,
82
91
  onLinkQuery,
83
- ...props
84
- }: MarkdownEditorRootProps) => {
85
- const [editorView, setEditorView] = useState<EditorView>();
86
-
92
+ onSelectObject,
93
+ onAction,
94
+ onFileUpload,
95
+ onViewModeChange,
96
+ }: MarkdownEditorProviderProps) => {
87
97
  // Preview blocks.
88
98
  const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);
89
99
  const previewOptions = useMemo<PreviewOptions>(
90
100
  () => ({
101
+ db: Obj.isObject(object) ? Obj.getDatabase(object) : undefined,
91
102
  addBlockContainer: (block) => {
92
103
  setPreviewBlocks((prev) => [...prev, block]);
93
104
  },
94
105
  removeBlockContainer: ({ link }) => {
95
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
106
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.dxn !== link.dxn));
96
107
  },
97
108
  }),
98
- [],
109
+ [object],
99
110
  );
100
111
 
101
- // Toolbar state.
102
- const toolbarState = useEditorToolbar({ viewMode });
112
+ // Context menu options (Editor.Root calls useEditorMenu with these props).
113
+ const menuOptions = useEditorMenuOptions({ slashCommandGroups, onLinkQuery });
103
114
 
104
- // Context menu.
105
- const menuOptions = useEditorMenuOptions({
106
- editorView,
107
- slashCommandGroups,
108
- onLinkQuery,
109
- });
110
- const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
111
-
112
- // Extensions.
115
+ // Core markdown extensions (popover/menu extension is added by Editor.Root).
113
116
  const coreExtensions = useExtensions({
114
117
  id,
115
118
  object,
119
+ compact,
120
+ viewMode,
121
+ selectionManager,
116
122
  editorStateStore,
117
123
  previewOptions,
118
- selectionManager,
119
124
  settings,
120
- viewMode,
125
+ onSelectObject,
121
126
  });
122
127
 
123
128
  const extensions = useMemo(
124
- () => [coreExtensions, menuExtension, extensionsProp].filter(isNonNullable),
125
- [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],
126
158
  );
127
159
 
128
160
  return (
129
- <MarkdownEditorContextProvider
130
- id={id}
131
- editorView={editorView}
132
- setEditorView={setEditorView}
133
- extensions={extensions}
134
- previewBlocks={previewBlocks}
135
- toolbarState={toolbarState}
136
- popoverMenu={menuProps}
137
- viewMode={viewMode}
138
- {...props}
139
- >
140
- {children}
141
- </MarkdownEditorContextProvider>
161
+ <MarkdownEditorContextProvider {...markdownContextValue}>{children(editorRootProps)}</MarkdownEditorContextProvider>
142
162
  );
143
163
  };
144
164
 
145
- MarkdownEditorRoot.displayName = 'MarkdownEditor.Root';
165
+ MarkdownEditorProvider.displayName = 'MarkdownEditor.Provider';
146
166
 
147
167
  //
148
- // MarkdownEditor.Main
168
+ // MarkdownEditor.Content
149
169
  //
150
170
 
171
+ const MARKDOWN_EDITOR_CONTENT_NAME = 'MarkdownEditor.Content';
172
+
151
173
  type MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;
152
174
 
153
- const MarkdownEditorContent = (props: MarkdownEditorContentProps) => {
154
- const {
155
- id,
156
- editorView,
157
- setEditorView,
158
- viewMode,
159
- toolbarState,
160
- extensions,
161
- popoverMenu: { groupsRef, ...menuProps },
162
- } = useMarkdownEditorContext(MarkdownEditorContent.displayName);
175
+ const MarkdownEditorContent = composable<HTMLDivElement, MarkdownEditorContentProps>(({ ...props }, _forwardedRef) => {
176
+ const { id, attendableId, compact, viewMode, onFileUpload } = useMarkdownEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
177
+
178
+ const { extensions, setController, state } = useEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
179
+
180
+ const handleRef = useCallback(
181
+ (view: EditorView | null) => {
182
+ setController(createEditorController(view));
183
+ },
184
+ [setController],
185
+ );
163
186
 
164
187
  return (
165
- <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>
166
- <NaturalMarkdownEditorContent
167
- {...props}
168
- id={id}
169
- viewMode={viewMode}
170
- toolbarState={toolbarState}
171
- extensions={extensions}
172
- ref={setEditorView}
173
- />
174
- </EditorMenuProvider>
188
+ <NaturalMarkdownEditorContent
189
+ {...composableProps(props)}
190
+ id={id}
191
+ attendableId={attendableId}
192
+ compact={compact}
193
+ viewMode={viewMode}
194
+ toolbarState={state as Atom.Writable<EditorToolbarState>}
195
+ extensions={extensions}
196
+ onFileUpload={onFileUpload}
197
+ ref={handleRef}
198
+ />
175
199
  );
176
- };
200
+ });
177
201
 
178
- MarkdownEditorContent.displayName = 'MarkdownEditor.Content';
202
+ MarkdownEditorContent.displayName = MARKDOWN_EDITOR_CONTENT_NAME;
179
203
 
180
204
  //
181
205
  // MarkdownEditor.Toolbar
182
206
  //
183
207
 
184
- type MarkdownEditorToolbarProps = Omit<
185
- NaturalMarkdownToolbarProps,
186
- 'state' | 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange'
208
+ const MARKDOWN_EDITOR_TOOLBAR_NAME = 'MarkdownEditor.Toolbar';
209
+
210
+ type MarkdownEditorToolbarProps = ThemedClassName<
211
+ Omit<NaturalMarkdownToolbarProps, 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'id'>
187
212
  >;
188
213
 
189
214
  const MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {
190
- const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar.displayName);
215
+ const { id, attendableId, onAction, onFileUpload, onViewModeChange } =
216
+ useMarkdownEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
217
+
218
+ const { controller } = useEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
191
219
 
192
- return <NaturalMarkdownToolbar {...props} {...rootProps} state={toolbarState} />;
220
+ return (
221
+ <NaturalMarkdownToolbar
222
+ {...props}
223
+ id={attendableId ?? id}
224
+ editorView={controller?.view ?? undefined}
225
+ onAction={onAction}
226
+ onFileUpload={onFileUpload}
227
+ onViewModeChange={onViewModeChange}
228
+ />
229
+ );
193
230
  };
194
231
 
195
- MarkdownEditorToolbar.displayName = 'MarkdownEditor.Toolbar';
232
+ MarkdownEditorToolbar.displayName = MARKDOWN_EDITOR_TOOLBAR_NAME;
196
233
 
197
234
  //
198
235
  // MarkdownEditor.Blocks (embedded objects)
199
236
  //
200
237
 
238
+ const MARKDOWN_EDITOR_BLOCKS_NAME = 'MarkdownEditor.Blocks';
239
+
201
240
  type MarkdownEditorBlocksProps = {};
202
241
 
203
242
  const MarkdownEditorBlocks = (_props: MarkdownEditorBlocksProps) => {
204
- const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);
243
+ const { previewBlocks } = useMarkdownEditorContext(MARKDOWN_EDITOR_BLOCKS_NAME);
205
244
 
206
245
  return (
207
246
  <>
208
247
  {previewBlocks.map(({ link, el }) => (
209
- <PreviewBlock key={link.ref} link={link} el={el} />
248
+ <PreviewBlock key={link.dxn} link={link} el={el} />
210
249
  ))}
211
250
  </>
212
251
  );
213
252
  };
214
253
 
215
- MarkdownEditorBlocks.displayName = 'MarkdownEditor.Blocks';
254
+ MarkdownEditorBlocks.displayName = MARKDOWN_EDITOR_BLOCKS_NAME;
216
255
 
217
256
  const PreviewBlock = ({ el, link }: PreviewBlock) => {
218
257
  const client = useClient();
219
- const dxn = DXN.parse(link.ref);
258
+ const dxn = DXN.parse(link.dxn);
220
259
  const subject = client.graph.makeRef(dxn).target;
221
260
  const data = useMemo(() => ({ subject }), [subject]);
222
261
 
223
- return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);
262
+ return createPortal(<Surface.Surface type={AppSurface.Card} data={data} limit={1} />, el);
224
263
  };
225
264
 
226
265
  //
227
266
  // MarkdownEditor
228
267
  //
229
268
 
269
+ /** @private */
230
270
  export const MarkdownEditor = {
231
- Root: MarkdownEditorRoot,
232
271
  Content: MarkdownEditorContent,
233
272
  Toolbar: MarkdownEditorToolbar,
234
273
  Blocks: MarkdownEditorBlocks,
235
274
  };
236
275
 
237
- export type {
238
- MarkdownEditorRootProps,
239
- MarkdownEditorContentProps,
240
- MarkdownEditorToolbarProps,
241
- MarkdownEditorBlocksProps,
242
- };
276
+ export type { MarkdownEditorContentProps, MarkdownEditorToolbarProps, MarkdownEditorBlocksProps };
277
+
278
+ /** @deprecated Use `MarkdownEditorProviderProps`. */
279
+ export type MarkdownEditorRootProps = MarkdownEditorProviderProps;
@@ -6,6 +6,7 @@ import { type EditorView } from '@codemirror/view';
6
6
  import { type Atom, RegistryContext } from '@effect-atom/atom-react';
7
7
  import React, { forwardRef, useCallback, useContext, useEffect, useImperativeHandle, useMemo } from 'react';
8
8
 
9
+ import { useCapabilities } from '@dxos/app-framework/ui';
9
10
  import { type ThemedClassName, useThemeContext, useTranslation } from '@dxos/react-ui';
10
11
  import {
11
12
  type EditorMenuGroup,
@@ -16,53 +17,56 @@ import {
16
17
  import {
17
18
  type EditorSelectionState,
18
19
  type EditorStateStore,
19
- type EditorViewMode,
20
20
  type ThemeExtensionsOptions,
21
+ mobileSlots,
21
22
  createBasicExtensions,
22
23
  createMarkdownExtensions,
23
24
  createThemeExtensions,
24
25
  dropFile,
25
- editorSlots,
26
+ documentSlots,
26
27
  formattingListener,
27
28
  processEditorPayload,
28
- stackItemContentEditorClassNames,
29
+ editorClassNames,
29
30
  } from '@dxos/ui-editor';
31
+ import { type EditorViewMode } from '@dxos/ui-editor/types';
30
32
  import { mx } from '@dxos/ui-theme';
31
33
  import { isTruthy } from '@dxos/util';
32
34
 
33
- import { useSelectCurrentThread } from '../../hooks';
34
- import { meta } from '../../meta';
35
+ import { meta } from '#meta';
36
+ import { MarkdownCapabilities } from '#types';
35
37
 
36
38
  import { type MarkdownEditorToolbarProps } from './MarkdownEditorToolbar';
37
39
 
38
40
  export type MarkdownEditorContentProps = ThemedClassName<{
39
41
  id: string;
42
+ attendableId?: string;
40
43
  role?: string;
44
+ compact?: boolean;
41
45
  viewMode?: EditorViewMode;
42
- scrollPastEnd?: boolean;
43
46
  slashCommandGroups?: EditorMenuGroup[];
44
47
  editorStateStore?: EditorStateStore;
45
48
  toolbarState?: Atom.Writable<EditorToolbarState>;
46
49
  onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;
47
50
  }> &
48
- // prettier-ignore
49
51
  Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &
50
52
  Pick<MarkdownEditorToolbarProps, 'onFileUpload'> &
51
53
  Pick<ThemeExtensionsOptions, 'slots'>;
52
54
 
55
+ // TODO(burdon): Move controller to Root.
53
56
  export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEditorContentProps>(
54
57
  (
55
58
  {
56
59
  classNames,
57
60
  id,
61
+ attendableId,
58
62
  role,
63
+ compact,
59
64
  viewMode,
60
65
  initialValue,
61
66
  editorStateStore,
62
67
  toolbarState,
63
68
  extensions,
64
- scrollPastEnd,
65
- slots = editorSlots,
69
+ slots,
66
70
  onFileUpload,
67
71
  },
68
72
  forwardedRef,
@@ -94,21 +98,19 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
94
98
  id,
95
99
  scrollTo,
96
100
  selection,
97
- // TODO(wittjosiah): Autofocus based on layout is racy.
98
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
99
101
  selectionEnd: true,
100
102
  }),
101
103
  initialValue,
102
104
  extensions: [
103
105
  createBasicExtensions({
104
106
  readOnly: viewMode === 'readonly',
105
- placeholder: t('editor placeholder'),
106
- scrollPastEnd: scrollPastEnd && role !== 'section',
107
+ placeholder: t('editor.placeholder'),
108
+ scrollPastEnd: !compact,
107
109
  search: true,
108
110
  }),
109
111
  createThemeExtensions({
110
112
  themeMode,
111
- slots,
113
+ slots: slots ?? (compact ? mobileSlots : documentSlots),
112
114
  syntaxHighlighting: true,
113
115
  }),
114
116
  createMarkdownExtensions(),
@@ -133,18 +135,24 @@ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEdito
133
135
 
134
136
  useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);
135
137
 
136
- useSelectCurrentThread(editorView, id);
138
+ const [editorViewRegistry] = useCapabilities(MarkdownCapabilities.EditorViews);
139
+ useEffect(() => {
140
+ if (editorView && editorViewRegistry) {
141
+ editorViewRegistry.register(attendableId ?? id, editorView, id);
142
+ return () => editorViewRegistry.unregister(attendableId ?? id);
143
+ }
144
+ }, [editorView, editorViewRegistry, attendableId, id]);
137
145
 
138
146
  useTest(editorView);
139
147
 
140
148
  return (
141
149
  <div
150
+ {...focusAttributes}
151
+ className={mx(editorClassNames(role), classNames)}
142
152
  role='none'
143
- ref={parentRef}
144
153
  data-testid='composer.markdownRoot'
145
- className={mx(stackItemContentEditorClassNames(role), classNames)}
146
154
  data-popover-collision-boundary={true}
147
- {...focusAttributes}
155
+ ref={parentRef}
148
156
  />
149
157
  );
150
158
  },
@@ -5,62 +5,43 @@
5
5
  import { type EditorView } from '@codemirror/view';
6
6
  import React, { useCallback, useState } from 'react';
7
7
 
8
- import { type Common } from '@dxos/app-framework';
9
- import { invariant } from '@dxos/invariant';
10
- import { type ThemedClassName } from '@dxos/react-ui';
11
- import { EditorToolbar, type EditorToolbarProps } from '@dxos/react-ui-editor';
12
- import { type EditorViewMode } from '@dxos/ui-editor';
8
+ import { type FileInfo } from '@dxos/app-toolkit';
9
+ import { Editor, type EditorToolbarProps } from '@dxos/react-ui-editor';
10
+ import { composable, composableProps } from '@dxos/ui-theme';
13
11
 
14
12
  import { FileUpload, type FileUploadAction } from './FileUpload';
15
13
 
16
- export type MarkdownEditorToolbarProps = ThemedClassName<
17
- {
18
- id: string;
19
- editorView?: EditorView;
20
- onFileUpload?: (file: File) => Promise<Common.FileInfo | undefined>;
21
- } & Pick<EditorToolbarProps, 'role' | 'state' | 'customActions' | 'onAction' | 'onViewModeChange'>
22
- >;
23
-
24
- export const MarkdownEditorToolbar = ({
25
- classNames,
26
- id,
27
- role,
28
- state,
29
- editorView,
30
- customActions,
31
- onAction,
32
- onFileUpload,
33
- onViewModeChange,
34
- }: MarkdownEditorToolbarProps) => {
35
- const [upload, setUpload] = useState<FileUploadAction | null>(null);
36
- const uploadRef = useCallback((next: FileUploadAction) => setUpload(() => next), []);
37
-
38
- const handleViewModeChange = useCallback((mode: EditorViewMode) => onViewModeChange?.(mode), [onViewModeChange]);
39
-
40
- const getView = useCallback(() => {
41
- invariant(editorView);
42
- return editorView;
43
- }, [editorView]);
44
-
45
- if (!editorView) {
46
- return <div />;
47
- }
48
-
49
- return (
50
- <>
51
- <EditorToolbar
52
- classNames={classNames}
53
- attendableId={id}
54
- role={role}
55
- state={state}
56
- customActions={customActions}
57
- getView={getView}
58
- onAction={onAction}
59
- onImageUpload={upload ?? undefined}
60
- onViewModeChange={handleViewModeChange}
61
- />
62
-
63
- {onFileUpload && <FileUpload ref={uploadRef} editorView={editorView} onFileUpload={onFileUpload} />}
64
- </>
65
- );
66
- };
14
+ export type MarkdownEditorToolbarProps = {
15
+ id: string;
16
+ editorView?: EditorView;
17
+ onFileUpload?: (file: File) => Promise<FileInfo | undefined>;
18
+ } & Pick<EditorToolbarProps, 'role' | 'customActions' | 'onAction' | 'onViewModeChange'>;
19
+
20
+ export const MarkdownEditorToolbar = composable<HTMLDivElement, MarkdownEditorToolbarProps>(
21
+ ({ id, role, editorView, customActions, onAction, onFileUpload, onViewModeChange, ...props }, forwardedRef) => {
22
+ const { className, ...rest } = composableProps(props);
23
+ const [upload, setUpload] = useState<FileUploadAction | null>(null);
24
+ const uploadRef = useCallback((next: FileUploadAction) => setUpload(() => next), []);
25
+
26
+ if (!editorView) {
27
+ return <div className={className} {...rest} ref={forwardedRef} />;
28
+ }
29
+
30
+ return (
31
+ <div role='none' className='contents' ref={forwardedRef}>
32
+ <Editor.Toolbar
33
+ {...rest}
34
+ classNames={className}
35
+ attendableId={id}
36
+ role={role}
37
+ customActions={customActions}
38
+ onAction={onAction}
39
+ onImageUpload={upload ?? undefined}
40
+ onViewModeChange={onViewModeChange}
41
+ />
42
+
43
+ {onFileUpload && <FileUpload ref={uploadRef} editorView={editorView} onFileUpload={onFileUpload} />}
44
+ </div>
45
+ );
46
+ },
47
+ );
@@ -0,0 +1,40 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+
7
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
8
+
9
+ import { translations } from '#translations';
10
+
11
+ import { MarkdownSettings } from './MarkdownSettings';
12
+
13
+ const meta = {
14
+ title: 'plugins/plugin-markdown/components/MarkdownSettings',
15
+ tags: ['settings'],
16
+ component: MarkdownSettings,
17
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
18
+ parameters: {
19
+ layout: 'fullscreen',
20
+ translations,
21
+ },
22
+ } satisfies Meta<typeof MarkdownSettings>;
23
+
24
+ export default meta;
25
+
26
+ type Story = StoryObj<typeof meta>;
27
+
28
+ export const Default: Story = {
29
+ args: {
30
+ settings: {
31
+ defaultViewMode: 'preview',
32
+ editorInputMode: 'default',
33
+ toolbar: true,
34
+ numberedHeadings: false,
35
+ folding: false,
36
+ experimental: false,
37
+ debug: false,
38
+ },
39
+ },
40
+ };