@dxos/plugin-markdown 0.8.4-main.1da679c → 0.8.4-main.21d9917

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 (365) hide show
  1. package/dist/lib/browser/MarkdownCard-HFNNE4B4.mjs +12 -0
  2. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +12 -0
  3. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs +32 -0
  4. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +7 -0
  5. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs +58 -0
  6. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +7 -0
  7. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +19 -0
  8. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +7 -0
  9. package/dist/lib/browser/blueprints/index.mjs +8 -0
  10. package/dist/lib/browser/blueprints/index.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-BX73DASG.mjs +702 -0
  12. package/dist/lib/browser/chunk-BX73DASG.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-CUGDX7KA.mjs +8 -0
  14. package/dist/lib/browser/chunk-CUGDX7KA.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-FWQQW6KU.mjs +144 -0
  16. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +7 -0
  17. package/dist/lib/browser/{chunk-Z7P6JGGW.mjs → chunk-JOXYQLKH.mjs} +9 -7
  18. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-KDKXFKDN.mjs +104 -0
  20. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +7 -0
  21. package/dist/lib/browser/chunk-LMO5UVKL.mjs +167 -0
  22. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-S45ULIOG.mjs +101 -0
  24. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +7 -0
  25. package/dist/lib/browser/chunk-VQ3WOAB6.mjs +60 -0
  26. package/dist/lib/browser/chunk-VQ3WOAB6.mjs.map +7 -0
  27. package/dist/lib/browser/cli/index.mjs +32 -0
  28. package/dist/lib/browser/cli/index.mjs.map +7 -0
  29. package/dist/lib/browser/index.mjs +124 -145
  30. package/dist/lib/browser/index.mjs.map +4 -4
  31. package/dist/lib/browser/meta.json +1 -1
  32. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs +53 -0
  33. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +7 -0
  34. package/dist/lib/browser/react-surface-64FZ7T7F.mjs +213 -0
  35. package/dist/lib/browser/react-surface-64FZ7T7F.mjs.map +7 -0
  36. package/dist/lib/browser/settings-JY5JE7MI.mjs +35 -0
  37. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +7 -0
  38. package/dist/lib/browser/state-QE7VSJWJ.mjs +29 -0
  39. package/dist/lib/browser/state-QE7VSJWJ.mjs.map +7 -0
  40. package/dist/lib/browser/types/index.mjs +10 -3
  41. package/dist/lib/node-esm/MarkdownCard-GMNXUWWR.mjs +13 -0
  42. package/dist/lib/node-esm/MarkdownCard-GMNXUWWR.mjs.map +7 -0
  43. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +13 -0
  44. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +7 -0
  45. package/dist/lib/node-esm/{anchor-sort-J2BK2XLZ.mjs → anchor-sort-G7D5TAI6.mjs} +12 -12
  46. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +7 -0
  47. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs +59 -0
  48. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +7 -0
  49. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +20 -0
  50. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +7 -0
  51. package/dist/lib/node-esm/blueprints/index.mjs +9 -0
  52. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs +105 -0
  54. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +7 -0
  55. package/dist/lib/node-esm/{chunk-J7A6TUB2.mjs → chunk-44VJC3QF.mjs} +9 -7
  56. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs +703 -0
  58. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +7 -0
  59. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +145 -0
  60. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +7 -0
  61. package/dist/lib/node-esm/chunk-KXEQCFMB.mjs +61 -0
  62. package/dist/lib/node-esm/chunk-KXEQCFMB.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs +168 -0
  64. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +102 -0
  66. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +7 -0
  67. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs +10 -0
  68. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs.map +7 -0
  69. package/dist/lib/node-esm/cli/index.mjs +33 -0
  70. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  71. package/dist/lib/node-esm/index.mjs +124 -145
  72. package/dist/lib/node-esm/index.mjs.map +4 -4
  73. package/dist/lib/node-esm/meta.json +1 -1
  74. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs +54 -0
  75. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +7 -0
  76. package/dist/lib/node-esm/react-surface-PKEVHTJK.mjs +214 -0
  77. package/dist/lib/node-esm/react-surface-PKEVHTJK.mjs.map +7 -0
  78. package/dist/lib/node-esm/settings-4UGMPIRY.mjs +36 -0
  79. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +7 -0
  80. package/dist/lib/node-esm/state-LXE5XIN4.mjs +30 -0
  81. package/dist/lib/node-esm/state-LXE5XIN4.mjs.map +7 -0
  82. package/dist/lib/node-esm/types/index.mjs +10 -3
  83. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  84. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  85. package/dist/types/src/blueprints/functions/create.d.ts +8 -0
  86. package/dist/types/src/blueprints/functions/create.d.ts.map +1 -0
  87. package/dist/types/src/blueprints/functions/create.test.d.ts +2 -0
  88. package/dist/types/src/blueprints/functions/create.test.d.ts.map +1 -0
  89. package/dist/types/src/blueprints/functions/index.d.ts +4 -0
  90. package/dist/types/src/blueprints/functions/index.d.ts.map +1 -0
  91. package/dist/types/src/{functions → blueprints/functions}/open.d.ts +1 -1
  92. package/dist/types/src/blueprints/functions/open.d.ts.map +1 -0
  93. package/dist/types/src/{functions/diff.d.ts → blueprints/functions/update.d.ts} +2 -2
  94. package/dist/types/src/blueprints/functions/update.d.ts.map +1 -0
  95. package/dist/types/src/blueprints/functions/update.test.d.ts +2 -0
  96. package/dist/types/src/blueprints/functions/update.test.d.ts.map +1 -0
  97. package/dist/types/src/blueprints/index.d.ts +2 -0
  98. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  99. package/dist/types/src/blueprints/markdown-blueprint.d.ts +21 -0
  100. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  101. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +5 -0
  102. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +1 -0
  103. package/dist/types/src/capabilities/anchor-sort/index.d.ts +3 -0
  104. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +1 -0
  105. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +5 -0
  106. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +1 -0
  107. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +3 -0
  108. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +1 -0
  109. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +5 -0
  110. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +1 -0
  111. package/dist/types/src/capabilities/artifact-definition/index.d.ts +3 -0
  112. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +1 -0
  113. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +10 -0
  114. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -0
  115. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +3 -0
  116. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -0
  117. package/dist/types/src/capabilities/index.d.ts +6 -17
  118. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  119. package/dist/types/src/capabilities/operation-resolver/index.d.ts +3 -0
  120. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +1 -0
  121. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +5 -0
  122. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -0
  123. package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
  124. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
  125. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
  126. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
  127. package/dist/types/src/capabilities/settings/index.d.ts +3 -0
  128. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
  129. package/dist/types/src/capabilities/settings/settings.d.ts +6 -0
  130. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
  131. package/dist/types/src/capabilities/state/index.d.ts +3 -0
  132. package/dist/types/src/capabilities/state/index.d.ts.map +1 -0
  133. package/dist/types/src/capabilities/state/state.d.ts +5 -0
  134. package/dist/types/src/capabilities/state/state.d.ts.map +1 -0
  135. package/dist/types/src/cli/index.d.ts +2 -0
  136. package/dist/types/src/cli/index.d.ts.map +1 -0
  137. package/dist/types/src/cli/plugin.d.ts +3 -0
  138. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  139. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +5 -4
  140. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  141. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +5 -6
  142. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  143. package/dist/types/src/components/MarkdownContainer.d.ts +21 -11
  144. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  145. package/dist/types/src/components/MarkdownContainer.stories.d.ts +9 -6
  146. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
  147. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  148. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  149. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +43 -23
  150. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  151. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +5 -110
  152. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  153. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +30 -0
  154. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  155. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +12 -0
  156. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  157. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -2
  158. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  159. package/dist/types/src/components/Suggestions.stories.d.ts +1 -2
  160. package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
  161. package/dist/types/src/components/index.d.ts +7 -2
  162. package/dist/types/src/components/index.d.ts.map +1 -1
  163. package/dist/types/src/hooks/index.d.ts +3 -0
  164. package/dist/types/src/hooks/index.d.ts.map +1 -1
  165. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  166. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  167. package/dist/types/src/hooks/useExtensions.d.ts +21 -0
  168. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  169. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  170. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  171. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
  172. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  173. package/dist/types/src/index.d.ts +1 -2
  174. package/dist/types/src/index.d.ts.map +1 -1
  175. package/dist/types/src/meta.d.ts +2 -2
  176. package/dist/types/src/meta.d.ts.map +1 -1
  177. package/dist/types/src/testing.d.ts +6 -0
  178. package/dist/types/src/testing.d.ts.map +1 -0
  179. package/dist/types/src/translations.d.ts +4 -0
  180. package/dist/types/src/translations.d.ts.map +1 -1
  181. package/dist/types/src/types/Markdown.d.ts +17 -15
  182. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  183. package/dist/types/src/types/MarkdownAction.d.ts +64 -31
  184. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  185. package/dist/types/src/types/capabilities.d.ts +22 -0
  186. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  187. package/dist/types/src/types/events.d.ts +5 -0
  188. package/dist/types/src/types/events.d.ts.map +1 -0
  189. package/dist/types/src/types/index.d.ts +3 -0
  190. package/dist/types/src/types/index.d.ts.map +1 -1
  191. package/dist/types/src/types/types.d.ts +2 -2
  192. package/dist/types/src/types/types.d.ts.map +1 -1
  193. package/dist/types/src/util.d.ts +6 -3
  194. package/dist/types/src/util.d.ts.map +1 -1
  195. package/dist/types/src/util.test.d.ts +2 -0
  196. package/dist/types/src/util.test.d.ts.map +1 -0
  197. package/dist/types/tsconfig.tsbuildinfo +1 -1
  198. package/package.json +89 -58
  199. package/src/MarkdownPlugin.tsx +79 -110
  200. package/src/blueprints/functions/create.conversations.json +1 -0
  201. package/src/blueprints/functions/create.test.ts +125 -0
  202. package/src/blueprints/functions/create.ts +34 -0
  203. package/src/blueprints/functions/index.ts +7 -0
  204. package/src/{functions → blueprints/functions}/open.ts +8 -5
  205. package/src/blueprints/functions/update.conversations.json +1 -0
  206. package/src/blueprints/functions/update.test.ts +149 -0
  207. package/src/{functions/diff.ts → blueprints/functions/update.ts} +8 -5
  208. package/src/blueprints/index.ts +5 -0
  209. package/src/blueprints/markdown-blueprint.ts +38 -0
  210. package/src/capabilities/anchor-sort/anchor-sort.ts +36 -0
  211. package/src/capabilities/anchor-sort/index.ts +7 -0
  212. package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +59 -0
  213. package/src/capabilities/app-graph-serializer/index.ts +7 -0
  214. package/src/capabilities/artifact-definition/artifact-definition.ts +110 -0
  215. package/src/capabilities/artifact-definition/index.ts +7 -0
  216. package/src/capabilities/blueprint-definition/blueprint-definition.ts +25 -0
  217. package/src/capabilities/blueprint-definition/index.ts +7 -0
  218. package/src/capabilities/index.ts +6 -12
  219. package/src/capabilities/operation-resolver/index.ts +7 -0
  220. package/src/capabilities/operation-resolver/operation-resolver.ts +45 -0
  221. package/src/capabilities/react-surface/index.ts +7 -0
  222. package/src/capabilities/react-surface/react-surface.tsx +100 -0
  223. package/src/capabilities/settings/index.ts +7 -0
  224. package/src/capabilities/settings/settings.ts +36 -0
  225. package/src/capabilities/state/index.ts +7 -0
  226. package/src/capabilities/state/state.ts +31 -0
  227. package/src/cli/index.ts +5 -0
  228. package/src/cli/plugin.ts +29 -0
  229. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +28 -49
  230. package/src/components/MarkdownCard/MarkdownCard.tsx +42 -55
  231. package/src/components/MarkdownContainer.stories.tsx +70 -58
  232. package/src/components/MarkdownContainer.tsx +104 -249
  233. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  234. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +55 -36
  235. package/src/components/MarkdownEditor/MarkdownEditor.tsx +221 -271
  236. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +162 -0
  237. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +66 -0
  238. package/src/components/MarkdownSettings/MarkdownSettings.tsx +24 -10
  239. package/src/components/Suggestions.stories.tsx +51 -54
  240. package/src/components/index.ts +10 -3
  241. package/src/hooks/index.ts +3 -0
  242. package/src/hooks/useEditorMenuOptions.ts +68 -0
  243. package/src/{extensions.tsx → hooks/useExtensions.tsx} +72 -98
  244. package/src/hooks/useLinkQuery.ts +83 -0
  245. package/src/hooks/useSelectCurrentThread.tsx +38 -33
  246. package/src/index.ts +1 -2
  247. package/src/meta.ts +5 -5
  248. package/src/testing.ts +27 -0
  249. package/src/translations.ts +4 -0
  250. package/src/types/Markdown.ts +11 -10
  251. package/src/types/MarkdownAction.ts +49 -19
  252. package/src/types/capabilities.ts +38 -0
  253. package/src/types/events.ts +13 -0
  254. package/src/types/index.ts +4 -0
  255. package/src/types/types.ts +3 -2
  256. package/src/util.test.ts +44 -0
  257. package/src/util.tsx +82 -7
  258. package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs +0 -80
  259. package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs.map +0 -7
  260. package/dist/lib/browser/MarkdownContainer-OZ5DHEIA.mjs +0 -750
  261. package/dist/lib/browser/MarkdownContainer-OZ5DHEIA.mjs.map +0 -7
  262. package/dist/lib/browser/anchor-sort-SUD373SW.mjs +0 -32
  263. package/dist/lib/browser/anchor-sort-SUD373SW.mjs.map +0 -7
  264. package/dist/lib/browser/app-graph-serializer-GH7JJZB7.mjs +0 -51
  265. package/dist/lib/browser/app-graph-serializer-GH7JJZB7.mjs.map +0 -7
  266. package/dist/lib/browser/blueprint-definition-JSNGFAZB.mjs +0 -11
  267. package/dist/lib/browser/chunk-BEE7VQPU.mjs +0 -78
  268. package/dist/lib/browser/chunk-BEE7VQPU.mjs.map +0 -7
  269. package/dist/lib/browser/chunk-LAVZ2W6X.mjs +0 -50
  270. package/dist/lib/browser/chunk-LAVZ2W6X.mjs.map +0 -7
  271. package/dist/lib/browser/chunk-ODB2PTBP.mjs +0 -28
  272. package/dist/lib/browser/chunk-ODB2PTBP.mjs.map +0 -7
  273. package/dist/lib/browser/chunk-OY6CGPOO.mjs +0 -16
  274. package/dist/lib/browser/chunk-OY6CGPOO.mjs.map +0 -7
  275. package/dist/lib/browser/chunk-SQLSKQRQ.mjs +0 -22
  276. package/dist/lib/browser/chunk-SQLSKQRQ.mjs.map +0 -7
  277. package/dist/lib/browser/chunk-UM2GILLR.mjs +0 -102
  278. package/dist/lib/browser/chunk-UM2GILLR.mjs.map +0 -7
  279. package/dist/lib/browser/chunk-Z7P6JGGW.mjs.map +0 -7
  280. package/dist/lib/browser/intent-resolver-SUBIHVU7.mjs +0 -62
  281. package/dist/lib/browser/intent-resolver-SUBIHVU7.mjs.map +0 -7
  282. package/dist/lib/browser/react-surface-JBQHF4GR.mjs +0 -215
  283. package/dist/lib/browser/react-surface-JBQHF4GR.mjs.map +0 -7
  284. package/dist/lib/browser/settings-T5ZMC5TH.mjs +0 -28
  285. package/dist/lib/browser/settings-T5ZMC5TH.mjs.map +0 -7
  286. package/dist/lib/browser/state-6QODXCSZ.mjs +0 -37
  287. package/dist/lib/browser/state-6QODXCSZ.mjs.map +0 -7
  288. package/dist/lib/browser/toolkit-GNADYSGW.mjs +0 -74
  289. package/dist/lib/browser/toolkit-GNADYSGW.mjs.map +0 -7
  290. package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs +0 -81
  291. package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs.map +0 -7
  292. package/dist/lib/node-esm/MarkdownContainer-Z4I23DPN.mjs +0 -751
  293. package/dist/lib/node-esm/MarkdownContainer-Z4I23DPN.mjs.map +0 -7
  294. package/dist/lib/node-esm/anchor-sort-J2BK2XLZ.mjs.map +0 -7
  295. package/dist/lib/node-esm/app-graph-serializer-LRYCXG7N.mjs +0 -52
  296. package/dist/lib/node-esm/app-graph-serializer-LRYCXG7N.mjs.map +0 -7
  297. package/dist/lib/node-esm/blueprint-definition-KX3Y5JHC.mjs +0 -12
  298. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs +0 -17
  299. package/dist/lib/node-esm/chunk-CB2R4YIY.mjs.map +0 -7
  300. package/dist/lib/node-esm/chunk-FXILAQ5F.mjs +0 -79
  301. package/dist/lib/node-esm/chunk-FXILAQ5F.mjs.map +0 -7
  302. package/dist/lib/node-esm/chunk-J7A6TUB2.mjs.map +0 -7
  303. package/dist/lib/node-esm/chunk-KAXL7TWD.mjs +0 -103
  304. package/dist/lib/node-esm/chunk-KAXL7TWD.mjs.map +0 -7
  305. package/dist/lib/node-esm/chunk-MJZPYYIH.mjs +0 -24
  306. package/dist/lib/node-esm/chunk-MJZPYYIH.mjs.map +0 -7
  307. package/dist/lib/node-esm/chunk-O6EXWGGS.mjs +0 -51
  308. package/dist/lib/node-esm/chunk-O6EXWGGS.mjs.map +0 -7
  309. package/dist/lib/node-esm/chunk-VCG2U522.mjs +0 -29
  310. package/dist/lib/node-esm/chunk-VCG2U522.mjs.map +0 -7
  311. package/dist/lib/node-esm/intent-resolver-YZEGYWGA.mjs +0 -63
  312. package/dist/lib/node-esm/intent-resolver-YZEGYWGA.mjs.map +0 -7
  313. package/dist/lib/node-esm/react-surface-JOXUHXQJ.mjs +0 -216
  314. package/dist/lib/node-esm/react-surface-JOXUHXQJ.mjs.map +0 -7
  315. package/dist/lib/node-esm/settings-LGG22OH4.mjs +0 -29
  316. package/dist/lib/node-esm/settings-LGG22OH4.mjs.map +0 -7
  317. package/dist/lib/node-esm/state-W3PECOJX.mjs +0 -38
  318. package/dist/lib/node-esm/state-W3PECOJX.mjs.map +0 -7
  319. package/dist/lib/node-esm/toolkit-ZCFWOGNH.mjs +0 -75
  320. package/dist/lib/node-esm/toolkit-ZCFWOGNH.mjs.map +0 -7
  321. package/dist/types/src/capabilities/anchor-sort.d.ts +0 -6
  322. package/dist/types/src/capabilities/anchor-sort.d.ts.map +0 -1
  323. package/dist/types/src/capabilities/app-graph-serializer.d.ts +0 -4
  324. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +0 -1
  325. package/dist/types/src/capabilities/artifact-definition.d.ts +0 -3
  326. package/dist/types/src/capabilities/artifact-definition.d.ts.map +0 -1
  327. package/dist/types/src/capabilities/blueprint-definition.d.ts +0 -5
  328. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +0 -1
  329. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  330. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  331. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  332. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  333. package/dist/types/src/capabilities/react-surface.d.ts +0 -4
  334. package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
  335. package/dist/types/src/capabilities/settings.d.ts +0 -4
  336. package/dist/types/src/capabilities/settings.d.ts.map +0 -1
  337. package/dist/types/src/capabilities/state.d.ts +0 -11
  338. package/dist/types/src/capabilities/state.d.ts.map +0 -1
  339. package/dist/types/src/capabilities/toolkit.d.ts +0 -4
  340. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  341. package/dist/types/src/components/Toolbar.stories.d.ts +0 -48
  342. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  343. package/dist/types/src/events.d.ts +0 -4
  344. package/dist/types/src/events.d.ts.map +0 -1
  345. package/dist/types/src/extensions.d.ts +0 -22
  346. package/dist/types/src/extensions.d.ts.map +0 -1
  347. package/dist/types/src/functions/diff.d.ts.map +0 -1
  348. package/dist/types/src/functions/index.d.ts +0 -3
  349. package/dist/types/src/functions/index.d.ts.map +0 -1
  350. package/dist/types/src/functions/open.d.ts.map +0 -1
  351. package/src/capabilities/anchor-sort.ts +0 -30
  352. package/src/capabilities/app-graph-serializer.ts +0 -54
  353. package/src/capabilities/artifact-definition.ts +0 -111
  354. package/src/capabilities/blueprint-definition.ts +0 -39
  355. package/src/capabilities/capabilities.ts +0 -21
  356. package/src/capabilities/intent-resolver.ts +0 -57
  357. package/src/capabilities/react-surface.tsx +0 -115
  358. package/src/capabilities/settings.ts +0 -25
  359. package/src/capabilities/state.ts +0 -31
  360. package/src/capabilities/toolkit.ts +0 -47
  361. package/src/components/Toolbar.stories.tsx +0 -118
  362. package/src/events.ts +0 -11
  363. package/src/functions/index.ts +0 -6
  364. /package/dist/lib/browser/{blueprint-definition-JSNGFAZB.mjs.map → MarkdownCard-HFNNE4B4.mjs.map} +0 -0
  365. /package/dist/lib/{node-esm/blueprint-definition-KX3Y5JHC.mjs.map → browser/MarkdownContainer-V7EAADMF.mjs.map} +0 -0
