@dxos/plugin-markdown 0.8.4-main.f5c0578 → 0.8.4-main.fcc0d83b33

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 (340) hide show
  1. package/dist/lib/browser/MarkdownSettings-YCTZJL5V.mjs +32 -0
  2. package/dist/lib/browser/MarkdownSettings-YCTZJL5V.mjs.map +7 -0
  3. package/dist/lib/browser/blueprints/index.mjs +51 -0
  4. package/dist/lib/browser/blueprints/index.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-5T3SYJIP.mjs +158 -0
  6. package/dist/lib/browser/chunk-5T3SYJIP.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-FG2ZL4PE.mjs +121 -0
  8. package/dist/lib/browser/chunk-FG2ZL4PE.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  10. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  11. package/dist/lib/browser/cli/index.mjs +39 -0
  12. package/dist/lib/browser/cli/index.mjs.map +7 -0
  13. package/dist/lib/browser/create-VSHCHZS4.mjs +30 -0
  14. package/dist/lib/browser/create-VSHCHZS4.mjs.map +7 -0
  15. package/dist/lib/browser/create-markdown-6LRG62W3.mjs +22 -0
  16. package/dist/lib/browser/create-markdown-6LRG62W3.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +569 -140
  18. package/dist/lib/browser/index.mjs.map +4 -4
  19. package/dist/lib/browser/meta.json +1 -1
  20. package/dist/lib/browser/open-TKTPEN3D.mjs +21 -0
  21. package/dist/lib/browser/open-TKTPEN3D.mjs.map +7 -0
  22. package/dist/lib/browser/operations/index.mjs +14 -0
  23. package/dist/lib/browser/operations/index.mjs.map +7 -0
  24. package/dist/lib/browser/scroll-to-anchor-HWERBJKN.mjs +49 -0
  25. package/dist/lib/browser/scroll-to-anchor-HWERBJKN.mjs.map +7 -0
  26. package/dist/lib/browser/set-view-mode-Z7HGT7TY.mjs +26 -0
  27. package/dist/lib/browser/set-view-mode-Z7HGT7TY.mjs.map +7 -0
  28. package/dist/lib/browser/translations.mjs +43 -0
  29. package/dist/lib/browser/translations.mjs.map +7 -0
  30. package/dist/lib/browser/types/index.mjs +11 -5
  31. package/dist/lib/browser/update-markdown-EJSHQRSC.mjs +45 -0
  32. package/dist/lib/browser/update-markdown-EJSHQRSC.mjs.map +7 -0
  33. package/dist/lib/node-esm/MarkdownSettings-LE66LODL.mjs +33 -0
  34. package/dist/lib/node-esm/MarkdownSettings-LE66LODL.mjs.map +7 -0
  35. package/dist/lib/node-esm/blueprints/index.mjs +52 -0
  36. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-43GF7QLH.mjs +159 -0
  38. package/dist/lib/node-esm/chunk-43GF7QLH.mjs.map +7 -0
  39. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  40. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  41. package/dist/lib/node-esm/chunk-IHC6DFTK.mjs +122 -0
  42. package/dist/lib/node-esm/chunk-IHC6DFTK.mjs.map +7 -0
  43. package/dist/lib/node-esm/cli/index.mjs +40 -0
  44. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  45. package/dist/lib/node-esm/create-PDW42WOY.mjs +31 -0
  46. package/dist/lib/node-esm/create-PDW42WOY.mjs.map +7 -0
  47. package/dist/lib/node-esm/create-markdown-BBPZPLQN.mjs +23 -0
  48. package/dist/lib/node-esm/create-markdown-BBPZPLQN.mjs.map +7 -0
  49. package/dist/lib/node-esm/index.mjs +569 -140
  50. package/dist/lib/node-esm/index.mjs.map +4 -4
  51. package/dist/lib/node-esm/meta.json +1 -1
  52. package/dist/lib/node-esm/open-B6GFN5DR.mjs +22 -0
  53. package/dist/lib/node-esm/open-B6GFN5DR.mjs.map +7 -0
  54. package/dist/lib/node-esm/operations/index.mjs +15 -0
  55. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  56. package/dist/lib/node-esm/scroll-to-anchor-CWEWWIS7.mjs +50 -0
  57. package/dist/lib/node-esm/scroll-to-anchor-CWEWWIS7.mjs.map +7 -0
  58. package/dist/lib/node-esm/set-view-mode-OMNNTSNM.mjs +27 -0
  59. package/dist/lib/node-esm/set-view-mode-OMNNTSNM.mjs.map +7 -0
  60. package/dist/lib/node-esm/translations.mjs +44 -0
  61. package/dist/lib/node-esm/translations.mjs.map +7 -0
  62. package/dist/lib/node-esm/types/index.mjs +11 -5
  63. package/dist/lib/node-esm/update-markdown-TAEAHVD2.mjs +46 -0
  64. package/dist/lib/node-esm/update-markdown-TAEAHVD2.mjs.map +7 -0
  65. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  66. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  67. package/dist/types/src/blueprints/index.d.ts +2 -0
  68. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  69. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  70. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  71. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  72. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  74. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -9
  76. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -0
  78. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/index.d.ts +9 -15
  80. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  81. package/dist/types/src/capabilities/node.d.ts +4 -0
  82. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  83. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  84. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  85. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  86. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/settings.d.ts +4 -2
  88. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/state.d.ts +4 -9
  90. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  91. package/dist/types/src/cli/index.d.ts +2 -0
  92. package/dist/types/src/cli/index.d.ts.map +1 -0
  93. package/dist/types/src/cli/plugin.d.ts +3 -0
  94. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  95. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  96. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +52 -21
  98. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  99. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
  100. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  101. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +33 -0
  102. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  103. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +13 -0
  104. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  105. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  106. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  107. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  108. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  109. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  110. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  111. package/dist/types/src/components/index.d.ts +3 -3
  112. package/dist/types/src/components/index.d.ts.map +1 -1
  113. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  114. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  115. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  116. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  117. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts +15 -0
  118. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts.map +1 -0
  119. package/dist/types/src/containers/MarkdownCard/index.d.ts +3 -0
  120. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  121. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  122. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  123. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  124. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  125. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  126. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  127. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  128. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  129. package/dist/types/src/containers/index.d.ts +6 -0
  130. package/dist/types/src/containers/index.d.ts.map +1 -0
  131. package/dist/types/src/hooks/index.d.ts +3 -1
  132. package/dist/types/src/hooks/index.d.ts.map +1 -1
  133. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  134. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  135. package/dist/types/src/hooks/useExtensions.d.ts +25 -0
  136. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  137. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  138. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  139. package/dist/types/src/index.d.ts +3 -3
  140. package/dist/types/src/index.d.ts.map +1 -1
  141. package/dist/types/src/meta.d.ts +2 -3
  142. package/dist/types/src/meta.d.ts.map +1 -1
  143. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  144. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  145. package/dist/types/src/operations/create.d.ts +5 -0
  146. package/dist/types/src/operations/create.d.ts.map +1 -0
  147. package/dist/types/src/operations/create.test.d.ts +2 -0
  148. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  149. package/dist/types/src/operations/definitions.d.ts +64 -0
  150. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  151. package/dist/types/src/operations/index.d.ts +4 -0
  152. package/dist/types/src/operations/index.d.ts.map +1 -0
  153. package/dist/types/src/operations/open.d.ts +5 -0
  154. package/dist/types/src/operations/open.d.ts.map +1 -0
  155. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  156. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  157. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  158. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  159. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  160. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  161. package/dist/types/src/operations/update.test.d.ts +2 -0
  162. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  163. package/dist/types/src/testing.d.ts +6 -0
  164. package/dist/types/src/testing.d.ts.map +1 -0
  165. package/dist/types/src/translations.d.ts +74 -32
  166. package/dist/types/src/translations.d.ts.map +1 -1
  167. package/dist/types/src/types/Markdown.d.ts +31 -30
  168. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  169. package/dist/types/src/types/Settings.d.ts +17 -0
  170. package/dist/types/src/types/Settings.d.ts.map +1 -0
  171. package/dist/types/src/types/capabilities.d.ts +34 -0
  172. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  173. package/dist/types/src/types/events.d.ts +5 -0
  174. package/dist/types/src/types/events.d.ts.map +1 -0
  175. package/dist/types/src/types/index.d.ts +4 -2
  176. package/dist/types/src/types/index.d.ts.map +1 -1
  177. package/dist/types/src/types/types.d.ts +3 -2
  178. package/dist/types/src/types/types.d.ts.map +1 -1
  179. package/dist/types/src/util.d.ts +7 -4
  180. package/dist/types/src/util.d.ts.map +1 -1
  181. package/dist/types/src/util.test.d.ts +2 -0
  182. package/dist/types/src/util.test.d.ts.map +1 -0
  183. package/dist/types/tsconfig.tsbuildinfo +1 -1
  184. package/package.json +118 -63
  185. package/src/MarkdownPlugin.tsx +91 -102
  186. package/src/blueprints/index.ts +5 -0
  187. package/src/blueprints/markdown-blueprint.ts +43 -0
  188. package/src/capabilities/anchor-sort.ts +29 -22
  189. package/src/capabilities/app-graph-serializer.ts +52 -42
  190. package/src/capabilities/artifact-definition.ts +87 -96
  191. package/src/capabilities/blueprint-definition.ts +17 -0
  192. package/src/capabilities/index.ts +12 -9
  193. package/src/capabilities/node.ts +11 -0
  194. package/src/capabilities/operation-handler.ts +16 -0
  195. package/src/capabilities/react-surface.tsx +116 -104
  196. package/src/capabilities/settings.ts +30 -18
  197. package/src/capabilities/state.ts +41 -25
  198. package/src/cli/index.ts +5 -0
  199. package/src/cli/plugin.ts +39 -0
  200. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  201. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +64 -38
  202. package/src/components/MarkdownEditor/MarkdownEditor.tsx +251 -267
  203. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +170 -0
  204. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -0
  205. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  206. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -92
  207. package/src/components/MarkdownSettings/index.ts +1 -1
  208. package/src/components/index.ts +4 -5
  209. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +68 -0
  210. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  211. package/src/containers/MarkdownCard/MarkdownEditableCard.tsx +42 -0
  212. package/src/containers/MarkdownCard/index.ts +6 -0
  213. package/src/containers/MarkdownCard/snippet.ts +54 -0
  214. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  215. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  216. package/src/containers/MarkdownContainer/index.ts +6 -0
  217. package/src/containers/index.ts +13 -0
  218. package/src/hooks/index.ts +3 -1
  219. package/src/hooks/useEditorMenuOptions.ts +68 -0
  220. package/src/hooks/useExtensions.tsx +262 -0
  221. package/src/hooks/useLinkQuery.ts +108 -0
  222. package/src/index.ts +4 -3
  223. package/src/meta.ts +6 -9
  224. package/src/operations/create-markdown.ts +20 -0
  225. package/src/operations/create.conversations.json +1 -0
  226. package/src/operations/create.test.ts +98 -0
  227. package/src/operations/create.ts +27 -0
  228. package/src/operations/definitions.ts +120 -0
  229. package/src/operations/index.ts +16 -0
  230. package/src/operations/open.ts +25 -0
  231. package/src/operations/scroll-to-anchor.ts +39 -0
  232. package/src/operations/set-view-mode.ts +24 -0
  233. package/src/operations/update-markdown.ts +51 -0
  234. package/src/operations/update.conversations.json +1 -0
  235. package/src/operations/update.test.ts +215 -0
  236. package/src/testing.ts +27 -0
  237. package/src/translations.ts +26 -31
  238. package/src/types/Markdown.ts +26 -31
  239. package/src/types/Settings.ts +65 -0
  240. package/src/types/capabilities.ts +51 -0
  241. package/src/types/events.ts +14 -0
  242. package/src/types/index.ts +5 -2
  243. package/src/types/types.ts +8 -3
  244. package/src/util.test.ts +44 -0
  245. package/src/util.tsx +83 -8
  246. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs +0 -80
  247. package/dist/lib/browser/MarkdownCard-IMCR4A4V.mjs.map +0 -7
  248. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs +0 -780
  249. package/dist/lib/browser/MarkdownContainer-VGJPHMVG.mjs.map +0 -7
  250. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs +0 -32
  251. package/dist/lib/browser/anchor-sort-AJKRIWFD.mjs.map +0 -7
  252. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs +0 -52
  253. package/dist/lib/browser/app-graph-serializer-OIS3MZX2.mjs.map +0 -7
  254. package/dist/lib/browser/chunk-IKPZHFTW.mjs +0 -30
  255. package/dist/lib/browser/chunk-IKPZHFTW.mjs.map +0 -7
  256. package/dist/lib/browser/chunk-JHH7VL52.mjs +0 -18
  257. package/dist/lib/browser/chunk-JHH7VL52.mjs.map +0 -7
  258. package/dist/lib/browser/chunk-JMBQG2ZC.mjs +0 -50
  259. package/dist/lib/browser/chunk-JMBQG2ZC.mjs.map +0 -7
  260. package/dist/lib/browser/chunk-JTIGSUMB.mjs +0 -80
  261. package/dist/lib/browser/chunk-JTIGSUMB.mjs.map +0 -7
  262. package/dist/lib/browser/chunk-LMJPXTPL.mjs +0 -16
  263. package/dist/lib/browser/chunk-LMJPXTPL.mjs.map +0 -7
  264. package/dist/lib/browser/chunk-MVL4K3OD.mjs +0 -52
  265. package/dist/lib/browser/chunk-MVL4K3OD.mjs.map +0 -7
  266. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs +0 -60
  267. package/dist/lib/browser/intent-resolver-BLLHRSTQ.mjs.map +0 -7
  268. package/dist/lib/browser/react-surface-NL3BZR6H.mjs +0 -208
  269. package/dist/lib/browser/react-surface-NL3BZR6H.mjs.map +0 -7
  270. package/dist/lib/browser/settings-Z7ZV7SLC.mjs +0 -28
  271. package/dist/lib/browser/settings-Z7ZV7SLC.mjs.map +0 -7
  272. package/dist/lib/browser/state-ORTZIEJU.mjs +0 -37
  273. package/dist/lib/browser/state-ORTZIEJU.mjs.map +0 -7
  274. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs +0 -81
  275. package/dist/lib/node-esm/MarkdownCard-JV2YDV3M.mjs.map +0 -7
  276. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs +0 -781
  277. package/dist/lib/node-esm/MarkdownContainer-BJRNCXJZ.mjs.map +0 -7
  278. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs +0 -33
  279. package/dist/lib/node-esm/anchor-sort-N7WEA5E3.mjs.map +0 -7
  280. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs +0 -53
  281. package/dist/lib/node-esm/app-graph-serializer-Q3B44VFB.mjs.map +0 -7
  282. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs +0 -17
  283. package/dist/lib/node-esm/chunk-AYWAYBAY.mjs.map +0 -7
  284. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs +0 -31
  285. package/dist/lib/node-esm/chunk-H4I2FGDZ.mjs.map +0 -7
  286. package/dist/lib/node-esm/chunk-H6TITL7A.mjs +0 -20
  287. package/dist/lib/node-esm/chunk-H6TITL7A.mjs.map +0 -7
  288. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs +0 -51
  289. package/dist/lib/node-esm/chunk-JDMMLOB6.mjs.map +0 -7
  290. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs +0 -81
  291. package/dist/lib/node-esm/chunk-KIRZFVX5.mjs.map +0 -7
  292. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs +0 -53
  293. package/dist/lib/node-esm/chunk-Z4XQ6C3D.mjs.map +0 -7
  294. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs +0 -61
  295. package/dist/lib/node-esm/intent-resolver-NHPUPSWK.mjs.map +0 -7
  296. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs +0 -209
  297. package/dist/lib/node-esm/react-surface-XJ6ODCBE.mjs.map +0 -7
  298. package/dist/lib/node-esm/settings-UCXEWBCT.mjs +0 -29
  299. package/dist/lib/node-esm/settings-UCXEWBCT.mjs.map +0 -7
  300. package/dist/lib/node-esm/state-47WSZG54.mjs +0 -38
  301. package/dist/lib/node-esm/state-47WSZG54.mjs.map +0 -7
  302. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  303. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  304. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  305. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  306. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -7
  307. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  308. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -42
  309. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  310. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  311. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  312. package/dist/types/src/components/MarkdownContainer.d.ts +0 -18
  313. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  314. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -9
  315. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  316. package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
  317. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  318. package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
  319. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  320. package/dist/types/src/events.d.ts +0 -4
  321. package/dist/types/src/events.d.ts.map +0 -1
  322. package/dist/types/src/extensions.d.ts +0 -24
  323. package/dist/types/src/extensions.d.ts.map +0 -1
  324. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  325. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  326. package/dist/types/src/types/MarkdownAction.d.ts +0 -42
  327. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  328. package/src/capabilities/capabilities.ts +0 -21
  329. package/src/capabilities/intent-resolver.ts +0 -58
  330. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -79
  331. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -75
  332. package/src/components/MarkdownCard/index.ts +0 -9
  333. package/src/components/MarkdownContainer.stories.tsx +0 -100
  334. package/src/components/MarkdownContainer.tsx +0 -255
  335. package/src/components/Suggestions.stories.tsx +0 -221
  336. package/src/components/Toolbar.stories.tsx +0 -112
  337. package/src/events.ts +0 -11
  338. package/src/extensions.tsx +0 -328
  339. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  340. package/src/types/MarkdownAction.ts +0 -31
