@dxos/plugin-markdown 0.8.4-main.69d29f4 → 0.8.4-main.6fa680abb7

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 (266) hide show
  1. package/dist/lib/browser/{chunk-VQ3WOAB6.mjs → MarkdownCard-KTTAKZAO.mjs} +28 -27
  2. package/dist/lib/browser/MarkdownCard-KTTAKZAO.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-KDKXFKDN.mjs → MarkdownContainer-DB5VCJSG.mjs} +45 -25
  4. package/dist/lib/browser/MarkdownContainer-DB5VCJSG.mjs.map +7 -0
  5. package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs +106 -0
  6. package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs.map +7 -0
  7. package/dist/lib/browser/{anchor-sort-WQ3TL7ZI.mjs → anchor-sort-KP3XOHL6.mjs} +6 -4
  8. package/dist/lib/browser/anchor-sort-KP3XOHL6.mjs.map +7 -0
  9. package/dist/lib/browser/{app-graph-serializer-ULZUJKOD.mjs → app-graph-serializer-QJVGW3AI.mjs} +9 -7
  10. package/dist/lib/browser/app-graph-serializer-QJVGW3AI.mjs.map +7 -0
  11. package/dist/lib/browser/blueprint-definition-GYGSMBAL.mjs +18 -0
  12. package/dist/lib/browser/blueprint-definition-GYGSMBAL.mjs.map +7 -0
  13. package/dist/lib/browser/blueprints/index.mjs +5 -4
  14. package/dist/lib/browser/{chunk-LMO5UVKL.mjs → chunk-2JGSYTNW.mjs} +29 -61
  15. package/dist/lib/browser/chunk-2JGSYTNW.mjs.map +7 -0
  16. package/dist/lib/browser/chunk-EY5RVGKO.mjs +178 -0
  17. package/dist/lib/browser/chunk-EY5RVGKO.mjs.map +7 -0
  18. package/dist/lib/browser/{chunk-BX73DASG.mjs → chunk-G2MHLFEL.mjs} +281 -205
  19. package/dist/lib/browser/chunk-G2MHLFEL.mjs.map +7 -0
  20. package/dist/lib/browser/{chunk-JOXYQLKH.mjs → chunk-NAJ3XQLK.mjs} +9 -4
  21. package/dist/lib/browser/chunk-NAJ3XQLK.mjs.map +7 -0
  22. package/dist/lib/browser/chunk-RYZHVXZ5.mjs +28 -0
  23. package/dist/lib/browser/chunk-RYZHVXZ5.mjs.map +7 -0
  24. package/dist/lib/browser/{chunk-CUGDX7KA.mjs → chunk-TIV2F6SR.mjs} +2 -2
  25. package/dist/lib/browser/cli/index.mjs +15 -13
  26. package/dist/lib/browser/cli/index.mjs.map +3 -3
  27. package/dist/lib/browser/index.mjs +44 -45
  28. package/dist/lib/browser/index.mjs.map +3 -3
  29. package/dist/lib/browser/meta.json +1 -1
  30. package/dist/lib/browser/{operation-resolver-EGCWOQKJ.mjs → operation-resolver-QLM762DE.mjs} +6 -18
  31. package/dist/lib/browser/operation-resolver-QLM762DE.mjs.map +7 -0
  32. package/dist/lib/browser/react-surface-3KWMKHEU.mjs +117 -0
  33. package/dist/lib/browser/react-surface-3KWMKHEU.mjs.map +7 -0
  34. package/dist/lib/browser/{settings-JY5JE7MI.mjs → settings-2PHGT4PJ.mjs} +8 -5
  35. package/dist/lib/browser/settings-2PHGT4PJ.mjs.map +7 -0
  36. package/dist/lib/browser/{state-QE7VSJWJ.mjs → state-KNJ7E36W.mjs} +7 -5
  37. package/dist/lib/{node-esm/state-LXE5XIN4.mjs.map → browser/state-KNJ7E36W.mjs.map} +2 -2
  38. package/dist/lib/browser/types/index.mjs +2 -1
  39. package/dist/lib/node-esm/{chunk-KXEQCFMB.mjs → MarkdownCard-EFCQQR22.mjs} +28 -27
  40. package/dist/lib/node-esm/MarkdownCard-EFCQQR22.mjs.map +7 -0
  41. package/dist/lib/node-esm/{chunk-3JYPCC7M.mjs → MarkdownContainer-X3UQUNWL.mjs} +45 -25
  42. package/dist/lib/node-esm/MarkdownContainer-X3UQUNWL.mjs.map +7 -0
  43. package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs +107 -0
  44. package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs.map +7 -0
  45. package/dist/lib/node-esm/{anchor-sort-G7D5TAI6.mjs → anchor-sort-4574EWPS.mjs} +6 -4
  46. package/dist/lib/node-esm/anchor-sort-4574EWPS.mjs.map +7 -0
  47. package/dist/lib/node-esm/{app-graph-serializer-W5YMQP7P.mjs → app-graph-serializer-CCMYKW2M.mjs} +9 -7
  48. package/dist/lib/node-esm/app-graph-serializer-CCMYKW2M.mjs.map +7 -0
  49. package/dist/lib/node-esm/blueprint-definition-TZPCKPPU.mjs +19 -0
  50. package/dist/lib/node-esm/blueprint-definition-TZPCKPPU.mjs.map +7 -0
  51. package/dist/lib/node-esm/blueprints/index.mjs +5 -4
  52. package/dist/lib/node-esm/{chunk-W3IIKDV5.mjs → chunk-4YMS5I4L.mjs} +2 -2
  53. package/dist/lib/node-esm/chunk-7UHD5AKT.mjs +179 -0
  54. package/dist/lib/node-esm/chunk-7UHD5AKT.mjs.map +7 -0
  55. package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs +29 -0
  56. package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs.map +7 -0
  57. package/dist/lib/node-esm/{chunk-44VJC3QF.mjs → chunk-QQF75YGF.mjs} +9 -4
  58. package/dist/lib/node-esm/chunk-QQF75YGF.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-D4BCFPKK.mjs → chunk-RKTB7TV3.mjs} +281 -205
  60. package/dist/lib/node-esm/chunk-RKTB7TV3.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-PRV35A7Z.mjs → chunk-XTF6AXHM.mjs} +29 -61
  62. package/dist/lib/node-esm/chunk-XTF6AXHM.mjs.map +7 -0
  63. package/dist/lib/node-esm/cli/index.mjs +15 -13
  64. package/dist/lib/node-esm/cli/index.mjs.map +3 -3
  65. package/dist/lib/node-esm/index.mjs +44 -45
  66. package/dist/lib/node-esm/index.mjs.map +3 -3
  67. package/dist/lib/node-esm/meta.json +1 -1
  68. package/dist/lib/node-esm/{operation-resolver-2HIS2AQZ.mjs → operation-resolver-IYXA7HEG.mjs} +6 -18
  69. package/dist/lib/node-esm/operation-resolver-IYXA7HEG.mjs.map +7 -0
  70. package/dist/lib/node-esm/react-surface-CYC6UH4E.mjs +118 -0
  71. package/dist/lib/node-esm/react-surface-CYC6UH4E.mjs.map +7 -0
  72. package/dist/lib/node-esm/{settings-4UGMPIRY.mjs → settings-4HAQICPV.mjs} +8 -5
  73. package/dist/lib/node-esm/settings-4HAQICPV.mjs.map +7 -0
  74. package/dist/lib/node-esm/{state-LXE5XIN4.mjs → state-XAMY5RVG.mjs} +7 -5
  75. package/dist/lib/{browser/state-QE7VSJWJ.mjs.map → node-esm/state-XAMY5RVG.mjs.map} +2 -2
  76. package/dist/lib/node-esm/types/index.mjs +2 -1
  77. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  78. package/dist/types/src/blueprints/functions/create.d.ts.map +1 -1
  79. package/dist/types/src/blueprints/functions/index.d.ts +41 -3
  80. package/dist/types/src/blueprints/functions/index.d.ts.map +1 -1
  81. package/dist/types/src/blueprints/functions/open.d.ts +8 -1
  82. package/dist/types/src/blueprints/functions/open.d.ts.map +1 -1
  83. package/dist/types/src/blueprints/functions/update.d.ts +16 -3
  84. package/dist/types/src/blueprints/functions/update.d.ts.map +1 -1
  85. package/dist/types/src/blueprints/index.d.ts +1 -1
  86. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  87. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  88. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +3 -2
  90. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +1 -1
  91. package/dist/types/src/capabilities/anchor-sort/index.d.ts +1 -1
  92. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +1 -1
  93. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +2 -2
  94. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +1 -1
  95. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +1 -1
  96. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +1 -1
  97. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +1 -1
  98. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +1 -1
  99. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +3 -7
  100. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -1
  101. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +1 -1
  102. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -1
  103. package/dist/types/src/capabilities/operation-resolver/index.d.ts +1 -1
  104. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -1
  105. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +2 -2
  106. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -1
  107. package/dist/types/src/capabilities/react-surface/index.d.ts +1 -1
  108. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -1
  109. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +2 -2
  110. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -1
  111. package/dist/types/src/capabilities/settings/index.d.ts +1 -1
  112. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -1
  113. package/dist/types/src/capabilities/settings/settings.d.ts +3 -2
  114. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -1
  115. package/dist/types/src/capabilities/state/state.d.ts +1 -1
  116. package/dist/types/src/cli/plugin.d.ts.map +1 -1
  117. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
  118. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  119. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +4 -3
  120. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  121. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +1 -1
  122. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  123. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +2 -0
  124. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  125. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +5 -5
  126. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  127. package/dist/types/src/components/index.d.ts +1 -8
  128. package/dist/types/src/components/index.d.ts.map +1 -1
  129. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  130. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  131. package/dist/types/src/{components → containers}/MarkdownCard/index.d.ts +0 -1
  132. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  133. package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.d.ts +6 -6
  134. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  135. package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.d.ts +31 -1
  136. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  137. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  138. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  139. package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  140. package/dist/types/src/containers/MarkdownSettings/index.d.ts +3 -0
  141. package/dist/types/src/containers/MarkdownSettings/index.d.ts.map +1 -0
  142. package/dist/types/src/containers/index.d.ts +6 -0
  143. package/dist/types/src/containers/index.d.ts.map +1 -0
  144. package/dist/types/src/hooks/useExtensions.d.ts +3 -3
  145. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  146. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
  147. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  148. package/dist/types/src/index.d.ts +1 -0
  149. package/dist/types/src/index.d.ts.map +1 -1
  150. package/dist/types/src/translations.d.ts +30 -0
  151. package/dist/types/src/translations.d.ts.map +1 -1
  152. package/dist/types/src/types/Markdown.d.ts +1 -1
  153. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  154. package/dist/types/src/types/MarkdownAction.d.ts +2 -22
  155. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  156. package/dist/types/src/types/events.d.ts.map +1 -1
  157. package/dist/types/src/util.d.ts +1 -1
  158. package/dist/types/src/util.d.ts.map +1 -1
  159. package/dist/types/tsconfig.tsbuildinfo +1 -1
  160. package/package.json +67 -60
  161. package/src/MarkdownPlugin.tsx +24 -35
  162. package/src/blueprints/functions/create.conversations.json +1 -1
  163. package/src/blueprints/functions/create.test.ts +24 -57
  164. package/src/blueprints/functions/create.ts +6 -5
  165. package/src/blueprints/functions/index.ts +11 -3
  166. package/src/blueprints/functions/open.ts +10 -10
  167. package/src/blueprints/functions/update.conversations.json +1 -1
  168. package/src/blueprints/functions/update.test.ts +133 -67
  169. package/src/blueprints/functions/update.ts +54 -13
  170. package/src/blueprints/index.ts +1 -1
  171. package/src/blueprints/markdown-blueprint.ts +14 -6
  172. package/src/capabilities/anchor-sort/anchor-sort.ts +3 -2
  173. package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +5 -4
  174. package/src/capabilities/artifact-definition/artifact-definition.ts +2 -2
  175. package/src/capabilities/blueprint-definition/blueprint-definition.ts +6 -14
  176. package/src/capabilities/operation-resolver/operation-resolver.ts +3 -14
  177. package/src/capabilities/react-surface/react-surface.tsx +30 -19
  178. package/src/capabilities/settings/settings.ts +3 -2
  179. package/src/capabilities/state/state.ts +2 -2
  180. package/src/cli/plugin.ts +5 -5
  181. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  182. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +25 -22
  183. package/src/components/MarkdownEditor/MarkdownEditor.tsx +43 -15
  184. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +6 -5
  185. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +13 -12
  186. package/src/components/index.ts +2 -14
  187. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +17 -7
  188. package/src/{components → containers}/MarkdownCard/MarkdownCard.tsx +24 -25
  189. package/src/{components → containers}/MarkdownCard/index.ts +0 -2
  190. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +22 -9
  191. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.tsx +57 -34
  192. package/src/containers/MarkdownContainer/index.ts +6 -0
  193. package/src/{components → containers}/MarkdownSettings/MarkdownSettings.tsx +24 -24
  194. package/src/containers/MarkdownSettings/index.ts +7 -0
  195. package/src/containers/index.ts +11 -0
  196. package/src/hooks/useEditorMenuOptions.ts +1 -1
  197. package/src/hooks/useExtensions.tsx +52 -89
  198. package/src/hooks/useLinkQuery.ts +3 -3
  199. package/src/hooks/useSelectCurrentThread.tsx +6 -6
  200. package/src/index.ts +2 -0
  201. package/src/meta.ts +1 -1
  202. package/src/testing.ts +2 -2
  203. package/src/translations.ts +3 -0
  204. package/src/types/Markdown.ts +13 -5
  205. package/src/types/MarkdownAction.ts +3 -18
  206. package/src/types/capabilities.ts +4 -4
  207. package/src/types/events.ts +4 -3
  208. package/src/util.tsx +2 -2
  209. package/dist/lib/browser/MarkdownCard-HFNNE4B4.mjs +0 -12
  210. package/dist/lib/browser/MarkdownCard-HFNNE4B4.mjs.map +0 -7
  211. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
  212. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs.map +0 -7
  213. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
  214. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
  215. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
  216. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
  217. package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
  218. package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
  219. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
  220. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
  221. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
  222. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
  223. package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
  224. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
  225. package/dist/lib/browser/chunk-VQ3WOAB6.mjs.map +0 -7
  226. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
  227. package/dist/lib/browser/react-surface-64FZ7T7F.mjs +0 -213
  228. package/dist/lib/browser/react-surface-64FZ7T7F.mjs.map +0 -7
  229. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
  230. package/dist/lib/node-esm/MarkdownCard-GMNXUWWR.mjs +0 -13
  231. package/dist/lib/node-esm/MarkdownCard-GMNXUWWR.mjs.map +0 -7
  232. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
  233. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
  234. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
  235. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
  236. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
  237. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
  238. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
  239. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
  240. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
  241. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
  242. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
  243. package/dist/lib/node-esm/chunk-KXEQCFMB.mjs.map +0 -7
  244. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
  245. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
  246. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
  247. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
  248. package/dist/lib/node-esm/react-surface-PKEVHTJK.mjs +0 -214
  249. package/dist/lib/node-esm/react-surface-PKEVHTJK.mjs.map +0 -7
  250. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
  251. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  252. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  253. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  254. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  255. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  256. package/dist/types/src/components/MarkdownSettings/index.d.ts +0 -2
  257. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +0 -1
  258. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  259. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  260. package/src/components/MarkdownSettings/index.ts +0 -5
  261. package/src/components/Suggestions.stories.tsx +0 -215
  262. /package/dist/lib/browser/{chunk-CUGDX7KA.mjs.map → chunk-TIV2F6SR.mjs.map} +0 -0
  263. /package/dist/lib/node-esm/{chunk-W3IIKDV5.mjs.map → chunk-4YMS5I4L.mjs.map} +0 -0
  264. /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +0 -0
  265. /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +0 -0
  266. /package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts +0 -0