@@ -0,0 +1,100 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import React, { forwardRef, useCallback, useMemo } from 'react';
7
+
8
+ import { Capability, Common } from '@dxos/app-framework';
9
+ import {
10
+ type SurfaceComponentProps,
11
+ useAtomCapability,
12
+ useAtomCapabilityState,
13
+ useCapability,
14
+ useSettingsState,
15
+ } from '@dxos/app-framework/react';
16
+ import { Obj } from '@dxos/echo';
17
+ import { AttentionCapabilities } from '@dxos/plugin-attention';
18
+ import { Text } from '@dxos/schema';
19
+ import { type EditorViewMode } from '@dxos/ui-editor';
20
+
21
+ import { MarkdownCard, MarkdownContainer, type MarkdownContainerProps, MarkdownSettings } from '../../components';
22
+ import { meta } from '../../meta';
23
+ import { Markdown, MarkdownCapabilities } from '../../types';
24
+
25
+ export default Capability.makeModule(() =>
26
+ Effect.succeed(
27
+ Capability.contributes(Common.Capability.ReactSurface, [
28
+ Common.createSurface({
29
+ id: `${meta.id}/surface/document`,
30
+ role: ['article', 'section', 'tabpanel'],
31
+ filter: (data): data is { subject: Markdown.Document; variant: undefined } =>
32
+ Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
33
+ component: ({ data, role, ref }) => {
34
+ return <Container id={Obj.getDXN(data.subject).toString()} subject={data.subject} role={role} ref={ref} />;
35
+ },
36
+ }),
37
+ Common.createSurface({
38
+ id: `${meta.id}/surface/text`,
39
+ 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} />;
44
+ },
45
+ }),
46
+ Common.createSurface({
47
+ id: `${meta.id}/surface/plugin-settings`,
48
+ role: 'article',
49
+ filter: (data): data is { subject: Common.Capability.Settings } =>
50
+ Common.Capability.isSettings(data.subject) && data.subject.prefix === meta.id,
51
+ component: ({ data: { subject } }) => {
52
+ const { settings, updateSettings } = useSettingsState<Markdown.Settings>(subject.atom);
53
+ return <MarkdownSettings settings={settings} onSettingsChange={updateSettings} />;
54
+ },
55
+ }),
56
+ Common.createSurface({
57
+ id: `${meta.id}/surface/preview`,
58
+ role: 'card--content',
59
+ filter: (data): data is { subject: Markdown.Document | Text.Text } =>
60
+ Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
61
+ component: ({ data }) => <MarkdownCard {...data} />,
62
+ }),
63
+ ]),
64
+ ),
65
+ );
66
+
67
+ /**
68
+ * Common wrapper.
69
+ */
70
+ const Container = forwardRef<HTMLDivElement, SurfaceComponentProps<Markdown.Document | Text.Text, { id: string }>>(
71
+ ({ id, subject, role }, forwardedRef) => {
72
+ const selectionManager = useCapability(AttentionCapabilities.Selection);
73
+ const settings = useAtomCapability(MarkdownCapabilities.Settings);
74
+ const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
75
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
76
+ const extensions = useCapability(MarkdownCapabilities.Extensions);
77
+ const extensionProviders = useMemo(() => extensions.flat(), [extensions]);
78
+
79
+ const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';
80
+ const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(
81
+ (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),
82
+ [id, setState],
83
+ );
84
+
85
+ return (
86
+ <MarkdownContainer
87
+ role={role}
88
+ subject={subject}
89
+ id={id}
90
+ settings={settings}
91
+ selectionManager={selectionManager}
92
+ extensionProviders={extensionProviders}
93
+ editorStateStore={editorState}
94
+ viewMode={viewMode}
95
+ onViewModeChange={handleViewModeChange}
96
+ ref={forwardedRef}
97
+ />
98
+ );
99
+ },
100
+ );
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { Capability } from '@dxos/app-framework';
6
+
7
+ export const MarkdownSettings = Capability.lazy('MarkdownSettings', () => import('./settings'));
@@ -0,0 +1,36 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capability, Common } from '@dxos/app-framework';
8
+ import { createKvsStore } from '@dxos/effect';
9
+
10
+ import { meta } from '../../meta';
11
+ import { Markdown, MarkdownCapabilities } from '../../types';
12
+
13
+ export default Capability.makeModule(() =>
14
+ Effect.sync(() => {
15
+ const settingsAtom = createKvsStore({
16
+ key: meta.id,
17
+ schema: Markdown.Settings,
18
+ defaultValue: () => ({
19
+ defaultViewMode: 'preview' as const,
20
+ toolbar: true,
21
+ numberedHeadings: true,
22
+ folding: true,
23
+ experimental: false,
24
+ }),
25
+ });
26
+
27
+ return [
28
+ Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),
29
+ Capability.contributes(Common.Capability.Settings, {
30
+ prefix: meta.id,
31
+ schema: Markdown.Settings,
32
+ atom: settingsAtom,
33
+ }),
34
+ ];
35
+ }),
36
+ );
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { Capability } from '@dxos/app-framework';
6
+
7
+ export const MarkdownState = Capability.lazy('MarkdownState', () => import('./state'));
@@ -0,0 +1,31 @@
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 { MarkdownCapabilities, MarkdownStateSchema } from '../../types';
13
+
14
+ export default Capability.makeModule(
15
+ Effect.fnUntraced(function* () {
16
+ // Persisted state using KVS store.
17
+ const stateAtom = createKvsStore({
18
+ key: `${meta.id}/state`,
19
+ schema: MarkdownStateSchema,
20
+ defaultValue: () => ({ viewMode: {} }),
21
+ });
22
+
23
+ // TODO(wittjosiah): Fold into state.
24
+ const editorState = createEditorStateStore(`${meta.id}/editor`);
25
+
26
+ return [
27
+ Capability.contributes(MarkdownCapabilities.State, stateAtom),
28
+ Capability.contributes(MarkdownCapabilities.EditorState, editorState),
29
+ ];
30
+ }),
31
+ );
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './plugin';
@@ -0,0 +1,29 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Common, Plugin } from '@dxos/app-framework';
8
+ import { type CreateObject } from '@dxos/plugin-space/types';
9
+ import { Text } from '@dxos/schema';
10
+
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';
15
+
16
+ export const MarkdownPlugin = Plugin.define(meta).pipe(
17
+ Common.Plugin.addSchemaModule({ schema: [Markdown.Document, Text.Text] }),
18
+ Common.Plugin.addMetadataModule({
19
+ metadata: {
20
+ id: Markdown.Document.typename,
21
+ metadata: {
22
+ createObject: ((props) => Effect.sync(() => Markdown.make(props))) satisfies CreateObject,
23
+ addToCollectionOnCreate: true,
24
+ },
25
+ },
26
+ }),
27
+ Common.Plugin.addOperationResolverModule({ activate: OperationResolver }),
28
+ Plugin.make,
29
+ );
@@ -2,78 +2,57 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
8
- import React from 'react';
6
+ import React, { useMemo } from 'react';
9
7
 
