@dxos/react-ui-editor 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 (426) hide show
  1. package/dist/lib/browser/index.mjs +1171 -8426
  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 +1171 -8425
  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 +43 -15
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +23 -0
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  13. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  14. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  15. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  16. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +36 -0
  18. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  20. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  22. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  24. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +46 -0
  26. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  28. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  30. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  32. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  34. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  35. package/dist/types/src/components/EditorToolbar/actions.d.ts +24 -0
  36. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +8 -7
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +8 -7
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +8 -7
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +4 -11
  44. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  46. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/search.d.ts +4 -11
  48. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  50. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  51. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +9 -8
  52. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  53. package/dist/types/src/components/index.d.ts +4 -2
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/hooks/useTextEditor.d.ts +6 -10
  56. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  57. package/dist/types/src/index.d.ts +0 -8
  58. package/dist/types/src/index.d.ts.map +1 -1
  59. package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +6 -10
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/{Command.stories.d.ts → CommandDialog.stories.d.ts} +2 -3
  62. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  63. package/dist/types/src/stories/Comments.stories.d.ts +4 -4
  64. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/EditorToolbar.stories.d.ts +5 -6
  66. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/Experimental.stories.d.ts +4 -4
  68. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  69. package/dist/types/src/stories/Markdown.stories.d.ts +4 -4
  70. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/Outliner.stories.d.ts +0 -1
  72. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  73. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -6
  74. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  75. package/dist/types/src/stories/Preview.stories.d.ts +5 -4
  76. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  77. package/dist/types/src/stories/Tags.stories.d.ts +0 -1
  78. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -5
  80. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  81. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  82. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  83. package/dist/types/src/stories/components/EditorStory.d.ts +10 -19
  84. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  85. package/dist/types/src/stories/components/util.d.ts +3 -3
  86. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  87. package/dist/types/src/translations.d.ts +5 -5
  88. package/dist/types/src/translations.d.ts.map +1 -1
  89. package/dist/types/src/util/index.d.ts +0 -6
  90. package/dist/types/src/util/index.d.ts.map +1 -1
  91. package/dist/types/src/util/react.d.ts +5 -1
  92. package/dist/types/src/util/react.d.ts.map +1 -1
  93. package/dist/types/tsconfig.tsbuildinfo +1 -1
  94. package/package.json +70 -73
  95. package/src/components/Editor/Editor.stories.tsx +95 -0
  96. package/src/components/Editor/Editor.tsx +164 -24
  97. package/src/components/EditorContent/EditorContent.tsx +83 -0
  98. package/src/components/EditorContent/controller.ts +50 -0
  99. package/src/components/EditorContent/index.ts +6 -0
  100. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +233 -0
  101. package/src/components/EditorMenuProvider/index.ts +10 -0
  102. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  103. package/src/components/EditorMenuProvider/menu.ts +70 -0
  104. package/src/components/EditorMenuProvider/popover.ts +285 -0
  105. package/src/components/EditorMenuProvider/useEditorMenu.ts +173 -0
  106. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +81 -0
  107. package/src/components/EditorPreviewProvider/index.ts +5 -0
  108. package/src/components/EditorToolbar/EditorToolbar.tsx +105 -91
  109. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  110. package/src/components/EditorToolbar/blocks.ts +5 -5
  111. package/src/components/EditorToolbar/formatting.ts +5 -5
  112. package/src/components/EditorToolbar/headings.ts +11 -8
  113. package/src/components/EditorToolbar/image.ts +9 -2
  114. package/src/components/EditorToolbar/index.ts +3 -7
  115. package/src/components/EditorToolbar/search.ts +9 -2
  116. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  117. package/src/components/EditorToolbar/view-mode.ts +5 -4
  118. package/src/components/index.ts +6 -2
  119. package/src/hooks/useTextEditor.ts +39 -33
  120. package/src/index.ts +0 -10
  121. package/src/stories/Automerge.stories.tsx +175 -0
  122. package/src/stories/{Command.stories.tsx → CommandDialog.stories.tsx} +21 -30
  123. package/src/stories/Comments.stories.tsx +51 -47
  124. package/src/stories/EditorToolbar.stories.tsx +39 -23
  125. package/src/stories/Experimental.stories.tsx +10 -12
  126. package/src/stories/Markdown.stories.tsx +19 -19
  127. package/src/stories/Outliner.stories.tsx +23 -24
  128. package/src/stories/Popover.stories.tsx +158 -0
  129. package/src/stories/Preview.stories.tsx +94 -85
  130. package/src/stories/Tags.stories.tsx +37 -14
  131. package/src/stories/TextEditor.stories.tsx +20 -51
  132. package/src/stories/Theme.stories.tsx +61 -0
  133. package/src/stories/components/EditorStory.tsx +36 -27
  134. package/src/stories/components/util.tsx +43 -11
  135. package/src/translations.ts +4 -4
  136. package/src/util/index.ts +1 -7
  137. package/src/util/react.tsx +6 -2
  138. package/dist/lib/browser/chunk-22UMM3QJ.mjs +0 -22
  139. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  140. package/dist/lib/browser/testing/index.mjs +0 -76
  141. package/dist/lib/browser/testing/index.mjs.map +0 -7
  142. package/dist/lib/browser/types/index.mjs +0 -13
  143. package/dist/lib/browser/types/index.mjs.map +0 -7
  144. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs +0 -24
  145. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  146. package/dist/lib/node-esm/testing/index.mjs +0 -78
  147. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  148. package/dist/lib/node-esm/types/index.mjs +0 -14
  149. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  150. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts +0 -38
  151. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +0 -1
  152. package/dist/types/src/components/CommandMenu/index.d.ts +0 -2
  153. package/dist/types/src/components/CommandMenu/index.d.ts.map +0 -1
  154. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  155. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  156. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  157. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  158. package/dist/types/src/defaults.d.ts +0 -14
  159. package/dist/types/src/defaults.d.ts.map +0 -1
  160. package/dist/types/src/extensions/annotations.d.ts +0 -9
  161. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  162. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  163. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  164. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  165. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  166. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  167. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  168. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  169. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  170. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  171. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  172. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  173. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  174. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  175. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  176. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  177. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  178. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  179. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  180. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  181. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  182. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  183. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  184. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  185. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  186. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  187. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  188. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  189. package/dist/types/src/extensions/blast.d.ts +0 -25
  190. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  191. package/dist/types/src/extensions/command/action.d.ts +0 -17
  192. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  193. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  194. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  195. package/dist/types/src/extensions/command/command.d.ts +0 -6
  196. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  197. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  198. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  199. package/dist/types/src/extensions/command/hint.d.ts +0 -19
  200. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  201. package/dist/types/src/extensions/command/index.d.ts +0 -7
  202. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  203. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  204. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  205. package/dist/types/src/extensions/command/state.d.ts +0 -16
  206. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  207. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  208. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  209. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -25
  210. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  211. package/dist/types/src/extensions/comments.d.ts +0 -95
  212. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  213. package/dist/types/src/extensions/debug.d.ts +0 -3
  214. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  215. package/dist/types/src/extensions/dnd.d.ts +0 -9
  216. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  217. package/dist/types/src/extensions/factories.d.ts +0 -78
  218. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  219. package/dist/types/src/extensions/focus.d.ts +0 -7
  220. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  221. package/dist/types/src/extensions/folding.d.ts +0 -7
  222. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  223. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  224. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  225. package/dist/types/src/extensions/index.d.ts +0 -25
  226. package/dist/types/src/extensions/index.d.ts.map +0 -1
  227. package/dist/types/src/extensions/json.d.ts +0 -7
  228. package/dist/types/src/extensions/json.d.ts.map +0 -1
  229. package/dist/types/src/extensions/listener.d.ts +0 -11
  230. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  231. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  232. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  233. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  234. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  235. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  236. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  237. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  238. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  239. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  240. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  241. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  242. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  243. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  244. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  245. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  246. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  247. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  248. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  249. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  250. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  251. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  252. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  253. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  254. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  255. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  256. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  257. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  258. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  259. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  260. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  261. package/dist/types/src/extensions/mention.d.ts +0 -7
  262. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  263. package/dist/types/src/extensions/modes.d.ts +0 -10
  264. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  265. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  266. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  267. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  268. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  269. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  270. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  271. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  272. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  273. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  274. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  275. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  276. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  277. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  278. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  279. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  280. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  281. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  282. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  283. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  284. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  285. package/dist/types/src/extensions/preview/preview.d.ts +0 -29
  286. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  287. package/dist/types/src/extensions/selection.d.ts +0 -24
  288. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  289. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  290. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  291. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  292. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  293. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  294. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  295. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  296. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  297. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -71
  298. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  299. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  300. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  301. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  302. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  303. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  304. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  305. package/dist/types/src/styles/index.d.ts +0 -4
  306. package/dist/types/src/styles/index.d.ts.map +0 -1
  307. package/dist/types/src/styles/markdown.d.ts +0 -8
  308. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  309. package/dist/types/src/styles/theme.d.ts +0 -38
  310. package/dist/types/src/styles/theme.d.ts.map +0 -1
  311. package/dist/types/src/styles/tokens.d.ts +0 -3
  312. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  313. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  314. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  315. package/dist/types/src/testing/index.d.ts +0 -3
  316. package/dist/types/src/testing/index.d.ts.map +0 -1
  317. package/dist/types/src/testing/util.d.ts +0 -3
  318. package/dist/types/src/testing/util.d.ts.map +0 -1
  319. package/dist/types/src/types/index.d.ts +0 -2
  320. package/dist/types/src/types/index.d.ts.map +0 -1
  321. package/dist/types/src/types/types.d.ts +0 -21
  322. package/dist/types/src/types/types.d.ts.map +0 -1
  323. package/dist/types/src/util/cursor.d.ts +0 -31
  324. package/dist/types/src/util/cursor.d.ts.map +0 -1
  325. package/dist/types/src/util/debug.d.ts +0 -17
  326. package/dist/types/src/util/debug.d.ts.map +0 -1
  327. package/dist/types/src/util/decorations.d.ts +0 -4
  328. package/dist/types/src/util/decorations.d.ts.map +0 -1
  329. package/dist/types/src/util/dom.d.ts +0 -10
  330. package/dist/types/src/util/dom.d.ts.map +0 -1
  331. package/dist/types/src/util/domino.d.ts +0 -18
  332. package/dist/types/src/util/domino.d.ts.map +0 -1
  333. package/dist/types/src/util/facet.d.ts +0 -3
  334. package/dist/types/src/util/facet.d.ts.map +0 -1
  335. package/src/components/CommandMenu/CommandMenu.tsx +0 -346
  336. package/src/components/CommandMenu/index.ts +0 -5
  337. package/src/components/EditorToolbar/util.ts +0 -76
  338. package/src/defaults.ts +0 -52
  339. package/src/extensions/annotations.ts +0 -55
  340. package/src/extensions/autocomplete.ts +0 -219
  341. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  342. package/src/extensions/automerge/automerge.test.tsx +0 -78
  343. package/src/extensions/automerge/automerge.ts +0 -86
  344. package/src/extensions/automerge/cursor.ts +0 -28
  345. package/src/extensions/automerge/defs.ts +0 -31
  346. package/src/extensions/automerge/index.ts +0 -5
  347. package/src/extensions/automerge/sync.ts +0 -75
  348. package/src/extensions/automerge/update-automerge.ts +0 -50
  349. package/src/extensions/automerge/update-codemirror.ts +0 -115
  350. package/src/extensions/autoscroll.ts +0 -157
  351. package/src/extensions/awareness/awareness-provider.ts +0 -127
  352. package/src/extensions/awareness/awareness.ts +0 -315
  353. package/src/extensions/awareness/index.ts +0 -6
  354. package/src/extensions/blast.ts +0 -363
  355. package/src/extensions/command/action.ts +0 -55
  356. package/src/extensions/command/command-menu.ts +0 -211
  357. package/src/extensions/command/command.ts +0 -34
  358. package/src/extensions/command/floating-menu.ts +0 -128
  359. package/src/extensions/command/hint.ts +0 -103
  360. package/src/extensions/command/index.ts +0 -10
  361. package/src/extensions/command/placeholder.ts +0 -113
  362. package/src/extensions/command/state.ts +0 -90
  363. package/src/extensions/command/typeahead.ts +0 -129
  364. package/src/extensions/command/useCommandMenu.ts +0 -115
  365. package/src/extensions/comments.ts +0 -597
  366. package/src/extensions/debug.ts +0 -15
  367. package/src/extensions/dnd.ts +0 -37
  368. package/src/extensions/factories.ts +0 -247
  369. package/src/extensions/focus.ts +0 -35
  370. package/src/extensions/folding.tsx +0 -46
  371. package/src/extensions/hashtag.tsx +0 -68
  372. package/src/extensions/index.ts +0 -28
  373. package/src/extensions/json.ts +0 -57
  374. package/src/extensions/listener.ts +0 -38
  375. package/src/extensions/markdown/action.ts +0 -117
  376. package/src/extensions/markdown/bundle.ts +0 -93
  377. package/src/extensions/markdown/changes.test.ts +0 -26
  378. package/src/extensions/markdown/changes.ts +0 -149
  379. package/src/extensions/markdown/debug.ts +0 -44
  380. package/src/extensions/markdown/decorate.ts +0 -600
  381. package/src/extensions/markdown/formatting.test.ts +0 -498
  382. package/src/extensions/markdown/formatting.ts +0 -1267
  383. package/src/extensions/markdown/highlight.ts +0 -183
  384. package/src/extensions/markdown/image.ts +0 -118
  385. package/src/extensions/markdown/index.ts +0 -13
  386. package/src/extensions/markdown/link.ts +0 -50
  387. package/src/extensions/markdown/parser.test.ts +0 -75
  388. package/src/extensions/markdown/styles.ts +0 -135
  389. package/src/extensions/markdown/table.ts +0 -150
  390. package/src/extensions/mention.ts +0 -41
  391. package/src/extensions/modes.ts +0 -41
  392. package/src/extensions/outliner/commands.ts +0 -270
  393. package/src/extensions/outliner/editor.test.ts +0 -33
  394. package/src/extensions/outliner/editor.ts +0 -184
  395. package/src/extensions/outliner/index.ts +0 -7
  396. package/src/extensions/outliner/outliner.test.ts +0 -100
  397. package/src/extensions/outliner/outliner.ts +0 -167
  398. package/src/extensions/outliner/selection.ts +0 -50
  399. package/src/extensions/outliner/tree.test.ts +0 -168
  400. package/src/extensions/outliner/tree.ts +0 -317
  401. package/src/extensions/preview/index.ts +0 -5
  402. package/src/extensions/preview/preview.ts +0 -190
  403. package/src/extensions/selection.ts +0 -100
  404. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  405. package/src/extensions/tags/extended-markdown.ts +0 -78
  406. package/src/extensions/tags/index.ts +0 -7
  407. package/src/extensions/tags/streamer.ts +0 -244
  408. package/src/extensions/tags/xml-tags.ts +0 -335
  409. package/src/extensions/tags/xml-util.ts +0 -94
  410. package/src/extensions/typewriter.ts +0 -68
  411. package/src/stories/CommandMenu.stories.tsx +0 -158
  412. package/src/styles/index.ts +0 -7
  413. package/src/styles/markdown.ts +0 -26
  414. package/src/styles/theme.ts +0 -267
  415. package/src/styles/tokens.ts +0 -17
  416. package/src/testing/PreviewPopover.tsx +0 -78
  417. package/src/testing/index.ts +0 -6
  418. package/src/testing/util.ts +0 -7
  419. package/src/types/index.ts +0 -5
  420. package/src/types/types.ts +0 -32
  421. package/src/util/cursor.ts +0 -56
  422. package/src/util/debug.ts +0 -64
  423. package/src/util/decorations.ts +0 -21
  424. package/src/util/dom.ts +0 -34
  425. package/src/util/domino.ts +0 -51
  426. package/src/util/facet.ts +0 -13