@@ -1,12 +1,15 @@
1
1
  import {
2
2
  MarkdownCapabilities,
3
- Markdown_exports,
3
+ Markdown_exports
4
+ } from "./chunk-2JGSYTNW.mjs";
5
+ import {
4
6
  meta
5
- } from "./chunk-LMO5UVKL.mjs";
7
+ } from "./chunk-RYZHVXZ5.mjs";
6
8
 
7
9
  // src/capabilities/settings/settings.ts
8
10
  import * as Effect from "effect/Effect";
9
- import { Capability, Common } from "@dxos/app-framework";
11
+ import { Capability } from "@dxos/app-framework";
12
+ import { AppCapabilities } from "@dxos/app-toolkit";
10
13
  import { createKvsStore } from "@dxos/effect";
11
14
  var settings_default = Capability.makeModule(() => Effect.sync(() => {
12
15
  const settingsAtom = createKvsStore({
@@ -22,7 +25,7 @@ var settings_default = Capability.makeModule(() => Effect.sync(() => {
22
25
  });
23
26
  return [
24
27
  Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),
25
- Capability.contributes(Common.Capability.Settings, {
28
+ Capability.contributes(AppCapabilities.Settings, {
26
29
  prefix: meta.id,
27
30
  schema: Markdown_exports.Settings,
28
31
  atom: settingsAtom
@@ -32,4 +35,4 @@ var settings_default = Capability.makeModule(() => Effect.sync(() => {
32
35
  export {
33
36
  settings_default as default
34
37
  };
35
- //# sourceMappingURL=settings-JY5JE7MI.mjs.map
38
+ //# sourceMappingURL=settings-2PHGT4PJ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/settings/settings.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { createKvsStore } from '@dxos/effect';\n\nimport { meta } from '../../meta';\nimport { Markdown, MarkdownCapabilities } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.sync(() => {\n const settingsAtom = createKvsStore({\n key: meta.id,\n schema: Markdown.Settings,\n defaultValue: () => ({\n defaultViewMode: 'preview' as const,\n toolbar: true,\n numberedHeadings: true,\n folding: true,\n experimental: false,\n }),\n });\n\n return [\n Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),\n Capability.contributes(AppCapabilities.Settings, {\n prefix: meta.id,\n schema: Markdown.Settings,\n atom: settingsAtom,\n }),\n ];\n }),\n);\n"],
5
+ "mappings": ";;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,sBAAsB;AAK/B,IAAA,mBAAeC,WAAWC,WAAW,MAC5BC,YAAK,MAAA;AACV,QAAMC,eAAeC,eAAe;IAClCC,KAAKC,KAAKC;IACVC,QAAQC,iBAASC;IACjBC,cAAc,OAAO;MACnBC,iBAAiB;MACjBC,SAAS;MACTC,kBAAkB;MAClBC,SAAS;MACTC,cAAc;IAChB;EACF,CAAA;AAEA,SAAO;IACLhB,WAAWiB,YAAYC,qBAAqBR,UAAUP,YAAAA;IACtDH,WAAWiB,YAAYE,gBAAgBT,UAAU;MAC/CU,QAAQd,KAAKC;MACbC,QAAQC,iBAASC;MACjBW,MAAMlB;IACR,CAAA;;AAEJ,CAAA,CAAA;",
6
+ "names": ["Effect", "Capability", "AppCapabilities", "createKvsStore", "Capability", "makeModule", "sync", "settingsAtom", "createKvsStore", "key", "meta", "id", "schema", "Markdown", "Settings", "defaultValue", "defaultViewMode", "toolbar", "numberedHeadings", "folding", "experimental", "contributes", "MarkdownCapabilities", "AppCapabilities", "prefix", "atom"]
7
+ }
@@ -1,8 +1,10 @@
1
1
  import {
2
2
  MarkdownCapabilities,
3
- MarkdownStateSchema,
3
+ MarkdownStateSchema
4
+ } from "./chunk-2JGSYTNW.mjs";
5
+ import {
4
6
  meta
5
- } from "./chunk-LMO5UVKL.mjs";
7
+ } from "./chunk-RYZHVXZ5.mjs";
6
8
 
7
9
  // src/capabilities/state/state.ts
8
10
  import * as Effect from "effect/Effect";
@@ -11,13 +13,13 @@ import { createKvsStore } from "@dxos/effect";
11
13
  import { createEditorStateStore } from "@dxos/ui-editor";
12
14
  var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
13
15
  const stateAtom = createKvsStore({
14
- key: `${meta.id}/state`,
16
+ key: `${meta.id}.state`,
15
17
  schema: MarkdownStateSchema,
16
18
  defaultValue: () => ({
17
19
  viewMode: {}
18
20
  })
19
21
  });
20
- const editorState = createEditorStateStore(`${meta.id}/editor`);
22
+ const editorState = createEditorStateStore(`${meta.id}.editor`);
21
23
  return [
22
24
  Capability.contributes(MarkdownCapabilities.State, stateAtom),
23
25
  Capability.contributes(MarkdownCapabilities.EditorState, editorState)
@@ -26,4 +28,4 @@ var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
26
28
  export {
27
29
  state_default as default
28
30
  };
29
- //# sourceMappingURL=state-QE7VSJWJ.mjs.map
31
+ //# sourceMappingURL=state-KNJ7E36W.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/capabilities/state/state.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { createKvsStore } from '@dxos/effect';\nimport { createEditorStateStore } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { MarkdownCapabilities, MarkdownStateSchema } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n // Persisted state using KVS store.\n const stateAtom = createKvsStore({\n key: `${meta.id}/state`,\n schema: MarkdownStateSchema,\n defaultValue: () => ({ viewMode: {} }),\n });\n\n // TODO(wittjosiah): Fold into state.\n const editorState = createEditorStateStore(`${meta.id}/editor`);\n\n return [\n Capability.contributes(MarkdownCapabilities.State, stateAtom),\n Capability.contributes(MarkdownCapabilities.EditorState, editorState),\n ];\n }),\n);\n"],
5
- "mappings": ";;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,8BAA8B;AAKvC,IAAA,gBAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAEhB,QAAMC,YAAYC,eAAe;IAC/BC,KAAK,GAAGC,KAAKC,EAAE;IACfC,QAAQC;IACRC,cAAc,OAAO;MAAEC,UAAU,CAAC;IAAE;EACtC,CAAA;AAGA,QAAMC,cAAcC,uBAAuB,GAAGP,KAAKC,EAAE,SAAS;AAE9D,SAAO;IACLP,WAAWc,YAAYC,qBAAqBC,OAAOb,SAAAA;IACnDH,WAAWc,YAAYC,qBAAqBE,aAAaL,WAAAA;;AAE7D,CAAA,CAAA;",
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { createKvsStore } from '@dxos/effect';\nimport { createEditorStateStore } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { MarkdownCapabilities, MarkdownStateSchema } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n // Persisted state using KVS store.\n const stateAtom = createKvsStore({\n key: `${meta.id}.state`,\n schema: MarkdownStateSchema,\n defaultValue: () => ({ viewMode: {} }),\n });\n\n // TODO(wittjosiah): Fold into state.\n const editorState = createEditorStateStore(`${meta.id}.editor`);\n\n return [\n Capability.contributes(MarkdownCapabilities.State, stateAtom),\n Capability.contributes(MarkdownCapabilities.EditorState, editorState),\n ];\n }),\n);\n"],
5
+ "mappings": ";;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,8BAA8B;AAKvC,IAAA,gBAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAEhB,QAAMC,YAAYC,eAAe;IAC/BC,KAAK,GAAGC,KAAKC,EAAE;IACfC,QAAQC;IACRC,cAAc,OAAO;MAAEC,UAAU,CAAC;IAAE;EACtC,CAAA;AAGA,QAAMC,cAAcC,uBAAuB,GAAGP,KAAKC,EAAE,SAAS;AAE9D,SAAO;IACLP,WAAWc,YAAYC,qBAAqBC,OAAOb,SAAAA;IACnDH,WAAWc,YAAYC,qBAAqBE,aAAaL,WAAAA;;AAE7D,CAAA,CAAA;",
6
6
  "names": ["Effect", "Capability", "createKvsStore", "createEditorStateStore", "Capability", "makeModule", "fnUntraced", "stateAtom", "createKvsStore", "key", "meta", "id", "schema", "MarkdownStateSchema", "defaultValue", "viewMode", "editorState", "createEditorStateStore", "contributes", "MarkdownCapabilities", "State", "EditorState"]
7
7
  }
@@ -5,7 +5,8 @@ import {
5
5
  MarkdownOperation,
6
6
  MarkdownStateSchema,
7
7
  Markdown_exports
8
- } from "../chunk-LMO5UVKL.mjs";
8
+ } from "../chunk-2JGSYTNW.mjs";
9
+ import "../chunk-RYZHVXZ5.mjs";
9
10
  export {
10
11
  Markdown_exports as Markdown,
11
12
  MarkdownAction_exports as MarkdownAction,
@@ -1,20 +1,20 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- MarkdownEditor
4
- } from "./chunk-D4BCFPKK.mjs";
5
- import {
3
+ MarkdownEditor,
6
4
  getContentSnippet
7
- } from "./chunk-SDTYEGGL.mjs";
5
+ } from "./chunk-RKTB7TV3.mjs";
6
+ import {
7
+ Markdown_exports
8
+ } from "./chunk-XTF6AXHM.mjs";
8
9
  import {
9
- Markdown_exports,
10
10
  meta
11
- } from "./chunk-PRV35A7Z.mjs";
11
+ } from "./chunk-CW4FZNMZ.mjs";
12
12
 
13
- // src/components/MarkdownCard/MarkdownCard.tsx
13
+ // src/containers/MarkdownCard/MarkdownCard.tsx
14
14
  import React, { useMemo } from "react";
15
15
  import { Obj } from "@dxos/echo";
16
16
  import { useTranslation } from "@dxos/react-ui";
17
- import { Card } from "@dxos/react-ui-mosaic";
17
+ import { Card } from "@dxos/react-ui";
18
18
  import { Text } from "@dxos/schema";
19
19
  var MarkdownCard = ({ subject }) => {
20
20
  const { t } = useTranslation(meta.id);
@@ -22,20 +22,30 @@ var MarkdownCard = ({ subject }) => {
22
22
  subject
23
23
  ]);
24
24
  const info = getInfo(subject);
25
- return /* @__PURE__ */ React.createElement(Card.Content, null, snippet && /* @__PURE__ */ React.createElement("div", {
26
- className: "max-h-[300px] overflow-hidden"
27
- }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
25
+ return /* @__PURE__ */ React.createElement(Card.Content, null, snippet && /* @__PURE__ */ React.createElement(Card.Section, null, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
28
26
  id: subject.id,
29
27
  viewMode: "readonly"
30
28
  }, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
31
29
  initialValue: snippet,
32
- slots: {},
33
- classNames: "!bg-transparent"
34
- }))), /* @__PURE__ */ React.createElement(Card.Text, {
30
+ classNames: "bg-transparent",
31
+ slots: {
32
+ editor: {
33
+ className: "max-h-[240px]"
34
+ }
35
+ }
36
+ }))), /* @__PURE__ */ React.createElement(Card.Section, null, /* @__PURE__ */ React.createElement(Card.Text, {
35
37
  classNames: "text-xs text-description"
36
38
  }, info.words, " ", t("words label", {
37
39
  count: info.words
38
- })));
40
+ }))));
41
+ };
42
+ var MAX_LINES = 5;
43
+ var getSnippet = (subject, fallback) => {
44
+ if (Obj.instanceOf(Markdown_exports.Document, subject)) {
45
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, MAX_LINES);
46
+ } else if (Obj.instanceOf(Text.Text, subject)) {
47
+ return getContentSnippet(subject.content ?? fallback, MAX_LINES);
48
+ }
39
49
  };
