@dxos/plugin-markdown 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6

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 (361) hide show
  1. package/dist/lib/browser/MarkdownSettings-5AD3X3II.mjs +124 -0
  2. package/dist/lib/browser/MarkdownSettings-5AD3X3II.mjs.map +7 -0
  3. package/dist/lib/browser/blueprints/index.mjs +47 -4
  4. package/dist/lib/browser/blueprints/index.mjs.map +4 -4
  5. package/dist/lib/browser/chunk-46WIDM4R.mjs +98 -0
  6. package/dist/lib/browser/chunk-46WIDM4R.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-GQKARRJU.mjs +158 -0
  8. package/dist/lib/browser/chunk-GQKARRJU.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  10. package/dist/lib/browser/cli/index.mjs +26 -19
  11. package/dist/lib/browser/cli/index.mjs.map +3 -3
  12. package/dist/lib/browser/create-I7QWPBMS.mjs +30 -0
  13. package/dist/lib/browser/create-I7QWPBMS.mjs.map +7 -0
  14. package/dist/lib/browser/create-markdown-6QQXSF3Q.mjs +22 -0
  15. package/dist/lib/browser/create-markdown-6QQXSF3Q.mjs.map +7 -0
  16. package/dist/lib/browser/index.mjs +586 -85
  17. package/dist/lib/browser/index.mjs.map +4 -4
  18. package/dist/lib/browser/meta.json +1 -1
  19. package/dist/lib/browser/open-NSBN4NKR.mjs +21 -0
  20. package/dist/lib/browser/open-NSBN4NKR.mjs.map +7 -0
  21. package/dist/lib/browser/operations/index.mjs +14 -0
  22. package/dist/lib/browser/operations/index.mjs.map +7 -0
  23. package/dist/lib/browser/scroll-to-anchor-RA5OMQCP.mjs +49 -0
  24. package/dist/lib/browser/scroll-to-anchor-RA5OMQCP.mjs.map +7 -0
  25. package/dist/lib/browser/set-view-mode-75MBU6CB.mjs +26 -0
  26. package/dist/lib/browser/set-view-mode-75MBU6CB.mjs.map +7 -0
  27. package/dist/lib/browser/types/index.mjs +6 -7
  28. package/dist/lib/browser/update-QQJYONAC.mjs +45 -0
  29. package/dist/lib/browser/update-QQJYONAC.mjs.map +7 -0
  30. package/dist/lib/node-esm/MarkdownSettings-ODDM67XG.mjs +125 -0
  31. package/dist/lib/node-esm/MarkdownSettings-ODDM67XG.mjs.map +7 -0
  32. package/dist/lib/node-esm/blueprints/index.mjs +47 -4
  33. package/dist/lib/node-esm/blueprints/index.mjs.map +4 -4
  34. package/dist/lib/node-esm/chunk-4MSJO6IJ.mjs +99 -0
  35. package/dist/lib/node-esm/chunk-4MSJO6IJ.mjs.map +7 -0
  36. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  37. package/dist/lib/node-esm/chunk-QRCQ55W7.mjs +159 -0
  38. package/dist/lib/node-esm/chunk-QRCQ55W7.mjs.map +7 -0
  39. package/dist/lib/node-esm/cli/index.mjs +26 -19
  40. package/dist/lib/node-esm/cli/index.mjs.map +3 -3
  41. package/dist/lib/node-esm/create-VJ5SIKYF.mjs +31 -0
  42. package/dist/lib/node-esm/create-VJ5SIKYF.mjs.map +7 -0
  43. package/dist/lib/node-esm/create-markdown-P5KNGLZ5.mjs +23 -0
  44. package/dist/lib/node-esm/create-markdown-P5KNGLZ5.mjs.map +7 -0
  45. package/dist/lib/node-esm/index.mjs +586 -85
  46. package/dist/lib/node-esm/index.mjs.map +4 -4
  47. package/dist/lib/node-esm/meta.json +1 -1
  48. package/dist/lib/node-esm/open-U3T6IVHN.mjs +22 -0
  49. package/dist/lib/node-esm/open-U3T6IVHN.mjs.map +7 -0
  50. package/dist/lib/node-esm/operations/index.mjs +15 -0
  51. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  52. package/dist/lib/node-esm/scroll-to-anchor-CVM3LVSQ.mjs +50 -0
  53. package/dist/lib/node-esm/scroll-to-anchor-CVM3LVSQ.mjs.map +7 -0
  54. package/dist/lib/node-esm/set-view-mode-WQJBCUXY.mjs +27 -0
  55. package/dist/lib/node-esm/set-view-mode-WQJBCUXY.mjs.map +7 -0
  56. package/dist/lib/node-esm/types/index.mjs +6 -7
  57. package/dist/lib/node-esm/update-24CQM75C.mjs +46 -0
  58. package/dist/lib/node-esm/update-24CQM75C.mjs.map +7 -0
  59. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  60. package/dist/types/src/blueprints/index.d.ts +1 -1
  61. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  62. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  63. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  64. package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
  65. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  66. package/dist/types/src/capabilities/app-graph-serializer.d.ts +5 -0
  67. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  68. package/dist/types/src/capabilities/artifact-definition.d.ts +5 -0
  69. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
  70. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  71. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  72. package/dist/types/src/capabilities/index.d.ts +27 -7
  73. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  74. package/dist/types/src/capabilities/node.d.ts +4 -0
  75. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  76. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  77. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  78. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  79. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  80. package/dist/types/src/capabilities/settings.d.ts +24 -0
  81. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  82. package/dist/types/src/capabilities/state.d.ts +6 -0
  83. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  84. package/dist/types/src/cli/plugin.d.ts.map +1 -1
  85. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
  86. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  87. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +14 -9
  88. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  89. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +2 -2
  90. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  91. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +4 -2
  92. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  93. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +11 -6
  94. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  95. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -6
  96. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  97. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +138 -0
  98. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  99. package/dist/types/src/components/MarkdownSettings/index.d.ts +2 -1
  100. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  101. package/dist/types/src/components/index.d.ts +3 -8
  102. package/dist/types/src/components/index.d.ts.map +1 -1
  103. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +1 -1
  104. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  105. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  106. package/dist/types/src/{components → containers}/MarkdownCard/index.d.ts +0 -1
  107. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  108. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +15 -0
  109. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  110. package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.d.ts +10 -7
  111. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  112. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +99 -0
  113. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  114. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  115. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  116. package/dist/types/src/containers/index.d.ts +5 -0
  117. package/dist/types/src/containers/index.d.ts.map +1 -0
  118. package/dist/types/src/hooks/index.d.ts +0 -1
  119. package/dist/types/src/hooks/index.d.ts.map +1 -1
  120. package/dist/types/src/hooks/useExtensions.d.ts +7 -5
  121. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  122. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  123. package/dist/types/src/index.d.ts +1 -0
  124. package/dist/types/src/index.d.ts.map +1 -1
  125. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  126. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  127. package/dist/types/src/operations/create.d.ts +5 -0
  128. package/dist/types/src/operations/create.d.ts.map +1 -0
  129. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  130. package/dist/types/src/operations/definitions.d.ts +64 -0
  131. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  132. package/dist/types/src/operations/index.d.ts +4 -0
  133. package/dist/types/src/operations/index.d.ts.map +1 -0
  134. package/dist/types/src/operations/open.d.ts +5 -0
  135. package/dist/types/src/operations/open.d.ts.map +1 -0
  136. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  137. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  138. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  139. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  140. package/dist/types/src/operations/update.d.ts +5 -0
  141. package/dist/types/src/operations/update.d.ts.map +1 -0
  142. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  143. package/dist/types/src/translations.d.ts +75 -35
  144. package/dist/types/src/translations.d.ts.map +1 -1
  145. package/dist/types/src/types/Markdown.d.ts +15 -16
  146. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  147. package/dist/types/src/types/Settings.d.ts +16 -0
  148. package/dist/types/src/types/Settings.d.ts.map +1 -0
  149. package/dist/types/src/types/capabilities.d.ts +31 -2
  150. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  151. package/dist/types/src/types/events.d.ts.map +1 -1
  152. package/dist/types/src/types/index.d.ts +2 -3
  153. package/dist/types/src/types/index.d.ts.map +1 -1
  154. package/dist/types/src/util.d.ts +2 -2
  155. package/dist/types/src/util.d.ts.map +1 -1
  156. package/dist/types/tsconfig.tsbuildinfo +1 -1
  157. package/package.json +89 -57
  158. package/src/MarkdownPlugin.tsx +49 -44
  159. package/src/blueprints/index.ts +1 -1
  160. package/src/blueprints/markdown-blueprint.ts +14 -8
  161. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +4 -3
  162. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +14 -9
  163. package/src/capabilities/{artifact-definition/artifact-definition.ts → artifact-definition.ts} +5 -5
  164. package/src/capabilities/blueprint-definition.ts +17 -0
  165. package/src/capabilities/index.ts +13 -7
  166. package/src/capabilities/node.ts +11 -0
  167. package/src/capabilities/operation-handler.ts +16 -0
  168. package/src/capabilities/{react-surface/react-surface.tsx → react-surface.tsx} +48 -27
  169. package/src/capabilities/{settings/settings.ts → settings.ts} +5 -4
  170. package/src/capabilities/state.ts +47 -0
  171. package/src/cli/plugin.ts +21 -10
  172. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  173. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +29 -29
  174. package/src/components/MarkdownEditor/MarkdownEditor.tsx +63 -32
  175. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +24 -17
  176. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +47 -55
  177. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  178. package/src/components/MarkdownSettings/MarkdownSettings.tsx +114 -98
  179. package/src/components/MarkdownSettings/index.ts +3 -1
  180. package/src/components/index.ts +4 -12
  181. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +17 -7
  182. package/src/{components → containers}/MarkdownCard/MarkdownCard.tsx +23 -30
  183. package/src/{components → containers}/MarkdownCard/index.ts +0 -2
  184. package/src/containers/MarkdownCard/snippet.ts +75 -0
  185. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +28 -18
  186. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.tsx +59 -36
  187. package/src/containers/MarkdownContainer/index.ts +6 -0
  188. package/src/containers/index.ts +10 -0
  189. package/src/hooks/index.ts +0 -1
  190. package/src/hooks/useEditorMenuOptions.ts +2 -2
  191. package/src/hooks/useExtensions.tsx +80 -93
  192. package/src/hooks/useLinkQuery.ts +31 -6
  193. package/src/index.ts +2 -0
  194. package/src/meta.ts +1 -1
  195. package/src/operations/create-markdown.ts +21 -0
  196. package/src/operations/create.conversations.json +1 -0
  197. package/src/operations/create.test.ts +98 -0
  198. package/src/operations/create.ts +27 -0
  199. package/src/operations/definitions.ts +119 -0
  200. package/src/operations/index.ts +16 -0
  201. package/src/operations/open.ts +25 -0
  202. package/src/operations/scroll-to-anchor.ts +40 -0
  203. package/src/operations/set-view-mode.ts +25 -0
  204. package/src/operations/update.conversations.json +1 -0
  205. package/src/operations/update.test.ts +215 -0
  206. package/src/operations/update.ts +51 -0
  207. package/src/testing.ts +2 -2
  208. package/src/translations.ts +49 -35
  209. package/src/types/Markdown.ts +18 -25
  210. package/src/types/Settings.ts +28 -0
  211. package/src/types/capabilities.ts +17 -5
  212. package/src/types/events.ts +5 -4
  213. package/src/types/index.ts +3 -4
  214. package/src/util.tsx +5 -5
  215. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs +0 -12
  216. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
  217. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs +0 -32
  218. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
  219. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs +0 -58
  220. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
  221. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
  222. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
  223. package/dist/lib/browser/chunk-BX73DASG.mjs +0 -702
  224. package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
  225. package/dist/lib/browser/chunk-CUGDX7KA.mjs +0 -8
  226. package/dist/lib/browser/chunk-CUGDX7KA.mjs.map +0 -7
  227. package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
  228. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
  229. package/dist/lib/browser/chunk-JOXYQLKH.mjs +0 -55
  230. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-KDKXFKDN.mjs +0 -104
  232. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-LMO5UVKL.mjs +0 -167
  234. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
  236. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
  237. package/dist/lib/browser/chunk-WIPSLZ6L.mjs +0 -60
  238. package/dist/lib/browser/chunk-WIPSLZ6L.mjs.map +0 -7
  239. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs +0 -53
  240. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
  241. package/dist/lib/browser/react-surface-SRPLD3ED.mjs +0 -213
  242. package/dist/lib/browser/react-surface-SRPLD3ED.mjs.map +0 -7
  243. package/dist/lib/browser/settings-JY5JE7MI.mjs +0 -35
  244. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
  245. package/dist/lib/browser/state-QE7VSJWJ.mjs +0 -29
  246. package/dist/lib/browser/state-QE7VSJWJ.mjs.map +0 -7
  247. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs +0 -13
  248. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs.map +0 -7
  249. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
  250. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
  251. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs +0 -33
  252. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
  253. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs +0 -59
  254. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
  255. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
  256. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
  257. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs +0 -105
  258. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
  259. package/dist/lib/node-esm/chunk-44VJC3QF.mjs +0 -56
  260. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
  261. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs +0 -703
  262. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
  263. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
  264. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs +0 -168
  266. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
  267. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs +0 -61
  268. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs.map +0 -7
  269. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
  270. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
  271. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs +0 -10
  272. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs.map +0 -7
  273. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs +0 -54
  274. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
  275. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs +0 -214
  276. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs.map +0 -7
  277. package/dist/lib/node-esm/settings-4UGMPIRY.mjs +0 -36
  278. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
  279. package/dist/lib/node-esm/state-LXE5XIN4.mjs +0 -30
  280. package/dist/lib/node-esm/state-LXE5XIN4.mjs.map +0 -7
  281. package/dist/types/src/blueprints/functions/create.d.ts +0 -8
  282. package/dist/types/src/blueprints/functions/create.d.ts.map +0 -1
  283. package/dist/types/src/blueprints/functions/create.test.d.ts.map +0 -1
  284. package/dist/types/src/blueprints/functions/index.d.ts +0 -4
  285. package/dist/types/src/blueprints/functions/index.d.ts.map +0 -1
  286. package/dist/types/src/blueprints/functions/open.d.ts +0 -7
  287. package/dist/types/src/blueprints/functions/open.d.ts.map +0 -1
  288. package/dist/types/src/blueprints/functions/update.d.ts +0 -6
  289. package/dist/types/src/blueprints/functions/update.d.ts.map +0 -1
  290. package/dist/types/src/blueprints/functions/update.test.d.ts.map +0 -1
  291. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +0 -5
  292. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  293. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  294. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  295. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +0 -5
  296. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  297. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  298. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  299. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +0 -5
  300. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  301. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  302. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  303. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -10
  304. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  305. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  306. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  307. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  308. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  309. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  310. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  311. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  312. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  314. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  316. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  317. package/dist/types/src/capabilities/settings/settings.d.ts +0 -6
  318. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  319. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  320. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  321. package/dist/types/src/capabilities/state/state.d.ts +0 -5
  322. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  323. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  324. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  325. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  326. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  327. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -59
  328. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  329. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  330. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  331. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  332. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  333. package/dist/types/src/types/MarkdownAction.d.ts +0 -66
  334. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  335. package/src/blueprints/functions/create.conversations.json +0 -1
  336. package/src/blueprints/functions/create.test.ts +0 -125
  337. package/src/blueprints/functions/create.ts +0 -34
  338. package/src/blueprints/functions/index.ts +0 -7
  339. package/src/blueprints/functions/open.ts +0 -33
  340. package/src/blueprints/functions/update.conversations.json +0 -1
  341. package/src/blueprints/functions/update.test.ts +0 -149
  342. package/src/blueprints/functions/update.ts +0 -38
  343. package/src/capabilities/anchor-sort/index.ts +0 -7
  344. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  345. package/src/capabilities/artifact-definition/index.ts +0 -7
  346. package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -25
  347. package/src/capabilities/blueprint-definition/index.ts +0 -7
  348. package/src/capabilities/operation-resolver/index.ts +0 -7
  349. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -45
  350. package/src/capabilities/react-surface/index.ts +0 -7
  351. package/src/capabilities/settings/index.ts +0 -7
  352. package/src/capabilities/state/index.ts +0 -7
  353. package/src/capabilities/state/state.ts +0 -31
  354. package/src/components/Suggestions.stories.tsx +0 -215
  355. package/src/hooks/useSelectCurrentThread.tsx +0 -61
  356. package/src/types/MarkdownAction.ts +0 -59
  357. /package/dist/lib/browser/{MarkdownCard-WHK3ORP7.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  358. /package/dist/lib/{browser/MarkdownContainer-V7EAADMF.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
  359. /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +0 -0
  360. /package/dist/types/src/{blueprints/functions → operations}/create.test.d.ts +0 -0
  361. /package/dist/types/src/{blueprints/functions → operations}/update.test.d.ts +0 -0
@@ -5,56 +5,76 @@
5
5
  import * as Effect from 'effect/Effect';
6
6
  import React, { forwardRef, useCallback, useMemo } from 'react';
7
7
 
8
- import { Capability, Common } from '@dxos/app-framework';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
9
  import {
10
- type SurfaceComponentProps,
10
+ Surface,
11
11
  useAtomCapability,
12
12
  useAtomCapabilityState,
13
13
  useCapability,
14
14
  useSettingsState,
15
- } from '@dxos/app-framework/react';
15
+ } from '@dxos/app-framework/ui';
16
+ import { AppCapabilities } from '@dxos/app-toolkit';
17
+ import { type ObjectSurfaceProps } from '@dxos/app-toolkit/ui';
16
18
  import { Obj } from '@dxos/echo';
17
- import { AttentionCapabilities } from '@dxos/plugin-attention';
19
+ import { AttentionCapabilities } from '@dxos/plugin-attention/types';
18
20
  import { Text } from '@dxos/schema';
19
21
  import { type EditorViewMode } from '@dxos/ui-editor';
20
22
 
21
- import { MarkdownCard, MarkdownContainer, type MarkdownContainerProps, MarkdownSettings } from '../../components';
22
- import { meta } from '../../meta';
23
- import { Markdown, MarkdownCapabilities } from '../../types';
23
+ import { MarkdownSettings } from '#components';
24
+ import { MarkdownCard, MarkdownContainer, type MarkdownContainerProps } from '#containers';
25
+ import { meta } from '#meta';
26
+ import { Markdown, MarkdownCapabilities } from '#types';
24
27
 
25
28
  export default Capability.makeModule(() =>
26
29
  Effect.succeed(
27
- Capability.contributes(Common.Capability.ReactSurface, [
28
- Common.createSurface({
29
- id: `${meta.id}/surface/document`,
30
+ Capability.contributes(Capabilities.ReactSurface, [
31
+ Surface.create({
32
+ id: `${meta.id}.surface.document`,
30
33
  role: ['article', 'section', 'tabpanel'],
31
- filter: (data): data is { subject: Markdown.Document; variant: undefined } =>
32
- Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
34
+ filter: (data): data is { subject: Markdown.Document; attendableId: string; variant: undefined } =>
35
+ typeof data.attendableId === 'string' && Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
33
36
  component: ({ data, role, ref }) => {
34
- return <Container id={Obj.getDXN(data.subject).toString()} subject={data.subject} role={role} ref={ref} />;
37
+ return (
38
+ <Container
39
+ id={Obj.getDXN(data.subject).toString()}
40
+ attendableId={data.attendableId}
41
+ subject={data.subject}
42
+ role={role}
43
+ ref={ref}
44
+ />
45
+ );
35
46
  },
36
47
  }),
37
- Common.createSurface({
38
- id: `${meta.id}/surface/text`,
48
+ Surface.create({
49
+ id: `${meta.id}.surface.text`,
39
50
  role: ['article', 'section', 'tabpanel'],
40
- filter: (data): data is { id: string; subject: Text.Text } =>
41
- typeof data.id === 'string' && Obj.instanceOf(Text.Text, data.subject),
42
- component: ({ data, role }) => {
43
- return <Container id={data.id} subject={data.subject} role={role} />;
51
+ // TODO(burdon): Why is attendableId required? See EventArticle.tsx
52
+ filter: (data): data is { attendableId: string; subject: Text.Text } =>
53
+ typeof data.attendableId === 'string' && Obj.instanceOf(Text.Text, data.subject),
54
+ component: ({ data, role, ref }) => {
55
+ return (
56
+ <Container
57
+ id={Obj.getDXN(data.subject).toString()}
58
+ attendableId={data.attendableId}
59
+ subject={data.subject}
60
+ role={role}
61
+ ref={ref}
62
+ />
63
+ );
44
64
  },
45
65
  }),
46
- Common.createSurface({
47
- id: `${meta.id}/surface/plugin-settings`,
66
+ Surface.create({
67
+ id: `${meta.id}.surface.plugin-settings`,
48
68
  role: 'article',
49
- filter: (data): data is { subject: Common.Capability.Settings } =>
50
- Common.Capability.isSettings(data.subject) && data.subject.prefix === meta.id,
69
+ filter: (data): data is { subject: AppCapabilities.Settings } =>
70
+ AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,
51
71
  component: ({ data: { subject } }) => {
52
72
  const { settings, updateSettings } = useSettingsState<Markdown.Settings>(subject.atom);
53
73
  return <MarkdownSettings settings={settings} onSettingsChange={updateSettings} />;
54
74
  },
55
75
  }),
56
- Common.createSurface({
57
- id: `${meta.id}/surface/preview`,
76
+ Surface.create({
77
+ id: `${meta.id}.surface.preview`,
58
78
  role: 'card--content',
59
79
  filter: (data): data is { subject: Markdown.Document | Text.Text } =>
60
80
  Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
@@ -67,8 +87,8 @@ export default Capability.makeModule(() =>
67
87
  /**
68
88
  * Common wrapper.
69
89
  */
70
- const Container = forwardRef<HTMLDivElement, SurfaceComponentProps<Markdown.Document | Text.Text, { id: string }>>(
71
- ({ id, subject, role }, forwardedRef) => {
90
+ const Container = forwardRef<HTMLDivElement, ObjectSurfaceProps<Markdown.Document | Text.Text, { id: string }>>(
91
+ ({ id, attendableId, subject, role }, forwardedRef) => {
72
92
  const selectionManager = useCapability(AttentionCapabilities.Selection);
73
93
  const settings = useAtomCapability(MarkdownCapabilities.Settings);
74
94
  const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
@@ -87,6 +107,7 @@ const Container = forwardRef<HTMLDivElement, SurfaceComponentProps<Markdown.Docu
87
107
  role={role}
88
108
  subject={subject}
89
109
  id={id}
110
+ attendableId={attendableId}
90
111
  settings={settings}
91
112
  selectionManager={selectionManager}
92
113
  extensionProviders={extensionProviders}
@@ -4,11 +4,12 @@
4
4
 
5
5
  import * as Effect from 'effect/Effect';
6
6
 
7
- import { Capability, Common } from '@dxos/app-framework';
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { AppCapabilities } from '@dxos/app-toolkit';
8
9
  import { createKvsStore } from '@dxos/effect';
9
10
 
10
- import { meta } from '../../meta';
11
- import { Markdown, MarkdownCapabilities } from '../../types';
11
+ import { meta } from '#meta';
12
+ import { Markdown, MarkdownCapabilities } from '#types';
12
13
 
13
14
  export default Capability.makeModule(() =>
14
15
  Effect.sync(() => {
@@ -26,7 +27,7 @@ export default Capability.makeModule(() =>
26
27
 
27
28
  return [
28
29
  Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),
29
- Capability.contributes(Common.Capability.Settings, {
30
+ Capability.contributes(AppCapabilities.Settings, {
30
31
  prefix: meta.id,
31
32
  schema: Markdown.Settings,
32
33
  atom: settingsAtom,
@@ -0,0 +1,47 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { createKvsStore } from '@dxos/effect';
9
+ import { createEditorStateStore } from '@dxos/ui-editor';
10
+
11
+ import { meta } from '#meta';
12
+ import { type EditorViewEntry, type EditorViewRegistry, MarkdownCapabilities, MarkdownStateSchema } from '#types';
13
+
14
+ const createEditorViewRegistry = (): EditorViewRegistry => {
15
+ const views = new Map<string, EditorViewEntry>();
16
+ return {
17
+ register: (attendableId, view, documentId) => {
18
+ views.set(attendableId, { view, documentId });
19
+ },
20
+ unregister: (attendableId) => {
21
+ views.delete(attendableId);
22
+ },
23
+ get: (attendableId) => views.get(attendableId),
24
+ };
25
+ };
26
+
27
+ export default Capability.makeModule(
28
+ Effect.fnUntraced(function* () {
29
+ // Persisted state using KVS store.
30
+ const stateAtom = createKvsStore({
31
+ key: `${meta.id}.state`,
32
+ schema: MarkdownStateSchema,
33
+ defaultValue: () => ({ viewMode: {} }),
34
+ });
35
+
36
+ // TODO(wittjosiah): Fold into state.
37
+ const editorState = createEditorStateStore(`${meta.id}.editor`);
38
+
39
+ const editorViews = createEditorViewRegistry();
40
+
41
+ return [
42
+ Capability.contributes(MarkdownCapabilities.State, stateAtom),
43
+ Capability.contributes(MarkdownCapabilities.EditorState, editorState),
44
+ Capability.contributes(MarkdownCapabilities.EditorViews, editorViews),
45
+ ];
46
+ }),
47
+ );
package/src/cli/plugin.ts CHANGED
@@ -4,26 +4,37 @@
4
4
 
5
5
  import * as Effect from 'effect/Effect';
6
6
 
7
- import { Common, Plugin } from '@dxos/app-framework';
7
+ import { Plugin } from '@dxos/app-framework';
8
+ import { AppPlugin } from '@dxos/app-toolkit';
9
+ import { Operation } from '@dxos/operation';
8
10
  import { type CreateObject } from '@dxos/plugin-space/types';
11
+ import { SpaceOperation } from '@dxos/plugin-space/operations';
9
12
  import { Text } from '@dxos/schema';
10
13
 
11
- // NOTE: Must not import from index to avoid pulling in react dependencies.
12
- import { OperationResolver } from '../capabilities/operation-resolver';
13
- import { meta } from '../meta';
14
- import { Markdown } from '../types';
14
+ import { OperationHandler } from '#capabilities';
15
+
16
+ import { meta } from '#meta';
17
+ import { Markdown } from '#types';
15
18
 
16
19
  export const MarkdownPlugin = Plugin.define(meta).pipe(
17
- Common.Plugin.addSchemaModule({ schema: [Markdown.Document, Text.Text] }),
18
- Common.Plugin.addMetadataModule({
20
+ AppPlugin.addMetadataModule({
19
21
  metadata: {
20
22
  id: Markdown.Document.typename,
21
23
  metadata: {
22
- createObject: ((props) => Effect.sync(() => Markdown.make(props))) satisfies CreateObject,
23
- addToCollectionOnCreate: true,
24
+ createObject: ((props, options) =>
25
+ Effect.gen(function* () {
26
+ const object = Markdown.make(props);
27
+ return yield* Operation.invoke(SpaceOperation.AddObject, {
28
+ object,
29
+ target: options.target,
30
+ hidden: true,
31
+ targetNodeId: options.targetNodeId,
32
+ });
33
+ })) satisfies CreateObject,
24
34
  },
25
35
  },
26
36
  }),
27
- Common.Plugin.addOperationResolverModule({ activate: OperationResolver }),
37
+ AppPlugin.addOperationHandlerModule({ activate: OperationHandler }),
38
+ AppPlugin.addSchemaModule({ schema: [Markdown.Document, Text.Text] }),
28
39
  Plugin.make,
29
40
  );
@@ -7,7 +7,7 @@ import React, { forwardRef, useEffect, useImperativeHandle } from 'react';
7
7
  import { createPortal } from 'react-dom';
8
8
  import { useDropzone } from 'react-dropzone';
9
9
 
10
- import { type Common } from '@dxos/app-framework';
10
+ import { type FileInfo } from '@dxos/app-toolkit';
11
11
  import { addLink } from '@dxos/ui-editor';
12
12
 
13
13
  export const IMAGE_FILES = ['.jpg', '.jpeg', '.png', '.gif'];
@@ -16,7 +16,7 @@ export type FileUploadAction = () => void;
16
16
 
17
17
  export type FileUploadProps = {
18
18
  editorView?: EditorView;
19
- onFileUpload?: (file: File) => Promise<Common.FileInfo | undefined>;
19
+ onFileUpload?: (file: File) => Promise<FileInfo | undefined>;
20
20
  };
21
21
 
22
22
  // TODO(burdon): Factor out.
@@ -9,63 +9,63 @@ import React from 'react';
9
9
  import { withPluginManager } from '@dxos/app-framework/testing';
10
10
  import { Filter, Obj } from '@dxos/echo';
11
11
  import { ClientPlugin } from '@dxos/plugin-client';
12
+ import { initializeIdentity } from '@dxos/plugin-client/testing';
12
13
  import { corePlugins } from '@dxos/plugin-testing';
13
14
  import { useQuery, useSpace } from '@dxos/react-client/echo';
14
- import { withLayout, withTheme } from '@dxos/react-ui/testing';
15
- import { useAttentionAttributes } from '@dxos/react-ui-attention';
15
+ import { Panel } from '@dxos/react-ui';
16
+ import { Loading, withLayout } from '@dxos/react-ui/testing';
17
+ import { AttendableContainer } from '@dxos/react-ui-attention';
16
18
  import { translations as editorTranslations } from '@dxos/react-ui-editor';
17
- import { Layout } from '@dxos/react-ui-mosaic';
19
+ import { Text } from '@dxos/schema';
18
20
 
19
21
  import { translations } from '../../translations';
20
- import { Markdown } from '../../types';
22
+ import { Markdown } from '#types';
21
23
 
22
24
  import { MarkdownEditor, type MarkdownEditorRootProps } from './MarkdownEditor';
23
25
 
24
- const content = Array.from({ length: 100 }, (_, i) => `Line ${i + 1}`).join('\n');
26
+ type DefaultStoryProps = Omit<MarkdownEditorRootProps, 'id' | 'extensions'>;
25
27
 
26
- type StoryProps = Omit<MarkdownEditorRootProps, 'id' | 'extensions'>;
27
-
28
- const DefaultStory = (props: StoryProps) => {
28
+ const DefaultStory = (props: DefaultStoryProps) => {
29
29
  const space = useSpace();
30
30
  const [doc] = useQuery(space?.db, Filter.type(Markdown.Document));
31
31
  const id = doc && Obj.getDXN(doc).toString();
32
- const attentionAttrs = useAttentionAttributes(id);
33
32
  if (!id) {
34
- return null;
33
+ return <Loading data={{ id }} />;
35
34
  }
36
35
 
37
36
  return (
38
- <div className='contents' {...attentionAttrs}>
39
- <Layout.Main toolbar>
40
- <MarkdownEditor.Root id={id} object={doc} {...props}>
41
- <MarkdownEditor.Toolbar id={id} />
42
- <MarkdownEditor.Content />
43
- </MarkdownEditor.Root>
44
- </Layout.Main>
45
- </div>
37
+ <AttendableContainer id={id} tabIndex={0} classNames='dx-container'>
38
+ <MarkdownEditor.Root id={id} object={doc} {...props}>
39
+ <Panel.Root>
40
+ <Panel.Toolbar asChild>
41
+ <MarkdownEditor.Toolbar />
42
+ </Panel.Toolbar>
43
+ <Panel.Content asChild>
44
+ <MarkdownEditor.Content />
45
+ </Panel.Content>
46
+ </Panel.Root>
47
+ </MarkdownEditor.Root>
48
+ </AttendableContainer>
46
49
  );
47
50
  };
48
51
 
49
52
  const meta: Meta<typeof DefaultStory> = {
50
- title: 'plugins/plugin-markdown/MarkdownEditor',
51
- component: DefaultStory,
52
- render: DefaultStory as any,
53
+ title: 'plugins/plugin-markdown/components/MarkdownEditor',
54
+ render: DefaultStory,
53
55
  decorators: [
54
- withTheme,
55
56
  withLayout({ layout: 'column' }),
56
57
  withPluginManager({
57
58
  plugins: [
58
59
  ...corePlugins(),
60
+ // TODO(burdon): Try to write story without ClientPlugin.
59
61
  ClientPlugin({
60
- types: [Markdown.Document],
62
+ types: [Markdown.Document, Text.Text],
61
63
  onClientInitialized: ({ client }) =>
62
64
  Effect.gen(function* () {
63
- yield* Effect.promise(() => client.halo.createIdentity());
64
- yield* Effect.promise(() => client.spaces.waitUntilReady());
65
- const space = client.spaces.default;
66
- yield* Effect.promise(() => space.waitUntilReady());
67
-
68
- space.db.add(Markdown.make({ content }));
65
+ const { personalSpace } = yield* initializeIdentity(client);
66
+ personalSpace.db.add(
67
+ Markdown.make({ content: Array.from({ length: 100 }, (_, i) => `Line ${i + 1}`).join('\n') }),
68
+ );
69
69
  }),
70
70
  }),
71
71
  ],
@@ -9,9 +9,11 @@ import { createContext } from '@radix-ui/react-context';
9
9
  import React, { type PropsWithChildren, useMemo, useState } from 'react';
10
10
  import { createPortal } from 'react-dom';
11
11
 
12
- import { Surface } from '@dxos/app-framework/react';
12
+ import { Surface } from '@dxos/app-framework/ui';
13
+ import { Obj } from '@dxos/echo';
13
14
  import { DXN } from '@dxos/keys';
14
15
  import { useClient } from '@dxos/react-client';
16
+ import { type ThemedClassName } from '@dxos/react-ui';
15
17
  import {
16
18
  EditorMenuProvider,
17
19
  type EditorToolbarState,
@@ -20,6 +22,7 @@ import {
20
22
  useEditorToolbar,
21
23
  } from '@dxos/react-ui-editor';
22
24
  import { type PreviewBlock, type PreviewOptions } from '@dxos/ui-editor';
25
+ import { composable, composableProps } from '@dxos/ui-theme';
23
26
  import { isNonNullable } from '@dxos/util';
24
27
 
25
28
  import {
@@ -28,7 +31,7 @@ import {
28
31
  type UseEditorMenuOptionsProps,
29
32
  useEditorMenuOptions,
30
33
  useExtensions,
31
- } from '../../hooks';
34
+ } from '#hooks';
32
35
 
33
36
  import {
34
37
  MarkdownEditorContent as NaturalMarkdownEditorContent,
@@ -45,12 +48,13 @@ import {
45
48
 
46
49
  type MarkdownEditorContextValue = {
47
50
  id: string;
51
+ attendableId?: string;
48
52
  setEditorView: (view: EditorView) => void;
49
53
  extensions: Extension[];
50
54
  previewBlocks: PreviewBlock[];
51
55
  toolbarState: Atom.Writable<EditorToolbarState>;
52
56
  popoverMenu: Omit<UseEditorMenu, 'extension'>;
53
- } & (Pick<ExtensionsOptions, 'viewMode'> &
57
+ } & (Pick<ExtensionsOptions, 'compact' | 'viewMode'> &
54
58
  Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange'>);
55
59
 
56
60
  const [MarkdownEditorContextProvider, useMarkdownEditorContext] =
@@ -64,22 +68,28 @@ type MarkdownEditorRootProps = PropsWithChildren<
64
68
  {
65
69
  object?: DocumentType;
66
70
  extensions?: Extension[];
67
- } & Pick<MarkdownEditorContextValue, 'id' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'viewMode'> &
71
+ } & Pick<
72
+ MarkdownEditorContextValue,
73
+ 'id' | 'attendableId' | 'viewMode' | 'compact' | 'onAction' | 'onFileUpload' | 'onViewModeChange'
74
+ > &
68
75
  Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &
69
- Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings'>
76
+ Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings' | 'onSelectObject'>
70
77
  >;
71
78
 
72
79
  const MarkdownEditorRoot = ({
73
80
  children,
74
81
  id,
82
+ attendableId,
75
83
  object,
76
- editorStateStore,
77
- selectionManager,
78
84
  settings,
85
+ compact,
79
86
  viewMode,
87
+ selectionManager,
88
+ editorStateStore,
80
89
  extensions: extensionsProp,
81
90
  slashCommandGroups,
82
91
  onLinkQuery,
92
+ onSelectObject,
83
93
  ...props
84
94
  }: MarkdownEditorRootProps) => {
85
95
  const [editorView, setEditorView] = useState<EditorView>();
@@ -88,36 +98,35 @@ const MarkdownEditorRoot = ({
88
98
  const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);
89
99
  const previewOptions = useMemo<PreviewOptions>(
90
100
  () => ({
101
+ db: Obj.isObject(object) ? Obj.getDatabase(object) : undefined,
91
102
  addBlockContainer: (block) => {
92
103
  setPreviewBlocks((prev) => [...prev, block]);
93
104
  },
94
105
  removeBlockContainer: ({ link }) => {
95
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
106
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.dxn !== link.dxn));
96
107
  },
97
108
  }),
98
- [],
109
+ [object],
99
110
  );
100
111
 
101
112
  // Toolbar state.
102
113
  const toolbarState = useEditorToolbar({ viewMode });
103
114
 
104
115
  // Context menu.
105
- const menuOptions = useEditorMenuOptions({
106
- editorView,
107
- slashCommandGroups,
108
- onLinkQuery,
109
- });
116
+ const menuOptions = useEditorMenuOptions({ editorView, slashCommandGroups, onLinkQuery });
110
117
  const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
111
118
 
112
119
  // Extensions.
113
120
  const coreExtensions = useExtensions({
114
121
  id,
115
122
  object,
123
+ compact,
124
+ viewMode,
125
+ selectionManager,
116
126
  editorStateStore,
117
127
  previewOptions,
118
- selectionManager,
119
128
  settings,
120
- viewMode,
129
+ onSelectObject,
121
130
  });
122
131
 
123
132
  const extensions = useMemo(
@@ -128,6 +137,8 @@ const MarkdownEditorRoot = ({
128
137
  return (
129
138
  <MarkdownEditorContextProvider
130
139
  id={id}
140
+ attendableId={attendableId}
141
+ compact={compact}
131
142
  editorView={editorView}
132
143
  setEditorView={setEditorView}
133
144
  extensions={extensions}
@@ -148,24 +159,30 @@ MarkdownEditorRoot.displayName = 'MarkdownEditor.Root';
148
159
  // MarkdownEditor.Main
149
160
  //
150
161
 
162
+ const MARKDOWN_EDITOR_CONTENT_NAME = 'MarkdownEditor.Content';
163
+
151
164
  type MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;
152
165
 
153
- const MarkdownEditorContent = (props: MarkdownEditorContentProps) => {
166
+ const MarkdownEditorContent = composable<HTMLDivElement, MarkdownEditorContentProps>(({ ...props }, _forwardedRef) => {
154
167
  const {
155
168
  id,
169
+ attendableId,
170
+ compact,
156
171
  editorView,
157
172
  setEditorView,
158
173
  viewMode,
159
174
  toolbarState,
160
175
  extensions,
161
176
  popoverMenu: { groupsRef, ...menuProps },
162
- } = useMarkdownEditorContext(MarkdownEditorContent.displayName);
177
+ } = useMarkdownEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
163
178
 
164
179
  return (
165
180
  <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>
166
181
  <NaturalMarkdownEditorContent
167
- {...props}
182
+ {...composableProps(props)}
168
183
  id={id}
184
+ attendableId={attendableId}
185
+ compact={compact}
169
186
  viewMode={viewMode}
170
187
  toolbarState={toolbarState}
171
188
  extensions={extensions}
@@ -173,54 +190,68 @@ const MarkdownEditorContent = (props: MarkdownEditorContentProps) => {
173
190
  />
174
191
  </EditorMenuProvider>
175
192
  );
176
- };
193
+ });
177
194
 
178
- MarkdownEditorContent.displayName = 'MarkdownEditor.Content';
195
+ MarkdownEditorContent.displayName = MARKDOWN_EDITOR_CONTENT_NAME;
179
196
 
180
197
  //
181
198
  // MarkdownEditor.Toolbar
182
199
  //
183
200
 
184
- type MarkdownEditorToolbarProps = Omit<
185
- NaturalMarkdownToolbarProps,
186
- 'state' | 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange'
201
+ const MARKDOWN_EDITOR_TOOLBAR_NAME = 'MarkdownEditor.Toolbar';
202
+
203
+ type MarkdownEditorToolbarProps = ThemedClassName<
204
+ Omit<NaturalMarkdownToolbarProps, 'state' | 'editorView' | 'onAction' | 'onFileUpload' | 'onViewModeChange' | 'id'>
187
205
  >;
188
206
 
189
207
  const MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {
190
- const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar.displayName);
208
+ const { id, attendableId, editorView, toolbarState, onAction, onFileUpload, onViewModeChange } =
209
+ useMarkdownEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
191
210
 
192
- return <NaturalMarkdownToolbar {...props} {...rootProps} state={toolbarState} />;
211
+ return (
212
+ <NaturalMarkdownToolbar
213
+ {...props}
214
+ id={attendableId ?? id}
215
+ editorView={editorView}
216
+ state={toolbarState}
217
+ onAction={onAction}
218
+ onFileUpload={onFileUpload}
219
+ onViewModeChange={onViewModeChange}
220
+ />
221
+ );
193
222
  };
194
223
 
195
- MarkdownEditorToolbar.displayName = 'MarkdownEditor.Toolbar';
224
+ MarkdownEditorToolbar.displayName = MARKDOWN_EDITOR_TOOLBAR_NAME;
196
225
 
197
226
  //
198
227
  // MarkdownEditor.Blocks (embedded objects)
199
228
  //
200
229
 
230
+ const MARKDOWN_EDITOR_BLOCKS_NAME = 'MarkdownEditor.Blocks';
231
+
201
232
  type MarkdownEditorBlocksProps = {};
202
233
 
203
234
  const MarkdownEditorBlocks = (_props: MarkdownEditorBlocksProps) => {
204
- const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);
235
+ const { previewBlocks } = useMarkdownEditorContext(MARKDOWN_EDITOR_BLOCKS_NAME);
205
236
 
206
237
  return (
207
238
  <>
208
239
  {previewBlocks.map(({ link, el }) => (
209
- <PreviewBlock key={link.ref} link={link} el={el} />
240
+ <PreviewBlock key={link.dxn} link={link} el={el} />
210
241
  ))}
211
242
  </>
212
243
  );
213
244
  };
214
245
 
215
- MarkdownEditorBlocks.displayName = 'MarkdownEditor.Blocks';
246
+ MarkdownEditorBlocks.displayName = MARKDOWN_EDITOR_BLOCKS_NAME;
216
247
 
217
248
  const PreviewBlock = ({ el, link }: PreviewBlock) => {
218
249
  const client = useClient();
219
- const dxn = DXN.parse(link.ref);
250
+ const dxn = DXN.parse(link.dxn);
220
251
  const subject = client.graph.makeRef(dxn).target;
221
252
  const data = useMemo(() => ({ subject }), [subject]);
222
253
 
223
- return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);
254
+ return createPortal(<Surface.Surface role='card--content' data={data} limit={1} />, el);
224
255
  };
225
256
 
226
257
  //