@dxos/plugin-markdown 0.8.4-main.406dc2a → 0.8.4-main.52d7546f51

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 (362) hide show
  1. package/dist/lib/browser/MarkdownCard-7VIO7R66.mjs +11 -0
  2. package/dist/lib/browser/MarkdownContainer-6E43EDAU.mjs +11 -0
  3. package/dist/lib/browser/anchor-sort-JBAZRPE7.mjs +33 -0
  4. package/dist/lib/browser/anchor-sort-JBAZRPE7.mjs.map +7 -0
  5. package/dist/lib/browser/app-graph-serializer-6Q5YBUPW.mjs +59 -0
  6. package/dist/lib/browser/app-graph-serializer-6Q5YBUPW.mjs.map +7 -0
  7. package/dist/lib/browser/blueprint-definition-6HOAW2E6.mjs +20 -0
  8. package/dist/lib/browser/blueprint-definition-6HOAW2E6.mjs.map +7 -0
  9. package/dist/lib/browser/blueprints/index.mjs +8 -0
  10. package/dist/lib/browser/blueprints/index.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-O6XUPW6S.mjs → chunk-2AAD3W6X.mjs} +12 -8
  12. package/dist/lib/browser/chunk-2AAD3W6X.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-4GT3QWMK.mjs +167 -0
  14. package/dist/lib/browser/chunk-4GT3QWMK.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-6SM75KL3.mjs +8 -0
  16. package/dist/lib/browser/chunk-6SM75KL3.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-7AQTX6D5.mjs +105 -0
  18. package/dist/lib/browser/chunk-7AQTX6D5.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-EZZFREFN.mjs +58 -0
  20. package/dist/lib/browser/chunk-EZZFREFN.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-HHRUUWGH.mjs +796 -0
  22. package/dist/lib/browser/chunk-HHRUUWGH.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-HQTBT5IY.mjs +176 -0
  24. package/dist/lib/browser/chunk-HQTBT5IY.mjs.map +7 -0
  25. package/dist/lib/browser/cli/index.mjs +33 -0
  26. package/dist/lib/browser/cli/index.mjs.map +7 -0
  27. package/dist/lib/browser/index.mjs +125 -143
  28. package/dist/lib/browser/index.mjs.map +4 -4
  29. package/dist/lib/browser/meta.json +1 -1
  30. package/dist/lib/browser/operation-resolver-UBQUPSXC.mjs +53 -0
  31. package/dist/lib/browser/operation-resolver-UBQUPSXC.mjs.map +7 -0
  32. package/dist/lib/browser/react-surface-7Z6AB26V.mjs +213 -0
  33. package/dist/lib/browser/react-surface-7Z6AB26V.mjs.map +7 -0
  34. package/dist/lib/browser/settings-V2XOFSD5.mjs +36 -0
  35. package/dist/lib/browser/settings-V2XOFSD5.mjs.map +7 -0
  36. package/dist/lib/browser/state-6Y3JB64H.mjs +29 -0
  37. package/dist/lib/browser/state-6Y3JB64H.mjs.map +7 -0
  38. package/dist/lib/browser/types/index.mjs +10 -3
  39. package/dist/lib/node-esm/MarkdownCard-YC3R2TQW.mjs +12 -0
  40. package/dist/lib/node-esm/MarkdownCard-YC3R2TQW.mjs.map +7 -0
  41. package/dist/lib/node-esm/MarkdownContainer-TTRUOXU6.mjs +12 -0
  42. package/dist/lib/node-esm/MarkdownContainer-TTRUOXU6.mjs.map +7 -0
  43. package/dist/lib/node-esm/anchor-sort-IQMDZRA3.mjs +34 -0
  44. package/dist/lib/node-esm/anchor-sort-IQMDZRA3.mjs.map +7 -0
  45. package/dist/lib/node-esm/app-graph-serializer-STEPJH57.mjs +60 -0
  46. package/dist/lib/node-esm/app-graph-serializer-STEPJH57.mjs.map +7 -0
  47. package/dist/lib/node-esm/blueprint-definition-UGDFF5OZ.mjs +21 -0
  48. package/dist/lib/node-esm/blueprint-definition-UGDFF5OZ.mjs.map +7 -0
  49. package/dist/lib/node-esm/blueprints/index.mjs +9 -0
  50. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  51. package/dist/lib/node-esm/chunk-AGZOFIK2.mjs +10 -0
  52. package/dist/lib/node-esm/chunk-AGZOFIK2.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-D46D75SK.mjs +797 -0
  54. package/dist/lib/node-esm/chunk-D46D75SK.mjs.map +7 -0
  55. package/dist/lib/node-esm/chunk-DCKB3AVD.mjs +59 -0
  56. package/dist/lib/node-esm/chunk-DCKB3AVD.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-K2IIYNCG.mjs +106 -0
  58. package/dist/lib/node-esm/chunk-K2IIYNCG.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-LOZVC2WA.mjs +177 -0
  60. package/dist/lib/node-esm/chunk-LOZVC2WA.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-XO3IEQJE.mjs → chunk-MLZQCT2N.mjs} +12 -8
  62. package/dist/lib/node-esm/chunk-MLZQCT2N.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-USKAPINH.mjs +168 -0
  64. package/dist/lib/node-esm/chunk-USKAPINH.mjs.map +7 -0
  65. package/dist/lib/node-esm/cli/index.mjs +34 -0
  66. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  67. package/dist/lib/node-esm/index.mjs +125 -143
  68. package/dist/lib/node-esm/index.mjs.map +4 -4
  69. package/dist/lib/node-esm/meta.json +1 -1
  70. package/dist/lib/node-esm/operation-resolver-QAGXDA5E.mjs +54 -0
  71. package/dist/lib/node-esm/operation-resolver-QAGXDA5E.mjs.map +7 -0
  72. package/dist/lib/node-esm/react-surface-VIXAH5CF.mjs +214 -0
  73. package/dist/lib/node-esm/react-surface-VIXAH5CF.mjs.map +7 -0
  74. package/dist/lib/node-esm/settings-EXSH2KF4.mjs +37 -0
  75. package/dist/lib/node-esm/settings-EXSH2KF4.mjs.map +7 -0
  76. package/dist/lib/node-esm/state-TVF2XT2T.mjs +30 -0
  77. package/dist/lib/node-esm/state-TVF2XT2T.mjs.map +7 -0
  78. package/dist/lib/node-esm/types/index.mjs +10 -3
  79. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  80. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  81. package/dist/types/src/{functions/open.d.ts → blueprints/functions/create.d.ts} +5 -4
  82. package/dist/types/src/blueprints/functions/create.d.ts.map +1 -0
  83. package/dist/types/src/blueprints/functions/create.test.d.ts +2 -0
  84. package/dist/types/src/blueprints/functions/create.test.d.ts.map +1 -0
  85. package/dist/types/src/blueprints/functions/index.d.ts +4 -0
  86. package/dist/types/src/blueprints/functions/index.d.ts.map +1 -0
  87. package/dist/types/src/blueprints/functions/open.d.ts +14 -0
  88. package/dist/types/src/blueprints/functions/open.d.ts.map +1 -0
  89. package/dist/types/src/blueprints/functions/update.d.ts +19 -0
  90. package/dist/types/src/blueprints/functions/update.d.ts.map +1 -0
  91. package/dist/types/src/blueprints/functions/update.test.d.ts +2 -0
  92. package/dist/types/src/blueprints/functions/update.test.d.ts.map +1 -0
  93. package/dist/types/src/blueprints/index.d.ts +2 -0
  94. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  95. package/dist/types/src/blueprints/markdown-blueprint.d.ts +21 -0
  96. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  97. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +6 -0
  98. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +1 -0
  99. package/dist/types/src/capabilities/anchor-sort/index.d.ts +3 -0
  100. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +1 -0
  101. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +5 -0
  102. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +1 -0
  103. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +3 -0
  104. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +1 -0
  105. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +5 -0
  106. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +1 -0
  107. package/dist/types/src/capabilities/artifact-definition/index.d.ts +3 -0
  108. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +1 -0
  109. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +11 -0
  110. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -0
  111. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +3 -0
  112. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -0
  113. package/dist/types/src/capabilities/index.d.ts +6 -17
  114. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/operation-resolver/index.d.ts +3 -0
  116. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -0
  117. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +5 -0
  118. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -0
  119. package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
  120. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
  121. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
  122. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
  123. package/dist/types/src/capabilities/settings/index.d.ts +3 -0
  124. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
  125. package/dist/types/src/capabilities/settings/settings.d.ts +7 -0
  126. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
  127. package/dist/types/src/capabilities/state/index.d.ts +3 -0
  128. package/dist/types/src/capabilities/state/index.d.ts.map +1 -0
  129. package/dist/types/src/capabilities/state/state.d.ts +5 -0
  130. package/dist/types/src/capabilities/state/state.d.ts.map +1 -0
  131. package/dist/types/src/cli/index.d.ts +2 -0
  132. package/dist/types/src/cli/index.d.ts.map +1 -0
  133. package/dist/types/src/cli/plugin.d.ts +3 -0
  134. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  135. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +5 -4
  136. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  137. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +5 -5
  138. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  139. package/dist/types/src/components/MarkdownContainer.d.ts +21 -11
  140. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  141. package/dist/types/src/components/MarkdownContainer.stories.d.ts +33 -0
  142. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
  143. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  144. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  145. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +43 -23
  146. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  147. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +5 -110
  148. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  149. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +30 -0
  150. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  151. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +12 -0
  152. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  153. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -2
  154. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  155. package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
  156. package/dist/types/src/components/index.d.ts +7 -2
  157. package/dist/types/src/components/index.d.ts.map +1 -1
  158. package/dist/types/src/hooks/index.d.ts +3 -0
  159. package/dist/types/src/hooks/index.d.ts.map +1 -1
  160. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  161. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  162. package/dist/types/src/hooks/useExtensions.d.ts +21 -0
  163. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  164. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  165. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  166. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  167. package/dist/types/src/index.d.ts +2 -2
  168. package/dist/types/src/index.d.ts.map +1 -1
  169. package/dist/types/src/meta.d.ts +2 -2
  170. package/dist/types/src/meta.d.ts.map +1 -1
  171. package/dist/types/src/testing.d.ts +6 -0
  172. package/dist/types/src/testing.d.ts.map +1 -0
  173. package/dist/types/src/translations.d.ts +33 -0
  174. package/dist/types/src/translations.d.ts.map +1 -1
  175. package/dist/types/src/types/Markdown.d.ts +16 -16
  176. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  177. package/dist/types/src/types/MarkdownAction.d.ts +63 -31
  178. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  179. package/dist/types/src/types/capabilities.d.ts +22 -0
  180. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  181. package/dist/types/src/types/events.d.ts +5 -0
  182. package/dist/types/src/types/events.d.ts.map +1 -0
  183. package/dist/types/src/types/index.d.ts +3 -0
  184. package/dist/types/src/types/index.d.ts.map +1 -1
  185. package/dist/types/src/types/types.d.ts +2 -2
  186. package/dist/types/src/types/types.d.ts.map +1 -1
  187. package/dist/types/src/util.d.ts +6 -3
  188. package/dist/types/src/util.d.ts.map +1 -1
  189. package/dist/types/src/util.test.d.ts +2 -0
  190. package/dist/types/src/util.test.d.ts.map +1 -0
  191. package/dist/types/tsconfig.tsbuildinfo +1 -1
  192. package/package.json +94 -56
  193. package/src/MarkdownPlugin.tsx +65 -94
  194. package/src/blueprints/functions/create.conversations.json +1 -0
  195. package/src/blueprints/functions/create.test.ts +92 -0
  196. package/src/blueprints/functions/create.ts +35 -0
  197. package/src/blueprints/functions/index.ts +7 -0
  198. package/src/{functions → blueprints/functions}/open.ts +11 -10
  199. package/src/blueprints/functions/update.conversations.json +1 -0
  200. package/src/blueprints/functions/update.test.ts +215 -0
  201. package/src/blueprints/functions/update.ts +79 -0
  202. package/src/blueprints/index.ts +5 -0
  203. package/src/blueprints/markdown-blueprint.ts +38 -0
  204. package/src/capabilities/anchor-sort/anchor-sort.ts +37 -0
  205. package/src/capabilities/anchor-sort/index.ts +7 -0
  206. package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +60 -0
  207. package/src/capabilities/app-graph-serializer/index.ts +7 -0
  208. package/src/capabilities/artifact-definition/artifact-definition.ts +110 -0
  209. package/src/capabilities/artifact-definition/index.ts +7 -0
  210. package/src/capabilities/blueprint-definition/blueprint-definition.ts +26 -0
  211. package/src/capabilities/blueprint-definition/index.ts +7 -0
  212. package/src/capabilities/index.ts +6 -12
  213. package/src/capabilities/operation-resolver/index.ts +7 -0
  214. package/src/capabilities/operation-resolver/operation-resolver.ts +45 -0
  215. package/src/capabilities/react-surface/index.ts +7 -0
  216. package/src/capabilities/react-surface/react-surface.tsx +102 -0
  217. package/src/capabilities/settings/index.ts +7 -0
  218. package/src/capabilities/settings/settings.ts +37 -0
  219. package/src/capabilities/state/index.ts +7 -0
  220. package/src/capabilities/state/state.ts +31 -0
  221. package/src/cli/index.ts +5 -0
  222. package/src/cli/plugin.ts +30 -0
  223. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +26 -44
  224. package/src/components/MarkdownCard/MarkdownCard.tsx +41 -53
  225. package/src/components/MarkdownContainer.stories.tsx +68 -54
  226. package/src/components/MarkdownContainer.tsx +106 -250
  227. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  228. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +56 -38
  229. package/src/components/MarkdownEditor/MarkdownEditor.tsx +227 -273
  230. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +162 -0
  231. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +66 -0
  232. package/src/components/MarkdownSettings/MarkdownSettings.tsx +48 -34
  233. package/src/components/Suggestions.stories.tsx +35 -39
  234. package/src/components/index.ts +10 -3
  235. package/src/hooks/index.ts +3 -0
  236. package/src/hooks/useEditorMenuOptions.ts +68 -0
  237. package/src/{extensions.tsx → hooks/useExtensions.tsx} +70 -95
  238. package/src/hooks/useLinkQuery.ts +83 -0
  239. package/src/hooks/useSelectCurrentThread.tsx +37 -32
  240. package/src/index.ts +3 -2
  241. package/src/meta.ts +5 -5
  242. package/src/testing.ts +27 -0
  243. package/src/translations.ts +6 -0
  244. package/src/types/Markdown.ts +8 -9
  245. package/src/types/MarkdownAction.ts +48 -18
  246. package/src/types/capabilities.ts +38 -0
  247. package/src/types/events.ts +14 -0
  248. package/src/types/index.ts +4 -0
  249. package/src/types/types.ts +3 -2
  250. package/src/util.test.ts +44 -0
  251. package/src/util.tsx +80 -11
  252. package/dist/lib/browser/MarkdownCard-AGWOTODZ.mjs +0 -83
  253. package/dist/lib/browser/MarkdownCard-AGWOTODZ.mjs.map +0 -7
  254. package/dist/lib/browser/MarkdownContainer-MV2UNAUV.mjs +0 -751
  255. package/dist/lib/browser/MarkdownContainer-MV2UNAUV.mjs.map +0 -7
  256. package/dist/lib/browser/anchor-sort-YWJI3BKT.mjs +0 -32
  257. package/dist/lib/browser/anchor-sort-YWJI3BKT.mjs.map +0 -7
  258. package/dist/lib/browser/app-graph-serializer-KYDFCUOW.mjs +0 -51
  259. package/dist/lib/browser/app-graph-serializer-KYDFCUOW.mjs.map +0 -7
  260. package/dist/lib/browser/blueprint-definition-BHRMFZAC.mjs +0 -11
  261. package/dist/lib/browser/chunk-6KU5DKP7.mjs +0 -51
  262. package/dist/lib/browser/chunk-6KU5DKP7.mjs.map +0 -7
  263. package/dist/lib/browser/chunk-HBBEHOP3.mjs +0 -106
  264. package/dist/lib/browser/chunk-HBBEHOP3.mjs.map +0 -7
  265. package/dist/lib/browser/chunk-O6XUPW6S.mjs.map +0 -7
  266. package/dist/lib/browser/chunk-ODB2PTBP.mjs +0 -28
  267. package/dist/lib/browser/chunk-ODB2PTBP.mjs.map +0 -7
  268. package/dist/lib/browser/chunk-OY6CGPOO.mjs +0 -16
  269. package/dist/lib/browser/chunk-OY6CGPOO.mjs.map +0 -7
  270. package/dist/lib/browser/chunk-XMT6PMU5.mjs +0 -79
  271. package/dist/lib/browser/chunk-XMT6PMU5.mjs.map +0 -7
  272. package/dist/lib/browser/chunk-Z5PDJNBV.mjs +0 -22
  273. package/dist/lib/browser/chunk-Z5PDJNBV.mjs.map +0 -7
  274. package/dist/lib/browser/intent-resolver-XHVCZZHU.mjs +0 -62
  275. package/dist/lib/browser/intent-resolver-XHVCZZHU.mjs.map +0 -7
  276. package/dist/lib/browser/react-surface-3A2GO3BN.mjs +0 -215
  277. package/dist/lib/browser/react-surface-3A2GO3BN.mjs.map +0 -7
  278. package/dist/lib/browser/settings-XY265Y2Q.mjs +0 -28
  279. package/dist/lib/browser/settings-XY265Y2Q.mjs.map +0 -7
  280. package/dist/lib/browser/state-6QODXCSZ.mjs +0 -37
  281. package/dist/lib/browser/state-6QODXCSZ.mjs.map +0 -7
  282. package/dist/lib/browser/toolkit-YA65QX2S.mjs +0 -76
  283. package/dist/lib/browser/toolkit-YA65QX2S.mjs.map +0 -7
  284. package/dist/lib/node-esm/MarkdownCard-B2IWTFOC.mjs +0 -84
  285. package/dist/lib/node-esm/MarkdownCard-B2IWTFOC.mjs.map +0 -7
  286. package/dist/lib/node-esm/MarkdownContainer-J2R3DLCQ.mjs +0 -752
  287. package/dist/lib/node-esm/MarkdownContainer-J2R3DLCQ.mjs.map +0 -7
  288. package/dist/lib/node-esm/anchor-sort-FCRYL2FX.mjs +0 -33
  289. package/dist/lib/node-esm/anchor-sort-FCRYL2FX.mjs.map +0 -7
  290. package/dist/lib/node-esm/app-graph-serializer-FAUQM3BH.mjs +0 -52
  291. package/dist/lib/node-esm/app-graph-serializer-FAUQM3BH.mjs.map +0 -7
  292. package/dist/lib/node-esm/blueprint-definition-XYFKMIDR.mjs +0 -12
  293. package/dist/lib/node-esm/chunk-7RDNIMTF.mjs +0 -24
  294. package/dist/lib/node-esm/chunk-7RDNIMTF.mjs.map +0 -7
  295. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs +0 -17
  296. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs.map +0 -7
  297. package/dist/lib/node-esm/chunk-FVI7LPC3.mjs +0 -107
  298. package/dist/lib/node-esm/chunk-FVI7LPC3.mjs.map +0 -7
  299. package/dist/lib/node-esm/chunk-FWZKC6X5.mjs +0 -80
  300. package/dist/lib/node-esm/chunk-FWZKC6X5.mjs.map +0 -7
  301. package/dist/lib/node-esm/chunk-VCG2U522.mjs +0 -29
  302. package/dist/lib/node-esm/chunk-VCG2U522.mjs.map +0 -7
  303. package/dist/lib/node-esm/chunk-XO3IEQJE.mjs.map +0 -7
  304. package/dist/lib/node-esm/chunk-ZBXV4ON7.mjs +0 -52
  305. package/dist/lib/node-esm/chunk-ZBXV4ON7.mjs.map +0 -7
  306. package/dist/lib/node-esm/intent-resolver-7A2EXGZQ.mjs +0 -63
  307. package/dist/lib/node-esm/intent-resolver-7A2EXGZQ.mjs.map +0 -7
  308. package/dist/lib/node-esm/react-surface-RCLL5WVQ.mjs +0 -216
  309. package/dist/lib/node-esm/react-surface-RCLL5WVQ.mjs.map +0 -7
  310. package/dist/lib/node-esm/settings-H3UDD3KO.mjs +0 -29
  311. package/dist/lib/node-esm/settings-H3UDD3KO.mjs.map +0 -7
  312. package/dist/lib/node-esm/state-W3PECOJX.mjs +0 -38
  313. package/dist/lib/node-esm/state-W3PECOJX.mjs.map +0 -7
  314. package/dist/lib/node-esm/toolkit-HSIKUGNK.mjs +0 -77
  315. package/dist/lib/node-esm/toolkit-HSIKUGNK.mjs.map +0 -7
  316. package/dist/types/src/capabilities/anchor-sort.d.ts +0 -6
  317. package/dist/types/src/capabilities/anchor-sort.d.ts.map +0 -1
  318. package/dist/types/src/capabilities/app-graph-serializer.d.ts +0 -4
  319. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +0 -1
  320. package/dist/types/src/capabilities/artifact-definition.d.ts +0 -3
  321. package/dist/types/src/capabilities/artifact-definition.d.ts.map +0 -1
  322. package/dist/types/src/capabilities/blueprint-definition.d.ts +0 -5
  323. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +0 -1
  324. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  325. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  326. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  327. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  328. package/dist/types/src/capabilities/react-surface.d.ts +0 -4
  329. package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
  330. package/dist/types/src/capabilities/settings.d.ts +0 -4
  331. package/dist/types/src/capabilities/settings.d.ts.map +0 -1
  332. package/dist/types/src/capabilities/state.d.ts +0 -11
  333. package/dist/types/src/capabilities/state.d.ts.map +0 -1
  334. package/dist/types/src/capabilities/toolkit.d.ts +0 -4
  335. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  336. package/dist/types/src/components/Toolbar.stories.d.ts +0 -48
  337. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  338. package/dist/types/src/events.d.ts +0 -4
  339. package/dist/types/src/events.d.ts.map +0 -1
  340. package/dist/types/src/extensions.d.ts +0 -22
  341. package/dist/types/src/extensions.d.ts.map +0 -1
  342. package/dist/types/src/functions/diff.d.ts +0 -6
  343. package/dist/types/src/functions/diff.d.ts.map +0 -1
  344. package/dist/types/src/functions/index.d.ts +0 -3
  345. package/dist/types/src/functions/index.d.ts.map +0 -1
  346. package/dist/types/src/functions/open.d.ts.map +0 -1
  347. package/src/capabilities/anchor-sort.ts +0 -30
  348. package/src/capabilities/app-graph-serializer.ts +0 -54
  349. package/src/capabilities/artifact-definition.ts +0 -112
  350. package/src/capabilities/blueprint-definition.ts +0 -39
  351. package/src/capabilities/capabilities.ts +0 -21
  352. package/src/capabilities/intent-resolver.ts +0 -58
  353. package/src/capabilities/react-surface.tsx +0 -115
  354. package/src/capabilities/settings.ts +0 -25
  355. package/src/capabilities/state.ts +0 -31
  356. package/src/capabilities/toolkit.ts +0 -49
  357. package/src/components/Toolbar.stories.tsx +0 -118
  358. package/src/events.ts +0 -11
  359. package/src/functions/diff.ts +0 -37
  360. package/src/functions/index.ts +0 -6
  361. /package/dist/lib/browser/{blueprint-definition-BHRMFZAC.mjs.map → MarkdownCard-7VIO7R66.mjs.map} +0 -0
  362. /package/dist/lib/{node-esm/blueprint-definition-XYFKMIDR.mjs.map → browser/MarkdownContainer-6E43EDAU.mjs.map} +0 -0
