@dxos/react-ui-editor 0.8.4-main.406dc2a → 0.8.4-main.422d1c7879

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 (426) hide show
  1. package/dist/lib/browser/index.mjs +1156 -8352
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +1148 -8343
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Editor/Editor.d.ts +41 -29
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +13 -20
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
  11. package/dist/types/src/components/Editor/EditorView.d.ts +31 -0
  12. package/dist/types/src/components/Editor/EditorView.d.ts.map +1 -0
  13. package/dist/types/src/components/Editor/controller.d.ts +10 -0
  14. package/dist/types/src/components/Editor/controller.d.ts.map +1 -0
  15. package/dist/types/src/{extensions/popover/PopoverMenuProvider.d.ts → components/EditorMenuProvider/EditorMenuProvider.d.ts} +7 -9
  16. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  18. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  20. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  22. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  23. package/dist/types/src/{extensions/popover → components/EditorMenuProvider}/popover.d.ts +1 -2
  24. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  26. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  28. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  30. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  32. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  33. package/dist/types/src/components/EditorToolbar/blocks.d.ts +4 -17
  34. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  35. package/dist/types/src/components/EditorToolbar/formatting.d.ts +4 -17
  36. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  37. package/dist/types/src/components/EditorToolbar/headings.d.ts +4 -17
  38. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/image.d.ts +3 -15
  40. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
  42. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/lists.d.ts +4 -17
  44. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/search.d.ts +3 -15
  46. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/types.d.ts +5 -0
  48. package/dist/types/src/components/EditorToolbar/types.d.ts.map +1 -0
  49. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +5 -18
  50. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  51. package/dist/types/src/components/index.d.ts +2 -1
  52. package/dist/types/src/components/index.d.ts.map +1 -1
  53. package/dist/types/src/extensions/Assistant.stories.d.ts +10 -0
  54. package/dist/types/src/extensions/Assistant.stories.d.ts.map +1 -0
  55. package/dist/types/src/extensions/assistant-extension.d.ts +24 -0
  56. package/dist/types/src/extensions/assistant-extension.d.ts.map +1 -0
  57. package/dist/types/src/extensions/index.d.ts +1 -25
  58. package/dist/types/src/extensions/index.d.ts.map +1 -1
  59. package/dist/types/src/hooks/index.d.ts +1 -0
  60. package/dist/types/src/hooks/index.d.ts.map +1 -1
  61. package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts +25 -0
  62. package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts.map +1 -0
  63. package/dist/types/src/hooks/useTextEditor.d.ts +2 -2
  64. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  65. package/dist/types/src/index.d.ts +0 -7
  66. package/dist/types/src/index.d.ts.map +1 -1
  67. package/dist/types/src/stories/Automerge.stories.d.ts +44 -0
  68. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  69. package/dist/types/src/stories/Comments.stories.d.ts +4 -3
  70. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/EditorToolbar.stories.d.ts +29 -27
  72. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  73. package/dist/types/src/stories/Experimental.stories.d.ts +4 -3
  74. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/Markdown.stories.d.ts +4 -3
  76. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  77. package/dist/types/src/stories/Outliner.stories.d.ts +2 -2
  78. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/Popover.stories.d.ts +3 -3
  80. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
  81. package/dist/types/src/stories/Preview.stories.d.ts +5 -3
  82. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  83. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  84. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -3
  85. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  86. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  87. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  88. package/dist/types/src/stories/components/EditorStory.d.ts +11 -20
  89. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  90. package/dist/types/src/stories/components/util.d.ts +3 -3
  91. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  92. package/dist/types/src/translations.d.ts +26 -26
  93. package/dist/types/src/translations.d.ts.map +1 -1
  94. package/dist/types/src/util/index.d.ts +0 -5
  95. package/dist/types/src/util/index.d.ts.map +1 -1
  96. package/dist/types/src/util/react.d.ts +6 -5
  97. package/dist/types/src/util/react.d.ts.map +1 -1
  98. package/dist/types/tsconfig.tsbuildinfo +1 -1
  99. package/package.json +70 -74
  100. package/src/components/Editor/Editor.stories.tsx +68 -51
  101. package/src/components/Editor/Editor.tsx +171 -61
  102. package/src/components/Editor/EditorView.tsx +83 -0
  103. package/src/components/Editor/controller.ts +50 -0
  104. package/src/{extensions/popover/PopoverMenuProvider.tsx → components/EditorMenuProvider/EditorMenuProvider.tsx} +49 -44
  105. package/src/components/EditorMenuProvider/index.ts +10 -0
  106. package/src/{extensions/popover → components/EditorMenuProvider}/menu-presets.ts +20 -19
  107. package/src/{extensions/popover → components/EditorMenuProvider}/menu.ts +21 -18
  108. package/src/{extensions/popover → components/EditorMenuProvider}/popover.ts +3 -11
  109. package/src/{extensions/popover/usePopoverMenu.ts → components/EditorMenuProvider/useEditorMenu.ts} +29 -22
  110. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  111. package/src/components/EditorPreviewProvider/index.ts +5 -0
  112. package/src/components/EditorToolbar/EditorToolbar.tsx +88 -112
  113. package/src/components/EditorToolbar/blocks.ts +55 -48
  114. package/src/components/EditorToolbar/formatting.ts +46 -48
  115. package/src/components/EditorToolbar/headings.ts +47 -51
  116. package/src/components/EditorToolbar/image.ts +16 -14
  117. package/src/components/EditorToolbar/index.ts +2 -7
  118. package/src/components/EditorToolbar/lists.ts +42 -41
  119. package/src/components/EditorToolbar/search.ts +16 -14
  120. package/src/components/EditorToolbar/types.ts +7 -0
  121. package/src/components/EditorToolbar/view-mode.ts +36 -42
  122. package/src/components/index.ts +3 -1
  123. package/src/extensions/Assistant.stories.tsx +111 -0
  124. package/src/extensions/assistant-extension.tsx +223 -0
  125. package/src/extensions/index.ts +2 -26
  126. package/src/hooks/index.ts +1 -0
  127. package/src/hooks/useBasicMarkdownExtensions.ts +55 -0
  128. package/src/hooks/useTextEditor.ts +13 -7
  129. package/src/index.ts +0 -9
  130. package/src/stories/Automerge.stories.tsx +173 -0
  131. package/src/stories/Comments.stories.tsx +48 -45
  132. package/src/stories/EditorToolbar.stories.tsx +40 -54
  133. package/src/stories/Experimental.stories.tsx +10 -12
  134. package/src/stories/Markdown.stories.tsx +16 -16
  135. package/src/stories/Outliner.stories.tsx +20 -29
  136. package/src/stories/Popover.stories.tsx +47 -53
  137. package/src/stories/Preview.stories.tsx +102 -84
  138. package/src/stories/Tags.stories.tsx +36 -13
  139. package/src/stories/TextEditor.stories.tsx +15 -21
  140. package/src/stories/Theme.stories.tsx +61 -0
  141. package/src/stories/components/EditorStory.tsx +46 -32
  142. package/src/stories/components/util.tsx +90 -59
  143. package/src/translations.ts +30 -25
  144. package/src/util/index.ts +1 -6
  145. package/src/util/react.tsx +8 -13
  146. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  147. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  148. package/dist/lib/browser/testing/index.mjs +0 -76
  149. package/dist/lib/browser/testing/index.mjs.map +0 -7
  150. package/dist/lib/browser/types/index.mjs +0 -13
  151. package/dist/lib/browser/types/index.mjs.map +0 -7
  152. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
  153. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  154. package/dist/lib/node-esm/testing/index.mjs +0 -78
  155. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  156. package/dist/lib/node-esm/types/index.mjs +0 -14
  157. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  158. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  159. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  160. package/dist/types/src/defaults.d.ts +0 -14
  161. package/dist/types/src/defaults.d.ts.map +0 -1
  162. package/dist/types/src/extensions/annotations.d.ts +0 -9
  163. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  164. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -26
  165. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
  166. package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
  167. package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
  168. package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
  169. package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
  170. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
  171. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
  172. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
  173. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
  174. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  175. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  176. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +0 -47
  177. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  178. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  179. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  180. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  181. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  182. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  183. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  184. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  185. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  186. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  187. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  188. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  189. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  190. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  191. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  192. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  193. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  194. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  195. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  196. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  197. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  198. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  199. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  200. package/dist/types/src/extensions/blast.d.ts +0 -25
  201. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  202. package/dist/types/src/extensions/comments.d.ts +0 -95
  203. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  204. package/dist/types/src/extensions/debug.d.ts +0 -3
  205. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  206. package/dist/types/src/extensions/dnd.d.ts +0 -9
  207. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  208. package/dist/types/src/extensions/factories.d.ts +0 -83
  209. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  210. package/dist/types/src/extensions/focus.d.ts +0 -7
  211. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  212. package/dist/types/src/extensions/folding.d.ts +0 -7
  213. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  214. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  215. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  216. package/dist/types/src/extensions/json.d.ts +0 -7
  217. package/dist/types/src/extensions/json.d.ts.map +0 -1
  218. package/dist/types/src/extensions/listener.d.ts +0 -11
  219. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  220. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  221. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  222. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  223. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  224. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  225. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  226. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  227. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  228. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  229. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  230. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  231. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  232. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  233. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  234. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  235. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  236. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  237. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  238. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  239. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  240. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  241. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  242. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  243. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  244. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  245. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  246. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  247. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  248. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  249. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  250. package/dist/types/src/extensions/mention.d.ts +0 -7
  251. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  252. package/dist/types/src/extensions/modes.d.ts +0 -10
  253. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  254. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  255. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  256. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  257. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  258. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  259. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  260. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  261. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  262. package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
  263. package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
  264. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  265. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  266. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  267. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  268. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  269. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  270. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  271. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  272. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  273. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  274. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +0 -1
  275. package/dist/types/src/extensions/popover/index.d.ts +0 -8
  276. package/dist/types/src/extensions/popover/index.d.ts.map +0 -1
  277. package/dist/types/src/extensions/popover/menu-presets.d.ts +0 -4
  278. package/dist/types/src/extensions/popover/menu-presets.d.ts.map +0 -1
  279. package/dist/types/src/extensions/popover/menu.d.ts +0 -24
  280. package/dist/types/src/extensions/popover/menu.d.ts.map +0 -1
  281. package/dist/types/src/extensions/popover/modal.d.ts +0 -7
  282. package/dist/types/src/extensions/popover/modal.d.ts.map +0 -1
  283. package/dist/types/src/extensions/popover/popover.d.ts.map +0 -1
  284. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +0 -34
  285. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +0 -1
  286. package/dist/types/src/extensions/popover/util.d.ts +0 -8
  287. package/dist/types/src/extensions/popover/util.d.ts.map +0 -1
  288. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  289. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  290. package/dist/types/src/extensions/preview/preview.d.ts +0 -28
  291. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  292. package/dist/types/src/extensions/selection.d.ts +0 -24
  293. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  294. package/dist/types/src/extensions/state.d.ts +0 -2
  295. package/dist/types/src/extensions/state.d.ts.map +0 -1
  296. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  297. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  298. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  299. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  300. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  301. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  302. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  303. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  304. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -72
  305. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  306. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  307. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  308. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  309. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  310. package/dist/types/src/stories/CommandDialog.stories.d.ts +0 -14
  311. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +0 -1
  312. package/dist/types/src/styles/index.d.ts +0 -4
  313. package/dist/types/src/styles/index.d.ts.map +0 -1
  314. package/dist/types/src/styles/markdown.d.ts +0 -8
  315. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  316. package/dist/types/src/styles/theme.d.ts +0 -38
  317. package/dist/types/src/styles/theme.d.ts.map +0 -1
  318. package/dist/types/src/styles/tokens.d.ts +0 -3
  319. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  320. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  321. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  322. package/dist/types/src/testing/index.d.ts +0 -3
  323. package/dist/types/src/testing/index.d.ts.map +0 -1
  324. package/dist/types/src/testing/util.d.ts +0 -3
  325. package/dist/types/src/testing/util.d.ts.map +0 -1
  326. package/dist/types/src/types/index.d.ts +0 -2
  327. package/dist/types/src/types/index.d.ts.map +0 -1
  328. package/dist/types/src/types/types.d.ts +0 -21
  329. package/dist/types/src/types/types.d.ts.map +0 -1
  330. package/dist/types/src/util/cursor.d.ts +0 -31
  331. package/dist/types/src/util/cursor.d.ts.map +0 -1
  332. package/dist/types/src/util/debug.d.ts +0 -17
  333. package/dist/types/src/util/debug.d.ts.map +0 -1
  334. package/dist/types/src/util/decorations.d.ts +0 -4
  335. package/dist/types/src/util/decorations.d.ts.map +0 -1
  336. package/dist/types/src/util/dom.d.ts +0 -10
  337. package/dist/types/src/util/dom.d.ts.map +0 -1
  338. package/dist/types/src/util/facet.d.ts +0 -3
  339. package/dist/types/src/util/facet.d.ts.map +0 -1
  340. package/src/components/EditorToolbar/util.ts +0 -76
  341. package/src/defaults.ts +0 -52
  342. package/src/extensions/annotations.ts +0 -55
  343. package/src/extensions/autocomplete/autocomplete.ts +0 -220
  344. package/src/extensions/autocomplete/index.ts +0 -8
  345. package/src/extensions/autocomplete/match.ts +0 -46
  346. package/src/extensions/autocomplete/placeholder.ts +0 -117
  347. package/src/extensions/autocomplete/typeahead.ts +0 -87
  348. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  349. package/src/extensions/automerge/automerge.test.tsx +0 -78
  350. package/src/extensions/automerge/automerge.ts +0 -105
  351. package/src/extensions/automerge/cursor.ts +0 -28
  352. package/src/extensions/automerge/defs.ts +0 -31
  353. package/src/extensions/automerge/index.ts +0 -5
  354. package/src/extensions/automerge/sync.ts +0 -79
  355. package/src/extensions/automerge/update-automerge.ts +0 -50
  356. package/src/extensions/automerge/update-codemirror.ts +0 -115
  357. package/src/extensions/autoscroll.ts +0 -157
  358. package/src/extensions/awareness/awareness-provider.ts +0 -127
  359. package/src/extensions/awareness/awareness.ts +0 -315
  360. package/src/extensions/awareness/index.ts +0 -6
  361. package/src/extensions/blast.ts +0 -363
  362. package/src/extensions/comments.ts +0 -597
  363. package/src/extensions/debug.ts +0 -15
  364. package/src/extensions/dnd.ts +0 -37
  365. package/src/extensions/factories.ts +0 -276
  366. package/src/extensions/focus.ts +0 -36
  367. package/src/extensions/folding.tsx +0 -44
  368. package/src/extensions/hashtag.tsx +0 -68
  369. package/src/extensions/json.ts +0 -57
  370. package/src/extensions/listener.ts +0 -38
  371. package/src/extensions/markdown/action.ts +0 -117
  372. package/src/extensions/markdown/bundle.ts +0 -95
  373. package/src/extensions/markdown/changes.test.ts +0 -26
  374. package/src/extensions/markdown/changes.ts +0 -149
  375. package/src/extensions/markdown/debug.ts +0 -44
  376. package/src/extensions/markdown/decorate.ts +0 -601
  377. package/src/extensions/markdown/formatting.test.ts +0 -498
  378. package/src/extensions/markdown/formatting.ts +0 -1267
  379. package/src/extensions/markdown/highlight.ts +0 -183
  380. package/src/extensions/markdown/image.ts +0 -118
  381. package/src/extensions/markdown/index.ts +0 -13
  382. package/src/extensions/markdown/link.ts +0 -50
  383. package/src/extensions/markdown/parser.test.ts +0 -75
  384. package/src/extensions/markdown/styles.ts +0 -135
  385. package/src/extensions/markdown/table.ts +0 -150
  386. package/src/extensions/mention.ts +0 -41
  387. package/src/extensions/modes.ts +0 -41
  388. package/src/extensions/outliner/commands.ts +0 -270
  389. package/src/extensions/outliner/editor.test.ts +0 -33
  390. package/src/extensions/outliner/editor.ts +0 -184
  391. package/src/extensions/outliner/index.ts +0 -7
  392. package/src/extensions/outliner/menu.ts +0 -128
  393. package/src/extensions/outliner/outliner.test.ts +0 -100
  394. package/src/extensions/outliner/outliner.ts +0 -167
  395. package/src/extensions/outliner/selection.ts +0 -50
  396. package/src/extensions/outliner/tree.test.ts +0 -168
  397. package/src/extensions/outliner/tree.ts +0 -317
  398. package/src/extensions/popover/index.ts +0 -12
  399. package/src/extensions/popover/modal.ts +0 -24
  400. package/src/extensions/popover/util.ts +0 -29
  401. package/src/extensions/preview/index.ts +0 -5
  402. package/src/extensions/preview/preview.ts +0 -188
  403. package/src/extensions/selection.ts +0 -100
  404. package/src/extensions/state.ts +0 -7
  405. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  406. package/src/extensions/tags/extended-markdown.ts +0 -78
  407. package/src/extensions/tags/index.ts +0 -7
  408. package/src/extensions/tags/streamer.ts +0 -243
  409. package/src/extensions/tags/xml-tags.ts +0 -393
  410. package/src/extensions/tags/xml-util.ts +0 -94
  411. package/src/extensions/typewriter.ts +0 -68
  412. package/src/stories/CommandDialog.stories.tsx +0 -78
  413. package/src/styles/index.ts +0 -7
  414. package/src/styles/markdown.ts +0 -26
  415. package/src/styles/theme.ts +0 -269
  416. package/src/styles/tokens.ts +0 -17
  417. package/src/testing/PreviewPopover.tsx +0 -80
  418. package/src/testing/index.ts +0 -6
  419. package/src/testing/util.ts +0 -7
  420. package/src/types/index.ts +0 -5
  421. package/src/types/types.ts +0 -32
  422. package/src/util/cursor.ts +0 -56
  423. package/src/util/debug.ts +0 -64
  424. package/src/util/decorations.ts +0 -21
  425. package/src/util/dom.ts +0 -34
  426. package/src/util/facet.ts +0 -13
