@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,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/hooks/useLinkQuery.ts", "../../../src/hooks/useEditorMenuOptions.ts", "../../../src/hooks/useExtensions.tsx", "../../../src/hooks/useSelectCurrentThread.tsx", "../../../src/components/MarkdownEditor/MarkdownEditor.tsx", "../../../src/components/MarkdownEditor/MarkdownEditorContent.tsx", "../../../src/components/MarkdownEditor/MarkdownEditorToolbar.tsx", "../../../src/components/MarkdownEditor/FileUpload.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport * as Option from 'effect/Option';\nimport { useCallback, useMemo } from 'react';\n\nimport { Capabilities } from '@dxos/app-framework';\nimport { usePluginManager } from '@dxos/app-framework/react';\nimport { Filter, Obj, Query, Type } from '@dxos/echo';\nimport { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from '@dxos/echo/internal';\nimport { type Space } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type EditorMenuGroup, type EditorMenuItem, insertAtCursor, insertAtLineStart } from '@dxos/react-ui-editor';\n\nexport const useLinkQuery = (space: Space | undefined) => {\n const { t } = useTranslation();\n\n const manager = usePluginManager();\n const resolve = useCallback(\n (typename: string) =>\n manager.context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {},\n [manager],\n );\n\n const filter = useMemo(\n () =>\n Filter.or(\n ...(space?.db.schemaRegistry.query({ location: ['database', 'runtime'] }).runSync() ?? [])\n .filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation)\n .filter((schema) => !SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false)))\n .map((schema) => Filter.typename(Type.getTypename(schema))),\n ),\n [space],\n );\n\n const handleLinkQuery = useCallback(\n async (query?: string): Promise<EditorMenuGroup[]> => {\n const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');\n const results = await space?.db.query(Query.select(filter)).run();\n\n // TODO(wittjosiah): Use `Obj.Any` type.\n const getLabel = (object: any) => {\n const label = Obj.getLabel(object);\n if (label) {\n return label;\n }\n\n // TODO(wittjosiah): Remove metadata labels.\n const type = Obj.getTypename(object)!;\n const metadata = resolve(type);\n return metadata.label?.(object) || ['object name placeholder', { ns: type, default: 'New object' }];\n };\n\n const items =\n results\n ?.filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name))\n // TODO(wittjosiah): Remove `any` type.\n .map((object: any): EditorMenuItem => {\n const metadata = resolve(Obj.getTypename(object)!);\n const label = toLocalizedString(getLabel(object), t);\n return {\n id: object.id,\n label,\n icon: metadata.icon,\n onSelect: ({ view, head }) => {\n const link = `[${label}](${Obj.getDXN(object)})`;\n if (query?.startsWith('@')) {\n insertAtLineStart(view, head, `!${link}\\n`);\n } else {\n insertAtCursor(view, head, `${link} `);\n }\n },\n };\n }) ?? [];\n\n return [{ id: 'echo', items }];\n },\n [space, filter, resolve],\n );\n\n return handleLinkQuery;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport { useCallback, useMemo, useRef } from 'react';\n\nimport { Domino, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport {\n type EditorMenuGroup,\n type UseEditorMenuProps,\n filterMenuGroups,\n formattingCommands,\n linkSlashCommands,\n} from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\nexport type UseEditorMenuOptionsProps = {\n editorView?: EditorView;\n slashCommandGroups?: EditorMenuGroup[];\n onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;\n};\n\nexport const useEditorMenuOptions = ({\n editorView,\n slashCommandGroups,\n onLinkQuery,\n}: UseEditorMenuOptionsProps): UseEditorMenuProps => {\n const { t } = useTranslation(meta.id);\n\n const getMenu = useCallback<NonNullable<UseEditorMenuProps['getMenu']>>(\n ({ text, trigger }) => {\n switch (trigger) {\n case '@': {\n return onLinkQuery?.(text) ?? [];\n }\n\n case '/':\n default: {\n return filterMenuGroups([formattingCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>\n text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true,\n );\n }\n }\n },\n [slashCommandGroups, onLinkQuery],\n );\n\n const viewRef = useRef(editorView);\n return useMemo<UseEditorMenuProps>(() => {\n const trigger = onLinkQuery ? ['/', '@'] : ['/'];\n const placeholder = {\n delay: 3_000,\n content: () =>\n Domino.of('div')\n .children(\n Domino.of('span').text('Press'),\n ...trigger.map((text) =>\n Domino.of('span')\n .classNames('mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm')\n .text(text),\n ),\n Domino.of('span').text('for commands.'),\n )\n .build(),\n };\n\n return { viewRef, getMenu, trigger, placeholder };\n }, [getMenu, onLinkQuery]);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type ViewUpdate } from '@codemirror/view';\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport { LayoutAction, type PromiseIntentDispatcher, createIntent } from '@dxos/app-framework';\nimport { useIntentDispatcher } from '@dxos/app-framework/react';\nimport { debounceAndThrottle } from '@dxos/async';\nimport { Obj } from '@dxos/echo';\nimport { createDocAccessor } from '@dxos/echo-db';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n Cursor,\n type EditorStateStore,\n EditorView,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n type PreviewOptions,\n type RenderCallback,\n createDataExtensions,\n decorateMarkdown,\n documentId,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n replacer,\n selectionState,\n typewriter,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { Text } from '@dxos/schema';\nimport { isTruthy } from '@dxos/util';\n\nimport { Markdown } from '../types';\nimport { setFallbackName } from '../util';\n\nexport type DocumentType = Markdown.Document | Text.Text | { id: string; text: string };\n\nexport type ExtensionsOptions = {\n id: string;\n object?: DocumentType;\n dispatch?: PromiseIntentDispatcher;\n settings?: Markdown.Settings;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n previewOptions?: PreviewOptions;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n id,\n object,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(object);\n\n let target: Obj.Any | undefined;\n if (Obj.instanceOf(Markdown.Document, object)) {\n target = (object as Markdown.Document).content.target;\n } else if (Obj.instanceOf(Text.Text, object)) {\n target = object;\n }\n\n // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.\n // TODO(burdon): Unsubscribe.\n // const query = space?.db.query(Filter.type(DocumentType));\n // query?.subscribe();\n\n const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n id,\n object,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n dispatch,\n }),\n [\n id,\n object,\n viewMode,\n dispatch,\n previewOptions,\n settings,\n settings?.debug,\n settings?.editorInputMode,\n settings?.folding,\n settings?.numberedHeadings,\n settings?.typewriter,\n selectionManager,\n ],\n );\n\n return useMemo<Extension[]>(\n () =>\n [\n // TODO(burdon): Pass this in?\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n target &&\n createDataExtensions({\n id,\n text: createDocAccessor(target, ['content']),\n messenger: space,\n identity,\n }),\n\n // TODO(burdon): Reconcile with effect in parent.\n Obj.instanceOf(Markdown.Document, object) &&\n listener({\n onChange: ({ text }) => {\n setFallbackName(object as Markdown.Document, text);\n },\n }),\n\n baseExtensions,\n selectionState(editorStateStore),\n ].filter(isTruthy),\n [identity, space, id, object, target, baseExtensions],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({\n id,\n object,\n dispatch,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings?.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings?.folding && folding(),\n ].filter(isTruthy);\n\n //\n // Markdown\n //\n if (viewMode !== 'source') {\n extensions.push(\n ...[\n formattingKeymap(),\n decorateMarkdown({\n selectionChangeDelay: 100,\n numberedHeadings: settings?.numberedHeadings ? { from: 2 } : undefined,\n // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.\n // TODO(burdon): Create dx-tag.\n renderLinkButton:\n dispatch && (object || id)\n ? createLinkRenderer((id: string) => {\n void dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [id],\n options: {\n pivotId: object && Obj.isObject(object) ? Obj.getDXN(object).toString() : id,\n },\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n preview(previewOptions),\n replacer(),\n ],\n );\n }\n\n if (settings?.debug) {\n const items = settings.typewriter?.split(/[,\\n]/) ?? '';\n if (items) {\n extensions.push(typewriter({ items }));\n }\n }\n\n return extensions;\n};\n\nconst selectionChange = (selectionManager: SelectionManager) => {\n return EditorView.updateListener.of(\n debounceAndThrottle((update: ViewUpdate) => {\n if (update.selectionSet) {\n const id = update.state.facet(documentId);\n const cursorConverter = update.state.facet(Cursor.converter);\n const selection = update.state.selection;\n const ranges = selection.ranges\n .map((range) => ({\n from: cursorConverter.toCursor(range.from),\n to: cursorConverter.toCursor(range.to),\n }))\n .filter(({ from, to }) => to > from);\n\n selectionManager.updateMultiRange(id, ranges);\n }\n }, 100),\n );\n};\n\n// TODO(burdon): Factor out styles.\nconst style = {\n hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',\n icon: 'inline-block leading-none mis-1 cursor-pointer',\n};\n\nconst createLinkRenderer =\n (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>\n (el, { url }) => {\n // TODO(burdon): Formalize/document internal link format.\n const isInternal =\n url.startsWith('/') ||\n // TODO(wittjosiah): This should probably be parsed out on paste?\n url.startsWith(window.location.origin);\n\n const options: AnchorHTMLAttributes<any> = isInternal\n ? {\n onClick: () => {\n const qualifiedId = url.split('/').at(-1);\n invariant(qualifiedId, 'Invalid link format.');\n onSelectObject(qualifiedId);\n },\n }\n : {\n href: url,\n rel: 'noreferrer',\n target: '_blank',\n };\n\n renderRoot(\n el,\n <a {...options} className={style.hover}>\n <Icon\n icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}\n size={4}\n classNames={style.icon}\n />\n </a>,\n );\n };\n\nconst renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {\n const web = new URL(url);\n renderRoot(\n el,\n <a href={url} rel='noreferrer' target='_blank' className={style.hover}>\n {web.origin}\n <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />\n </a>,\n );\n};\n\n// TODO(burdon): REMOVE.\nconst renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport * as Schema from 'effect/Schema';\nimport { useMemo } from 'react';\n\nimport { LayoutAction, createResolver } from '@dxos/app-framework';\nimport { useIntentResolver } from '@dxos/app-framework/react';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | null, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver({\n intent: LayoutAction.UpdateLayout,\n position: 'hoist',\n filter: (\n data,\n ): data is {\n part: 'current';\n subject: string;\n options: { cursor: string };\n } => {\n if (!Schema.is(LayoutAction.ScrollIntoView.fields.input)(data)) {\n return false;\n }\n\n return !!editorView && data.subject === documentId && !!data.options?.cursor;\n },\n resolve: ({ options: { cursor } }) => {\n invariant(editorView, 'Editor view is not defined.');\n const range = Cursor.getRangeFromCursor(editorView.state, cursor!);\n if (range) {\n const selection = editorView.state.selection.main.from !== range.from ? { anchor: range.from } : undefined;\n const effects = [\n // NOTE: This does not use the DOM scrollIntoView function.\n EditorView.scrollIntoView(range.from, {\n y: 'start',\n yMargin: 96,\n }),\n ];\n if (selection) {\n // Update the editor selection to get bi-directional highlighting.\n effects.push(setSelection.of({ current: documentId }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n },\n }),\n [documentId, editorView],\n );\n\n useIntentResolver(meta.id, scrollIntoViewResolver);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Extension } from '@codemirror/state';\nimport { type EditorView } from '@codemirror/view';\nimport { createContext } from '@radix-ui/react-context';\nimport React, { type PropsWithChildren, useMemo, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { Surface } from '@dxos/app-framework/react';\nimport { DXN } from '@dxos/keys';\nimport { type Live } from '@dxos/live-object';\nimport { useClient } from '@dxos/react-client';\nimport {\n EditorMenuProvider,\n type EditorToolbarState,\n type PreviewBlock,\n type PreviewOptions,\n type UseEditorMenu,\n useEditorMenu,\n useEditorToolbar,\n} from '@dxos/react-ui-editor';\nimport { isNonNullable } from '@dxos/util';\n\nimport {\n type DocumentType,\n type ExtensionsOptions,\n type UseEditorMenuOptionsProps,\n useEditorMenuOptions,\n useExtensions,\n} from '../../hooks';\n\nimport {\n MarkdownEditorContent as NaturalMarkdownEditorContent,\n type MarkdownEditorContentProps as NaturalMarkdownEditorContentProps,\n} from './MarkdownEditorContent';\nimport {\n MarkdownEditorToolbar as NaturalMarkdownToolbar,\n type MarkdownEditorToolbarProps as NaturalMarkdownToolbarProps,\n} from './MarkdownEditorToolbar';\n\n//\n// Context\n//\n\ntype MarkdownEditorContextValue = {\n id: string;\n setEditorView: (view: EditorView) => void;\n extensions: Extension[];\n previewBlocks: PreviewBlock[];\n toolbarState: Live<EditorToolbarState>;\n popoverMenu: Omit<UseEditorMenu, 'extension'>;\n} & (Pick<ExtensionsOptions, 'viewMode'> &\n Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onFileUpload' | 'onViewModeChange'>);\n\nconst [MarkdownEditorContextProvider, useMarkdownEditorContext] =\n createContext<MarkdownEditorContextValue>('MarkdownEditor.Context');\n\n//\n// MarkdownEditor.Root\n//\n\ntype MarkdownEditorRootProps = PropsWithChildren<\n {\n object?: DocumentType;\n extensions?: Extension[];\n } & Pick<MarkdownEditorContextValue, 'id' | 'onFileUpload' | 'onViewModeChange' | 'viewMode'> &\n Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &\n Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings'>\n>;\n\nconst MarkdownEditorRoot = ({\n children,\n id,\n object,\n editorStateStore,\n selectionManager,\n settings,\n viewMode,\n extensions: extensionsParam,\n slashCommandGroups,\n onLinkQuery,\n ...props\n}: MarkdownEditorRootProps) => {\n const [editorView, setEditorView] = useState<EditorView>();\n\n // Preview blocks.\n const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);\n const previewOptions = useMemo<PreviewOptions>(\n () => ({\n addBlockContainer: (block) => {\n setPreviewBlocks((prev) => [...prev, block]);\n },\n removeBlockContainer: ({ link }) => {\n setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));\n },\n }),\n [],\n );\n\n // Toolbar state.\n const toolbarState = useEditorToolbar({ viewMode });\n\n // Context menu.\n const menuOptions = useEditorMenuOptions({\n editorView,\n slashCommandGroups,\n onLinkQuery,\n });\n const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);\n\n // Extensions.\n const coreExtensions = useExtensions({\n id,\n object,\n editorStateStore,\n previewOptions,\n selectionManager,\n settings,\n viewMode,\n });\n\n const extensions = useMemo(\n () => [coreExtensions, menuExtension, extensionsParam].filter(isNonNullable),\n [coreExtensions, menuExtension, extensionsParam],\n );\n\n return (\n <MarkdownEditorContextProvider\n id={id}\n editorView={editorView}\n setEditorView={setEditorView}\n extensions={extensions}\n previewBlocks={previewBlocks}\n toolbarState={toolbarState}\n popoverMenu={menuProps}\n viewMode={viewMode}\n {...props}\n >\n {children}\n </MarkdownEditorContextProvider>\n );\n};\n\nMarkdownEditorRoot.displayName = 'MarkdownEditor.Root';\n\n//\n// MarkdownEditor.Main\n//\n\ntype MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;\n\nconst MarkdownEditorContent = (props: MarkdownEditorContentProps) => {\n const {\n id,\n editorView,\n setEditorView,\n viewMode,\n toolbarState,\n extensions,\n popoverMenu: { groupsRef, ...menuProps },\n } = useMarkdownEditorContext(MarkdownEditorContent.displayName);\n\n return (\n <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>\n <NaturalMarkdownEditorContent\n {...props}\n id={id}\n viewMode={viewMode}\n toolbarState={toolbarState}\n extensions={extensions}\n ref={setEditorView}\n />\n </EditorMenuProvider>\n );\n};\n\nMarkdownEditorContent.displayName = 'MarkdownEditor.Content';\n\n//\n// MarkdownEditor.Toolbar\n//\n\ntype MarkdownEditorToolbarProps = Omit<\n NaturalMarkdownToolbarProps,\n 'state' | 'editorView' | 'onFileUpload' | 'onViewModeChange'\n>;\n\nconst MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {\n const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar.displayName);\n\n return <NaturalMarkdownToolbar {...props} {...rootProps} state={toolbarState} />;\n};\n\nMarkdownEditorToolbar.displayName = 'MarkdownEditor.Toolbar';\n\n//\n// MarkdownEditor.Blocks (embedded objects)\n//\n\ntype MarkdownEditorBlocksProps = {};\n\nconst MarkdownEditorBlocks = (_props: MarkdownEditorBlocksProps) => {\n const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);\n\n return (\n <>\n {previewBlocks.map(({ link, el }) => (\n <PreviewBlock key={link.ref} link={link} el={el} />\n ))}\n </>\n );\n};\n\nMarkdownEditorBlocks.displayName = 'MarkdownEditor.Blocks';\n\nconst PreviewBlock = ({ el, link }: PreviewBlock) => {\n const client = useClient();\n const dxn = DXN.parse(link.ref);\n const subject = client.graph.makeRef(dxn).target;\n const data = useMemo(() => ({ subject }), [subject]);\n\n return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);\n};\n\n//\n// MarkdownEditor\n//\n\nexport const MarkdownEditor = {\n Root: MarkdownEditorRoot,\n Content: MarkdownEditorContent,\n Toolbar: MarkdownEditorToolbar,\n Blocks: MarkdownEditorBlocks,\n};\n\nexport type {\n MarkdownEditorRootProps,\n MarkdownEditorContentProps,\n MarkdownEditorToolbarProps,\n MarkdownEditorBlocksProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useEffect, useImperativeHandle, useMemo } from 'react';\n\nimport { type Live } from '@dxos/live-object';\nimport { type ThemedClassName, useDynamicRef, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type EditorMenuGroup,\n type EditorSelectionState,\n type EditorStateStore,\n type EditorToolbarState,\n type EditorViewMode,\n type ThemeExtensionsOptions,\n type UseTextEditorProps,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorSlots,\n formattingListener,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { mx } from '@dxos/react-ui-theme';\nimport { isTruthy } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../../hooks';\nimport { meta } from '../../meta';\n\nimport { type MarkdownEditorToolbarProps } from './MarkdownEditorToolbar';\n\nexport type MarkdownEditorContentProps = ThemedClassName<{\n id: string;\n role?: string;\n viewMode?: EditorViewMode;\n scrollPastEnd?: boolean;\n slashCommandGroups?: EditorMenuGroup[];\n editorStateStore?: EditorStateStore;\n toolbarState?: Live<EditorToolbarState>;\n onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;\n}> &\n // prettier-ignore\n Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &\n Pick<MarkdownEditorToolbarProps, 'onFileUpload'> &\n Pick<ThemeExtensionsOptions, 'slots'>;\n\nexport const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEditorContentProps>(\n (\n {\n classNames,\n id,\n role,\n viewMode,\n initialValue,\n editorStateStore,\n toolbarState,\n extensions,\n scrollPastEnd,\n slots = editorSlots,\n onFileUpload,\n },\n forwardedRef,\n ) => {\n const { t } = useTranslation(meta.id);\n const { themeMode } = useThemeContext();\n\n // TODO(burdon): Toolbar state is not reactive.\n const toolbarStateRef = useDynamicRef(toolbarState);\n\n // Restore last selection and scroll point.\n const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);\n\n const {\n parentRef,\n view: editorView,\n focusAttributes,\n } = useTextEditor(\n () => ({\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racy.\n // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n selectionEnd: true,\n }),\n initialValue,\n extensions: [\n createBasicExtensions({\n readOnly: viewMode === 'readonly',\n placeholder: t('editor placeholder'),\n scrollPastEnd: scrollPastEnd && role !== 'section',\n search: true,\n }),\n createThemeExtensions({\n themeMode,\n slots,\n syntaxHighlighting: true,\n }),\n createMarkdownExtensions(),\n formattingListener(() => toolbarStateRef.current),\n role !== 'section' &&\n onFileUpload &&\n dropFile({\n // TODO(wittjosiah): Factor out to file uploader plugin.\n onDrop: async (view, { files }) => {\n const file = files[0];\n const info = file && onFileUpload ? await onFileUpload(file) : undefined;\n if (info) {\n processEditorPayload(view, { type: 'image', data: info.url });\n }\n },\n }),\n extensions,\n ].filter(isTruthy),\n }),\n [id, viewMode, themeMode, extensions],\n );\n\n useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);\n\n useSelectCurrentThread(editorView, id);\n\n useTest(editorView);\n\n return (\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n className={mx(stackItemContentEditorClassNames(role), classNames)}\n data-popover-collision-boundary={true}\n {...focusAttributes}\n />\n );\n },\n);\n\n// Expose editor view for playwright tests.\n// TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.\nconst useTest = (view: EditorView | null) => {\n useEffect(() => {\n const composer = (window as any).composer;\n if (composer) {\n composer.editorView = view;\n }\n }, [view]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { useCallback, useState } from 'react';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { EditorToolbar, type EditorToolbarProps, type EditorViewMode } from '@dxos/react-ui-editor';\n\nimport { FileUpload, type FileUploadAction } from './FileUpload';\n\nexport type MarkdownEditorToolbarProps = ThemedClassName<\n {\n id: string;\n editorView?: EditorView;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n } & Pick<EditorToolbarProps, 'role' | 'state' | 'customActions' | 'onViewModeChange'>\n>;\n\nexport const MarkdownEditorToolbar = ({\n classNames,\n id,\n role,\n state,\n editorView,\n customActions,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorToolbarProps) => {\n const [upload, setUpload] = useState<FileUploadAction | null>(null);\n const uploadRef = useCallback((next: FileUploadAction) => setUpload(() => next), []);\n\n const handleViewModeChange = useCallback((mode: EditorViewMode) => onViewModeChange?.(mode), [onViewModeChange]);\n\n const getView = useCallback(() => {\n invariant(editorView);\n return editorView;\n }, [editorView]);\n\n if (!editorView) {\n return <div />;\n }\n\n return (\n <>\n <EditorToolbar\n classNames={classNames}\n attendableId={id}\n role={role}\n state={state}\n customActions={customActions}\n getView={getView}\n onImageUpload={upload ?? undefined}\n onViewModeChange={handleViewModeChange}\n />\n\n {onFileUpload && <FileUpload ref={uploadRef} editorView={editorView} onFileUpload={onFileUpload} />}\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useEffect, useImperativeHandle } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { addLink } from '@dxos/react-ui-editor';\n\nexport const IMAGE_FILES = ['.jpg', '.jpeg', '.png', '.gif'];\n\nexport type FileUploadAction = () => void;\n\nexport type FileUploadProps = {\n editorView?: EditorView;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n};\n\n// TODO(burdon): Factor out.\n// TODO(burdon): Move to root? (support drag into document via dropzone).\nexport const FileUpload = forwardRef<FileUploadAction, FileUploadProps>(\n ({ editorView, onFileUpload }, forwardedRef) => {\n // https://react-dropzone.js.org\n const { acceptedFiles, open, inputRef } = useDropzone({\n disabled: !onFileUpload,\n multiple: false,\n noDrag: true,\n accept: {\n 'image/*': IMAGE_FILES,\n },\n });\n\n useImperativeHandle(forwardedRef, () => open, []);\n\n useEffect(() => {\n if (editorView && acceptedFiles.length && onFileUpload) {\n requestAnimationFrame(async () => {\n // NOTE: Clone file since react-dropzone patches in a non-standard `path` property, which confuses IPFS.\n const f = acceptedFiles[0];\n const file = new File([f], f.name, {\n type: f.type,\n lastModified: f.lastModified,\n });\n\n // TODO(burdon): Factor out.\n const info = await onFileUpload(file);\n if (info) {\n addLink({ url: info.url, image: true })(editorView);\n }\n });\n }\n }, [editorView, acceptedFiles, onFileUpload]);\n\n if (!onFileUpload) {\n return null;\n }\n\n return <>{createPortal(<input ref={inputRef} />, document.body)} </>;\n },\n);\n"],
5
+ "mappings": "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",
6
+ "names": ["Option", "useCallback", "useMemo", "Capabilities", "usePluginManager", "Filter", "Obj", "Query", "Type", "EntityKind", "SystemTypeAnnotation", "getTypeAnnotation", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "useLinkQuery", "space", "t", "useTranslation", "manager", "usePluginManager", "resolve", "useCallback", "typename", "context", "getCapabilities", "Capabilities", "Metadata", "find", "id", "metadata", "filter", "useMemo", "Filter", "or", "db", "schemaRegistry", "query", "location", "runSync", "schema", "getTypeAnnotation", "kind", "EntityKind", "Relation", "SystemTypeAnnotation", "get", "pipe", "getOrElse", "map", "Type", "getTypename", "handleLinkQuery", "name", "startsWith", "slice", "toLowerCase", "results", "Query", "select", "run", "getLabel", "object", "label", "Obj", "type", "ns", "default", "items", "toLocalizedString", "includes", "icon", "onSelect", "view", "head", "link", "getDXN", "insertAtLineStart", "insertAtCursor", "useCallback", "useMemo", "useRef", "Domino", "toLocalizedString", "useTranslation", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "useEditorMenuOptions", "editorView", "slashCommandGroups", "onLinkQuery", "t", "useTranslation", "meta", "id", "getMenu", "useCallback", "text", "trigger", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "viewRef", "useRef", "useMemo", "placeholder", "delay", "content", "Domino", "of", "children", "map", "classNames", "build", "React", "useMemo", "createRoot", "LayoutAction", "createIntent", "useIntentDispatcher", "debounceAndThrottle", "Obj", "createDocAccessor", "invariant", "getSpace", "useIdentity", "Icon", "ThemeProvider", "Cursor", "EditorView", "InputModeExtensions", "createDataExtensions", "decorateMarkdown", "documentId", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "replacer", "selectionState", "typewriter", "defaultTx", "Text", "isTruthy", "useExtensions", "id", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "previewOptions", "dispatchPromise", "dispatch", "useIntentDispatcher", "identity", "useIdentity", "space", "getSpace", "target", "Obj", "instanceOf", "Markdown", "Document", "content", "Text", "baseExtensions", "useMemo", "createBaseExtensions", "debug", "editorInputMode", "folding", "numberedHeadings", "typewriter", "createDataExtensions", "text", "createDocAccessor", "messenger", "listener", "onChange", "setFallbackName", "selectionState", "filter", "isTruthy", "extensions", "selectionChange", "InputModeExtensions", "push", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "isObject", "getDXN", "toString", "linkTooltip", "renderLinkTooltip", "preview", "replacer", "items", "split", "EditorView", "updateListener", "of", "debounceAndThrottle", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "map", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "EditorView", "Schema", "useMemo", "LayoutAction", "createResolver", "useIntentResolver", "invariant", "Cursor", "setSelection", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "intent", "LayoutAction", "UpdateLayout", "position", "filter", "data", "is", "ScrollIntoView", "fields", "input", "subject", "options", "cursor", "resolve", "invariant", "range", "Cursor", "getRangeFromCursor", "state", "selection", "main", "from", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "dispatch", "useIntentResolver", "meta", "id", "createContext", "React", "useMemo", "useState", "createPortal", "Surface", "DXN", "useClient", "EditorMenuProvider", "useEditorMenu", "useEditorToolbar", "isNonNullable", "React", "forwardRef", "useEffect", "useImperativeHandle", "useMemo", "useDynamicRef", "useThemeContext", "useTranslation", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorSlots", "formattingListener", "processEditorPayload", "stackItemContentEditorClassNames", "useTextEditor", "mx", "isTruthy", "MarkdownEditorContent", "forwardRef", "classNames", "id", "role", "viewMode", "initialValue", "editorStateStore", "toolbarState", "extensions", "scrollPastEnd", "slots", "editorSlots", "onFileUpload", "forwardedRef", "t", "useTranslation", "meta", "themeMode", "useThemeContext", "toolbarStateRef", "useDynamicRef", "scrollTo", "selection", "useMemo", "getState", "parentRef", "view", "editorView", "focusAttributes", "useTextEditor", "selectionEnd", "createBasicExtensions", "readOnly", "placeholder", "search", "createThemeExtensions", "syntaxHighlighting", "createMarkdownExtensions", "formattingListener", "current", "dropFile", "onDrop", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "filter", "isTruthy", "useImperativeHandle", "useSelectCurrentThread", "useTest", "React", "div", "ref", "data-testid", "className", "mx", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "useEffect", "composer", "window", "React", "useCallback", "useState", "invariant", "EditorToolbar", "React", "forwardRef", "useEffect", "useImperativeHandle", "createPortal", "useDropzone", "addLink", "IMAGE_FILES", "FileUpload", "forwardRef", "editorView", "onFileUpload", "forwardedRef", "acceptedFiles", "open", "inputRef", "useDropzone", "disabled", "multiple", "noDrag", "accept", "useImperativeHandle", "useEffect", "length", "requestAnimationFrame", "f", "file", "File", "name", "type", "lastModified", "info", "addLink", "url", "image", "React", "createPortal", "input", "ref", "document", "body", "MarkdownEditorToolbar", "classNames", "id", "role", "state", "editorView", "customActions", "onFileUpload", "onViewModeChange", "upload", "setUpload", "useState", "uploadRef", "useCallback", "next", "handleViewModeChange", "mode", "getView", "invariant", "React", "div", "EditorToolbar", "attendableId", "onImageUpload", "undefined", "FileUpload", "ref", "MarkdownEditorContextProvider", "useMarkdownEditorContext", "createContext", "MarkdownEditorRoot", "children", "id", "object", "editorStateStore", "selectionManager", "settings", "viewMode", "extensions", "extensionsParam", "slashCommandGroups", "onLinkQuery", "props", "editorView", "setEditorView", "useState", "previewBlocks", "setPreviewBlocks", "previewOptions", "useMemo", "addBlockContainer", "block", "prev", "removeBlockContainer", "link", "filter", "prevLink", "ref", "toolbarState", "useEditorToolbar", "menuOptions", "useEditorMenuOptions", "extension", "menuExtension", "menuProps", "useEditorMenu", "coreExtensions", "useExtensions", "isNonNullable", "React", "popoverMenu", "displayName", "MarkdownEditorContent", "groupsRef", "EditorMenuProvider", "view", "groups", "current", "NaturalMarkdownEditorContent", "MarkdownEditorToolbar", "rootProps", "NaturalMarkdownToolbar", "state", "MarkdownEditorBlocks", "_props", "map", "el", "PreviewBlock", "key", "client", "useClient", "dxn", "DXN", "parse", "subject", "graph", "makeRef", "target", "data", "createPortal", "Surface", "role", "limit", "MarkdownEditor", "Root", "Content", "Toolbar", "Blocks"]
7
+ }
@@ -1,17 +1,17 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- MARKDOWN_PLUGIN
4
- } from "./chunk-CXG7GMYP.mjs";
3
+ meta
4
+ } from "./chunk-SHAMSMKQ.mjs";
5
5
 
6
6
  // src/capabilities/capabilities.ts
7
7
  import { defineCapability } from "@dxos/app-framework";
8
8
  (function(MarkdownCapabilities2) {
9
- MarkdownCapabilities2.State = defineCapability(`${MARKDOWN_PLUGIN}/capability/state`);
10
- MarkdownCapabilities2.Extensions = defineCapability(`${MARKDOWN_PLUGIN}/capability/extensions`);
9
+ MarkdownCapabilities2.State = defineCapability(`${meta.id}/capability/state`);
10
+ MarkdownCapabilities2.Extensions = defineCapability(`${meta.id}/capability/extensions`);
11
11
  })(MarkdownCapabilities || (MarkdownCapabilities = {}));
12
12
  var MarkdownCapabilities;
13
13
 
14
14
  export {
15
15
  MarkdownCapabilities
16
16
  };
17
- //# sourceMappingURL=chunk-ACFGXH2K.mjs.map
17
+ //# sourceMappingURL=chunk-GMMVSXQ6.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/capabilities.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { defineCapability } from '@dxos/app-framework';\nimport { type EditorStateStore, type EditorViewMode } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\nimport { type MarkdownExtensionProvider, type MarkdownPluginState } from '../types';\n\nexport namespace MarkdownCapabilities {\n export const State = defineCapability<{\n state: MarkdownPluginState;\n editorState: EditorStateStore;\n getViewMode: (id: string) => EditorViewMode;\n // TODO(burdon): Event object.\n setViewMode: (id: string, viewMode: EditorViewMode) => void;\n }>(`${meta.id}/capability/state`);\n\n // TODO(burdon): Move to ./types (external API)?\n export const Extensions = defineCapability<MarkdownExtensionProvider[]>(`${meta.id}/capability/extensions`);\n}\n"],
5
+ "mappings": ";;;;;;AAIA,SAASA,wBAAwB;UAMhBC,uBAAAA;wBACFC,QAAQC,iBAMlB,GAAGC,KAAKC,EAAE,mBAAmB;wBAGnBC,aAAaH,iBAA8C,GAAGC,KAAKC,EAAE,wBAAwB;AAC5G,GAXiBJ,yBAAAA,uBAAAA,CAAAA,EAAAA;;",
6
+ "names": ["defineCapability", "MarkdownCapabilities", "State", "defineCapability", "meta", "id", "Extensions"]
7
+ }
@@ -1,26 +1,28 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- DocumentType
4
- } from "./chunk-JEEQLO7C.mjs";
3
+ Markdown_exports
4
+ } from "./chunk-YFRTKXTB.mjs";
5
5
  import {
6
6
  meta
7
- } from "./chunk-CXG7GMYP.mjs";
7
+ } from "./chunk-SHAMSMKQ.mjs";
8
8
 