@@ -0,0 +1,66 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+ import React, { useCallback, useState } from 'react';
7
+
8
+ import { type FileInfo } from '@dxos/app-toolkit';
9
+ import { invariant } from '@dxos/invariant';
10
+ import { type ThemedClassName } from '@dxos/react-ui';
11
+ import { EditorToolbar, type EditorToolbarProps } from '@dxos/react-ui-editor';
12
+ import { type EditorViewMode } from '@dxos/ui-editor';
13
+
14
+ import { FileUpload, type FileUploadAction } from './FileUpload';
15
+
16
+ export type MarkdownEditorToolbarProps = ThemedClassName<
17
+ {
18
+ id: string;
19
+ editorView?: EditorView;
20
+ onFileUpload?: (file: File) => Promise<FileInfo | undefined>;
21
+ } & Pick<EditorToolbarProps, 'role' | 'state' | 'customActions' | 'onAction' | 'onViewModeChange'>
22
+ >;
23
+
24
+ export const MarkdownEditorToolbar = ({
25
+ classNames,
26
+ id,
27
+ role,
28
+ state,
29
+ editorView,
30
+ customActions,
31
+ onAction,
32
+ onFileUpload,
33
+ onViewModeChange,
34
+ }: MarkdownEditorToolbarProps) => {
35
+ const [upload, setUpload] = useState<FileUploadAction | null>(null);
36
+ const uploadRef = useCallback((next: FileUploadAction) => setUpload(() => next), []);
37
+
38
+ const handleViewModeChange = useCallback((mode: EditorViewMode) => onViewModeChange?.(mode), [onViewModeChange]);
39
+
40
+ const getView = useCallback(() => {
41
+ invariant(editorView);
42
+ return editorView;
43
+ }, [editorView]);
44
+
45
+ if (!editorView) {
46
+ return <div />;
47
+ }
48
+
49
+ return (
50
+ <>
51
+ <EditorToolbar
52
+ classNames={classNames}
53
+ attendableId={id}
54
+ role={role}
55
+ state={state}
56
+ customActions={customActions}
57
+ getView={getView}
58
+ onAction={onAction}
59
+ onImageUpload={upload ?? undefined}
60
+ onViewModeChange={handleViewModeChange}
61
+ />
62
+
63
+ {onFileUpload && <FileUpload ref={uploadRef} editorView={editorView} onFileUpload={onFileUpload} />}
64
+ </>
65
+ );
66
+ };
@@ -5,25 +5,30 @@
5
5
  import React from 'react';
