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

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