@@ -1,221 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type Meta } from '@storybook/react-vite';
8
- import { Match, Option, Schema, pipe } from 'effect';
9
- import React, { type FC, useEffect, useMemo, useState } from 'react';
10
-
11
- import {
12
- Capabilities,
13
- CollaborationActions,
14
- IntentPlugin,
15
- SettingsPlugin,
16
- contributes,
17
- createIntent,
18
- useCapability,
19
- useIntentDispatcher,
20
- } from '@dxos/app-framework';
21
- import { withPluginManager } from '@dxos/app-framework/testing';
22
- import { Obj, Ref, Type } from '@dxos/echo';
23
- import { invariant } from '@dxos/invariant';
24
- import { DXN } from '@dxos/keys';
25
- import { ClientPlugin } from '@dxos/plugin-client';
26
- import { PreviewPlugin } from '@dxos/plugin-preview';
27
- import { SpacePlugin } from '@dxos/plugin-space';
28
- import { StorybookLayoutPlugin } from '@dxos/plugin-storybook-layout';
29
- import { ThemePlugin } from '@dxos/plugin-theme';
30
- import { faker } from '@dxos/random';
31
- import { createDocAccessor, fullyQualifiedId, toCursorRange, useQueue, useSpace } from '@dxos/react-client/echo';
32
- import { IconButton, Toolbar } from '@dxos/react-ui';
33
- import { type EditorSelection, type Range, command, useTextEditor } from '@dxos/react-ui-editor';
34
- import { StackItem } from '@dxos/react-ui-stack';
35
- import { defaultTx } from '@dxos/react-ui-theme';
36
- import { DataType } from '@dxos/schema';
37
- import { withLayout } from '@dxos/storybook-utils';
38
-
39
- import { MarkdownCapabilities } from '../capabilities';
40
- import { MarkdownPlugin } from '../MarkdownPlugin';
41
- import { meta } from '../meta';
42
- import { translations } from '../translations';
43
- import { Markdown } from '../types';
44
-
45
- import { MarkdownContainer } from './MarkdownContainer';
46
-
47
- faker.seed(1);
48
-
49
- const TestItem = Schema.Struct({
50
- title: Schema.String.annotations({
51
- title: 'Title',
52
- description: 'Product title',
53
- }),
54
- description: Schema.String.annotations({
55
- title: 'Description',
56
- description: 'Product description',
57
- }),
58
- }).pipe(
59
- Type.Obj({
60
- typename: 'dxos.org/type/Test',
61
- version: '0.1.0',
62
- }),
63
- );
64
-
65
- const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, content }) => {
66
- const { dispatchPromise: dispatch } = useIntentDispatcher();
67
- const { parentRef } = useTextEditor({ initialValue: content });
68
- const { editorState } = useCapability(MarkdownCapabilities.State);
69
-
70
- const space = useSpace();
71
- const queueDxn = useMemo(() => space && space.queues.create().dxn, [space]);
72
- const queue = useQueue<DataType.Message>(queueDxn);
73
-
74
- const handleInsert = async () => {
75
- invariant(space);
76
- invariant(queue);
77
- await queue.append([
78
- Obj.make(DataType.Message, {
79
- created: new Date().toISOString(),
80
- sender: { role: 'assistant' },
81
- blocks: [{ _tag: 'text', text: 'Hello' }],
82
- }),
83
- ]);
84
- const message = queue.objects.at(-1);
85
- invariant(message);
86
-
87
- const text = await doc.content.load();
88
- const accessor = createDocAccessor(text, ['content']);
89
- const cursor = pipe(
90
- editorState.getState(fullyQualifiedId(doc))?.selection,
91
- Option.fromNullable,
92
- Option.map(selectionToRange),
93
- Option.map((range) => toCursorRange(accessor, range.from, range.to)),
94
- Option.getOrUndefined,
95
- );
96
-
97
- // {
98
- // const ref = refFromDXN(new DXN(DXN.kind.QUEUE, [...queue.dxn.parts, message.id]));
99
- // const message = deref(ref);
100
- // }
101
-
102
- void dispatch(
103
- createIntent(CollaborationActions.InsertContent, {
104
- target: doc as any as Type.Expando,
105
- object: Ref.fromDXN(new DXN(DXN.kind.QUEUE, [...queue.dxn.parts, message.id])),
106
- at: cursor,
107
- label: 'Proposal',
108
- }),
109
- );
110
- };
111
-
112
- return (
113
- <StackItem.Content toolbar>
114
- <Toolbar.Root>
115
- <IconButton icon='ph--plus--regular' disabled={!queue} label='Insert' onClick={handleInsert} />
116
- </Toolbar.Root>
117
- <div ref={parentRef} className='p-4' />
118
- </StackItem.Content>
119
- );
120
- };
121
-
122
- const DefaultStory = ({ document, chat }: { document: string; chat: string }) => {
123
- const space = useSpace();
124
- const [doc, setDoc] = useState<Markdown.Document>();
125
- const settings = useCapability(Capabilities.SettingsStore).getStore<Markdown.Settings>(meta.id)!.value;
126
- const { editorState } = useCapability(MarkdownCapabilities.State);
127
-
128
- useEffect(() => {
129
- if (!space) {
130
- return undefined;
131
- }
132
-
133
- const doc = space.db.add(
134
- Markdown.makeDocument({
135
- name: 'Test',
136
- content: document.replaceAll(/\[(\w+)\]/g, (_, label) => {
137
- const obj = space.db.add(Obj.make(TestItem, { title: label, description: faker.lorem.paragraph() }));
138
- const dxn = Ref.make(obj).dxn.toString();
139
- return `[${label}][${dxn}]`;
140
- }),
141
- }),
142
- );
143
-
144
- setDoc(doc);
145
- }, [space]);
146
-
147
- if (!space || !doc) {
148
- return <></>;
149
- }
150
-
151
- return (
152
- <>
153
- <MarkdownContainer id={doc.id} object={doc} settings={settings} editorStateStore={editorState} />
154
- <TestChat doc={doc} content={chat} />
155
- </>
156
- );
157
- };
158
-
159
- // TODO(burdon): Make consistent.
160
- const storybook: Meta<typeof DefaultStory> = {
161
- title: 'plugins/plugin-markdown/Suggestions',
162
- render: DefaultStory,
163
- decorators: [
164
- withPluginManager({
165
- plugins: [
166
- ThemePlugin({ tx: defaultTx }),
167
- StorybookLayoutPlugin(),
168
- ClientPlugin({
169
- types: [Markdown.Document, TestItem],
170
- onClientInitialized: async ({ client }) => {
171
- await client.halo.createIdentity();
172
- },
173
- }),
174
- SpacePlugin(),
175
- SettingsPlugin(),
176
- IntentPlugin(),
177
- MarkdownPlugin(),
178
- PreviewPlugin(),
179
- ],
180
- capabilities: [contributes(MarkdownCapabilities.Extensions, [() => command()])],
181
- }),
182
- withLayout({ fullscreen: true, classNames: 'grid grid-cols-2' }),
183
- ],
184
- parameters: {
185
- translations,
186
- controls: { disable: true },
187
- },
188
- };
189
-
190
- export default storybook;
191
-
192
- type Story = Meta<typeof DefaultStory>;
193
-
194
- export const Default: Story = {
195
- args: {
196
- chat: 'Hello\n',
197
- document: [
198
- '# Test',
199
- '',
200
- faker.lorem.paragraph(1),
201
- '',
202
- 'This is a [DXOS] story that tests [ECHO] references inside the Markdown plugin.',
203
- '',
204
- faker.lorem.paragraph(3),
205
- '',
206
- ].join('\n'),
207
- },
208
- };
209
-
210
- // TODO(wittjosiah): Factor out.
211
- const selectionToRange = Match.type<EditorSelection>().pipe(
212
- Match.when(
213
- ({ head, anchor }) => (head ? head > anchor : false),
214
- ({ head, anchor }) => ({ from: anchor, to: head! }) as Range,
215
- ),
216
- Match.when(
217
- ({ head, anchor }) => (head ? head < anchor : false),
218
- ({ head, anchor }) => ({ from: head!, to: anchor }) as Range,
219
- ),
220
- Match.orElse(({ anchor }) => ({ from: anchor, to: anchor }) as Range),
221
- );
@@ -1,112 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type Meta } from '@storybook/react-vite';
8
- import React, { type FC, useCallback, useState } from 'react';
9
-
10
- import { invariant } from '@dxos/invariant';
11
- import { PublicKey } from '@dxos/keys';
12
- import { faker } from '@dxos/random';
13
- import { createDocAccessor } from '@dxos/react-client/echo';
14
- import { useThemeContext } from '@dxos/react-ui';
15
- import {
16
- type Comment,
17
- EditorToolbar,
18
- type EditorViewMode,
19
- comments,
20
- createBasicExtensions,
21
- createDataExtensions,
22
- createMarkdownExtensions,
23
- createThemeExtensions,
24
- decorateMarkdown,
25
- editorSlots,
26
- formattingKeymap,
27
- translations,
28
- useComments,
29
- useEditorToolbarState,
30
- useFormattingState,
31
- useTextEditor,
32
- } from '@dxos/react-ui-editor';
33
- import { DataType } from '@dxos/schema';
34
- import { withLayout, withTheme } from '@dxos/storybook-utils';
35
-
36
- faker.seed(101);
37
-
38
- const DefaultStory: FC<{ content?: string }> = ({ content = '' }) => {
39
- const { themeMode } = useThemeContext();
40
- const [text] = useState(DataType.makeText(content));
41
- const toolbarState = useEditorToolbarState({ viewMode: 'preview' });
42
- const formattingObserver = useFormattingState(toolbarState);
43
- const { parentRef, view } = useTextEditor(() => {
44
- return {
45
- id: text.id,
46
- initialValue: text.content,
47
- extensions: [
48
- formattingObserver,
49
- createBasicExtensions({ readOnly: toolbarState.viewMode === 'readonly' }),
50
- createMarkdownExtensions({ themeMode }),
51
- createThemeExtensions({ themeMode, syntaxHighlighting: true, slots: editorSlots }),
52
- createDataExtensions({ id: text.id, text: createDocAccessor(text, ['content']) }),
53
- comments({
54
- onCreate: ({ cursor }) => {
55
- const id = PublicKey.random().toHex();
56
- setComments((comments) => [...comments, { id, cursor }]);
57
- return id;
58
- },
59
- }),
60
- formattingKeymap(),
61
- ...(toolbarState.viewMode !== 'source' ? [decorateMarkdown()] : []),
62
- ],
63
- };
64
- }, [text, formattingObserver, toolbarState.viewMode, themeMode]);
65
-
66
- const handleViewModeChange = (viewMode: EditorViewMode) => {
67
- toolbarState.viewMode = viewMode;
68
- };
69
-
70
- const getView = useCallback(() => {
71
- invariant(view);
72
- return view;
73
- }, [view]);
74
-
75
- const [_comments, setComments] = useState<Comment[]>([]);
76
- useComments(view, text.id, _comments);
77
-
78
- return (
79
- <div role='none' className='flex flex-col'>
80
- <EditorToolbar state={toolbarState ?? {}} getView={getView} viewMode={handleViewModeChange} />
81
- <div className='flex grow overflow-hidden' ref={parentRef} />
82
- </div>
83
- );
84
- };
85
-
86
- const content = [
87
- '# Demo',
88
- '',
89
- 'The editor supports **Markdown** styles.',
90
- '',
91
- faker.lorem.paragraph({ min: 5, max: 8 }),
92
- '',
93
- '',
94
- ].join('\n');
95
-
96
- const meta: Meta<typeof EditorToolbar> = {
97
- title: 'plugins/plugin-markdown/Toolbar',
98
- component: EditorToolbar,
99
- render: DefaultStory as any,
100
- decorators: [withTheme, withLayout({ fullscreen: true })],
101
- parameters: {
102
- translations,
103
- },
104
- };
105
-
106
- export default meta;
107
-
108
- export const Default = {
109
- args: {
110
- content,
111
- },
112
- };
package/src/events.ts DELETED
@@ -1,11 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Events } from '@dxos/app-framework';
6
-
7
- import { meta } from './meta';
8
-
9
- export namespace MarkdownEvents {
10
- export const SetupExtensions = Events.createStateEvent(`${meta.id}/event/setup-extensions`);
11
- }
@@ -1,328 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import { type ViewUpdate } from '@codemirror/view';
6
- import React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';
7
- import { createRoot } from 'react-dom/client';
8
-
9
- import {
10
- LayoutAction,
11
- type PromiseIntentDispatcher,
12
- createIntent,
13
- useCapabilities,
14
- useIntentDispatcher,
15
- } from '@dxos/app-framework';
16
- import { debounceAndThrottle } from '@dxos/async';
17
- import { invariant } from '@dxos/invariant';
18
- import { type QueryResult, createDocAccessor, fullyQualifiedId, getSpace } from '@dxos/react-client/echo';
19
- import { useIdentity } from '@dxos/react-client/halo';
20
- import { Icon, ThemeProvider } from '@dxos/react-ui';
21
- import { type SelectionManager } from '@dxos/react-ui-attention';
22
- import {
23
- type AutocompleteResult,
24
- Cursor,
25
- type EditorStateStore,
26
- EditorView,
27
- type EditorViewMode,
28
- type Extension,
29
- InputModeExtensions,
30
- type PreviewOptions,
31
- type RenderCallback,
32
- autocomplete,
33
- createDataExtensions,
34
- decorateMarkdown,
35
- documentId,
36
- folding,
37
- formattingKeymap,
38
- linkTooltip,
39
- listener,
40
- preview,
41
- selectionState,
42
- typewriter,
43
- } from '@dxos/react-ui-editor';
44
- import { defaultTx } from '@dxos/react-ui-theme';
45
- import { type DataType } from '@dxos/schema';
46
- import { isNotFalsy } from '@dxos/util';
47
-
48
- import { MarkdownCapabilities } from './capabilities';
49
- import { type Markdown } from './types';
50
- import { setFallbackName } from './util';
51
-
52
- type ExtensionsOptions = {
53
- document?: Markdown.Document;
54
- id?: string;
55
- text?: DataType.Text;
56
- dispatch?: PromiseIntentDispatcher;
57
- query?: QueryResult<Markdown.Document>;
58
- settings: Markdown.Settings;
59
- selectionManager?: SelectionManager;
60
- viewMode?: EditorViewMode;
61
- editorStateStore?: EditorStateStore;
62
- previewOptions?: PreviewOptions;
63
- };
64
-
65
- // TODO(burdon): Merge with createBaseExtensions below.
66
- export const useExtensions = ({
67
- document,
68
- id,
69
- text,
70
- settings,
71
- selectionManager,
72
- viewMode,
73
- editorStateStore,
74
- previewOptions,
75
- }: ExtensionsOptions): Extension[] => {
76
- const { dispatchPromise: dispatch } = useIntentDispatcher();
77
- const identity = useIdentity();
78
- const space = getSpace(document) ?? getSpace(text);
79
-
80
- // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.
81
- // TODO(burdon): Unsubscribe.
82
- // const query = space?.db.query(Filter.type(DocumentType));
83
- // query?.subscribe();
84
- const baseExtensions = useMemo(
85
- () =>
86
- createBaseExtensions({
87
- document,
88
- id,
89
- text,
90
- settings,
91
- selectionManager,
92
- viewMode,
93
- previewOptions,
94
- dispatch,
95
- // query,
96
- }),
97
- [
98
- document,
99
- id,
100
- text,
101
- viewMode,
102
- dispatch,
103
- previewOptions,
104
- settings,
105
- settings.editorInputMode,
106
- settings.folding,
107
- settings.numberedHeadings,
108
- settings.debug,
109
- settings.typewriter,
110
- selectionManager,
111
- ],
112
- );
113
-
114
- const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);
115
-
116
- //
117
- // External extensions from other plugins.
118
- //
119
- const pluginExtensions = useMemo<Extension[]>(() => {
120
- if (!document) {
121
- return [];
122
- }
123
-
124
- return extensionProviders.flat().reduce((acc: Extension[], provider) => {
125
- const extension = typeof provider === 'function' ? provider({ document }) : provider;
126
- if (extension) {
127
- acc.push(extension);
128
- }
129
-
130
- return acc;
131
- }, []);
132
- }, [extensionProviders, document]);
133
-
134
- //
135
- // Basic plugins.
136
- //
137
- return useMemo<Extension[]>(
138
- () =>
139
- [
140
- // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.
141
- document &&
142
- createDataExtensions({
143
- id: document.id,
144
- text: document.content.target && createDocAccessor(document.content.target, ['content']),
145
- space,
146
- identity,
147
- }),
148
- text &&
149
- id &&
150
- createDataExtensions({
151
- id,
152
- text: createDocAccessor(text, ['content']),
153
- space,
154
- identity,
155
- }),
156
- selectionState(editorStateStore),
157
- document &&
158
- listener({
159
- onChange: (text) => setFallbackName(document, text),
160
- }),
161
- baseExtensions,
162
- pluginExtensions,
163
- ].filter(isNotFalsy),
164
- [baseExtensions, pluginExtensions, document, document?.content?.target, text, id, space, identity],
165
- );
166
- };
167
-
168
- /**
169
- * Create extension instances for editor.
170
- */
171
- const createBaseExtensions = ({
172
- document,
173
- id,
174
- dispatch,
175
- settings,
176
- selectionManager,
177
- query,
178
- viewMode,
179
- previewOptions,
180
- }: ExtensionsOptions): Extension[] => {
181
- const extensions: Extension[] = [
182
- selectionManager && selectionChange(selectionManager),
183
- settings.editorInputMode && InputModeExtensions[settings.editorInputMode],
184
- settings.folding && folding(),
185
- ].filter(isNotFalsy);
186
-
187
- //
188
- // Markdown
189
- //
190
- if (viewMode !== 'source') {
191
- extensions.push(
192
- ...[
193
- formattingKeymap(),
194
- decorateMarkdown({
195
- selectionChangeDelay: 100,
196
- numberedHeadings: settings.numberedHeadings ? { from: 2 } : undefined,
197
- // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
198
- renderLinkButton:
199
- dispatch && (document || id)
200
- ? createLinkRenderer((id: string) => {
201
- void dispatch(
202
- createIntent(LayoutAction.Open, {
203
- part: 'main',
204
- subject: [id],
205
- options: {
206
- pivotId: document ? fullyQualifiedId(document) : id,
207
- },
208
- }),
209
- );
210
- })
211
- : undefined,
212
- }),
213
- linkTooltip(renderLinkTooltip),
214
- preview(previewOptions),
215
- ],
216
- );
217
- }
218
-
219
- //
220
- // Autocomplete object links.
221
- //
222
- if (query) {
223
- extensions.push(
224
- autocomplete({
225
- onSearch: (text: string) => {
226
- // TODO(burdon): Specify filter (e.g., stack).
227
- return query.objects
228
- .map<AutocompleteResult | undefined>((object) =>
229
- object.name?.length && object.id !== document?.id
230
- ? {
231
- label: object.name,
232
- // TODO(burdon): Factor out URL builder.
233
- apply: `[${object.name}](/${fullyQualifiedId(object)})`,
234
- }
235
- : undefined,
236
- )
237
- .filter(isNotFalsy);
238
- },
239
- }),
240
- );
241
- }
242
-
243
- if (settings.debug) {
244
- const items = settings.typewriter?.split(/[,\n]/) ?? '';
245
- if (items) {
246
- extensions.push(typewriter({ items }));
247
- }
248
- }
249
-
250
- return extensions;
251
- };
252
-
253
- export const selectionChange = (selectionManager: SelectionManager) => {
254
- return EditorView.updateListener.of(
255
- debounceAndThrottle((update: ViewUpdate) => {
256
- if (update.selectionSet) {
257
- const id = update.state.facet(documentId);
258
- const cursorConverter = update.state.facet(Cursor.converter);
259
- const selection = update.state.selection;
260
- const ranges = selection.ranges
261
- .map((range) => ({
262
- from: cursorConverter.toCursor(range.from),
263
- to: cursorConverter.toCursor(range.to),
264
- }))
265
- .filter(({ from, to }) => to > from);
266
- selectionManager.updateMultiRange(id, ranges);
267
- }
268
- }, 100),
269
- );
270
- };
271
-
272
- // TODO(burdon): Factor out styles.
273
- const style = {
274
- hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',
275
- icon: 'inline-block leading-none mis-1 cursor-pointer',
276
- };
277
-
278
- const createLinkRenderer =
279
- (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>
280
- (el, { url }) => {
281
- // TODO(burdon): Formalize/document internal link format.
282
- const isInternal =
283
- url.startsWith('/') ||
284
- // TODO(wittjosiah): This should probably be parsed out on paste?
285
- url.startsWith(window.location.origin);
286
-
287
- const options: AnchorHTMLAttributes<any> = isInternal
288
- ? {
289
- onClick: () => {
290
- const qualifiedId = url.split('/').at(-1);
291
- invariant(qualifiedId, 'Invalid link format.');
292
- onSelectObject(qualifiedId);
293
- },
294
- }
295
- : {
296
- href: url,
297
- rel: 'noreferrer',
298
- target: '_blank',
299
- };
300
-
301
- renderRoot(
302
- el,
303
- <a {...options} className={style.hover}>
304
- <Icon
305
- icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}
306
- size={4}
307
- classNames={style.icon}
308
- />
309
- </a>,
310
- );
311
- };
312
-
313
- const renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {
314
- const web = new URL(url);
315
- renderRoot(
316
- el,
317
- <a href={url} rel='noreferrer' target='_blank' className={style.hover}>
318
- {web.origin}
319
- <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />
320
- </a>,
321
- );
322
- };
323
-
324
- // TODO(burdon): Remove react rendering; use DOM directly.
325
- export const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {
326
- createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);
327
- return root;
328
- };