10
- import { IntentPlugin } from '@dxos/app-framework';
8
+ import { OperationPlugin } from '@dxos/app-framework';
11
9
  import { withPluginManager } from '@dxos/app-framework/testing';
12
10
  import { Markdown } from '@dxos/plugin-markdown/types';
13
11
  import { faker } from '@dxos/random';
14
- import { CardContainer } from '@dxos/react-ui-stack/testing';
15
- import { withLayout, withTheme } from '@dxos/storybook-utils';
12
+ import { withTheme } from '@dxos/react-ui/testing';
13
+ import { CardContainer } from '@dxos/react-ui-mosaic/testing';
16
14
 
17
15
  import { translations } from '../../translations';
18
16
 
19
- import { MarkdownCard } from './MarkdownCard';
17
+ import { MarkdownCard, type MarkdownCardProps } from './MarkdownCard';
20
18
 
21
19
  faker.seed(1234);
22
20
 
23
- const meta: Meta<typeof MarkdownCard> = {
21
+ // TODO(wittjosiah): ECHO objects don't work when passed via Storybook args.
22
+ const MarkdownCardStory = ({ ...args }: Omit<MarkdownCardProps, 'subject'>) => {
23
+ const subject = useMemo(
24
+ () =>
25
+ Markdown.make({
26
+ name: faker.lorem.words(3),
27
+ content: faker.lorem.paragraphs(3),
28
+ }),
29
+ [],
30
+ );
31
+ return (
32
+ <CardContainer icon='ph--text-aa--regular'>
33
+ <MarkdownCard subject={subject} {...args} />
34
+ </CardContainer>
35
+ );
36
+ };
37
+
38
+ const meta: Meta<typeof MarkdownCardStory> = {
24
39
  title: 'plugins/plugin-markdown/Card',
25
- component: MarkdownCard,
26
- render: ({ role, subject, ...args }) => {
27
- return (
28
- <CardContainer icon='ph--text-aa--regular' role={role}>
29
- <MarkdownCard role={role} subject={subject} {...args} />
30
- </CardContainer>
31
- );
32
- },
40
+ component: MarkdownCardStory,
33
41
  decorators: [
42
+ withTheme,
34
43
  withPluginManager({
35
- plugins: [IntentPlugin()],
44
+ plugins: [OperationPlugin()],
36
45
  }),
37
- withTheme,
38
- withLayout(),
39
46
  ],
40
47
  parameters: {
41
48
  layout: 'centered',
42
49
  translations,
43
50
  },
44
51
  tags: ['cards'],
45
- } satisfies Meta<typeof MarkdownCard>;
52
+ };
46
53
 