6
6
 
7
7
  import { Input, Select, useTranslation } from '@dxos/react-ui';
8
- import { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';
9
- import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';
8
+ import { Settings } from '@dxos/react-ui-form';
9
+ import { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/ui-editor';
10
10
 
11
11
  import { meta } from '../../meta';
12
12
  import { type Markdown } from '../../types';
13
13
 
14
- export const MarkdownSettings = ({ settings }: { settings: Markdown.Settings }) => {
14
+ export type MarkdownSettingsComponentProps = {
15
+ settings: Markdown.Settings;
16
+ onSettingsChange: (fn: (current: Markdown.Settings) => Markdown.Settings) => void;
17
+ };
18
+
19
+ export const MarkdownSettings = ({ settings, onSettingsChange }: MarkdownSettingsComponentProps) => {
15
20
  const { t } = useTranslation(meta.id);
16
21
 
17
22
  // TODO(wittjosiah): Add skill test confirmation for entering vim mode.
18
23
  return (
19
- <ControlPage>
20
- <ControlSection title={t('settings title', { ns: meta.id })}>
21
- <ControlGroup>
22
- <ControlItemInput title={t('default view mode label')}>
24
+ <Settings.Root>
25
+ <Settings.Section title={t('settings title', { ns: meta.id })}>
26
+ <Settings.Group>
27
+ <Settings.ItemInput title={t('default view mode label')}>
23
28
  <Select.Root
24
29
  value={settings.defaultViewMode}
25
30
  onValueChange={(value) => {
26
- settings.defaultViewMode = value as EditorViewMode;
31
+ onSettingsChange((s) => ({ ...s, defaultViewMode: value as EditorViewMode }));
27
32
  }}
28
33
  >
29
34
  <Select.TriggerButton />
@@ -32,7 +37,7 @@ export const MarkdownSettings = ({ settings }: { settings: Markdown.Settings })
32
37
  <Select.Viewport>
33
38
  {EditorViewModes.map((mode) => (
34
39
  <Select.Option key={mode} value={mode}>
35
- {t(`${mode} mode label`, { ns: 'react-ui-editor' })}
40
+ {t(`${mode} mode label`, { ns: '@dxos/react-ui-editor' })}
36
41
  </Select.Option>
37
42
  ))}
38
43
  </Select.Viewport>
@@ -40,13 +45,13 @@ export const MarkdownSettings = ({ settings }: { settings: Markdown.Settings })
40
45
  </Select.Content>
41
46
  </Select.Portal>
42
47
  </Select.Root>
43
- </ControlItemInput>
48
+ </Settings.ItemInput>
44
49
 
45
- <ControlItemInput title={t('editor input mode label')}>
50
+ <Settings.ItemInput title={t('editor input mode label')}>
46
51
  <Select.Root
47
52
  value={settings.editorInputMode ?? 'default'}
48
53
  onValueChange={(value) => {
49
- settings.editorInputMode = value as EditorInputMode;
54
+ onSettingsChange((s) => ({ ...s, editorInputMode: value as EditorInputMode }));
50
55
  }}
51
56
  >
52
57
  <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />
@@ -63,46 +68,55 @@ export const MarkdownSettings = ({ settings }: { settings: Markdown.Settings })
63
68
  </Select.Content>
64
69
  </Select.Portal>
65
70
  </Select.Root>
66
- </ControlItemInput>
71
+ </Settings.ItemInput>
67
72
 
68
- <ControlItemInput title={t('settings toolbar label')}>
69
- <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />
70
- </ControlItemInput>
73
+ <Settings.ItemInput title={t('settings toolbar label')}>
74
+ <Input.Switch
75
+ checked={settings.toolbar}
76
+ onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, toolbar: !!checked }))}
77
+ />
78
+ </Settings.ItemInput>
71
79
 
72
- <ControlItemInput title={t('settings numbered headings label')}>
80
+ <Settings.ItemInput title={t('settings numbered headings label')}>
73
81
  <Input.Switch
74
82
  checked={settings.numberedHeadings}
75
- onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}
83
+ onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, numberedHeadings: !!checked }))}
76
84
  />