@@ -4,62 +4,58 @@
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
6
 
7
- import { type NodeArg } from '@dxos/app-graph';
8
- import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
7
+ import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
8
+ import { setHeading } from '@dxos/ui-editor';
9
9
 
10
- import { setHeading } from '../../extensions';
11
10
  import { translationKey } from '../../translations';
12
-
13
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
14
-
15
- const createHeadingGroupAction = (value: string) =>
16
- createEditorActionGroup(
17
- 'heading',
18
- {
19
- variant: 'dropdownMenu',
20
- applyActive: true,
21
- selectCardinality: 'single',
22
- value,
23
- } as ToolbarMenuActionGroupProperties,
24
- 'ph--text-h--regular',
25
- );
26
-
27
- const createHeadingActions = (getView: () => EditorView) =>
28
- Object.entries({
29
- '0': 'ph--paragraph--regular',
30
- '1': 'ph--text-h-one--regular',
31
- '2': 'ph--text-h-two--regular',
32
- '3': 'ph--text-h-three--regular',
33
- '4': 'ph--text-h-four--regular',
34
- '5': 'ph--text-h-five--regular',
35
- '6': 'ph--text-h-six--regular',
36
- }).map(([levelStr, icon]) => {
37
- const level = parseInt(levelStr);
38
- return createEditorAction(
39
- `heading--${levelStr}`,
40
- {
41
- label: ['heading level label', { count: level, ns: translationKey }],
42
- icon,
43
- },
44
- () => setHeading(level)(getView()),
45
- );
46
- });
11
+ import { type EditorToolbarState } from './types';
12
+
13
+ const headingIcons: Record<string, string> = {
14
+ 0: 'ph--paragraph--regular',
15
+ 1: 'ph--text-h-one--regular',
16
+ 2: 'ph--text-h-two--regular',
17
+ 3: 'ph--text-h-three--regular',
18
+ 4: 'ph--text-h-four--regular',
19
+ 5: 'ph--text-h-five--regular',
20
+ 6: 'ph--text-h-six--regular',
21
+ };
47
22
 