47
54
  export default meta;
48
55
 
49
56
  type Story = StoryObj<typeof meta>;
50
57
 
51
- export const Popover: Story = {
52
- args: {
53
- role: 'card--popover',
54
- subject: Markdown.makeDocument({
55
- name: faker.lorem.words(3),
56
- content: faker.lorem.paragraphs(3),
57
- }),
58
- },
59
- };
60
-
61
- export const Intrinsic: Story = {
62
- args: {
63
- role: 'card--intrinsic',
64
- subject: Markdown.makeDocument({
65
- name: faker.lorem.words(3),
66
- content: faker.lorem.paragraphs(3),
67
- }),
68
- },
69
- };
70
-
71
- export const Extrinsic: Story = {
72
- args: {
73
- role: 'card--extrinsic',
74
- subject: Markdown.makeDocument({
75
- name: faker.lorem.words(3),
76
- content: faker.lorem.paragraphs(3),
77
- }),
78
- },
79
- };
58
+ export const Default: Story = {};
@@ -2,74 +2,61 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { pipe } from 'effect';
6
- import React, { useCallback } from 'react';
5
+ import React, { useMemo } from 'react';
7
6
 
8
- import { LayoutAction, chain, createIntent, useIntentDispatcher } from '@dxos/app-framework';
9
7
  import { Obj } from '@dxos/echo';
