@dxos/plugin-markdown 0.8.4-main.c85a9c8dae → 0.8.4-main.d9fc60f731

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 (429) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +1 -1
  3. package/dist/lib/neutral/EditableMarkdownCard-AW7MD35U.mjs +34 -0
  4. package/dist/lib/neutral/EditableMarkdownCard-AW7MD35U.mjs.map +7 -0
  5. package/dist/lib/{browser/MarkdownContainer-KER2N5M2.mjs → neutral/MarkdownArticle-Z4QRU3WD.mjs} +52 -34
  6. package/dist/lib/neutral/MarkdownArticle-Z4QRU3WD.mjs.map +7 -0
  7. package/dist/lib/neutral/MarkdownCard-36P4AHYL.mjs +107 -0
  8. package/dist/lib/neutral/MarkdownCard-36P4AHYL.mjs.map +7 -0
  9. package/dist/lib/neutral/MarkdownPlugin.mjs +58 -0
  10. package/dist/lib/neutral/MarkdownPlugin.mjs.map +7 -0
  11. package/dist/lib/neutral/MarkdownPlugin.node.mjs +25 -0
  12. package/dist/lib/neutral/MarkdownPlugin.node.mjs.map +7 -0
  13. package/dist/lib/neutral/MarkdownPlugin.workerd.mjs +23 -0
  14. package/dist/lib/neutral/MarkdownPlugin.workerd.mjs.map +7 -0
  15. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs +32 -0
  16. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs.map +7 -0
  17. package/dist/lib/{browser/anchor-sort-EHJGOCYW.mjs → neutral/anchor-sort-37GOHBLW.mjs} +6 -8
  18. package/dist/lib/neutral/anchor-sort-37GOHBLW.mjs.map +7 -0
  19. package/dist/lib/{browser/app-graph-serializer-QBZDVASK.mjs → neutral/app-graph-serializer-EN5E3BMG.mjs} +14 -18
  20. package/dist/lib/neutral/app-graph-serializer-EN5E3BMG.mjs.map +7 -0
  21. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs +15 -0
  22. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs.map +7 -0
  23. package/dist/lib/{browser → neutral}/blueprints/index.mjs +2 -3
  24. package/dist/lib/neutral/capabilities/index.mjs +25 -0
  25. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  26. package/dist/lib/neutral/capabilities/node.mjs +11 -0
  27. package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
  28. package/dist/lib/neutral/chunk-36QFEVOZ.mjs +30 -0
  29. package/dist/lib/neutral/chunk-36QFEVOZ.mjs.map +7 -0
  30. package/dist/lib/neutral/chunk-A45UVZEH.mjs +285 -0
  31. package/dist/lib/neutral/chunk-A45UVZEH.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-E5NVTEKQ.mjs +8 -0
  33. package/dist/lib/neutral/chunk-E5NVTEKQ.mjs.map +7 -0
  34. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  35. package/dist/lib/neutral/chunk-KDN4GKG2.mjs +98 -0
  36. package/dist/lib/neutral/chunk-KDN4GKG2.mjs.map +7 -0
  37. package/dist/lib/neutral/chunk-LXNSKCPD.mjs +44 -0
  38. package/dist/lib/neutral/chunk-LXNSKCPD.mjs.map +7 -0
  39. package/dist/lib/neutral/comment-config-ZEA66BUR.mjs +31 -0
  40. package/dist/lib/neutral/comment-config-ZEA66BUR.mjs.map +7 -0
  41. package/dist/lib/neutral/components/index.mjs +371 -0
  42. package/dist/lib/neutral/components/index.mjs.map +7 -0
  43. package/dist/lib/neutral/containers/index.mjs +13 -0
  44. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  45. package/dist/lib/neutral/create-HONLDBVT.mjs +28 -0
  46. package/dist/lib/neutral/create-HONLDBVT.mjs.map +7 -0
  47. package/dist/lib/neutral/create-markdown-UCPD2Z3V.mjs +20 -0
  48. package/dist/lib/neutral/create-markdown-UCPD2Z3V.mjs.map +7 -0
  49. package/dist/lib/neutral/create-object-VU3KX663.mjs +28 -0
  50. package/dist/lib/neutral/create-object-VU3KX663.mjs.map +7 -0
  51. package/dist/lib/neutral/hooks/index.mjs +316 -0
  52. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  53. package/dist/lib/neutral/index.mjs +42 -0
  54. package/dist/lib/neutral/meta.json +1 -0
  55. package/dist/lib/neutral/meta.mjs +8 -0
  56. package/dist/lib/neutral/open-VVDMNJ7J.mjs +20 -0
  57. package/dist/lib/neutral/open-VVDMNJ7J.mjs.map +7 -0
  58. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs +13 -0
  59. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs.map +7 -0
  60. package/dist/lib/neutral/operations/index.mjs +8 -0
  61. package/dist/lib/neutral/operations/index.mjs.map +7 -0
  62. package/dist/lib/neutral/plugin.mjs +16 -0
  63. package/dist/lib/neutral/plugin.mjs.map +7 -0
  64. package/dist/lib/{node-esm/react-surface-LC5CI6VP.mjs → neutral/react-surface-EMYFM37T.mjs} +45 -42
  65. package/dist/lib/neutral/react-surface-EMYFM37T.mjs.map +7 -0
  66. package/dist/lib/neutral/scroll-to-anchor-Y3P676QG.mjs +47 -0
  67. package/dist/lib/neutral/scroll-to-anchor-Y3P676QG.mjs.map +7 -0
  68. package/dist/lib/neutral/set-view-mode-JZB7UXIF.mjs +24 -0
  69. package/dist/lib/neutral/set-view-mode-JZB7UXIF.mjs.map +7 -0
  70. package/dist/lib/{browser/settings-7FMWKB7N.mjs → neutral/settings-TDGDLCUR.mjs} +7 -11
  71. package/dist/lib/neutral/settings-TDGDLCUR.mjs.map +7 -0
  72. package/dist/lib/neutral/state-5COCF5PN.mjs +44 -0
  73. package/dist/lib/neutral/state-5COCF5PN.mjs.map +7 -0
  74. package/dist/lib/neutral/testing.mjs +30 -0
  75. package/dist/lib/neutral/testing.mjs.map +7 -0
  76. package/dist/lib/neutral/translations.mjs +44 -0
  77. package/dist/lib/neutral/translations.mjs.map +7 -0
  78. package/dist/lib/neutral/types/index.mjs +16 -0
  79. package/dist/lib/neutral/types/index.mjs.map +7 -0
  80. package/dist/lib/neutral/update-markdown-F25F4EPF.mjs +44 -0
  81. package/dist/lib/neutral/update-markdown-F25F4EPF.mjs.map +7 -0
  82. package/dist/types/src/MarkdownPlugin.d.ts +1 -0
  83. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  84. package/dist/types/src/{cli/plugin.d.ts → MarkdownPlugin.node.d.ts} +2 -1
  85. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  86. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  87. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  88. package/dist/types/src/MarkdownPlugin.workerd.d.ts +4 -0
  89. package/dist/types/src/MarkdownPlugin.workerd.d.ts.map +1 -0
  90. package/dist/types/src/blueprints/markdown-blueprint.d.ts +2 -2
  91. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  92. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  93. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  94. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  95. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  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 -7
  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.map +1 -0
  107. package/dist/types/src/capabilities/{settings/settings.d.ts → settings.d.ts} +1 -2
  108. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  109. package/dist/types/src/capabilities/state.d.ts +6 -0
  110. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  111. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +33 -22
  112. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  113. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +3 -3
  114. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  115. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +6 -3
  116. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  117. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +6 -5
  118. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  119. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +6 -0
  120. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -0
  121. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  122. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  123. package/dist/types/src/components/MarkdownSettings/index.d.ts +2 -0
  124. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -0
  125. package/dist/types/src/components/index.d.ts +2 -0
  126. package/dist/types/src/components/index.d.ts.map +1 -1
  127. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts +15 -0
  128. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts.map +1 -0
  129. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.stories.d.ts +9 -0
  130. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.stories.d.ts.map +1 -0
  131. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts +3 -0
  132. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts.map +1 -0
  133. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.d.ts +40 -0
  134. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.d.ts.map +1 -0
  135. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.stories.d.ts +97 -0
  136. package/dist/types/src/containers/MarkdownArticle/MarkdownArticle.stories.d.ts.map +1 -0
  137. package/dist/types/src/containers/MarkdownArticle/index.d.ts +3 -0
  138. package/dist/types/src/containers/MarkdownArticle/index.d.ts.map +1 -0
  139. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +1 -1
  140. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  141. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +1 -1
  142. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  143. package/dist/types/src/containers/MarkdownCard/index.d.ts +1 -2
  144. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -1
  145. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  146. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  147. package/dist/types/src/containers/index.d.ts +3 -3
  148. package/dist/types/src/containers/index.d.ts.map +1 -1
  149. package/dist/types/src/hooks/index.d.ts +0 -1
  150. package/dist/types/src/hooks/index.d.ts.map +1 -1
  151. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  152. package/dist/types/src/hooks/useExtensions.d.ts +10 -6
  153. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  154. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  155. package/dist/types/src/index.d.ts +2 -3
  156. package/dist/types/src/index.d.ts.map +1 -1
  157. package/dist/types/src/meta.d.ts +1 -1
  158. package/dist/types/src/meta.d.ts.map +1 -1
  159. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  160. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  161. package/dist/types/src/operations/create.d.ts +5 -0
  162. package/dist/types/src/operations/create.d.ts.map +1 -0
  163. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  164. package/dist/types/src/operations/index.d.ts +3 -0
  165. package/dist/types/src/operations/index.d.ts.map +1 -0
  166. package/dist/types/src/operations/open.d.ts +5 -0
  167. package/dist/types/src/operations/open.d.ts.map +1 -0
  168. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  169. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  170. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  171. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  172. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  173. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  174. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  175. package/dist/types/src/plugin.d.ts +4 -0
  176. package/dist/types/src/plugin.d.ts.map +1 -0
  177. package/dist/types/src/testing.d.ts +1 -0
  178. package/dist/types/src/testing.d.ts.map +1 -1
  179. package/dist/types/src/translations.d.ts +70 -62
  180. package/dist/types/src/translations.d.ts.map +1 -1
  181. package/dist/types/src/types/Markdown.d.ts +23 -22
  182. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  183. package/dist/types/src/types/MarkdownCapabilities.d.ts +32 -0
  184. package/dist/types/src/types/MarkdownCapabilities.d.ts.map +1 -0
  185. package/dist/types/src/types/MarkdownEvents.d.ts +3 -0
  186. package/dist/types/src/types/MarkdownEvents.d.ts.map +1 -0
  187. package/dist/types/src/types/MarkdownOperation.d.ts +64 -0
  188. package/dist/types/src/types/MarkdownOperation.d.ts.map +1 -0
  189. package/dist/types/src/types/Settings.d.ts +30 -0
  190. package/dist/types/src/types/Settings.d.ts.map +1 -0
  191. package/dist/types/src/types/index.d.ts +5 -5
  192. package/dist/types/src/types/index.d.ts.map +1 -1
  193. package/dist/types/src/types/types.d.ts +1 -0
  194. package/dist/types/src/types/types.d.ts.map +1 -1
  195. package/dist/types/src/util.d.ts +2 -2
  196. package/dist/types/src/util.d.ts.map +1 -1
  197. package/dist/types/tsconfig.tsbuildinfo +1 -1
  198. package/package.json +133 -90
  199. package/src/MarkdownPlugin.node.ts +20 -0
  200. package/src/MarkdownPlugin.test.ts +26 -0
  201. package/src/MarkdownPlugin.tsx +15 -55
  202. package/src/MarkdownPlugin.workerd.ts +19 -0
  203. package/src/blueprints/markdown-blueprint.ts +9 -12
  204. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +3 -3
  205. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +14 -10
  206. package/src/capabilities/{blueprint-definition/blueprint-definition.ts → blueprint-definition.ts} +3 -1
  207. package/src/capabilities/comment-config.ts +33 -0
  208. package/src/capabilities/create-object.ts +31 -0
  209. package/src/capabilities/index.ts +16 -7
  210. package/src/capabilities/node.ts +13 -0
  211. package/src/capabilities/operation-handler.ts +16 -0
  212. package/src/capabilities/react-surface.tsx +128 -0
  213. package/src/capabilities/{settings/settings.ts → settings.ts} +2 -2
  214. package/src/capabilities/state.ts +47 -0
  215. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +39 -36
  216. package/src/components/MarkdownEditor/MarkdownEditor.tsx +122 -94
  217. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +27 -17
  218. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +37 -57
  219. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  220. package/src/components/MarkdownSettings/MarkdownSettings.tsx +35 -0
  221. package/src/components/MarkdownSettings/index.ts +5 -0
  222. package/src/components/index.ts +4 -0
  223. package/src/containers/EditableMarkdownCard/EditableMarkdownCard.stories.tsx +86 -0
  224. package/src/containers/EditableMarkdownCard/EditableMarkdownCard.tsx +44 -0
  225. package/src/containers/EditableMarkdownCard/index.ts +6 -0
  226. package/src/containers/{MarkdownContainer/MarkdownContainer.stories.tsx → MarkdownArticle/MarkdownArticle.stories.tsx} +31 -26
  227. package/src/containers/MarkdownArticle/MarkdownArticle.tsx +146 -0
  228. package/src/containers/MarkdownArticle/index.ts +6 -0
  229. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +12 -12
  230. package/src/containers/MarkdownCard/MarkdownCard.tsx +38 -24
  231. package/src/containers/MarkdownCard/index.ts +1 -3
  232. package/src/containers/MarkdownCard/snippet.ts +54 -0
  233. package/src/containers/index.ts +3 -3
  234. package/src/hooks/index.ts +0 -1
  235. package/src/hooks/useEditorMenuOptions.ts +2 -2
  236. package/src/hooks/useExtensions.tsx +65 -42
  237. package/src/hooks/useLinkQuery.ts +42 -32
  238. package/src/index.ts +2 -6
  239. package/src/meta.ts +17 -7
  240. package/src/operations/create-markdown.ts +19 -0
  241. package/src/operations/create.conversations.json +1 -0
  242. package/src/{blueprints/functions → operations}/create.test.ts +30 -26
  243. package/src/operations/create.ts +26 -0
  244. package/src/operations/index.ts +14 -0
  245. package/src/operations/open.ts +25 -0
  246. package/src/operations/scroll-to-anchor.ts +38 -0
  247. package/src/operations/set-view-mode.ts +23 -0
  248. package/src/operations/update-markdown.ts +51 -0
  249. package/src/operations/update.conversations.json +1 -0
  250. package/src/{blueprints/functions → operations}/update.test.ts +50 -52
  251. package/src/plugin.ts +11 -0
  252. package/src/testing.ts +22 -9
  253. package/src/translations.ts +27 -38
  254. package/src/types/Markdown.ts +15 -31
  255. package/src/types/MarkdownCapabilities.ts +51 -0
  256. package/src/types/MarkdownEvents.ts +14 -0
  257. package/src/types/MarkdownOperation.ts +133 -0
  258. package/src/types/Settings.ts +85 -0
  259. package/src/types/index.ts +6 -6
  260. package/src/types/types.ts +4 -1
  261. package/src/util.tsx +4 -4
  262. package/dist/lib/browser/MarkdownCard-5NPSEJ2M.mjs +0 -61
  263. package/dist/lib/browser/MarkdownCard-5NPSEJ2M.mjs.map +0 -7
  264. package/dist/lib/browser/MarkdownContainer-KER2N5M2.mjs.map +0 -7
  265. package/dist/lib/browser/MarkdownSettings-2N4TT2FG.mjs +0 -106
  266. package/dist/lib/browser/MarkdownSettings-2N4TT2FG.mjs.map +0 -7
  267. package/dist/lib/browser/anchor-sort-EHJGOCYW.mjs.map +0 -7
  268. package/dist/lib/browser/app-graph-serializer-QBZDVASK.mjs.map +0 -7
  269. package/dist/lib/browser/blueprint-definition-ASGDSKKE.mjs +0 -18
  270. package/dist/lib/browser/blueprint-definition-ASGDSKKE.mjs.map +0 -7
  271. package/dist/lib/browser/chunk-7JEOX3X6.mjs +0 -783
  272. package/dist/lib/browser/chunk-7JEOX3X6.mjs.map +0 -7
  273. package/dist/lib/browser/chunk-HK6EGNP5.mjs +0 -8
  274. package/dist/lib/browser/chunk-HK6EGNP5.mjs.map +0 -7
  275. package/dist/lib/browser/chunk-P3TN2W6M.mjs +0 -154
  276. package/dist/lib/browser/chunk-P3TN2W6M.mjs.map +0 -7
  277. package/dist/lib/browser/chunk-RJO5W5YX.mjs +0 -59
  278. package/dist/lib/browser/chunk-RJO5W5YX.mjs.map +0 -7
  279. package/dist/lib/browser/chunk-W24NJ6WB.mjs +0 -178
  280. package/dist/lib/browser/chunk-W24NJ6WB.mjs.map +0 -7
  281. package/dist/lib/browser/chunk-YBMRREXE.mjs +0 -28
  282. package/dist/lib/browser/chunk-YBMRREXE.mjs.map +0 -7
  283. package/dist/lib/browser/cli/index.mjs +0 -35
  284. package/dist/lib/browser/cli/index.mjs.map +0 -7
  285. package/dist/lib/browser/index.mjs +0 -157
  286. package/dist/lib/browser/index.mjs.map +0 -7
  287. package/dist/lib/browser/meta.json +0 -1
  288. package/dist/lib/browser/operation-resolver-3KOXJM7P.mjs +0 -54
  289. package/dist/lib/browser/operation-resolver-3KOXJM7P.mjs.map +0 -7
  290. package/dist/lib/browser/react-surface-WU4VTE43.mjs +0 -115
  291. package/dist/lib/browser/react-surface-WU4VTE43.mjs.map +0 -7
  292. package/dist/lib/browser/settings-7FMWKB7N.mjs.map +0 -7
  293. package/dist/lib/browser/state-7UJKJDGE.mjs +0 -31
  294. package/dist/lib/browser/state-7UJKJDGE.mjs.map +0 -7
  295. package/dist/lib/browser/types/index.mjs +0 -18
  296. package/dist/lib/node-esm/MarkdownCard-4MXS7AQR.mjs +0 -62
  297. package/dist/lib/node-esm/MarkdownCard-4MXS7AQR.mjs.map +0 -7
  298. package/dist/lib/node-esm/MarkdownContainer-BZ637MS3.mjs +0 -109
  299. package/dist/lib/node-esm/MarkdownContainer-BZ637MS3.mjs.map +0 -7
  300. package/dist/lib/node-esm/MarkdownSettings-FQTYCTD7.mjs +0 -107
  301. package/dist/lib/node-esm/MarkdownSettings-FQTYCTD7.mjs.map +0 -7
  302. package/dist/lib/node-esm/anchor-sort-QWZO6B2R.mjs +0 -35
  303. package/dist/lib/node-esm/anchor-sort-QWZO6B2R.mjs.map +0 -7
  304. package/dist/lib/node-esm/app-graph-serializer-3UVXEHJG.mjs +0 -61
  305. package/dist/lib/node-esm/app-graph-serializer-3UVXEHJG.mjs.map +0 -7
  306. package/dist/lib/node-esm/blueprint-definition-TG7OZIWW.mjs +0 -19
  307. package/dist/lib/node-esm/blueprint-definition-TG7OZIWW.mjs.map +0 -7
  308. package/dist/lib/node-esm/blueprints/index.mjs +0 -10
  309. package/dist/lib/node-esm/chunk-ANIFP6M2.mjs +0 -60
  310. package/dist/lib/node-esm/chunk-ANIFP6M2.mjs.map +0 -7
  311. package/dist/lib/node-esm/chunk-KCH3EL53.mjs +0 -10
  312. package/dist/lib/node-esm/chunk-KCH3EL53.mjs.map +0 -7
  313. package/dist/lib/node-esm/chunk-N73JZ4CD.mjs +0 -784
  314. package/dist/lib/node-esm/chunk-N73JZ4CD.mjs.map +0 -7
  315. package/dist/lib/node-esm/chunk-NBGAJPVH.mjs +0 -179
  316. package/dist/lib/node-esm/chunk-NBGAJPVH.mjs.map +0 -7
  317. package/dist/lib/node-esm/chunk-W7AM4HCG.mjs +0 -29
  318. package/dist/lib/node-esm/chunk-W7AM4HCG.mjs.map +0 -7
  319. package/dist/lib/node-esm/chunk-WBZQ246U.mjs +0 -155
  320. package/dist/lib/node-esm/chunk-WBZQ246U.mjs.map +0 -7
  321. package/dist/lib/node-esm/cli/index.mjs +0 -36
  322. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  323. package/dist/lib/node-esm/index.mjs +0 -158
  324. package/dist/lib/node-esm/index.mjs.map +0 -7
  325. package/dist/lib/node-esm/meta.json +0 -1
  326. package/dist/lib/node-esm/operation-resolver-2MEWKRFP.mjs +0 -55
  327. package/dist/lib/node-esm/operation-resolver-2MEWKRFP.mjs.map +0 -7
  328. package/dist/lib/node-esm/react-surface-LC5CI6VP.mjs.map +0 -7
  329. package/dist/lib/node-esm/settings-DBK2SPWT.mjs +0 -39
  330. package/dist/lib/node-esm/settings-DBK2SPWT.mjs.map +0 -7
  331. package/dist/lib/node-esm/state-EEPLRAOT.mjs +0 -32
  332. package/dist/lib/node-esm/state-EEPLRAOT.mjs.map +0 -7
  333. package/dist/lib/node-esm/types/index.mjs +0 -19
  334. package/dist/types/src/blueprints/functions/create.d.ts +0 -8
  335. package/dist/types/src/blueprints/functions/create.d.ts.map +0 -1
  336. package/dist/types/src/blueprints/functions/create.test.d.ts.map +0 -1
  337. package/dist/types/src/blueprints/functions/index.d.ts +0 -42
  338. package/dist/types/src/blueprints/functions/index.d.ts.map +0 -1
  339. package/dist/types/src/blueprints/functions/open.d.ts +0 -14
  340. package/dist/types/src/blueprints/functions/open.d.ts.map +0 -1
  341. package/dist/types/src/blueprints/functions/update.d.ts +0 -19
  342. package/dist/types/src/blueprints/functions/update.d.ts.map +0 -1
  343. package/dist/types/src/blueprints/functions/update.test.d.ts.map +0 -1
  344. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  345. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  346. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  347. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  348. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  349. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  350. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +0 -5
  351. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  352. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  353. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  354. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -6
  355. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  356. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  357. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  358. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  359. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  360. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  361. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  362. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  363. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  364. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  365. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  366. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  367. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  368. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  369. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  370. package/dist/types/src/capabilities/state/state.d.ts +0 -5
  371. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  372. package/dist/types/src/cli/index.d.ts +0 -2
  373. package/dist/types/src/cli/index.d.ts.map +0 -1
  374. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  375. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +0 -27
  376. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +0 -1
  377. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +0 -88
  378. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +0 -1
  379. package/dist/types/src/containers/MarkdownContainer/index.d.ts +0 -3
  380. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +0 -1
  381. package/dist/types/src/containers/MarkdownSettings/MarkdownSettings.d.ts +0 -8
  382. package/dist/types/src/containers/MarkdownSettings/MarkdownSettings.d.ts.map +0 -1
  383. package/dist/types/src/containers/MarkdownSettings/index.d.ts +0 -3
  384. package/dist/types/src/containers/MarkdownSettings/index.d.ts.map +0 -1
  385. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  386. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  387. package/dist/types/src/types/MarkdownAction.d.ts +0 -66
  388. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  389. package/dist/types/src/types/capabilities.d.ts +0 -22
  390. package/dist/types/src/types/capabilities.d.ts.map +0 -1
  391. package/dist/types/src/types/events.d.ts +0 -5
  392. package/dist/types/src/types/events.d.ts.map +0 -1
  393. package/src/blueprints/functions/create.conversations.json +0 -1
  394. package/src/blueprints/functions/create.ts +0 -35
  395. package/src/blueprints/functions/index.ts +0 -15
  396. package/src/blueprints/functions/open.ts +0 -33
  397. package/src/blueprints/functions/update.conversations.json +0 -1
  398. package/src/blueprints/functions/update.ts +0 -79
  399. package/src/capabilities/anchor-sort/index.ts +0 -7
  400. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  401. package/src/capabilities/artifact-definition/artifact-definition.ts +0 -110
  402. package/src/capabilities/artifact-definition/index.ts +0 -7
  403. package/src/capabilities/blueprint-definition/index.ts +0 -7
  404. package/src/capabilities/operation-resolver/index.ts +0 -7
  405. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -45
  406. package/src/capabilities/react-surface/index.ts +0 -7
  407. package/src/capabilities/react-surface/react-surface.tsx +0 -102
  408. package/src/capabilities/settings/index.ts +0 -7
  409. package/src/capabilities/state/index.ts +0 -7
  410. package/src/capabilities/state/state.ts +0 -31
  411. package/src/cli/index.ts +0 -5
  412. package/src/cli/plugin.ts +0 -30
  413. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +0 -114
  414. package/src/containers/MarkdownContainer/index.ts +0 -7
  415. package/src/containers/MarkdownSettings/MarkdownSettings.tsx +0 -122
  416. package/src/containers/MarkdownSettings/index.ts +0 -7
  417. package/src/hooks/useSelectCurrentThread.tsx +0 -61
  418. package/src/types/MarkdownAction.ts +0 -59
  419. package/src/types/capabilities.ts +0 -38
  420. package/src/types/events.ts +0 -14
  421. /package/dist/lib/{browser → neutral}/blueprints/index.mjs.map +0 -0
  422. /package/dist/lib/{browser/types/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  423. /package/dist/lib/{node-esm/blueprints → neutral}/index.mjs.map +0 -0
  424. /package/dist/lib/{node-esm/types/index.mjs.map → neutral/meta.mjs.map} +0 -0
  425. /package/dist/types/src/capabilities/{anchor-sort/anchor-sort.d.ts → anchor-sort.d.ts} +0 -0
  426. /package/dist/types/src/capabilities/{app-graph-serializer/app-graph-serializer.d.ts → app-graph-serializer.d.ts} +0 -0
  427. /package/dist/types/src/capabilities/{react-surface/react-surface.d.ts → react-surface.d.ts} +0 -0
  428. /package/dist/types/src/{blueprints/functions → operations}/create.test.d.ts +0 -0
  429. /package/dist/types/src/{blueprints/functions → operations}/update.test.d.ts +0 -0
@@ -0,0 +1,86 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import * as Effect from 'effect/Effect';
7
+ import React from 'react';
8
+
9
+ import { ProcessManagerPlugin } from '@dxos/app-framework';
10
+ import { withPluginManager } from '@dxos/app-framework/testing';
11
+ import { Filter, Obj } from '@dxos/echo';
12
+ import { ClientPlugin, initializeIdentity } from '@dxos/plugin-client/testing';
13
+ import { corePlugins } from '@dxos/plugin-testing';
14
+ import { random } from '@dxos/random';
15
+ import { useQuery, useSpaces } from '@dxos/react-client/echo';
16
+ import { Card } from '@dxos/react-ui';
17
+ import { translations as editorTranslations } from '@dxos/react-ui-editor/translations';
18
+ import { CardContainer } from '@dxos/react-ui-mosaic/testing';
19
+ import { Loading, withTheme } from '@dxos/react-ui/testing';
20
+ import { Text } from '@dxos/schema';
21
+
22
+ import { translations } from '#translations';
23
+ import { Markdown } from '#types';
24
+
25
+ import { EditableMarkdownCard, type EditableMarkdownCardProps } from './EditableMarkdownCard';
26
+
27
+ random.seed(1234);
28
+
29
+ const EditableMarkdownCardStory = ({ ...args }: Omit<EditableMarkdownCardProps, 'subject'>) => {
30
+ const [space] = useSpaces();
31
+ const [doc] = useQuery(space?.db, Filter.type(Markdown.Document));
32
+ if (!doc) {
33
+ return <Loading data={{ space: !!space }} />;
34
+ }
35
+
36
+ return (
37
+ <CardContainer icon='ph--text-aa--regular'>
38
+ <Card.Root border={false}>
39
+ <Card.Header>
40
+ <Card.DragHandle />
41
+ <Card.Title>{Obj.getLabel(doc)}</Card.Title>
42
+ <Card.Menu />
43
+ </Card.Header>
44
+ <EditableMarkdownCard subject={doc} {...args} />
45
+ </Card.Root>
46
+ </CardContainer>
47
+ );
48
+ };
49
+
50
+ const meta: Meta<typeof EditableMarkdownCardStory> = {
51
+ title: 'plugins/plugin-markdown/containers/EditableMarkdownCard',
52
+ component: EditableMarkdownCardStory,
53
+ decorators: [
54
+ withTheme(),
55
+ withPluginManager({
56
+ plugins: [
57
+ ...corePlugins(),
58
+ ProcessManagerPlugin(),
59
+ ClientPlugin({
60
+ types: [Markdown.Document, Text.Text],
61
+ onClientInitialized: ({ client }) =>
62
+ Effect.gen(function* () {
63
+ const { personalSpace } = yield* initializeIdentity(client);
64
+ personalSpace.db.add(
65
+ Markdown.make({
66
+ name: random.lorem.words(3),
67
+ content: '# Title\n' + random.lorem.paragraphs(3),
68
+ }),
69
+ );
70
+ }),
71
+ }),
72
+ ],
73
+ }),
74
+ ],
75
+ parameters: {
76
+ layout: 'centered',
77
+ translations: [...translations, ...editorTranslations],
78
+ },
79
+ tags: ['cards'],
80
+ };
81
+
82
+ export default meta;
83
+
84
+ type Story = StoryObj<typeof meta>;
85
+
86
+ export const Default: Story = {};
@@ -0,0 +1,44 @@
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 MarkdownArticle
23
+ * remains the canonical surface for full article views.
24
+ */
25
+ export const EditableMarkdownCard = ({ subject }: EditableMarkdownCardProps) => {
26
+ const id = Obj.getURI(subject);
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
+ <Card.Row fullWidth>
34
+ <MarkdownEditorProvider id={id} object={subject} viewMode='source'>
35
+ {(editorRootProps) => (
36
+ <Editor.Root {...editorRootProps}>
37
+ <MarkdownEditor.Content compact initialValue={initialValue} />
38
+ </Editor.Root>
39
+ )}
40
+ </MarkdownEditorProvider>
41
+ </Card.Row>
42
+ </Card.Section>
43
+ );
44
+ };
@@ -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';
@@ -10,29 +10,38 @@ import { Capability, Plugin } from '@dxos/app-framework';
10
10
  import { withPluginManager } from '@dxos/app-framework/testing';
