@dxos/plugin-markdown 0.8.4-main.3c1ae3b → 0.8.4-main.3fbcb4aa9b

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 (404) hide show
  1. package/dist/lib/neutral/EditableMarkdownCard-P4F4TIUM.mjs +32 -0
  2. package/dist/lib/neutral/EditableMarkdownCard-P4F4TIUM.mjs.map +7 -0
  3. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs +102 -0
  4. package/dist/lib/neutral/MarkdownCard-INMBLUL4.mjs.map +7 -0
  5. package/dist/lib/neutral/MarkdownContainer-2BDGD3PL.mjs +126 -0
  6. package/dist/lib/neutral/MarkdownContainer-2BDGD3PL.mjs.map +7 -0
  7. package/dist/lib/neutral/MarkdownPlugin.mjs +58 -0
  8. package/dist/lib/neutral/MarkdownPlugin.mjs.map +7 -0
  9. package/dist/lib/neutral/MarkdownPlugin.node.mjs +25 -0
  10. package/dist/lib/neutral/MarkdownPlugin.node.mjs.map +7 -0
  11. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs +32 -0
  12. package/dist/lib/neutral/MarkdownSettings-YCTZJL5V.mjs.map +7 -0
  13. package/dist/lib/{browser/anchor-sort-3MYLO74J.mjs → neutral/anchor-sort-L4VCKDO6.mjs} +9 -9
  14. package/dist/lib/neutral/anchor-sort-L4VCKDO6.mjs.map +7 -0
  15. package/dist/lib/neutral/app-graph-serializer-3XFKP4ER.mjs +56 -0
  16. package/dist/lib/neutral/app-graph-serializer-3XFKP4ER.mjs.map +7 -0
  17. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs +15 -0
  18. package/dist/lib/neutral/blueprint-definition-33OK2KUL.mjs.map +7 -0
  19. package/dist/lib/neutral/blueprints/index.mjs +8 -0
  20. package/dist/lib/neutral/capabilities/index.mjs +25 -0
  21. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  22. package/dist/lib/neutral/capabilities/node.mjs +11 -0
  23. package/dist/lib/neutral/capabilities/node.mjs.map +7 -0
  24. package/dist/lib/{browser/chunk-BQTYJOFB.mjs → neutral/chunk-3LYCPEVP.mjs} +2 -9
  25. package/dist/lib/neutral/chunk-3LYCPEVP.mjs.map +7 -0
  26. package/dist/lib/neutral/chunk-6N7AD3IU.mjs +8 -0
  27. package/dist/lib/neutral/chunk-6N7AD3IU.mjs.map +7 -0
  28. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  29. package/dist/lib/{browser/chunk-KPH4ZPQN.mjs → neutral/chunk-KDN4GKG2.mjs} +8 -9
  30. package/dist/lib/neutral/chunk-KDN4GKG2.mjs.map +7 -0
  31. package/dist/lib/neutral/chunk-LXNSKCPD.mjs +44 -0
  32. package/dist/lib/neutral/chunk-LXNSKCPD.mjs.map +7 -0
  33. package/dist/lib/neutral/chunk-SOLAMEK3.mjs +276 -0
  34. package/dist/lib/neutral/chunk-SOLAMEK3.mjs.map +7 -0
  35. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs +30 -0
  36. package/dist/lib/neutral/comment-config-7VTHRUIZ.mjs.map +7 -0
  37. package/dist/lib/neutral/components/index.mjs +370 -0
  38. package/dist/lib/neutral/components/index.mjs.map +7 -0
  39. package/dist/lib/neutral/containers/index.mjs +13 -0
  40. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  41. package/dist/lib/neutral/create-3PGJ2NEK.mjs +28 -0
  42. package/dist/lib/neutral/create-3PGJ2NEK.mjs.map +7 -0
  43. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs +20 -0
  44. package/dist/lib/neutral/create-markdown-5LS46GMH.mjs.map +7 -0
  45. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs +27 -0
  46. package/dist/lib/neutral/create-object-ZA6VXLJJ.mjs.map +7 -0
  47. package/dist/lib/neutral/hooks/index.mjs +322 -0
  48. package/dist/lib/neutral/hooks/index.mjs.map +7 -0
  49. package/dist/lib/neutral/index.mjs +42 -0
  50. package/dist/lib/neutral/meta.json +1 -0
  51. package/dist/lib/neutral/meta.mjs +8 -0
  52. package/dist/lib/neutral/open-WCYGBLAG.mjs +20 -0
  53. package/dist/lib/neutral/open-WCYGBLAG.mjs.map +7 -0
  54. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs +13 -0
  55. package/dist/lib/neutral/operation-handler-2ARMPBGZ.mjs.map +7 -0
  56. package/dist/lib/neutral/operations/index.mjs +8 -0
  57. package/dist/lib/neutral/plugin.mjs +16 -0
  58. package/dist/lib/neutral/plugin.mjs.map +7 -0
  59. package/dist/lib/neutral/react-surface-TB4TY57T.mjs +119 -0
  60. package/dist/lib/neutral/react-surface-TB4TY57T.mjs.map +7 -0
  61. package/dist/lib/neutral/scroll-to-anchor-6FIOKVKT.mjs +47 -0
  62. package/dist/lib/neutral/scroll-to-anchor-6FIOKVKT.mjs.map +7 -0
  63. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs +24 -0
  64. package/dist/lib/neutral/set-view-mode-37RSPFEN.mjs.map +7 -0
  65. package/dist/lib/neutral/settings-TDGDLCUR.mjs +34 -0
  66. package/dist/lib/neutral/settings-TDGDLCUR.mjs.map +7 -0
  67. package/dist/lib/neutral/state-5COCF5PN.mjs +44 -0
  68. package/dist/lib/neutral/state-5COCF5PN.mjs.map +7 -0
  69. package/dist/lib/neutral/testing.mjs +20 -0
  70. package/dist/lib/neutral/testing.mjs.map +7 -0
  71. package/dist/lib/neutral/translations.mjs +43 -0
  72. package/dist/lib/neutral/translations.mjs.map +7 -0
  73. package/dist/lib/neutral/types/index.mjs +16 -0
  74. package/dist/lib/neutral/update-markdown-5EDRD3SH.mjs +44 -0
  75. package/dist/lib/neutral/update-markdown-5EDRD3SH.mjs.map +7 -0
  76. package/dist/types/src/MarkdownPlugin.d.ts +3 -1
  77. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  78. package/dist/types/src/MarkdownPlugin.node.d.ts +4 -0
  79. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  80. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  81. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  82. package/dist/types/src/blueprints/index.d.ts +2 -0
  83. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  84. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  85. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  86. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -2
  87. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  88. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  89. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  90. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -1
  91. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  92. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -6
  93. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
  94. package/dist/types/src/capabilities/comment-config.d.ts +12 -0
  95. package/dist/types/src/capabilities/comment-config.d.ts.map +1 -0
  96. package/dist/types/src/capabilities/create-object.d.ts +11 -0
  97. package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
  98. package/dist/types/src/capabilities/index.d.ts +22 -14
  99. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  100. package/dist/types/src/capabilities/node.d.ts +10 -0
  101. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  102. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  103. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  104. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  105. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  106. package/dist/types/src/capabilities/settings.d.ts +4 -2
  107. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/state.d.ts +4 -9
  109. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  110. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +1 -1
  111. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  112. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +34 -22
  113. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  114. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +3 -3
  115. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  116. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +11 -7
  117. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  118. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +6 -5
  119. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  120. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  121. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  122. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  123. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  124. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  125. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  126. package/dist/types/src/components/index.d.ts +3 -8
  127. package/dist/types/src/components/index.d.ts.map +1 -1
  128. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts +15 -0
  129. package/dist/types/src/containers/EditableMarkdownCard/EditableMarkdownCard.d.ts.map +1 -0
  130. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts +3 -0
  131. package/dist/types/src/containers/EditableMarkdownCard/index.d.ts.map +1 -0
  132. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  133. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  134. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  135. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  136. package/dist/types/src/containers/MarkdownCard/index.d.ts +2 -0
  137. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  138. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  139. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  140. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  141. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  142. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  143. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  144. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  145. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  146. package/dist/types/src/containers/index.d.ts +6 -0
  147. package/dist/types/src/containers/index.d.ts.map +1 -0
  148. package/dist/types/src/hooks/index.d.ts +0 -1
  149. package/dist/types/src/hooks/index.d.ts.map +1 -1
  150. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  151. package/dist/types/src/hooks/useExtensions.d.ts +10 -6
  152. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  153. package/dist/types/src/hooks/useLinkQuery.d.ts +2 -2
  154. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  155. package/dist/types/src/index.d.ts +2 -3
  156. package/dist/types/src/index.d.ts.map +1 -1
  157. package/dist/types/src/meta.d.ts +2 -2
  158. package/dist/types/src/meta.d.ts.map +1 -1
  159. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  160. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  161. package/dist/types/src/operations/create.d.ts +5 -0
  162. package/dist/types/src/operations/create.d.ts.map +1 -0
  163. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  164. package/dist/types/src/operations/index.d.ts +3 -0
  165. package/dist/types/src/operations/index.d.ts.map +1 -0
  166. package/dist/types/src/operations/open.d.ts +5 -0
  167. package/dist/types/src/operations/open.d.ts.map +1 -0
  168. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  169. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  170. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  171. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  172. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  173. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  174. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  175. package/dist/types/src/plugin.d.ts +4 -0
  176. package/dist/types/src/plugin.d.ts.map +1 -0
  177. package/dist/types/src/testing.d.ts.map +1 -1
  178. package/dist/types/src/translations.d.ts +74 -37
  179. package/dist/types/src/translations.d.ts.map +1 -1
  180. package/dist/types/src/types/Markdown.d.ts +28 -28
  181. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  182. package/dist/types/src/types/MarkdownCapabilities.d.ts +32 -0
  183. package/dist/types/src/types/MarkdownCapabilities.d.ts.map +1 -0
  184. package/dist/types/src/types/MarkdownEvents.d.ts +3 -0
  185. package/dist/types/src/types/MarkdownEvents.d.ts.map +1 -0
  186. package/dist/types/src/types/MarkdownOperation.d.ts +64 -0
  187. package/dist/types/src/types/MarkdownOperation.d.ts.map +1 -0
  188. package/dist/types/src/types/Settings.d.ts +17 -0
  189. package/dist/types/src/types/Settings.d.ts.map +1 -0
  190. package/dist/types/src/types/index.d.ts +5 -2
  191. package/dist/types/src/types/index.d.ts.map +1 -1
  192. package/dist/types/src/types/types.d.ts +3 -2
  193. package/dist/types/src/types/types.d.ts.map +1 -1
  194. package/dist/types/src/util.d.ts +3 -3
  195. package/dist/types/src/util.d.ts.map +1 -1
  196. package/dist/types/tsconfig.tsbuildinfo +1 -1
  197. package/package.json +147 -85
  198. package/src/MarkdownPlugin.node.ts +20 -0
  199. package/src/MarkdownPlugin.test.ts +26 -0
  200. package/src/MarkdownPlugin.tsx +33 -85
  201. package/src/blueprints/index.ts +5 -0
  202. package/src/blueprints/markdown-blueprint.ts +43 -0
  203. package/src/capabilities/anchor-sort.ts +26 -20
  204. package/src/capabilities/app-graph-serializer.ts +52 -42
  205. package/src/capabilities/artifact-definition.ts +82 -84
  206. package/src/capabilities/blueprint-definition.ts +11 -35
  207. package/src/capabilities/comment-config.ts +32 -0
  208. package/src/capabilities/create-object.ts +30 -0
  209. package/src/capabilities/index.ts +15 -11
  210. package/src/capabilities/node.ts +13 -0
  211. package/src/capabilities/operation-handler.ts +16 -0
  212. package/src/capabilities/react-surface.tsx +112 -82
  213. package/src/capabilities/settings.ts +30 -18
  214. package/src/capabilities/state.ts +41 -25
  215. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  216. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +47 -43
  217. package/src/components/MarkdownEditor/MarkdownEditor.tsx +146 -103
  218. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +49 -32
  219. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +37 -53
  220. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  221. package/src/components/MarkdownSettings/MarkdownSettings.tsx +23 -96
  222. package/src/components/MarkdownSettings/index.ts +1 -1
  223. package/src/components/index.ts +4 -12
  224. package/src/containers/EditableMarkdownCard/EditableMarkdownCard.tsx +42 -0
  225. package/src/containers/EditableMarkdownCard/index.ts +6 -0
  226. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +68 -0
  227. package/src/containers/MarkdownCard/MarkdownCard.tsx +67 -0
  228. package/src/containers/MarkdownCard/index.ts +5 -0
  229. package/src/containers/MarkdownCard/snippet.ts +54 -0
  230. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  231. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  232. package/src/containers/MarkdownContainer/index.ts +6 -0
  233. package/src/containers/index.ts +11 -0
  234. package/src/hooks/index.ts +0 -1
  235. package/src/hooks/useEditorMenuOptions.ts +11 -14
  236. package/src/hooks/useExtensions.tsx +95 -112
  237. package/src/hooks/useLinkQuery.ts +42 -33
  238. package/src/index.ts +2 -5
  239. package/src/meta.ts +3 -3
  240. package/src/operations/create-markdown.ts +19 -0
  241. package/src/operations/create.conversations.json +1 -0
  242. package/src/operations/create.test.ts +97 -0
  243. package/src/operations/create.ts +26 -0
  244. package/src/operations/index.ts +14 -0
  245. package/src/operations/open.ts +25 -0
  246. package/src/operations/scroll-to-anchor.ts +38 -0
  247. package/src/operations/set-view-mode.ts +23 -0
  248. package/src/operations/update-markdown.ts +51 -0
  249. package/src/operations/update.conversations.json +1 -0
  250. package/src/operations/update.test.ts +214 -0
  251. package/src/plugin.ts +11 -0
  252. package/src/testing.ts +2 -2
  253. package/src/translations.ts +26 -36
  254. package/src/types/Markdown.ts +24 -26
  255. package/src/types/MarkdownCapabilities.ts +51 -0
  256. package/src/types/MarkdownEvents.ts +14 -0
  257. package/src/types/MarkdownOperation.ts +122 -0
  258. package/src/types/Settings.ts +65 -0
  259. package/src/types/index.ts +6 -3
  260. package/src/types/types.ts +7 -3
  261. package/src/util.tsx +7 -5
  262. package/dist/lib/browser/MarkdownCard-THZFDOOV.mjs +0 -13
  263. package/dist/lib/browser/MarkdownContainer-VKPSVI5F.mjs +0 -16
  264. package/dist/lib/browser/anchor-sort-3MYLO74J.mjs.map +0 -7
  265. package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs +0 -51
  266. package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs.map +0 -7
  267. package/dist/lib/browser/blueprint-definition-R5T6LTPN.mjs +0 -13
  268. package/dist/lib/browser/chunk-56SUMOIZ.mjs +0 -734
  269. package/dist/lib/browser/chunk-56SUMOIZ.mjs.map +0 -7
  270. package/dist/lib/browser/chunk-6OMOMVO7.mjs +0 -107
  271. package/dist/lib/browser/chunk-6OMOMVO7.mjs.map +0 -7
  272. package/dist/lib/browser/chunk-BQTYJOFB.mjs.map +0 -7
  273. package/dist/lib/browser/chunk-CN35HEBX.mjs +0 -79
  274. package/dist/lib/browser/chunk-CN35HEBX.mjs.map +0 -7
  275. package/dist/lib/browser/chunk-IBCHVMZW.mjs +0 -16
  276. package/dist/lib/browser/chunk-IBCHVMZW.mjs.map +0 -7
  277. package/dist/lib/browser/chunk-KCOBZZIL.mjs +0 -111
  278. package/dist/lib/browser/chunk-KCOBZZIL.mjs.map +0 -7
  279. package/dist/lib/browser/chunk-KPH4ZPQN.mjs.map +0 -7
  280. package/dist/lib/browser/chunk-NXT2E2BG.mjs +0 -57
  281. package/dist/lib/browser/chunk-NXT2E2BG.mjs.map +0 -7
  282. package/dist/lib/browser/chunk-RJPOHSYN.mjs +0 -152
  283. package/dist/lib/browser/chunk-RJPOHSYN.mjs.map +0 -7
  284. package/dist/lib/browser/chunk-U6Y53XZK.mjs +0 -20
  285. package/dist/lib/browser/chunk-U6Y53XZK.mjs.map +0 -7
  286. package/dist/lib/browser/index.mjs +0 -160
  287. package/dist/lib/browser/index.mjs.map +0 -7
  288. package/dist/lib/browser/intent-resolver-55ASQRIW.mjs +0 -62
  289. package/dist/lib/browser/intent-resolver-55ASQRIW.mjs.map +0 -7
  290. package/dist/lib/browser/meta.json +0 -1
  291. package/dist/lib/browser/react-surface-Q3C5H2KT.mjs +0 -215
  292. package/dist/lib/browser/react-surface-Q3C5H2KT.mjs.map +0 -7
  293. package/dist/lib/browser/settings-G3ZOXJQY.mjs +0 -28
  294. package/dist/lib/browser/settings-G3ZOXJQY.mjs.map +0 -7
  295. package/dist/lib/browser/state-BTUKVZHY.mjs +0 -37
  296. package/dist/lib/browser/state-BTUKVZHY.mjs.map +0 -7
  297. package/dist/lib/browser/toolkit.mjs +0 -13
  298. package/dist/lib/browser/types/index.mjs +0 -10
  299. package/dist/lib/node-esm/MarkdownCard-QHSSZGIY.mjs +0 -14
  300. package/dist/lib/node-esm/MarkdownCard-QHSSZGIY.mjs.map +0 -7
  301. package/dist/lib/node-esm/MarkdownContainer-G3ZQJS7A.mjs +0 -17
  302. package/dist/lib/node-esm/MarkdownContainer-G3ZQJS7A.mjs.map +0 -7
  303. package/dist/lib/node-esm/anchor-sort-W4HCTYUQ.mjs +0 -33
  304. package/dist/lib/node-esm/anchor-sort-W4HCTYUQ.mjs.map +0 -7
  305. package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs +0 -52
  306. package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs.map +0 -7
  307. package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs +0 -14
  308. package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs.map +0 -7
  309. package/dist/lib/node-esm/chunk-6F6FCTIA.mjs +0 -100
  310. package/dist/lib/node-esm/chunk-6F6FCTIA.mjs.map +0 -7
  311. package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs +0 -153
  312. package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs.map +0 -7
  313. package/dist/lib/node-esm/chunk-FR6RW6DH.mjs +0 -735
  314. package/dist/lib/node-esm/chunk-FR6RW6DH.mjs.map +0 -7
  315. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs +0 -17
  316. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs.map +0 -7
  317. package/dist/lib/node-esm/chunk-I5JSQBPI.mjs +0 -58
  318. package/dist/lib/node-esm/chunk-I5JSQBPI.mjs.map +0 -7
  319. package/dist/lib/node-esm/chunk-KM7KYV6W.mjs +0 -22
  320. package/dist/lib/node-esm/chunk-KM7KYV6W.mjs.map +0 -7
  321. package/dist/lib/node-esm/chunk-KYWXTMKI.mjs +0 -108
  322. package/dist/lib/node-esm/chunk-KYWXTMKI.mjs.map +0 -7
  323. package/dist/lib/node-esm/chunk-R3SGV4ES.mjs +0 -112
  324. package/dist/lib/node-esm/chunk-R3SGV4ES.mjs.map +0 -7
  325. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs +0 -29
  326. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs.map +0 -7
  327. package/dist/lib/node-esm/chunk-YFRTKXTB.mjs +0 -80
  328. package/dist/lib/node-esm/chunk-YFRTKXTB.mjs.map +0 -7
  329. package/dist/lib/node-esm/index.mjs +0 -161
  330. package/dist/lib/node-esm/index.mjs.map +0 -7
  331. package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs +0 -63
  332. package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs.map +0 -7
  333. package/dist/lib/node-esm/meta.json +0 -1
  334. package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs +0 -216
  335. package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs.map +0 -7
  336. package/dist/lib/node-esm/settings-IBFFCGNL.mjs +0 -29
  337. package/dist/lib/node-esm/settings-IBFFCGNL.mjs.map +0 -7
  338. package/dist/lib/node-esm/state-K6EH7SRZ.mjs +0 -38
  339. package/dist/lib/node-esm/state-K6EH7SRZ.mjs.map +0 -7
  340. package/dist/lib/node-esm/toolkit.mjs +0 -14
  341. package/dist/lib/node-esm/toolkit.mjs.map +0 -7
  342. package/dist/lib/node-esm/types/index.mjs +0 -11
  343. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  344. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  345. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  346. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  347. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -20
  348. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  349. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -9
  350. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  351. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  352. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  353. package/dist/types/src/components/MarkdownContainer.d.ts +0 -19
  354. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  355. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -59
  356. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  357. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  358. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  359. package/dist/types/src/events.d.ts +0 -4
  360. package/dist/types/src/events.d.ts.map +0 -1
  361. package/dist/types/src/functions/create.d.ts +0 -8
  362. package/dist/types/src/functions/create.d.ts.map +0 -1
  363. package/dist/types/src/functions/create.test.d.ts.map +0 -1
  364. package/dist/types/src/functions/index.d.ts +0 -18
  365. package/dist/types/src/functions/index.d.ts.map +0 -1
  366. package/dist/types/src/functions/open.d.ts +0 -7
  367. package/dist/types/src/functions/open.d.ts.map +0 -1
  368. package/dist/types/src/functions/update.d.ts +0 -6
  369. package/dist/types/src/functions/update.d.ts.map +0 -1
  370. package/dist/types/src/functions/update.test.d.ts.map +0 -1
  371. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  372. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  373. package/dist/types/src/toolkit.d.ts +0 -3
  374. package/dist/types/src/toolkit.d.ts.map +0 -1
  375. package/dist/types/src/types/MarkdownAction.d.ts +0 -34
  376. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  377. package/src/capabilities/capabilities.ts +0 -22
  378. package/src/capabilities/intent-resolver.ts +0 -58
  379. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -76
  380. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -96
  381. package/src/components/MarkdownCard/index.ts +0 -9
  382. package/src/components/MarkdownContainer.stories.tsx +0 -136
  383. package/src/components/MarkdownContainer.tsx +0 -108
  384. package/src/components/Suggestions.stories.tsx +0 -226
  385. package/src/events.ts +0 -11
  386. package/src/functions/create.conversations.json +0 -1
  387. package/src/functions/create.test.ts +0 -124
  388. package/src/functions/create.ts +0 -34
  389. package/src/functions/index.ts +0 -13
  390. package/src/functions/open.ts +0 -33
  391. package/src/functions/update.conversations.json +0 -1
  392. package/src/functions/update.test.ts +0 -147
  393. package/src/functions/update.ts +0 -38
  394. package/src/hooks/useSelectCurrentThread.tsx +0 -66
  395. package/src/toolkit.ts +0 -6
  396. package/src/types/MarkdownAction.ts +0 -29
  397. /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
  398. /package/dist/lib/{browser/MarkdownCard-THZFDOOV.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
  399. /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
  400. /package/dist/lib/{browser/MarkdownContainer-VKPSVI5F.mjs.map → neutral/meta.mjs.map} +0 -0
  401. /package/dist/lib/{browser/blueprint-definition-R5T6LTPN.mjs.map → neutral/operations/index.mjs.map} +0 -0
  402. /package/dist/lib/{browser/toolkit.mjs.map → neutral/types/index.mjs.map} +0 -0
  403. /package/dist/types/src/{functions → operations}/create.test.d.ts +0 -0
  404. /package/dist/types/src/{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,11 @@
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 EditableMarkdownCard: ComponentType<any> = lazy(() => import('./EditableMarkdownCard'));
11
+ 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';
@@ -5,7 +5,7 @@
5
5
  import { type EditorView } from '@codemirror/view';
6
6
  import { useCallback, useMemo, useRef } from 'react';
7
7
 
8
- import { Domino, toLocalizedString, useTranslation } from '@dxos/react-ui';
8
+ import { toLocalizedString, useTranslation } from '@dxos/react-ui';
9
9
  import {
10
10
  type EditorMenuGroup,
11
11
  type UseEditorMenuProps,
@@ -13,8 +13,9 @@ import {
13
13
  formattingCommands,
14
14
  linkSlashCommands,
15
15
  } from '@dxos/react-ui-editor';
16
+ import { Domino } from '@dxos/ui';
16
17
 
17
- import { meta } from '../meta';
18
+ import { meta } from '#meta';
18
19
 
19
20
  export type UseEditorMenuOptionsProps = {
20
21
  editorView?: EditorView;
@@ -52,18 +53,14 @@ export const useEditorMenuOptions = ({
52
53
  const trigger = onLinkQuery ? ['/', '@'] : ['/'];
53
54
  const placeholder = {
54
55
  delay: 3_000,
55
- content: () =>
56
- Domino.of('div')
57
- .children(
58
- Domino.of('span').text('Press'),
59
- ...trigger.map((text) =>
60
- Domino.of('span')
61
- .classNames('mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm')
62
- .text(text),
63
- ),
64
- Domino.of('span').text('for commands.'),
65
- )
66
- .build(),
56
+ content: () => {
57
+ const pressEl = Domino.of('span').text('Press');
58
+ const triggerEls = trigger.map((text) =>
59
+ Domino.of('span').classNames('mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-xs').text(text),
60
+ );
61
+ const forCommandsEl = Domino.of('span').text('for commands.');
62
+ return Domino.of('div').append(pressEl, ...triggerEls, forCommandsEl).root;
63
+ },
67
64
  };
68
65
 
69
66
  return { viewRef, getMenu, trigger, placeholder };
@@ -3,28 +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 { LayoutAction, type PromiseIntentDispatcher, createIntent } from '@dxos/app-framework';
10
- import { useIntentDispatcher } 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
- import { getSpace } from '@dxos/react-client/echo';
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';
17
+ import { Text } from '@dxos/schema';
18
+ import { Domino } from '@dxos/ui';
19
19
  import {
20
20
  Cursor,
21
21
  type EditorStateStore,
22
22
  EditorView,
23
- type EditorViewMode,
24
23
  type Extension,
25
24
  InputModeExtensions,
26
25
  type PreviewOptions,
27
- type RenderCallback,
28
26
  createDataExtensions,
29
27
  decorateMarkdown,
30
28
  documentId,
@@ -35,13 +33,13 @@ import {
35
33
  preview,
36
34
  replacer,
37
35
  selectionState,
38
- typewriter,
39
- } from '@dxos/react-ui-editor';
40
- import { defaultTx } from '@dxos/react-ui-theme';
41
- import { Text } from '@dxos/schema';
42
- import { isTruthy } from '@dxos/util';
36
+ snippets,
37
+ } from '@dxos/ui-editor';
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
- dispatch?: PromiseIntentDispatcher;
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,21 +64,23 @@ 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 { dispatchPromise: dispatch } = useIntentDispatcher();
74
+ const { platform } = useThemeContext();
71
75
  const identity = useIdentity();
72
76
  const space = getSpace(object);
73
77
 
74
- let target: Obj.Any | undefined;
75
- if (Obj.instanceOf(Markdown.Document, object)) {
76
- target = (object as Markdown.Document).content.target;
77
- } else if (Obj.instanceOf(Text.Text, object)) {
78
- target = object;
79
- }
78
+ // Get the content reference from Document objects.
79
+ const contentRef = Obj.instanceOf(Markdown.Document, object) ? (object as Markdown.Document).content : undefined;
80
+ // Use useObject to trigger re-render when the reference loads (returns snapshot for reactivity).
81
+ useObject(contentRef);
82
+ // Get the actual live object target via .target (needed for createDocAccessor).
83
+ const target = contentRef?.target ?? (Obj.instanceOf(Text.Text, object) ? object : undefined);
80
84
 
81
85
  // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.
82
86
  // TODO(burdon): Unsubscribe.
@@ -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
- dispatch,
100
+ platform,
101
+ onSelectObject,
96
102
  }),
97
103
  [
98
104
  id,
99
105
  object,
106
+ compact,
100
107
  viewMode,
101
- dispatch,
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
- dispatch,
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,22 +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
- dispatch && (object || id)
173
- ? createLinkRenderer((id: string) => {
174
- void dispatch(
175
- createIntent(LayoutAction.Open, {
176
- part: 'main',
177
- subject: [id],
178
- options: {
179
- pivotId: object && Obj.isObject(object) ? Obj.getDXN(object).toString() : id,
180
- },
181
- }),
182
- );
183
- })
184
- : undefined,
178
+ // TODO(wittjosiah): For internal links render the label of the object.
179
+ renderLinkButton: onSelectObject && createRenderLink(onSelectObject),
185
180
  }),
186
181
  linkTooltip(renderLinkTooltip),
187
182
  preview(previewOptions),
@@ -191,9 +186,9 @@ const createBaseExtensions = ({
191
186
  }
192
187
 
193
188
  if (settings?.debug) {
194
- const items = settings.typewriter?.split(/[,\n]/) ?? '';
189
+ const items = settings.snippets?.split(/[,\n]/) ?? '';
195
190
  if (items) {
196
- extensions.push(typewriter({ items }));
191
+ extensions.push(snippets({ items }));
197
192
  }
198
193
  }
199
194
 
@@ -201,79 +196,67 @@ const createBaseExtensions = ({
201
196
  };
202
197
 
203
198
  const selectionChange = (selectionManager: SelectionManager) => {
204
- return EditorView.updateListener.of(
205
- debounceAndThrottle((update: ViewUpdate) => {
206
- if (update.selectionSet) {
207
- const id = update.state.facet(documentId);
208
- const cursorConverter = update.state.facet(Cursor.converter);
209
- const selection = update.state.selection;
210
- const ranges = selection.ranges
211
- .map((range) => ({
212
- from: cursorConverter.toCursor(range.from),
213
- to: cursorConverter.toCursor(range.to),
214
- }))
215
- .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);
216
209
 
217
- selectionManager.updateMultiRange(id, ranges);
218
- }
219
- }, 100),
220
- );
221
- };
210
+ selectionManager.updateMultiRange(id, ranges);
211
+ }, 100);
222
212
 
223
- // TODO(burdon): Factor out styles.
224
- const style = {
225
- hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',
226
- 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
+ });
227
218
  };
