@dxos/plugin-markdown 0.8.4-main.5acf9ea → 0.8.4-main.66e292d

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 (265) hide show
  1. package/dist/lib/browser/MarkdownCard-TC3GGUSX.mjs +12 -0
  2. package/dist/lib/browser/MarkdownCard-TC3GGUSX.mjs.map +7 -0
  3. package/dist/lib/browser/MarkdownContainer-YF22DV4M.mjs +15 -0
  4. package/dist/lib/browser/MarkdownContainer-YF22DV4M.mjs.map +7 -0
  5. package/dist/lib/browser/{anchor-sort-Z7JQA7RL.mjs → anchor-sort-3MYLO74J.mjs} +10 -10
  6. package/dist/lib/browser/anchor-sort-3MYLO74J.mjs.map +7 -0
  7. package/dist/lib/browser/{app-graph-serializer-ZT5OVF5G.mjs → app-graph-serializer-BZJ4TQOE.mjs} +11 -12
  8. package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs.map +7 -0
  9. package/dist/lib/browser/blueprint-definition-HED54GGW.mjs +13 -0
  10. package/dist/lib/browser/blueprint-definition-HED54GGW.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-3IPVL3E4.mjs +20 -0
  12. package/dist/lib/browser/chunk-3IPVL3E4.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-BE3IO2CM.mjs +150 -0
  14. package/dist/lib/browser/chunk-BE3IO2CM.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-ZGY3DYC2.mjs → chunk-BQTYJOFB.mjs} +5 -7
  16. package/dist/lib/browser/chunk-BQTYJOFB.mjs.map +7 -0
  17. package/dist/lib/browser/{chunk-YHMGUSO7.mjs → chunk-CN35HEBX.mjs} +16 -17
  18. package/dist/lib/browser/chunk-CN35HEBX.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-DLZ5RR3P.mjs +96 -0
  20. package/dist/lib/browser/chunk-DLZ5RR3P.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-CD4E4K7J.mjs → chunk-IBCHVMZW.mjs} +2 -2
  22. package/dist/lib/browser/{chunk-CD4E4K7J.mjs.map → chunk-IBCHVMZW.mjs.map} +2 -2
  23. package/dist/lib/browser/{chunk-K7ZFMSC4.mjs → chunk-NXT2E2BG.mjs} +10 -5
  24. package/dist/lib/browser/chunk-NXT2E2BG.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-VMX5SDGW.mjs → chunk-OKNQ57GF.mjs} +9 -8
  26. package/dist/lib/browser/chunk-OKNQ57GF.mjs.map +7 -0
  27. package/dist/lib/browser/chunk-V7P7EIWG.mjs +829 -0
  28. package/dist/lib/browser/chunk-V7P7EIWG.mjs.map +7 -0
  29. package/dist/lib/browser/index.mjs +32 -34
  30. package/dist/lib/browser/index.mjs.map +3 -3
  31. package/dist/lib/browser/{intent-resolver-EBEF7WEI.mjs → intent-resolver-55ASQRIW.mjs} +22 -20
  32. package/dist/lib/browser/intent-resolver-55ASQRIW.mjs.map +7 -0
  33. package/dist/lib/browser/meta.json +1 -1
  34. package/dist/lib/browser/{react-surface-ZPMZT4VU.mjs → react-surface-GPD6T435.mjs} +89 -86
  35. package/dist/lib/browser/react-surface-GPD6T435.mjs.map +7 -0
  36. package/dist/lib/browser/{settings-MBDK4TWE.mjs → settings-G3ZOXJQY.mjs} +5 -5
  37. package/dist/lib/browser/{settings-MBDK4TWE.mjs.map → settings-G3ZOXJQY.mjs.map} +1 -1
  38. package/dist/lib/browser/{state-ZA6PZPUI.mjs → state-BTUKVZHY.mjs} +5 -5
  39. package/dist/lib/browser/state-BTUKVZHY.mjs.map +7 -0
  40. package/dist/lib/browser/toolkit.mjs +13 -0
  41. package/dist/lib/browser/toolkit.mjs.map +7 -0
  42. package/dist/lib/browser/types/index.mjs +2 -2
  43. package/dist/lib/node-esm/MarkdownCard-FTEHVH7P.mjs +13 -0
  44. package/dist/lib/node-esm/MarkdownCard-FTEHVH7P.mjs.map +7 -0
  45. package/dist/lib/node-esm/MarkdownContainer-L75AIJFM.mjs +16 -0
  46. package/dist/lib/node-esm/MarkdownContainer-L75AIJFM.mjs.map +7 -0
  47. package/dist/lib/node-esm/{anchor-sort-R6AAKYNG.mjs → anchor-sort-W4HCTYUQ.mjs} +10 -10
  48. package/dist/lib/node-esm/anchor-sort-W4HCTYUQ.mjs.map +7 -0
  49. package/dist/lib/node-esm/{app-graph-serializer-X4M5QEI6.mjs → app-graph-serializer-OCTHXWLF.mjs} +11 -12
  50. package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs.map +7 -0
  51. package/dist/lib/node-esm/blueprint-definition-HAQGJOMQ.mjs +14 -0
  52. package/dist/lib/node-esm/blueprint-definition-HAQGJOMQ.mjs.map +7 -0
  53. package/dist/lib/node-esm/chunk-3DN4DPVA.mjs +151 -0
  54. package/dist/lib/node-esm/chunk-3DN4DPVA.mjs.map +7 -0
  55. package/dist/lib/node-esm/{chunk-LZK3TLKM.mjs → chunk-7GN66TDQ.mjs} +9 -8
  56. package/dist/lib/node-esm/chunk-7GN66TDQ.mjs.map +7 -0
  57. package/dist/lib/node-esm/{chunk-B3J2M4YL.mjs → chunk-GMMVSXQ6.mjs} +2 -2
  58. package/dist/lib/node-esm/{chunk-B3J2M4YL.mjs.map → chunk-GMMVSXQ6.mjs.map} +2 -2
  59. package/dist/lib/node-esm/{chunk-YGNVDYMB.mjs → chunk-I5JSQBPI.mjs} +10 -5
  60. package/dist/lib/node-esm/chunk-I5JSQBPI.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-RCIXKCVG.mjs → chunk-SHAMSMKQ.mjs} +5 -7
  62. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs.map +7 -0
  63. package/dist/lib/node-esm/chunk-TYUGABTD.mjs +22 -0
  64. package/dist/lib/node-esm/chunk-TYUGABTD.mjs.map +7 -0
  65. package/dist/lib/node-esm/chunk-UVLACSAE.mjs +830 -0
  66. package/dist/lib/node-esm/chunk-UVLACSAE.mjs.map +7 -0
  67. package/dist/lib/node-esm/{chunk-6GCOJS4Y.mjs → chunk-YFRTKXTB.mjs} +16 -17
  68. package/dist/lib/node-esm/chunk-YFRTKXTB.mjs.map +7 -0
  69. package/dist/lib/node-esm/chunk-ZNS55FS3.mjs +97 -0
  70. package/dist/lib/node-esm/chunk-ZNS55FS3.mjs.map +7 -0
  71. package/dist/lib/node-esm/index.mjs +32 -34
  72. package/dist/lib/node-esm/index.mjs.map +3 -3
  73. package/dist/lib/node-esm/{intent-resolver-L2UGZ72W.mjs → intent-resolver-DTBVWCNO.mjs} +22 -20
  74. package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs.map +7 -0
  75. package/dist/lib/node-esm/meta.json +1 -1
  76. package/dist/lib/node-esm/{react-surface-3JJSTTQP.mjs → react-surface-QWG7CJ5U.mjs} +89 -86
  77. package/dist/lib/node-esm/react-surface-QWG7CJ5U.mjs.map +7 -0
  78. package/dist/lib/node-esm/{settings-LBDWWPZJ.mjs → settings-IBFFCGNL.mjs} +5 -5
  79. package/dist/lib/node-esm/{settings-LBDWWPZJ.mjs.map → settings-IBFFCGNL.mjs.map} +1 -1
  80. package/dist/lib/node-esm/{state-UIHO2SFZ.mjs → state-K6EH7SRZ.mjs} +5 -5
  81. package/dist/lib/node-esm/state-K6EH7SRZ.mjs.map +7 -0
  82. package/dist/lib/node-esm/toolkit.mjs +14 -0
  83. package/dist/lib/node-esm/toolkit.mjs.map +7 -0
  84. package/dist/lib/node-esm/types/index.mjs +2 -2
  85. package/dist/types/src/MarkdownPlugin.d.ts +1 -1
  86. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/anchor-sort.d.ts +2 -4
  88. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
  90. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  91. package/dist/types/src/capabilities/artifact-definition.d.ts +1 -9
  92. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  93. package/dist/types/src/capabilities/blueprint-definition.d.ts +7 -0
  94. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  95. package/dist/types/src/capabilities/capabilities.d.ts +1 -1
  96. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  97. package/dist/types/src/capabilities/index.d.ts +10 -12
  98. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  99. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  100. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  101. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  102. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  103. package/dist/types/src/capabilities/settings.d.ts +1 -1
  104. package/dist/types/src/capabilities/state.d.ts +2 -2
  105. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  106. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +7 -0
  107. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  108. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  109. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  110. package/dist/types/src/components/MarkdownCard/index.d.ts +4 -0
  111. package/dist/types/src/components/MarkdownCard/index.d.ts.map +1 -0
  112. package/dist/types/src/components/MarkdownContainer.d.ts +8 -12
  113. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  114. package/dist/types/src/components/MarkdownContainer.stories.d.ts +55 -5
  115. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
  116. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
  117. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
  118. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +42 -23
  119. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  120. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
  121. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  122. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +26 -0
  123. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
  124. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +12 -0
  125. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
  126. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  127. package/dist/types/src/components/Suggestions.stories.d.ts +1 -2
  128. package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
  129. package/dist/types/src/components/index.d.ts +4 -2
  130. package/dist/types/src/components/index.d.ts.map +1 -1
  131. package/dist/types/src/functions/create.d.ts +8 -0
  132. package/dist/types/src/functions/create.d.ts.map +1 -0
  133. package/dist/types/src/functions/create.test.d.ts +2 -0
  134. package/dist/types/src/functions/create.test.d.ts.map +1 -0
  135. package/dist/types/src/functions/index.d.ts +18 -0
  136. package/dist/types/src/functions/index.d.ts.map +1 -0
  137. package/dist/types/src/functions/open.d.ts +7 -0
  138. package/dist/types/src/functions/open.d.ts.map +1 -0
  139. package/dist/types/src/functions/update.d.ts +6 -0
  140. package/dist/types/src/functions/update.d.ts.map +1 -0
  141. package/dist/types/src/functions/update.test.d.ts +2 -0
  142. package/dist/types/src/functions/update.test.d.ts.map +1 -0
  143. package/dist/types/src/hooks/index.d.ts +3 -0
  144. package/dist/types/src/hooks/index.d.ts.map +1 -1
  145. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  146. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  147. package/dist/types/src/hooks/useExtensions.d.ts +21 -0
  148. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
  149. package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
  150. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
  151. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
  152. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  153. package/dist/types/src/index.d.ts +2 -1
  154. package/dist/types/src/index.d.ts.map +1 -1
  155. package/dist/types/src/meta.d.ts +0 -1
  156. package/dist/types/src/meta.d.ts.map +1 -1
  157. package/dist/types/src/testing.d.ts +6 -0
  158. package/dist/types/src/testing.d.ts.map +1 -0
  159. package/dist/types/src/toolkit.d.ts +3 -0
  160. package/dist/types/src/toolkit.d.ts.map +1 -0
  161. package/dist/types/src/translations.d.ts +5 -0
  162. package/dist/types/src/translations.d.ts.map +1 -1
  163. package/dist/types/src/types/Markdown.d.ts +11 -9
  164. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  165. package/dist/types/src/types/MarkdownAction.d.ts +7 -15
  166. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  167. package/dist/types/src/types/index.d.ts.map +1 -1
  168. package/dist/types/src/types/types.d.ts.map +1 -1
  169. package/dist/types/src/util.d.ts +3 -3
  170. package/dist/types/src/util.d.ts.map +1 -1
  171. package/dist/types/tsconfig.tsbuildinfo +1 -1
  172. package/package.json +76 -57
  173. package/src/MarkdownPlugin.tsx +90 -99
  174. package/src/capabilities/anchor-sort.ts +7 -6
  175. package/src/capabilities/app-graph-serializer.ts +7 -7
  176. package/src/capabilities/artifact-definition.ts +17 -21
  177. package/src/capabilities/blueprint-definition.ts +43 -0
  178. package/src/capabilities/capabilities.ts +2 -1
  179. package/src/capabilities/index.ts +3 -2
  180. package/src/capabilities/intent-resolver.ts +16 -15
  181. package/src/capabilities/react-surface.tsx +46 -67
  182. package/src/capabilities/state.ts +3 -2
  183. package/src/components/{MarkdownPreview/MarkdownPreview.stories.tsx → MarkdownCard/MarkdownCard.stories.tsx} +17 -18
  184. package/src/components/MarkdownCard/MarkdownCard.tsx +89 -0
  185. package/src/components/MarkdownCard/index.ts +9 -0
  186. package/src/components/MarkdownContainer.stories.tsx +79 -43
  187. package/src/components/MarkdownContainer.tsx +79 -220
  188. package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
  189. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +57 -34
  190. package/src/components/MarkdownEditor/MarkdownEditor.tsx +221 -272
  191. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +136 -0
  192. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +63 -0
  193. package/src/components/MarkdownSettings/MarkdownSettings.tsx +77 -74
  194. package/src/components/Suggestions.stories.tsx +54 -48
  195. package/src/components/index.ts +3 -1
  196. package/src/functions/create.conversations.json +1 -0
  197. package/src/functions/create.test.ts +128 -0
  198. package/src/functions/create.ts +34 -0
  199. package/src/functions/index.ts +13 -0
  200. package/src/functions/open.ts +32 -0
  201. package/src/functions/update.conversations.json +1 -0
  202. package/src/functions/update.test.ts +151 -0
  203. package/src/functions/update.ts +37 -0
  204. package/src/hooks/index.ts +3 -0
  205. package/src/hooks/useEditorMenuOptions.ts +71 -0
  206. package/src/{extensions.tsx → hooks/useExtensions.tsx} +66 -115
  207. package/src/hooks/useLinkQuery.ts +83 -0
  208. package/src/hooks/useSelectCurrentThread.tsx +15 -5
  209. package/src/index.ts +3 -1
  210. package/src/meta.ts +3 -6
  211. package/src/testing.ts +27 -0
  212. package/src/toolkit.ts +6 -0
  213. package/src/translations.ts +5 -0
  214. package/src/types/Markdown.ts +9 -7
  215. package/src/types/MarkdownAction.ts +5 -6
  216. package/src/types/index.ts +1 -0
  217. package/src/types/types.ts +1 -0
  218. package/src/util.tsx +10 -5
  219. package/dist/lib/browser/MarkdownContainer-NNBPE6A5.mjs +0 -779
  220. package/dist/lib/browser/MarkdownContainer-NNBPE6A5.mjs.map +0 -7
  221. package/dist/lib/browser/MarkdownPreview-7VG3K24R.mjs +0 -80
  222. package/dist/lib/browser/MarkdownPreview-7VG3K24R.mjs.map +0 -7
  223. package/dist/lib/browser/anchor-sort-Z7JQA7RL.mjs.map +0 -7
  224. package/dist/lib/browser/app-graph-serializer-ZT5OVF5G.mjs.map +0 -7
  225. package/dist/lib/browser/artifact-definition-7VNP5PCP.mjs +0 -145
  226. package/dist/lib/browser/artifact-definition-7VNP5PCP.mjs.map +0 -7
  227. package/dist/lib/browser/chunk-K7ZFMSC4.mjs.map +0 -7
  228. package/dist/lib/browser/chunk-VCUKIILA.mjs +0 -20
  229. package/dist/lib/browser/chunk-VCUKIILA.mjs.map +0 -7
  230. package/dist/lib/browser/chunk-VMX5SDGW.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-YHMGUSO7.mjs.map +0 -7
  232. package/dist/lib/browser/chunk-ZGY3DYC2.mjs.map +0 -7
  233. package/dist/lib/browser/intent-resolver-EBEF7WEI.mjs.map +0 -7
  234. package/dist/lib/browser/react-surface-ZPMZT4VU.mjs.map +0 -7
  235. package/dist/lib/browser/state-ZA6PZPUI.mjs.map +0 -7
  236. package/dist/lib/node-esm/MarkdownContainer-Q6UO7DKT.mjs +0 -780
  237. package/dist/lib/node-esm/MarkdownContainer-Q6UO7DKT.mjs.map +0 -7
  238. package/dist/lib/node-esm/MarkdownPreview-UVWR2YK3.mjs +0 -81
  239. package/dist/lib/node-esm/MarkdownPreview-UVWR2YK3.mjs.map +0 -7
  240. package/dist/lib/node-esm/anchor-sort-R6AAKYNG.mjs.map +0 -7
  241. package/dist/lib/node-esm/app-graph-serializer-X4M5QEI6.mjs.map +0 -7
  242. package/dist/lib/node-esm/artifact-definition-IRIILD7S.mjs +0 -146
  243. package/dist/lib/node-esm/artifact-definition-IRIILD7S.mjs.map +0 -7
  244. package/dist/lib/node-esm/chunk-6GCOJS4Y.mjs.map +0 -7
  245. package/dist/lib/node-esm/chunk-A7LLVI34.mjs +0 -22
  246. package/dist/lib/node-esm/chunk-A7LLVI34.mjs.map +0 -7
  247. package/dist/lib/node-esm/chunk-LZK3TLKM.mjs.map +0 -7
  248. package/dist/lib/node-esm/chunk-RCIXKCVG.mjs.map +0 -7
  249. package/dist/lib/node-esm/chunk-YGNVDYMB.mjs.map +0 -7
  250. package/dist/lib/node-esm/intent-resolver-L2UGZ72W.mjs.map +0 -7
  251. package/dist/lib/node-esm/react-surface-3JJSTTQP.mjs.map +0 -7
  252. package/dist/lib/node-esm/state-UIHO2SFZ.mjs.map +0 -7
  253. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +0 -6
  254. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +0 -1
  255. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +0 -10
  256. package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +0 -1
  257. package/dist/types/src/components/MarkdownPreview/index.d.ts +0 -4
  258. package/dist/types/src/components/MarkdownPreview/index.d.ts.map +0 -1
  259. package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
  260. package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
  261. package/dist/types/src/extensions.d.ts +0 -24
  262. package/dist/types/src/extensions.d.ts.map +0 -1
  263. package/src/components/MarkdownPreview/MarkdownPreview.tsx +0 -73
  264. package/src/components/MarkdownPreview/index.ts +0 -9
  265. package/src/components/Toolbar.stories.tsx +0 -112
