@dxos/plugin-markdown 0.8.4-main.f9ba587 → 0.8.4-main.fcfe5033a5

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 (337) hide show
  1. package/dist/lib/browser/MarkdownSettings-62YSRY7L.mjs +32 -0
  2. package/dist/lib/browser/MarkdownSettings-62YSRY7L.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-4KOZEH2H.mjs +121 -0
  6. package/dist/lib/browser/chunk-4KOZEH2H.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  8. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-QFPZONKP.mjs +158 -0
  10. package/dist/lib/browser/chunk-QFPZONKP.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-YL5ELZWP.mjs +30 -0
  14. package/dist/lib/browser/create-YL5ELZWP.mjs.map +7 -0
  15. package/dist/lib/browser/create-markdown-LU5IDKMH.mjs +22 -0
  16. package/dist/lib/browser/create-markdown-LU5IDKMH.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +614 -142
  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-AFSOZZ6G.mjs +21 -0
  21. package/dist/lib/browser/open-AFSOZZ6G.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-IPXV32A6.mjs +49 -0
  25. package/dist/lib/browser/scroll-to-anchor-IPXV32A6.mjs.map +7 -0
  26. package/dist/lib/browser/set-view-mode-2QWB24RR.mjs +26 -0
  27. package/dist/lib/browser/set-view-mode-2QWB24RR.mjs.map +7 -0
  28. package/dist/lib/browser/types/index.mjs +12 -14
  29. package/dist/lib/browser/update-HZNVYBMO.mjs +45 -0
  30. package/dist/lib/browser/update-HZNVYBMO.mjs.map +7 -0
  31. package/dist/lib/node-esm/MarkdownSettings-QMPISOEU.mjs +33 -0
  32. package/dist/lib/node-esm/MarkdownSettings-QMPISOEU.mjs.map +7 -0
  33. package/dist/lib/node-esm/blueprints/index.mjs +52 -0
  34. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  35. package/dist/lib/node-esm/chunk-3OPDJJJH.mjs +122 -0
  36. package/dist/lib/node-esm/chunk-3OPDJJJH.mjs.map +7 -0
  37. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  38. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  39. package/dist/lib/node-esm/chunk-JUGS6RKO.mjs +159 -0
  40. package/dist/lib/node-esm/chunk-JUGS6RKO.mjs.map +7 -0
  41. package/dist/lib/node-esm/cli/index.mjs +40 -0
  42. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  43. package/dist/lib/node-esm/create-SMQAIM3V.mjs +31 -0
  44. package/dist/lib/node-esm/create-SMQAIM3V.mjs.map +7 -0
  45. package/dist/lib/node-esm/create-markdown-X2OASYKG.mjs +23 -0
  46. package/dist/lib/node-esm/create-markdown-X2OASYKG.mjs.map +7 -0
  47. package/dist/lib/node-esm/index.mjs +614 -142
  48. package/dist/lib/node-esm/index.mjs.map +4 -4
  49. package/dist/lib/node-esm/meta.json +1 -1
  50. package/dist/lib/node-esm/open-SRWLLOKE.mjs +22 -0
  51. package/dist/lib/node-esm/open-SRWLLOKE.mjs.map +7 -0
  52. package/dist/lib/node-esm/operations/index.mjs +15 -0
  53. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  54. package/dist/lib/node-esm/scroll-to-anchor-M76GXKYQ.mjs +50 -0
  55. package/dist/lib/node-esm/scroll-to-anchor-M76GXKYQ.mjs.map +7 -0
  56. package/dist/lib/node-esm/set-view-mode-6BB6KIDS.mjs +27 -0
  57. package/dist/lib/node-esm/set-view-mode-6BB6KIDS.mjs.map +7 -0
  58. package/dist/lib/node-esm/types/index.mjs +12 -14
  59. package/dist/lib/node-esm/update-4CELTLXK.mjs +46 -0
  60. package/dist/lib/node-esm/update-4CELTLXK.mjs.map +7 -0
  61. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  62. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  63. package/dist/types/src/blueprints/index.d.ts +2 -0
  64. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  65. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  66. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  67. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  68. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  70. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  71. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -9
  72. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  74. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  75. package/dist/types/src/capabilities/index.d.ts +9 -16
  76. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/node.d.ts +4 -0
  78. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  80. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  81. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  82. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/settings.d.ts +4 -2
  84. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/state.d.ts +4 -9
  86. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  87. package/dist/types/src/cli/index.d.ts +2 -0
  88. package/dist/types/src/cli/index.d.ts.map +1 -0
  89. package/dist/types/src/cli/plugin.d.ts +3 -0
  90. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  91. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  92. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  93. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +44 -21
  94. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  95. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
  96. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +32 -0
  98. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  99. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +13 -0
  100. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  101. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  102. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  103. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  104. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  105. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  106. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  107. package/dist/types/src/components/index.d.ts +3 -3
  108. package/dist/types/src/components/index.d.ts.map +1 -1
  109. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  110. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  111. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  112. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  113. package/dist/types/src/containers/MarkdownCard/index.d.ts +2 -0
  114. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  115. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  116. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  117. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  118. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  119. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +77 -0
  120. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  121. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  122. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  123. package/dist/types/src/containers/index.d.ts +5 -0
  124. package/dist/types/src/containers/index.d.ts.map +1 -0
  125. package/dist/types/src/hooks/index.d.ts +3 -1
  126. package/dist/types/src/hooks/index.d.ts.map +1 -1
  127. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  128. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  129. package/dist/types/src/hooks/useExtensions.d.ts +24 -0
  130. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  131. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  132. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  133. package/dist/types/src/index.d.ts +5 -3
  134. package/dist/types/src/index.d.ts.map +1 -1
  135. package/dist/types/src/meta.d.ts +2 -3
  136. package/dist/types/src/meta.d.ts.map +1 -1
  137. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  138. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  139. package/dist/types/src/operations/create.d.ts +5 -0
  140. package/dist/types/src/operations/create.d.ts.map +1 -0
  141. package/dist/types/src/operations/create.test.d.ts +2 -0
  142. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  143. package/dist/types/src/operations/definitions.d.ts +64 -0
  144. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  145. package/dist/types/src/operations/index.d.ts +4 -0
  146. package/dist/types/src/operations/index.d.ts.map +1 -0
  147. package/dist/types/src/operations/open.d.ts +5 -0
  148. package/dist/types/src/operations/open.d.ts.map +1 -0
  149. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  150. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  151. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  152. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  153. package/dist/types/src/operations/update.d.ts +5 -0
  154. package/dist/types/src/operations/update.d.ts.map +1 -0
  155. package/dist/types/src/operations/update.test.d.ts +2 -0
  156. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  157. package/dist/types/src/testing.d.ts +6 -0
  158. package/dist/types/src/testing.d.ts.map +1 -0
  159. package/dist/types/src/translations.d.ts +54 -29
  160. package/dist/types/src/translations.d.ts.map +1 -1
  161. package/dist/types/src/types/Markdown.d.ts +44 -0
  162. package/dist/types/src/types/Markdown.d.ts.map +1 -0
  163. package/dist/types/src/types/Settings.d.ts +17 -0
  164. package/dist/types/src/types/Settings.d.ts.map +1 -0
  165. package/dist/types/src/types/capabilities.d.ts +33 -0
  166. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  167. package/dist/types/src/types/events.d.ts +5 -0
  168. package/dist/types/src/types/events.d.ts.map +1 -0
  169. package/dist/types/src/types/index.d.ts +4 -1
  170. package/dist/types/src/types/index.d.ts.map +1 -1
  171. package/dist/types/src/types/types.d.ts +4 -60
  172. package/dist/types/src/types/types.d.ts.map +1 -1
  173. package/dist/types/src/util.d.ts +17 -5
  174. package/dist/types/src/util.d.ts.map +1 -1
  175. package/dist/types/src/util.test.d.ts +2 -0
  176. package/dist/types/src/util.test.d.ts.map +1 -0
  177. package/dist/types/tsconfig.tsbuildinfo +1 -1
  178. package/package.json +124 -56
  179. package/src/MarkdownPlugin.tsx +90 -107
  180. package/src/blueprints/index.ts +5 -0
  181. package/src/blueprints/markdown-blueprint.ts +44 -0
  182. package/src/capabilities/anchor-sort.ts +29 -22
  183. package/src/capabilities/app-graph-serializer.ts +55 -42
  184. package/src/capabilities/artifact-definition.ts +93 -99
  185. package/src/capabilities/blueprint-definition.ts +17 -0
  186. package/src/capabilities/index.ts +12 -10
  187. package/src/capabilities/node.ts +11 -0
  188. package/src/capabilities/operation-handler.ts +16 -0
  189. package/src/capabilities/react-surface.tsx +110 -102
  190. package/src/capabilities/settings.ts +30 -18
  191. package/src/capabilities/state.ts +40 -24
  192. package/src/cli/index.ts +5 -0
  193. package/src/cli/plugin.ts +39 -0
  194. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  195. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +63 -37
  196. package/src/components/MarkdownEditor/MarkdownEditor.tsx +251 -266
  197. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +170 -0
  198. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -0
  199. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +39 -0
  200. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -92
  201. package/src/components/MarkdownSettings/index.ts +1 -1
  202. package/src/components/index.ts +4 -5
  203. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +67 -0
  204. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  205. package/src/containers/MarkdownCard/index.ts +5 -0
  206. package/src/containers/MarkdownCard/snippet.ts +52 -0
  207. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +135 -0
  208. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +145 -0
  209. package/src/containers/MarkdownContainer/index.ts +6 -0
  210. package/src/containers/index.ts +10 -0
  211. package/src/hooks/index.ts +3 -1
  212. package/src/hooks/useEditorMenuOptions.ts +68 -0
  213. package/src/hooks/useExtensions.tsx +264 -0
  214. package/src/hooks/useLinkQuery.ts +108 -0
  215. package/src/index.ts +8 -3
  216. package/src/meta.ts +9 -10
  217. package/src/operations/create-markdown.ts +20 -0
  218. package/src/operations/create.conversations.json +1 -0
  219. package/src/operations/create.test.ts +98 -0
  220. package/src/operations/create.ts +27 -0
  221. package/src/operations/definitions.ts +120 -0
  222. package/src/operations/index.ts +16 -0
  223. package/src/operations/open.ts +25 -0
  224. package/src/operations/scroll-to-anchor.ts +39 -0
  225. package/src/operations/set-view-mode.ts +24 -0
  226. package/src/operations/update.conversations.json +1 -0
  227. package/src/operations/update.test.ts +215 -0
  228. package/src/operations/update.ts +51 -0
  229. package/src/testing.ts +27 -0
  230. package/src/translations.ts +27 -30
  231. package/src/types/Markdown.ts +50 -0
  232. package/src/types/Settings.ts +65 -0
  233. package/src/types/capabilities.ts +50 -0
  234. package/src/types/events.ts +14 -0
  235. package/src/types/index.ts +5 -1
  236. package/src/types/types.ts +7 -50
  237. package/src/util.test.ts +44 -0
  238. package/src/util.tsx +100 -11
  239. package/dist/lib/browser/MarkdownContainer-BO5MZWA4.mjs +0 -771
  240. package/dist/lib/browser/MarkdownContainer-BO5MZWA4.mjs.map +0 -7
  241. package/dist/lib/browser/MarkdownPreview-XYP2VXI2.mjs +0 -80
  242. package/dist/lib/browser/MarkdownPreview-XYP2VXI2.mjs.map +0 -7
  243. package/dist/lib/browser/anchor-sort-UKJJ7ZNP.mjs +0 -32
  244. package/dist/lib/browser/anchor-sort-UKJJ7ZNP.mjs.map +0 -7
  245. package/dist/lib/browser/app-graph-serializer-7DKUUZSJ.mjs +0 -52
  246. package/dist/lib/browser/app-graph-serializer-7DKUUZSJ.mjs.map +0 -7
  247. package/dist/lib/browser/artifact-definition-JSUG6XPF.mjs +0 -145
  248. package/dist/lib/browser/artifact-definition-JSUG6XPF.mjs.map +0 -7
  249. package/dist/lib/browser/chunk-5JRBJCZM.mjs +0 -50
  250. package/dist/lib/browser/chunk-5JRBJCZM.mjs.map +0 -7
  251. package/dist/lib/browser/chunk-777RIED6.mjs +0 -16
  252. package/dist/lib/browser/chunk-777RIED6.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-EPTSAJZM.mjs +0 -22
  254. package/dist/lib/browser/chunk-EPTSAJZM.mjs.map +0 -7
  255. package/dist/lib/browser/chunk-IZLATPXQ.mjs +0 -20
  256. package/dist/lib/browser/chunk-IZLATPXQ.mjs.map +0 -7
  257. package/dist/lib/browser/chunk-LFML7LC6.mjs +0 -51
  258. package/dist/lib/browser/chunk-LFML7LC6.mjs.map +0 -7
  259. package/dist/lib/browser/chunk-UANWRJZU.mjs +0 -79
  260. package/dist/lib/browser/chunk-UANWRJZU.mjs.map +0 -7
  261. package/dist/lib/browser/intent-resolver-3MXYO3MW.mjs +0 -64
  262. package/dist/lib/browser/intent-resolver-3MXYO3MW.mjs.map +0 -7
  263. package/dist/lib/browser/react-surface-NAXBGUR3.mjs +0 -205
  264. package/dist/lib/browser/react-surface-NAXBGUR3.mjs.map +0 -7
  265. package/dist/lib/browser/settings-KN75ZQY6.mjs +0 -28
  266. package/dist/lib/browser/settings-KN75ZQY6.mjs.map +0 -7
  267. package/dist/lib/browser/state-LZWTAS65.mjs +0 -37
  268. package/dist/lib/browser/state-LZWTAS65.mjs.map +0 -7
  269. package/dist/lib/node-esm/MarkdownContainer-J2NVCX2H.mjs +0 -772
  270. package/dist/lib/node-esm/MarkdownContainer-J2NVCX2H.mjs.map +0 -7
  271. package/dist/lib/node-esm/MarkdownPreview-JEXD3KSQ.mjs +0 -81
  272. package/dist/lib/node-esm/MarkdownPreview-JEXD3KSQ.mjs.map +0 -7
  273. package/dist/lib/node-esm/anchor-sort-IPIS5D5B.mjs +0 -33
  274. package/dist/lib/node-esm/anchor-sort-IPIS5D5B.mjs.map +0 -7
  275. package/dist/lib/node-esm/app-graph-serializer-YRMRPW7A.mjs +0 -53
  276. package/dist/lib/node-esm/app-graph-serializer-YRMRPW7A.mjs.map +0 -7
  277. package/dist/lib/node-esm/artifact-definition-6C2MOHGP.mjs +0 -146
  278. package/dist/lib/node-esm/artifact-definition-6C2MOHGP.mjs.map +0 -7
  279. package/dist/lib/node-esm/chunk-ACFGXH2K.mjs +0 -17
  280. package/dist/lib/node-esm/chunk-ACFGXH2K.mjs.map +0 -7
  281. package/dist/lib/node-esm/chunk-CWTFQSN7.mjs +0 -52
  282. package/dist/lib/node-esm/chunk-CWTFQSN7.mjs.map +0 -7
  283. package/dist/lib/node-esm/chunk-CXG7GMYP.mjs +0 -24
  284. package/dist/lib/node-esm/chunk-CXG7GMYP.mjs.map +0 -7
  285. package/dist/lib/node-esm/chunk-FWKOJW6J.mjs +0 -22
  286. package/dist/lib/node-esm/chunk-FWKOJW6J.mjs.map +0 -7
  287. package/dist/lib/node-esm/chunk-JEEQLO7C.mjs +0 -80
  288. package/dist/lib/node-esm/chunk-JEEQLO7C.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-Q5DIKLN5.mjs +0 -51
  290. package/dist/lib/node-esm/chunk-Q5DIKLN5.mjs.map +0 -7
  291. package/dist/lib/node-esm/intent-resolver-BZYWV53A.mjs +0 -65
  292. package/dist/lib/node-esm/intent-resolver-BZYWV53A.mjs.map +0 -7
  293. package/dist/lib/node-esm/react-surface-BSAGEIN6.mjs +0 -206
  294. package/dist/lib/node-esm/react-surface-BSAGEIN6.mjs.map +0 -7
  295. package/dist/lib/node-esm/settings-KVP7TVX7.mjs +0 -29
  296. package/dist/lib/node-esm/settings-KVP7TVX7.mjs.map +0 -7
  297. package/dist/lib/node-esm/state-NW3W4JCQ.mjs +0 -38
  298. package/dist/lib/node-esm/state-NW3W4JCQ.mjs.map +0 -7
  299. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  300. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  301. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  302. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  303. package/dist/types/src/components/MarkdownContainer.d.ts +0 -18
  304. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  305. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -9
  306. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  307. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +0 -6
  308. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +0 -1
  309. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +0 -17
  310. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +0 -1
  311. package/dist/types/src/components/MarkdownPreview/index.d.ts +0 -4
  312. package/dist/types/src/components/MarkdownPreview/index.d.ts.map +0 -1
  313. package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
  314. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  315. package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
  316. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  317. package/dist/types/src/events.d.ts +0 -4
  318. package/dist/types/src/events.d.ts.map +0 -1
  319. package/dist/types/src/extensions.d.ts +0 -24
  320. package/dist/types/src/extensions.d.ts.map +0 -1
  321. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  322. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  323. package/dist/types/src/types/schema.d.ts +0 -35
  324. package/dist/types/src/types/schema.d.ts.map +0 -1
  325. package/src/capabilities/capabilities.ts +0 -20
  326. package/src/capabilities/intent-resolver.ts +0 -63
  327. package/src/components/MarkdownContainer.stories.tsx +0 -103
  328. package/src/components/MarkdownContainer.tsx +0 -241
  329. package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +0 -74
  330. package/src/components/MarkdownPreview/MarkdownPreview.tsx +0 -71
  331. package/src/components/MarkdownPreview/index.ts +0 -9
  332. package/src/components/Suggestions.stories.tsx +0 -215
  333. package/src/components/Toolbar.stories.tsx +0 -113
  334. package/src/events.ts +0 -11
  335. package/src/extensions.tsx +0 -328
  336. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  337. package/src/types/schema.ts +0 -39
