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

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 (357) hide show
  1. package/dist/lib/browser/MarkdownCard-7VIO7R66.mjs +11 -0
  2. package/dist/lib/browser/MarkdownContainer-6E43EDAU.mjs +11 -0
  3. package/dist/lib/browser/{anchor-sort-3MYLO74J.mjs → anchor-sort-JBAZRPE7.mjs} +8 -7
  4. package/dist/lib/browser/anchor-sort-JBAZRPE7.mjs.map +7 -0
  5. package/dist/lib/browser/app-graph-serializer-6Q5YBUPW.mjs +59 -0
  6. package/dist/lib/browser/app-graph-serializer-6Q5YBUPW.mjs.map +7 -0
  7. package/dist/lib/browser/blueprint-definition-6HOAW2E6.mjs +20 -0
  8. package/dist/lib/browser/blueprint-definition-6HOAW2E6.mjs.map +7 -0
  9. package/dist/lib/browser/blueprints/index.mjs +8 -0
  10. package/dist/lib/browser/{chunk-NXT2E2BG.mjs → chunk-2AAD3W6X.mjs} +6 -6
  11. package/dist/lib/browser/chunk-2AAD3W6X.mjs.map +7 -0
  12. package/dist/lib/browser/chunk-4GT3QWMK.mjs +167 -0
  13. package/dist/lib/browser/chunk-4GT3QWMK.mjs.map +7 -0
  14. package/dist/lib/browser/chunk-6SM75KL3.mjs +8 -0
  15. package/dist/lib/browser/chunk-6SM75KL3.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-7AQTX6D5.mjs +105 -0
  17. package/dist/lib/browser/chunk-7AQTX6D5.mjs.map +7 -0
  18. package/dist/lib/browser/chunk-EZZFREFN.mjs +58 -0
  19. package/dist/lib/browser/chunk-EZZFREFN.mjs.map +7 -0
  20. package/dist/lib/browser/chunk-HHRUUWGH.mjs +796 -0
  21. package/dist/lib/browser/chunk-HHRUUWGH.mjs.map +7 -0
  22. package/dist/lib/browser/chunk-HQTBT5IY.mjs +176 -0
  23. package/dist/lib/browser/chunk-HQTBT5IY.mjs.map +7 -0
  24. package/dist/lib/browser/cli/index.mjs +33 -0
  25. package/dist/lib/browser/cli/index.mjs.map +7 -0
  26. package/dist/lib/browser/index.mjs +124 -129
  27. package/dist/lib/browser/index.mjs.map +4 -4
  28. package/dist/lib/browser/meta.json +1 -1
  29. package/dist/lib/browser/operation-resolver-UBQUPSXC.mjs +53 -0
  30. package/dist/lib/browser/operation-resolver-UBQUPSXC.mjs.map +7 -0
  31. package/dist/lib/browser/react-surface-7Z6AB26V.mjs +213 -0
  32. package/dist/lib/browser/react-surface-7Z6AB26V.mjs.map +7 -0
  33. package/dist/lib/browser/settings-V2XOFSD5.mjs +36 -0
  34. package/dist/lib/browser/settings-V2XOFSD5.mjs.map +7 -0
  35. package/dist/lib/browser/state-6Y3JB64H.mjs +29 -0
  36. package/dist/lib/browser/state-6Y3JB64H.mjs.map +7 -0
  37. package/dist/lib/browser/types/index.mjs +10 -3
  38. package/dist/lib/node-esm/MarkdownCard-YC3R2TQW.mjs +12 -0
  39. package/dist/lib/node-esm/MarkdownContainer-TTRUOXU6.mjs +12 -0
  40. package/dist/lib/node-esm/{anchor-sort-W4HCTYUQ.mjs → anchor-sort-IQMDZRA3.mjs} +8 -7
  41. package/dist/lib/node-esm/anchor-sort-IQMDZRA3.mjs.map +7 -0
  42. package/dist/lib/node-esm/app-graph-serializer-STEPJH57.mjs +60 -0
  43. package/dist/lib/node-esm/app-graph-serializer-STEPJH57.mjs.map +7 -0
  44. package/dist/lib/node-esm/blueprint-definition-UGDFF5OZ.mjs +21 -0
  45. package/dist/lib/node-esm/blueprint-definition-UGDFF5OZ.mjs.map +7 -0
  46. package/dist/lib/node-esm/blueprints/index.mjs +9 -0
  47. package/dist/lib/node-esm/chunk-AGZOFIK2.mjs +10 -0
  48. package/dist/lib/node-esm/chunk-AGZOFIK2.mjs.map +7 -0
  49. package/dist/lib/node-esm/chunk-D46D75SK.mjs +797 -0
  50. package/dist/lib/node-esm/chunk-D46D75SK.mjs.map +7 -0
  51. package/dist/lib/node-esm/chunk-DCKB3AVD.mjs +59 -0
  52. package/dist/lib/node-esm/chunk-DCKB3AVD.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-K2IIYNCG.mjs +106 -0
  54. package/dist/lib/node-esm/chunk-K2IIYNCG.mjs.map +7 -0
  55. package/dist/lib/node-esm/chunk-LOZVC2WA.mjs +177 -0
  56. package/dist/lib/node-esm/chunk-LOZVC2WA.mjs.map +7 -0
  57. package/dist/lib/node-esm/{chunk-I5JSQBPI.mjs → chunk-MLZQCT2N.mjs} +6 -6
  58. package/dist/lib/node-esm/chunk-MLZQCT2N.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-USKAPINH.mjs +168 -0
  60. package/dist/lib/node-esm/chunk-USKAPINH.mjs.map +7 -0
  61. package/dist/lib/node-esm/cli/index.mjs +34 -0
  62. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  63. package/dist/lib/node-esm/index.mjs +124 -129
  64. package/dist/lib/node-esm/index.mjs.map +4 -4
  65. package/dist/lib/node-esm/meta.json +1 -1
  66. package/dist/lib/node-esm/operation-resolver-QAGXDA5E.mjs +54 -0
  67. package/dist/lib/node-esm/operation-resolver-QAGXDA5E.mjs.map +7 -0
  68. package/dist/lib/node-esm/react-surface-VIXAH5CF.mjs +214 -0
  69. package/dist/lib/node-esm/react-surface-VIXAH5CF.mjs.map +7 -0
  70. package/dist/lib/node-esm/settings-EXSH2KF4.mjs +37 -0
  71. package/dist/lib/node-esm/settings-EXSH2KF4.mjs.map +7 -0
  72. package/dist/lib/node-esm/state-TVF2XT2T.mjs +30 -0
  73. package/dist/lib/node-esm/state-TVF2XT2T.mjs.map +7 -0
  74. package/dist/lib/node-esm/types/index.mjs +10 -3
  75. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  76. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  77. package/dist/types/src/blueprints/functions/create.d.ts.map +1 -0
  78. package/dist/types/src/blueprints/functions/create.test.d.ts.map +1 -0
  79. package/dist/types/src/blueprints/functions/index.d.ts +4 -0
  80. package/dist/types/src/blueprints/functions/index.d.ts.map +1 -0
  81. package/dist/types/src/blueprints/functions/open.d.ts +14 -0
  82. package/dist/types/src/blueprints/functions/open.d.ts.map +1 -0
  83. package/dist/types/src/blueprints/functions/update.d.ts +19 -0
  84. package/dist/types/src/blueprints/functions/update.d.ts.map +1 -0
  85. package/dist/types/src/blueprints/functions/update.test.d.ts.map +1 -0
  86. package/dist/types/src/blueprints/index.d.ts +2 -0
  87. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  88. package/dist/types/src/blueprints/markdown-blueprint.d.ts +21 -0
  89. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  90. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +6 -0
  91. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +1 -0
  92. package/dist/types/src/capabilities/anchor-sort/index.d.ts +3 -0
  93. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +1 -0
  94. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +5 -0
  95. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +1 -0
  96. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +3 -0
  97. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +1 -0
  98. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +5 -0
  99. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +1 -0
  100. package/dist/types/src/capabilities/artifact-definition/index.d.ts +3 -0
  101. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +1 -0
  102. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +11 -0
  103. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -0
  104. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +3 -0
  105. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -0
  106. package/dist/types/src/capabilities/index.d.ts +6 -13
  107. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  108. package/dist/types/src/capabilities/operation-resolver/index.d.ts +3 -0
  109. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -0
  110. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +5 -0
  111. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -0
  112. package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
  113. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
  114. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
  115. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
  116. package/dist/types/src/capabilities/settings/index.d.ts +3 -0
  117. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
  118. package/dist/types/src/capabilities/settings/settings.d.ts +7 -0
  119. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
  120. package/dist/types/src/capabilities/state/index.d.ts +3 -0
  121. package/dist/types/src/capabilities/state/index.d.ts.map +1 -0
  122. package/dist/types/src/capabilities/state/state.d.ts +5 -0
  123. package/dist/types/src/capabilities/state/state.d.ts.map +1 -0
  124. package/dist/types/src/cli/index.d.ts +2 -0
  125. package/dist/types/src/cli/index.d.ts.map +1 -0
  126. package/dist/types/src/cli/plugin.d.ts +3 -0
  127. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  128. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +4 -16
  129. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  130. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +5 -5
  131. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  132. package/dist/types/src/components/MarkdownContainer.d.ts +16 -7
  133. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  134. package/dist/types/src/components/MarkdownContainer.stories.d.ts +29 -0
  135. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
  136. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +1 -1
  137. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  138. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +8 -7
  139. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  140. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  141. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +6 -5
  142. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  143. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +3 -3
  144. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  145. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -2
  146. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  147. package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
  148. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  149. package/dist/types/src/hooks/useExtensions.d.ts +3 -3
  150. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  151. package/dist/types/src/hooks/useLinkQuery.d.ts +2 -2
  152. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  153. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  154. package/dist/types/src/index.d.ts +2 -2
  155. package/dist/types/src/index.d.ts.map +1 -1
  156. package/dist/types/src/meta.d.ts +2 -2
  157. package/dist/types/src/meta.d.ts.map +1 -1
  158. package/dist/types/src/translations.d.ts +29 -0
  159. package/dist/types/src/translations.d.ts.map +1 -1
  160. package/dist/types/src/types/Markdown.d.ts +12 -12
  161. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  162. package/dist/types/src/types/MarkdownAction.d.ts +62 -30
  163. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  164. package/dist/types/src/types/capabilities.d.ts +22 -0
  165. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  166. package/dist/types/src/types/events.d.ts +5 -0
  167. package/dist/types/src/types/events.d.ts.map +1 -0
  168. package/dist/types/src/types/index.d.ts +3 -0
  169. package/dist/types/src/types/index.d.ts.map +1 -1
  170. package/dist/types/src/types/types.d.ts +2 -2
  171. package/dist/types/src/types/types.d.ts.map +1 -1
  172. package/dist/types/src/util.d.ts.map +1 -1
  173. package/dist/types/tsconfig.tsbuildinfo +1 -1
  174. package/package.json +88 -66
  175. package/src/MarkdownPlugin.tsx +64 -76
  176. package/src/blueprints/functions/create.conversations.json +1 -0
  177. package/src/blueprints/functions/create.test.ts +92 -0
  178. package/src/{functions → blueprints/functions}/create.ts +4 -3
  179. package/src/blueprints/functions/index.ts +7 -0
  180. package/src/{functions → blueprints/functions}/open.ts +10 -10
  181. package/src/blueprints/functions/update.conversations.json +1 -0
  182. package/src/blueprints/functions/update.test.ts +215 -0
  183. package/src/blueprints/functions/update.ts +79 -0
  184. package/src/blueprints/index.ts +5 -0
  185. package/src/blueprints/markdown-blueprint.ts +38 -0
  186. package/src/capabilities/anchor-sort/anchor-sort.ts +37 -0
  187. package/src/capabilities/anchor-sort/index.ts +7 -0
  188. package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +60 -0
  189. package/src/capabilities/app-graph-serializer/index.ts +7 -0
  190. package/src/capabilities/artifact-definition/artifact-definition.ts +110 -0
  191. package/src/capabilities/artifact-definition/index.ts +7 -0
  192. package/src/capabilities/blueprint-definition/blueprint-definition.ts +26 -0
  193. package/src/capabilities/blueprint-definition/index.ts +7 -0
  194. package/src/capabilities/index.ts +6 -11
  195. package/src/capabilities/operation-resolver/index.ts +7 -0
  196. package/src/capabilities/operation-resolver/operation-resolver.ts +45 -0
  197. package/src/capabilities/react-surface/index.ts +7 -0
  198. package/src/capabilities/react-surface/react-surface.tsx +102 -0
  199. package/src/capabilities/settings/index.ts +7 -0
  200. package/src/capabilities/settings/settings.ts +37 -0
  201. package/src/capabilities/state/index.ts +7 -0
  202. package/src/capabilities/state/state.ts +31 -0
  203. package/src/cli/index.ts +5 -0
  204. package/src/cli/plugin.ts +30 -0
  205. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +26 -44
  206. package/src/components/MarkdownCard/MarkdownCard.tsx +23 -55
  207. package/src/components/MarkdownContainer.stories.tsx +49 -62
  208. package/src/components/MarkdownContainer.tsx +37 -32
  209. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  210. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +17 -18
  211. package/src/components/MarkdownEditor/MarkdownEditor.tsx +26 -21
  212. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +22 -12
  213. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +6 -3
  214. package/src/components/MarkdownSettings/MarkdownSettings.tsx +48 -34
  215. package/src/components/Suggestions.stories.tsx +22 -33
  216. package/src/hooks/useEditorMenuOptions.ts +10 -13
  217. package/src/hooks/useExtensions.tsx +24 -28
  218. package/src/hooks/useLinkQuery.ts +12 -12
  219. package/src/hooks/useSelectCurrentThread.tsx +37 -42
  220. package/src/index.ts +3 -2
  221. package/src/meta.ts +2 -2
  222. package/src/testing.ts +1 -1
  223. package/src/translations.ts +2 -0
  224. package/src/types/Markdown.ts +2 -2
  225. package/src/types/MarkdownAction.ts +48 -18
  226. package/src/types/capabilities.ts +38 -0
  227. package/src/types/events.ts +14 -0
  228. package/src/types/index.ts +3 -0
  229. package/src/types/types.ts +3 -2
  230. package/src/util.tsx +3 -1
  231. package/dist/lib/browser/MarkdownCard-THZFDOOV.mjs +0 -13
  232. package/dist/lib/browser/MarkdownContainer-VKPSVI5F.mjs +0 -16
  233. package/dist/lib/browser/anchor-sort-3MYLO74J.mjs.map +0 -7
  234. package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs +0 -51
  235. package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs.map +0 -7
  236. package/dist/lib/browser/blueprint-definition-R5T6LTPN.mjs +0 -13
  237. package/dist/lib/browser/chunk-56SUMOIZ.mjs +0 -734
  238. package/dist/lib/browser/chunk-56SUMOIZ.mjs.map +0 -7
  239. package/dist/lib/browser/chunk-6OMOMVO7.mjs +0 -107
  240. package/dist/lib/browser/chunk-6OMOMVO7.mjs.map +0 -7
  241. package/dist/lib/browser/chunk-BQTYJOFB.mjs +0 -28
  242. package/dist/lib/browser/chunk-BQTYJOFB.mjs.map +0 -7
  243. package/dist/lib/browser/chunk-CN35HEBX.mjs +0 -79
  244. package/dist/lib/browser/chunk-CN35HEBX.mjs.map +0 -7
  245. package/dist/lib/browser/chunk-IBCHVMZW.mjs +0 -16
  246. package/dist/lib/browser/chunk-IBCHVMZW.mjs.map +0 -7
  247. package/dist/lib/browser/chunk-KCOBZZIL.mjs +0 -111
  248. package/dist/lib/browser/chunk-KCOBZZIL.mjs.map +0 -7
  249. package/dist/lib/browser/chunk-KPH4ZPQN.mjs +0 -99
  250. package/dist/lib/browser/chunk-KPH4ZPQN.mjs.map +0 -7
  251. package/dist/lib/browser/chunk-NXT2E2BG.mjs.map +0 -7
  252. package/dist/lib/browser/chunk-RJPOHSYN.mjs +0 -152
  253. package/dist/lib/browser/chunk-RJPOHSYN.mjs.map +0 -7
  254. package/dist/lib/browser/chunk-U6Y53XZK.mjs +0 -20
  255. package/dist/lib/browser/chunk-U6Y53XZK.mjs.map +0 -7
  256. package/dist/lib/browser/intent-resolver-55ASQRIW.mjs +0 -62
  257. package/dist/lib/browser/intent-resolver-55ASQRIW.mjs.map +0 -7
  258. package/dist/lib/browser/react-surface-Q3C5H2KT.mjs +0 -215
  259. package/dist/lib/browser/react-surface-Q3C5H2KT.mjs.map +0 -7
  260. package/dist/lib/browser/settings-G3ZOXJQY.mjs +0 -28
  261. package/dist/lib/browser/settings-G3ZOXJQY.mjs.map +0 -7
  262. package/dist/lib/browser/state-BTUKVZHY.mjs +0 -37
  263. package/dist/lib/browser/state-BTUKVZHY.mjs.map +0 -7
  264. package/dist/lib/browser/toolkit.mjs +0 -13
  265. package/dist/lib/node-esm/MarkdownCard-QHSSZGIY.mjs +0 -14
  266. package/dist/lib/node-esm/MarkdownContainer-G3ZQJS7A.mjs +0 -17
  267. package/dist/lib/node-esm/anchor-sort-W4HCTYUQ.mjs.map +0 -7
  268. package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs +0 -52
  269. package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs.map +0 -7
  270. package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs +0 -14
  271. package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs.map +0 -7
  272. package/dist/lib/node-esm/chunk-6F6FCTIA.mjs +0 -100
  273. package/dist/lib/node-esm/chunk-6F6FCTIA.mjs.map +0 -7
  274. package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs +0 -153
  275. package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs.map +0 -7
  276. package/dist/lib/node-esm/chunk-FR6RW6DH.mjs +0 -735
  277. package/dist/lib/node-esm/chunk-FR6RW6DH.mjs.map +0 -7
  278. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs +0 -17
  279. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs.map +0 -7
  280. package/dist/lib/node-esm/chunk-I5JSQBPI.mjs.map +0 -7
  281. package/dist/lib/node-esm/chunk-KM7KYV6W.mjs +0 -22
  282. package/dist/lib/node-esm/chunk-KM7KYV6W.mjs.map +0 -7
  283. package/dist/lib/node-esm/chunk-KYWXTMKI.mjs +0 -108
  284. package/dist/lib/node-esm/chunk-KYWXTMKI.mjs.map +0 -7
  285. package/dist/lib/node-esm/chunk-R3SGV4ES.mjs +0 -112
  286. package/dist/lib/node-esm/chunk-R3SGV4ES.mjs.map +0 -7
  287. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs +0 -29
  288. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-YFRTKXTB.mjs +0 -80
  290. package/dist/lib/node-esm/chunk-YFRTKXTB.mjs.map +0 -7
  291. package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs +0 -63
  292. package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs.map +0 -7
  293. package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs +0 -216
  294. package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs.map +0 -7
  295. package/dist/lib/node-esm/settings-IBFFCGNL.mjs +0 -29
  296. package/dist/lib/node-esm/settings-IBFFCGNL.mjs.map +0 -7
  297. package/dist/lib/node-esm/state-K6EH7SRZ.mjs +0 -38
  298. package/dist/lib/node-esm/state-K6EH7SRZ.mjs.map +0 -7
  299. package/dist/lib/node-esm/toolkit.mjs +0 -14
  300. package/dist/lib/node-esm/toolkit.mjs.map +0 -7
  301. package/dist/types/src/capabilities/anchor-sort.d.ts +0 -4
  302. package/dist/types/src/capabilities/anchor-sort.d.ts.map +0 -1
  303. package/dist/types/src/capabilities/app-graph-serializer.d.ts +0 -4
  304. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +0 -1
  305. package/dist/types/src/capabilities/artifact-definition.d.ts +0 -3
  306. package/dist/types/src/capabilities/artifact-definition.d.ts.map +0 -1
  307. package/dist/types/src/capabilities/blueprint-definition.d.ts +0 -7
  308. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +0 -1
  309. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  310. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  311. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  312. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/react-surface.d.ts +0 -4
  314. package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/settings.d.ts +0 -4
  316. package/dist/types/src/capabilities/settings.d.ts.map +0 -1
  317. package/dist/types/src/capabilities/state.d.ts +0 -11
  318. package/dist/types/src/capabilities/state.d.ts.map +0 -1
  319. package/dist/types/src/events.d.ts +0 -4
  320. package/dist/types/src/events.d.ts.map +0 -1
  321. package/dist/types/src/functions/create.d.ts.map +0 -1
  322. package/dist/types/src/functions/create.test.d.ts.map +0 -1
  323. package/dist/types/src/functions/index.d.ts +0 -18
  324. package/dist/types/src/functions/index.d.ts.map +0 -1
  325. package/dist/types/src/functions/open.d.ts +0 -7
  326. package/dist/types/src/functions/open.d.ts.map +0 -1
  327. package/dist/types/src/functions/update.d.ts +0 -6
  328. package/dist/types/src/functions/update.d.ts.map +0 -1
  329. package/dist/types/src/functions/update.test.d.ts.map +0 -1
  330. package/dist/types/src/toolkit.d.ts +0 -3
  331. package/dist/types/src/toolkit.d.ts.map +0 -1
  332. package/src/capabilities/anchor-sort.ts +0 -31
  333. package/src/capabilities/app-graph-serializer.ts +0 -54
  334. package/src/capabilities/artifact-definition.ts +0 -112
  335. package/src/capabilities/blueprint-definition.ts +0 -43
  336. package/src/capabilities/capabilities.ts +0 -22
  337. package/src/capabilities/intent-resolver.ts +0 -58
  338. package/src/capabilities/react-surface.tsx +0 -97
  339. package/src/capabilities/settings.ts +0 -25
  340. package/src/capabilities/state.ts +0 -31
  341. package/src/events.ts +0 -11
  342. package/src/functions/create.conversations.json +0 -1
  343. package/src/functions/create.test.ts +0 -124
  344. package/src/functions/index.ts +0 -13
  345. package/src/functions/update.conversations.json +0 -1
  346. package/src/functions/update.test.ts +0 -147
  347. package/src/functions/update.ts +0 -38
  348. package/src/toolkit.ts +0 -6
  349. /package/dist/lib/browser/{MarkdownCard-THZFDOOV.mjs.map → MarkdownCard-7VIO7R66.mjs.map} +0 -0
  350. /package/dist/lib/browser/{MarkdownContainer-VKPSVI5F.mjs.map → MarkdownContainer-6E43EDAU.mjs.map} +0 -0
  351. /package/dist/lib/browser/{blueprint-definition-R5T6LTPN.mjs.map → blueprints/index.mjs.map} +0 -0
  352. /package/dist/lib/{browser/toolkit.mjs.map → node-esm/MarkdownCard-YC3R2TQW.mjs.map} +0 -0
  353. /package/dist/lib/node-esm/{MarkdownCard-QHSSZGIY.mjs.map → MarkdownContainer-TTRUOXU6.mjs.map} +0 -0
  354. /package/dist/lib/node-esm/{MarkdownContainer-G3ZQJS7A.mjs.map → blueprints/index.mjs.map} +0 -0
  355. /package/dist/types/src/{functions → blueprints/functions}/create.d.ts +0 -0
  356. /package/dist/types/src/{functions → blueprints/functions}/create.test.d.ts +0 -0
  357. /package/dist/types/src/{functions → blueprints/functions}/update.test.d.ts +0 -0
