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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (379) hide show
  1. package/dist/lib/browser/blueprints/index.mjs +46 -4
  2. package/dist/lib/browser/blueprints/index.mjs.map +4 -4
  3. package/dist/lib/browser/chunk-DNSKDWUL.mjs +156 -0
  4. package/dist/lib/browser/chunk-DNSKDWUL.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-SW6IK2GJ.mjs +124 -0
  6. package/dist/lib/browser/chunk-SW6IK2GJ.mjs.map +7 -0
  7. package/dist/lib/browser/create-SRADQOTE.mjs +29 -0
  8. package/dist/lib/browser/create-SRADQOTE.mjs.map +7 -0
  9. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs +21 -0
  10. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +109 -126
  12. package/dist/lib/browser/index.mjs.map +4 -4
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/open-ANTKMST5.mjs +20 -0
  15. package/dist/lib/browser/open-ANTKMST5.mjs.map +7 -0
  16. package/dist/lib/browser/operations/index.mjs +13 -0
  17. package/dist/lib/browser/operations/index.mjs.map +7 -0
  18. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs +48 -0
  19. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs.map +7 -0
  20. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs +25 -0
  21. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs.map +7 -0
  22. package/dist/lib/browser/types/index.mjs +5 -7
  23. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs +44 -0
  24. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs.map +7 -0
  25. package/dist/lib/node-esm/blueprints/index.mjs +46 -4
  26. package/dist/lib/node-esm/blueprints/index.mjs.map +4 -4
  27. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs +157 -0
  28. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs.map +7 -0
  29. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs +125 -0
  30. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs.map +7 -0
  31. package/dist/lib/node-esm/create-6JGQPPQ6.mjs +30 -0
  32. package/dist/lib/node-esm/create-6JGQPPQ6.mjs.map +7 -0
  33. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs +22 -0
  34. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs.map +7 -0
  35. package/dist/lib/node-esm/index.mjs +109 -126
  36. package/dist/lib/node-esm/index.mjs.map +4 -4
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/open-GB6HNBHS.mjs +21 -0
  39. package/dist/lib/node-esm/open-GB6HNBHS.mjs.map +7 -0
  40. package/dist/lib/node-esm/operations/index.mjs +14 -0
  41. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  42. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs +49 -0
  43. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs.map +7 -0
  44. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs +26 -0
  45. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs.map +7 -0
  46. package/dist/lib/node-esm/types/index.mjs +5 -7
  47. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs +45 -0
  48. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs.map +7 -0
  49. package/dist/types/src/MarkdownPlugin.d.ts +1 -0
  50. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  51. package/dist/types/src/{cli/plugin.d.ts → MarkdownPlugin.node.d.ts} +2 -1
  52. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  53. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  54. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  55. package/dist/types/src/blueprints/index.d.ts +1 -1
  56. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  57. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  58. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  59. package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
  60. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  61. package/dist/types/src/capabilities/app-graph-serializer.d.ts +5 -0
  62. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  63. package/dist/types/src/capabilities/artifact-definition.d.ts +5 -0
  64. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
  65. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  66. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  67. package/dist/types/src/capabilities/index.d.ts +9 -7
  68. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/node.d.ts +4 -0
  70. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  71. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  72. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  73. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  74. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  75. package/dist/types/src/capabilities/settings.d.ts +6 -0
  76. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  77. package/dist/types/src/capabilities/state.d.ts +6 -0
  78. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  79. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
  80. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  81. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +33 -22
  82. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  83. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +3 -3
  84. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +6 -3
  86. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  87. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +7 -6
  88. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  89. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -6
  90. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  91. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  92. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  94. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  95. package/dist/types/src/components/index.d.ts +3 -8
  96. package/dist/types/src/components/index.d.ts.map +1 -1
  97. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +1 -1
  98. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  99. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +1 -1
  100. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  101. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts +15 -0
  102. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts.map +1 -0
  103. package/dist/types/src/containers/MarkdownCard/index.d.ts +3 -0
  104. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  105. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  106. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  107. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  108. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  109. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  110. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  111. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  112. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  113. package/dist/types/src/containers/index.d.ts +6 -0
  114. package/dist/types/src/containers/index.d.ts.map +1 -0
  115. package/dist/types/src/hooks/index.d.ts +0 -1
  116. package/dist/types/src/hooks/index.d.ts.map +1 -1
  117. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  118. package/dist/types/src/hooks/useExtensions.d.ts +10 -6
  119. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  120. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  121. package/dist/types/src/index.d.ts +2 -1
  122. package/dist/types/src/index.d.ts.map +1 -1
  123. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  124. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  125. package/dist/types/src/operations/create.d.ts +5 -0
  126. package/dist/types/src/operations/create.d.ts.map +1 -0
  127. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  128. package/dist/types/src/operations/definitions.d.ts +64 -0
  129. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  130. package/dist/types/src/operations/index.d.ts +4 -0
  131. package/dist/types/src/operations/index.d.ts.map +1 -0
  132. package/dist/types/src/operations/open.d.ts +5 -0
  133. package/dist/types/src/operations/open.d.ts.map +1 -0
  134. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  135. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  136. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  137. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  138. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  139. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  140. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  141. package/dist/types/src/testing.d.ts.map +1 -1
  142. package/dist/types/src/translations.d.ts +74 -37
  143. package/dist/types/src/translations.d.ts.map +1 -1
  144. package/dist/types/src/types/Markdown.d.ts +15 -16
  145. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  146. package/dist/types/src/types/Settings.d.ts +17 -0
  147. package/dist/types/src/types/Settings.d.ts.map +1 -0
  148. package/dist/types/src/types/capabilities.d.ts +15 -3
  149. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  150. package/dist/types/src/types/events.d.ts.map +1 -1
  151. package/dist/types/src/types/index.d.ts +2 -3
  152. package/dist/types/src/types/index.d.ts.map +1 -1
  153. package/dist/types/src/types/types.d.ts +1 -0
  154. package/dist/types/src/types/types.d.ts.map +1 -1
  155. package/dist/types/src/util.d.ts +2 -2
  156. package/dist/types/src/util.d.ts.map +1 -1
  157. package/dist/types/tsconfig.tsbuildinfo +1 -1
  158. package/package.json +94 -75
  159. package/src/MarkdownPlugin.node.ts +41 -0
  160. package/src/MarkdownPlugin.test.ts +26 -0
  161. package/src/MarkdownPlugin.tsx +52 -45
  162. package/src/blueprints/index.ts +1 -1
  163. package/src/blueprints/markdown-blueprint.ts +14 -9
  164. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +4 -3
  165. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +14 -9
  166. package/src/capabilities/{artifact-definition/artifact-definition.ts → artifact-definition.ts} +6 -6
  167. package/src/capabilities/blueprint-definition.ts +19 -0
  168. package/src/capabilities/index.ts +14 -7
  169. package/src/capabilities/node.ts +11 -0
  170. package/src/capabilities/operation-handler.ts +16 -0
  171. package/src/capabilities/react-surface.tsx +127 -0
  172. package/src/capabilities/{settings/settings.ts → settings.ts} +5 -4
  173. package/src/capabilities/state.ts +47 -0
  174. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  175. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +39 -34
  176. package/src/components/MarkdownEditor/MarkdownEditor.tsx +139 -102
  177. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +26 -18
  178. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +37 -56
  179. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  180. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -109
  181. package/src/components/MarkdownSettings/index.ts +1 -1
  182. package/src/components/index.ts +4 -12
  183. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +22 -12
  184. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  185. package/src/containers/MarkdownCard/MarkdownEditableCard.tsx +42 -0
  186. package/src/containers/MarkdownCard/index.ts +6 -0
  187. package/src/containers/MarkdownCard/snippet.ts +54 -0
  188. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +36 -24
  189. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  190. package/src/containers/MarkdownContainer/index.ts +6 -0
  191. package/src/containers/index.ts +13 -0
  192. package/src/hooks/index.ts +0 -1
  193. package/src/hooks/useEditorMenuOptions.ts +3 -3
  194. package/src/hooks/useExtensions.tsx +86 -98
  195. package/src/hooks/useLinkQuery.ts +31 -6
  196. package/src/index.ts +5 -1
  197. package/src/meta.ts +1 -1
  198. package/src/operations/create-markdown.ts +20 -0
  199. package/src/operations/create.conversations.json +1 -0
  200. package/src/operations/create.test.ts +97 -0
  201. package/src/operations/create.ts +27 -0
  202. package/src/operations/definitions.ts +120 -0
  203. package/src/operations/index.ts +16 -0
  204. package/src/operations/open.ts +25 -0
  205. package/src/operations/scroll-to-anchor.ts +39 -0
  206. package/src/operations/set-view-mode.ts +24 -0
  207. package/src/operations/update-markdown.ts +51 -0
  208. package/src/operations/update.conversations.json +1 -0
  209. package/src/operations/update.test.ts +214 -0
  210. package/src/testing.ts +2 -2
  211. package/src/translations.ts +26 -36
  212. package/src/types/Markdown.ts +18 -25
  213. package/src/types/Settings.ts +65 -0
  214. package/src/types/capabilities.ts +19 -6
  215. package/src/types/events.ts +5 -4
  216. package/src/types/index.ts +3 -4
  217. package/src/types/types.ts +4 -1
  218. package/src/util.tsx +5 -5
  219. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs +0 -12
  220. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs.map +0 -7
  221. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
  222. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs.map +0 -7
  223. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs +0 -32
  224. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
  225. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs +0 -58
  226. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
  227. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
  228. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
  229. package/dist/lib/browser/chunk-BX73DASG.mjs +0 -702
  230. package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-CUGDX7KA.mjs +0 -8
  232. package/dist/lib/browser/chunk-CUGDX7KA.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
  234. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-JOXYQLKH.mjs +0 -55
  236. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
  237. package/dist/lib/browser/chunk-KDKXFKDN.mjs +0 -104
  238. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
  239. package/dist/lib/browser/chunk-LMO5UVKL.mjs +0 -167
  240. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
  241. package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
  242. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
  243. package/dist/lib/browser/chunk-WIPSLZ6L.mjs +0 -60
  244. package/dist/lib/browser/chunk-WIPSLZ6L.mjs.map +0 -7
  245. package/dist/lib/browser/cli/index.mjs +0 -32
  246. package/dist/lib/browser/cli/index.mjs.map +0 -7
  247. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs +0 -53
  248. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
  249. package/dist/lib/browser/react-surface-SRPLD3ED.mjs +0 -213
  250. package/dist/lib/browser/react-surface-SRPLD3ED.mjs.map +0 -7
  251. package/dist/lib/browser/settings-JY5JE7MI.mjs +0 -35
  252. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
  253. package/dist/lib/browser/state-QE7VSJWJ.mjs +0 -29
  254. package/dist/lib/browser/state-QE7VSJWJ.mjs.map +0 -7
  255. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs +0 -13
  256. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs.map +0 -7
  257. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
  258. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
  259. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs +0 -33
  260. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
  261. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs +0 -59
  262. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
  263. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
  264. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs +0 -105
  266. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
  267. package/dist/lib/node-esm/chunk-44VJC3QF.mjs +0 -56
  268. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
  269. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs +0 -703
  270. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
  271. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
  272. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
  273. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs +0 -168
  274. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
  275. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs +0 -61
  276. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs.map +0 -7
  277. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
  278. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
  279. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs +0 -10
  280. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs.map +0 -7
  281. package/dist/lib/node-esm/cli/index.mjs +0 -33
  282. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  283. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs +0 -54
  284. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
  285. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs +0 -214
  286. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs.map +0 -7
  287. package/dist/lib/node-esm/settings-4UGMPIRY.mjs +0 -36
  288. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
  289. package/dist/lib/node-esm/state-LXE5XIN4.mjs +0 -30
  290. package/dist/lib/node-esm/state-LXE5XIN4.mjs.map +0 -7
  291. package/dist/types/src/blueprints/functions/create.d.ts +0 -8
  292. package/dist/types/src/blueprints/functions/create.d.ts.map +0 -1
  293. package/dist/types/src/blueprints/functions/create.test.d.ts.map +0 -1
  294. package/dist/types/src/blueprints/functions/index.d.ts +0 -4
  295. package/dist/types/src/blueprints/functions/index.d.ts.map +0 -1
  296. package/dist/types/src/blueprints/functions/open.d.ts +0 -7
  297. package/dist/types/src/blueprints/functions/open.d.ts.map +0 -1
  298. package/dist/types/src/blueprints/functions/update.d.ts +0 -6
  299. package/dist/types/src/blueprints/functions/update.d.ts.map +0 -1
  300. package/dist/types/src/blueprints/functions/update.test.d.ts.map +0 -1
  301. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +0 -5
  302. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  303. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  304. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  305. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +0 -5
  306. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  307. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  308. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  309. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +0 -5
  310. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  311. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  312. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -10
  314. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  316. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  317. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  318. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  319. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  320. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  321. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  322. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  323. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  324. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  325. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  326. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  327. package/dist/types/src/capabilities/settings/settings.d.ts +0 -6
  328. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  329. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  330. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  331. package/dist/types/src/capabilities/state/state.d.ts +0 -5
  332. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  333. package/dist/types/src/cli/index.d.ts +0 -2
  334. package/dist/types/src/cli/index.d.ts.map +0 -1
  335. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  336. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  337. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  338. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  339. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  340. package/dist/types/src/components/MarkdownContainer.d.ts +0 -28
  341. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  342. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -59
  343. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  344. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  345. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  346. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  347. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  348. package/dist/types/src/types/MarkdownAction.d.ts +0 -66
  349. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  350. package/src/blueprints/functions/create.conversations.json +0 -1
  351. package/src/blueprints/functions/create.test.ts +0 -125
  352. package/src/blueprints/functions/create.ts +0 -34
  353. package/src/blueprints/functions/index.ts +0 -7
  354. package/src/blueprints/functions/open.ts +0 -33
  355. package/src/blueprints/functions/update.conversations.json +0 -1
  356. package/src/blueprints/functions/update.test.ts +0 -149
  357. package/src/blueprints/functions/update.ts +0 -38
  358. package/src/capabilities/anchor-sort/index.ts +0 -7
  359. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  360. package/src/capabilities/artifact-definition/index.ts +0 -7
  361. package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -25
  362. package/src/capabilities/blueprint-definition/index.ts +0 -7
  363. package/src/capabilities/operation-resolver/index.ts +0 -7
  364. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -45
  365. package/src/capabilities/react-surface/index.ts +0 -7
  366. package/src/capabilities/react-surface/react-surface.tsx +0 -100
  367. package/src/capabilities/settings/index.ts +0 -7
  368. package/src/capabilities/state/index.ts +0 -7
  369. package/src/capabilities/state/state.ts +0 -31
  370. package/src/cli/index.ts +0 -5
  371. package/src/cli/plugin.ts +0 -29
  372. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -64
  373. package/src/components/MarkdownCard/index.ts +0 -9
  374. package/src/components/MarkdownContainer.tsx +0 -111
  375. package/src/components/Suggestions.stories.tsx +0 -215
  376. package/src/hooks/useSelectCurrentThread.tsx +0 -61
  377. package/src/types/MarkdownAction.ts +0 -59
  378. /package/dist/types/src/{blueprints/functions → operations}/create.test.d.ts +0 -0
  379. /package/dist/types/src/{blueprints/functions → operations}/update.test.d.ts +0 -0