9
9
  // src/translations.ts
10
10
  var translations = [
11
11
  {
12
12
  "en-US": {
13
- [DocumentType.typename]: {
13
+ [Markdown_exports.Document.typename]: {
14
14
  "typename label": "Document",
15
15
  "typename label_zero": "Documents",
16
16
  "typename label_one": "Document",
17
17
  "typename label_other": "Documents",
18
18
  "object name placeholder": "New document",
19
19
  "rename object label": "Rename document",
20
- "delete object label": "Delete document"
20
+ "delete object label": "Delete document",
21
+ "object deleted label": "Document deleted"
21
22
  },
22
23
  [meta.id]: {
23
24
  "plugin name": "Editor",
25
+ "settings title": "Editor settings",
24
26
  "choose markdown from space dialog title": "Choose one or more documents to add",
25
27
  // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)
26
28
  "empty choose markdown from space message": "None available; try creating a new one instead?",
@@ -41,7 +43,10 @@ var translations = [
41
43
  "default view mode label": "Default view mode",
42
44
  "upload image label": "Upload image",
43
45
  "fallback title": "Untitled",
44
- "navigate to document label": "Open document"
46
+ "navigate to document label": "Open document",
47
+ "words label_zero": "words",
48
+ "words label_one": "word",
49
+ "words label_other": "words"
45
50
  }
46
51
  }
47
52
  }
@@ -50,4 +55,4 @@ var translations = [
50
55
  export {
51
56
  translations
52
57
  };
53
- //# sourceMappingURL=chunk-VIR2ABYE.mjs.map
58
+ //# sourceMappingURL=chunk-I5JSQBPI.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/translations.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nimport { meta } from './meta';\nimport { Markdown } from './types';\n\nexport const translations = [\n {\n 'en-US': {\n [Markdown.Document.typename]: {\n 'typename label': 'Document',\n 'typename label_zero': 'Documents',\n 'typename label_one': 'Document',\n 'typename label_other': 'Documents',\n 'object name placeholder': 'New document',\n 'rename object label': 'Rename document',\n 'delete object label': 'Delete document',\n 'object deleted label': 'Document deleted',\n },\n [meta.id]: {\n 'plugin name': 'Editor',\n 'settings title': 'Editor settings',\n 'choose markdown from space dialog title': 'Choose one or more documents to add',\n // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)\n 'empty choose markdown from space message': 'None available; try creating a new one instead?',\n 'chooser done label': 'Add selected',\n 'editor placeholder': '',\n 'editor input mode label': 'Editor input mode',\n 'select editor input mode placeholder': 'Select editor input mode…',\n 'settings editor input mode default label': 'Default',\n 'settings editor input mode vim label': 'Vim',\n 'settings editor input mode vscode label': 'VS Code',\n 'settings toolbar label': 'Show toolbar',\n 'settings numbered headings label': 'Numbered headings',\n 'settings folding label': 'Folding',\n 'settings experimental label': 'Enable experimental features',\n 'settings debug label': 'Enable debugging features',\n 'settings debug placeholder': 'Typewriter script...',\n 'toggle view mode label': 'Toggle read-only',\n 'default view mode label': 'Default view mode',\n 'upload image label': 'Upload image',\n 'fallback title': 'Untitled',\n 'navigate to document label': 'Open document',\n 'words label_zero': 'words',\n 'words label_one': 'word',\n 'words label_other': 'words',\n },\n },\n },\n] as const satisfies Resource[];\n"],
5
+ "mappings": ";;;;;;;;;AASO,IAAMA,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,iBAASC,SAASC,QAAQ,GAAG;QAC5B,kBAAkB;QAClB,uBAAuB;QACvB,sBAAsB;QACtB,wBAAwB;QACxB,2BAA2B;QAC3B,uBAAuB;QACvB,uBAAuB;QACvB,wBAAwB;MAC1B;MACA,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,2CAA2C;;QAE3C,4CAA4C;QAC5C,sBAAsB;QACtB,sBAAsB;QACtB,2BAA2B;QAC3B,wCAAwC;QACxC,4CAA4C;QAC5C,wCAAwC;QACxC,2CAA2C;QAC3C,0BAA0B;QAC1B,oCAAoC;QACpC,0BAA0B;QAC1B,+BAA+B;QAC/B,wBAAwB;QACxB,8BAA8B;QAC9B,0BAA0B;QAC1B,2BAA2B;QAC3B,sBAAsB;QACtB,kBAAkB;QAClB,8BAA8B;QAC9B,oBAAoB;QACpB,mBAAmB;QACnB,qBAAqB;MACvB;IACF;EACF;;",
6
+ "names": ["translations", "Markdown", "Document", "typename", "meta", "id"]
7
+ }
@@ -0,0 +1,22 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/capabilities/index.ts
4
+ import { lazy } from "@dxos/app-framework";
5
+ var AnchorSort = lazy(() => import("./anchor-sort-W4HCTYUQ.mjs"));
6
+ var AppGraphSerializer = lazy(() => import("./app-graph-serializer-OCTHXWLF.mjs"));
7
+ var BlueprintDefinition = lazy(() => import("./blueprint-definition-2JV3WV22.mjs"));
8
+ var IntentResolver = lazy(() => import("./intent-resolver-DTBVWCNO.mjs"));
9
+ var ReactSurface = lazy(() => import("./react-surface-QWRT4SD6.mjs"));
10
+ var MarkdownSettings = lazy(() => import("./settings-IBFFCGNL.mjs"));
11
+ var MarkdownState = lazy(() => import("./state-K6EH7SRZ.mjs"));
12
+
13
+ export {
14
+ AnchorSort,
15
+ AppGraphSerializer,
16
+ BlueprintDefinition,
17
+ IntentResolver,
18
+ ReactSurface,
19
+ MarkdownSettings,
20
+ MarkdownState
21
+ };
22
+ //# sourceMappingURL=chunk-KM7KYV6W.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AnchorSort: any = lazy(() => import('./anchor-sort'));\nexport const AppGraphSerializer = lazy(() => import('./app-graph-serializer'));\nexport const BlueprintDefinition = lazy(() => import('./blueprint-definition'));\nexport const IntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\nexport const MarkdownSettings = lazy(() => import('./settings'));\nexport const MarkdownState = lazy(() => import('./state'));\n\nexport * from './blueprint-definition';\nexport * from './capabilities';\n"],
5
+ "mappings": ";;;AAIA,SAASA,YAAY;AAEd,IAAMC,aAAkBC,KAAK,MAAM,OAAO,4BAAA,CAAA;AAC1C,IAAMC,qBAAqBD,KAAK,MAAM,OAAO,qCAAA,CAAA;AAC7C,IAAME,sBAAsBF,KAAK,MAAM,OAAO,qCAAA,CAAA;AAC9C,IAAMG,iBAAiBH,KAAK,MAAM,OAAO,gCAAA,CAAA;AACzC,IAAMI,eAAeJ,KAAK,MAAM,OAAO,8BAAA,CAAA;AACvC,IAAMK,mBAAmBL,KAAK,MAAM,OAAO,yBAAA,CAAA;AAC3C,IAAMM,gBAAgBN,KAAK,MAAM,OAAO,sBAAA,CAAA;",
6
+ "names": ["lazy", "AnchorSort", "lazy", "AppGraphSerializer", "BlueprintDefinition", "IntentResolver", "ReactSurface", "MarkdownSettings", "MarkdownState"]
7
+ }
@@ -0,0 +1,108 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ MarkdownCapabilities
4
+ } from "./chunk-GMMVSXQ6.mjs";
5
+ import {
6
+ MarkdownEditor,
7
+ useLinkQuery
8
+ } from "./chunk-FR6RW6DH.mjs";
9
+ import {
10
+ Markdown_exports
11
+ } from "./chunk-YFRTKXTB.mjs";
12
+
13
+ // src/components/MarkdownContainer.tsx
14
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
15
+ import { Atom } from "@effect-atom/atom-react";
16
+ import React, { forwardRef, useMemo } from "react";
17
+ import { Capabilities } from "@dxos/app-framework";
18
+ import { useAppGraph, useCapabilities } from "@dxos/app-framework/react";
19
+ import { Obj } from "@dxos/echo";
20
+ import { getSpace } from "@dxos/react-client/echo";
21
+ import { StackItem } from "@dxos/react-ui-stack";
22
+ import { Text } from "@dxos/schema";
23
+ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ id, role, object, settings, extensionProviders, ...props }, forwardedRef) => {
24
+ var _effect = _useSignals();
25
+ try {
26
+ const space = getSpace(object);
27
+ const isDocument = Obj.instanceOf(Markdown_exports.Document, object);
28
+ const isText = Obj.instanceOf(Text.Text, object);
29
+ const attendableId = isDocument ? Obj.getDXN(object).toString() : void 0;
30
+ const otherExtensionProviders = useCapabilities(MarkdownCapabilities.Extensions);
31
+ const extensions = useMemo(() => {
32
+ if (!Obj.instanceOf(Markdown_exports.Document, object)) {
33
+ return [];
34
+ }
35
+ return [
36
+ ...otherExtensionProviders ?? [],
37
+ ...extensionProviders ?? []
38
+ ].flat().reduce((acc, provider) => {
39
+ const extension = typeof provider === "function" ? provider({
40
+ document: object
41
+ }) : provider;
42
+ if (extension) {
43
+ acc.push(extension);
44
+ }
45
+ return acc;
46
+ }, []);
47
+ }, [
48
+ extensionProviders,
49
+ otherExtensionProviders,
50
+ object
51
+ ]);
52
+ const { graph } = useAppGraph();
53
+ const customActions = useMemo(() => {
54
+ return Atom.make((get) => {
55
+ const actions = get(graph.actions(id));
56
+ const nodes = actions.filter((action) => action.properties.disposition === "toolbar");
57
+ const edges = nodes.map((node) => ({
58
+ source: "root",
59
+ target: node.id
60
+ }));
61
+ return {
62
+ nodes,
63
+ edges
64
+ };
65
+ });
66
+ }, [
67
+ graph
68
+ ]);
69
+ const [upload] = useCapabilities(Capabilities.FileUploader);
70
+ const handleFileUpload = useMemo(() => {
71
+ if (!space || !upload) {
72
+ return void 0;
73
+ }
74
+ return async (file) => upload(space, file);
75
+ }, [
76
+ space,
77
+ upload
78
+ ]);
79
+ const handleLinkQuery = useLinkQuery(space);
80
+ return /* @__PURE__ */ React.createElement(StackItem.Content, {
81
+ toolbar: settings.toolbar,
82
+ ref: forwardedRef
83
+ }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
84
+ id: attendableId ?? id,
85
+ object,
86
+ extensions,
87
+ onFileUpload: handleFileUpload,
88
+ onLinkQuery: handleLinkQuery,
89
+ ...props
90
+ }, settings.toolbar && /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
91
+ id: attendableId ?? id,
92
+ role,
93
+ customActions
94
+ }), /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
95
+ initialValue: isDocument ? object.content?.target?.content : isText ? object.content : object.text,
96
+ scrollPastEnd: role === "article"
97
+ }), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null)));
98
+ } finally {
99
+ _effect.f();
100
+ }
101
+ });
102
+ var MarkdownContainer_default = MarkdownContainer;
103
+
104
+ export {
105
+ MarkdownContainer,
106
+ MarkdownContainer_default
107
+ };
108
+ //# sourceMappingURL=chunk-KYWXTMKI.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/MarkdownContainer.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Extension } from '@codemirror/state';\nimport { Atom } from '@effect-atom/atom-react';\nimport React, { forwardRef, useMemo } from 'react';\n\nimport { Capabilities } from '@dxos/app-framework';\nimport { useAppGraph, useCapabilities } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownCapabilities } from '../capabilities';\nimport { type DocumentType, useLinkQuery } from '../hooks';\nimport { Markdown, type MarkdownPluginState } from '../types';\n\nimport { MarkdownEditor, type MarkdownEditorContentProps, type MarkdownEditorRootProps } from './MarkdownEditor';\n\nexport type MarkdownContainerProps = {\n role?: string;\n object: DocumentType;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n} & (Pick<MarkdownEditorRootProps, 'id' | 'viewMode' | 'onViewModeChange'> &\n Pick<MarkdownEditorContentProps, 'editorStateStore'> &\n Pick<MarkdownPluginState, 'extensionProviders'>);\n\nexport const MarkdownContainer = forwardRef<HTMLDivElement, MarkdownContainerProps>(\n ({ id, role, object, settings, extensionProviders, ...props }, forwardedRef) => {\n const space = getSpace(object);\n const isDocument = Obj.instanceOf(Markdown.Document, object);\n const isText = Obj.instanceOf(Text.Text, object);\n const attendableId = isDocument ? Obj.getDXN(object).toString() : undefined;\n\n // Extensions from other plugins.\n // TODO(burdon): Document MarkdownPluginState.extensionProviders\n const otherExtensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n const extensions = useMemo<Extension[]>(() => {\n if (!Obj.instanceOf(Markdown.Document, object)) {\n return [];\n }\n\n return [...(otherExtensionProviders ?? []), ...(extensionProviders ?? [])]\n .flat()\n .reduce((acc: Extension[], provider) => {\n const extension =\n typeof provider === 'function' ? provider({ document: object as Markdown.Document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []);\n }, [extensionProviders, otherExtensionProviders, object]);\n\n // Toolbar actions from app graph.\n const { graph } = useAppGraph();\n const customActions = useMemo(() => {\n return Atom.make((get) => {\n const actions = get(graph.actions(id));\n const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');\n const edges = nodes.map((node) => ({ source: 'root', target: node.id }));\n return { nodes, edges };\n });\n }, [graph]);\n\n // File upload.\n const [upload] = useCapabilities(Capabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (!space || !upload) {\n return undefined;\n }\n\n return async (file: File) => upload(space, file);\n }, [space, upload]);\n\n // Query for @ refs.\n const handleLinkQuery = useLinkQuery(space);\n\n return (\n <StackItem.Content toolbar={settings.toolbar} ref={forwardedRef}>\n <MarkdownEditor.Root\n id={attendableId ?? id}\n object={object}\n extensions={extensions}\n onFileUpload={handleFileUpload}\n onLinkQuery={handleLinkQuery}\n {...props}\n >\n {settings.toolbar && (\n <MarkdownEditor.Toolbar id={attendableId ?? id} role={role} customActions={customActions} />\n )}\n <MarkdownEditor.Content\n initialValue={isDocument ? object.content?.target?.content : isText ? object.content : object.text}\n scrollPastEnd={role === 'article'}\n />\n <MarkdownEditor.Blocks />\n </MarkdownEditor.Root>\n </StackItem.Content>\n );\n },\n);\n\nexport default MarkdownContainer;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;AAKA,SAASA,YAAY;AACrB,OAAOC,SAASC,YAAYC,eAAe;AAE3C,SAASC,oBAAoB;AAC7B,SAASC,aAAaC,uBAAuB;AAC7C,SAASC,WAAW;AACpB,SAASC,gBAAgB;AAEzB,SAASC,iBAAiB;AAC1B,SAASC,YAAY;AAiBd,IAAMC,oBAAoBC,2BAC/B,CAAC,EAAEC,IAAIC,MAAMC,QAAQC,UAAUC,oBAAoB,GAAGC,MAAAA,GAASC,iBAAAA;;;AAC7D,UAAMC,QAAQC,SAASN,MAAAA;AACvB,UAAMO,aAAaC,IAAIC,WAAWC,iBAASC,UAAUX,MAAAA;AACrD,UAAMY,SAASJ,IAAIC,WAAWI,KAAKA,MAAMb,MAAAA;AACzC,UAAMc,eAAeP,aAAaC,IAAIO,OAAOf,MAAAA,EAAQgB,SAAQ,IAAKC;AAIlE,UAAMC,0BAA0BC,gBAAgBC,qBAAqBC,UAAU;AAC/E,UAAMC,aAAaC,QAAqB,MAAA;AACtC,UAAI,CAACf,IAAIC,WAAWC,iBAASC,UAAUX,MAAAA,GAAS;AAC9C,eAAO,CAAA;MACT;AAEA,aAAO;WAAKkB,2BAA2B,CAAA;WAAShB,sBAAsB,CAAA;QACnEsB,KAAI,EACJC,OAAO,CAACC,KAAkBC,aAAAA;AACzB,cAAMC,YACJ,OAAOD,aAAa,aAAaA,SAAS;UAAEE,UAAU7B;QAA4B,CAAA,IAAK2B;AACzF,YAAIC,WAAW;AACbF,cAAII,KAAKF,SAAAA;QACX;AAEA,eAAOF;MACT,GAAG,CAAA,CAAE;IACT,GAAG;MAACxB;MAAoBgB;MAAyBlB;KAAO;AAGxD,UAAM,EAAE+B,MAAK,IAAKC,YAAAA;AAClB,UAAMC,gBAAgBV,QAAQ,MAAA;AAC5B,aAAOW,KAAKC,KAAK,CAACC,QAAAA;AAChB,cAAMC,UAAUD,IAAIL,MAAMM,QAAQvC,EAAAA,CAAAA;AAClC,cAAMwC,QAAQD,QAAQE,OAAO,CAACC,WAAWA,OAAOC,WAAWC,gBAAgB,SAAA;AAC3E,cAAMC,QAAQL,MAAMM,IAAI,CAACC,UAAU;UAAEC,QAAQ;UAAQC,QAAQF,KAAK/C;QAAG,EAAA;AACrE,eAAO;UAAEwC;UAAOK;QAAM;MACxB,CAAA;IACF,GAAG;MAACZ;KAAM;AAGV,UAAM,CAACiB,MAAAA,IAAU7B,gBAAgB8B,aAAaC,YAAY;AAC1D,UAAMC,mBAAmB5B,QAAQ,MAAA;AAC/B,UAAI,CAAClB,SAAS,CAAC2C,QAAQ;AACrB,eAAO/B;MACT;AAEA,aAAO,OAAOmC,SAAeJ,OAAO3C,OAAO+C,IAAAA;IAC7C,GAAG;MAAC/C;MAAO2C;KAAO;AAGlB,UAAMK,kBAAkBC,aAAajD,KAAAA;AAErC,WACE,sBAAA,cAACkD,UAAUC,SAAO;MAACC,SAASxD,SAASwD;MAASC,KAAKtD;OACjD,sBAAA,cAACuD,eAAeC,MAAI;MAClB9D,IAAIgB,gBAAgBhB;MACpBE;MACAsB;MACAuC,cAAcV;MACdW,aAAaT;MACZ,GAAGlD;OAEHF,SAASwD,WACR,sBAAA,cAACE,eAAeI,SAAO;MAACjE,IAAIgB,gBAAgBhB;MAAIC;MAAYkC;QAE9D,sBAAA,cAAC0B,eAAeH,SAAO;MACrBQ,cAAczD,aAAaP,OAAOiE,SAASlB,QAAQkB,UAAUrD,SAASZ,OAAOiE,UAAUjE,OAAOkE;MAC9FC,eAAepE,SAAS;QAE1B,sBAAA,cAAC4D,eAAeS,QAAM,IAAA,CAAA,CAAA;;;;AAI9B,CAAA;AAGF,IAAA,4BAAexE;",
6
+ "names": ["Atom", "React", "forwardRef", "useMemo", "Capabilities", "useAppGraph", "useCapabilities", "Obj", "getSpace", "StackItem", "Text", "MarkdownContainer", "forwardRef", "id", "role", "object", "settings", "extensionProviders", "props", "forwardedRef", "space", "getSpace", "isDocument", "Obj", "instanceOf", "Markdown", "Document", "isText", "Text", "attendableId", "getDXN", "toString", "undefined", "otherExtensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "extensions", "useMemo", "flat", "reduce", "acc", "provider", "extension", "document", "push", "graph", "useAppGraph", "customActions", "Atom", "make", "get", "actions", "nodes", "filter", "action", "properties", "disposition", "edges", "map", "node", "source", "target", "upload", "Capabilities", "FileUploader", "handleFileUpload", "file", "handleLinkQuery", "useLinkQuery", "StackItem", "Content", "toolbar", "ref", "MarkdownEditor", "Root", "onFileUpload", "onLinkQuery", "Toolbar", "initialValue", "content", "text", "scrollPastEnd", "Blocks"]
7
+ }
@@ -0,0 +1,112 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ MarkdownEditor
4
+ } from "./chunk-FR6RW6DH.mjs";
5
+ import {
6
+ getContentSnippet,
7
+ getFallbackName
8
+ } from "./chunk-6F6FCTIA.mjs";
9
+ import {
10
+ Markdown_exports
11
+ } from "./chunk-YFRTKXTB.mjs";
12
+ import {
13
+ meta
14
+ } from "./chunk-SHAMSMKQ.mjs";
15
+
16
+ // src/components/MarkdownCard/MarkdownCard.tsx
17
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
18
+ import * as Function from "effect/Function";
19
+ import React, { forwardRef, useCallback, useMemo } from "react";
20
+ import { LayoutAction, chain, createIntent } from "@dxos/app-framework";
21
+ import { useIntentDispatcher } from "@dxos/app-framework/react";
22
+ import { Obj } from "@dxos/echo";
23
+ import { IconButton, useTranslation } from "@dxos/react-ui";
24
+ import { Card } from "@dxos/react-ui-stack";
25
+ import { Text } from "@dxos/schema";
26
+ var MarkdownCard = /* @__PURE__ */ forwardRef(({ subject, role }, forwardedRef) => {
27
+ var _effect = _useSignals();
28
+ try {
29
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
30
+ const { t } = useTranslation(meta.id);
31
+ const snippet = useMemo(() => getSnippet(subject, t("fallback abstract")), [
32
+ subject
33
+ ]);
34
+ const info = getInfo(subject);
35
+ const handleNavigate = useCallback(() => {
36
+ void dispatch(Function.pipe(createIntent(LayoutAction.UpdatePopover, {
37
+ part: "popover",
38
+ subject: null,
39
+ options: {
40
+ state: false,
41
+ anchorId: ""
42
+ }
43
+ }), chain(LayoutAction.Open, {
44
+ part: "main",
45
+ subject: [
46
+ Obj.getDXN(subject).toString()
47
+ ]
48
+ })));
49
+ }, [
50
+ dispatch,
51
+ subject
52
+ ]);
53
+ return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
54
+ role,
55
+ ref: forwardedRef
56
+ }, /* @__PURE__ */ React.createElement(Card.Heading, {
57
+ classNames: "flex items-center"
58
+ }, getTitle(subject, t("fallback title")), /* @__PURE__ */ React.createElement("span", {
59
+ className: "grow"
60
+ }), /* @__PURE__ */ React.createElement(IconButton, {
61
+ iconOnly: true,
62
+ icon: "ph--arrow-right--regular",
63
+ label: t("navigate to document label"),
64
+ onClick: handleNavigate
65
+ })), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
66
+ classNames: "flex max-h-[300px] overflow-hidden"
67
+ }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
68
+ id: subject.id,
69
+ viewMode: "readonly"
70
+ }, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
71
+ initialValue: snippet,
72
+ slots: {},
73
+ classNames: "!bg-transparent"
74
+ }))), /* @__PURE__ */ React.createElement(Card.Text, {
75
+ classNames: "text-xs text-description"
76
+ }, info.words, " ", t("words label", {
77
+ count: info.words
78
+ })));
79
+ } finally {
80
+ _effect.f();
81
+ }
82
+ });
83
+ var getInfo = (subject) => {
84
+ const text = (Obj.instanceOf(Markdown_exports.Document, subject) ? subject.content?.target?.content : subject.content) ?? "";
85
+ return {
86
+ words: text.split(" ").length
87
+ };
88
+ };
89
+ var getTitle = (subject, fallback) => {
90
+ if (Obj.instanceOf(Markdown_exports.Document, subject)) {
91
+ const title = Obj.getLabel(subject);
92
+ return title ?? getFallbackName(subject.content?.target?.content ?? fallback);
93
+ } else if (Obj.instanceOf(Text.Text, subject)) {
94
+ return getFallbackName(subject.content);
95
+ }
96
+ };
97
+ var getSnippet = (subject, fallback) => {
98
+ if (Obj.instanceOf(Markdown_exports.Document, subject)) {
99
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
100
+ } else if (Obj.instanceOf(Text.Text, subject)) {
101
+ return getContentSnippet(subject.content ?? fallback);
102
+ }
103
+ };
104
+
105
+ // src/components/MarkdownCard/index.ts
106
+ var MarkdownCard_default = MarkdownCard;
107
+
108
+ export {
109
+ MarkdownCard,
110
+ MarkdownCard_default
111
+ };
112
+ //# sourceMappingURL=chunk-R3SGV4ES.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/MarkdownCard/MarkdownCard.tsx", "../../../src/components/MarkdownCard/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\nimport React, { forwardRef, useCallback, useMemo } from 'react';\n\nimport { LayoutAction, chain, createIntent } from '@dxos/app-framework';\nimport { useIntentDispatcher } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { type CardPreviewProps } from '@dxos/plugin-preview';\nimport { IconButton, useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui-stack';\nimport { Text } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet, getFallbackName } from '../../util';\nimport { MarkdownEditor } from '../MarkdownEditor';\n\nexport type MarkdownCardProps = CardPreviewProps<Markdown.Document | Text.Text>;\n\nexport const MarkdownCard = forwardRef<HTMLDivElement, MarkdownCardProps>(\n ({ subject, role }: MarkdownCardProps, forwardedRef) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { t } = useTranslation(meta.id);\n const snippet = useMemo(() => getSnippet(subject, t('fallback abstract')), [subject]);\n const info = getInfo(subject);\n\n // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.\n const handleNavigate = useCallback(() => {\n void dispatch(\n Function.pipe(\n createIntent(LayoutAction.UpdatePopover, {\n part: 'popover',\n subject: null,\n options: { state: false, anchorId: '' },\n }),\n chain(LayoutAction.Open, {\n part: 'main',\n subject: [Obj.getDXN(subject).toString()],\n }),\n ),\n );\n }, [dispatch, subject]);\n\n return (\n <Card.SurfaceRoot role={role} ref={forwardedRef}>\n <Card.Heading classNames='flex items-center'>\n {getTitle(subject, t('fallback title'))}\n <span className='grow' />\n <IconButton\n iconOnly\n icon='ph--arrow-right--regular'\n label={t('navigate to document label')}\n onClick={handleNavigate}\n />\n </Card.Heading>\n {snippet && (\n <Card.Text classNames='flex max-h-[300px] overflow-hidden'>\n <MarkdownEditor.Root id={subject.id} viewMode='readonly'>\n <MarkdownEditor.Content initialValue={snippet} slots={{}} classNames='!bg-transparent' />\n </MarkdownEditor.Root>\n </Card.Text>\n )}\n <Card.Text classNames='text-xs text-description'>\n {info.words} {t('words label', { count: info.words })}\n </Card.Text>\n </Card.SurfaceRoot>\n );\n },\n);\n\nconst getInfo = (subject: Markdown.Document | Text.Text) => {\n const text = (Obj.instanceOf(Markdown.Document, subject) ? subject.content?.target?.content : subject.content) ?? '';\n return { words: text.split(' ').length };\n};\n\n// TODO(burdon): Factor out.\nconst getTitle = (subject: Markdown.Document | Text.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n const title = Obj.getLabel(subject);\n return title ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getFallbackName(subject.content);\n }\n};\n\n// TODO(burdon): Factor out.\nconst getSnippet = (subject: Markdown.Document | Text.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback);\n }\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport * from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
5
+ "mappings": "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",
6
+ "names": ["Function", "React", "forwardRef", "useCallback", "useMemo", "LayoutAction", "chain", "createIntent", "useIntentDispatcher", "Obj", "IconButton", "useTranslation", "Card", "Text", "MarkdownCard", "forwardRef", "subject", "role", "forwardedRef", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "meta", "id", "snippet", "useMemo", "getSnippet", "info", "getInfo", "handleNavigate", "useCallback", "pipe", "createIntent", "LayoutAction", "UpdatePopover", "part", "options", "state", "anchorId", "chain", "Open", "Obj", "getDXN", "toString", "Card", "SurfaceRoot", "ref", "Heading", "classNames", "getTitle", "span", "className", "IconButton", "iconOnly", "icon", "label", "onClick", "Text", "MarkdownEditor", "Root", "viewMode", "Content", "initialValue", "slots", "words", "count", "text", "instanceOf", "Markdown", "Document", "content", "target", "split", "length", "fallback", "title", "getLabel", "getFallbackName", "getDescription", "getContentSnippet", "MarkdownCard"]
7
+ }
@@ -0,0 +1,29 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ var __defProp = Object.defineProperty;
3
+ var __export = (target, all) => {
4
+ for (var name in all)
5
+ __defProp(target, name, { get: all[name], enumerable: true });
6
+ };
7
+
8
+ // src/meta.ts
9
+ import { trim } from "@dxos/util";
10
+ var meta = {
11
+ id: "dxos.org/plugin/markdown",
12
+ name: "Markdown",
13
+ description: trim`
14
+ Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.
15
+ Supports AI-powered editing assistance and seamlessly integrates with other workspace objects.
16
+ `,
17
+ icon: "ph--text-aa--regular",
18
+ iconHue: "indigo",
19
+ source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-markdown",
20
+ screenshots: [
21
+ "https://dxos.network/plugin-details-markdown-dark.png"
22
+ ]
23
+ };
24
+
25
+ export {
26
+ __export,
27
+ meta
28
+ };
29
+ //# sourceMappingURL=chunk-SHAMSMKQ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/meta.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/markdown',\n name: 'Markdown',\n description: trim`\n Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.\n Supports AI-powered editing assistance and seamlessly integrates with other workspace objects.\n `,\n icon: 'ph--text-aa--regular',\n iconHue: 'indigo',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-markdown',\n screenshots: ['https://dxos.network/plugin-details-markdown-dark.png'],\n};\n"],
5
+ "mappings": ";;;;;;;;AAKA,SAASA,YAAY;AAEd,IAAMC,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;EACNC,SAAS;EACTC,QAAQ;EACRC,aAAa;IAAC;;AAChB;",
6
+ "names": ["trim", "meta", "id", "name", "description", "trim", "icon", "iconHue", "source", "screenshots"]
7
+ }