@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
@@ -2,43 +2,75 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
- import { type Meta } from '@storybook/react-vite';
8
- import React, { useMemo } from 'react';
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
9
7
 
10
8
  import { IntentPlugin } from '@dxos/app-framework';
11
9
  import { withPluginManager } from '@dxos/app-framework/testing';
12
- import { createDocAccessor, createObject } from '@dxos/react-client/echo';
13
- import { withAttention } from '@dxos/react-ui-attention/testing';
14
- import { automerge, translations as editorTranslations } from '@dxos/react-ui-editor';
15
- import { withLayout, withTheme } from '@dxos/storybook-utils';
10
+ import { Filter, Obj } from '@dxos/echo';
11
+ import { AttentionPlugin } from '@dxos/plugin-attention';
12
+ import { ClientPlugin } from '@dxos/plugin-client';
13
+ import { useQuery, useSpace } from '@dxos/react-client/echo';
14
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
15
+ import { useAttentionAttributes } from '@dxos/react-ui-attention';
16
+ import { translations as editorTranslations } from '@dxos/react-ui-editor';
17
+ import { StackItem } from '@dxos/react-ui-stack';
16
18
 
17
- import { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';
18
19
  import { translations } from '../../translations';
20
+ import { Markdown } from '../../types';
21
+
22
+ import { MarkdownEditor, type MarkdownEditorRootProps } from './MarkdownEditor';
19
23
 
20
24
  const content = Array.from({ length: 100 }, (_, i) => `Line ${i + 1}`).join('\n');
21
25
 
22
- type StoryProps = MarkdownEditorProps & {
23
- content?: string;
24
- toolbar?: boolean;
25
- };
26
+ type StoryProps = Omit<MarkdownEditorRootProps, 'id' | 'extensions'>;
27
+
28
+ const DefaultStory = (props: StoryProps) => {
29
+ const space = useSpace();
30
+ const [doc] = useQuery(space?.db, Filter.type(Markdown.Document));
31
+ const id = doc && Obj.getDXN(doc).toString();
32
+ const attentionAttrs = useAttentionAttributes(id);
33
+
34
+ if (!id) {
35
+ return null;
36
+ }
26
37
 
27
- const DefaultStory = ({ content = '# Test', toolbar }: StoryProps) => {
28
- const doc = useMemo(() => createObject({ content }), [content]); // TODO(burdon): Remove dependency on createObject.
29
- const extensions = useMemo(() => [automerge(createDocAccessor(doc, ['content']))], [doc]);
30
- return <MarkdownEditor id='test' initialValue={doc.content} extensions={extensions} toolbar={toolbar} />;
38
+ return (
39
+ <div className='contents' {...attentionAttrs}>
40
+ <StackItem.Content toolbar>
41
+ <MarkdownEditor.Root id={id} object={doc} {...props}>
42
+ <MarkdownEditor.Toolbar id={id} />
43
+ <MarkdownEditor.Content />
44
+ </MarkdownEditor.Root>
45
+ </StackItem.Content>
46
+ </div>
47
+ );
31
48
  };
32
49
 
33
- const meta: Meta<typeof MarkdownEditor> = {
50
+ const meta: Meta<typeof DefaultStory> = {
34
51
  title: 'plugins/plugin-markdown/MarkdownEditor',
35
- component: MarkdownEditor,
36
- render: DefaultStory,
52
+ component: DefaultStory,
53
+ render: DefaultStory as any,
37
54
  decorators: [
38
- withPluginManager({ plugins: [IntentPlugin()] }),
39
- withAttention,
40
55
  withTheme,
41
- withLayout({ fullscreen: true }),
56
+ withLayout({ container: 'column' }),
57
+ // TODO(burdon): Create story without client.
58
+ withPluginManager({
59
+ plugins: [
60
+ ClientPlugin({
61
+ types: [Markdown.Document],
62
+ onClientInitialized: async ({ client }) => {
63
+ await client.halo.createIdentity();
64
+ await client.spaces.waitUntilReady();
65
+ const space = client.spaces.default;
66
+ await space.waitUntilReady();
67
+ space.db.add(Markdown.make({ content }));
68
+ },
69
+ }),
70
+ IntentPlugin(),
71
+ AttentionPlugin(),
72
+ ],
73
+ }),
42
74
  ],
43
75
  parameters: {
44
76
  translations: [...translations, ...editorTranslations],
@@ -47,15 +79,6 @@ const meta: Meta<typeof MarkdownEditor> = {
47
79
 
48
80
  export default meta;
49
81
 
50
- export const Default = {
51
- args: {
52
- content,
53
- },
54
- };
82
+ type Story = StoryObj<typeof meta>;
55
83
 
56
- export const WithToolbar = {
57
- args: {
58
- toolbar: true,
59
- content,
60
- },
61
- };
84
+ export const Default: Story = {};
@@ -1,294 +1,243 @@
1
1
  //
2
- // Copyright 2023 DXOS.org
2
+ // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ import { type Extension } from '@codemirror/state';
5
6
  import { type EditorView } from '@codemirror/view';
6
- import React, { forwardRef, useMemo, useEffect, useCallback, useImperativeHandle, useRef } from 'react';
7
- import { useDropzone } from 'react-dropzone';
8
-
9
- import { type FileInfo } from '@dxos/app-framework';
10
- import { invariant } from '@dxos/invariant';
11
- import { toLocalizedString, useThemeContext, useTranslation } from '@dxos/react-ui';
7
+ import { createContext } from '@radix-ui/react-context';
8
+ import React, { type PropsWithChildren, useMemo, useState } from 'react';
9
+ import { createPortal } from 'react-dom';
10
+
11
+ import { Surface } from '@dxos/app-framework/react';
12
+ import { DXN } from '@dxos/keys';
13
+ import { type Live } from '@dxos/live-object';
14
+ import { useClient } from '@dxos/react-client';
12
15
  import {
13
- CommandMenu,
14
- type CommandMenuGroup,
15
- type DNDOptions,
16
- type EditorInputMode,
17
- type EditorSelectionState,
18
- type EditorStateStore,
19
- EditorToolbar,
20
- type EditorToolbarActionGraphProps,
21
- type EditorViewMode,
22
- RefPopover,
23
- type UseTextEditorProps,
24
- addLink,
25
- createElement,
26
- coreSlashCommands,
27
- createBasicExtensions,
28
- createMarkdownExtensions,
29
- createThemeExtensions,
30
- dropFile,
31
- editorGutter,
32
- editorSlots,
33
- filterItems,
34
- linkSlashCommands,
35
- processEditorPayload,
36
- stackItemContentEditorClassNames,
37
- useEditorToolbarState,
38
- useFormattingState,
39
- useTextEditor,
40
- useCommandMenu,
41
- type UseCommandMenuOptions,
16
+ EditorMenuProvider,
17
+ type EditorToolbarState,
18
+ type PreviewBlock,
19
+ type PreviewOptions,
20
+ type UseEditorMenu,
21
+ useEditorMenu,
22
+ useEditorToolbar,
42
23
  } from '@dxos/react-ui-editor';
43
- import { StackItem } from '@dxos/react-ui-stack';
44
- import { isNotFalsy, isNonNullable } from '@dxos/util';
24
+ import { isNonNullable } from '@dxos/util';
25
+
26
+ import {
27
+ type DocumentType,
28
+ type ExtensionsOptions,
29
+ type UseEditorMenuOptionsProps,
30
+ useEditorMenuOptions,
31
+ useExtensions,
32
+ } from '../../hooks';
45
33
 
46
- import { useSelectCurrentThread } from '../../hooks';
47
- import { MARKDOWN_PLUGIN } from '../../meta';
48
- import { type MarkdownPluginState } from '../../types';
34
+ import {
35
+ MarkdownEditorContent as NaturalMarkdownEditorContent,
36
+ type MarkdownEditorContentProps as NaturalMarkdownEditorContentProps,
37
+ } from './MarkdownEditorContent';
38
+ import {
39
+ MarkdownEditorToolbar as NaturalMarkdownToolbar,
40
+ type MarkdownEditorToolbarProps as NaturalMarkdownToolbarProps,
41
+ } from './MarkdownEditorToolbar';
42
+
43
+ //
44
+ // Context
45
+ //
49
46
 
50
- export type MarkdownEditorProps = {
47
+ type MarkdownEditorContextValue = {
51
48
  id: string;
52
- role?: string;
53
- inputMode?: EditorInputMode;
54
- scrollPastEnd?: boolean;
55
- slashCommandGroups?: CommandMenuGroup[];
56
- toolbar?: boolean;
57
- customActions?: EditorToolbarActionGraphProps['customActions'];
58
- // TODO(wittjosiah): Generalize custom toolbar actions (e.g. comment, upload, etc.)
59
- viewMode?: EditorViewMode;
60
- editorStateStore?: EditorStateStore;
61
- onViewModeChange?: (id: string, mode: EditorViewMode) => void;
62
- onLinkQuery?: (query?: string) => Promise<CommandMenuGroup[]>;
63
- onFileUpload?: (file: File) => Promise<FileInfo | undefined>;
64
- } & Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &
65
- Partial<Pick<MarkdownPluginState, 'extensionProviders'>>;
66
-
67
- /**
68
- * Base markdown editor component.
69
- * This component provides all the features of the markdown editor that do no depend on ECHO.
70
- * This allows it to be used as a common editor for markdown content on arbitrary backends (e.g. files).
71
- */
72
- export const MarkdownEditor = ({
73
- extensions: _extensions,
49
+ setEditorView: (view: EditorView) => void;
50
+ extensions: Extension[];
51
+ previewBlocks: PreviewBlock[];
52
+ toolbarState: Live<EditorToolbarState>;
53
+ popoverMenu: Omit<UseEditorMenu, 'extension'>;
54
+ } & (Pick<ExtensionsOptions, 'viewMode'> &
55
+ Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onFileUpload' | 'onViewModeChange'>);
56
+
57
+ const [MarkdownEditorContextProvider, useMarkdownEditorContext] =
58
+ createContext<MarkdownEditorContextValue>('MarkdownEditor.Context');
59
+
60
+ //
61
+ // MarkdownEditor.Root
62
+ //
63
+
64
+ type MarkdownEditorRootProps = PropsWithChildren<
65
+ {
66
+ object?: DocumentType;
67
+ extensions?: Extension[];
68
+ } & Pick<MarkdownEditorContextValue, 'id' | 'onFileUpload' | 'onViewModeChange' | 'viewMode'> &
69
+ Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &
70
+ Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings'>
71
+ >;
72
+
73
+ const MarkdownEditorRoot = ({
74
+ children,
75
+ id,
76
+ object,
77
+ editorStateStore,
78
+ selectionManager,
79
+ settings,
80
+ viewMode,
81
+ extensions: extensionsParam,
74
82
  slashCommandGroups,
75
83
  onLinkQuery,
76
84
  ...props
77
- }: MarkdownEditorProps) => {
78
- const { t } = useTranslation();
79
- const viewRef = useRef<EditorView>();
80
-
81
- const getMenu = useCallback(
82
- (trigger: string, query?: string) => {
83
- switch (trigger) {
84
- case '@':
85
- return onLinkQuery?.(query) ?? [];
86
- case '/':
87
- default:
88
- return filterItems([coreSlashCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>
89
- query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true,
90
- );
91
- }
92
- },
93
- [onLinkQuery, slashCommandGroups],
85
+ }: MarkdownEditorRootProps) => {
86
+ const [editorView, setEditorView] = useState<EditorView>();
87
+
88
+ // Preview blocks.
89
+ const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);
90
+ const previewOptions = useMemo<PreviewOptions>(
91
+ () => ({
92
+ addBlockContainer: (block) => {
93
+ setPreviewBlocks((prev) => [...prev, block]);
94
+ },
95
+ removeBlockContainer: ({ link }) => {
96
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
97
+ },
98
+ }),
99
+ [],
94
100
  );
95
101
 
96
- const options = useMemo<UseCommandMenuOptions>(() => {
97
- const trigger = onLinkQuery ? ['/', '@'] : ['/'];
98
- return {
99
- viewRef,
100
- trigger,
101
- placeholder: {
102
- delay: 3_000,
103
- content: () => {
104
- return createElement('div', undefined, [
105
- createElement('span', { text: 'Press' }),
106
- ...trigger.map((text) =>
107
- createElement('span', {
108
- className: 'border border-separator rounded-sm mx-1 px-1.5 pt-[1px] pb-[2px]',
109
- text,
110
- }),
111
- ),
112
- createElement('span', { text: 'for commands.' }),
113
- ]);
114
- },
115
- },
116
- getMenu,
117
- };
118
- }, [getMenu]);
102
+ // Toolbar state.
103
+ const toolbarState = useEditorToolbar({ viewMode });
104
+
105
+ // Context menu.
106
+ const menuOptions = useEditorMenuOptions({
107
+ editorView,
108
+ slashCommandGroups,
109
+ onLinkQuery,
110
+ });
111
+ const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
112
+
113
+ // Extensions.
114
+ const coreExtensions = useExtensions({
115
+ id,
116
+ object,
117
+ editorStateStore,
118
+ previewOptions,
119
+ selectionManager,
120
+ settings,
121
+ viewMode,
122
+ });
123
+
124
+ const extensions = useMemo(
125
+ () => [coreExtensions, menuExtension, extensionsParam].filter(isNonNullable),
126
+ [coreExtensions, menuExtension, extensionsParam],
127
+ );
119
128
 
120
- const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu(options);
129
+ return (
130
+ <MarkdownEditorContextProvider
131
+ id={id}
132
+ editorView={editorView}
133
+ setEditorView={setEditorView}
134
+ extensions={extensions}
135
+ previewBlocks={previewBlocks}
136
+ toolbarState={toolbarState}
137
+ popoverMenu={menuProps}
138
+ viewMode={viewMode}
139
+ {...props}
140
+ >
141
+ {children}
142
+ </MarkdownEditorContextProvider>
143
+ );
144
+ };
121
145
 
122
- const extensions = useMemo(() => [_extensions, commandMenu].filter(isNotFalsy), [_extensions, commandMenu]);
146
+ MarkdownEditorRoot.displayName = 'MarkdownEditor.Root';
147
+
148
+ //
149
+ // MarkdownEditor.Main
150
+ //
151
+
152
+ type MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;
153
+
154
+ const MarkdownEditorContent = (props: MarkdownEditorContentProps) => {
155
+ const {
156
+ id,
157
+ editorView,
158
+ setEditorView,
159
+ viewMode,
160
+ toolbarState,
161
+ extensions,
162
+ popoverMenu: { groupsRef, ...menuProps },
163
+ } = useMarkdownEditorContext(MarkdownEditorContent.displayName);
123
164
 
124
165
  return (
125
- <RefPopover modal={false} {...refPopoverProps}>
126
- <MarkdownEditorImpl ref={viewRef} {...props} extensions={extensions} />
127
- <CommandMenu groups={groupsRef.current} currentItem={currentItem} onSelect={onSelect} />
128
- </RefPopover>
166
+ <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>
167
+ <NaturalMarkdownEditorContent
168
+ {...props}
169
+ id={id}
170
+ viewMode={viewMode}
171
+ toolbarState={toolbarState}
172
+ extensions={extensions}
173
+ ref={setEditorView}
174
+ />
175
+ </EditorMenuProvider>
129
176
  );
130
177
  };
131
178
 
132
- const MarkdownEditorImpl = forwardRef<EditorView | undefined, MarkdownEditorProps>(
133
- (
134
- {
135
- id,
136
- role = 'article',
137
- initialValue,
138
- customActions,
139
- editorStateStore,
140
- extensions,
141
- extensionProviders,
142
- scrollPastEnd,
143
- toolbar,
144
- viewMode,
145
- onFileUpload,
146
- onViewModeChange,
147
- },
148
- forwardedRef,
149
- ) => {
150
- const { t } = useTranslation(MARKDOWN_PLUGIN);
151
- const { themeMode } = useThemeContext();
152
- const toolbarState = useEditorToolbarState({ viewMode });
153
- const formattingObserver = useFormattingState(toolbarState);
154
-
155
- // Restore last selection and scroll point.
156
- const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);
157
-
158
- // Extensions from other plugins.
159
- // TODO(burdon): Reconcile with DocumentEditor.useExtensions.
160
- const providerExtensions = useMemo(
161
- () => extensionProviders?.flatMap((provider) => provider({})).filter(isNonNullable),
162
- [extensionProviders],
163
- );
164
-
165
- // TODO(wittjosiah): Factor out to file uploader plugin.
166
- // Drag files.
167
- const handleDrop: DNDOptions['onDrop'] = async (view, { files }) => {
168
- const file = files[0];
169
- const info = file && onFileUpload ? await onFileUpload(file) : undefined;
170
- if (info) {
171
- processEditorPayload(view, { type: 'image', data: info.url });
172
- }
173
- };
174
-
175
- const {
176
- parentRef,
177
- view: editorView,
178
- focusAttributes,
179
- } = useTextEditor(
180
- () => ({
181
- initialValue,
182
- extensions: [
183
- formattingObserver,
184
- createBasicExtensions({
185
- readOnly: viewMode === 'readonly',
186
- placeholder: t('editor placeholder'),
187
- scrollPastEnd: role === 'section' ? false : scrollPastEnd,
188
- }),
189
- createMarkdownExtensions({ themeMode }),
190
- createThemeExtensions({ themeMode, syntaxHighlighting: true, slots: editorSlots }),
191
- editorGutter,
192
- role !== 'section' && onFileUpload && dropFile({ onDrop: handleDrop }),
193
- providerExtensions,
194
- extensions,
195
- ].filter(isNotFalsy),
196
- ...(role !== 'section' && {
197
- id,
198
- scrollTo,
199
- selection,
200
- // TODO(wittjosiah): Autofocus based on layout is racy.
201
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
202
- moveToEndOfLine: true,
203
- }),
204
- }),
205
- [id, formattingObserver, viewMode, themeMode, extensions, providerExtensions],
206
- );
207
-
208
- useImperativeHandle(forwardedRef, () => editorView, [editorView]);
209
- useTest(editorView);
210
- useSelectCurrentThread(editorView, id);
211
-
212
- // https://react-dropzone.js.org/#src
213
- const { acceptedFiles, getInputProps, open } = useDropzone({
214
- multiple: false,
215
- noDrag: true,
216
- accept: {
217
- 'image/*': ['.jpg', '.jpeg', '.png', '.gif'],
218
- },
219
- });
220
-
221
- useEffect(() => {
222
- if (editorView && onFileUpload && acceptedFiles.length) {
223
- requestAnimationFrame(async () => {
224
- // NOTE: Clone file since react-dropzone patches in a non-standard `path` property, which confuses IPFS.
225
- const f = acceptedFiles[0];
226
- const file = new File([f], f.name, {
227
- type: f.type,
228
- lastModified: f.lastModified,
229
- });
230
-
231
- const info = await onFileUpload(file);
232
- if (info) {
233
- addLink({ url: info.url, image: true })(editorView);
234
- }
235
- });
236
- }
237
- }, [acceptedFiles, editorView, onFileUpload]);
238
-
239
- const getView = useCallback(() => {
240
- invariant(editorView);
241
- return editorView;
242
- }, [editorView]);
243
-
244
- const handleViewModeChange = useCallback(
245
- (mode: EditorViewMode) => onViewModeChange?.(id, mode),
246
- [id, onViewModeChange],
247
- );
248
-
249
- const handleImageUpload = useCallback(() => {
250
- if (onFileUpload) {
251
- open();
252
- }
253
- }, [onFileUpload]);
254
-
255
- return (
256
- <StackItem.Content toolbar={!!toolbar}>
257
- {toolbar && (
258
- <>
259
- <EditorToolbar
260
- attendableId={id}
261
- role={role}
262
- state={toolbarState}
263
- customActions={customActions}
264
- getView={getView}
265
- image={handleImageUpload}
266
- viewMode={handleViewModeChange}
267
- />
268
- <input {...getInputProps()} />
269
- </>
270
- )}
271
- <div
272
- role='none'
273
- ref={parentRef}
274
- data-testid='composer.markdownRoot'
275
- data-toolbar={toolbar ? 'enabled' : 'disabled'}
276
- className={stackItemContentEditorClassNames(role)}
277
- data-popover-collision-boundary={true}
278
- {...focusAttributes}
279
- />
280
- </StackItem.Content>
281
- );
282
- },
283
- );
284
-
285
- // Expose editor view for playwright tests.
286
- // TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.
287
- const useTest = (view?: EditorView) => {
288
- useEffect(() => {
289
- const composer = (window as any).composer;
290
- if (composer) {
291
- composer.editorView = view;
292
- }
293
- }, [view]);
179
+ MarkdownEditorContent.displayName = 'MarkdownEditor.Content';
180
+
181
+ //
182
+ // MarkdownEditor.Toolbar
183
+ //
184
+
185
+ type MarkdownEditorToolbarProps = Omit<
186
+ NaturalMarkdownToolbarProps,
187
+ 'state' | 'editorView' | 'onFileUpload' | 'onViewModeChange'
188
+ >;
189
+
190
+ const MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {
191
+ const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar.displayName);
192
+
193
+ return <NaturalMarkdownToolbar {...props} {...rootProps} state={toolbarState} />;
194
+ };
195
+
196
+ MarkdownEditorToolbar.displayName = 'MarkdownEditor.Toolbar';
197
+
198
+ //
199
+ // MarkdownEditor.Blocks (embedded objects)
200
+ //
201
+
202
+ type MarkdownEditorBlocksProps = {};
203
+
204
+ const MarkdownEditorBlocks = (_props: MarkdownEditorBlocksProps) => {
205
+ const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);
206
+
207
+ return (
208
+ <>
209
+ {previewBlocks.map(({ link, el }) => (
210
+ <PreviewBlock key={link.ref} link={link} el={el} />
211
+ ))}
212
+ </>
213
+ );
214
+ };
215
+
216
+ MarkdownEditorBlocks.displayName = 'MarkdownEditor.Blocks';
217
+
218
+ const PreviewBlock = ({ el, link }: PreviewBlock) => {
219
+ const client = useClient();
220
+ const dxn = DXN.parse(link.ref);
221
+ const subject = client.graph.makeRef(dxn).target;
222
+ const data = useMemo(() => ({ subject }), [subject]);
223
+
224
+ return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);
225
+ };
226
+
227
+ //
228
+ // MarkdownEditor
229
+ //
230
+
231
+ export const MarkdownEditor = {
232
+ Root: MarkdownEditorRoot,
233
+ Content: MarkdownEditorContent,
234
+ Toolbar: MarkdownEditorToolbar,
235
+ Blocks: MarkdownEditorBlocks,
236
+ };
237
+
238
+ export type {
239
+ MarkdownEditorRootProps,
240
+ MarkdownEditorContentProps,
241
+ MarkdownEditorToolbarProps,
242
+ MarkdownEditorBlocksProps,
294
243
  };