77
- </ControlItemInput>
85
+ </Settings.ItemInput>
78
86
 
79
- <ControlItemInput title={t('settings folding label')}>
80
- <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />
81
- </ControlItemInput>
87
+ <Settings.ItemInput title={t('settings folding label')}>
88
+ <Input.Switch
89
+ checked={settings.folding}
90
+ onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, folding: !!checked }))}
91
+ />
92
+ </Settings.ItemInput>
82
93
 
83
- <ControlItemInput title={t('settings experimental label')}>
94
+ <Settings.ItemInput title={t('settings experimental label')}>
84
95
  <Input.Switch
85
96
  checked={settings.experimental}
86
- onCheckedChange={(checked) => (settings.experimental = !!checked)}
97
+ onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, experimental: !!checked }))}
87
98
  />
88
- </ControlItemInput>
99
+ </Settings.ItemInput>
89
100
 
90
- <ControlItemInput title={t('settings debug label')}>
91
- <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />
92
- </ControlItemInput>
101
+ <Settings.ItemInput title={t('settings debug label')}>
102
+ <Input.Switch
103
+ checked={settings.debug}
104
+ onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, debug: !!checked }))}
105
+ />
106
+ </Settings.ItemInput>
93
107
 
94
108
  {settings.debug && (
95
- <ControlItemInput title={t('settings debug textarea label', { ns: meta.id })}>
109
+ <Settings.ItemInput title={t('settings debug textarea label', { ns: meta.id })}>
96
110
  <Input.TextArea
97
111
  rows={5}
98
112
  value={settings.typewriter}
99
- onChange={({ target: { value } }) => (settings.typewriter = value)}
113
+ onChange={({ target: { value } }) => onSettingsChange((s) => ({ ...s, typewriter: value }))}
100
114
  placeholder={t('settings debug placeholder')}
101
115
  />
102
- </ControlItemInput>
116
+ </Settings.ItemInput>
103
117
  )}
