@dxos/plugin-markdown 0.8.4-main.dedc0f3 → 0.8.4-main.dfabb4ec29

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 (399) hide show
  1. package/dist/lib/neutral/EditableMarkdownCard-P4F4TIUM.mjs +32 -0
  2. package/dist/lib/neutral/EditableMarkdownCard-P4F4TIUM.mjs.map +7 -0
  3. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs +102 -0
  4. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs.map +7 -0
  5. package/dist/lib/neutral/MarkdownContainer-2BDGD3PL.mjs +126 -0
  6. package/dist/lib/neutral/MarkdownContainer-2BDGD3PL.mjs.map +7 -0
  7. package/dist/lib/neutral/MarkdownPlugin.mjs +58 -0
  8. package/dist/lib/neutral/MarkdownPlugin.mjs.map +7 -0
  9. package/dist/lib/neutral/MarkdownPlugin.node.mjs +25 -0
  10. package/dist/lib/neutral/MarkdownPlugin.node.mjs.map +7 -0
  11. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs +32 -0
  12. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs.map +7 -0
  13. package/dist/lib/neutral/anchor-sort-L4VCKDO6.mjs +32 -0
  14. package/dist/lib/neutral/anchor-sort-L4VCKDO6.mjs.map +7 -0
  15. package/dist/lib/neutral/app-graph-serializer-3XFKP4ER.mjs +56 -0
  16. package/dist/lib/neutral/app-graph-serializer-3XFKP4ER.mjs.map +7 -0
  17. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs +15 -0
  18. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs.map +7 -0
  19. package/dist/lib/neutral/blueprints/index.mjs +8 -0
  20. package/dist/lib/neutral/capabilities/index.mjs +25 -0
  21. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  22. package/dist/lib/neutral/capabilities/node.mjs +11 -0
  23. package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
  24. package/dist/lib/neutral/chunk-3LYCPEVP.mjs +21 -0
  25. package/dist/lib/neutral/chunk-3LYCPEVP.mjs.map +7 -0
  26. package/dist/lib/neutral/chunk-6N7AD3IU.mjs +8 -0
  27. package/dist/lib/neutral/chunk-6N7AD3IU.mjs.map +7 -0
  28. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  29. package/dist/lib/neutral/chunk-KDN4GKG2.mjs +98 -0
  30. package/dist/lib/neutral/chunk-KDN4GKG2.mjs.map +7 -0
  31. package/dist/lib/neutral/chunk-LXNSKCPD.mjs +44 -0
  32. package/dist/lib/neutral/chunk-LXNSKCPD.mjs.map +7 -0
  33. package/dist/lib/neutral/chunk-SOLAMEK3.mjs +276 -0
  34. package/dist/lib/neutral/chunk-SOLAMEK3.mjs.map +7 -0
  35. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs +30 -0
  36. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs.map +7 -0
  37. package/dist/lib/neutral/components/index.mjs +370 -0
  38. package/dist/lib/neutral/components/index.mjs.map +7 -0
  39. package/dist/lib/neutral/containers/index.mjs +13 -0
  40. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  41. package/dist/lib/neutral/create-3PGJ2NEK.mjs +28 -0
  42. package/dist/lib/neutral/create-3PGJ2NEK.mjs.map +7 -0
  43. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs +20 -0
  44. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs.map +7 -0
  45. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs +27 -0
  46. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs.map +7 -0
  47. package/dist/lib/neutral/hooks/index.mjs +322 -0
  48. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  49. package/dist/lib/neutral/index.mjs +42 -0
  50. package/dist/lib/neutral/meta.json +1 -0
  51. package/dist/lib/neutral/meta.mjs +8 -0
  52. package/dist/lib/neutral/open-WCYGBLAG.mjs +20 -0
  53. package/dist/lib/neutral/open-WCYGBLAG.mjs.map +7 -0
  54. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs +13 -0
  55. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs.map +7 -0
  56. package/dist/lib/neutral/operations/index.mjs +8 -0
  57. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  58. package/dist/lib/neutral/plugin.mjs +16 -0
  59. package/dist/lib/neutral/plugin.mjs.map +7 -0
  60. package/dist/lib/neutral/react-surface-TB4TY57T.mjs +119 -0
  61. package/dist/lib/neutral/react-surface-TB4TY57T.mjs.map +7 -0
  62. package/dist/lib/neutral/scroll-to-anchor-6FIOKVKT.mjs +47 -0
  63. package/dist/lib/neutral/scroll-to-anchor-6FIOKVKT.mjs.map +7 -0
  64. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs +24 -0
  65. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs.map +7 -0
  66. package/dist/lib/neutral/settings-TDGDLCUR.mjs +34 -0
  67. package/dist/lib/neutral/settings-TDGDLCUR.mjs.map +7 -0
  68. package/dist/lib/neutral/state-5COCF5PN.mjs +44 -0
  69. package/dist/lib/neutral/state-5COCF5PN.mjs.map +7 -0
  70. package/dist/lib/neutral/testing.mjs +20 -0
  71. package/dist/lib/neutral/testing.mjs.map +7 -0
  72. package/dist/lib/neutral/translations.mjs +43 -0
  73. package/dist/lib/neutral/translations.mjs.map +7 -0
  74. package/dist/lib/neutral/types/index.mjs +16 -0
  75. package/dist/lib/neutral/types/index.mjs.map +7 -0
  76. package/dist/lib/neutral/update-markdown-5EDRD3SH.mjs +44 -0
  77. package/dist/lib/neutral/update-markdown-5EDRD3SH.mjs.map +7 -0
  78. package/dist/types/src/MarkdownPlugin.d.ts +3 -1
  79. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  80. package/dist/types/src/MarkdownPlugin.node.d.ts +4 -0
  81. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  82. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  83. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  84. package/dist/types/src/blueprints/index.d.ts +2 -0
  85. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  86. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  87. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  88. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  89. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  90. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  91. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  92. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -1
  93. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  94. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -4
  95. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
  96. package/dist/types/src/capabilities/comment-config.d.ts +12 -0
  97. package/dist/types/src/capabilities/comment-config.d.ts.map +1 -0
  98. package/dist/types/src/capabilities/create-object.d.ts +11 -0
  99. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  100. package/dist/types/src/capabilities/index.d.ts +22 -18
  101. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  102. package/dist/types/src/capabilities/node.d.ts +10 -0
  103. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  104. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  105. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  107. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/settings.d.ts +4 -2
  109. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  110. package/dist/types/src/capabilities/state.d.ts +4 -9
  111. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  112. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  113. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  114. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +52 -21
  115. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  116. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +5 -110
  117. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  118. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +33 -0
  119. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  120. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +13 -0
  121. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  122. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  123. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  124. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  125. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  126. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  127. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  128. package/dist/types/src/components/index.d.ts +3 -3
  129. package/dist/types/src/components/index.d.ts.map +1 -1
  130. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts +15 -0
  131. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts.map +1 -0
  132. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts +3 -0
  133. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts.map +1 -0
  134. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  135. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  136. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  137. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  138. package/dist/types/src/containers/MarkdownCard/index.d.ts +2 -0
  139. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  140. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  141. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  142. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  143. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  144. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  145. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  146. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  147. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  148. package/dist/types/src/containers/index.d.ts +6 -0
  149. package/dist/types/src/containers/index.d.ts.map +1 -0
  150. package/dist/types/src/hooks/index.d.ts +3 -1
  151. package/dist/types/src/hooks/index.d.ts.map +1 -1
  152. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  153. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  154. package/dist/types/src/hooks/useExtensions.d.ts +25 -0
  155. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  156. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  157. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  158. package/dist/types/src/index.d.ts +2 -3
  159. package/dist/types/src/index.d.ts.map +1 -1
  160. package/dist/types/src/meta.d.ts +2 -2
  161. package/dist/types/src/meta.d.ts.map +1 -1
  162. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  163. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  164. package/dist/types/src/operations/create.d.ts +5 -0
  165. package/dist/types/src/operations/create.d.ts.map +1 -0
  166. package/dist/types/src/operations/create.test.d.ts +2 -0
  167. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  168. package/dist/types/src/operations/index.d.ts +3 -0
  169. package/dist/types/src/operations/index.d.ts.map +1 -0
  170. package/dist/types/src/operations/open.d.ts +5 -0
  171. package/dist/types/src/operations/open.d.ts.map +1 -0
  172. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  173. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  174. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  175. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  176. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  177. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  178. package/dist/types/src/operations/update.test.d.ts +2 -0
  179. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  180. package/dist/types/src/plugin.d.ts +4 -0
  181. package/dist/types/src/plugin.d.ts.map +1 -0
  182. package/dist/types/src/testing.d.ts +6 -0
  183. package/dist/types/src/testing.d.ts.map +1 -0
  184. package/dist/types/src/translations.d.ts +74 -33
  185. package/dist/types/src/translations.d.ts.map +1 -1
  186. package/dist/types/src/types/Markdown.d.ts +32 -30
  187. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  188. package/dist/types/src/types/MarkdownCapabilities.d.ts +32 -0
  189. package/dist/types/src/types/MarkdownCapabilities.d.ts.map +1 -0
  190. package/dist/types/src/types/MarkdownEvents.d.ts +3 -0
  191. package/dist/types/src/types/MarkdownEvents.d.ts.map +1 -0
  192. package/dist/types/src/types/MarkdownOperation.d.ts +64 -0
  193. package/dist/types/src/types/MarkdownOperation.d.ts.map +1 -0
  194. package/dist/types/src/types/Settings.d.ts +17 -0
  195. package/dist/types/src/types/Settings.d.ts.map +1 -0
  196. package/dist/types/src/types/index.d.ts +5 -2
  197. package/dist/types/src/types/index.d.ts.map +1 -1
  198. package/dist/types/src/types/types.d.ts +3 -2
  199. package/dist/types/src/types/types.d.ts.map +1 -1
  200. package/dist/types/src/util.d.ts +8 -5
  201. package/dist/types/src/util.d.ts.map +1 -1
  202. package/dist/types/src/util.test.d.ts +2 -0
  203. package/dist/types/src/util.test.d.ts.map +1 -0
  204. package/dist/types/tsconfig.tsbuildinfo +1 -1
  205. package/package.json +150 -72
  206. package/src/MarkdownPlugin.node.ts +20 -0
  207. package/src/MarkdownPlugin.test.ts +26 -0
  208. package/src/MarkdownPlugin.tsx +47 -117
  209. package/src/blueprints/index.ts +5 -0
  210. package/src/blueprints/markdown-blueprint.ts +43 -0
  211. package/src/capabilities/anchor-sort.ts +29 -22
  212. package/src/capabilities/app-graph-serializer.ts +52 -42
  213. package/src/capabilities/artifact-definition.ts +84 -85
  214. package/src/capabilities/blueprint-definition.ts +11 -31
  215. package/src/capabilities/comment-config.ts +32 -0
  216. package/src/capabilities/create-object.ts +30 -0
  217. package/src/capabilities/index.ts +15 -12
  218. package/src/capabilities/node.ts +13 -0
  219. package/src/capabilities/operation-handler.ts +16 -0
  220. package/src/capabilities/react-surface.tsx +115 -103
  221. package/src/capabilities/settings.ts +30 -18
  222. package/src/capabilities/state.ts +41 -25
  223. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  224. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +63 -39
  225. package/src/components/MarkdownEditor/MarkdownEditor.tsx +248 -256
  226. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +169 -0
  227. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -0
  228. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  229. package/src/components/MarkdownSettings/MarkdownSettings.tsx +23 -96
  230. package/src/components/MarkdownSettings/index.ts +1 -1
  231. package/src/components/index.ts +4 -5
  232. package/src/containers/EditableMarkdownCard/EditableMarkdownCard.tsx +42 -0
  233. package/src/containers/EditableMarkdownCard/index.ts +6 -0
  234. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +68 -0
  235. package/src/containers/MarkdownCard/MarkdownCard.tsx +67 -0
  236. package/src/containers/MarkdownCard/index.ts +5 -0
  237. package/src/containers/MarkdownCard/snippet.ts +54 -0
  238. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  239. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  240. package/src/containers/MarkdownContainer/index.ts +6 -0
  241. package/src/containers/index.ts +11 -0
  242. package/src/hooks/index.ts +3 -1
  243. package/src/hooks/useEditorMenuOptions.ts +68 -0
  244. package/src/hooks/useExtensions.tsx +262 -0
  245. package/src/hooks/useLinkQuery.ts +92 -0
  246. package/src/index.ts +2 -5
  247. package/src/meta.ts +6 -6
  248. package/src/operations/create-markdown.ts +19 -0
  249. package/src/operations/create.conversations.json +1 -0
  250. package/src/operations/create.test.ts +97 -0
  251. package/src/operations/create.ts +26 -0
  252. package/src/operations/index.ts +14 -0
  253. package/src/operations/open.ts +25 -0
  254. package/src/operations/scroll-to-anchor.ts +38 -0
  255. package/src/operations/set-view-mode.ts +23 -0
  256. package/src/operations/update-markdown.ts +51 -0
  257. package/src/operations/update.conversations.json +1 -0
  258. package/src/operations/update.test.ts +214 -0
  259. package/src/plugin.ts +11 -0
  260. package/src/testing.ts +27 -0
  261. package/src/translations.ts +26 -32
  262. package/src/types/Markdown.ts +31 -32
  263. package/src/types/MarkdownCapabilities.ts +51 -0
  264. package/src/types/MarkdownEvents.ts +14 -0
  265. package/src/types/MarkdownOperation.ts +122 -0
  266. package/src/types/Settings.ts +65 -0
  267. package/src/types/index.ts +6 -2
  268. package/src/types/types.ts +7 -3
  269. package/src/util.test.ts +44 -0
  270. package/src/util.tsx +84 -9
  271. package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs +0 -80
  272. package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs.map +0 -7
  273. package/dist/lib/browser/MarkdownContainer-JW7TRDSA.mjs +0 -755
  274. package/dist/lib/browser/MarkdownContainer-JW7TRDSA.mjs.map +0 -7
  275. package/dist/lib/browser/anchor-sort-E33BSTYF.mjs +0 -32
  276. package/dist/lib/browser/anchor-sort-E33BSTYF.mjs.map +0 -7
  277. package/dist/lib/browser/app-graph-serializer-OX62DNPT.mjs +0 -51
  278. package/dist/lib/browser/app-graph-serializer-OX62DNPT.mjs.map +0 -7
  279. package/dist/lib/browser/blueprint-definition-5YKFUHRU.mjs +0 -11
  280. package/dist/lib/browser/chunk-BEE7VQPU.mjs +0 -78
  281. package/dist/lib/browser/chunk-BEE7VQPU.mjs.map +0 -7
  282. package/dist/lib/browser/chunk-F6JJLKLN.mjs +0 -102
  283. package/dist/lib/browser/chunk-F6JJLKLN.mjs.map +0 -7
  284. package/dist/lib/browser/chunk-LAVZ2W6X.mjs +0 -50
  285. package/dist/lib/browser/chunk-LAVZ2W6X.mjs.map +0 -7
  286. package/dist/lib/browser/chunk-ODB2PTBP.mjs +0 -28
  287. package/dist/lib/browser/chunk-ODB2PTBP.mjs.map +0 -7
  288. package/dist/lib/browser/chunk-OY6CGPOO.mjs +0 -16
  289. package/dist/lib/browser/chunk-OY6CGPOO.mjs.map +0 -7
  290. package/dist/lib/browser/chunk-SUOK6YMI.mjs +0 -22
  291. package/dist/lib/browser/chunk-SUOK6YMI.mjs.map +0 -7
  292. package/dist/lib/browser/chunk-Z7P6JGGW.mjs +0 -53
  293. package/dist/lib/browser/chunk-Z7P6JGGW.mjs.map +0 -7
  294. package/dist/lib/browser/index.mjs +0 -173
  295. package/dist/lib/browser/index.mjs.map +0 -7
  296. package/dist/lib/browser/intent-resolver-WDDH56JC.mjs +0 -62
  297. package/dist/lib/browser/intent-resolver-WDDH56JC.mjs.map +0 -7
  298. package/dist/lib/browser/meta.json +0 -1
  299. package/dist/lib/browser/react-surface-L3NTMD4D.mjs +0 -215
  300. package/dist/lib/browser/react-surface-L3NTMD4D.mjs.map +0 -7
  301. package/dist/lib/browser/settings-AABBTB4Q.mjs +0 -28
  302. package/dist/lib/browser/settings-AABBTB4Q.mjs.map +0 -7
  303. package/dist/lib/browser/state-FTHQQX7V.mjs +0 -37
  304. package/dist/lib/browser/state-FTHQQX7V.mjs.map +0 -7
  305. package/dist/lib/browser/toolkit-2AJTHG74.mjs +0 -74
  306. package/dist/lib/browser/toolkit-2AJTHG74.mjs.map +0 -7
  307. package/dist/lib/browser/types/index.mjs +0 -10
  308. package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs +0 -81
  309. package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs.map +0 -7
  310. package/dist/lib/node-esm/MarkdownContainer-HRGQXIXP.mjs +0 -756
  311. package/dist/lib/node-esm/MarkdownContainer-HRGQXIXP.mjs.map +0 -7
  312. package/dist/lib/node-esm/anchor-sort-ALP2NH24.mjs +0 -33
  313. package/dist/lib/node-esm/anchor-sort-ALP2NH24.mjs.map +0 -7
  314. package/dist/lib/node-esm/app-graph-serializer-56TD3BMX.mjs +0 -52
  315. package/dist/lib/node-esm/app-graph-serializer-56TD3BMX.mjs.map +0 -7
  316. package/dist/lib/node-esm/blueprint-definition-GVW67KGV.mjs +0 -12
  317. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs +0 -17
  318. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs.map +0 -7
  319. package/dist/lib/node-esm/chunk-DVK63TD3.mjs +0 -103
  320. package/dist/lib/node-esm/chunk-DVK63TD3.mjs.map +0 -7
  321. package/dist/lib/node-esm/chunk-FXILAQ5F.mjs +0 -79
  322. package/dist/lib/node-esm/chunk-FXILAQ5F.mjs.map +0 -7
  323. package/dist/lib/node-esm/chunk-J7A6TUB2.mjs +0 -54
  324. package/dist/lib/node-esm/chunk-J7A6TUB2.mjs.map +0 -7
  325. package/dist/lib/node-esm/chunk-JC2YWB5D.mjs +0 -24
  326. package/dist/lib/node-esm/chunk-JC2YWB5D.mjs.map +0 -7
  327. package/dist/lib/node-esm/chunk-O6EXWGGS.mjs +0 -51
  328. package/dist/lib/node-esm/chunk-O6EXWGGS.mjs.map +0 -7
  329. package/dist/lib/node-esm/chunk-VCG2U522.mjs +0 -29
  330. package/dist/lib/node-esm/chunk-VCG2U522.mjs.map +0 -7
  331. package/dist/lib/node-esm/index.mjs +0 -174
  332. package/dist/lib/node-esm/index.mjs.map +0 -7
  333. package/dist/lib/node-esm/intent-resolver-2I5HKCUU.mjs +0 -63
  334. package/dist/lib/node-esm/intent-resolver-2I5HKCUU.mjs.map +0 -7
  335. package/dist/lib/node-esm/meta.json +0 -1
  336. package/dist/lib/node-esm/react-surface-YZSZFR5D.mjs +0 -216
  337. package/dist/lib/node-esm/react-surface-YZSZFR5D.mjs.map +0 -7
  338. package/dist/lib/node-esm/settings-CXGR6DH4.mjs +0 -29
  339. package/dist/lib/node-esm/settings-CXGR6DH4.mjs.map +0 -7
  340. package/dist/lib/node-esm/state-NWMQ3XAI.mjs +0 -38
  341. package/dist/lib/node-esm/state-NWMQ3XAI.mjs.map +0 -7
  342. package/dist/lib/node-esm/toolkit-RC44I2MI.mjs +0 -75
  343. package/dist/lib/node-esm/toolkit-RC44I2MI.mjs.map +0 -7
  344. package/dist/lib/node-esm/types/index.mjs +0 -11
  345. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  346. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  347. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  348. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  349. package/dist/types/src/capabilities/toolkit.d.ts +0 -4
  350. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  351. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -7
  352. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  353. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -10
  354. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  355. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  356. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  357. package/dist/types/src/components/MarkdownContainer.d.ts +0 -18
  358. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  359. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -55
  360. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  361. package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
  362. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  363. package/dist/types/src/components/Toolbar.stories.d.ts +0 -48
  364. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  365. package/dist/types/src/events.d.ts +0 -4
  366. package/dist/types/src/events.d.ts.map +0 -1
  367. package/dist/types/src/extensions.d.ts +0 -22
  368. package/dist/types/src/extensions.d.ts.map +0 -1
  369. package/dist/types/src/functions/diff.d.ts +0 -6
  370. package/dist/types/src/functions/diff.d.ts.map +0 -1
  371. package/dist/types/src/functions/index.d.ts +0 -3
  372. package/dist/types/src/functions/index.d.ts.map +0 -1
  373. package/dist/types/src/functions/open.d.ts +0 -7
  374. package/dist/types/src/functions/open.d.ts.map +0 -1
  375. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  376. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  377. package/dist/types/src/types/MarkdownAction.d.ts +0 -33
  378. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  379. package/src/capabilities/capabilities.ts +0 -21
  380. package/src/capabilities/intent-resolver.ts +0 -57
  381. package/src/capabilities/toolkit.ts +0 -47
  382. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -79
  383. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -75
  384. package/src/components/MarkdownCard/index.ts +0 -9
  385. package/src/components/MarkdownContainer.stories.tsx +0 -100
  386. package/src/components/MarkdownContainer.tsx +0 -255
  387. package/src/components/Suggestions.stories.tsx +0 -218
  388. package/src/components/Toolbar.stories.tsx +0 -118
  389. package/src/events.ts +0 -11
  390. package/src/extensions.tsx +0 -300
  391. package/src/functions/diff.ts +0 -35
  392. package/src/functions/index.ts +0 -6
  393. package/src/functions/open.ts +0 -30
  394. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  395. package/src/types/MarkdownAction.ts +0 -29
  396. /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
  397. /package/dist/lib/{browser/blueprint-definition-5YKFUHRU.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  398. /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
  399. /package/dist/lib/{node-esm/blueprint-definition-GVW67KGV.mjs.map → neutral/meta.mjs.map} +0 -0
@@ -0,0 +1,169 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+ import { type Atom, RegistryContext } from '@effect-atom/atom-react';
7
+ import React, { forwardRef, useCallback, useContext, useEffect, useImperativeHandle, useMemo } from 'react';
8
+
9
+ import { useCapabilities } from '@dxos/app-framework/ui';
10
+ import { type ThemedClassName, useThemeContext, useTranslation } from '@dxos/react-ui';
11
+ import {
12
+ type EditorMenuGroup,
13
+ type EditorToolbarState,
14
+ type UseTextEditorProps,
15
+ useTextEditor,
16
+ } from '@dxos/react-ui-editor';
17
+ import {
18
+ type EditorSelectionState,
19
+ type EditorStateStore,
20
+ type ThemeExtensionsOptions,
21
+ mobileSlots,
22
+ createBasicExtensions,
23
+ createMarkdownExtensions,
24
+ createThemeExtensions,
25
+ dropFile,
26
+ documentSlots,
27
+ formattingListener,
28
+ processEditorPayload,
29
+ editorClassNames,
30
+ } from '@dxos/ui-editor';
31
+ import { type EditorViewMode } from '@dxos/ui-editor/types';
32
+ import { mx } from '@dxos/ui-theme';
33
+ import { isTruthy } from '@dxos/util';
34
+
35
+ import { meta } from '#meta';
36
+ import { MarkdownCapabilities } from '#types';
37
+
38
+ import { type MarkdownEditorToolbarProps } from './MarkdownEditorToolbar';
39
+
40
+ export type MarkdownEditorContentProps = ThemedClassName<{
41
+ id: string;
42
+ attendableId?: string;
43
+ role?: string;
44
+ compact?: boolean;
45
+ viewMode?: EditorViewMode;
46
+ slashCommandGroups?: EditorMenuGroup[];
47
+ editorStateStore?: EditorStateStore;
48
+ toolbarState?: Atom.Writable<EditorToolbarState>;
49
+ onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;
50
+ }> &
51
+ Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &
52
+ Pick<MarkdownEditorToolbarProps, 'onFileUpload'> &
53
+ Pick<ThemeExtensionsOptions, 'slots'>;
54
+
55
+ // TODO(burdon): Move controller to Root.
56
+ export const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEditorContentProps>(
57
+ (
58
+ {
59
+ classNames,
60
+ id,
61
+ attendableId,
62
+ role,
63
+ compact,
64
+ viewMode,
65
+ initialValue,
66
+ editorStateStore,
67
+ toolbarState,
68
+ extensions,
69
+ slots,
70
+ onFileUpload,
71
+ },
72
+ forwardedRef,
73
+ ) => {
74
+ const { t } = useTranslation(meta.id);
75
+ const { themeMode } = useThemeContext();
76
+ const registry = useContext(RegistryContext);
77
+
78
+ // Callback to update toolbar state atom.
79
+ const updateToolbarState = useCallback(
80
+ (formatting: EditorToolbarState) => {
81
+ if (toolbarState) {
82
+ registry.set(toolbarState, { ...registry.get(toolbarState), ...formatting });
83
+ }
84
+ },
85
+ [registry, toolbarState],
86
+ );
87
+
88
+ // Restore last selection and scroll point.
89
+ const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);
90
+
91
+ const {
92
+ parentRef,
93
+ view: editorView,
94
+ focusAttributes,
95
+ } = useTextEditor(
96
+ () => ({
97
+ ...(role !== 'section' && {
98
+ id,
99
+ scrollTo,
100
+ selection,
101
+ selectionEnd: true,
102
+ }),
103
+ initialValue,
104
+ extensions: [
105
+ createBasicExtensions({
106
+ readOnly: viewMode === 'readonly',
107
+ placeholder: t('editor.placeholder'),
108
+ scrollPastEnd: !compact,
109
+ search: true,
110
+ }),
111
+ createThemeExtensions({
112
+ themeMode,
113
+ slots: slots ?? (compact ? mobileSlots : documentSlots),
114
+ syntaxHighlighting: true,
115
+ }),
116
+ createMarkdownExtensions(),
117
+ toolbarState && formattingListener(updateToolbarState),
118
+ role !== 'section' &&
119
+ onFileUpload &&
120
+ dropFile({
121
+ // TODO(wittjosiah): Factor out to file uploader plugin.
122
+ onDrop: async (view, { files }) => {
123
+ const file = files[0];
124
+ const info = file && onFileUpload ? await onFileUpload(file) : undefined;
125
+ if (info) {
126
+ processEditorPayload(view, { type: 'image', data: info.url });
127
+ }
128
+ },
129
+ }),
130
+ extensions,
131
+ ].filter(isTruthy),
132
+ }),
133
+ [id, viewMode, themeMode, extensions, compact],
134
+ );
135
+
136
+ useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);
137
+
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]);
145
+
146
+ useTest(editorView);
147
+
148
+ return (
149
+ <div
150
+ {...focusAttributes}
151
+ className={mx(editorClassNames(role), classNames)}
152
+ data-testid='composer.markdownRoot'
153
+ data-popover-collision-boundary={true}
154
+ ref={parentRef}
155
+ />
156
+ );
157
+ },
158
+ );
159
+
160
+ // Expose editor view for playwright tests.
161
+ // TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.
162
+ const useTest = (view: EditorView | null) => {
163
+ useEffect(() => {
164
+ const composer = (window as any).composer;
165
+ if (composer) {
166
+ composer.editorView = view;
167
+ }
168
+ }, [view]);
169
+ };
@@ -0,0 +1,47 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+ import React, { useCallback, useState } from 'react';
7
+
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';
11
+
12
+ import { FileUpload, type FileUploadAction } from './FileUpload';
13
+
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 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
+ };
@@ -4,105 +4,32 @@
4
4
 