@@ -1,771 +0,0 @@
1
- import "./chunk-IZLATPXQ.mjs";
2
- import {
3
- MarkdownCapabilities
4
- } from "./chunk-777RIED6.mjs";
5
- import {
6
- getFallbackName,
7
- setFallbackName
8
- } from "./chunk-LFML7LC6.mjs";
9
- import {
10
- DocumentType
11
- } from "./chunk-UANWRJZU.mjs";
12
- import {
13
- MARKDOWN_PLUGIN
14
- } from "./chunk-EPTSAJZM.mjs";
15
-
16
- // src/components/MarkdownContainer.tsx
17
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
18
- import { Rx } from "@effect-rx/rx-react";
19
- import React3, { useCallback as useCallback2, useEffect as useEffect2, useMemo as useMemo4, useState } from "react";
20
- import { createPortal } from "react-dom";
21
- import { Capabilities, Surface, useAppGraph, useCapabilities as useCapabilities2, usePluginManager } from "@dxos/app-framework";
22
- import { DXN, Filter, Obj, Query } from "@dxos/echo";
23
- import { SpaceCapabilities } from "@dxos/plugin-space";
24
- import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2, useQuery, useSpace } from "@dxos/react-client/echo";
25
- import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
26
- import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
27
- import { DataType } from "@dxos/schema";
28
-
29
- // src/components/MarkdownEditor/MarkdownEditor.tsx
30
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
31
- import React, { forwardRef, useMemo as useMemo2, useEffect, useCallback, useImperativeHandle, useRef } from "react";
32
- import { useDropzone } from "react-dropzone";
33
- import { invariant as invariant2 } from "@dxos/invariant";
34
- import { toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
35
- import { CommandMenu, EditorToolbar, RefPopover, addLink, createElement, coreSlashCommands, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, filterItems, linkSlashCommands, processEditorPayload, stackItemContentEditorClassNames, useEditorToolbarState, useFormattingState, useTextEditor, useCommandMenu } from "@dxos/react-ui-editor";
36
- import { StackItem } from "@dxos/react-ui-stack";
37
- import { isNotFalsy, isNonNullable } from "@dxos/util";
38
-
39
- // src/hooks/useSelectCurrentThread.tsx
40
- import { EditorView } from "@codemirror/view";
41
- import { Schema } from "effect";
42
- import { useMemo } from "react";
43
- import { createResolver, LayoutAction, useIntentResolver } from "@dxos/app-framework";
44
- import { invariant } from "@dxos/invariant";
45
- import { Cursor, setSelection } from "@dxos/react-ui-editor";
46
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useSelectCurrentThread.tsx";
47
- var useSelectCurrentThread = (editorView, documentId2) => {
48
- const scrollIntoViewResolver = useMemo(() => createResolver({
49
- intent: LayoutAction.UpdateLayout,
50
- position: "hoist",
51
- filter: (data) => {
52
- if (!Schema.is(LayoutAction.ScrollIntoView.fields.input)(data)) {
53
- return false;
54
- }
55
- return !!editorView && data.subject === documentId2 && !!data.options?.cursor;
56
- },
57
- resolve: ({ options: { cursor } }) => {
58
- invariant(editorView, "Editor view is not defined.", {
59
- F: __dxlog_file,
60
- L: 32,
61
- S: void 0,
62
- A: [
63
- "editorView",
64
- "'Editor view is not defined.'"
65
- ]
66
- });
67
- const range = Cursor.getRangeFromCursor(editorView.state, cursor);
68
- if (range) {
69
- const selection = editorView.state.selection.main.from !== range.from ? {
70
- anchor: range.from
71
- } : void 0;
72
- const effects = [
73
- // NOTE: This does not use the DOM scrollIntoView function.
74
- EditorView.scrollIntoView(range.from, {
75
- y: "start",
76
- yMargin: 96
77
- })
78
- ];
79
- if (selection) {
80
- effects.push(setSelection.of({
81
- current: documentId2
82
- }));
83
- }
84
- editorView.dispatch({
85
- effects,
86
- selection: selection ? {
87
- anchor: range.from
88
- } : void 0
89
- });
90
- }
91
- }
92
- }), [
93
- documentId2,
94
- editorView
95
- ]);
96
- useIntentResolver(MARKDOWN_PLUGIN, scrollIntoViewResolver);
97
- };
98
-
99
- // src/components/MarkdownEditor/MarkdownEditor.tsx
100
- var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditor.tsx";
101
- var MarkdownEditor = ({ extensions: _extensions, slashCommandGroups, onLinkQuery, ...props }) => {
102
- var _effect = _useSignals();
103
- try {
104
- const { t } = useTranslation();
105
- const viewRef = useRef();
106
- const getMenu = useCallback((trigger, query) => {
107
- switch (trigger) {
108
- case "@":
109
- return onLinkQuery?.(query) ?? [];
110
- case "/":
111
- default:
112
- return filterItems([
113
- coreSlashCommands,
114
- linkSlashCommands,
115
- ...slashCommandGroups ?? []
116
- ], (item) => query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true);
117
- }
118
- }, [
119
- onLinkQuery,
120
- slashCommandGroups
121
- ]);
122
- const options = useMemo2(() => {
123
- const trigger = onLinkQuery ? [
124
- "/",
125
- "@"
126
- ] : [
127
- "/"
128
- ];
129
- return {
130
- viewRef,
131
- trigger,
132
- placeholder: {
133
- delay: 3e3,
134
- content: () => {
135
- return createElement("div", void 0, [
136
- createElement("span", {
137
- text: "Press"
138
- }),
139
- ...trigger.map((text) => createElement("span", {
140
- className: "border border-separator rounded-sm mx-1 px-1.5 pt-[1px] pb-[2px]",
141
- text
142
- })),
143
- createElement("span", {
144
- text: "for commands."
145
- })
146
- ]);
147
- }
148
- },
149
- getMenu
150
- };
151
- }, [
152
- getMenu
153
- ]);
154
- const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu(options);
155
- const extensions = useMemo2(() => [
156
- _extensions,
157
- commandMenu
158
- ].filter(isNotFalsy), [
159
- _extensions,
160
- commandMenu
161
- ]);
162
- return /* @__PURE__ */ React.createElement(RefPopover, {
163
- modal: false,
164
- ...refPopoverProps
165
- }, /* @__PURE__ */ React.createElement(MarkdownEditorImpl, {
166
- ref: viewRef,
167
- ...props,
168
- extensions
169
- }), /* @__PURE__ */ React.createElement(CommandMenu, {
170
- groups: groupsRef.current,
171
- currentItem,
172
- onSelect
173
- }));
174
- } finally {
175
- _effect.f();
176
- }
177
- };
178
- var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", initialValue, customActions, editorStateStore, extensions, extensionProviders, scrollPastEnd, toolbar, viewMode, onFileUpload, onViewModeChange }, forwardedRef) => {
179
- var _effect = _useSignals();
180
- try {
181
- const { t } = useTranslation(MARKDOWN_PLUGIN);
182
- const { themeMode } = useThemeContext();
183
- const toolbarState = useEditorToolbarState({
184
- viewMode
185
- });
186
- const formattingObserver = useFormattingState(toolbarState);
187
- const { scrollTo, selection } = useMemo2(() => editorStateStore?.getState(id) ?? {}, [
188
- id
189
- ]);
190
- const providerExtensions = useMemo2(() => extensionProviders?.flatMap((provider) => provider({})).filter(isNonNullable), [
191
- extensionProviders
192
- ]);
193
- const handleDrop = async (view, { files }) => {
194
- const file = files[0];
195
- const info = file && onFileUpload ? await onFileUpload(file) : void 0;
196
- if (info) {
197
- processEditorPayload(view, {
198
- type: "image",
199
- data: info.url
200
- });
201
- }
202
- };
203
- const { parentRef, view: editorView, focusAttributes } = useTextEditor(() => ({
204
- initialValue,
205
- extensions: [
206
- formattingObserver,
207
- createBasicExtensions({
208
- readOnly: viewMode === "readonly",
209
- placeholder: t("editor placeholder"),
210
- scrollPastEnd: role === "section" ? false : scrollPastEnd
211
- }),
212
- createMarkdownExtensions({
213
- themeMode
214
- }),
215
- createThemeExtensions({
216
- themeMode,
217
- syntaxHighlighting: true,
218
- slots: editorSlots
219
- }),
220
- editorGutter,
221
- role !== "section" && onFileUpload && dropFile({
222
- onDrop: handleDrop
223
- }),
224
- providerExtensions,
225
- extensions
226
- ].filter(isNotFalsy),
227
- ...role !== "section" && {
228
- id,
229
- scrollTo,
230
- selection,
231
- // TODO(wittjosiah): Autofocus based on layout is racy.
232
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
233
- moveToEndOfLine: true
234
- }
235
- }), [
236
- id,
237
- formattingObserver,
238
- viewMode,
239
- themeMode,
240
- extensions,
241
- providerExtensions
242
- ]);
243
- useImperativeHandle(forwardedRef, () => editorView, [
244
- editorView
245
- ]);
246
- useTest(editorView);
247
- useSelectCurrentThread(editorView, id);
248
- const { acceptedFiles, getInputProps, open } = useDropzone({
249
- multiple: false,
250
- noDrag: true,
251
- accept: {
252
- "image/*": [
253
- ".jpg",
254
- ".jpeg",
255
- ".png",
256
- ".gif"
257
- ]
258
- }
259
- });
260
- useEffect(() => {
261
- if (editorView && onFileUpload && acceptedFiles.length) {
262
- requestAnimationFrame(async () => {
263
- const f = acceptedFiles[0];
264
- const file = new File([
265
- f
266
- ], f.name, {
267
- type: f.type,
268
- lastModified: f.lastModified
269
- });
270
- const info = await onFileUpload(file);
271
- if (info) {
272
- addLink({
273
- url: info.url,
274
- image: true
275
- })(editorView);
276
- }
277
- });
278
- }
279
- }, [
280
- acceptedFiles,
281
- editorView,
282
- onFileUpload
283
- ]);
284
- const getView = useCallback(() => {
285
- invariant2(editorView, void 0, {
286
- F: __dxlog_file2,
287
- L: 240,
288
- S: void 0,
289
- A: [
290
- "editorView",
291
- ""
292
- ]
293
- });
294
- return editorView;
295
- }, [
296
- editorView
297
- ]);
298
- const handleViewModeChange = useCallback((mode) => onViewModeChange?.(id, mode), [
299
- id,
300
- onViewModeChange
301
- ]);
302
- const handleImageUpload = useCallback(() => {
303
- if (onFileUpload) {
304
- open();
305
- }
306
- }, [
307
- onFileUpload
308
- ]);
309
- return /* @__PURE__ */ React.createElement(StackItem.Content, {
310
- toolbar: !!toolbar
311
- }, toolbar && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(EditorToolbar, {
312
- attendableId: id,
313
- role,
314
- state: toolbarState,
315
- customActions,
316
- getView,
317
- image: handleImageUpload,
318
- viewMode: handleViewModeChange
319
- }), /* @__PURE__ */ React.createElement("input", getInputProps())), /* @__PURE__ */ React.createElement("div", {
320
- role: "none",
321
- ref: parentRef,
322
- "data-testid": "composer.markdownRoot",
323
- "data-toolbar": toolbar ? "enabled" : "disabled",
324
- className: stackItemContentEditorClassNames(role),
325
- "data-popover-collision-boundary": true,
326
- ...focusAttributes
327
- }));
328
- } finally {
329
- _effect.f();
330
- }
331
- });
332
- var useTest = (view) => {
333
- useEffect(() => {
334
- const composer = window.composer;
335
- if (composer) {
336
- composer.editorView = view;
337
- }
338
- }, [
339
- view
340
- ]);
341
- };
342
-
343
- // src/extensions.tsx
344
- import React2, { useMemo as useMemo3 } from "react";
345
- import { createRoot } from "react-dom/client";
346
- import { createIntent, LayoutAction as LayoutAction2, useCapabilities, useIntentDispatcher } from "@dxos/app-framework";
347
- import { debounceAndThrottle } from "@dxos/async";
348
- import { invariant as invariant3 } from "@dxos/invariant";
349
- import { createDocAccessor, fullyQualifiedId, getSpace } from "@dxos/react-client/echo";
350
- import { useIdentity } from "@dxos/react-client/halo";
351
- import { Icon, ThemeProvider } from "@dxos/react-ui";
352
- import { InputModeExtensions, createDataExtensions, autocomplete, decorateMarkdown, folding, formattingKeymap, linkTooltip, listener, preview, selectionState, typewriter, EditorView as EditorView2, documentId, Cursor as Cursor2 } from "@dxos/react-ui-editor";
353
- import { defaultTx } from "@dxos/react-ui-theme";
354
- import { isNotFalsy as isNotFalsy2 } from "@dxos/util";
355
- var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
356
- var useExtensions = ({ document, id, text, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
357
- const { dispatchPromise: dispatch } = useIntentDispatcher();
358
- const identity = useIdentity();
359
- const space = getSpace(document) ?? getSpace(text);
360
- const baseExtensions = useMemo3(() => createBaseExtensions({
361
- document,
362
- id,
363
- text,
364
- settings,
365
- selectionManager,
366
- viewMode,
367
- previewOptions,
368
- dispatch
369
- }), [
370
- document,
371
- id,
372
- text,
373
- viewMode,
374
- dispatch,
375
- previewOptions,
376
- settings,
377
- settings.editorInputMode,
378
- settings.folding,
379
- settings.numberedHeadings,
380
- settings.debug,
381
- settings.typewriter,
382
- selectionManager
383
- ]);
384
- const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);
385
- const pluginExtensions = useMemo3(() => {
386
- if (!document) {
387
- return [];
388
- }
389
- return extensionProviders.flat().reduce((acc, provider) => {
390
- const extension = typeof provider === "function" ? provider({
391
- document
392
- }) : provider;
393
- if (extension) {
394
- acc.push(extension);
395
- }
396
- return acc;
397
- }, []);
398
- }, [
399
- extensionProviders,
400
- document
401
- ]);
402
- return useMemo3(() => [
403
- // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.
404
- document && createDataExtensions({
405
- id: document.id,
406
- text: document.content.target && createDocAccessor(document.content.target, [
407
- "content"
408
- ]),
409
- space,
410
- identity
411
- }),
412
- text && id && createDataExtensions({
413
- id,
414
- text: createDocAccessor(text, [
415
- "content"
416
- ]),
417
- space,
418
- identity
419
- }),
420
- selectionState(editorStateStore),
421
- document && listener({
422
- onChange: (text2) => setFallbackName(document, text2)
423
- }),
424
- baseExtensions,
425
- pluginExtensions
426
- ].filter(isNotFalsy2), [
427
- baseExtensions,
428
- pluginExtensions,
429
- document,
430
- document?.content?.target,
431
- text,
432
- id,
433
- space,
434
- identity
435
- ]);
436
- };
437
- var createBaseExtensions = ({ document, id, dispatch, settings, selectionManager, query, viewMode, previewOptions }) => {
438
- const extensions = [
439
- selectionManager && selectionChange(selectionManager),
440
- settings.editorInputMode && InputModeExtensions[settings.editorInputMode],
441
- settings.folding && folding()
442
- ].filter(isNotFalsy2);
443
- if (viewMode !== "source") {
444
- extensions.push(...[
445
- formattingKeymap(),
446
- decorateMarkdown({
447
- selectionChangeDelay: 100,
448
- numberedHeadings: settings.numberedHeadings ? {
449
- from: 2
450
- } : void 0,
451
- // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
452
- renderLinkButton: dispatch && (document || id) ? createLinkRenderer((id2) => {
453
- void dispatch(createIntent(LayoutAction2.Open, {
454
- part: "main",
455
- subject: [
456
- id2
457
- ],
458
- options: {
459
- pivotId: document ? fullyQualifiedId(document) : id2
460
- }
461
- }));
462
- }) : void 0
463
- }),
464
- linkTooltip(renderLinkTooltip),
465
- preview(previewOptions)
466
- ]);
467
- }
468
- if (query) {
469
- extensions.push(autocomplete({
470
- onSearch: (text) => {
471
- return query.objects.map((object) => object.name?.length && object.id !== document?.id ? {
472
- label: object.name,
473
- // TODO(burdon): Factor out URL builder.
474
- apply: `[${object.name}](/${fullyQualifiedId(object)})`
475
- } : void 0).filter(isNotFalsy2);
476
- }
477
- }));
478
- }
479
- if (settings.debug) {
480
- const items = settings.typewriter?.split(/[,\n]/) ?? "";
481
- if (items) {
482
- extensions.push(typewriter({
483
- items
484
- }));
485
- }
486
- }
487
- return extensions;
488
- };
489
- var selectionChange = (selectionManager) => {
490
- return EditorView2.updateListener.of(debounceAndThrottle((update) => {
491
- if (update.selectionSet) {
492
- const id = update.state.facet(documentId);
493
- const cursorConverter = update.state.facet(Cursor2.converter);
494
- const selection = update.state.selection;
495
- const ranges = selection.ranges.map((range) => ({
496
- from: cursorConverter.toCursor(range.from),
497
- to: cursorConverter.toCursor(range.to)
498
- })).filter(({ from, to }) => to > from);
499
- selectionManager.updateMultiRange(id, ranges);
500
- }
501
- }, 100));
502
- };
503
- var style = {
504
- hover: "rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400",
505
- icon: "inline-block leading-none mis-1 cursor-pointer"
506
- };
507
- var createLinkRenderer = (onSelectObject) => (el, { url }) => {
508
- const isInternal = url.startsWith("/") || // TODO(wittjosiah): This should probably be parsed out on paste?
509
- url.startsWith(window.location.origin);
510
- const options = isInternal ? {
511
- onClick: () => {
512
- const qualifiedId = url.split("/").at(-1);
513
- invariant3(qualifiedId, "Invalid link format.", {
514
- F: __dxlog_file3,
515
- L: 291,
516
- S: void 0,
517
- A: [
518
- "qualifiedId",
519
- "'Invalid link format.'"
520
- ]
521
- });
522
- onSelectObject(qualifiedId);
523
- }
524
- } : {
525
- href: url,
526
- rel: "noreferrer",
527
- target: "_blank"
528
- };
529
- renderRoot(el, /* @__PURE__ */ React2.createElement("a", {
530
- ...options,
531
- className: style.hover
532
- }, /* @__PURE__ */ React2.createElement(Icon, {
533
- icon: isInternal ? "ph--arrow-square-down--bold" : "ph--arrow-square-out--bold",
534
- size: 4,
535
- classNames: style.icon
536
- })));
537
- };
538
- var renderLinkTooltip = (el, { url }) => {
539
- const web = new URL(url);
540
- renderRoot(el, /* @__PURE__ */ React2.createElement("a", {
541
- href: url,
542
- rel: "noreferrer",
543
- target: "_blank",
544
- className: style.hover
545
- }, web.origin, /* @__PURE__ */ React2.createElement(Icon, {
546
- icon: "ph--arrow-square-out--bold",
547
- size: 4,
548
- classNames: style.icon
549
- })));
550
- };
551
- var renderRoot = (root, node) => {
552
- createRoot(root).render(/* @__PURE__ */ React2.createElement(ThemeProvider, {
553
- tx: defaultTx
554
- }, node));
555
- return root;
556
- };
557
-
558
- // src/components/MarkdownContainer.tsx
559
- var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMode, editorStateStore, onViewModeChange }) => {
560
- var _effect = _useSignals2();
561
- try {
562
- const { t } = useTranslation2();
563
- const scrollPastEnd = role === "article";
564
- const doc = Obj.instanceOf(DocumentType, object) ? object : void 0;
565
- const text = Obj.instanceOf(DataType.Text, object) ? object : void 0;
566
- const [previewBlocks, setPreviewBlocks] = useState([]);
567
- const previewOptions = useMemo4(() => ({
568
- addBlockContainer: (link, el) => {
569
- setPreviewBlocks((prev) => [
570
- ...prev,
571
- {
572
- link,
573
- el
574
- }
575
- ]);
576
- },
577
- removeBlockContainer: (link) => {
578
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
579
- }
580
- }), []);
581
- const extensions = useExtensions({
582
- document: doc,
583
- text,
584
- id,
585
- settings,
586
- selectionManager,
587
- viewMode,
588
- editorStateStore,
589
- previewOptions
590
- });
591
- const manager = usePluginManager();
592
- const resolve = useCallback2((typename) => manager.context.getCapabilities(Capabilities.Metadata).find(({ id: id2 }) => id2 === typename)?.metadata ?? {}, [
593
- manager
594
- ]);
595
- const space = getSpace2(object);
596
- const objectForms = useCapabilities2(SpaceCapabilities.ObjectForm);
597
- const filter = useMemo4(() => Filter.or(...objectForms.map((form) => Filter.type(form.objectSchema))), [
598
- objectForms
599
- ]);
600
- const onLinkQuery = useCallback2(async (query) => {
601
- const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
602
- const results = await space?.db.query(Query.select(filter)).run();
603
- const getLabel = (object2) => {
604
- const type = Obj.getTypename(object2);
605
- const metadata = resolve(type);
606
- return metadata.label?.(object2) || object2.name || [
607
- "object name placeholder",
608
- {
609
- ns: type,
610
- default: "New object"
611
- }
612
- ];
613
- };
614
- const items = results?.objects.filter((object2) => toLocalizedString2(getLabel(object2), t).toLowerCase().includes(name)).map((object2) => {
615
- const metadata = resolve(Obj.getTypename(object2));
616
- const label = toLocalizedString2(getLabel(object2), t);
617
- return {
618
- id: object2.id,
619
- label,
620
- icon: metadata.icon,
621
- onSelect: (view, head) => {
622
- const link = `[${label}][${Obj.getDXN(object2)}]`;
623
- if (query?.startsWith("@")) {
624
- insertAtLineStart(view, head, `!${link}
625
- `);
626
- } else {
627
- insertAtCursor(view, head, `${link} `);
628
- }
629
- }
630
- };
631
- }) ?? [];
632
- return [
633
- {
634
- id: "echo",
635
- items
636
- }
637
- ];
638
- }, [
639
- filter,
640
- resolve,
641
- space
642
- ]);
643
- const editor = doc ? /* @__PURE__ */ React3.createElement(DocumentEditor, {
644
- id: fullyQualifiedId2(object),
645
- role,
646
- document: doc,
647
- extensions,
648
- viewMode,
649
- settings,
650
- scrollPastEnd,
651
- onViewModeChange,
652
- onLinkQuery: space ? onLinkQuery : void 0
653
- }) : text ? /* @__PURE__ */ React3.createElement(MarkdownEditor, {
654
- id,
655
- role,
656
- initialValue: text.content,
657
- extensions,
658
- viewMode,
659
- toolbar: settings.toolbar,
660
- inputMode: settings.editorInputMode,
661
- scrollPastEnd,
662
- onViewModeChange,
663
- onLinkQuery: space ? onLinkQuery : void 0
664
- }) : (
665
- // TODO(burdon): Normalize with above.
666
- /* @__PURE__ */ React3.createElement(MarkdownEditor, {
667
- id,
668
- role,
669
- initialValue: object.text,
670
- extensions,
671
- viewMode,
672
- toolbar: settings.toolbar,
673
- inputMode: settings.editorInputMode,
674
- scrollPastEnd,
675
- onViewModeChange,
676
- onLinkQuery: space ? onLinkQuery : void 0
677
- })
678
- );
679
- return /* @__PURE__ */ React3.createElement(React3.Fragment, null, editor, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React3.createElement(PreviewBlock, {
680
- key: link.ref,
681
- link,
682
- el
683
- })));
684
- } finally {
685
- _effect.f();
686
- }
687
- };
688
- var PreviewBlock = ({ link, el }) => {
689
- var _effect = _useSignals2();
690
- try {
691
- const echoDXN = useMemo4(() => DXN.parse(link.ref).asEchoDXN(), [
692
- link.ref
693
- ]);
694
- const space = useSpace(echoDXN?.spaceId);
695
- const [subject] = useQuery(space, Query.select(Filter.ids(echoDXN?.echoId ?? "")));
696
- const data = useMemo4(() => ({
697
- subject
698
- }), [
699
- subject
700
- ]);
701
- return /* @__PURE__ */ createPortal(/* @__PURE__ */ React3.createElement(Surface, {
702
- role: "card--document",
703
- data,
704
- limit: 1
705
- }), el);
706
- } finally {
707
- _effect.f();
708
- }
709
- };
710
- var DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }) => {
711
- var _effect = _useSignals2();
712
- try {
713
- const space = getSpace2(doc);
714
- useEffect2(() => {
715
- if (typeof doc.fallbackName === "string") {
716
- return;
717
- }
718
- const fallbackName = doc.content?.target?.content ? getFallbackName(doc.content.target.content) : void 0;
719
- if (fallbackName) {
720
- doc.fallbackName = fallbackName;
721
- }
722
- }, [
723
- doc,
724
- doc.content
725
- ]);
726
- const [upload] = useCapabilities2(Capabilities.FileUploader);
727
- const handleFileUpload = useMemo4(() => {
728
- if (space === void 0 || upload === void 0) {
729
- return void 0;
730
- }
731
- return async (file) => upload(file, space);
732
- }, [
733
- space,
734
- upload
735
- ]);
736
- const { graph } = useAppGraph();
737
- const customActions = useMemo4(() => {
738
- return Rx.make((get) => {
739
- const actions = get(graph.actions(id));
740
- const nodes = actions.filter((action) => action.properties.disposition === "toolbar");
741
- return {
742
- nodes,
743
- edges: nodes.map((node) => ({
744
- source: "root",
745
- target: node.id
746
- }))
747
- };
748
- });
749
- }, [
750
- graph
751
- ]);
752
- return /* @__PURE__ */ React3.createElement(MarkdownEditor, {
753
- id,
754
- initialValue: doc.content?.target?.content,
755
- viewMode,
756
- toolbar: settings.toolbar,
757
- customActions,
758
- inputMode: settings.editorInputMode,
759
- onFileUpload: handleFileUpload,
760
- ...props
761
- });
762
- } finally {
763
- _effect.f();
764
- }
765
- };
766
- var MarkdownContainer_default = MarkdownContainer;
767
- export {
768
- DocumentEditor,
769
- MarkdownContainer_default as default
770
- };
771
- //# sourceMappingURL=MarkdownContainer-BO5MZWA4.mjs.map