@@ -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 MarkdownContainerProps = 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 MarkdownContainer = forwardRef<HTMLDivElement, MarkdownContainerProps>(
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 { MarkdownContainer, type MarkdownContainerProps } from './MarkdownContainer';
6
+ export { MarkdownContainer as default } from './MarkdownContainer';
@@ -0,0 +1,13 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type ComponentType, lazy } from 'react';
6
+
7
+ export type { MarkdownContainerProps } from './MarkdownContainer';
8
+
9
+ export const MarkdownCard: ComponentType<any> = lazy(() => import('./MarkdownCard'));
10
+ export const MarkdownEditableCard: ComponentType<any> = lazy(() =>
11
+ import('./MarkdownCard').then((m) => ({ default: m.MarkdownEditableCard })),
12
+ );
13
+ export const MarkdownContainer: ComponentType<any> = lazy(() => import('./MarkdownContainer'));
@@ -5,4 +5,3 @@
5
5
  export * from './useEditorMenuOptions';
6
6
  export * from './useExtensions';
7
7
  export * from './useLinkQuery';
8
- export * from './useSelectCurrentThread';
@@ -15,7 +15,7 @@ import {
15
15
  } from '@dxos/react-ui-editor';
16
16
  import { Domino } from '@dxos/ui';
17
17
 