10
- import { type PreviewProps } from '@dxos/plugin-preview';
11
- import { fullyQualifiedId } from '@dxos/react-client/echo';
12
- import { Button, Icon, useTranslation } from '@dxos/react-ui';
13
- import { Card } from '@dxos/react-ui-stack';
14
- import { DataType } from '@dxos/schema';
8
+ import { useTranslation } from '@dxos/react-ui';
9
+ import { Card } from '@dxos/react-ui-mosaic';
10
+ import { Text } from '@dxos/schema';
15
11
 
16
12
  import { meta } from '../../meta';
17
13
  import { Markdown } from '../../types';
18
- import { getAbstract, getFallbackName } from '../../util';
14
+ import { getContentSnippet, getFallbackName } from '../../util';
15
+ import { MarkdownEditor } from '../MarkdownEditor';
16
+
17
+ export type MarkdownCardProps = { subject: Markdown.Document | Text.Text };
18
+
19
+ export const MarkdownCard = ({ subject }: MarkdownCardProps) => {
20
+ const { t } = useTranslation(meta.id);
21
+ const snippet = useMemo(() => getSnippet(subject), [subject]);
22
+ const info = getInfo(subject);
23
+
24
+ return (
25
+ <Card.Content>
26
+ {snippet && (
27
+ <div className='max-h-[300px] overflow-hidden'>
28
+ <MarkdownEditor.Root id={subject.id} viewMode='readonly'>
29
+ <MarkdownEditor.Content initialValue={snippet} slots={{}} classNames='!bg-transparent' />
30
+ </MarkdownEditor.Root>
31
+ </div>
32
+ )}
33
+ <Card.Text classNames='text-xs text-description'>
34
+ {info.words} {t('words label', { count: info.words })}
35
+ </Card.Text>
36
+ </Card.Content>
37
+ );
38
+ };
39
+
40
+ const getInfo = (subject: Markdown.Document | Text.Text) => {
41
+ const text = (Obj.instanceOf(Markdown.Document, subject) ? subject.content?.target?.content : subject.content) ?? '';
42
+ return { words: text.split(' ').length };
43
+ };
19
44
 