40
50
  var getInfo = (subject) => {
41
51
  const text = (Obj.instanceOf(Markdown_exports.Document, subject) ? subject.content?.target?.content : subject.content) ?? "";
@@ -43,19 +53,10 @@ var getInfo = (subject) => {
43
53
  words: text.split(" ").length
44
54
  };
45
55
  };
46
- var getSnippet = (subject, fallback) => {
47
- if (Obj.instanceOf(Markdown_exports.Document, subject)) {
48
- return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
49
- } else if (Obj.instanceOf(Text.Text, subject)) {
50
- return getContentSnippet(subject.content ?? fallback);
51
- }
52
- };
53
56
 
54
- // src/components/MarkdownCard/index.ts
57
+ // src/containers/MarkdownCard/index.ts
55
58
  var MarkdownCard_default = MarkdownCard;
56
-
57
59
  export {
58
- MarkdownCard,
59
- MarkdownCard_default
60
+ MarkdownCard_default as default
60
61
  };
61
- //# sourceMappingURL=chunk-KXEQCFMB.mjs.map
62
+ //# sourceMappingURL=MarkdownCard-EFCQQR22.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownCard/MarkdownCard.tsx", "../../../src/containers/MarkdownCard/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Obj } from '@dxos/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownEditor } from '../../components';\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet } from '../../util';\n\nexport type MarkdownCardProps = { subject: Markdown.Document | Text.Text };\n\nexport const MarkdownCard = ({ subject }: MarkdownCardProps) => {\n const { t } = useTranslation(meta.id);\n const snippet = useMemo(() => getSnippet(subject), [subject]);\n const info = getInfo(subject);\n\n return (\n <Card.Content>\n {snippet && (\n <Card.Section>\n <MarkdownEditor.Root id={subject.id} viewMode='readonly'>\n <MarkdownEditor.Content\n initialValue={snippet}\n classNames='bg-transparent'\n slots={{\n editor: { className: 'max-h-[240px]' },\n }}\n />\n </MarkdownEditor.Root>\n </Card.Section>\n )}\n <Card.Section>\n <Card.Text classNames='text-xs text-description'>\n {info.words} {t('words label', { count: info.words })}\n </Card.Text>\n </Card.Section>\n </Card.Content>\n );\n};\n\nconst MAX_LINES = 5;\n\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, MAX_LINES);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback, MAX_LINES);\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// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
5
+ "mappings": ";;;;;;;;;;;;;AAIA,OAAOA,SAASC,eAAe;AAE/B,SAASC,WAAW;AACpB,SAASC,sBAAsB;AAC/B,SAASC,YAAY;AACrB,SAASC,YAAY;AASd,IAAMC,eAAe,CAAC,EAAEC,QAAO,MAAqB;AACzD,QAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,QAAMC,UAAUC,QAAQ,MAAMC,WAAWP,OAAAA,GAAU;IAACA;GAAQ;AAC5D,QAAMQ,OAAOC,QAAQT,OAAAA;AAErB,SACE,sBAAA,cAACU,KAAKC,SAAO,MACVN,WACC,sBAAA,cAACK,KAAKE,SAAO,MACX,sBAAA,cAACC,eAAeC,MAAI;IAACV,IAAIJ,QAAQI;IAAIW,UAAS;KAC5C,sBAAA,cAACF,eAAeF,SAAO;IACrBK,cAAcX;IACdY,YAAW;IACXC,OAAO;MACLC,QAAQ;QAAEC,WAAW;MAAgB;IACvC;QAKR,sBAAA,cAACV,KAAKE,SAAO,MACX,sBAAA,cAACF,KAAKW,MAAI;IAACJ,YAAW;KACnBT,KAAKc,OAAM,KAAErB,EAAE,eAAe;IAAEsB,OAAOf,KAAKc;EAAM,CAAA,CAAA,CAAA,CAAA;AAK7D;AAEA,IAAME,YAAY;AAElB,IAAMjB,aAAa,CAACP,SAAwCyB,aAAAA;AAC1D,MAAIC,IAAIC,WAAWC,iBAASC,UAAU7B,OAAAA,GAAU;AAC9C,WAAO0B,IAAII,eAAe9B,OAAAA,KAAY+B,kBAAkB/B,QAAQgC,SAASC,QAAQD,WAAWP,UAAUD,SAAAA;EACxG,WAAWE,IAAIC,WAAWN,KAAKA,MAAMrB,OAAAA,GAAU;AAC7C,WAAO+B,kBAAkB/B,QAAQgC,WAAWP,UAAUD,SAAAA;EACxD;AACF;AAEA,IAAMf,UAAU,CAACT,YAAAA;AACf,QAAMkC,QAAQR,IAAIC,WAAWC,iBAASC,UAAU7B,OAAAA,IAAWA,QAAQgC,SAASC,QAAQD,UAAUhC,QAAQgC,YAAY;AAClH,SAAO;IAAEV,OAAOY,KAAKC,MAAM,GAAA,EAAKC;EAAO;AACzC;;;ACtDA,IAAA,uBAAeC;",
6
+ "names": ["React", "useMemo", "Obj", "useTranslation", "Card", "Text", "MarkdownCard", "subject", "t", "useTranslation", "meta", "id", "snippet", "useMemo", "getSnippet", "info", "getInfo", "Card", "Content", "Section", "MarkdownEditor", "Root", "viewMode", "initialValue", "classNames", "slots", "editor", "className", "Text", "words", "count", "MAX_LINES", "fallback", "Obj", "instanceOf", "Markdown", "Document", "getDescription", "getContentSnippet", "content", "target", "text", "split", "length", "MarkdownCard"]
7
+ }
@@ -2,25 +2,26 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  MarkdownEditor,
4
4
  useLinkQuery