@@ -1,735 +0,0 @@
1
- import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- setFallbackName
4
- } from "./chunk-6F6FCTIA.mjs";
5
- import {
6
- Markdown_exports
7
- } from "./chunk-YFRTKXTB.mjs";
8
- import {
9
- meta
10
- } from "./chunk-SHAMSMKQ.mjs";
11
-
12
- // src/hooks/useLinkQuery.ts
13
- import * as Option from "effect/Option";
14
- import { useCallback, useMemo } from "react";
15
- import { Capabilities } from "@dxos/app-framework";
16
- import { usePluginManager } from "@dxos/app-framework/react";
17
- import { Filter, Obj, Query, Type } from "@dxos/echo";
18
- import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from "@dxos/echo/internal";
19
- import { toLocalizedString, useTranslation } from "@dxos/react-ui";
20
- import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
21
- var useLinkQuery = (space) => {
22
- const { t } = useTranslation();
23
- const manager = usePluginManager();
24
- const resolve = useCallback((typename) => manager.context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {}, [
25
- manager
26
- ]);
27
- const filter = useMemo(() => Filter.or(...(space?.db.schemaRegistry.query({
28
- location: [
29
- "database",
30
- "runtime"
31
- ]
32
- }).runSync() ?? []).filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation).filter((schema) => !SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false))).map((schema) => Filter.typename(Type.getTypename(schema)))), [
33
- space
34
- ]);
35
- const handleLinkQuery = useCallback(async (query) => {
36
- const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
37
- const results = await space?.db.query(Query.select(filter)).run();
38
- const getLabel = (object) => {
39
- const label = Obj.getLabel(object);
40
- if (label) {
41
- return label;
42
- }
43
- const type = Obj.getTypename(object);
44
- const metadata = resolve(type);
45
- return metadata.label?.(object) || [
46
- "object name placeholder",
47
- {
48
- ns: type,
49
- default: "New object"
50
- }
51
- ];
52
- };
53
- const items = results?.filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name)).map((object) => {
54
- const metadata = resolve(Obj.getTypename(object));
55
- const label = toLocalizedString(getLabel(object), t);
56
- return {
57
- id: object.id,
58
- label,
59
- icon: metadata.icon,
60
- onSelect: ({ view, head }) => {
61
- const link = `[${label}](${Obj.getDXN(object)})`;
62
- if (query?.startsWith("@")) {
63
- insertAtLineStart(view, head, `!${link}
64
- `);
65
- } else {
66
- insertAtCursor(view, head, `${link} `);
67
- }
68
- }
69
- };
70
- }) ?? [];
71
- return [
72
- {
73
- id: "echo",
74
- items
75
- }
76
- ];
77
- }, [
78
- space,
79
- filter,
80
- resolve
81
- ]);
82
- return handleLinkQuery;
83
- };
84
-
85
- // src/hooks/useEditorMenuOptions.ts
86
- import { useCallback as useCallback2, useMemo as useMemo2, useRef } from "react";
87
- import { Domino, toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
88
- import { filterMenuGroups, formattingCommands, linkSlashCommands } from "@dxos/react-ui-editor";
89
- var useEditorMenuOptions = ({ editorView, slashCommandGroups, onLinkQuery }) => {
90
- const { t } = useTranslation2(meta.id);
91
- const getMenu = useCallback2(({ text, trigger }) => {
92
- switch (trigger) {
93
- case "@": {
94
- return onLinkQuery?.(text) ?? [];
95
- }
96
- case "/":
97
- default: {
98
- return filterMenuGroups([
99
- formattingCommands,
100
- linkSlashCommands,
101
- ...slashCommandGroups ?? []
102
- ], (item) => text ? toLocalizedString2(item.label, t).toLowerCase().includes(text.toLowerCase()) : true);
103
- }
104
- }
105
- }, [
106
- slashCommandGroups,
107
- onLinkQuery
108
- ]);
109
- const viewRef = useRef(editorView);
110
- return useMemo2(() => {
111
- const trigger = onLinkQuery ? [
112
- "/",
113
- "@"
114
- ] : [
115
- "/"
116
- ];
117
- const placeholder = {
118
- delay: 3e3,
119
- content: () => Domino.of("div").children(Domino.of("span").text("Press"), ...trigger.map((text) => Domino.of("span").classNames("mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm").text(text)), Domino.of("span").text("for commands.")).build()
120
- };
121
- return {
122
- viewRef,
123
- getMenu,
124
- trigger,
125
- placeholder
126
- };
127
- }, [
128
- getMenu,
129
- onLinkQuery
130
- ]);
131
- };
132
-
133
- // src/hooks/useExtensions.tsx
134
- import React, { useMemo as useMemo3 } from "react";
135
- import { createRoot } from "react-dom/client";
136
- import { LayoutAction, createIntent } from "@dxos/app-framework";
137
- import { useIntentDispatcher } from "@dxos/app-framework/react";
138
- import { debounceAndThrottle } from "@dxos/async";
139
- import { Obj as Obj2 } from "@dxos/echo";
140
- import { createDocAccessor } from "@dxos/echo-db";
141
- import { invariant } from "@dxos/invariant";
142
- import { getSpace } from "@dxos/react-client/echo";
143
- import { useIdentity } from "@dxos/react-client/halo";
144
- import { Icon, ThemeProvider } from "@dxos/react-ui";
145
- import { Cursor, EditorView, InputModeExtensions, createDataExtensions, decorateMarkdown, documentId, folding, formattingKeymap, linkTooltip, listener, preview, replacer, selectionState, typewriter } from "@dxos/react-ui-editor";
146
- import { defaultTx } from "@dxos/react-ui-theme";
147
- import { Text } from "@dxos/schema";
148
- import { isTruthy } from "@dxos/util";
149
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useExtensions.tsx";
150
- var useExtensions = ({ id, object, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
151
- const { dispatchPromise: dispatch } = useIntentDispatcher();
152
- const identity = useIdentity();
153
- const space = getSpace(object);
154
- let target;
155
- if (Obj2.instanceOf(Markdown_exports.Document, object)) {
156
- target = object.content.target;
157
- } else if (Obj2.instanceOf(Text.Text, object)) {
158
- target = object;
159
- }
160
- const baseExtensions = useMemo3(() => createBaseExtensions({
161
- id,
162
- object,
163
- settings,
164
- selectionManager,
165
- viewMode,
166
- previewOptions,
167
- dispatch
168
- }), [
169
- id,
170
- object,
171
- viewMode,
172
- dispatch,
173
- previewOptions,
174
- settings,
175
- settings?.debug,
176
- settings?.editorInputMode,
177
- settings?.folding,
178
- settings?.numberedHeadings,
179
- settings?.typewriter,
180
- selectionManager
181
- ]);
182
- return useMemo3(() => [
183
- // TODO(burdon): Pass this in?
184
- // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.
185
- target && createDataExtensions({
186
- id,
187
- text: createDocAccessor(target, [
188
- "content"
189
- ]),
190
- messenger: space,
191
- identity
192
- }),
193
- // TODO(burdon): Reconcile with effect in parent.
194
- Obj2.instanceOf(Markdown_exports.Document, object) && listener({
195
- onChange: ({ text }) => {
196
- setFallbackName(object, text);
197
- }
198
- }),
199
- baseExtensions,
200
- selectionState(editorStateStore)
201
- ].filter(isTruthy), [
202
- identity,
203
- space,
204
- id,
205
- object,
206
- target,
207
- baseExtensions
208
- ]);
209
- };
210
- var createBaseExtensions = ({ id, object, dispatch, settings, selectionManager, viewMode, previewOptions }) => {
211
- const extensions = [
212
- selectionManager && selectionChange(selectionManager),
213
- settings?.editorInputMode && InputModeExtensions[settings.editorInputMode],
214
- settings?.folding && folding()
215
- ].filter(isTruthy);
216
- if (viewMode !== "source") {
217
- extensions.push(...[
218
- formattingKeymap(),
219
- decorateMarkdown({
220
- selectionChangeDelay: 100,
221
- numberedHeadings: settings?.numberedHeadings ? {
222
- from: 2
223
- } : void 0,
224
- // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
225
- // TODO(burdon): Create dx-tag.
226
- renderLinkButton: dispatch && (object || id) ? createLinkRenderer((id2) => {
227
- void dispatch(createIntent(LayoutAction.Open, {
228
- part: "main",
229
- subject: [
230
- id2
231
- ],
232
- options: {
233
- pivotId: object && Obj2.isObject(object) ? Obj2.getDXN(object).toString() : id2
234
- }
235
- }));
236
- }) : void 0
237
- }),
238
- linkTooltip(renderLinkTooltip),
239
- preview(previewOptions),
240
- replacer()
241
- ]);
242
- }
243
- if (settings?.debug) {
244
- const items = settings.typewriter?.split(/[,\n]/) ?? "";
245
- if (items) {
246
- extensions.push(typewriter({
247
- items
248
- }));
249
- }
250
- }
251
- return extensions;
252
- };
253
- var selectionChange = (selectionManager) => {
254
- return EditorView.updateListener.of(debounceAndThrottle((update) => {
255
- if (update.selectionSet) {
256
- const id = update.state.facet(documentId);
257
- const cursorConverter = update.state.facet(Cursor.converter);
258
- const selection = update.state.selection;
259
- const ranges = selection.ranges.map((range) => ({
260
- from: cursorConverter.toCursor(range.from),
261
- to: cursorConverter.toCursor(range.to)
262
- })).filter(({ from, to }) => to > from);
263
- selectionManager.updateMultiRange(id, ranges);
264
- }
265
- }, 100));
266
- };
267
- var style = {
268
- hover: "rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400",
269
- icon: "inline-block leading-none mis-1 cursor-pointer"
270
- };
271
- var createLinkRenderer = (onSelectObject) => (el, { url }) => {
272
- const isInternal = url.startsWith("/") || // TODO(wittjosiah): This should probably be parsed out on paste?
273
- url.startsWith(window.location.origin);
274
- const options = isInternal ? {
275
- onClick: () => {
276
- const qualifiedId = url.split("/").at(-1);
277
- invariant(qualifiedId, "Invalid link format.", {
278
- F: __dxlog_file,
279
- L: 242,
280
- S: void 0,
281
- A: [
282
- "qualifiedId",
283
- "'Invalid link format.'"
284
- ]
285
- });
286
- onSelectObject(qualifiedId);
287
- }
288
- } : {
289
- href: url,
290
- rel: "noreferrer",
291
- target: "_blank"
292
- };
293
- renderRoot(el, /* @__PURE__ */ React.createElement("a", {
294
- ...options,
295
- className: style.hover
296
- }, /* @__PURE__ */ React.createElement(Icon, {
297
- icon: isInternal ? "ph--arrow-square-down--bold" : "ph--arrow-square-out--bold",
298
- size: 4,
299
- classNames: style.icon
300
- })));
301
- };
302
- var renderLinkTooltip = (el, { url }) => {
303
- const web = new URL(url);
304
- renderRoot(el, /* @__PURE__ */ React.createElement("a", {
305
- href: url,
306
- rel: "noreferrer",
307
- target: "_blank",
308
- className: style.hover
309
- }, web.origin, /* @__PURE__ */ React.createElement(Icon, {
310
- icon: "ph--arrow-square-out--bold",
311
- size: 4,
312
- classNames: style.icon
313
- })));
314
- };
315
- var renderRoot = (root, node) => {
316
- createRoot(root).render(/* @__PURE__ */ React.createElement(ThemeProvider, {
317
- tx: defaultTx
318
- }, node));
319
- return root;
320
- };
321
-
322
- // src/hooks/useSelectCurrentThread.tsx
323
- import { EditorView as EditorView2 } from "@codemirror/view";
324
- import * as Schema from "effect/Schema";
325
- import { useMemo as useMemo4 } from "react";
326
- import { LayoutAction as LayoutAction2, createResolver } from "@dxos/app-framework";
327
- import { useIntentResolver } from "@dxos/app-framework/react";
328
- import { invariant as invariant2 } from "@dxos/invariant";
329
- import { Cursor as Cursor2, setSelection } from "@dxos/react-ui-editor";
330
- var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useSelectCurrentThread.tsx";
331
- var useSelectCurrentThread = (editorView, documentId2) => {
332
- const scrollIntoViewResolver = useMemo4(() => createResolver({
333
- intent: LayoutAction2.UpdateLayout,
334
- position: "hoist",
335
- filter: (data) => {
336
- if (!Schema.is(LayoutAction2.ScrollIntoView.fields.input)(data)) {
337
- return false;
338
- }
339
- return !!editorView && data.subject === documentId2 && !!data.options?.cursor;
340
- },
341
- resolve: ({ options: { cursor } }) => {
342
- invariant2(editorView, "Editor view is not defined.", {
343
- F: __dxlog_file2,
344
- L: 39,
345
- S: void 0,
346
- A: [
347
- "editorView",
348
- "'Editor view is not defined.'"
349
- ]
350
- });
351
- const range = Cursor2.getRangeFromCursor(editorView.state, cursor);
352
- if (range) {
353
- const selection = editorView.state.selection.main.from !== range.from ? {
354
- anchor: range.from
355
- } : void 0;
356
- const effects = [
357
- // NOTE: This does not use the DOM scrollIntoView function.
358
- EditorView2.scrollIntoView(range.from, {
359
- y: "start",
360
- yMargin: 96
361
- })
362
- ];
363
- if (selection) {
364
- effects.push(setSelection.of({
365
- current: documentId2
366
- }));
367
- }
368
- editorView.dispatch({
369
- effects,
370
- selection: selection ? {
371
- anchor: range.from
372
- } : void 0
373
- });
374
- }
375
- }
376
- }), [
377
- documentId2,
378
- editorView
379
- ]);
380
- useIntentResolver(meta.id, scrollIntoViewResolver);
381
- };
382
-
383
- // src/components/MarkdownEditor/MarkdownEditor.tsx
384
- import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
385
- import { createContext } from "@radix-ui/react-context";
386
- import React5, { useMemo as useMemo6, useState as useState2 } from "react";
387
- import { createPortal as createPortal2 } from "react-dom";
388
- import { Surface } from "@dxos/app-framework/react";
389
- import { DXN } from "@dxos/keys";
390
- import { useClient } from "@dxos/react-client";
391
- import { EditorMenuProvider, useEditorMenu, useEditorToolbar } from "@dxos/react-ui-editor";
392
- import { isNonNullable } from "@dxos/util";
393
-
394
- // src/components/MarkdownEditor/MarkdownEditorContent.tsx
395
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
396
- import React2, { forwardRef, useEffect, useImperativeHandle, useMemo as useMemo5 } from "react";
397
- import { useDynamicRef, useThemeContext, useTranslation as useTranslation3 } from "@dxos/react-ui";
398
- import { createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorSlots, formattingListener, processEditorPayload, stackItemContentEditorClassNames, useTextEditor } from "@dxos/react-ui-editor";
399
- import { mx } from "@dxos/react-ui-theme";
400
- import { isTruthy as isTruthy2 } from "@dxos/util";
401
- var MarkdownEditorContent = /* @__PURE__ */ forwardRef(({ classNames, id, role, viewMode, initialValue, editorStateStore, toolbarState, extensions, scrollPastEnd, slots = editorSlots, onFileUpload }, forwardedRef) => {
402
- var _effect = _useSignals();
403
- try {
404
- const { t } = useTranslation3(meta.id);
405
- const { themeMode } = useThemeContext();
406
- const toolbarStateRef = useDynamicRef(toolbarState);
407
- const { scrollTo, selection } = useMemo5(() => editorStateStore?.getState(id) ?? {}, [
408
- id
409
- ]);
410
- const { parentRef, view: editorView, focusAttributes } = useTextEditor(() => ({
411
- ...role !== "section" && {
412
- id,
413
- scrollTo,
414
- selection,
415
- // TODO(wittjosiah): Autofocus based on layout is racy.
416
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
417
- selectionEnd: true
418
- },
419
- initialValue,
420
- extensions: [
421
- createBasicExtensions({
422
- readOnly: viewMode === "readonly",
423
- placeholder: t("editor placeholder"),
424
- scrollPastEnd: scrollPastEnd && role !== "section",
425
- search: true
426
- }),
427
- createThemeExtensions({
428
- themeMode,
429
- slots,
430
- syntaxHighlighting: true
431
- }),
432
- createMarkdownExtensions(),
433
- formattingListener(() => toolbarStateRef.current),
434
- role !== "section" && onFileUpload && dropFile({
435
- // TODO(wittjosiah): Factor out to file uploader plugin.
436
- onDrop: async (view, { files }) => {
437
- const file = files[0];
438
- const info = file && onFileUpload ? await onFileUpload(file) : void 0;
439
- if (info) {
440
- processEditorPayload(view, {
441
- type: "image",
442
- data: info.url
443
- });
444
- }
445
- }
446
- }),
447
- extensions
448
- ].filter(isTruthy2)
449
- }), [
450
- id,
451
- viewMode,
452
- themeMode,
453
- extensions
454
- ]);
455
- useImperativeHandle(forwardedRef, () => editorView, [
456
- editorView
457
- ]);
458
- useSelectCurrentThread(editorView, id);
459
- useTest(editorView);
460
- return /* @__PURE__ */ React2.createElement("div", {
461
- role: "none",
462
- ref: parentRef,
463
- "data-testid": "composer.markdownRoot",
464
- className: mx(stackItemContentEditorClassNames(role), classNames),
465
- "data-popover-collision-boundary": true,
466
- ...focusAttributes
467
- });
468
- } finally {
469
- _effect.f();
470
- }
471
- });
472
- var useTest = (view) => {
473
- useEffect(() => {
474
- const composer = window.composer;
475
- if (composer) {
476
- composer.editorView = view;
477
- }
478
- }, [
479
- view
480
- ]);
481
- };
482
-
483
- // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
484
- import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
485
- import React4, { useCallback as useCallback3, useState } from "react";
486
- import { invariant as invariant3 } from "@dxos/invariant";
487
- import { EditorToolbar } from "@dxos/react-ui-editor";
488
-
489
- // src/components/MarkdownEditor/FileUpload.tsx
490
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
491
- import React3, { forwardRef as forwardRef2, useEffect as useEffect2, useImperativeHandle as useImperativeHandle2 } from "react";
492
- import { createPortal } from "react-dom";
493
- import { useDropzone } from "react-dropzone";
494
- import { addLink } from "@dxos/react-ui-editor";
495
- var IMAGE_FILES = [
496
- ".jpg",
497
- ".jpeg",
498
- ".png",
499
- ".gif"
500
- ];
501
- var FileUpload = /* @__PURE__ */ forwardRef2(({ editorView, onFileUpload }, forwardedRef) => {
502
- var _effect = _useSignals2();
503
- try {
504
- const { acceptedFiles, open, inputRef } = useDropzone({
505
- disabled: !onFileUpload,
506
- multiple: false,
507
- noDrag: true,
508
- accept: {
509
- "image/*": IMAGE_FILES
510
- }
511
- });
512
- useImperativeHandle2(forwardedRef, () => open, []);
513
- useEffect2(() => {
514
- if (editorView && acceptedFiles.length && onFileUpload) {
515
- requestAnimationFrame(async () => {
516
- const f = acceptedFiles[0];
517
- const file = new File([
518
- f
519
- ], f.name, {
520
- type: f.type,
521
- lastModified: f.lastModified
522
- });
523
- const info = await onFileUpload(file);
524
- if (info) {
525
- addLink({
526
- url: info.url,
527
- image: true
528
- })(editorView);
529
- }
530
- });
531
- }
532
- }, [
533
- editorView,
534
- acceptedFiles,
535
- onFileUpload
536
- ]);
537
- if (!onFileUpload) {
538
- return null;
539
- }
540
- return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ createPortal(/* @__PURE__ */ React3.createElement("input", {
541
- ref: inputRef
542
- }), document.body), " ");
543
- } finally {
544
- _effect.f();
545
- }
546
- });
547
-
548
- // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
549
- var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx";
550
- var MarkdownEditorToolbar = ({ classNames, id, role, state, editorView, customActions, onFileUpload, onViewModeChange }) => {
551
- var _effect = _useSignals3();
552
- try {
553
- const [upload, setUpload] = useState(null);
554
- const uploadRef = useCallback3((next) => setUpload(() => next), []);
555
- const handleViewModeChange = useCallback3((mode) => onViewModeChange?.(mode), [
556
- onViewModeChange
557
- ]);
558
- const getView = useCallback3(() => {
559
- invariant3(editorView, void 0, {
560
- F: __dxlog_file3,
561
- L: 39,
562
- S: void 0,
563
- A: [
564
- "editorView",
565
- ""
566
- ]
567
- });
568
- return editorView;
569
- }, [
570
- editorView
571
- ]);
572
- if (!editorView) {
573
- return /* @__PURE__ */ React4.createElement("div", null);
574
- }
575
- return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(EditorToolbar, {
576
- classNames,
577
- attendableId: id,
578
- role,
579
- state,
580
- customActions,
581
- getView,
582
- onImageUpload: upload ?? void 0,
583
- onViewModeChange: handleViewModeChange
584
- }), onFileUpload && /* @__PURE__ */ React4.createElement(FileUpload, {
585
- ref: uploadRef,
586
- editorView,
587
- onFileUpload
588
- }));
589
- } finally {
590
- _effect.f();
591
- }
592
- };
593
-
594
- // src/components/MarkdownEditor/MarkdownEditor.tsx
595
- var [MarkdownEditorContextProvider, useMarkdownEditorContext] = createContext("MarkdownEditor.Context");
596
- var MarkdownEditorRoot = ({ children, id, object, editorStateStore, selectionManager, settings, viewMode, extensions: extensionsParam, slashCommandGroups, onLinkQuery, ...props }) => {
597
- var _effect = _useSignals4();
598
- try {
599
- const [editorView, setEditorView] = useState2();
600
- const [previewBlocks, setPreviewBlocks] = useState2([]);
601
- const previewOptions = useMemo6(() => ({
602
- addBlockContainer: (block) => {
603
- setPreviewBlocks((prev) => [
604
- ...prev,
605
- block
606
- ]);
607
- },
608
- removeBlockContainer: ({ link }) => {
609
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
610
- }
611
- }), []);
612
- const toolbarState = useEditorToolbar({
613
- viewMode
614
- });
615
- const menuOptions = useEditorMenuOptions({
616
- editorView,
617
- slashCommandGroups,
618
- onLinkQuery
619
- });
620
- const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
621
- const coreExtensions = useExtensions({
622
- id,
623
- object,
624
- editorStateStore,
625
- previewOptions,
626
- selectionManager,
627
- settings,
628
- viewMode
629
- });
630
- const extensions = useMemo6(() => [
631
- coreExtensions,
632
- menuExtension,
633
- extensionsParam
634
- ].filter(isNonNullable), [
635
- coreExtensions,
636
- menuExtension,
637
- extensionsParam
638
- ]);
639
- return /* @__PURE__ */ React5.createElement(MarkdownEditorContextProvider, {
640
- id,
641
- editorView,
642
- setEditorView,
643
- extensions,
644
- previewBlocks,
645
- toolbarState,
646
- popoverMenu: menuProps,
647
- viewMode,
648
- ...props
649
- }, children);
650
- } finally {
651
- _effect.f();
652
- }
653
- };
654
- MarkdownEditorRoot.displayName = "MarkdownEditor.Root";
655
- var MarkdownEditorContent2 = (props) => {
656
- var _effect = _useSignals4();
657
- try {
658
- const { id, editorView, setEditorView, viewMode, toolbarState, extensions, popoverMenu: { groupsRef, ...menuProps } } = useMarkdownEditorContext(MarkdownEditorContent2.displayName);
659
- return /* @__PURE__ */ React5.createElement(EditorMenuProvider, {
660
- view: editorView,
661
- groups: groupsRef.current,
662
- ...menuProps
663
- }, /* @__PURE__ */ React5.createElement(MarkdownEditorContent, {
664
- ...props,
665
- id,
666
- viewMode,
667
- toolbarState,
668
- extensions,
669
- ref: setEditorView
670
- }));
671
- } finally {
672
- _effect.f();
673
- }
674
- };
675
- MarkdownEditorContent2.displayName = "MarkdownEditor.Content";
676
- var MarkdownEditorToolbar2 = (props) => {
677
- var _effect = _useSignals4();
678
- try {
679
- const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar2.displayName);
680
- return /* @__PURE__ */ React5.createElement(MarkdownEditorToolbar, {
681
- ...props,
682
- ...rootProps,
683
- state: toolbarState
684
- });
685
- } finally {
686
- _effect.f();
687
- }
688
- };
689
- MarkdownEditorToolbar2.displayName = "MarkdownEditor.Toolbar";
690
- var MarkdownEditorBlocks = (_props) => {
691
- var _effect = _useSignals4();
692
- try {
693
- const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);
694
- return /* @__PURE__ */ React5.createElement(React5.Fragment, null, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React5.createElement(PreviewBlock, {
695
- key: link.ref,
696
- link,
697
- el
698
- })));
699
- } finally {
700
- _effect.f();
701
- }
702
- };
703
- MarkdownEditorBlocks.displayName = "MarkdownEditor.Blocks";
704
- var PreviewBlock = ({ el, link }) => {
705
- var _effect = _useSignals4();
706
- try {
707
- const client = useClient();
708
- const dxn = DXN.parse(link.ref);
709
- const subject = client.graph.makeRef(dxn).target;
710
- const data = useMemo6(() => ({
711
- subject
712
- }), [
713
- subject
714
- ]);
715
- return /* @__PURE__ */ createPortal2(/* @__PURE__ */ React5.createElement(Surface, {
716
- role: "card--transclusion",
717
- data,
718
- limit: 1
719
- }), el);
720
- } finally {
721
- _effect.f();
722
- }
723
- };
724
- var MarkdownEditor = {
725
- Root: MarkdownEditorRoot,
726
- Content: MarkdownEditorContent2,
727
- Toolbar: MarkdownEditorToolbar2,
728
- Blocks: MarkdownEditorBlocks
729
- };
730
-
731
- export {
732
- useLinkQuery,
733
- MarkdownEditor
734
- };
735
- //# sourceMappingURL=chunk-FR6RW6DH.mjs.map