20
45
  // TODO(burdon): Factor out.
21
- const getTitle = (subject: Markdown.Document | DataType.Text, fallback: string) => {
46
+ const getTitle = (subject: Markdown.Document | Text.Text, fallback: string) => {
22
47
  if (Obj.instanceOf(Markdown.Document, subject)) {
23
- return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);
24
- } else if (Obj.instanceOf(DataType.Text, subject)) {
48
+ const title = Obj.getLabel(subject);
49
+ return title ?? getFallbackName(subject.content?.target?.content ?? fallback);
50
+ } else if (Obj.instanceOf(Text.Text, subject)) {
25
51
  return getFallbackName(subject.content);
26
52
  }
27
53
  };
28
54
 
29
55
  // TODO(burdon): Factor out.
30
- const getSnippet = (subject: Markdown.Document | DataType.Text, fallback: string) => {
56
+ const getSnippet = (subject: Markdown.Document | Text.Text, fallback?: string) => {
31
57
  if (Obj.instanceOf(Markdown.Document, subject)) {
32
- return getAbstract(subject.content?.target?.content ?? fallback);
33
- } else if (Obj.instanceOf(DataType.Text, subject)) {
34
- return getAbstract(subject.content);
58
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
59
+ } else if (Obj.instanceOf(Text.Text, subject)) {
60
+ return getContentSnippet(subject.content ?? fallback);
35
61
  }
36
62
  };
37
-
38
- export type MarkdownCardProps = PreviewProps<Markdown.Document | DataType.Text>;
39
-
40
- export const MarkdownCard = ({ subject, role }: MarkdownCardProps) => {
41
- const { dispatchPromise: dispatch } = useIntentDispatcher();
42
- const { t } = useTranslation(meta.id);
43
- const snippet = getSnippet(subject, t('fallback abstract'));
44
-
45
- // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.
46
- const handleNavigate = useCallback(
47
- () =>
48
- dispatch(
49
- pipe(
50
- createIntent(LayoutAction.UpdatePopover, {
51
- part: 'popover',
52
- subject: null,
53
- options: { state: false, anchorId: '' },
54
- }),
55
- chain(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(subject)] }),
56
- ),
57
- ),
58
- [dispatch, subject],
59
- );
60
-
61
- return (
62
- <Card.SurfaceRoot role={role}>
63
- <Card.Heading>{getTitle(subject, t('fallback title'))}</Card.Heading>
64
- {snippet && <Card.Text classNames='line-clamp-3 break-words col-span-2'>{snippet}</Card.Text>}
65
- {role === 'card--popover' && (
66
- <Card.Chrome>
67
- <Button onClick={handleNavigate}>
68
- <span className='grow'>{t('navigate to document label')}</span>
69
- <Icon icon='ph--arrow-right--regular' />
70
- </Button>
71
- </Card.Chrome>
72
- )}
73
- </Card.SurfaceRoot>
74
- );
75
- };
@@ -2,36 +2,25 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import * as Effect from 'effect/Effect';
8
7
  import React, { useMemo } from 'react';