11
11
  import { Surface, useOperationInvoker } from '@dxos/app-framework/ui';
12
12
  import { AppActivationEvents, LayoutOperation } from '@dxos/app-toolkit';
13
+ import { AppSurface } from '@dxos/app-toolkit/ui';
13
14
  import { Obj, Query } from '@dxos/echo';
14
- import { ClientPlugin } from '@dxos/plugin-client';
15
- import { PreviewPlugin } from '@dxos/plugin-preview';
15
+ import { DXN } from '@dxos/keys';
16
+ import { ClientPlugin } from '@dxos/plugin-client/testing';
17
+ import { initializeIdentity } from '@dxos/plugin-client/testing';
18
+ import { PreviewPlugin } from '@dxos/plugin-preview/testing';
16
19
  import { StorybookPlugin, corePlugins } from '@dxos/plugin-testing';
17
- import { faker } from '@dxos/random';
18
- import { useQuery, useSpace } from '@dxos/react-client/echo';
20
+ import { random } from '@dxos/random';
21
+ import { useQuery, useSpaces } from '@dxos/react-client/echo';
19
22
  import { useAsyncEffect } from '@dxos/react-ui';
20
- import { withLayout, withTheme } from '@dxos/react-ui/testing';
21
23
  import { useAttentionAttributes } from '@dxos/react-ui-attention';