228
219
 
229
- const createLinkRenderer =
220
+ const createRenderLink =
230
221
  (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>
231
222
  (el, { url }) => {
232
223
  // TODO(burdon): Formalize/document internal link format.
233
- const isInternal =
234
- url.startsWith('/') ||
235
- // TODO(wittjosiah): This should probably be parsed out on paste?
236
- 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'));
237
229
 
238
- const options: AnchorHTMLAttributes<any> = isInternal
239
- ? {
240
- onClick: () => {
241
- const qualifiedId = url.split('/').at(-1);
242
- invariant(qualifiedId, 'Invalid link format.');
243
- onSelectObject(qualifiedId);
244
- },
245
- }
246
- : {
247
- href: url,
248
- rel: 'noreferrer',
249
- target: '_blank',
250
- };
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
+ }
251
244
 
252
- renderRoot(
253
- el,
254
- <a {...options} className={style.hover}>
255
- <Icon
256
- icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}
257
- size={4}
258
- classNames={style.icon}
259
- />
260
- </a>,
261
- );
245
+ keyboardEvent.preventDefault();
246
+ keyboardEvent.stopPropagation();
247
+ onSelectObject(qualifiedId);
248
+ });
249
+ }
250
+
251
+ el.appendChild(icon.root);
262
252
  };