5
- } from "./chunk-D4BCFPKK.mjs";
5
+ } from "./chunk-RKTB7TV3.mjs";
6
6
  import {
7
7
  MarkdownCapabilities,
8
8
  Markdown_exports
9
- } from "./chunk-PRV35A7Z.mjs";
9
+ } from "./chunk-XTF6AXHM.mjs";
10
+ import "./chunk-CW4FZNMZ.mjs";
10
11
 
11
- // src/components/MarkdownContainer.tsx
12
+ // src/containers/MarkdownContainer/MarkdownContainer.tsx
12
13
  import { Atom } from "@effect-atom/atom-react";
13
- import React, { forwardRef, useMemo } from "react";
14
- import { Common } from "@dxos/app-framework";
15
- import { useAppGraph, useCapabilities } from "@dxos/app-framework/react";
14
+ import React, { forwardRef, useCallback, useMemo } from "react";
15
+ import { useCapabilities, useOperationInvoker } from "@dxos/app-framework/ui";
16
+ import { AppCapabilities, LayoutOperation } from "@dxos/app-toolkit";
17
+ import { useAppGraph } from "@dxos/app-toolkit/ui";
16
18
  import { Obj } from "@dxos/echo";
17
19
  import { useActionRunner } from "@dxos/plugin-graph";