24
+ import { withLayout } from '@dxos/react-ui/testing';
22
25
  import { Text } from '@dxos/schema';
23
26
  import { type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
24
27
  import { Organization, Person } from '@dxos/types';
25
28
 
29
+ import { translations } from '#translations';
30
+ import { Markdown, MarkdownCapabilities, MarkdownEvents } from '#types';
31
+
26
32
  import { MarkdownPlugin } from '../../MarkdownPlugin';
27
- import { translations } from '../../translations';
28
- import { Markdown, MarkdownCapabilities, MarkdownEvents } from '../../types';
29
33
 
30
- faker.seed(1);
34
+ random.seed(1);
31
35
 
32
- const generator: ValueGenerator = faker as any;
36
+ const generator: ValueGenerator = random as any;
33
37
 
34
38
  /** Minimal plugin that contributes an empty Extensions capability for stories. */
35
- const MarkdownExtensionsPlugin = Plugin.define({ id: 'story-markdown-extensions', name: 'Story Extensions' }).pipe(
39
+ const MarkdownExtensionsPlugin = Plugin.define(
40
+ Plugin.makeMeta({
41
+ key: DXN.make('org.dxos.plugin.markdown.story.markdownExtensions'),
42
+ name: 'Story Extensions',
43
+ }),
44
+ ).pipe(
36
45
  Plugin.addModule({
37
46
  id: 'extensions',
38
47
  activatesOn: MarkdownEvents.SetupExtensions,
@@ -43,10 +52,10 @@ const MarkdownExtensionsPlugin = Plugin.define({ id: 'story-markdown-extensions'
43
52
 
44
53
  const DefaultStory = () => {
45
54
  const { invokePromise } = useOperationInvoker();
46
- const space = useSpace();
55
+ const [space] = useSpaces();
47
56
  const [doc] = useQuery(space?.db, Query.type(Markdown.Document));
48
- const data = useMemo(() => ({ subject: doc }), [doc]);
49
- const id = doc && Obj.getDXN(doc).toString();
57
+ const id = doc && Obj.getURI(doc);
58
+ const data = useMemo(() => ({ subject: doc, attendableId: id ?? 'story' }), [doc, id]);
50
59
  const attentionAttrs = useAttentionAttributes(id);
51
60
 
52
61
  useAsyncEffect(async () => {
@@ -57,16 +66,15 @@ const DefaultStory = () => {
57
66
 
58
67
  return (
59
68
  <div className='contents' {...attentionAttrs}>
60
- <Surface.Surface role='article' data={data} limit={1} />
69
+ <Surface.Surface type={AppSurface.Article} data={data} limit={1} />
61
70
  </div>
62
71
  );
63
72
  };
64
73
 
65
74
  const meta = {
66
- title: 'plugins/plugin-markdown/containers/MarkdownContainer',
75
+ title: 'plugins/plugin-markdown/containers/MarkdownArticle',
67
76
  render: DefaultStory,
68
77
  decorators: [
69
- withTheme(),
70
78
  withLayout({ layout: 'column' }),
71
79
  withPluginManager<{ title?: string; content?: string }>((context) => ({
72
80
  setupEvents: [AppActivationEvents.SetupSettings, MarkdownEvents.SetupExtensions],
@@ -78,20 +86,17 @@ const meta = {
78
86
  types: [Markdown.Document, Text.Text, Person.Person, Organization.Organization],
79
87
  onClientInitialized: ({ client }) =>
80
88
  Effect.gen(function* () {
81
- yield* Effect.promise(() => client.halo.createIdentity());
82
- yield* Effect.promise(() => client.spaces.waitUntilReady());
83
- yield* Effect.promise(() => client.spaces.default.waitUntilReady());
89
+ const { personalSpace } = yield* initializeIdentity(client);
84
90
 
85
- const space = client.spaces.default;
86
- const createObjects = createObjectFactory(space.db, generator);
91
+ const createObjects = createObjectFactory(personalSpace.db, generator);
87
92
  yield* Effect.promise(() => createObjects([{ type: Organization.Organization, count: 10 }]));
88
93
 
89
- const queue = space.queues.create();
94
+ const queue = personalSpace.queues.create();
90
95
  const kai = Obj.make(Person.Person, { fullName: 'Kai' });
91
96
  const dxos = Obj.make(Organization.Organization, { name: 'DXOS' });
92
97
  yield* Effect.promise(() => queue.append([kai, dxos]));
93
98
 
94
- space.db.add(
99
+ personalSpace.db.add(
95
100
  Markdown.make({
96
101
  name: context.args.title ?? 'Testing',
97
102
  content: [
@@ -99,8 +104,8 @@ const meta = {
99
104
  context.args.content ?? '',
100
105
  // TODO(burdon): Popovers not currently working.
101
106
  '## Here are some objects',
102
- `![Alice](${Obj.getDXN(kai)})`,
103
- `![DXOS](${Obj.getDXN(dxos)})`,
107
+ `![Alice](${Obj.getURI(kai)})`,
108
+ `![DXOS](${Obj.getURI(dxos)})`,
104
109
  '',
105
110
  'END',
106
111
  '',
@@ -108,7 +113,7 @@ const meta = {
108
113
  }),
109
114
  );
110
115
 
111
- yield* Effect.promise(() => space.db.flush({ indexes: true }));
116
+ yield* Effect.promise(() => personalSpace.db.flush({ indexes: true }));
112
117
  }),
113
118
  }),
114
119
 
@@ -0,0 +1,146 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import { type Extension } from '@codemirror/state';
6
+ import { Atom } from '@effect-atom/atom-react';
7
+ import React, { forwardRef, useCallback, useMemo } from 'react';
8
+
9
+ import { useCapabilities, useOperationInvoker } from '@dxos/app-framework/ui';
10
+ import { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';
11
+ import { AppSurface, useAppGraph } from '@dxos/app-toolkit/ui';
12
+ import { Obj } from '@dxos/echo';
13
+ import { useActionRunner } from '@dxos/plugin-graph';
14
+ import { useObject } from '@dxos/react-client/echo';
15
+ import { Panel } from '@dxos/react-ui';
16
+ import { type SelectionManager } from '@dxos/react-ui-attention';
17
+ import { Editor } from '@dxos/react-ui-editor';
18
+ import { Text } from '@dxos/schema';
19
+
20
+ import {
21
+ MarkdownEditor,
22
+ MarkdownEditorProvider,
23
+ type MarkdownEditorContentProps,
24
+ type MarkdownEditorProviderProps,
25
+ } from '#components';
26
+ import { useLinkQuery } from '#hooks';
27
+ import { Markdown, MarkdownCapabilities, type MarkdownPluginState } from '#types';
28
+
29
+ export type MarkdownArticleProps = AppSurface.ObjectArticleProps<
30
+ Markdown.Document | Text.Text,
31
+ {
32
+ id: string;
33
+ settings: Markdown.Settings;
34
+ selectionManager?: SelectionManager;
35
+ } & Pick<MarkdownPluginState, 'extensionProviders'> &
36
+ Pick<MarkdownEditorProviderProps, 'viewMode' | 'onSelectObject' | 'onViewModeChange'> &
37
+ Pick<MarkdownEditorContentProps, 'editorStateStore'>
38
+ >;
39
+
40
+ export const MarkdownArticle = forwardRef<HTMLDivElement, MarkdownArticleProps>(
41
+ (
42
+ { role, subject: object, id, attendableId, settings, extensionProviders, onSelectObject, viewMode, ...props },
43
+ forwardedRef,
44
+ ) => {
45
+ const db = Obj.isObject(object) ? Obj.getDatabase(object) : undefined;
46
+ const [docContent] = useObject(Obj.instanceOf(Markdown.Document, object) ? object.content : undefined, 'content');
47
+ const [textContent] = useObject(Obj.instanceOf(Text.Text, object) ? object : undefined, 'content');
48
+ const initialValue = docContent ?? textContent;
49
+
50
+ // Extensions from other plugins.
51
+ const otherExtensionProviders = useCapabilities(MarkdownCapabilities.Extensions);
52
+ const extensions = useMemo<Extension[]>(() => {
53
+ if (!Obj.instanceOf(Markdown.Document, object) && !Obj.instanceOf(Text.Text, object)) {
54
+ return [];
55
+ }
56
+
57
+ const document = Obj.instanceOf(Markdown.Document, object) ? object : undefined;
58
+ return [...(otherExtensionProviders ?? []), ...(extensionProviders ?? [])]
59
+ .flat()
60
+ .reduce((acc: Extension[], provider) => {
61
+ const extension = typeof provider === 'function' ? provider({ document, viewMode }) : provider;
62
+ if (extension) {
63
+ acc.push(extension);
64
+ }
65
+
66
+ return acc;
67
+ }, []);
68
+ }, [extensionProviders, otherExtensionProviders, object, viewMode]);
69
+
70
+ // Toolbar actions from app graph.
71
+ const { graph } = useAppGraph();
72
+ const runAction = useActionRunner();
73
+ const customActions = useMemo(() => {
74
+ return Atom.make((get) => {
75
+ const actions = get(graph.actions(attendableId ?? id));
76
+ const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');
77
+ const edges = nodes.map((node) => ({ source: 'root', target: node.id, relation: 'child' }));
78
+ return { nodes, edges };
79
+ });
80
+ }, [graph]);
81
+
82
+ // File upload.
83
+ const [upload] = useCapabilities(AppCapabilities.FileUploader);
84
+ const handleFileUpload = useMemo(() => {
85
+ if (!db || !upload) {
86
+ return undefined;
87
+ }
88
+
89
+ return async (file: File) => upload(db, file);
90
+ }, [db, upload]);
91
+
92
+ // Query for @ refs.
93
+ const handleLinkQuery = useLinkQuery(db);
94
+
95
+ // Open linked objects.
96
+ const { invokePromise } = useOperationInvoker();
97
+ const handleSelectObject = useCallback(
98
+ (targetId: string) => {
99
+ if (onSelectObject) {
100
+ onSelectObject(targetId);
101
+ } else {
102
+ void invokePromise?.(LayoutOperation.Open, {
103
+ subject: [targetId],
104
+ pivotId: attendableId,
105
+ // TODO(wittjosiah): This should probably pre-validate.
106
+ navigation: 'immediate',
107
+ });
108
+ }
109
+ },
110
+ [onSelectObject, invokePromise, attendableId],
111
+ );
112
+
113
+ return (
114
+ <MarkdownEditorProvider
115
+ id={id}
116
+ attendableId={attendableId}
117
+ object={object}
118
+ compact={role !== 'article'}
119
+ extensions={extensions}
120
+ settings={settings}
121
+ viewMode={viewMode}
122
+ onAction={runAction}
123
+ onFileUpload={handleFileUpload}
124
+ onLinkQuery={handleLinkQuery}
125
+ onSelectObject={handleSelectObject}
126
+ {...props}
127
+ >
128
+ {(editorRootProps) => (
129
+ <Editor.Root {...editorRootProps}>
130
+ <Panel.Root role={role} ref={forwardedRef}>
131
+ {settings.toolbar && (
132
+ <Panel.Toolbar classNames='bg-toolbar-surface'>
133
+ <MarkdownEditor.Toolbar classNames='dx-document' customActions={customActions} />
134
+ </Panel.Toolbar>
135
+ )}
136
+ <Panel.Content>
137
+ <MarkdownEditor.Content initialValue={initialValue} />
138
+ <MarkdownEditor.Blocks />
139
+ </Panel.Content>
140
+ </Panel.Root>
141
+ </Editor.Root>
142
+ )}
143
+ </MarkdownEditorProvider>
144
+ );
145
+ },
146
+ );
@@ -0,0 +1,6 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { MarkdownArticle, type MarkdownArticleProps } from './MarkdownArticle';
6
+ export { MarkdownArticle as default } from './MarkdownArticle';
@@ -5,28 +5,28 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useMemo } from 'react';
7
7
 
8
- import { OperationPlugin, RuntimePlugin } from '@dxos/app-framework';
8
+ import { ProcessManagerPlugin } from '@dxos/app-framework';
9
9
  import { withPluginManager } from '@dxos/app-framework/testing';
10
10
  import { Obj } from '@dxos/echo';
11
- import { ClientPlugin } from '@dxos/plugin-client';
12
- import { Markdown } from '@dxos/plugin-markdown/types';
13
- import { faker } from '@dxos/random';
11
+ import { ClientPlugin } from '@dxos/plugin-client/testing';
12
+ import { Markdown } from '@dxos/plugin-markdown';
13
+ import { random } from '@dxos/random';
14
14
  import { Card } from '@dxos/react-ui';
15
- import { withTheme } from '@dxos/react-ui/testing';
16
15
  import { CardContainer } from '@dxos/react-ui-mosaic/testing';
16
+ import { withTheme } from '@dxos/react-ui/testing';
17
17
 
18
- import { translations } from '../../translations';
18
+ import { translations } from '#translations';
19
19
 
20
20
  import { MarkdownCard, type MarkdownCardProps } from './MarkdownCard';
21
21
 
22
- faker.seed(1234);
22
+ random.seed(1234);
23
23
 
24
24
  const MarkdownCardStory = ({ ...args }: Omit<MarkdownCardProps, 'subject'>) => {
25
25
  const subject = useMemo(
26
26
  () =>
27
27
  Markdown.make({
28
- name: faker.lorem.words(3),
29
- content: faker.lorem.paragraphs(5),
28
+ name: random.lorem.words(3),
29
+ content: '# Title\n' + random.lorem.paragraphs(5),
30
30
  }),
31
31
  [],
32
32
  );
@@ -34,11 +34,11 @@ const MarkdownCardStory = ({ ...args }: Omit<MarkdownCardProps, 'subject'>) => {
34
34
  return (
35
35
  <CardContainer icon='ph--text-aa--regular'>
36
36
  <Card.Root border={false}>
37
- <Card.Toolbar>
37
+ <Card.Header>
38
38
  <Card.DragHandle />
39
39
  <Card.Title>{Obj.getLabel(subject)}</Card.Title>
40
40
  <Card.Menu />
41
- </Card.Toolbar>
41
+ </Card.Header>
42
42
  <MarkdownCard subject={subject} {...args} />
43
43
  </Card.Root>
44
44
  </CardContainer>
@@ -51,7 +51,7 @@ const meta: Meta<typeof MarkdownCardStory> = {
51
51
  decorators: [
52
52
  withTheme(),
53
53
  withPluginManager({
54
- plugins: [OperationPlugin(), RuntimePlugin(), ClientPlugin({})],
54
+ plugins: [ProcessManagerPlugin(), ClientPlugin({})],
55
55
  }),
56
56
  ],
57
57
  parameters: {
@@ -5,53 +5,67 @@
5
5
  import React, { useMemo } from 'react';
6
6
 
7
7
  import { Obj } from '@dxos/echo';
8
- import { useTranslation } from '@dxos/react-ui';
9
- import { Card } from '@dxos/react-ui';
8
+ import { Card, useTranslation } from '@dxos/react-ui';
9
+ import { Editor } from '@dxos/react-ui-editor';
10
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';
11
16
 
12
- import { MarkdownEditor } from '../../components';
13
- import { meta } from '../../meta';
14
- import { Markdown } from '../../types';
15
17
  import { getContentSnippet } from '../../util';
18
+ import { snippet as snippetExtension } from './snippet';
16
19
 
17
20
  export type MarkdownCardProps = { subject: Markdown.Document | Text.Text };
18
21
 
19
22
  export const MarkdownCard = ({ subject }: MarkdownCardProps) => {
20
23
  const { t } = useTranslation(meta.id);
21
24
  const snippet = useMemo(() => getSnippet(subject), [subject]);
25
+ const extensions = useMemo(() => [snippetExtension({ height: 300, scale: 0.8 })], []);
22
26
  const info = getInfo(subject);
23
27
 
24
28
  return (
25
- <Card.Content>
29
+ <Card.Body>
26
30
  {snippet && (
27
- <Card.Section>
28
- <MarkdownEditor.Root id={subject.id} viewMode='readonly'>
29
- <MarkdownEditor.Content
30
- initialValue={snippet}
31
- classNames='bg-transparent'
32
- slots={{
33
- editor: { className: 'max-h-[240px]' },
34
- }}
35
- />
36
- </MarkdownEditor.Root>
31
+ <Card.Section className='relative'>
32
+ <Card.Row fullWidth>
33
+ <MarkdownEditorProvider id={subject.id} viewMode='readonly' extensions={extensions}>
34
+ {(editorRootProps) => (
35
+ <Editor.Root {...editorRootProps}>
36
+ <MarkdownEditor.Content initialValue={snippet} slots={{ content: { className: 'px-2!' } }} />
37
+ </Editor.Root>
38
+ )}
39
+ </MarkdownEditorProvider>
40
+ <Fade />
41
+ </Card.Row>
37
42
  </Card.Section>
38
43
  )}
39
44
  <Card.Section>
40
- <Card.Text classNames='text-xs text-description'>
41
- {info.words} {t('words label', { count: info.words })}
42
- </Card.Text>
45
+ <Card.Row fullWidth>
46
+ <Card.Text classNames='px-2 text-xs text-description'>
47
+ {info.words} {t('words.label', { count: info.words })}
48
+ </Card.Text>
49
+ </Card.Row>
43
50
  </Card.Section>
44
- </Card.Content>
51
+ </Card.Body>
45
52
  );
46
53
  };
47
54
 
48
- const MAX_LINES = 5;
55
+ const Fade = () => (
56
+ <div
57
+ className={mx(
58
+ 'z-10 absolute bottom-0 inset-x-0 h-12 w-full',
59
+ 'bg-gradient-to-b from-transparent to-(--surface-bg) pointer-events-none',
60
+ )}
61
+ />
62
+ );
49
63
 
50
- const getSnippet = (subject: Markdown.Document | Text.Text, fallback?: string) => {
64
+ const getSnippet = (subject: Markdown.Document | Text.Text, fallback?: string, maxLines = 16) => {
51
65
  if (Obj.instanceOf(Markdown.Document, subject)) {
52
- return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, MAX_LINES);
66
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, maxLines);
53
67
  } else if (Obj.instanceOf(Text.Text, subject)) {
54
- return getContentSnippet(subject.content ?? fallback, MAX_LINES);
68
+ return getContentSnippet(subject.content ?? fallback, maxLines);
55
69
  }
56
70
  };
57
71
 
@@ -2,6 +2,4 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { MarkdownCard } from './MarkdownCard';
6
-
7
- export default MarkdownCard;
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
+ };
@@ -4,8 +4,8 @@
4
4
 
5
5
  import { type ComponentType, lazy } from 'react';
6
6
 
7
- export type { MarkdownContainerProps } from './MarkdownContainer/MarkdownContainer';
7
+ export type { MarkdownArticleProps } from './MarkdownArticle';
8
8
 
9
9
  export const MarkdownCard: ComponentType<any> = lazy(() => import('./MarkdownCard'));
10
- export const MarkdownContainer: ComponentType<any> = lazy(() => import('./MarkdownContainer'));
11
- export const MarkdownSettings: ComponentType<any> = lazy(() => import('./MarkdownSettings'));
10
+ export const EditableMarkdownCard: ComponentType<any> = lazy(() => import('./EditableMarkdownCard'));
11
+ export const MarkdownArticle: ComponentType<any> = lazy(() => import('./MarkdownArticle'));
@@ -5,4 +5,3 @@
5
5
  export * from './useEditorMenuOptions';
6
6
  export * from './useExtensions';
7
7
  export * from './useLinkQuery';
8
- export * from './useSelectCurrentThread';