104
- </ControlGroup>
105
- </ControlSection>
106
- </ControlPage>
118
+ </Settings.Group>
119
+ </Settings.Section>
120
+ </Settings.Root>
107
121
  );
108
122
  };
@@ -3,37 +3,34 @@
3
3
  //
4
4
 
5
5
  import { type Meta } from '@storybook/react-vite';
6
+ import * as Effect from 'effect/Effect';
6
7
  import * as Function from 'effect/Function';
7
8
  import * as Match from 'effect/Match';
8
9
  import * as Option from 'effect/Option';
9
10
  import * as Schema from 'effect/Schema';
10
11
  import React, { type FC, useEffect, useMemo, useState } from 'react';
11
12
 
12
- import { Capabilities, IntentPlugin, SettingsPlugin, useCapability, useIntentDispatcher } from '@dxos/app-framework';
13
13
  import { withPluginManager } from '@dxos/app-framework/testing';
14
+ import { useAtomCapability, useCapability } from '@dxos/app-framework/ui';
14
15
  import { Obj, Ref, Type } from '@dxos/echo';
16
+ import { createDocAccessor, toCursorRange } from '@dxos/echo-db';
15
17
  import { invariant } from '@dxos/invariant';
16
18
  import { ClientPlugin } from '@dxos/plugin-client';