18
20
  import { useObject } from "@dxos/react-client/echo";
19
- import { Layout } from "@dxos/react-ui-mosaic";
21
+ import { Panel } from "@dxos/react-ui";
20
22
  import { Text } from "@dxos/schema";
21
- var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id, settings, extensionProviders, ...props }, forwardedRef) => {
23
+ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id, attendableId, settings, extensionProviders, onSelectObject, ...props }, forwardedRef) => {
22
24
  const db = Obj.isObject(object) ? Obj.getDatabase(object) : void 0;
23
- const attendableId = Obj.instanceOf(Markdown_exports.Document, object) ? Obj.getDXN(object).toString() : void 0;
24
25
  const [docContent] = useObject(Obj.instanceOf(Markdown_exports.Document, object) ? object.content : void 0, "content");
25
26
  const [textContent] = useObject(Obj.instanceOf(Text.Text, object) ? object : void 0, "content");
26
27
  const initialValue = docContent ?? textContent;
@@ -50,11 +51,12 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
50
51
  const runAction = useActionRunner();
51
52
  const customActions = useMemo(() => {
52
53
  return Atom.make((get) => {
53
- const actions = get(graph.actions(id));
54
+ const actions = get(graph.actions(attendableId ?? id));
54
55
  const nodes = actions.filter((action) => action.properties.disposition === "toolbar");
55
56
  const edges = nodes.map((node) => ({
56
57
  source: "root",
57
- target: node.id
58
+ target: node.id,
59
+ relation: "child"
58
60
  }));
59
61
  return {
60
62
  nodes,
@@ -64,7 +66,7 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
64
66
  }, [
65
67
  graph
66
68
  ]);
67
- const [upload] = useCapabilities(Common.Capability.FileUploader);
69
+ const [upload] = useCapabilities(AppCapabilities.FileUploader);
68
70
  const handleFileUpload = useMemo(() => {
69
71
  if (!db || !upload) {
70
72
  return void 0;
@@ -75,31 +77,49 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
75
77
  upload
76
78
  ]);
77
79
  const handleLinkQuery = useLinkQuery(db);
78
- return /* @__PURE__ */ React.createElement(Layout.Main, {
79
- toolbar: settings.toolbar,
80
- ref: forwardedRef
81
- }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
82
- id: attendableId ?? id,
80
+ const { invokePromise } = useOperationInvoker();
81
+ const handleSelectObject = useCallback((targetId) => {
82
+ if (onSelectObject) {
83
+ onSelectObject(targetId);
84
+ } else {
85
+ void invokePromise?.(LayoutOperation.Open, {
86
+ subject: [
87
+ targetId
88
+ ],
89
+ pivotId: attendableId
90
+ });
91
+ }
92
+ }, [
93
+ onSelectObject,
94
+ invokePromise,
95
+ object,
96
+ id
97
+ ]);
98
+ return /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
99
+ id,
100
+ attendableId,
83
101
  object,
84
102
  extensions,
85
103
  settings,
86
104
  onAction: runAction,
87
105
  onFileUpload: handleFileUpload,
88
106
  onLinkQuery: handleLinkQuery,
107
+ onSelectObject: handleSelectObject,
89
108
  ...props
90
- }, settings.toolbar && /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
91
- id: attendableId ?? id,
109
+ }, /* @__PURE__ */ React.createElement(Panel.Root, {
92
110
  role,
111
+ ref: forwardedRef
112
+ }, settings.toolbar && /* @__PURE__ */ React.createElement(Panel.Toolbar, {
113
+ asChild: true
114
+ }, /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
93
115
  customActions
94
- }), /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
116
+ })), /* @__PURE__ */ React.createElement(Panel.Content, null, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
95
117
  initialValue,
96
118
  scrollPastEnd: role === "article"
97
- }), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null)));
119
+ }), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null))));
98
120
  });