48
23
  const computeHeadingValue = (state: EditorToolbarState) => {
49
24
  const blockType = state ? state.blockType : 'paragraph';
50
- const header = blockType && /heading(\d)/.exec(blockType);
51
- return header ? header[1] : blockType === 'paragraph' || !blockType ? '0' : '';
25
+ const heading = blockType && /heading(\d)/.exec(blockType);
26
+ return heading ? heading[1] : blockType === 'paragraph' || !blockType ? '0' : '';
52
27
  };
53
28
 
54
- export const createHeadings = (state: EditorToolbarState, getView: () => EditorView) => {
55
- const headingValue = computeHeadingValue(state);
56
- const headingGroupAction = createHeadingGroupAction(headingValue);
57
- const headingActions = createHeadingActions(getView);
58
- return {
59
- nodes: [headingGroupAction as NodeArg<any>, ...headingActions],
60
- edges: [
61
- { source: 'root', target: 'heading' },
62
- ...headingActions.map(({ id }) => ({ source: headingGroupAction.id, target: id })),
63
- ],
29
+ /** Add heading actions to the builder. */
30
+ export const addHeadings =
31
+ (state: EditorToolbarState, getView: () => EditorView): ActionGroupBuilderFn =>
32
+ (builder) => {
33
+ const headingValue = computeHeadingValue(state);
34
+ builder.group(
35
+ 'heading',
36
+ {
37
+ label: ['heading.label', { ns: translationKey }],
38
+ icon: 'ph--text-h--regular',
39
+ iconOnly: true,
40
+ variant: 'dropdownMenu',
41
+ applyActive: true,
42
+ selectCardinality: 'single',
43
+ // TODO(wittjosiah): Remove? Not sure this does anything.
44
+ value: headingValue,
45
+ } as ToolbarMenuActionGroupProperties,
46
+ (group) => {
47
+ for (const [levelStr, icon] of Object.entries(headingIcons)) {
48
+ const level = parseInt(levelStr);
49
+ group.action(
50
+ `heading--${levelStr}`,
51
+ {
52
+ label: ['heading-level.label', { count: level, ns: translationKey }],
53
+ icon,
54
+ checked: levelStr === headingValue,
55
+ },
56
+ () => setHeading(level)(getView()),
57
+ );
58
+ }
59
+ },
60
+ );
64
61
  };
65
- };
@@ -2,19 +2,21 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { createEditorAction } from './util';
5
+ import { type ActionGroupBuilderFn } from '@dxos/react-ui-menu';
6
6
 
7
- const createImageUploadAction = (onImageUpload: () => void) =>
8
- createEditorAction(
9
- 'image',
10
- {
11
- testId: 'editor.toolbar.image',
12
- icon: 'ph--image-square--regular',
13
- },
14
- onImageUpload,
15
- );
7
+ import { translationKey } from '../../translations';
16
8
 
17
- export const createImageUpload = (onImageUpload: () => void) => ({
18
- nodes: [createImageUploadAction(onImageUpload)],
19
- edges: [{ source: 'root', target: 'image' }],
20
- });
9
+ /** Add image upload action to the builder. */
10
+ export const addImageUpload =
11
+ (onImageUpload: () => void): ActionGroupBuilderFn =>
12
+ (builder) => {
13
+ builder.action(
14
+ 'image',
15
+ {
16
+ label: ['image.label', { ns: translationKey }],
17
+ testId: 'editor.toolbar.image',
18
+ icon: 'ph--image-square--regular',
19
+ },
20
+ onImageUpload,
21
+ );
22
+ };
@@ -2,11 +2,6 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
+ export * from './types';
6
+
5
7
  export * from './EditorToolbar';
6
- export {
7
- type EditorToolbarState,
8
- type EditorToolbarActionGraphProps,
9
- useEditorToolbarState,
10
- createEditorAction,
11
- createEditorActionGroup,
12
- } from './util';
@@ -4,12 +4,11 @@
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
6
 
7
- import { type NodeArg } from '@dxos/app-graph';
8
- import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
7
+ import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
8
+ import { List, addList, removeList } from '@dxos/ui-editor';
9
9
 
10
- import { List, addList, removeList } from '../../extensions';
11
-
12
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
10
+ import { translationKey } from '../../translations';
11
+ import { type EditorToolbarState } from './types';
13
12
 
14
13
  const listStyles = {
15
14
  bullet: 'ph--list-bullets--regular',
@@ -17,40 +16,42 @@ const listStyles = {
17
16
  task: 'ph--list-checks--regular',
18
17
  };
19
18
 
20
- const createListGroupAction = (value: string) =>
21
- createEditorActionGroup('list', {
22
- variant: 'toggleGroup',
23
- selectCardinality: 'single',
24
- value,
25
- } as ToolbarMenuActionGroupProperties);
26
-
27
- const createListActions = (value: string, getView: () => EditorView) =>
28
- Object.entries(listStyles).map(([listStyle, icon]) => {
29
- const checked = value === listStyle;
30
- return createEditorAction(`list-${listStyle}`, { checked, icon }, () => {
31
- const view = getView();
32
- if (!view) {
33
- return;
34
- }
35
-
36
- const listType = listStyle === 'ordered' ? List.Ordered : listStyle === 'bullet' ? List.Bullet : List.Task;
37
- if (checked) {
38
- removeList(listType)(view);
39
- } else {
40
- addList(listType)(view);
41
- }
42
- });
43
- });
44
-
45
- export const createLists = (state: EditorToolbarState, getView: () => EditorView) => {
46
- const value = state.listStyle ?? '';
47
- const listGroupAction = createListGroupAction(value);
48
- const listActionsMap = createListActions(value, getView);
49
- return {
50
- nodes: [listGroupAction as NodeArg<any>, ...listActionsMap],
51
- edges: [
52
- { source: 'root', target: 'list' },
53
- ...listActionsMap.map(({ id }) => ({ source: listGroupAction.id, target: id })),
54
- ],
19
+ /** Add list actions to the builder. */
20
+ export const addLists =
21
+ (state: EditorToolbarState, getView: () => EditorView): ActionGroupBuilderFn =>
22
+ (builder) => {
23
+ const value = state.listStyle ?? '';
24
+ builder.group(
25
+ 'list',
26
+ {
27
+ label: ['list.label', { ns: translationKey }],
28
+ iconOnly: true,
29
+ variant: 'toggleGroup',
30
+ selectCardinality: 'single',
31
+ value,
32
+ } as ToolbarMenuActionGroupProperties,
33
+ (group) => {
34
+ for (const [listStyle, icon] of Object.entries(listStyles)) {
35
+ const checked = value === listStyle;
36
+ group.action(
37
+ `list-${listStyle}`,
38
+ { label: [`list.${listStyle}.label`, { ns: translationKey }], checked, icon },
39
+ () => {
40
+ const view = getView();
41
+ if (!view) {
42
+ return;
43
+ }
44
+
45
+ const listType =
46
+ listStyle === 'ordered' ? List.Ordered : listStyle === 'bullet' ? List.Bullet : List.Task;
47
+ if (checked) {
48
+ removeList(listType)(view);
49
+ } else {
50
+ addList(listType)(view);
51
+ }
52
+ },
53
+ );
54
+ }
55
+ },
56
+ );
55
57
  };
56
- };
@@ -5,19 +5,21 @@
5
5
  import { openSearchPanel } from '@codemirror/search';
6
6
  import { type EditorView } from '@codemirror/view';
7
7
 
8
- import { createEditorAction } from './util';
8
+ import { type ActionGroupBuilderFn } from '@dxos/react-ui-menu';
9
9
 
10
- const createSearchAction = (getView: () => EditorView) =>
11
- createEditorAction(
12
- 'search',
13
- {
14
- testId: 'editor.toolbar.search',
15
- icon: 'ph--magnifying-glass--regular',
16
- },
17
- () => openSearchPanel(getView()),
18
- );
10
+ import { translationKey } from '../../translations';
19
11
 
20
- export const createSearch = (getView: () => EditorView) => ({
21
- nodes: [createSearchAction(getView)],
22
- edges: [{ source: 'root', target: 'search' }],
23
- });
12
+ /** Add search action to the builder. */
13
+ export const addSearch =
14
+ (getView: () => EditorView): ActionGroupBuilderFn =>
15
+ (builder) => {
16
+ builder.action(
17
+ 'search',
18
+ {
19
+ label: ['search.label', { ns: translationKey }],
20
+ testId: 'editor.toolbar.search',
21
+ icon: 'ph--magnifying-glass--regular',
22
+ },
23
+ () => openSearchPanel(getView()),
24
+ );
25
+ };
@@ -0,0 +1,7 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorViewMode, type Formatting } from '@dxos/ui-editor';
6
+
7
+ export type EditorToolbarState = Formatting & { viewMode?: EditorViewMode };
@@ -2,53 +2,47 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { type NodeArg } from '@dxos/app-graph';
6
- import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
5
+ import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
6
+ import { type EditorViewMode } from '@dxos/ui-editor';
7
7
 
8
8
  import { translationKey } from '../../translations';
9
- import { type EditorViewMode } from '../../types';
9
+ import { type EditorToolbarState } from './types';
10
10
 
11
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
12
-
13
- const createViewModeGroupAction = (value: string) =>
14
- createEditorActionGroup(
15
- 'viewMode',
16
- {
17
- variant: 'dropdownMenu',
18
- applyActive: true,
19
- selectCardinality: 'single',
20
- value,
21
- } as ToolbarMenuActionGroupProperties,
22
- 'ph--eye--regular',
23
- );
11
+ const viewModes = {
12
+ preview: 'ph--eye--regular',
13
+ source: 'ph--pencil-simple--regular',
14
+ readonly: 'ph--pencil-slash--regular',
15
+ };
24
16
 
25
- const createViewModeActions = (value: string, onViewModeChange: (mode: EditorViewMode) => void) =>
26
- Object.entries({
27
- preview: 'ph--eye--regular',
28
- source: 'ph--pencil-simple--regular',
29
- readonly: 'ph--pencil-slash--regular',
30
- }).map(([viewMode, icon]) => {
31
- const checked = viewMode === value;
32
- return createEditorAction(
33
- `view-mode--${viewMode}`,
17
+ /** Add view mode actions to the builder. */
18
+ export const addViewMode =
19
+ (state: EditorToolbarState, onViewModeChange: (mode: EditorViewMode) => void): ActionGroupBuilderFn =>
20
+ (builder) => {
21
+ const value = state.viewMode ?? 'source';
22
+ builder.group(
23
+ 'viewMode',
34
24
  {
35
- label: [`${viewMode} mode label`, { ns: translationKey }],
36
- checked,
37
- icon,
25
+ label: ['view-mode.label', { ns: translationKey }],
26
+ icon: 'ph--eye--regular',
27
+ iconOnly: true,
28
+ variant: 'dropdownMenu',
29
+ applyActive: true,
30
+ selectCardinality: 'single',
31
+ value,
32
+ } as ToolbarMenuActionGroupProperties,
33
+ (group) => {
34
+ for (const [viewMode, icon] of Object.entries(viewModes)) {
35
+ const checked = viewMode === value;
36
+ group.action(
37
+ `view-mode--${viewMode}`,
38
+ {
39
+ label: [`view-mode.${viewMode}.label`, { ns: translationKey }],
40
+ checked,
41
+ icon,
42
+ },
43
+ () => onViewModeChange(viewMode as EditorViewMode),
44
+ );
45
+ }
38
46
  },
39
- () => onViewModeChange(viewMode as EditorViewMode),
40
47
  );
41
- });
42
-
43
- export const createViewMode = (state: EditorToolbarState, onViewModeChange: (mode: EditorViewMode) => void) => {
44
- const value = state.viewMode ?? 'source';
45
- const viewModeGroupAction = createViewModeGroupAction(value);
46
- const viewModeActions = createViewModeActions(value, onViewModeChange);
47
- return {
48
- nodes: [viewModeGroupAction as NodeArg<any>, ...viewModeActions],
49
- edges: [
50
- { source: 'root', target: 'viewMode' },
51
- ...viewModeActions.map(({ id }) => ({ source: viewModeGroupAction.id, target: id })),
52
- ],
53
48
  };
54
- };
@@ -3,4 +3,6 @@
3
3
  //
4
4
 
5
5
  export * from './Editor';
6
- export * from './EditorToolbar';
6
+
7
+ export * from './EditorMenuProvider';
8
+ export * from './EditorPreviewProvider';
@@ -0,0 +1,111 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import * as LanguageModel from '@effect/ai/LanguageModel';
6
+ import type { Meta, StoryObj } from '@storybook/react-vite';
7
+ import * as Effect from 'effect/Effect';
8
+ import * as Layer from 'effect/Layer';
9
+ import * as ManagedRuntime from 'effect/ManagedRuntime';
10
+ import React, { useEffect, useMemo, useState } from 'react';
11
+
12
+ import { AiService } from '@dxos/ai';
13
+ import { AiServiceTestingPreset } from '@dxos/ai/testing';
14
+ import { useThemeContext } from '@dxos/react-ui';
15
+ import { Loading, withLayout, withTheme } from '@dxos/react-ui/testing';
16
+ import { compactSlots, createBasicExtensions, createThemeExtensions } from '@dxos/ui-editor';
17
+ import { trim } from '@dxos/util';
18
+
19
+ import { Editor, type EditorViewProps } from '../components';
20
+ import { translations } from '../translations';
21
+ import { assistant, type AssistantOptions } from './assistant-extension';
22
+
23
+ // TODO(burdon): Factor out.
24
+ const useTestGenerate = () => {
25
+ const [generate, setGenerate] = useState<AssistantOptions['generate']>();
26
+ useEffect(() => {
27
+ let disposed = false;
28
+ const rt = ManagedRuntime.make(
29
+ AiService.model('@anthropic/claude-haiku-4-5').pipe(
30
+ Layer.provide(AiServiceTestingPreset('edge-remote')),
31
+ Layer.orDie,
32
+ ),
33
+ );
34
+
35
+ if (!disposed) {
36
+ setGenerate(
37
+ () =>
38
+ ({ instructions, content }: { instructions: string; content: string }) =>
39
+ rt.runPromise(
40
+ Effect.gen(function* () {
41
+ const prompt = [instructions, content].join('\n\n');
42
+ const response = yield* LanguageModel.generateText({ prompt });
43
+ return response.text;
44
+ }),
45
+ ),
46
+ );
47
+ }
48
+
49
+ return () => {
50
+ disposed = true;
51
+ void rt.dispose();
52
+ };
53
+ }, []);
54
+
55
+ return generate;
56
+ };
57
+
58
+ type DefaultStoryProps = Pick<EditorViewProps, 'value'>;
59
+
60
+ const DefaultStory = (props: DefaultStoryProps) => {
61
+ const { themeMode } = useThemeContext();
62
+ const generate = useTestGenerate();
63
+ const extensions = useMemo(
64
+ () =>
65
+ generate
66
+ ? [
67
+ createBasicExtensions({ placeholder: 'Type here...' }),
68
+ createThemeExtensions({ themeMode, slots: compactSlots }),
69
+ assistant({ generate }),
70
+ ]
71
+ : [],
72
+ [generate, themeMode],
73
+ );
74
+
75
+ if (extensions.length === 0) {
76
+ return <Loading />;
77
+ }
78
+
79
+ return (
80
+ <Editor.Root>
81
+ <Editor.View {...props} classNames='dx-container border border-subdued-separator' extensions={extensions} />
82
+ </Editor.Root>
83
+ );
84
+ };
85
+
86
+ const meta: Meta<typeof DefaultStory> = {
87
+ title: 'ui/react-ui-editor/Assistant',
88
+ render: DefaultStory,
89
+ decorators: [withTheme(), withLayout({ layout: 'column' })],
90
+ tags: ['experimental'],
91
+ parameters: {
92
+ layout: 'fullscreen',
93
+ translations,
94
+ },
95
+ };
96
+
97
+ export default meta;
98
+
99
+ type Story = StoryObj<typeof meta>;
100
+
101
+ export const Default: Story = {
102
+ args: {
103
+ value: trim`
104
+ This text has a speling mistake.
105
+
106
+ And it grammatical errors.
107
+
108
+ But we can fix it.
109
+ `,
110
+ },
111
+ };