263
253
 
264
254
  const renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {
265
- const web = new URL(url);
266
- renderRoot(
267
- el,
268
- <a href={url} rel='noreferrer' target='_blank' className={style.hover}>
269
- {web.origin}
270
- <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />
271
- </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,
272
261
  );
273
262
  };
274
-
275
- // TODO(burdon): REMOVE.
276
- const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {
277
- createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);
278
- return root;
279
- };
@@ -5,66 +5,54 @@
5
5
  import * as Option from 'effect/Option';
6
6
  import { useCallback, useMemo } from 'react';
7
7
 
8
- import { Capabilities } from '@dxos/app-framework';
9
- import { usePluginManager } from '@dxos/app-framework/react';
10
- import { Filter, Obj, Query, Type } from '@dxos/echo';
8
+ import { type Database, Filter, Obj, Query, Type } from '@dxos/echo';
9
+ import { Annotation } from '@dxos/echo';
11
10
  import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from '@dxos/echo/internal';
12
- import { type Space } from '@dxos/react-client/echo';
13
- import { toLocalizedString, useTranslation } from '@dxos/react-ui';
14
- import { type EditorMenuGroup, type EditorMenuItem, insertAtCursor, insertAtLineStart } from '@dxos/react-ui-editor';
11
+ import { type Label, toLocalizedString, useTranslation } from '@dxos/react-ui';
12
+ import { type EditorMenuGroup, type EditorMenuItem } from '@dxos/react-ui-editor';
13
+ import { insertAtCursor, insertAtLineStart } from '@dxos/ui-editor';
15
14
 