9
8
 
10
- import {
11
- type Capabilities,
12
- IntentPlugin,
13
- LayoutAction,
14
- SettingsPlugin,
15
- Surface,
16
- createIntent,
17
- useIntentDispatcher,
18
- } from '@dxos/app-framework';
9
+ import { Common } from '@dxos/app-framework';
10
+ import { Surface, useOperationInvoker } from '@dxos/app-framework/react';
19
11
  import { withPluginManager } from '@dxos/app-framework/testing';
20
12
  import { Obj, Query } from '@dxos/echo';
21
- import { AttentionPlugin } from '@dxos/plugin-attention';
22
13
  import { ClientPlugin } from '@dxos/plugin-client';
23
- import { GraphPlugin } from '@dxos/plugin-graph';
24
14
  import { PreviewPlugin } from '@dxos/plugin-preview';
25
- import { SpacePlugin } from '@dxos/plugin-space';
26
- import { StorybookLayoutPlugin } from '@dxos/plugin-storybook-layout';
27
- import { ThemePlugin } from '@dxos/plugin-theme';
15
+ import { StorybookPlugin, corePlugins } from '@dxos/plugin-testing';
28
16
  import { faker } from '@dxos/random';
29
17
  import { useQuery, useSpace } from '@dxos/react-client/echo';
30
18
  import { useAsyncEffect } from '@dxos/react-ui';