18
- import { meta } from '../meta';
18
+ import { meta } from '#meta';
19
19
 
20
20
  export type UseEditorMenuOptionsProps = {
21
21
  editorView?: EditorView;
@@ -56,10 +56,10 @@ export const useEditorMenuOptions = ({
56
56
  content: () => {
57
57
  const pressEl = Domino.of('span').text('Press');
58
58
  const triggerEls = trigger.map((text) =>
59
- Domino.of('span').classNames('mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm').text(text),
59
+ Domino.of('span').classNames('mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-xs').text(text),
60
60
  );
61
61
  const forCommandsEl = Domino.of('span').text('for commands.');
62
- return Domino.of('div').children(pressEl, ...triggerEls, forCommandsEl).root;
62
+ return Domino.of('div').append(pressEl, ...triggerEls, forCommandsEl).root;
63
63
  },
64
64
  };
65
65
 
@@ -3,29 +3,26 @@
3
3
  //
4
4
 
5
5
  import { type ViewUpdate } from '@codemirror/view';
6
- import React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';
7
- import { createRoot } from 'react-dom/client';
6
+ import { useMemo } from 'react';
8
7
 
9
- import { Common } from '@dxos/app-framework';
10
- import { useOperationInvoker } from '@dxos/app-framework/react';
8
+ import { fromUrlPath } from '@dxos/app-toolkit';
11
9
  import { debounceAndThrottle } from '@dxos/async';
12
10
  import { Obj } from '@dxos/echo';
13
11
  import { createDocAccessor } from '@dxos/echo-db';
14
12
  import { invariant } from '@dxos/invariant';
15
13
  import { getSpace, useObject } from '@dxos/react-client/echo';
16
14
  import { useIdentity } from '@dxos/react-client/halo';
17
- import { Icon, ThemeProvider } from '@dxos/react-ui';
15
+ import { useThemeContext } from '@dxos/react-ui';
18
16
  import { type SelectionManager } from '@dxos/react-ui-attention';
19
17
  import { Text } from '@dxos/schema';
18
+ import { Domino } from '@dxos/ui';
20
19
  import {
21
20
  Cursor,
22
21
  type EditorStateStore,
23
22
  EditorView,
24
- type EditorViewMode,
25
23
  type Extension,
26
24
  InputModeExtensions,
27
25
  type PreviewOptions,
28
- type RenderCallback,
29
26
  createDataExtensions,
30
27
  decorateMarkdown,
31
28
  documentId,
@@ -36,12 +33,13 @@ import {
36
33
  preview,
37
34
  replacer,
38
35
  selectionState,
39
- typewriter,
36
+ snippets,
40
37
  } from '@dxos/ui-editor';
41
- import { defaultTx } from '@dxos/ui-theme';
42
- import { isTruthy } from '@dxos/util';
38
+ import { type EditorViewMode, type RenderCallback } from '@dxos/ui-editor/types';
39
+ import { isTruthy, safeUrl } from '@dxos/util';
40
+
41
+ import { Markdown } from '#types';
43
42
 
44
- import { Markdown } from '../types';
45
43
  import { setFallbackName } from '../util';
46
44
 
47
45
  export type DocumentType = Markdown.Document | Text.Text | { id: string; text: string };
@@ -49,12 +47,16 @@ export type DocumentType = Markdown.Document | Text.Text | { id: string; text: s
49
47
  export type ExtensionsOptions = {
50
48
  id: string;
51
49
  object?: DocumentType;
52
- invokePromise?: Common.Capability.OperationInvoker['invokePromise'];
53
50
  settings?: Markdown.Settings;
54
- selectionManager?: SelectionManager;
51
+ compact?: boolean;
55
52
  viewMode?: EditorViewMode;
53
+ editable?: boolean;
54
+ selectionManager?: SelectionManager;
56
55
  editorStateStore?: EditorStateStore;
57
56
  previewOptions?: PreviewOptions;
57
+ platform?: 'mobile' | 'desktop';
58
+ /** Callback when an internal link is clicked. */
59
+ onSelectObject?: (objectId: string) => void;
58
60
  };
59
61
 
60
62
  // TODO(burdon): Merge with createBaseExtensions below.
@@ -62,12 +64,14 @@ export const useExtensions = ({
62
64
  id,
63
65
  object,
64
66
  settings,
65
- selectionManager,
67
+ compact,
66
68
  viewMode,
69
+ selectionManager,
67
70
  editorStateStore,
68
71
  previewOptions,
72
+ onSelectObject,
69
73
  }: ExtensionsOptions): Extension[] => {
70
- const { invokePromise } = useOperationInvoker();
74
+ const { platform } = useThemeContext();
71
75
  const identity = useIdentity();
72
76
  const space = getSpace(object);
73
77
 
@@ -89,24 +93,27 @@ export const useExtensions = ({
89
93
  id,
90
94
  object,
91
95
  settings,
92
- selectionManager,
96
+ compact,
93
97
  viewMode,
98
+ selectionManager,
94
99
  previewOptions,
95
- invokePromise,
100
+ platform,
101
+ onSelectObject,
96
102
  }),
97
103
  [
98
104
  id,
99
105
  object,
106
+ compact,
100
107
  viewMode,
101
- invokePromise,
108
+ selectionManager,
102
109
  previewOptions,
103
110
  settings,
104
111
  settings?.debug,
105
112
  settings?.editorInputMode,
106
113
  settings?.folding,
107
114
  settings?.numberedHeadings,
108
- settings?.typewriter,
109
- selectionManager,
115
+ platform,
116
+ onSelectObject,
110
117
  ],
111
118
  );
112
119
 
@@ -144,16 +151,18 @@ export const useExtensions = ({
144
151
  const createBaseExtensions = ({
145
152
  id,
146
153
  object,
147
- invokePromise,
154
+ onSelectObject,
148
155
  settings,
149
- selectionManager,
156
+ compact,
150
157
  viewMode,
158
+ selectionManager,
151
159
  previewOptions,
160
+ platform,
152
161
  }: ExtensionsOptions): Extension[] => {
153
162
  const extensions: Extension[] = [
154
163
  selectionManager && selectionChange(selectionManager),
155
164
  settings?.editorInputMode && InputModeExtensions[settings.editorInputMode],
156
- settings?.folding && folding(),
165
+ settings?.folding && !compact && platform !== 'mobile' && folding(),
157
166
  ].filter(isTruthy);
158
167
 
159
168
  //
@@ -166,17 +175,8 @@ const createBaseExtensions = ({
166
175
  decorateMarkdown({
167
176
  selectionChangeDelay: 100,
168
177
  numberedHeadings: settings?.numberedHeadings ? { from: 2 } : undefined,
169
- // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
170
- // TODO(burdon): Create dx-tag.
171
- renderLinkButton:
172
- invokePromise && (object || id)
173
- ? createLinkRenderer((targetId: string) => {
174
- void invokePromise(Common.LayoutOperation.Open, {
175
- subject: [targetId],
176
- pivotId: object && Obj.isObject(object) ? Obj.getDXN(object).toString() : id,
177
- });
178
- })
179
- : undefined,
178
+ // TODO(wittjosiah): For internal links render the label of the object.
179
+ renderLinkButton: onSelectObject && createRenderLink(onSelectObject),
180
180
  }),
181
181
  linkTooltip(renderLinkTooltip),
182
182
  preview(previewOptions),
@@ -186,9 +186,9 @@ const createBaseExtensions = ({
186
186
  }
187
187
 
188
188
  if (settings?.debug) {
189
- const items = settings.typewriter?.split(/[,\n]/) ?? '';
189
+ const items = settings.snippets?.split(/[,\n]/) ?? '';
190
190
  if (items) {
191
- extensions.push(typewriter({ items }));
191
+ extensions.push(snippets({ items }));
192
192
  }
193
193
  }
194
194
 
@@ -196,79 +196,67 @@ const createBaseExtensions = ({
196
196
  };
197
197
 
198
198
  const selectionChange = (selectionManager: SelectionManager) => {
199
- return EditorView.updateListener.of(
200
- debounceAndThrottle((update: ViewUpdate) => {
201
- if (update.selectionSet) {
202
- const id = update.state.facet(documentId);
203
- const cursorConverter = update.state.facet(Cursor.converter);
204
- const selection = update.state.selection;
205
- const ranges = selection.ranges
206
- .map((range) => ({
207
- from: cursorConverter.toCursor(range.from),
208
- to: cursorConverter.toCursor(range.to),
209
- }))
210
- .filter(({ from, to }) => to > from);
199
+ const debouncedHandler = debounceAndThrottle((update: ViewUpdate) => {
200
+ const id = update.state.facet(documentId);
201
+ const cursorConverter = update.state.facet(Cursor.converter);
202
+ const selection = update.state.selection;
203
+ const ranges = selection.ranges
204
+ .map((range) => ({
205
+ from: cursorConverter.toCursor(range.from),
206
+ to: cursorConverter.toCursor(range.to),
207
+ }))
208
+ .filter(({ from, to }) => to > from);
211
209
 
212
- selectionManager.updateMultiRange(id, ranges);
213
- }
214
- }, 100),
215
- );
216
- };
210
+ selectionManager.updateMultiRange(id, ranges);
211
+ }, 100);
217
212
 
218
- // TODO(burdon): Factor out styles.
219
- const style = {
220
- hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',
221
- icon: 'inline-block leading-none mis-1 cursor-pointer',
213
+ return EditorView.updateListener.of((update: ViewUpdate) => {
214
+ if (update.selectionSet) {
215
+ debouncedHandler(update);
216
+ }
217
+ });
222
218
  };
223
219
 
224
- const createLinkRenderer =
220
+ const createRenderLink =
225
221
  (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>
226
222
  (el, { url }) => {
227
223
  // TODO(burdon): Formalize/document internal link format.
228
- const isInternal =
229
- url.startsWith('/') ||
230
- // TODO(wittjosiah): This should probably be parsed out on paste?
231
- url.startsWith(window.location.origin);
224
+ const isInternal = url.startsWith('/') || url.startsWith(window.location.origin);
225
+ const qualifiedId = isInternal ? fromUrlPath(new URL(url, window.location.origin).pathname) : undefined;
226
+ const icon = Domino.of('span')
227
+ .classNames('dx-link ms-1 inline-block align-[-0.125em]')
228
+ .append(Domino.svg(isInternal ? 'ph--arrow-square-down--regular' : 'ph--arrow-square-out--regular'));
232
229
 
233
- const options: AnchorHTMLAttributes<any> = isInternal
234
- ? {
235
- onClick: () => {
236
- const qualifiedId = url.split('/').at(-1);
237
- invariant(qualifiedId, 'Invalid link format.');
238
- onSelectObject(qualifiedId);
239
- },
240
- }
241
- : {
242
- href: url,
243
- rel: 'noreferrer',
244
- target: '_blank',
245
- };
230
+ if (isInternal) {
231
+ invariant(qualifiedId, 'Invalid link format.');
232
+ icon
233
+ .attributes({ role: 'button', tabindex: '0' })
234
+ .on('click', (event) => {
235
+ event.preventDefault();
236
+ event.stopPropagation();
237
+ onSelectObject(qualifiedId);
238
+ })
239
+ .on('keydown', (event) => {
240
+ const keyboardEvent = event as KeyboardEvent;
241
+ if (keyboardEvent.key !== 'Enter' && keyboardEvent.key !== ' ') {
242
+ return;
243
+ }
246
244
 
247
- renderRoot(
248
- el,
249
- <a {...options} className={style.hover}>
250
- <Icon
251
- icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}
252
- size={4}
253
- classNames={style.icon}
254
- />
255
- </a>,
256
- );
245
+ keyboardEvent.preventDefault();
246
+ keyboardEvent.stopPropagation();
247
+ onSelectObject(qualifiedId);
248
+ });
249
+ }
250
+
251
+ el.appendChild(icon.root);
257
252
  };
258
253
 
259
254
  const renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {
260
- const web = new URL(url);
261
- renderRoot(
262
- el,
263
- <a href={url} rel='noreferrer' target='_blank' className={style.hover}>
264
- {web.origin}
265
- <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />
266
- </a>,
255
+ el.appendChild(
256
+ Domino.of('a')
257
+ .attributes({ href: url, target: '_blank', rel: 'noreferrer' })
258
+ .classNames('dx-link flex items-center gap-2')
259
+ .text(safeUrl(url)?.toString() ?? url)
260
+ .append(Domino.svg('ph--arrow-square-out--regular')).root,
267
261
  );
268
262
  };
269
-
270
- // TODO(burdon): REMOVE.
271
- const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {
272
- createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);
273
- return root;
274
- };
@@ -5,21 +5,23 @@
5
5
  import * as Option from 'effect/Option';
6
6
  import { useCallback, useMemo } from 'react';
7
7
 
8
- import { Common } from '@dxos/app-framework';
9
- import { usePluginManager } from '@dxos/app-framework/react';
8
+ import { usePluginManager } from '@dxos/app-framework/ui';
9
+ import { AppCapabilities } from '@dxos/app-toolkit';
10
10
  import { type Database, Filter, Obj, Query, Type } from '@dxos/echo';
11
11
  import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from '@dxos/echo/internal';
12
12
  import { toLocalizedString, useTranslation } from '@dxos/react-ui';
13
13
  import { type EditorMenuGroup, type EditorMenuItem } from '@dxos/react-ui-editor';
14
14
  import { insertAtCursor, insertAtLineStart } from '@dxos/ui-editor';
15
15
 
16
+ import { Markdown } from '../types';
17
+
16
18
  export const useLinkQuery = (db: Database.Database | undefined) => {
17
19
  const { t } = useTranslation();
18
20
 
19
21
  const manager = usePluginManager();
20
22
  const resolve = useCallback(
21
23
  (typename: string) =>
22
- manager.capabilities.getAll(Common.Capability.Metadata).find(({ id }) => id === typename)?.metadata ?? {},
24
+ manager.capabilities.getAll(AppCapabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {},
23
25
  [manager],
24
26
  );
25
27
 
@@ -36,6 +38,7 @@ export const useLinkQuery = (db: Database.Database | undefined) => {
36
38
 
37
39
  const handleLinkQuery = useCallback(
38
40
  async (query?: string): Promise<EditorMenuGroup[]> => {
41
+ // A second "@" switches the link query into block-embed mode, so "@@foo" searches for "foo".
39
42
  const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');
40
43
  const results = await db?.query(Query.select(filter)).run();
41
44
 
@@ -49,7 +52,7 @@ export const useLinkQuery = (db: Database.Database | undefined) => {
49
52
  // TODO(wittjosiah): Remove metadata labels.
50
53
  const type = Obj.getTypename(object)!;
51
54
  const metadata = resolve(type);
52
- return metadata.label?.(object) || ['object name placeholder', { ns: type, default: 'New object' }];
55
+ return metadata.label?.(object) || ['object-name.placeholder', { ns: type, defaultValue: 'New object' }];
53
56
  };
54
57
 
55
58
  const items =
@@ -65,6 +68,7 @@ export const useLinkQuery = (db: Database.Database | undefined) => {
65
68
  icon: metadata.icon,
66
69
  onSelect: ({ view, head }) => {
67
70
  const link = `[${label}](${Obj.getDXN(object)})`;
71
+ // "@@" inserts a block embed on its own line instead of an inline link.
68
72
  if (query?.startsWith('@')) {
69
73
  insertAtLineStart(view, head, `!${link}\n`);
70
74
  } else {
@@ -74,9 +78,30 @@ export const useLinkQuery = (db: Database.Database | undefined) => {
74
78
  };
75
79
  }) ?? [];
76
80
 
77
- return [{ id: 'echo', items }];
81
+ // Add "Create new document" option at the end.
82
+ const createItem: EditorMenuItem = {
83
+ id: 'create-document',
84
+ label: ['add-object.label', { ns: Markdown.Document.typename }],
85
+ icon: 'ph--plus--regular',
86
+ onSelect: ({ view, head }) => {
87
+ const doc = Markdown.make({ name: name || undefined });
88
+ db?.add(doc);
89
+ const label = name || t('object-name.placeholder', { ns: Markdown.Document.typename });
90
+ const link = `[${label}](${Obj.getDXN(doc)})`;
91
+ if (query?.startsWith('@')) {
92
+ insertAtLineStart(view, head, `!${link}\n`);
93
+ } else {
94
+ insertAtCursor(view, head, `${link} `);
95
+ }
96
+ },
97
+ };
98
+
99
+ return [
100
+ { id: 'echo', items },
101
+ { id: 'create', items: [createItem] },
102
+ ];
78
103
  },
79
- [db, filter, resolve],
104
+ [db, filter, resolve, t],
80
105
  );
81
106
 
82
107
  return handleLinkQuery;
package/src/index.ts CHANGED
@@ -2,10 +2,14 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import { Plugin } from '@dxos/app-framework';
6
+
7
+ import { meta } from './meta';
8
+
5
9
  export { MarkdownCapabilities, MarkdownEvents } from './types';
6
10
 
7
11
  export * from './meta';
8
12
  export * from './types';
9
13
  export * from './util';
10
14
 
11
- export * from './MarkdownPlugin';
15
+ export const MarkdownPlugin = Plugin.lazy(meta, () => import('#plugin'));
package/src/meta.ts CHANGED
@@ -6,7 +6,7 @@ import { type Plugin } from '@dxos/app-framework';
6
6
  import { trim } from '@dxos/util';
7
7
 
8
8
  export const meta: Plugin.Meta = {
9
- id: 'dxos.org/plugin/markdown',
9
+ id: 'org.dxos.plugin.markdown',
10
10
  name: 'Markdown',
11
11
  description: trim`
12
12
  Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.
@@ -0,0 +1,20 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Operation } from '@dxos/compute';
8
+
9
+ import { Markdown } from '../types';
10
+ import { CreateMarkdown } from './definitions';
11
+
12
+ const handler: Operation.WithHandler<typeof CreateMarkdown> = CreateMarkdown.pipe(
13
+ Operation.withHandler(({ name, content }) =>
14
+ Effect.succeed({
15
+ object: Markdown.make({ name, content }),
16
+ }),
17
+ ),
18
+ );
19
+
20
+ export default handler;