16
- export const useLinkQuery = (space: Space | undefined) => {
17
- const { t } = useTranslation();
15
+ import { Markdown } from '../types';
18
16
 
19
- const manager = usePluginManager();
20
- const resolve = useCallback(
21
- (typename: string) =>
22
- manager.context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {},
23
- [manager],
24
- );
17
+ export const useLinkQuery = (db: Database.Database | undefined) => {
18
+ const { t } = useTranslation();
25
19
 
26
20
  const filter = useMemo(
27
21
  () =>
28
22
  Filter.or(
29
- ...(space?.db.schemaRegistry.query({ location: ['database', 'runtime'] }).runSync() ?? [])
23
+ ...(db?.schemaRegistry.query({ location: ['database', 'runtime'] }).runSync() ?? [])
30
24
  .filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation)
31
25
  .filter((schema) => !SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false)))
32
26
  .map((schema) => Filter.typename(Type.getTypename(schema))),
33
27
  ),
34
- [space],
28
+ [db],
35
29
  );
36
30
 
37
31
  const handleLinkQuery = useCallback(
38
32
  async (query?: string): Promise<EditorMenuGroup[]> => {
33
+ // A second "@" switches the link query into block-embed mode, so "@@foo" searches for "foo".
39
34
  const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');
40
- const results = await space?.db.query(Query.select(filter)).run();
35
+ const results = await db?.query(Query.select(filter)).run();
41
36
 
42
- // TODO(wittjosiah): Use `Obj.Any` type.
43
- const getLabel = (object: any) => {
44
- const label = Obj.getLabel(object);
45
- if (label) {
46
- return label;
47
- }
48
-
49
- // TODO(wittjosiah): Remove metadata labels.
37
+ const getLabel = (object: Obj.Unknown): Label => {
50
38
  const type = Obj.getTypename(object)!;
51
- const metadata = resolve(type);
52
- return metadata.label?.(object) || ['object name placeholder', { ns: type, default: 'New object' }];
39
+ return Obj.getLabel(object) ?? ['object-name.placeholder', { ns: type, defaultValue: 'New object' }];
53
40
  };
54
41
 
55
42
  const items =
56
43
  results
57
44
  ?.filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name))
58
- // TODO(wittjosiah): Remove `any` type.
59
- .map((object: any): EditorMenuItem => {
60
- const metadata = resolve(Obj.getTypename(object)!);
45
+ .map((object: Obj.Unknown): EditorMenuItem => {
46
+ const schema = Obj.getSchema(object);
47
+ const icon = schema ? Option.getOrUndefined(Annotation.IconAnnotation.get(schema))?.icon : undefined;
61
48
  const label = toLocalizedString(getLabel(object), t);
62
49
  return {
63
50
  id: object.id,
64
51
  label,
65
- icon: metadata.icon,
52
+ icon,
66
53
  onSelect: ({ view, head }) => {
67
54
  const link = `[${label}](${Obj.getDXN(object)})`;
55
+ // "@@" inserts a block embed on its own line instead of an inline link.
68
56
  if (query?.startsWith('@')) {
69
57
  insertAtLineStart(view, head, `!${link}\n`);
70
58
  } else {
@@ -74,9 +62,30 @@ export const useLinkQuery = (space: Space | undefined) => {
74
62
  };
75
63
  }) ?? [];
76
64
 
77
- return [{ id: 'echo', items }];
65
+ // Add "Create new document" option at the end.
66
+ const createItem: EditorMenuItem = {
67
+ id: 'create-document',
68
+ label: ['add-object.label', { ns: Markdown.Document.typename }],
69
+ icon: 'ph--plus--regular',
70
+ onSelect: ({ view, head }) => {
71
+ const doc = Markdown.make({ name: name || undefined });
72
+ db?.add(doc);
73
+ const label = name || t('object-name.placeholder', { ns: Markdown.Document.typename });
74
+ const link = `[${label}](${Obj.getDXN(doc)})`;
75
+ if (query?.startsWith('@')) {
76
+ insertAtLineStart(view, head, `!${link}\n`);
77
+ } else {
78
+ insertAtCursor(view, head, `${link} `);
79
+ }
80
+ },
81
+ };
82
+
83
+ return [
84
+ { id: 'echo', items },
85
+ { id: 'create', items: [createItem] },
86
+ ];
78
87
  },
79
- [space, filter, resolve],
88
+ [db, filter, t],
80
89
  );
81
90
 
82
91
  return handleLinkQuery;