@@ -3,27 +3,29 @@
3
3
  //
4
4
 
5
5
  import { next as A } from '@automerge/automerge';
6
- import { Option, pipe, type Schema } from 'effect';
6
+ import * as Option from 'effect/Option';
7
+ import type * as Schema from 'effect/Schema';
7
8
 
8
9
  import {
9
10
  Capabilities,
10
11
  CollaborationActions,
12
+ type PluginContext,
11
13
  contributes,
12
14
  createResolver,
13
- type PluginContext,
14
15
  } from '@dxos/app-framework';
15
16
  import { Obj } from '@dxos/echo';
16
- import { createDocAccessor, getRangeFromCursor } from '@dxos/react-client/echo';
17
+ import { createDocAccessor, getRangeFromCursor } from '@dxos/echo-db';
17
18
 
18
- import { MarkdownCapabilities } from './capabilities';
19
19
  import { Markdown, MarkdownAction } from '../types';
20
20
 
21
+ import { MarkdownCapabilities } from './capabilities';
22
+
21
23
  export default (context: PluginContext) =>
22
24
  contributes(Capabilities.IntentResolver, [
23
25
  createResolver({
24
26
  intent: MarkdownAction.Create,
25
27
  resolve: ({ name, content }) => {
26
- return { data: { object: Markdown.makeDocument({ name, content }) } };
28
+ return { data: { object: Markdown.make({ name, content }) } };
27
29
  },
28
30
  }),
29
31
  createResolver({
@@ -34,23 +36,22 @@ export default (context: PluginContext) =>
34
36
  },
35
37
  }),
36
38
  createResolver({
37
- intent: CollaborationActions.InsertContent,
39
+ intent: CollaborationActions.AcceptProposal,
38
40
  filter: (
39
41
  data,
40
- ): data is Omit<Schema.Schema.Type<typeof CollaborationActions.InsertContent.fields.input>, 'target'> & {
41
- target: Markdown.Document;
42
- } => Obj.instanceOf(Markdown.Document, data.target),
43
- resolve: async ({ target, object: objectRef, at, label }) => {
44
- const text = await target.content.load();
42
+ ): data is Omit<Schema.Schema.Type<typeof CollaborationActions.AcceptProposal.fields.input>, 'subject'> & {
43
+ subject: Markdown.Document;
44
+ } => Obj.instanceOf(Markdown.Document, data.subject),
45
+ resolve: async ({ subject, anchor, proposal }) => {
46
+ const text = await subject.content.load();
45
47
  const accessor = createDocAccessor(text, ['content']);
46
- const { start, end } = pipe(
47
- Option.fromNullable(at),
48
+ const { start, end } = Option.fromNullable(anchor).pipe(
48
49
  Option.flatMap((at) => Option.fromNullable(getRangeFromCursor(accessor, at))),
50
+ // Fallback to the end of the document.
49
51
  Option.getOrElse(() => ({ start: text.content.length - 1, end: text.content.length - 1 })),
50
52
  );
51
53
  accessor.handle.change((doc) => {
52
- const ref = `[${label ?? 'Generated content'}]](${objectRef.dxn.toString()})\n`;
53
- A.splice(doc, accessor.path.slice(), start, end - start, ref);
54
+ A.splice(doc, accessor.path.slice(), start, end - start, proposal.text);
54
55
  });
55
56
  },
56
57
  }),
@@ -2,21 +2,22 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import React from 'react';
5
+ import React, { useCallback } from 'react';
6
6
 
7
- import { createSurface, contributes, Capabilities, useCapability } from '@dxos/app-framework';
7
+ import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
8
+ import { SurfaceCardRole, useCapability } from '@dxos/app-framework/react';
8
9
  import { Obj } from '@dxos/echo';
9
10
  import { SettingsStore } from '@dxos/local-storage';
10
11
  import { AttentionCapabilities } from '@dxos/plugin-attention';
11
- import { fullyQualifiedId } from '@dxos/react-client/echo';
12
- import { DataType } from '@dxos/schema';
12
+ import { Text } from '@dxos/schema';
13
13
 
14
- import { MarkdownCapabilities } from './capabilities';
15
- import { MarkdownContainer, MarkdownSettings, MarkdownPreview } from '../components';
14
+ import { MarkdownCard, MarkdownContainer, type MarkdownContainerProps, MarkdownSettings } from '../components';
16
15
  import { meta } from '../meta';
17
16
  import { Markdown } from '../types';
18
17
  import { isEditorModel } from '../util';
19
18
 
19
+ import { MarkdownCapabilities } from './capabilities';
20
+
20
21
  export default () =>
21
22
  contributes(Capabilities.ReactSurface, [
22
23
  createSurface({
@@ -25,76 +26,25 @@ export default () =>
25
26
  filter: (data): data is { subject: Markdown.Document; variant: undefined } =>
26
27
  Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,
27
28
  component: ({ data, role }) => {
28
- const selectionManager = useCapability(AttentionCapabilities.Selection);
29
- const settingsStore = useCapability(Capabilities.SettingsStore);
30
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
31
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
32
- const viewMode = getViewMode(fullyQualifiedId(data.subject));
33
-
34
- return (
35
- <MarkdownContainer
36
- id={fullyQualifiedId(data.subject)}
37
- object={data.subject}
38
- role={role}
39
- settings={settings}
40
- selectionManager={selectionManager}
41
- extensionProviders={state.extensionProviders}
42
- viewMode={viewMode}
43
- editorStateStore={editorState}
44
- onViewModeChange={setViewMode}
45
- />
46
- );
29
+ return <Container id={Obj.getDXN(data.subject).toString()} subject={data.subject} role={role} />;
47
30
  },
48
31
  }),
49
32
  createSurface({
50
33
  id: `${meta.id}/surface/text`,
51
34
  role: ['article', 'section', 'tabpanel'],
52
- filter: (data): data is { id: string; subject: DataType.Text } =>
53
- typeof data.id === 'string' && Obj.instanceOf(DataType.Text, data.subject),
35
+ filter: (data): data is { id: string; subject: Text.Text } =>
36
+ typeof data.id === 'string' && Obj.instanceOf(Text.Text, data.subject),
54
37
  component: ({ data, role }) => {
55
- const selectionManager = useCapability(AttentionCapabilities.Selection);
56
- const settingsStore = useCapability(Capabilities.SettingsStore);
57
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
58
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
59
-
60
- return (
61
- <MarkdownContainer
62
- id={data.id}
63
- object={data.subject}
64
- role={role}
65
- settings={settings}
66
- selectionManager={selectionManager}
67
- extensionProviders={state.extensionProviders}
68
- viewMode={getViewMode(data.id)}
69
- editorStateStore={editorState}
70
- onViewModeChange={setViewMode}
71
- />
72
- );
38
+ return <Container id={data.id} subject={data.subject} role={role} />;
73
39
  },
74
40
  }),
41
+ // TODO(burdon): Remove this variant and conform to Text.
75
42
  createSurface({
76
43
  id: `${meta.id}/surface/editor`,
77
44
  role: ['article', 'section'],
78
45
  filter: (data): data is { subject: { id: string; text: string } } => isEditorModel(data.subject),
79
46
  component: ({ data, role }) => {
80
- const selectionManager = useCapability(AttentionCapabilities.Selection);
81
- const settingsStore = useCapability(Capabilities.SettingsStore);
82
- const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
83
- const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
84
-
85
- return (
86
- <MarkdownContainer
87
- id={data.subject.id}
88
- object={data.subject}
89
- role={role}
90
- settings={settings}
91
- selectionManager={selectionManager}
92
- extensionProviders={state.extensionProviders}
93
- viewMode={getViewMode(data.subject.id)}
94
- editorStateStore={editorState}
95
- onViewModeChange={setViewMode}
96
- />
97
- );
47
+ return <Container id={data.subject.id} subject={data.subject} role={role} />;
98
48
  },
99
49
  }),
100
50
  createSurface({
@@ -106,9 +56,38 @@ export default () =>
106
56
  }),
107
57
  createSurface({
108
58
  id: `${meta.id}/surface/preview`,
109
- role: ['card--popover', 'card--intrinsic', 'card--extrinsic', 'card--transclusion', 'card'],
110
- filter: (data): data is { subject: Markdown.Document | DataType.Text } =>
111
- Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(DataType.Text, data.subject),
112
- component: ({ data, role }) => <MarkdownPreview {...data} role={role} />,
59
+ role: SurfaceCardRole.literals as any,
60
+ filter: (data): data is { subject: Markdown.Document | Text.Text } =>
61
+ Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
62
+ component: ({ data, role }) => <MarkdownCard {...data} role={role as SurfaceCardRole} />,
113
63
  }),
114
64
  ]);
65
+
66
+ /**
67
+ * Common wrapper.
68
+ */
69
+ const Container = ({ id, subject, role }: { id: string; subject: MarkdownContainerProps['object']; role: string }) => {
70
+ const selectionManager = useCapability(AttentionCapabilities.Selection);
71
+ const settingsStore = useCapability(Capabilities.SettingsStore);
72
+ const settings = settingsStore.getStore<Markdown.Settings>(meta.id)!.value;
73
+ const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);
74
+ const viewMode = getViewMode(id);
75
+ const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(
76
+ (mode) => setViewMode(id, mode),
77
+ [id, setViewMode],
78
+ );
79
+
80
+ return (
81
+ <MarkdownContainer
82
+ id={id}
83
+ object={subject}
84
+ role={role}
85
+ settings={settings}
86
+ selectionManager={selectionManager}
87
+ extensionProviders={state.extensionProviders}
88
+ editorStateStore={editorState}
89
+ viewMode={viewMode}
90
+ onViewModeChange={handleViewModeChange}
91
+ />
92
+ );
93
+ };
@@ -2,14 +2,15 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, contributes, type PluginContext } from '@dxos/app-framework';
5
+ import { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';
6
6
  import { LocalStorageStore } from '@dxos/local-storage';
7
7
  import { type EditorViewMode, createEditorStateStore } from '@dxos/react-ui-editor';
8
8
 
9
- import { MarkdownCapabilities } from './capabilities';
10
9
  import { meta } from '../meta';
11
10
  import { type Markdown, type MarkdownPluginState } from '../types';
12
11
 
12
+ import { MarkdownCapabilities } from './capabilities';
13
+
13
14
  export default (context: PluginContext) => {
14
15
  const state = new LocalStorageStore<MarkdownPluginState>(meta.id, { extensionProviders: [], viewMode: {} });
15
16
  state.prop({ key: 'viewMode', type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>() });
@@ -2,44 +2,43 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
- import { type StoryObj, type Meta } from '@storybook/react-vite';
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
6
  import React from 'react';
9
7
 
10
8
  import { IntentPlugin } from '@dxos/app-framework';
11
9
  import { withPluginManager } from '@dxos/app-framework/testing';
12
10
  import { Markdown } from '@dxos/plugin-markdown/types';
13
11
  import { faker } from '@dxos/random';
12
+ import { withTheme } from '@dxos/react-ui/testing';
14
13
  import { CardContainer } from '@dxos/react-ui-stack/testing';
15
- import { withTheme, withLayout } from '@dxos/storybook-utils';
16
14
 
17
- import { MarkdownPreview } from './MarkdownPreview';
18
15
  import { translations } from '../../translations';
19
16
 
17
+ import { MarkdownCard } from './MarkdownCard';
18
+
20
19
  faker.seed(1234);
21
20
 
22
- const meta: Meta<typeof MarkdownPreview> = {
23
- title: 'Cards/plugin-markdown',
24
- component: MarkdownPreview,
21
+ const meta: Meta<typeof MarkdownCard> = {
22
+ title: 'plugins/plugin-markdown/Card',
23
+ component: MarkdownCard,
25
24
  render: ({ role, subject, ...args }) => {
26
25
  return (
27
26
  <CardContainer icon='ph--text-aa--regular' role={role}>
28
- <MarkdownPreview role={role} subject={subject} {...args} />
27
+ <MarkdownCard role={role} subject={subject} {...args} />
29
28
  </CardContainer>
30
29
  );
31
30
  },
32
31
  decorators: [
32
+ withTheme,
33
33
  withPluginManager({
34
34
  plugins: [IntentPlugin()],
35
35
  }),
36
- withTheme,
37
- withLayout(),
38
36
  ],
39
37
  parameters: {
40
38
  layout: 'centered',
41
39
  translations,
42
40
  },
41
+ tags: ['cards'],
43
42
  };
44
43
 
45
44
  export default meta;
@@ -49,27 +48,27 @@ type Story = StoryObj<typeof meta>;
49
48
  export const Popover: Story = {
50
49
  args: {
51
50
  role: 'card--popover',
52
- subject: Markdown.makeDocument({
51
+ subject: Markdown.make({
53
52
  name: faker.lorem.words(3),
54
53
  content: faker.lorem.paragraphs(3),
55
54
  }),
56
55
  },
57
56
  };
58
57
 
59
- export const Extrinsic: Story = {
58
+ export const Intrinsic: Story = {
60
59
  args: {
61
- role: 'card--extrinsic',
62
- subject: Markdown.makeDocument({
60
+ role: 'card--intrinsic',
61
+ subject: Markdown.make({
63
62
  name: faker.lorem.words(3),
64
63
  content: faker.lorem.paragraphs(3),
65
64
  }),
66
65
  },
67
66
  };
68
67
 
69
- export const Intrinsic: Story = {
68
+ export const Extrinsic: Story = {
70
69
  args: {
71
- role: 'card--intrinsic',
72
- subject: Markdown.makeDocument({
70
+ role: 'card--extrinsic',
71
+ subject: Markdown.make({
73
72
  name: faker.lorem.words(3),
74
73
  content: faker.lorem.paragraphs(3),
75
74
  }),
@@ -0,0 +1,89 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Function from 'effect/Function';
6
+ import React, { useCallback } from 'react';
7
+
8
+ import { LayoutAction, chain, createIntent } from '@dxos/app-framework';
9
+ import { useIntentDispatcher } from '@dxos/app-framework/react';
10
+ import { Obj } from '@dxos/echo';
11
+ import { type CardPreviewProps } from '@dxos/plugin-preview';
12
+ import { IconButton, useTranslation } from '@dxos/react-ui';
13
+ import { Card } from '@dxos/react-ui-stack';
14
+ import { Text } from '@dxos/schema';
15
+
16
+ import { meta } from '../../meta';
17
+ import { Markdown } from '../../types';
18
+ import { getContentSnippet, getFallbackName } from '../../util';
19
+
20
+ export type MarkdownCardProps = CardPreviewProps<Markdown.Document | Text.Text>;
21
+
22
+ export const MarkdownCard = ({ subject, role }: MarkdownCardProps) => {
23
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
24
+ const { t } = useTranslation(meta.id);
25
+ const snippet = getSnippet(subject, t('fallback abstract'));
26
+ const info = getInfo(subject);
27
+
28
+ // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.
29
+ const handleNavigate = useCallback(
30
+ () =>
31
+ dispatch(
32
+ Function.pipe(
33
+ createIntent(LayoutAction.UpdatePopover, {
34
+ part: 'popover',
35
+ subject: null,
36
+ options: { state: false, anchorId: '' },
37
+ }),
38
+ chain(LayoutAction.Open, {
39
+ part: 'main',
40
+ subject: [Obj.getDXN(subject).toString()],
41
+ }),
42
+ ),
43
+ ),
44
+ [dispatch, subject],
45
+ );
46
+
47
+ return (
48
+ <Card.SurfaceRoot role={role}>
49
+ <Card.Heading classNames='flex items-center'>
50
+ {getTitle(subject, t('fallback title'))}
51
+ <span className='grow' />
52
+ <IconButton
53
+ iconOnly
54
+ icon='ph--arrow-right--regular'
55
+ label={t('navigate to document label')}
56
+ onClick={handleNavigate}
57
+ />
58
+ </Card.Heading>
59
+ {snippet && <Card.Text classNames='line-clamp-3 text-sm text-description'>{snippet}</Card.Text>}
60
+ <Card.Text classNames='text-xs text-description'>
61
+ {info.words} {t('words label', { count: info.words })}
62
+ </Card.Text>
63
+ </Card.SurfaceRoot>
64
+ );
65
+ };
66
+
67
+ const getInfo = (subject: Markdown.Document | Text.Text) => {
68
+ const text = (Obj.instanceOf(Markdown.Document, subject) ? subject.content?.target?.content : subject.content) ?? '';
69
+ return { words: text.split(' ').length };
70
+ };
71
+
72
+ // TODO(burdon): Factor out.
73
+ const getTitle = (subject: Markdown.Document | Text.Text, fallback: string) => {
74
+ if (Obj.instanceOf(Markdown.Document, subject)) {
75
+ const title = Obj.getLabel(subject);
76
+ return title ?? getFallbackName(subject.content?.target?.content ?? fallback);
77
+ } else if (Obj.instanceOf(Text.Text, subject)) {
78
+ return getFallbackName(subject.content);
79
+ }
80
+ };
81
+
82
+ // TODO(burdon): Factor out.
83
+ const getSnippet = (subject: Markdown.Document | Text.Text, fallback: string) => {
84
+ if (Obj.instanceOf(Markdown.Document, subject)) {
85
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
86
+ } else if (Obj.instanceOf(Text.Text, subject)) {
87
+ return getContentSnippet(subject.content ?? fallback);
88
+ }
89
+ };
@@ -0,0 +1,9 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { MarkdownCard } from './MarkdownCard';
6
+
7
+ export * from './MarkdownCard';
8
+
9
+ export default MarkdownCard;
@@ -2,28 +2,29 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
- import { type Meta } from '@storybook/react-vite';
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
6
  import React, { useMemo } from 'react';
9
7
 
10
- import { Capabilities, contributes, IntentPlugin, SettingsPlugin, Surface } from '@dxos/app-framework';
8
+ import { type Capabilities, IntentPlugin, LayoutAction, SettingsPlugin, createIntent } from '@dxos/app-framework';
9
+ import { Surface, useIntentDispatcher } from '@dxos/app-framework/react';
11
10
  import { withPluginManager } from '@dxos/app-framework/testing';
12
- import { todo } from '@dxos/debug';
13
- import { Query, Type } from '@dxos/echo';
11
+ import { Obj, Query } from '@dxos/echo';
14
12
  import { AttentionPlugin } from '@dxos/plugin-attention';
15
13
  import { ClientPlugin } from '@dxos/plugin-client';
16
14
  import { GraphPlugin } from '@dxos/plugin-graph';
17
15
  import { PreviewPlugin } from '@dxos/plugin-preview';
18
- import { SpaceCapabilities, SpacePlugin } from '@dxos/plugin-space';
16
+ import { SpacePlugin } from '@dxos/plugin-space';
19
17
  import { StorybookLayoutPlugin } from '@dxos/plugin-storybook-layout';
20
18
  import { ThemePlugin } from '@dxos/plugin-theme';
21
19
  import { faker } from '@dxos/random';
22
20
  import { useQuery, useSpace } from '@dxos/react-client/echo';
21
+ import { useAsyncEffect } from '@dxos/react-ui';
22
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
23
+ import { useAttentionAttributes } from '@dxos/react-ui-attention';
23
24
  import { defaultTx } from '@dxos/react-ui-theme';
24
- import { DataType } from '@dxos/schema';
25
- import { createObjectFactory, Testing, type ValueGenerator } from '@dxos/schema/testing';
26
- import { withLayout } from '@dxos/storybook-utils';
25
+ import { Text } from '@dxos/schema';
26
+ import { type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
27
+ import { Organization, Person } from '@dxos/types';
27
28
 
28
29
  import { MarkdownPlugin } from '../MarkdownPlugin';
29
30
  import { translations } from '../translations';
@@ -34,67 +35,102 @@ faker.seed(1);
34
35
  const generator: ValueGenerator = faker as any;
35
36
 
36
37
  const DefaultStory = () => {
38
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
37
39
  const space = useSpace();
38
40
  const [doc] = useQuery(space, Query.type(Markdown.Document));
39
41
  const data = useMemo(() => ({ subject: doc }), [doc]);
42
+ const id = doc && Obj.getDXN(doc).toString();
43
+ const attentionAttrs = useAttentionAttributes(id);
44
+
45
+ useAsyncEffect(async () => {
46
+ if (space) {
47
+ await dispatch(
48
+ createIntent(LayoutAction.SwitchWorkspace, {
49
+ part: 'workspace',
50
+ subject: space.id,
51
+ }),
52
+ );
53
+ }
54
+ }, [space, dispatch]);
40
55
 
41
- return <Surface role='article' data={data} />;
56
+ return (
57
+ <div className='contents' {...attentionAttrs}>
58
+ <Surface role='article' data={data} limit={1} />
59
+ </div>
60
+ );
42
61
  };
43
62
 
44
- const meta: Meta<typeof DefaultStory> = {
63
+ const meta = {
45
64
  title: 'plugins/plugin-markdown/MarkdownContainer',
46
65
  render: DefaultStory,
47
66
  decorators: [
48
- withPluginManager({
67
+ withTheme,
68
+ withLayout({ container: 'column' }),
69
+ withPluginManager<{ title?: string; content?: string }>((context) => ({
49
70
  plugins: [
50
- AttentionPlugin(),
51
- ThemePlugin({ tx: defaultTx }),
52
- StorybookLayoutPlugin(),
53
71
  ClientPlugin({
54
- types: [Markdown.Document, DataType.Text, Testing.Contact],
55
- onClientInitialized: async (_, client) => {
72
+ types: [Markdown.Document, Text.Text, Person.Person, Organization.Organization],
73
+ onClientInitialized: async ({ client }) => {
56
74
  await client.halo.createIdentity();
57
75
  await client.spaces.waitUntilReady();
58
76
  await client.spaces.default.waitUntilReady();
77
+
59
78
  const space = client.spaces.default;
60
- const doc = Markdown.makeDocument({ name: 'Test', content: '# Test\n\n' });
61
- space.db.add(doc);
62
79
  const createObjects = createObjectFactory(space.db, generator);
63
- await createObjects([{ type: Testing.Contact, count: 10 }]);
80
+ await createObjects([{ type: Organization.Organization, count: 10 }]);
81
+
82
+ const queue = space.queues.create();
83
+ const kai = Obj.make(Person.Person, { fullName: 'Kai' });
84
+ const dxos = Obj.make(Organization.Organization, { name: 'DXOS' });
85
+ await queue.append([kai, dxos]);
86
+
87
+ space.db.add(
88
+ Markdown.make({
89
+ name: context.args.title ?? 'Testing',
90
+ content: [
91
+ `# ${context.args.title ?? 'Testing'}`,
92
+ context.args.content ?? '',
93
+ // TODO(burdon): Popovers not currently working.
94
+ '## Here are some objects',
95
+ `![Alice](${Obj.getDXN(kai)})`,
96
+ `![DXOS](${Obj.getDXN(dxos)})`,
97
+ '',
98
+ 'END',
99
+ '',
100
+ ].join('\n\n'),
101
+ }),
102
+ );
103
+
64
104
  await space.db.flush({ indexes: true });
65
105
  },
66
106
  }),
67
- SpacePlugin(),
68
- SettingsPlugin(),
107
+ SpacePlugin({}),
108
+ GraphPlugin(),
69
109
  IntentPlugin(),
110
+ SettingsPlugin(),
111
+ // UI
112
+ ThemePlugin({ tx: defaultTx }),
113
+ AttentionPlugin(),
70
114
  MarkdownPlugin(),
71
115
  PreviewPlugin(),
72
- GraphPlugin(),
73
- ],
74
- capabilities: [
75
- // NOTE: Editor only queries for object form schemas when linking.
76
- contributes(SpaceCapabilities.ObjectForm, {
77
- objectSchema: Testing.Contact,
78
- getIntent: () => todo(),
79
- }),
80
- contributes(Capabilities.Metadata, {
81
- id: Type.getTypename(Testing.Contact),
82
- metadata: {
83
- icon: 'ph--user--regular',
84
- },
85
- }),
116
+ StorybookLayoutPlugin({}),
86
117
  ],
87
- }),
88
- withLayout({ fullscreen: true }),
118
+ })),
89
119
  ],
90
120
  parameters: {
91
- translations,
121
+ layout: 'fullscreen',
92
122
  controls: { disable: true },
123
+ translations,
93
124
  },
94
- };
125
+ } satisfies Meta<typeof Capabilities>;
95
126
 
96
127
  export default meta;
97
128
 
98
- type Story = Meta<typeof DefaultStory>;
129
+ type Story = StoryObj<typeof meta>;
99
130
 
100
- export const Default: Story = {};
131
+ export const Default: Story = {
132
+ args: {
133
+ title: 'Testing',
134
+ content: ['This is a line with **some** formatting.'].join('\n\n'),
135
+ },
136
+ };