17
- import { GraphPlugin } from '@dxos/plugin-graph';
18
19
  import { PreviewPlugin } from '@dxos/plugin-preview';
19
- import { SpacePlugin } from '@dxos/plugin-space';
20
- import { StorybookLayoutPlugin } from '@dxos/plugin-storybook-layout';
21
- import { ThemePlugin } from '@dxos/plugin-theme';
20
+ import { StorybookPlugin, corePlugins } from '@dxos/plugin-testing';
22
21
  import { faker } from '@dxos/random';
23
- import { createDocAccessor, fullyQualifiedId, toCursorRange, useQueue, useSpace } from '@dxos/react-client/echo';
22
+ import { useQueue, useSpace } from '@dxos/react-client/echo';
24
23
  import { IconButton, Toolbar } from '@dxos/react-ui';
24
+ import { Layout } from '@dxos/react-ui';
25
25
  import { withTheme } from '@dxos/react-ui/testing';
26
- import { type EditorSelection, type Range, useTextEditor } from '@dxos/react-ui-editor';
27
- import { StackItem } from '@dxos/react-ui-stack';
28
- import { defaultTx } from '@dxos/react-ui-theme';
29
- import { DataType } from '@dxos/schema';
26
+ import { useTextEditor } from '@dxos/react-ui-editor';
30
27
  import { render } from '@dxos/storybook-utils';