99
- var MarkdownContainer_default = MarkdownContainer;
100
-
101
121
  export {
102
122
  MarkdownContainer,
103
- MarkdownContainer_default
123
+ MarkdownContainer as default
104
124
  };
105
- //# sourceMappingURL=chunk-3JYPCC7M.mjs.map
125
+ //# sourceMappingURL=MarkdownContainer-X3UQUNWL.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownContainer/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, useCallback, useMemo } from 'react';\n\nimport { useCapabilities, useOperationInvoker } from '@dxos/app-framework/ui';\nimport { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';\nimport { type SurfaceComponentProps } from '@dxos/app-toolkit/ui';\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { Obj } from '@dxos/echo';\nimport { useActionRunner } from '@dxos/plugin-graph';\nimport { useObject } from '@dxos/react-client/echo';\nimport { Panel } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownEditor, type MarkdownEditorContentProps, type MarkdownEditorRootProps } from '../../components';\nimport { useLinkQuery } from '../../hooks';\nimport { Markdown, MarkdownCapabilities, type MarkdownPluginState } from '../../types';\n\nexport type MarkdownContainerProps = SurfaceComponentProps<\n Markdown.Document | Text.Text,\n {\n id: string;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n } & Pick<MarkdownPluginState, 'extensionProviders'> &\n Pick<MarkdownEditorRootProps, 'viewMode' | 'onSelectObject' | 'onViewModeChange'> &\n Pick<MarkdownEditorContentProps, 'editorStateStore'>\n>;\n\nexport const MarkdownContainer = forwardRef<HTMLDivElement, MarkdownContainerProps>(\n (\n { role, subject: object, id, attendableId, settings, extensionProviders, onSelectObject, ...props },\n forwardedRef,\n ) => {\n const db = Obj.isObject(object) ? Obj.getDatabase(object) : undefined;\n const [docContent] = useObject(Obj.instanceOf(Markdown.Document, object) ? object.content : undefined, 'content');\n const [textContent] = useObject(Obj.instanceOf(Text.Text, object) ? object : undefined, 'content');\n const initialValue = docContent ?? textContent;\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) && !Obj.instanceOf(Text.Text, 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 runAction = useActionRunner();\n const customActions = useMemo(() => {\n return Atom.make((get) => {\n const actions = get(graph.actions(attendableId ?? id));\n const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');\n const edges = nodes.map((node) => ({ source: 'root', target: node.id, relation: 'child' }));\n return { nodes, edges };\n });\n }, [graph]);\n\n // File upload.\n const [upload] = useCapabilities(AppCapabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (!db || !upload) {\n return undefined;\n }\n\n return async (file: File) => upload(db, file);\n }, [db, upload]);\n\n // Query for @ refs.\n const handleLinkQuery = useLinkQuery(db);\n\n // Open linked objects.\n const { invokePromise } = useOperationInvoker();\n const handleSelectObject = useCallback(\n (targetId: string) => {\n if (onSelectObject) {\n onSelectObject(targetId);\n } else {\n void invokePromise?.(LayoutOperation.Open, {\n subject: [targetId],\n pivotId: attendableId,\n });\n }\n },\n [onSelectObject, invokePromise, object, id],\n );\n\n return (\n <MarkdownEditor.Root\n id={id}\n attendableId={attendableId}\n object={object}\n extensions={extensions}\n settings={settings}\n onAction={runAction}\n onFileUpload={handleFileUpload}\n onLinkQuery={handleLinkQuery}\n onSelectObject={handleSelectObject}\n {...props}\n >\n <Panel.Root role={role} ref={forwardedRef}>\n {settings.toolbar && (\n <Panel.Toolbar asChild>\n <MarkdownEditor.Toolbar customActions={customActions} />\n </Panel.Toolbar>\n )}\n <Panel.Content>\n <MarkdownEditor.Content initialValue={initialValue} scrollPastEnd={role === 'article'} />\n <MarkdownEditor.Blocks />\n </Panel.Content>\n </Panel.Root>\n </MarkdownEditor.Root>\n );\n },\n);\n"],
5
+ "mappings": "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",
6
+ "names": ["Atom", "React", "forwardRef", "useCallback", "useMemo", "useCapabilities", "useOperationInvoker", "AppCapabilities", "LayoutOperation", "useAppGraph", "Obj", "useActionRunner", "useObject", "Panel", "Text", "MarkdownContainer", "forwardRef", "role", "subject", "object", "id", "attendableId", "settings", "extensionProviders", "onSelectObject", "props", "forwardedRef", "db", "Obj", "isObject", "getDatabase", "undefined", "docContent", "useObject", "instanceOf", "Markdown", "Document", "content", "textContent", "Text", "initialValue", "otherExtensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "extensions", "useMemo", "flat", "reduce", "acc", "provider", "extension", "document", "push", "graph", "useAppGraph", "runAction", "useActionRunner", "customActions", "Atom", "make", "get", "actions", "nodes", "filter", "action", "properties", "disposition", "edges", "map", "node", "source", "target", "relation", "upload", "AppCapabilities", "FileUploader", "handleFileUpload", "file", "handleLinkQuery", "useLinkQuery", "invokePromise", "useOperationInvoker", "handleSelectObject", "useCallback", "targetId", "LayoutOperation", "Open", "pivotId", "MarkdownEditor", "Root", "onAction", "onFileUpload", "onLinkQuery", "Panel", "ref", "toolbar", "Toolbar", "asChild", "Content", "scrollPastEnd", "Blocks"]
7
+ }
@@ -0,0 +1,107 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ meta
4
+ } from "./chunk-CW4FZNMZ.mjs";
5
+
6
+ // src/containers/MarkdownSettings/MarkdownSettings.tsx
7
+ import React from "react";
8
+ import { Input, Select, useTranslation } from "@dxos/react-ui";
9
+ import { Settings } from "@dxos/react-ui-form";
10
+ import { EditorInputModes, EditorViewModes } from "@dxos/ui-editor";
11
+ var MarkdownSettings = ({ settings, onSettingsChange }) => {
12
+ const { t } = useTranslation(meta.id);
13
+ return /* @__PURE__ */ React.createElement(Settings.Root, null, /* @__PURE__ */ React.createElement(Settings.Section, {
14
+ title: t("settings title", {
15
+ ns: meta.id
16
+ })
17
+ }, /* @__PURE__ */ React.createElement(Settings.Group, null, /* @__PURE__ */ React.createElement(Settings.ItemInput, {
18
+ title: t("default view mode label")
19
+ }, /* @__PURE__ */ React.createElement(Select.Root, {
20
+ value: settings.defaultViewMode,
21
+ onValueChange: (value) => {
22
+ onSettingsChange((s) => ({
23
+ ...s,
24
+ defaultViewMode: value
25
+ }));
26
+ }
27
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, null), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorViewModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
28
+ key: mode,
29
+ value: mode
30
+ }, t(`${mode} mode label`, {
31
+ ns: "@dxos/react-ui-editor"
32
+ })))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
33
+ title: t("editor input mode label")
34
+ }, /* @__PURE__ */ React.createElement(Select.Root, {
35
+ value: settings.editorInputMode ?? "default",
36
+ onValueChange: (value) => {
37
+ onSettingsChange((s) => ({
38
+ ...s,
39
+ editorInputMode: value
40
+ }));
41
+ }
42
+ }, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
43
+ placeholder: t("select editor input mode placeholder")
44
+ }), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorInputModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
45
+ key: mode,
46
+ value: mode
47
+ }, t(`settings editor input mode ${mode} label`)))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
48
+ title: t("settings toolbar label")
49
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
50
+ checked: settings.toolbar,
51
+ onCheckedChange: (checked) => onSettingsChange((s) => ({
52
+ ...s,
53
+ toolbar: !!checked
54
+ }))
55
+ })), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
56
+ title: t("settings numbered headings label")
57
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
58
+ checked: settings.numberedHeadings,
59
+ onCheckedChange: (checked) => onSettingsChange((s) => ({
60
+ ...s,
61
+ numberedHeadings: !!checked
62
+ }))
63
+ })), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
64
+ title: t("settings folding label")
65
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
66
+ checked: settings.folding,
67
+ onCheckedChange: (checked) => onSettingsChange((s) => ({
68
+ ...s,
69
+ folding: !!checked
70
+ }))
71
+ })), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
72
+ title: t("settings experimental label")
73
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
74
+ checked: settings.experimental,
75
+ onCheckedChange: (checked) => onSettingsChange((s) => ({
76
+ ...s,
77
+ experimental: !!checked
78
+ }))
79
+ })), /* @__PURE__ */ React.createElement(Settings.ItemInput, {
80
+ title: t("settings debug label")
81
+ }, /* @__PURE__ */ React.createElement(Input.Switch, {
82
+ checked: settings.debug,
83
+ onCheckedChange: (checked) => onSettingsChange((s) => ({
84
+ ...s,
85
+ debug: !!checked
86
+ }))
87
+ })), settings.debug && /* @__PURE__ */ React.createElement(Settings.ItemInput, {
88
+ title: t("settings debug textarea label", {
89
+ ns: meta.id
90
+ })
91
+ }, /* @__PURE__ */ React.createElement(Input.TextArea, {
92
+ rows: 5,
93
+ value: settings.typewriter,
94
+ onChange: ({ target: { value } }) => onSettingsChange((s) => ({
95
+ ...s,
96
+ typewriter: value
97
+ })),
98
+ placeholder: t("settings debug placeholder")
99
+ })))));
100
+ };
101
+
102
+ // src/containers/MarkdownSettings/index.ts
103
+ var MarkdownSettings_default = MarkdownSettings;
104
+ export {
105
+ MarkdownSettings_default as default
106
+ };
107
+ //# sourceMappingURL=MarkdownSettings-U7GJ4OP3.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownSettings/MarkdownSettings.tsx", "../../../src/containers/MarkdownSettings/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { type Markdown } from '../../types';\n\nexport type MarkdownSettingsComponentProps = {\n settings: Markdown.Settings;\n onSettingsChange: (fn: (current: Markdown.Settings) => Markdown.Settings) => void;\n};\n\nexport const MarkdownSettings = ({ settings, onSettingsChange }: MarkdownSettingsComponentProps) => {\n const { t } = useTranslation(meta.id);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <Settings.Root>\n <Settings.Section title={t('settings title', { ns: meta.id })}>\n <Settings.Group>\n <Settings.ItemInput title={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, defaultViewMode: value as EditorViewMode }));\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: '@dxos/react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, editorInputMode: value as EditorInputMode }));\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings toolbar label')}>\n <Input.Switch\n checked={settings.toolbar}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, toolbar: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, numberedHeadings: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings folding label')}>\n <Input.Switch\n checked={settings.folding}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, folding: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, experimental: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings debug label')}>\n <Input.Switch\n checked={settings.debug}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, debug: !!checked }))}\n />\n </Settings.ItemInput>\n\n {settings.debug && (\n <Settings.ItemInput title={t('settings debug textarea label', { ns: meta.id })}>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => onSettingsChange((s) => ({ ...s, typewriter: value }))}\n placeholder={t('settings debug placeholder')}\n />\n </Settings.ItemInput>\n )}\n </Settings.Group>\n </Settings.Section>\n </Settings.Root>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownSettings } from './MarkdownSettings';\n\nexport default MarkdownSettings;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "Input", "Select", "useTranslation", "Settings", "EditorInputModes", "EditorViewModes", "MarkdownSettings", "settings", "onSettingsChange", "t", "useTranslation", "meta", "id", "Settings", "Root", "Section", "title", "ns", "Group", "ItemInput", "Select", "value", "defaultViewMode", "onValueChange", "s", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "Arrow", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "MarkdownSettings"]
7
+ }
@@ -1,14 +1,16 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  Markdown_exports
4
- } from "./chunk-PRV35A7Z.mjs";
4
+ } from "./chunk-XTF6AXHM.mjs";
5
+ import "./chunk-CW4FZNMZ.mjs";
5
6
 