31
- import { defaultTx } from '@dxos/react-ui-theme';
32
- import { DataType } from '@dxos/schema';
19
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
20
+ import { useAttentionAttributes } from '@dxos/react-ui-attention';
21
+ import { Text } from '@dxos/schema';
33
22
  import { type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
34
- import { withLayout } from '@dxos/storybook-utils';
23
+ import { Organization, Person } from '@dxos/types';
35
24
 
36
25
  import { MarkdownPlugin } from '../MarkdownPlugin';
37
26
  import { translations } from '../translations';
@@ -42,70 +31,93 @@ faker.seed(1);
42
31
  const generator: ValueGenerator = faker as any;
43
32
 
44
33
  const DefaultStory = () => {
45
- const { dispatchPromise: dispatch } = useIntentDispatcher();
34
+ const { invokePromise } = useOperationInvoker();
46
35
  const space = useSpace();
47
- const [doc] = useQuery(space, Query.type(Markdown.Document));
36
+ const [doc] = useQuery(space?.db, Query.type(Markdown.Document));
48
37
  const data = useMemo(() => ({ subject: doc }), [doc]);
38
+ const id = doc && Obj.getDXN(doc).toString();
39
+ const attentionAttrs = useAttentionAttributes(id);
49
40
 
50
41
  useAsyncEffect(async () => {
51
42
  if (space) {
52
- await dispatch(createIntent(LayoutAction.SwitchWorkspace, { part: 'workspace', subject: space.id }));
43
+ await invokePromise(Common.LayoutOperation.SwitchWorkspace, { subject: space.id });
53
44
  }
54
- }, [space, dispatch]);
45
+ }, [space, invokePromise]);
55
46
 
56
- return <Surface role='article' data={data} limit={1} />;
47
+ return (
48
+ <div className='contents' {...attentionAttrs}>
49
+ <Surface role='article' data={data} limit={1} />
50
+ </div>
51
+ );
57
52
  };
58
53
 
59
54
  const meta = {
60
55
  title: 'plugins/plugin-markdown/MarkdownContainer',
61
56
  render: DefaultStory,
62
57
  decorators: [
63
- withPluginManager({
58
+ withTheme,
59
+ withLayout({ layout: 'column' }),
60
+ withPluginManager<{ title?: string; content?: string }>((context) => ({
64
61
  plugins: [
65
- AttentionPlugin(),
66
- ThemePlugin({ tx: defaultTx }),
67
- StorybookLayoutPlugin(),
62
+ ...corePlugins(),
63
+ StorybookPlugin({}),
68
64
  ClientPlugin({
69
- types: [Markdown.Document, DataType.Text, DataType.Person, DataType.Organization],
70
- onClientInitialized: async ({ client }) => {
71
- await client.halo.createIdentity();
72
- await client.spaces.waitUntilReady();
73
- await client.spaces.default.waitUntilReady();
74
- const space = client.spaces.default;
75
-
76
- const queue = space.queues.create();
77
- const alice = Obj.make(DataType.Person, { fullName: 'Alice' });
78
- const acme = Obj.make(DataType.Organization, { name: 'ACME' });
79
- await queue.append([alice, acme]);
80
-
81
- const doc = Markdown.makeDocument({
82
- name: 'Test',
83
- content: `# Test\n\n![Alice](${Obj.getDXN(alice)})\n\n![ACME](${Obj.getDXN(acme)})`,
84
- });
85
- space.db.add(doc);
86
- const createObjects = createObjectFactory(space.db, generator);
87
- await createObjects([{ type: DataType.Organization, count: 10 }]);
88
- await space.db.flush({ indexes: true });
89
- },
65
+ types: [Markdown.Document, Text.Text, Person.Person, Organization.Organization],
66
+ onClientInitialized: ({ client }) =>
67
+ Effect.gen(function* () {
68
+ yield* Effect.promise(() => client.halo.createIdentity());
69
+ yield* Effect.promise(() => client.spaces.waitUntilReady());
70
+ yield* Effect.promise(() => client.spaces.default.waitUntilReady());
71
+
72
+ const space = client.spaces.default;
73
+ const createObjects = createObjectFactory(space.db, generator);
74
+ yield* Effect.promise(() => createObjects([{ type: Organization.Organization, count: 10 }]));
75
+
76
+ const queue = space.queues.create();
77
+ const kai = Obj.make(Person.Person, { fullName: 'Kai' });
78
+ const dxos = Obj.make(Organization.Organization, { name: 'DXOS' });
79
+ yield* Effect.promise(() => queue.append([kai, dxos]));
80
+
81
+ space.db.add(
82
+ Markdown.make({
83
+ name: context.args.title ?? 'Testing',
84
+ content: [
85
+ `# ${context.args.title ?? 'Testing'}`,
86
+ context.args.content ?? '',
87
+ // TODO(burdon): Popovers not currently working.
88
+ '## Here are some objects',
89
+ `![Alice](${Obj.getDXN(kai)})`,
90
+ `![DXOS](${Obj.getDXN(dxos)})`,
91
+ '',
92
+ 'END',
93
+ '',
94
+ ].join('\n\n'),
95
+ }),
96
+ );
97
+
98
+ yield* Effect.promise(() => space.db.flush({ indexes: true }));
99
+ }),
90
100
  }),
91
- SpacePlugin(),
92
- SettingsPlugin(),
93
- IntentPlugin(),
101
+
94
102
  MarkdownPlugin(),
95
103
  PreviewPlugin(),
96
- GraphPlugin(),
97
104
  ],
98
- }),
99
- withLayout({ fullscreen: true }),
105
+ })),
100
106
  ],
101
107
  parameters: {
102
- translations,
108
+ layout: 'fullscreen',
103
109
  controls: { disable: true },
110
+ translations,
104
111
  },
105
- } satisfies Meta<typeof Capabilities>;
112
+ } satisfies Meta<typeof DefaultStory>;
106
113
 
107
114
  export default meta;
108
115
 
109
116
  type Story = StoryObj<typeof meta>;
110
117
 
111
- export const Default: Story = {};
118
+ export const Default: Story = {
119
+ args: {
120
+ title: 'Testing',
121
+ content: ['This is a line with **some** formatting.'].join('\n\n'),
122
+ },
123
+ };