28
+ import { Message } from '@dxos/types';
29
+ import { type EditorSelection, type Range } from '@dxos/ui-editor';
31
30
 
32
- import { MarkdownCapabilities } from '../capabilities';
33
31
  import { MarkdownPlugin } from '../MarkdownPlugin';
34
- import { meta } from '../meta';
35
32
  import { translations } from '../translations';
36
- import { Markdown } from '../types';
33
+ import { Markdown, MarkdownCapabilities } from '../types';
37
34
 
38
35
  import { MarkdownContainer } from './MarkdownContainer';
39
36
 
@@ -49,26 +46,25 @@ const TestItem = Schema.Struct({
49
46
  description: 'Product description',
50
47
  }),
51
48
  }).pipe(
52
- Type.Obj({
49
+ Type.object({
53
50
  typename: 'dxos.org/type/Test',
54
51
  version: '0.1.0',
55
52
  }),
56
53
  );
57
54
 
58
55
  const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, content }) => {
59
- const { dispatchPromise: dispatch } = useIntentDispatcher();
60
56
  const { parentRef } = useTextEditor({ initialValue: content });
61
- const { editorState } = useCapability(MarkdownCapabilities.State);
57
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
62
58
 
63
59
  const space = useSpace();
64
60
  const queueDxn = useMemo(() => space && space.queues.create().dxn, [space]);
65
- const queue = useQueue<DataType.Message>(queueDxn);
61
+ const queue = useQueue<Message.Message>(queueDxn);
66
62
 
67
63
  const handleInsert = async () => {
68
64
  invariant(space);
69
65
  invariant(queue);
70
66
  await queue.append([
71
- Obj.make(DataType.Message, {
67
+ Obj.make(Message.Message, {
72
68
  created: new Date().toISOString(),
73
69
  sender: { role: 'assistant' },
74
70
  blocks: [{ _tag: 'text', text: 'Hello' }],
@@ -80,7 +76,7 @@ const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, conten
80
76
  const text = await doc.content.load();
81
77
  const accessor = createDocAccessor(text, ['content']);
82
78
  const cursor = Function.pipe(
83
- editorState.getState(fullyQualifiedId(doc))?.selection,
79
+ editorState.getState(Obj.getDXN(doc).toString())?.selection,
84
80
  Option.fromNullable,
85
81
  Option.map(selectionToRange),
86
82
  Option.map((range) => toCursorRange(accessor, range.from, range.to)),
@@ -94,7 +90,7 @@ const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, conten
94
90
 
95
91
  // void dispatch(
96
92
  // createIntent(CollaborationActions.InsertContent, {
97
- // target: doc as any as Type.Expando,
93
+ // target: doc as any as TestSchema.Expando,
98
94
  // object: Ref.fromDXN(new DXN(DXN.kind.QUEUE, [...queue.dxn.parts, message.id])),
99
95
  // at: cursor,
100
96
  // label: 'Proposal',
@@ -103,20 +99,20 @@ const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, conten
103
99
  };
104
100
 
105
101
  return (
106
- <StackItem.Content toolbar>
102
+ <Layout.Main toolbar>
107
103
  <Toolbar.Root>
108
104
  <IconButton icon='ph--plus--regular' disabled={!queue} label='Insert' onClick={handleInsert} />
109
105
  </Toolbar.Root>
110
106
  <div ref={parentRef} className='p-4' />
111
- </StackItem.Content>
107
+ </Layout.Main>
112
108
  );
113
109
  };
114
110
 
115
111
  const DefaultStory = ({ document, chat }: { document: string; chat: string }) => {
116
112
  const space = useSpace();
117
113
  const [doc, setDoc] = useState<Markdown.Document>();
118
- const settings = useCapability(Capabilities.SettingsStore).getStore<Markdown.Settings>(meta.id)!.value;
119
- const { editorState } = useCapability(MarkdownCapabilities.State);
114
+ const settings = useAtomCapability(MarkdownCapabilities.Settings);
115
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
120
116
 
121
117
  useEffect(() => {
122
118
  if (!space) {
@@ -124,10 +120,15 @@ const DefaultStory = ({ document, chat }: { document: string; chat: string }) =>
124
120
  }
125
121
 
126
122
  const doc = space.db.add(
127
- Markdown.makeDocument({
123
+ Markdown.make({
128
124
  name: 'Test',
129
125
  content: document.replaceAll(/\[(\w+)\]/g, (_, label) => {
130
- const obj = space.db.add(Obj.make(TestItem, { title: label, description: faker.lorem.paragraph() }));
126
+ const obj = space.db.add(
127
+ Obj.make(TestItem, {
128
+ title: label,
129
+ description: faker.lorem.paragraph(),
130
+ }),
131
+ );
131
132
  const dxn = Ref.make(obj).dxn.toString();
132
133
  return `[${label}](${dxn})`;
133
134
  }),
@@ -141,10 +142,9 @@ const DefaultStory = ({ document, chat }: { document: string; chat: string }) =>
141
142
  return null;
142
143
  }
143
144
 
144
- // TODO(burdon): Layout issue.
145
145
  return (
146
146
  <div className='grid grid-cols-2 bs-full overflow-hidden'>
147
- <MarkdownContainer id={doc.id} object={doc} settings={settings} editorStateStore={editorState} />
147
+ <MarkdownContainer id={doc.id} subject={doc} settings={settings} editorStateStore={editorState} />
148
148
  <TestChat doc={doc} content={chat} />
149
149
  </div>
150
150
  );
@@ -154,25 +154,21 @@ const storybook: Meta<typeof DefaultStory> = {
154
154
  title: 'plugins/plugin-markdown/Suggestions',
155
155
  render: render(DefaultStory),
156
156
  decorators: [
157
- withTheme,
157
+ withTheme(),
158
158
  withPluginManager({
159
159
  plugins: [
160
+ ...corePlugins(),
161
+ StorybookPlugin({}),
160
162
  ClientPlugin({
161
163
  types: [Markdown.Document, TestItem],
162
- onClientInitialized: async ({ client }) => {
163
- await client.halo.createIdentity();
164
- },
164
+ onClientInitialized: ({ client }) =>
165
+ Effect.gen(function* () {
166
+ yield* Effect.promise(() => client.halo.createIdentity());
167
+ }),
165
168
  }),
166
- SpacePlugin({}),
167
- GraphPlugin(),
168
- IntentPlugin(),
169
- SettingsPlugin(),
170
169
 
171
- // UI
172
- ThemePlugin({ tx: defaultTx }),
173
170
  MarkdownPlugin(),
174
171
  PreviewPlugin(),
175
- StorybookLayoutPlugin({}),
176
172
  ],
177
173
  }),
178
174
  ],
@@ -2,9 +2,16 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from 'react';
5
+ import { type LazyExoticComponent, lazy } from 'react';
6
6
 
7
+ import { type MarkdownCard as MarkdownCardType } from './MarkdownCard';
8
+ import { type MarkdownContainer as MarkdownContainerType } from './MarkdownContainer';
9
+
10
+ export * from './MarkdownCard';
11
+ export * from './MarkdownContainer';
7
12
  export * from './MarkdownSettings';
8
13
 
9
- export const MarkdownContainer = lazy(() => import('./MarkdownContainer'));
10
- export const MarkdownCard = lazy(() => import('./MarkdownCard'));
14
+ export const MarkdownCard: LazyExoticComponent<typeof MarkdownCardType> = lazy(() => import('./MarkdownCard'));
15
+ export const MarkdownContainer: LazyExoticComponent<typeof MarkdownContainerType> = lazy(
16
+ () => import('./MarkdownContainer'),
17
+ );
@@ -2,4 +2,7 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
+ export * from './useEditorMenuOptions';
6
+ export * from './useExtensions';
7
+ export * from './useLinkQuery';
5
8
  export * from './useSelectCurrentThread';
@@ -0,0 +1,68 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+ import { useCallback, useMemo, useRef } from 'react';
7
+
8
+ import { toLocalizedString, useTranslation } from '@dxos/react-ui';
9
+ import {
10
+ type EditorMenuGroup,
11
+ type UseEditorMenuProps,
12
+ filterMenuGroups,
13
+ formattingCommands,
14
+ linkSlashCommands,
15
+ } from '@dxos/react-ui-editor';
16
+ import { Domino } from '@dxos/ui';
17
+
18
+ import { meta } from '../meta';
19
+
20
+ export type UseEditorMenuOptionsProps = {
21
+ editorView?: EditorView;
22
+ slashCommandGroups?: EditorMenuGroup[];
23
+ onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;
24
+ };
25
+
26
+ export const useEditorMenuOptions = ({
27
+ editorView,
28
+ slashCommandGroups,
29
+ onLinkQuery,
30
+ }: UseEditorMenuOptionsProps): UseEditorMenuProps => {
31
+ const { t } = useTranslation(meta.id);
32
+
33
+ const getMenu = useCallback<NonNullable<UseEditorMenuProps['getMenu']>>(
34
+ ({ text, trigger }) => {
35
+ switch (trigger) {
36
+ case '@': {
37
+ return onLinkQuery?.(text) ?? [];
38
+ }
39
+
40
+ case '/':
41
+ default: {
42
+ return filterMenuGroups([formattingCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>
43
+ text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true,
44
+ );
45
+ }
46
+ }
47
+ },
48
+ [slashCommandGroups, onLinkQuery],
49
+ );
50
+
51
+ const viewRef = useRef(editorView);
52
+ return useMemo<UseEditorMenuProps>(() => {
53
+ const trigger = onLinkQuery ? ['/', '@'] : ['/'];
54
+ const placeholder = {
55
+ delay: 3_000,
56
+ content: () => {
57
+ const pressEl = Domino.of('span').text('Press');
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),
60
+ );
61
+ const forCommandsEl = Domino.of('span').text('for commands.');
62
+ return Domino.of('div').children(pressEl, ...triggerEls, forCommandsEl).root;
63
+ },
64
+ };
65
+
66
+ return { viewRef, getMenu, trigger, placeholder };
67
+ }, [getMenu, onLinkQuery]);
68
+ };