6
7
  // src/capabilities/anchor-sort/anchor-sort.ts
7
8
  import * as Effect from "effect/Effect";
8
- import { Capability, Common } from "@dxos/app-framework";
9
+ import { Capability } from "@dxos/app-framework";
10
+ import { AppCapabilities } from "@dxos/app-toolkit";
9
11
  import { Relation } from "@dxos/echo";
10
12
  import { createDocAccessor, getRangeFromCursor } from "@dxos/echo-db";
11
- var anchor_sort_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Common.Capability.AnchorSort, {
13
+ var anchor_sort_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(AppCapabilities.AnchorSort, {
12
14
  key: Markdown_exports.Document.typename,
13
15
  sort: (anchorA, anchorB) => {
14
16
  const doc = Relation.getTarget(anchorA);
@@ -30,4 +32,4 @@ var anchor_sort_default = Capability.makeModule(() => Effect.succeed(Capability.
30
32
  export {
31
33
  anchor_sort_default as default
32
34
  };
33
- //# sourceMappingURL=anchor-sort-G7D5TAI6.mjs.map
35
+ //# sourceMappingURL=anchor-sort-4574EWPS.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/anchor-sort/anchor-sort.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { Relation } from '@dxos/echo';\nimport { createDocAccessor, getRangeFromCursor } from '@dxos/echo-db';\nimport { type AnchoredTo } from '@dxos/types';\n\nimport { Markdown } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.succeed(\n Capability.contributes(AppCapabilities.AnchorSort, {\n key: Markdown.Document.typename,\n sort: (anchorA: AnchoredTo.AnchoredTo, anchorB: AnchoredTo.AnchoredTo) => {\n const doc = Relation.getTarget(anchorA) as Markdown.Document;\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (doc !== Relation.getTarget(anchorB) || !accessor) {\n return 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n const posA = getStartPosition(anchorA.anchor);\n const posB = getStartPosition(anchorB.anchor);\n return posA - posB;\n },\n }),\n ),\n);\n"],
5
+ "mappings": ";;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,gBAAgB;AACzB,SAASC,mBAAmBC,0BAA0B;AAKtD,IAAA,sBAAeC,WAAWC,WAAW,MAC5BC,eACLF,WAAWG,YAAYC,gBAAgBC,YAAY;EACjDC,KAAKC,iBAASC,SAASC;EACvBC,MAAM,CAACC,SAAgCC,YAAAA;AACrC,UAAMC,MAAMC,SAASC,UAAUJ,OAAAA;AAC/B,UAAMK,WAAWH,IAAII,QAAQC,SAASC,kBAAkBN,IAAII,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIP,QAAQC,SAASC,UAAUH,OAAAA,KAAY,CAACI,UAAU;AACpD,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBV,QAAQkB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBT,QAAQiB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA,CAAA,CAAA;",
6
+ "names": ["Effect", "Capability", "AppCapabilities", "Relation", "createDocAccessor", "getRangeFromCursor", "Capability", "makeModule", "succeed", "contributes", "AppCapabilities", "AnchorSort", "key", "Markdown", "Document", "typename", "sort", "anchorA", "anchorB", "doc", "Relation", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
7
+ }
@@ -1,22 +1,24 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  translations
4
- } from "./chunk-44VJC3QF.mjs";
4
+ } from "./chunk-QQF75YGF.mjs";
5
5
  import {
6
6
  MarkdownOperation,
7
7
  Markdown_exports
8
- } from "./chunk-PRV35A7Z.mjs";
8
+ } from "./chunk-XTF6AXHM.mjs";
9
+ import "./chunk-CW4FZNMZ.mjs";
9
10
 
10
11
  // src/capabilities/app-graph-serializer/app-graph-serializer.ts
11
12
  import * as Effect from "effect/Effect";
12
- import { Capability, Common } from "@dxos/app-framework";
13
+ import { Capabilities, Capability } from "@dxos/app-framework";
14
+ import { AppCapabilities } from "@dxos/app-toolkit";
13
15
  import { Obj } from "@dxos/echo";
16
+ import { Collection } from "@dxos/echo";
14
17
  import { SpaceOperation } from "@dxos/plugin-space/types";
15
18
  import { isSpace } from "@dxos/react-client/echo";
16
- import { Collection } from "@dxos/schema";
17
19
  var app_graph_serializer_default = Capability.makeModule(Effect.fnUntraced(function* () {
18
20
  const capabilities = yield* Capability.Service;
19
- return Capability.contributes(Common.Capability.AppGraphSerializer, [
21
+ return Capability.contributes(AppCapabilities.AppGraphSerializer, [
20
22
  {
21
23
  inputType: Markdown_exports.Document.typename,
22
24
  outputType: "text/markdown",
@@ -36,7 +38,7 @@ var app_graph_serializer_default = Capability.makeModule(Effect.fnUntraced(funct
36
38
  if (!space || !target) {
37
39
  return;
38
40
  }
39
- const { invokePromise } = capabilities.get(Common.Capability.OperationInvoker);
41
+ const { invokePromise } = capabilities.get(Capabilities.OperationInvoker);
40
42
  const createResult = await invokePromise(MarkdownOperation.Create, {
41
43
  name: data.name,
42
44
  content: data.data
@@ -56,4 +58,4 @@ var app_graph_serializer_default = Capability.makeModule(Effect.fnUntraced(funct
56
58
  export {
57
59
  app_graph_serializer_default as default
58
60
  };
59
- //# sourceMappingURL=app-graph-serializer-W5YMQP7P.mjs.map
61
+ //# sourceMappingURL=app-graph-serializer-CCMYKW2M.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-serializer/app-graph-serializer.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { Obj } from '@dxos/echo';\nimport { Collection } from '@dxos/echo';\nimport { SpaceOperation } from '@dxos/plugin-space/types';\nimport { isSpace } from '@dxos/react-client/echo';\n\nimport { translations } from '../../translations';\nimport { Markdown, MarkdownOperation } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n // Get context for lazy capability access in callbacks.\n const capabilities = yield* Capability.Service;\n\n return Capability.contributes(AppCapabilities.AppGraphSerializer, [\n {\n inputType: Markdown.Document.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await doc.content.load();\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][Markdown.Document.typename]['object name placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => Obj.instanceOf(Collection.Collection, ancestor)) ??\n space?.properties[Collection.Collection.typename]?.target;\n if (!space || !target) {\n return;\n }\n\n const { invokePromise } = capabilities.get(Capabilities.OperationInvoker);\n const createResult = await invokePromise(MarkdownOperation.Create, { name: data.name, content: data.data });\n if (!createResult.data?.object) {\n return undefined;\n }\n await invokePromise(SpaceOperation.AddObject, { target, object: createResult.data.object });\n\n return createResult.data.object;\n },\n },\n ]);\n }),\n);\n"],
5
+ "mappings": ";;;;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,uBAAuB;AAChC,SAASC,WAAW;AACpB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,eAAe;AAKxB,IAAA,+BAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAEhB,QAAMC,eAAe,OAAOH,WAAWI;AAEvC,SAAOJ,WAAWK,YAAYC,gBAAgBC,oBAAoB;IAChE;MACEC,WAAWC,iBAASC,SAASC;MAC7BC,YAAY;;MAEZC,WAAW,OAAOC,SAAAA;AAChB,cAAMC,MAAMD,KAAKE;AACjB,cAAMC,UAAU,MAAMF,IAAIE,QAAQC,KAAI;AACtC,eAAO;UACLC,MACEJ,IAAII,QACJJ,IAAIK,gBACJC,aAAa,CAAA,EAAG,OAAA,EAASZ,iBAASC,SAASC,QAAQ,EAAE,yBAAA;UACvDK,MAAMC,QAAQA;UACdK,MAAM;QACR;MACF;MACAC,aAAa,OAAOP,MAAMQ,cAAAA;AACxB,cAAMC,QAAQD,UAAUE,KAAKC,OAAAA;AAC7B,cAAMC,SACJJ,UAAUK,SAAS,CAACC,aAAaC,IAAIC,WAAWC,WAAWA,YAAYH,QAAAA,CAAAA,KACvEL,OAAOS,WAAWD,WAAWA,WAAWtB,QAAQ,GAAGiB;AACrD,YAAI,CAACH,SAAS,CAACG,QAAQ;AACrB;QACF;AAEA,cAAM,EAAEO,cAAa,IAAKhC,aAAaiC,IAAIC,aAAaC,gBAAgB;AACxE,cAAMC,eAAe,MAAMJ,cAAcK,kBAAkBC,QAAQ;UAAEtB,MAAMH,KAAKG;UAAMF,SAASD,KAAKA;QAAK,CAAA;AACzG,YAAI,CAACuB,aAAavB,MAAM0B,QAAQ;AAC9B,iBAAOC;QACT;AACA,cAAMR,cAAcS,eAAeC,WAAW;UAAEjB;UAAQc,QAAQH,aAAavB,KAAK0B;QAAO,CAAA;AAEzF,eAAOH,aAAavB,KAAK0B;MAC3B;IACF;GACD;AACH,CAAA,CAAA;",
6
+ "names": ["Effect", "Capabilities", "Capability", "AppCapabilities", "Obj", "Collection", "SpaceOperation", "isSpace", "Capability", "makeModule", "fnUntraced", "capabilities", "Service", "contributes", "AppCapabilities", "AppGraphSerializer", "inputType", "Markdown", "Document", "typename", "outputType", "serialize", "node", "doc", "data", "content", "load", "name", "fallbackName", "translations", "type", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "Obj", "instanceOf", "Collection", "properties", "invokePromise", "get", "Capabilities", "OperationInvoker", "createResult", "MarkdownOperation", "Create", "object", "undefined", "SpaceOperation", "AddObject"]
7
+ }
@@ -0,0 +1,19 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ markdown_blueprint_default
4
+ } from "./chunk-7UHD5AKT.mjs";
5
+ import "./chunk-XTF6AXHM.mjs";
6
+ import "./chunk-CW4FZNMZ.mjs";
7
+
8
+ // src/capabilities/blueprint-definition/blueprint-definition.ts
9
+ import * as Effect from "effect/Effect";
10
+ import { Capability } from "@dxos/app-framework";
11
+ import { AppCapabilities } from "@dxos/app-toolkit";
12
+ var blueprintDefinition = Capability.makeModule(() => Effect.succeed([
13
+ Capability.contributes(AppCapabilities.BlueprintDefinition, markdown_blueprint_default)
14
+ ]));
15
+ var blueprint_definition_default = blueprintDefinition;
16
+ export {
17
+ blueprint_definition_default as default
18
+ };
19
+ //# sourceMappingURL=blueprint-definition-TZPCKPPU.mjs.map