@@ -2,133 +2,147 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- import { Rx } from '@effect-rx/rx-react';
5
+ import { type EditorView } from '@codemirror/view';
6
+ import { Atom } from '@effect-atom/atom-react';
6
7
  import React, { memo, useMemo } from 'react';
7
8
 
8
- import { rxFromSignal } from '@dxos/app-graph';
9
- import { ElevationProvider } from '@dxos/react-ui';
9
+ import { type Node } from '@dxos/app-graph';
10
+ import { ElevationProvider, type ThemedClassName } from '@dxos/react-ui';
10
11
  import {
11
12
  type ActionGraphProps,
13
+ type MenuAction,
12
14
  MenuProvider,
13
15
  ToolbarMenu,
14
16
  createGapSeparator,
15
17
  useMenuActions,
16
18
  } from '@dxos/react-ui-menu';
19
+ import { type EditorViewMode } from '@dxos/ui-editor';
17
20
 
21
+ import { createLists } from './actions';
18
22
  import { createBlocks } from './blocks';
19
23
  import { createFormatting } from './formatting';
20
24
  import { createHeadings } from './headings';
21
25
  import { createImageUpload } from './image';
22
- import { createLists } from './lists';
23
26
  import { createSearch } from './search';
24
- import { type EditorToolbarActionGraphProps, type EditorToolbarFeatureFlags, type EditorToolbarProps } from './util';
27
+ import { type EditorToolbarState } from './useEditorToolbar';
25
28
  import { createViewMode } from './view-mode';