5
5
  import React from 'react';
6
6
 
7
- import { Input, Select, useTranslation } from '@dxos/react-ui';
8
- import { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';
9
- import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';
7
+ import { type AppSurface } from '@dxos/app-toolkit/ui';
8
+ import { Input } from '@dxos/react-ui';
9
+ import { Settings as SettingsForm, type SettingsFieldProps } from '@dxos/react-ui-form';
10
10
 
11
- import { meta } from '../../meta';
12
- import { type Markdown } from '../../types';
11
+ import { meta } from '#meta';
12
+ import { Markdown } from '#types';
13
13
 
14
- export const MarkdownSettings = ({ settings }: { settings: Markdown.Settings }) => {
15
- const { t } = useTranslation(meta.id);
14
+ export type MarkdownSettingsProps = AppSurface.SettingsArticleProps<Markdown.Settings>;
16
15
 
17
- // TODO(wittjosiah): Add skill test confirmation for entering vim mode.
18
- return (
19
- <ControlPage>
20
- <ControlSection title={t('settings title', { ns: meta.id })}>
21
- <ControlGroup>
22
- <ControlItemInput title={t('default view mode label')}>
23
- <Select.Root
24
- value={settings.defaultViewMode}
25
- onValueChange={(value) => {
26
- settings.defaultViewMode = value as EditorViewMode;
27
- }}
28
- >
29
- <Select.TriggerButton />
30
- <Select.Portal>
31
- <Select.Content>
32
- <Select.Viewport>
33
- {EditorViewModes.map((mode) => (
34
- <Select.Option key={mode} value={mode}>
35
- {t(`${mode} mode label`, { ns: 'react-ui-editor' })}
36
- </Select.Option>
37
- ))}
38
- </Select.Viewport>
39
- <Select.Arrow />
40
- </Select.Content>
41
- </Select.Portal>
42
- </Select.Root>
43
- </ControlItemInput>
44
-
45
- <ControlItemInput title={t('editor input mode label')}>
46
- <Select.Root
47
- value={settings.editorInputMode ?? 'default'}
48
- onValueChange={(value) => {
49
- settings.editorInputMode = value as EditorInputMode;
50
- }}
51
- >
52
- <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />
53
- <Select.Portal>
54
- <Select.Content>
55
- <Select.Viewport>
56
- {EditorInputModes.map((mode) => (
57
- <Select.Option key={mode} value={mode}>
58
- {t(`settings editor input mode ${mode} label`)}
59
- </Select.Option>
60
- ))}
61
- </Select.Viewport>
62
- <Select.Arrow />
63
- </Select.Content>
64
- </Select.Portal>
65
- </Select.Root>
66
- </ControlItemInput>
67
-
68
- <ControlItemInput title={t('settings toolbar label')}>
69
- <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />
70
- </ControlItemInput>
71
-
72
- <ControlItemInput title={t('settings numbered headings label')}>
73
- <Input.Switch
74
- checked={settings.numberedHeadings}
75
- onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}
76
- />
77
- </ControlItemInput>
16
+ const SnippetsField = ({ value, onChange, readonly }: SettingsFieldProps<string | undefined>) => (
17
+ <Input.TextArea disabled={readonly} rows={5} value={value ?? ''} onChange={(event) => onChange(event.target.value)} />
18
+ );
78
19
 
79
- <ControlItemInput title={t('settings folding label')}>
80
- <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />
81
- </ControlItemInput>
82
-
83
- <ControlItemInput title={t('settings experimental label')}>
84
- <Input.Switch
85
- checked={settings.experimental}
86
- onCheckedChange={(checked) => (settings.experimental = !!checked)}
87
- />
88
- </ControlItemInput>
89
-
90
- <ControlItemInput title={t('settings debug label')}>
91
- <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />
92
- </ControlItemInput>
93
-
94
- {settings.debug && (
95
- <ControlItemInput title={t('settings debug textarea label', { ns: meta.id })}>
96
- <Input.TextArea
97
- rows={5}
98
- value={settings.typewriter}
99
- onChange={({ target: { value } }) => (settings.typewriter = value)}
100
- placeholder={t('settings debug placeholder')}
101
- />
102
- </ControlItemInput>
103
- )}
104
- </ControlGroup>
105
- </ControlSection>
106
- </ControlPage>
20
+ export const MarkdownSettings = ({ settings, onSettingsChange }: MarkdownSettingsProps) => {
21
+ return (
22
+ <SettingsForm.Viewport>
23
+ <SettingsForm.Section title={meta.name ?? 'Editor'}>
24
+ <SettingsForm.FieldSet
25
+ readonly={!onSettingsChange}
26
+ schema={Markdown.Settings}
27
+ visible={(path, values) => path !== 'snippets' || !!values.debug}
28
+ fieldMap={{ snippets: SnippetsField }}
29
+ values={settings}
30
+ onValuesChanged={(values) => onSettingsChange?.(() => values)}
31
+ />
32
+ </SettingsForm.Section>
33
+ </SettingsForm.Viewport>
107
34
  );
108
35
  };
@@ -2,4 +2,4 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './MarkdownSettings';
5
+ export { MarkdownSettings as default } from './MarkdownSettings';
@@ -1,10 +1,9 @@
1
1
  //
2
- // Copyright 2023 DXOS.org
2
+ // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from 'react';
5
+ import { type ComponentType, lazy } from 'react';
6
6
 
7
- export * from './MarkdownSettings';
7
+ export * from './MarkdownEditor';
8
8
 
9
- export const MarkdownContainer = lazy(() => import('./MarkdownContainer'));
10
- export const MarkdownCard = lazy(() => import('./MarkdownCard'));
9
+ export const MarkdownSettings: ComponentType<any> = lazy(() => import('./MarkdownSettings'));
@@ -0,0 +1,42 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import React from 'react';
6
+
7
+ import { Obj } from '@dxos/echo';
8
+ import { useObject } from '@dxos/react-client/echo';
9
+ import { Card } from '@dxos/react-ui';
10
+ import { Editor } from '@dxos/react-ui-editor';
11
+ import { Text } from '@dxos/schema';
12
+
13
+ import { MarkdownEditor, MarkdownEditorProvider } from '#components';
14
+ import { Markdown } from '#types';
15
+
16
+ export type EditableMarkdownCardProps = { subject: Markdown.Document | Text.Text };
17
+
18
+ /**
19
+ * Full-bleed editable variant of {@link MarkdownCard}. Activated by the host
20
+ * passing `editable: true` on the card surface data (e.g. plugin-board cells).
21
+ * Renders a plain editor (no app-graph toolbar / file upload / link queries)
22
+ * so it stays self-contained inside the card; the regular MarkdownContainer
23
+ * remains the canonical surface for full article views.
24
+ */
25
+ export const EditableMarkdownCard = ({ subject }: EditableMarkdownCardProps) => {
26
+ const id = Obj.getDXN(subject).toString();
27
+ const [docContent] = useObject(Obj.instanceOf(Markdown.Document, subject) ? subject.content : undefined, 'content');
28
+ const [textContent] = useObject(Obj.instanceOf(Text.Text, subject) ? subject : undefined, 'content');
29
+ const initialValue = docContent ?? textContent;
30
+
31
+ return (
32
+ <Card.Section classNames='overflow-hidden'>
33
+ <MarkdownEditorProvider id={id} object={subject} viewMode='source'>
34
+ {(editorRootProps) => (
35
+ <Editor.Root {...editorRootProps}>
36
+ <MarkdownEditor.Content compact initialValue={initialValue} />
37
+ </Editor.Root>
38
+ )}
39
+ </MarkdownEditorProvider>
40
+ </Card.Section>
41
+ );
42
+ };
@@ -0,0 +1,6 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ export { EditableMarkdownCard, type EditableMarkdownCardProps } from './EditableMarkdownCard';
6
+ export { EditableMarkdownCard as default } from './EditableMarkdownCard';
@@ -0,0 +1,68 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React, { useMemo } from 'react';
7
+
8
+ import { OperationPlugin, RuntimePlugin } from '@dxos/app-framework';
9
+ import { withPluginManager } from '@dxos/app-framework/testing';
10
+ import { Obj } from '@dxos/echo';
11
+ import { ClientPlugin } from '@dxos/plugin-client/plugin';
12
+ import { Markdown } from '@dxos/plugin-markdown';
13
+ import { random } from '@dxos/random';
14
+ import { Card } from '@dxos/react-ui';
15
+ import { CardContainer } from '@dxos/react-ui-mosaic/testing';
16
+ import { withTheme } from '@dxos/react-ui/testing';
17
+
18
+ import { translations } from '#translations';
19
+
20
+ import { MarkdownCard, type MarkdownCardProps } from './MarkdownCard';
21
+
22
+ random.seed(1234);
23
+
24
+ const MarkdownCardStory = ({ ...args }: Omit<MarkdownCardProps, 'subject'>) => {
25
+ const subject = useMemo(
26
+ () =>
27
+ Markdown.make({
28
+ name: random.lorem.words(3),
29
+ content: '# Title\n' + random.lorem.paragraphs(5),
30
+ }),
31
+ [],
32
+ );
33
+
34
+ return (
35
+ <CardContainer icon='ph--text-aa--regular'>
36
+ <Card.Root border={false}>
37
+ <Card.Toolbar>
38
+ <Card.DragHandle />
39
+ <Card.Title>{Obj.getLabel(subject)}</Card.Title>
40
+ <Card.Menu />
41
+ </Card.Toolbar>
42
+ <MarkdownCard subject={subject} {...args} />
43
+ </Card.Root>
44
+ </CardContainer>
45
+ );
46
+ };
47
+
48
+ const meta: Meta<typeof MarkdownCardStory> = {
49
+ title: 'plugins/plugin-markdown/containers/MarkdownCard',
50
+ component: MarkdownCardStory,
51
+ decorators: [
52
+ withTheme(),
53
+ withPluginManager({
54
+ plugins: [OperationPlugin(), RuntimePlugin(), ClientPlugin({})],
55
+ }),
56
+ ],
57
+ parameters: {
58
+ layout: 'centered',
59
+ translations,
60
+ },
61
+ tags: ['cards'],
62
+ };
63
+
64
+ export default meta;
65
+
66
+ type Story = StoryObj<typeof meta>;
67
+
68
+ export const Default: Story = {};
@@ -0,0 +1,67 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import React, { useMemo } from 'react';
6
+
7
+ import { Obj } from '@dxos/echo';
8
+ import { Card, useTranslation } from '@dxos/react-ui';
9
+ import { Editor } from '@dxos/react-ui-editor';
10
+ import { Text } from '@dxos/schema';
11
+ import { mx } from '@dxos/ui-theme';
12
+
13
+ import { MarkdownEditor, MarkdownEditorProvider } from '#components';
14
+ import { meta } from '#meta';
15
+ import { Markdown } from '#types';
16
+
17
+ import { getContentSnippet } from '../../util';
18
+ import { snippet as snippetExtension } from './snippet';
19
+
20
+ export type MarkdownCardProps = { subject: Markdown.Document | Text.Text };
21
+
22
+ export const MarkdownCard = ({ subject }: MarkdownCardProps) => {
23
+ const { t } = useTranslation(meta.id);
24
+ const snippet = useMemo(() => getSnippet(subject), [subject]);
25
+ const extensions = useMemo(() => [snippetExtension({ height: 300, scale: 0.8 })], []);
26
+ const info = getInfo(subject);
27
+
28
+ return (
29
+ <Card.Content>
30
+ {snippet && (
31
+ <Card.Section className='relative px-1'>
32
+ <MarkdownEditorProvider id={subject.id} viewMode='readonly' extensions={extensions}>
33
+ {(editorRootProps) => (
34
+ <Editor.Root {...editorRootProps}>
35
+ <MarkdownEditor.Content initialValue={snippet} slots={{ content: { className: 'm-0' } }} />
36
+ </Editor.Root>
37
+ )}
38
+ </MarkdownEditorProvider>
39
+ <div
40
+ className={mx(
41
+ 'z-10 absolute bottom-0 inset-x-0 h-12 w-full',
42
+ 'bg-gradient-to-b from-transparent to-(--surface-bg) pointer-events-none',
43
+ )}
44
+ />
45
+ </Card.Section>
46
+ )}
47
+ <Card.Section>
48
+ <Card.Text classNames='px-1.5 text-xs text-description'>
49
+ {info.words} {t('words.label', { count: info.words })}
50
+ </Card.Text>
51
+ </Card.Section>
52
+ </Card.Content>
53
+ );
54
+ };
55
+
56
+ const getSnippet = (subject: Markdown.Document | Text.Text, fallback?: string, maxLines = 16) => {
57
+ if (Obj.instanceOf(Markdown.Document, subject)) {
58
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, maxLines);
59
+ } else if (Obj.instanceOf(Text.Text, subject)) {
60
+ return getContentSnippet(subject.content ?? fallback, maxLines);
61
+ }
62
+ };
63
+
64
+ const getInfo = (subject: Markdown.Document | Text.Text) => {
65
+ const text = (Obj.instanceOf(Markdown.Document, subject) ? subject.content?.target?.content : subject.content) ?? '';
66
+ return { words: text.split(' ').length };
67
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { MarkdownCard as default } from './MarkdownCard';
@@ -0,0 +1,54 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { EditorState } from '@codemirror/state';
6
+ import { EditorView } from '@codemirror/view';
7
+
8
+ export type SnippetOptions = {
9
+ /** Maximum height of the editor in pixels. Overflowing content is hidden. */
10
+ height: number;
11
+ /** Zoom factor applied to the editor (e.g. 0.5 renders at 50%). @default 1 */
12
+ scale?: number;
13
+ };
14
+
15
+ /**
16
+ * CodeMirror extension for rendering a non-scrollable snippet of editor content.
17
+ * Constrains the editor to the given height via CSS `max-height`, wraps long
18
+ * lines (`pre-wrap`), and disables scrolling entirely.
19
+ *
20
+ * NOTE: Uses CSS `zoom` rather than `transform: scale` because `zoom` affects
21
+ * layout, so line wrapping fills the full visual width of the container.
22
+ * `transform: scale` only scales paint output, leaving empty space on the right.
23
+ */
24
+ export const snippet = ({ height, scale = 1 }: SnippetOptions) => {
25
+ return [
26
+ EditorState.readOnly.of(true),
27
+ EditorView.editable.of(false),
28
+ EditorState.transactionFilter.of((tr) => {
29
+ if (tr.selection) {
30
+ return [];
31
+ } // Drop any selection changes.
32
+ return tr;
33
+ }),
34
+ EditorView.theme({
35
+ // Outer editor element: clip to the caller-specified height.
36
+ '&': {
37
+ maxHeight: `${height}px`,
38
+ overflow: 'hidden',
39
+ },
40
+ '.cm-scroller': {
41
+ // Prevent scroll; scale up the inner clip so the final pixel height matches `height`.
42
+ maxHeight: `${height / scale}px`,
43
+ overflow: 'hidden !important',
44
+ padding: '0',
45
+ },
46
+ '.cm-content': {
47
+ // zoom (unlike transform: scale) affects layout, so line-wrapping fills the full visual width of the container.
48
+ zoom: scale,
49
+ margin: '0',
50
+ padding: '0',
51
+ },
52
+ }),
53
+ ];
54
+ };