@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,735 @@
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