26
29
 
30
+ export type EditorToolbarFeatureFlags = Partial<{
31
+ showHeadings: boolean;
32
+ showFormatting: boolean;
33
+ showLists: boolean;
34
+ showBlocks: boolean;
35
+ showSearch: boolean;
36
+
37
+ // TODO(wittjosiah): Factor out (depends on plugin-level capabilities.)
38
+ onImageUpload: () => void;
39
+ onViewModeChange: (mode: EditorViewMode) => void;
40
+ }>;
41
+
42
+ export type EditorToolbarActionGraphProps = {
43
+ state: Atom.Atom<EditorToolbarState>;
44
+ getView: () => EditorView;
45
+ // TODO(wittjosiah): Control positioning.
46
+ customActions?: Atom.Atom<ActionGraphProps>;
47
+ };
48
+
49
+ export type EditorToolbarProps = ThemedClassName<
50
+ {
51
+ role?: string;
52
+ attendableId?: string;
53
+ /** Handler for executing actions. Required when customActions use Operation.invoke. */
54
+ onAction?: (action: MenuAction, params: Node.InvokeProps) => void;
55
+ } & (EditorToolbarActionGraphProps & EditorToolbarFeatureFlags)
56
+ >;
57
+
58
+ // TODO(burdon): Remove role dependency.
59
+ export const EditorToolbar = memo(({ classNames, role, attendableId, onAction, ...props }: EditorToolbarProps) => {
60
+ const menuProps = useEditorToolbarActionGraph(props);
61
+
62
+ return (
63
+ <ElevationProvider elevation={role === 'section' ? 'positioned' : 'base'}>
64
+ <MenuProvider {...menuProps} attendableId={attendableId} onAction={onAction}>
65
+ <ToolbarMenu classNames={classNames} textBlockWidth />
66
+ </MenuProvider>
67
+ </ElevationProvider>
68
+ );
69
+ });
70
+
71
+ type ToolbarActionsProps = Pick<EditorToolbarActionGraphProps, 'state' | 'getView' | 'customActions'> &
72
+ EditorToolbarFeatureFlags;
73
+
74
+ // TODO(wittjosiah): Toolbar re-rendering is causing this graph to be recreated and breaking reactivity in some cases.
75
+ // E.g. for toolbar dropdowns which use active icon, the icon is not updated when the active item changes.
76
+ // This is currently only happening in the markdown plugin usage and should be reproduced in an editor story.
77
+ const useEditorToolbarActionGraph = ({ state, getView, customActions, ...features }: ToolbarActionsProps) => {
78
+ const menuCreator = useMemo(
79
+ () => createToolbarActions({ state, getView, customActions, ...features }),
80
+ [
81
+ state,
82
+ getView,
83
+ customActions,
84
+ features?.showHeadings,
85
+ features?.showFormatting,
86
+ features?.showLists,
87
+ features?.showBlocks,
88
+ features?.showSearch,
89
+ features?.onImageUpload,
90
+ features?.onViewModeChange,
91
+ ],
92
+ );
93
+
94
+ return useMenuActions(menuCreator);
95
+ };
96
+
27
97
  const createToolbarActions = ({
28
- getView,
29
98
  state,
99
+ getView,
30
100
  customActions,
31
101
  ...features
32
- }: EditorToolbarFeatureFlags &
33
- Pick<EditorToolbarActionGraphProps, 'getView' | 'state' | 'customActions'>): Rx.Rx<ActionGraphProps> => {
34
- return Rx.make((get) => {
102
+ }: ToolbarActionsProps): Atom.Atom<ActionGraphProps> => {
103
+ return Atom.make((get) => {
35
104
  const graph: ActionGraphProps = {
36
105
  nodes: [],
37
106
  edges: [],
38
107
  };
39
108
 
40
- if (features.headings ?? true) {
41
- const headings = get(rxFromSignal(() => createHeadings(state, getView)));
42
- graph.nodes.push(...headings.nodes);
43
- graph.edges.push(...headings.edges);
44
- }
45
- if (features.formatting ?? true) {
46
- const formatting = get(rxFromSignal(() => createFormatting(state, getView)));
47
- graph.nodes.push(...formatting.nodes);
48
- graph.edges.push(...formatting.edges);
109
+ // TODO(burdon): Builder pattern?
110
+ const addSubGraph = (graph: ActionGraphProps, subGraph: ActionGraphProps) => {
111
+ graph.nodes.push(...subGraph.nodes);
112
+ graph.edges.push(...subGraph.edges);
113
+ };
114
+
115
+ // Subscribe to state changes.
116
+ const stateSnapshot = get(state);
117
+
118
+ if (features?.showHeadings ?? true) {
119
+ addSubGraph(graph, createHeadings(stateSnapshot, getView));
49
120
  }
50
- if (features.lists ?? true) {
51
- const lists = get(rxFromSignal(() => createLists(state, getView)));
52
- graph.nodes.push(...lists.nodes);
53
- graph.edges.push(...lists.edges);
121
+ if (features?.showFormatting ?? true) {
122
+ addSubGraph(graph, createFormatting(stateSnapshot, getView));
54
123
  }
55
- if (features.blocks ?? true) {
56
- const blocks = get(rxFromSignal(() => createBlocks(state, getView)));
57
- graph.nodes.push(...blocks.nodes);
58
- graph.edges.push(...blocks.edges);
124
+ if (features?.showLists ?? true) {
125
+ addSubGraph(graph, createLists(stateSnapshot, getView));
59
126
  }
60
- if (features.image) {
61
- const image = get(rxFromSignal(() => createImageUpload(features.image!)));
62
- graph.nodes.push(...image.nodes);
63
- graph.edges.push(...image.edges);
127
+ if (features?.showBlocks ?? true) {
128
+ addSubGraph(graph, createBlocks(stateSnapshot, getView));
64
129
  }
65
- {
66
- const gap = createGapSeparator();
67
- graph.nodes.push(...gap.nodes);
68
- graph.edges.push(...gap.edges);
130
+ if (features?.onImageUpload) {
131
+ addSubGraph(graph, createImageUpload(features.onImageUpload!));
69
132
  }
133
+
134
+ addSubGraph(graph, createGapSeparator());
135
+
70
136
  if (customActions) {
71
- const custom = get(customActions);
72
- graph.nodes.push(...custom.nodes);
73
- graph.edges.push(...custom.edges);
137
+ addSubGraph(graph, get(customActions));
74
138
  }
75
- if (features.search ?? true) {
76
- const search = get(rxFromSignal(() => createSearch(getView)));
77
- graph.nodes.push(...search.nodes);
78
- graph.edges.push(...search.edges);
139
+ if (features?.showSearch ?? true) {
140
+ addSubGraph(graph, createSearch(getView));
79
141
  }
80
- if (features.viewMode) {
81
- const viewMode = get(rxFromSignal(() => createViewMode(state, features.viewMode!)));
82
- graph.nodes.push(...viewMode.nodes);
83
- graph.edges.push(...viewMode.edges);
142
+ if (features?.onViewModeChange) {
143
+ addSubGraph(graph, createViewMode(stateSnapshot, features.onViewModeChange!));
84
144
  }
85
145
 
86
146
  return graph;
87
147
  });
88
148
  };
89
-
90
- // TODO(wittjosiah): Toolbar re-rendering is causing this graph to be recreated and breaking reactivity in some cases.
91
- // E.g. for toolbar dropdowns which use active icon, the icon is not updated when the active item changes.
92
- // This is currently only happening in the markdown plugin usage and should be reproduced in an editor story.
93
- const useEditorToolbarActionGraph = (props: EditorToolbarProps) => {
94
- const menuCreator = useMemo(
95
- () =>
96
- createToolbarActions({
97
- getView: props.getView,
98
- state: props.state,
99
- customActions: props.customActions,
100
- headings: props.headings,
101
- formatting: props.formatting,
102
- lists: props.lists,
103
- blocks: props.blocks,
104
- image: props.image,
105
- search: props.search,
106
- viewMode: props.viewMode,
107
- }),
108
- [
109
- props.getView,
110
- props.state,
111
- props.customActions,
112
- props.headings,
113
- props.formatting,
114
- props.lists,
115
- props.blocks,
116
- props.image,
117
- props.search,
118
- props.viewMode,
119
- ],
120
- );
121
-
122
- return useMenuActions(menuCreator);
123
- };
124
-
125
- export const EditorToolbar = memo(({ classNames, attendableId, role, ...props }: EditorToolbarProps) => {
126
- const menuProps = useEditorToolbarActionGraph(props);
127
- return (
128
- <ElevationProvider elevation={role === 'section' ? 'positioned' : 'base'}>
129
- <MenuProvider {...menuProps} attendableId={attendableId}>
130
- <ToolbarMenu classNames={classNames} textBlockWidth />
131
- </MenuProvider>
132
- </ElevationProvider>
133
- );
134
- });
@@ -4,12 +4,19 @@
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 Node } from '@dxos/app-graph';
8
+ import {
9
+ type MenuItemGroup,
10
+ type ToolbarMenuActionGroupProperties,
11
+ createMenuAction,
12
+ createMenuItemGroup,
13
+ } from '@dxos/react-ui-menu';
14
+ import { List, addList, removeList } from '@dxos/ui-editor';
15
+ import { type MenuActionProperties } from '@dxos/ui-types';
9
16
 
10
- import { List, addList, removeList } from '../../extensions';
17
+ import { translationKey } from '../../translations';
11
18
 
12
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
19
+ import { type EditorToolbarState } from './useEditorToolbar';
13
20
 
14
21
  const listStyles = {
15
22
  bullet: 'ph--list-bullets--regular',
@@ -17,6 +24,43 @@ const listStyles = {
17
24
  task: 'ph--list-checks--regular',
18
25
  };
19
26
 
27
+ export const createLists = (state: EditorToolbarState, getView: () => EditorView) => {
28
+ const value = state.listStyle ?? '';
29
+ const listGroupAction = createListGroupAction(value);
30
+ const listActionsMap = createListActions(value, getView);
31
+ return {
32
+ nodes: [listGroupAction as Node.NodeArg<any>, ...listActionsMap],
33
+ edges: [
34
+ { source: 'root', target: 'list' },
35
+ ...listActionsMap.map(({ id }) => ({ source: listGroupAction.id, target: id })),
36
+ ],
37
+ };
38
+ };
39
+
40
+ export const createEditorAction = (id: string, props: Partial<MenuActionProperties>, invoke: () => void) => {
41
+ const { label = [`${id} label`, { ns: translationKey }], ...rest } = props;
42
+
43
+ return createMenuAction(id, invoke, {
44
+ label,
45
+ ...rest,
46
+ }) as Node.Action<MenuActionProperties>;
47
+ };
48
+
49
+ export const createEditorActionGroup = (
50
+ id: string,
51
+ props: Omit<ToolbarMenuActionGroupProperties, 'icon'>,
52
+ icon?: string,
53
+ ): MenuItemGroup<ToolbarMenuActionGroupProperties> => {
54
+ const { label = [`${id} label`, { ns: translationKey }], ...rest } = props;
55
+
56
+ return createMenuItemGroup(id, {
57
+ label,
58
+ icon,
59
+ iconOnly: true,
60
+ ...rest,
61
+ }) as MenuItemGroup<ToolbarMenuActionGroupProperties>;
62
+ };
63
+
20
64
  const createListGroupAction = (value: string) =>
21
65
  createEditorActionGroup('list', {
22
66
  variant: 'toggleGroup',
@@ -41,16 +85,3 @@ const createListActions = (value: string, getView: () => EditorView) =>
41
85
  }
42
86
  });
43
87
  });
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
- ],
55
- };
56
- };
@@ -4,12 +4,12 @@
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
6
 
7
- import { type NodeArg } from '@dxos/app-graph';
7
+ import { type Node } from '@dxos/app-graph';
8
8
  import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
9
+ import { addBlockquote, addCodeblock, insertTable, removeBlockquote, removeCodeblock } from '@dxos/ui-editor';
9
10
 
10
- import { addBlockquote, addCodeblock, insertTable, removeBlockquote, removeCodeblock } from '../../extensions';
11
-
12
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
11
+ import { createEditorAction, createEditorActionGroup } from './actions';
12
+ import { type EditorToolbarState } from './useEditorToolbar';
13
13
 
14
14
  const createBlockGroupAction = (value: string) =>
15
15
  createEditorActionGroup('block', {
@@ -50,7 +50,7 @@ export const createBlocks = (state: EditorToolbarState, getView: () => EditorVie
50
50
  const blockGroupAction = createBlockGroupAction(value);
51
51
  const blockActions = createBlockActions(value, getView, state.blankLine);
52
52
  return {
53
- nodes: [blockGroupAction as NodeArg<any>, ...blockActions],
53
+ nodes: [blockGroupAction as Node.NodeArg<any>, ...blockActions],
54
54
  edges: [
55
55
  { source: 'root', target: 'block' },
56
56
  ...blockActions.map(({ id }) => ({ source: blockGroupAction.id, target: id })),
@@ -4,12 +4,12 @@
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
6
 
7
- import { type NodeArg } from '@dxos/app-graph';
7
+ import { type Node } from '@dxos/app-graph';
8
8
  import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
9
+ import { type Formatting, Inline, addLink, removeLink, setStyle } from '@dxos/ui-editor';
9
10
 
10
- import { type Formatting, Inline, addLink, removeLink, setStyle } from '../../extensions';
11
-
12
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
11
+ import { createEditorAction, createEditorActionGroup } from './actions';
12
+ import { type EditorToolbarState } from './useEditorToolbar';
13
13
 
14
14
  const formats = {
15
15
  strong: 'ph--text-b--regular',
@@ -56,7 +56,7 @@ export const createFormatting = (state: EditorToolbarState, getView: () => Edito
56
56
  const formattingGroupAction = createFormattingGroup(state);
57
57
  const formattingActions = createFormattingActions(state, getView);
58
58
  return {
59
- nodes: [formattingGroupAction as NodeArg<any>, ...formattingActions],
59
+ nodes: [formattingGroupAction as Node.NodeArg<any>, ...formattingActions],
60
60
  edges: [
61
61
  { source: 'root', target: 'formatting' },
62
62
  ...formattingActions.map(({ id }) => ({ source: formattingGroupAction.id, target: id })),
@@ -4,13 +4,14 @@
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
6
 
7
- import { type NodeArg } from '@dxos/app-graph';
7
+ import { type Node } from '@dxos/app-graph';
8
8
  import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
9
+ import { setHeading } from '@dxos/ui-editor';
9
10
 
10
- import { setHeading } from '../../extensions';
11
11
  import { translationKey } from '../../translations';
12
12
 
13
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
13
+ import { createEditorAction, createEditorActionGroup } from './actions';
14
+ import { type EditorToolbarState } from './useEditorToolbar';
14
15
 
15
16
  const createHeadingGroupAction = (value: string) =>
16
17
  createEditorActionGroup(
@@ -19,12 +20,13 @@ const createHeadingGroupAction = (value: string) =>
19
20
  variant: 'dropdownMenu',
20
21
  applyActive: true,
21
22
  selectCardinality: 'single',
23
+ // TODO(wittjosiah): Remove? Not sure this does anything.
22
24
  value,
23
25
  } as ToolbarMenuActionGroupProperties,
24
26
  'ph--text-h--regular',
25
27
  );
26
28
 
27
- const createHeadingActions = (getView: () => EditorView) =>
29
+ const createHeadingActions = (currentLevel: string, getView: () => EditorView) =>
28
30
  Object.entries({
29
31
  '0': 'ph--paragraph--regular',
30
32
  '1': 'ph--text-h-one--regular',
@@ -40,6 +42,7 @@ const createHeadingActions = (getView: () => EditorView) =>
40
42
  {
41
43
  label: ['heading level label', { count: level, ns: translationKey }],
42
44
  icon,
45
+ checked: levelStr === currentLevel,
43
46
  },
44
47
  () => setHeading(level)(getView()),
45
48
  );
@@ -47,16 +50,16 @@ const createHeadingActions = (getView: () => EditorView) =>
47
50
 
48
51
  const computeHeadingValue = (state: EditorToolbarState) => {
49
52
  const blockType = state ? state.blockType : 'paragraph';
50
- const header = blockType && /heading(\d)/.exec(blockType);
51
- return header ? header[1] : blockType === 'paragraph' || !blockType ? '0' : '';
53
+ const heading = blockType && /heading(\d)/.exec(blockType);
54
+ return heading ? heading[1] : blockType === 'paragraph' || !blockType ? '0' : '';
52
55
  };
53
56
 
54
57
  export const createHeadings = (state: EditorToolbarState, getView: () => EditorView) => {
55
58
  const headingValue = computeHeadingValue(state);
56
59
  const headingGroupAction = createHeadingGroupAction(headingValue);
57
- const headingActions = createHeadingActions(getView);
60
+ const headingActions = createHeadingActions(headingValue, getView);
58
61
  return {
59
- nodes: [headingGroupAction as NodeArg<any>, ...headingActions],
62
+ nodes: [headingGroupAction as Node.NodeArg<any>, ...headingActions],
60
63
  edges: [
61
64
  { source: 'root', target: 'heading' },
62
65
  ...headingActions.map(({ id }) => ({ source: headingGroupAction.id, target: id })),
@@ -2,7 +2,9 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { createEditorAction } from './util';
5
+ import { type Node } from '@dxos/app-graph';
6
+
7
+ import { createEditorAction } from './actions';
6
8
 
7
9
  const createImageUploadAction = (onImageUpload: () => void) =>
8
10
  createEditorAction(
@@ -14,7 +16,12 @@ const createImageUploadAction = (onImageUpload: () => void) =>
14
16
  onImageUpload,
15
17
  );
16
18
 
17
- export const createImageUpload = (onImageUpload: () => void) => ({
19
+ export const createImageUpload = (
20
+ onImageUpload: () => void,
21
+ ): {
22
+ nodes: Node.NodeArg<any>[];
23
+ edges: Array<{ source: string; target: string }>;
24
+ } => ({
18
25
  nodes: [createImageUploadAction(onImageUpload)],
19
26
  edges: [{ source: 'root', target: 'image' }],
20
27
  });
@@ -3,10 +3,6 @@
3
3
  //
4
4
 
5
5
  export * from './EditorToolbar';
6
- export {
7
- type EditorToolbarState,
8
- type EditorToolbarActionGraphProps,
9
- useEditorToolbarState,
10
- createEditorAction,
11
- createEditorActionGroup,
12
- } from './util';
6
+
7
+ export { createEditorAction, createEditorActionGroup } from './actions';
8
+ export { type EditorToolbarState, useEditorToolbar } from './useEditorToolbar';
@@ -5,7 +5,9 @@
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 Node } from '@dxos/app-graph';
9
+
10
+ import { createEditorAction } from './actions';
9
11
 
10
12
  const createSearchAction = (getView: () => EditorView) =>
11
13
  createEditorAction(
@@ -17,7 +19,12 @@ const createSearchAction = (getView: () => EditorView) =>
17
19
  () => openSearchPanel(getView()),
18
20
  );
19
21
 
20
- export const createSearch = (getView: () => EditorView) => ({
22
+ export const createSearch = (
23
+ getView: () => EditorView,
24
+ ): {
25
+ nodes: Node.NodeArg<any>[];
26
+ edges: Array<{ source: string; target: string }>;
27
+ } => ({
21
28
  nodes: [createSearchAction(getView)],
22
29
  edges: [{ source: 'root', target: 'search' }],
23
30
  });
@@ -0,0 +1,20 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { Atom } from '@effect-atom/atom-react';
6
+ import { useMemo } from 'react';
7
+
8
+ import { type EditorViewMode, type Formatting } from '@dxos/ui-editor';
9
+
10
+ // TODO(burdon): Move to extensions.
11
+ export type EditorToolbarState = { viewMode?: EditorViewMode } & Formatting;
12
+
13
+ /**
14
+ * Creates an atom for editor toolbar state.
15
+ * @deprecated Use Editor.Root
16
+ */
17
+ export const useEditorToolbar = (initialState: EditorToolbarState = {}): Atom.Writable<EditorToolbarState> => {
18
+ // TODO(wittjosiah): Including initialState in the deps causes reactivity issues.
19
+ return useMemo(() => Atom.make<EditorToolbarState>(initialState), []);
20
+ };
@@ -2,13 +2,14 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { type NodeArg } from '@dxos/app-graph';
5
+ import { type Node } from '@dxos/app-graph';
6
6
  import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
7
+ import { type EditorViewMode } from '@dxos/ui-editor';
7
8
 
8
9
  import { translationKey } from '../../translations';
9
- import { type EditorViewMode } from '../../types';
10
10
 
11
- import { type EditorToolbarState, createEditorAction, createEditorActionGroup } from './util';
11
+ import { createEditorAction, createEditorActionGroup } from './actions';
12
+ import { type EditorToolbarState } from './useEditorToolbar';
12
13
 
13
14
  const createViewModeGroupAction = (value: string) =>
14
15
  createEditorActionGroup(
@@ -45,7 +46,7 @@ export const createViewMode = (state: EditorToolbarState, onViewModeChange: (mod
45
46
  const viewModeGroupAction = createViewModeGroupAction(value);
46
47
  const viewModeActions = createViewModeActions(value, onViewModeChange);
47
48
  return {
48
- nodes: [viewModeGroupAction as NodeArg<any>, ...viewModeActions],
49
+ nodes: [viewModeGroupAction as Node.NodeArg<any>, ...viewModeActions],
49
50
  edges: [
50
51
  { source: 'root', target: 'viewMode' },
51
52
  ...viewModeActions.map(({ id }) => ({ source: viewModeGroupAction.id, target: id })),
@@ -3,5 +3,9 @@
3
3
  //
4
4
 
5
5
  export * from './Editor';
6
- export * from './EditorToolbar';
7
- export * from './CommandMenu';
6
+
7
+ // TODO(burdon): Remove once Editor is fully migrated.
8
+ export { EditorContent, createEditorController } from './EditorContent';
9
+ export * from './EditorMenuProvider';
10
+ export * from './EditorPreviewProvider';
11
+ export { EditorToolbar, type EditorToolbarProps, type EditorToolbarState, useEditorToolbar } from './EditorToolbar';