@dxos/react-ui-editor 0.8.4-main.f9ba587 → 0.8.4-main.fcc0d83b33

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 (414) hide show
  1. package/dist/lib/browser/index.mjs +1407 -7549
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/browser/translations.mjs +39 -0
  5. package/dist/lib/browser/translations.mjs.map +7 -0
  6. package/dist/lib/node-esm/index.mjs +1407 -7548
  7. package/dist/lib/node-esm/index.mjs.map +4 -4
  8. package/dist/lib/node-esm/meta.json +1 -1
  9. package/dist/lib/node-esm/translations.mjs +41 -0
  10. package/dist/lib/node-esm/translations.mjs.map +7 -0
  11. package/dist/types/src/components/Editor/Editor.d.ts +54 -15
  12. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  13. package/dist/types/src/components/Editor/Editor.stories.d.ts +23 -0
  14. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  15. package/dist/types/src/components/Editor/EditorView.d.ts +31 -0
  16. package/dist/types/src/components/Editor/EditorView.d.ts.map +1 -0
  17. package/dist/types/src/components/Editor/controller.d.ts +10 -0
  18. package/dist/types/src/components/Editor/controller.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +34 -0
  20. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  22. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  24. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  26. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +47 -0
  28. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  30. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  32. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  34. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  35. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  36. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +4 -17
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +4 -17
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +4 -17
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +3 -15
  44. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
  46. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/lists.d.ts +4 -17
  48. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/search.d.ts +3 -15
  50. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  51. package/dist/types/src/components/EditorToolbar/types.d.ts +6 -0
  52. package/dist/types/src/components/EditorToolbar/types.d.ts.map +1 -0
  53. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +5 -18
  54. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  55. package/dist/types/src/components/index.d.ts +2 -2
  56. package/dist/types/src/components/index.d.ts.map +1 -1
  57. package/dist/types/src/extensions/Assistant.stories.d.ts +10 -0
  58. package/dist/types/src/extensions/Assistant.stories.d.ts.map +1 -0
  59. package/dist/types/src/extensions/assistant-extension.d.ts +24 -0
  60. package/dist/types/src/extensions/assistant-extension.d.ts.map +1 -0
  61. package/dist/types/src/extensions/index.d.ts +1 -22
  62. package/dist/types/src/extensions/index.d.ts.map +1 -1
  63. package/dist/types/src/hooks/index.d.ts +1 -0
  64. package/dist/types/src/hooks/index.d.ts.map +1 -1
  65. package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts +25 -0
  66. package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts.map +1 -0
  67. package/dist/types/src/hooks/useTextEditor.d.ts +6 -10
  68. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  69. package/dist/types/src/index.d.ts +0 -9
  70. package/dist/types/src/index.d.ts.map +1 -1
  71. package/dist/types/src/stories/Automerge.stories.d.ts +44 -0
  72. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  73. package/dist/types/src/stories/Comments.stories.d.ts +22 -10
  74. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/EditorToolbar.stories.d.ts +42 -4
  76. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  77. package/dist/types/src/stories/Experimental.stories.d.ts +23 -13
  78. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/Markdown.stories.d.ts +33 -43
  80. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  81. package/dist/types/src/stories/Outliner.stories.d.ts +16 -22
  82. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  83. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  84. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  85. package/dist/types/src/stories/Preview.stories.d.ts +23 -7
  86. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  87. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  88. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  89. package/dist/types/src/stories/TextEditor.stories.d.ts +38 -52
  90. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  91. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  92. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  93. package/dist/types/src/stories/components/EditorStory.d.ts +11 -23
  94. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  95. package/dist/types/src/stories/components/util.d.ts +4 -3
  96. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  97. package/dist/types/src/translations.d.ts +26 -26
  98. package/dist/types/src/translations.d.ts.map +1 -1
  99. package/dist/types/src/util/index.d.ts +0 -4
  100. package/dist/types/src/util/index.d.ts.map +1 -1
  101. package/dist/types/src/util/react.d.ts +7 -6
  102. package/dist/types/src/util/react.d.ts.map +1 -1
  103. package/dist/types/tsconfig.tsbuildinfo +1 -1
  104. package/package.json +95 -82
  105. package/src/components/Editor/Editor.stories.tsx +89 -0
  106. package/src/components/Editor/Editor.tsx +175 -24
  107. package/src/components/Editor/EditorView.tsx +84 -0
  108. package/src/components/Editor/controller.ts +50 -0
  109. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +226 -0
  110. package/src/components/EditorMenuProvider/index.ts +10 -0
  111. package/src/components/EditorMenuProvider/menu-presets.ts +125 -0
  112. package/src/components/EditorMenuProvider/menu.ts +70 -0
  113. package/src/components/EditorMenuProvider/popover.ts +286 -0
  114. package/src/components/EditorMenuProvider/useEditorMenu.ts +180 -0
  115. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  116. package/src/components/EditorPreviewProvider/index.ts +5 -0
  117. package/src/components/EditorToolbar/EditorToolbar.tsx +92 -103
  118. package/src/components/EditorToolbar/blocks.ts +53 -48
  119. package/src/components/EditorToolbar/formatting.ts +42 -46
  120. package/src/components/EditorToolbar/headings.ts +47 -45
  121. package/src/components/EditorToolbar/image.ts +16 -10
  122. package/src/components/EditorToolbar/index.ts +2 -7
  123. package/src/components/EditorToolbar/lists.ts +40 -41
  124. package/src/components/EditorToolbar/search.ts +16 -10
  125. package/src/components/EditorToolbar/types.ts +8 -0
  126. package/src/components/EditorToolbar/view-mode.ts +40 -40
  127. package/src/components/index.ts +3 -2
  128. package/src/extensions/Assistant.stories.tsx +112 -0
  129. package/src/extensions/assistant-extension.tsx +223 -0
  130. package/src/extensions/index.ts +2 -23
  131. package/src/hooks/index.ts +1 -0
  132. package/src/hooks/useBasicMarkdownExtensions.ts +55 -0
  133. package/src/hooks/useTextEditor.ts +39 -45
  134. package/src/index.ts +0 -13
  135. package/src/stories/Automerge.stories.tsx +174 -0
  136. package/src/stories/Comments.stories.tsx +59 -51
  137. package/src/stories/EditorToolbar.stories.tsx +50 -62
  138. package/src/stories/Experimental.stories.tsx +24 -22
  139. package/src/stories/Markdown.stories.tsx +37 -33
  140. package/src/stories/Outliner.stories.tsx +54 -44
  141. package/src/stories/Popover.stories.tsx +157 -0
  142. package/src/stories/Preview.stories.tsx +114 -95
  143. package/src/stories/Tags.stories.tsx +104 -0
  144. package/src/stories/TextEditor.stories.tsx +50 -75
  145. package/src/stories/Theme.stories.tsx +61 -0
  146. package/src/stories/components/EditorStory.tsx +50 -35
  147. package/src/stories/components/util.tsx +90 -59
  148. package/src/translations.ts +30 -25
  149. package/src/util/index.ts +1 -5
  150. package/src/util/react.tsx +9 -14
  151. package/dist/lib/browser/chunk-22UMM3QJ.mjs +0 -22
  152. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  153. package/dist/lib/browser/testing/index.mjs +0 -6
  154. package/dist/lib/browser/testing/index.mjs.map +0 -7
  155. package/dist/lib/browser/types/index.mjs +0 -13
  156. package/dist/lib/browser/types/index.mjs.map +0 -7
  157. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs +0 -24
  158. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  159. package/dist/lib/node-esm/testing/index.mjs +0 -8
  160. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  161. package/dist/lib/node-esm/types/index.mjs +0 -14
  162. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  163. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  164. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  165. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  166. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  167. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  168. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  169. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  170. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  171. package/dist/types/src/components/Popover/index.d.ts +0 -4
  172. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  173. package/dist/types/src/defaults.d.ts +0 -14
  174. package/dist/types/src/defaults.d.ts.map +0 -1
  175. package/dist/types/src/extensions/annotations.d.ts +0 -9
  176. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  177. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  178. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  179. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  180. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  181. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +0 -56
  182. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  183. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  184. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  185. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  186. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  187. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  188. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  189. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  190. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  191. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  192. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  193. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  194. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  195. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  196. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  197. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  198. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  199. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  200. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  201. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  202. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  203. package/dist/types/src/extensions/blast.d.ts +0 -25
  204. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  205. package/dist/types/src/extensions/command/action.d.ts +0 -17
  206. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  207. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  208. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  209. package/dist/types/src/extensions/command/command.d.ts +0 -6
  210. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  211. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  212. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  213. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  214. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  215. package/dist/types/src/extensions/command/index.d.ts +0 -7
  216. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  217. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  218. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  219. package/dist/types/src/extensions/command/state.d.ts +0 -16
  220. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  221. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  222. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  223. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  224. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  225. package/dist/types/src/extensions/comments.d.ts +0 -95
  226. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  227. package/dist/types/src/extensions/debug.d.ts +0 -3
  228. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  229. package/dist/types/src/extensions/dnd.d.ts +0 -9
  230. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  231. package/dist/types/src/extensions/factories.d.ts +0 -82
  232. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  233. package/dist/types/src/extensions/focus.d.ts +0 -7
  234. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  235. package/dist/types/src/extensions/folding.d.ts +0 -7
  236. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  237. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  238. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  239. package/dist/types/src/extensions/json.d.ts +0 -7
  240. package/dist/types/src/extensions/json.d.ts.map +0 -1
  241. package/dist/types/src/extensions/listener.d.ts +0 -11
  242. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  243. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  244. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  245. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -16
  246. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  247. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  248. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  249. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  250. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  251. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  252. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  253. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -17
  254. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  255. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  256. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  257. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  258. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  259. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  260. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  261. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  262. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  263. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  264. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  265. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  266. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  267. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  268. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  269. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  270. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  271. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  272. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  273. package/dist/types/src/extensions/mention.d.ts +0 -7
  274. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  275. package/dist/types/src/extensions/modes.d.ts +0 -10
  276. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  277. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  278. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  279. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  280. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  281. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  282. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  283. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  284. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  285. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  286. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  287. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  288. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  289. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  290. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  291. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  292. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  293. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  294. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  295. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  296. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  297. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  298. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  299. package/dist/types/src/extensions/selection.d.ts +0 -24
  300. package/dist/types/src/extensions/selection.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 +0 -7
  304. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  305. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  306. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  307. package/dist/types/src/styles/index.d.ts +0 -4
  308. package/dist/types/src/styles/index.d.ts.map +0 -1
  309. package/dist/types/src/styles/markdown.d.ts +0 -8
  310. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  311. package/dist/types/src/styles/theme.d.ts +0 -38
  312. package/dist/types/src/styles/theme.d.ts.map +0 -1
  313. package/dist/types/src/styles/tokens.d.ts +0 -3
  314. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  315. package/dist/types/src/testing/index.d.ts +0 -2
  316. package/dist/types/src/testing/index.d.ts.map +0 -1
  317. package/dist/types/src/testing/util.d.ts +0 -2
  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/dom.d.ts +0 -20
  328. package/dist/types/src/util/dom.d.ts.map +0 -1
  329. package/dist/types/src/util/facet.d.ts +0 -3
  330. package/dist/types/src/util/facet.d.ts.map +0 -1
  331. package/src/components/EditorToolbar/util.ts +0 -65
  332. package/src/components/Popover/CommandMenu.tsx +0 -279
  333. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  334. package/src/components/Popover/RefPopover.tsx +0 -99
  335. package/src/components/Popover/index.ts +0 -7
  336. package/src/defaults.ts +0 -49
  337. package/src/extensions/annotations.ts +0 -55
  338. package/src/extensions/autocomplete.ts +0 -69
  339. package/src/extensions/automerge/automerge.stories.tsx +0 -142
  340. package/src/extensions/automerge/automerge.test.tsx +0 -78
  341. package/src/extensions/automerge/automerge.ts +0 -85
  342. package/src/extensions/automerge/cursor.ts +0 -28
  343. package/src/extensions/automerge/defs.ts +0 -31
  344. package/src/extensions/automerge/index.ts +0 -5
  345. package/src/extensions/automerge/sync.ts +0 -75
  346. package/src/extensions/automerge/update-automerge.ts +0 -50
  347. package/src/extensions/automerge/update-codemirror.ts +0 -115
  348. package/src/extensions/awareness/awareness-provider.ts +0 -127
  349. package/src/extensions/awareness/awareness.ts +0 -315
  350. package/src/extensions/awareness/index.ts +0 -6
  351. package/src/extensions/blast.ts +0 -363
  352. package/src/extensions/command/action.ts +0 -56
  353. package/src/extensions/command/command-menu.ts +0 -210
  354. package/src/extensions/command/command.ts +0 -34
  355. package/src/extensions/command/floating-menu.ts +0 -133
  356. package/src/extensions/command/hint.ts +0 -102
  357. package/src/extensions/command/index.ts +0 -10
  358. package/src/extensions/command/placeholder.ts +0 -113
  359. package/src/extensions/command/state.ts +0 -89
  360. package/src/extensions/command/typeahead.ts +0 -129
  361. package/src/extensions/command/useCommandMenu.ts +0 -118
  362. package/src/extensions/comments.ts +0 -592
  363. package/src/extensions/debug.ts +0 -15
  364. package/src/extensions/dnd.ts +0 -37
  365. package/src/extensions/factories.ts +0 -259
  366. package/src/extensions/focus.ts +0 -35
  367. package/src/extensions/folding.tsx +0 -46
  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 -116
  372. package/src/extensions/markdown/bundle.ts +0 -71
  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 -591
  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 -119
  381. package/src/extensions/markdown/index.ts +0 -13
  382. package/src/extensions/markdown/link.ts +0 -47
  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 -144
  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/outliner.test.ts +0 -99
  393. package/src/extensions/outliner/outliner.ts +0 -166
  394. package/src/extensions/outliner/selection.ts +0 -50
  395. package/src/extensions/outliner/tree.test.ts +0 -167
  396. package/src/extensions/outliner/tree.ts +0 -317
  397. package/src/extensions/preview/index.ts +0 -5
  398. package/src/extensions/preview/preview.ts +0 -193
  399. package/src/extensions/selection.ts +0 -100
  400. package/src/extensions/typewriter.ts +0 -68
  401. package/src/stories/Command.stories.tsx +0 -97
  402. package/src/stories/CommandMenu.stories.tsx +0 -159
  403. package/src/styles/index.ts +0 -7
  404. package/src/styles/markdown.ts +0 -26
  405. package/src/styles/theme.ts +0 -266
  406. package/src/styles/tokens.ts +0 -17
  407. package/src/testing/index.ts +0 -5
  408. package/src/testing/util.ts +0 -5
  409. package/src/types/index.ts +0 -5
  410. package/src/types/types.ts +0 -32
  411. package/src/util/cursor.ts +0 -55
  412. package/src/util/debug.ts +0 -64
  413. package/src/util/dom.ts +0 -56
  414. package/src/util/facet.ts +0 -13
@@ -0,0 +1,226 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+ import { useControllableState } from '@radix-ui/react-use-controllable-state';
7
+ import React, { Fragment, type PropsWithChildren, useCallback, useEffect, useRef, useState } from 'react';
8
+
9
+ import { addEventListener } from '@dxos/async';
10
+ import { invariant } from '@dxos/invariant';
11
+ import {
12
+ DX_ANCHOR_ACTIVATE,
13
+ type DxAnchorActivate,
14
+ Icon,
15
+ Popover,
16
+ ScrollArea,
17
+ toLocalizedString,
18
+ useDynamicRef,
19
+ useThemeContext,
20
+ useTranslation,
21
+ } from '@dxos/react-ui';
22
+
23
+ import { type EditorMenuGroup, type EditorMenuItem } from './menu';
24
+
25
+ export type EditorMenuProviderProps = PropsWithChildren<{
26
+ view?: EditorView | null;
27
+ groups?: EditorMenuGroup[];
28
+ currentItem?: string;
29
+ open?: boolean;
30
+ defaultOpen?: boolean;
31
+ numItems?: number;
32
+ onOpenChange?: (event: { view: EditorView; open: boolean; trigger?: string }) => void;
33
+ onActivate?: (event: { view: EditorView; trigger?: string }) => void;
34
+ onSelect?: (event: { view: EditorView; item: EditorMenuItem }) => void;
35
+ onCancel?: (event: { view: EditorView }) => void;
36
+ }>;
37
+
38
+ /**
39
+ * Implements the Popover and listens for the `dx-anchor-activate` event from the `popover` extension's decoration.
40
+ * NOTE: We don't use DropdownMenu because the command menu needs to manage focus explicitly.
41
+ * I.e., focus must remain in the editor while displaying the menu (for type-ahead).
42
+ */
43
+ export const EditorMenuProvider = ({
44
+ children,
45
+ view,
46
+ groups,
47
+ currentItem,
48
+ open: openProp,
49
+ defaultOpen,
50
+ numItems = 8,
51
+ onOpenChange,
52
+ onActivate,
53
+ onSelect,
54
+ onCancel,
55
+ }: EditorMenuProviderProps) => {
56
+ const { tx } = useThemeContext();
57
+ const triggerRef = useRef<HTMLButtonElement | null>(null);
58
+
59
+ const viewRef = useDynamicRef(view);
60
+ const [open, setOpen] = useControllableState({
61
+ prop: openProp,
62
+ defaultProp: defaultOpen,
63
+ onChange: (open) => {
64
+ invariant(viewRef.current);
65
+ onOpenChange?.({ view: viewRef.current, open });
66
+ },
67
+ });
68
+
69
+ const [root, setRoot] = useState<HTMLDivElement | null>(null);
70
+ useEffect(() => {
71
+ if (!root) {
72
+ return;
73
+ }
74
+
75
+ // Listen for trigger.
76
+ return addEventListener(
77
+ root,
78
+ DX_ANCHOR_ACTIVATE as any,
79
+ (event: DxAnchorActivate) => {
80
+ const { trigger, dxn } = event;
81
+ if (!dxn) {
82
+ triggerRef.current = trigger as HTMLButtonElement;
83
+ if (onActivate) {
84
+ onActivate({ view: viewRef.current!, trigger: trigger.getAttribute('data-trigger') ?? undefined });
85
+ } else {
86
+ requestAnimationFrame(() => setOpen(true));
87
+ }
88
+ }
89
+ },
90
+ {
91
+ capture: true,
92
+ passive: false,
93
+ },
94
+ );
95
+ }, [root, onActivate]);
96
+
97
+ const handleSelect = useCallback<NonNullable<MenuProps['onSelect']>>(
98
+ (item) => {
99
+ invariant(viewRef.current);
100
+ onSelect?.({ view: viewRef.current, item });
101
+ },
102
+ [viewRef, onSelect],
103
+ );
104
+
105
+ const menuGroups = groups?.filter((group) => group.items.length > 0) ?? [];
106
+
107
+ return (
108
+ <Popover.Root modal={false} open={open} onOpenChange={setOpen}>
109
+ <Popover.VirtualTrigger virtualRef={triggerRef} />
110
+
111
+ {/* Menu. */}
112
+ <Popover.Portal>
113
+ <Popover.Content
114
+ align='start'
115
+ classNames={['flex flex-col', !menuGroups.length && 'hidden']}
116
+ style={{
117
+ maxBlockSize: 36 * numItems + 10,
118
+ }}
119
+ // NOTE: We keep the focus in the editor, but Radix routes escape key.
120
+ onEscapeKeyDown={() => {
121
+ const currentView = viewRef.current;
122
+ if (currentView) {
123
+ onCancel?.({ view: currentView });
124
+ }
125
+ }}
126
+ onOpenAutoFocus={(event) => event.preventDefault()}
127
+ >
128
+ <Popover.Viewport asChild classNames='dx-container'>
129
+ <ScrollArea.Root thin>
130
+ <ScrollArea.Viewport>
131
+ <Menu groups={menuGroups} currentItem={currentItem} onSelect={handleSelect} />
132
+ </ScrollArea.Viewport>
133
+ </ScrollArea.Root>
134
+ </Popover.Viewport>
135
+ <Popover.Arrow />
136
+ </Popover.Content>
137
+ </Popover.Portal>
138
+
139
+ {/* Content */}
140
+ <div role='none' className='contents' ref={setRoot}>
141
+ {children}
142
+ </div>
143
+ </Popover.Root>
144
+ );
145
+ };
146
+
147
+ //
148
+ // Menu
149
+ //
150
+
151
+ type MenuProps = {
152
+ groups: EditorMenuGroup[];
153
+ } & Pick<MenuGroupProps, 'currentItem' | 'onSelect'>;
154
+
155
+ const Menu = ({ groups, currentItem, onSelect }: MenuProps) => {
156
+ const { tx } = useThemeContext();
157
+ return (
158
+ <ul>
159
+ {groups.map((group, index) => (
160
+ <Fragment key={group.id}>
161
+ <MenuGroup group={group} currentItem={currentItem} onSelect={onSelect} />
162
+ {index < groups.length - 1 && <div className={tx('menu.separator', {})} />}
163
+ </Fragment>
164
+ ))}
165
+ </ul>
166
+ );
167
+ };
168
+
169
+ //
170
+ // Menu Group
171
+ //
172
+
173
+ type MenuGroupProps = {
174
+ group: EditorMenuGroup;
175
+ currentItem?: string;
176
+ } & Pick<MenuItemProps, 'onSelect'>;
177
+
178
+ const MenuGroup = ({ group, currentItem, onSelect }: MenuGroupProps) => {
179
+ const { tx } = useThemeContext();
180
+ const { t } = useTranslation();
181
+
182
+ return (
183
+ <>
184
+ {group.label && (
185
+ <div className={tx('menu.groupLabel', {})}>
186
+ <span>{toLocalizedString(group.label, t)}</span>
187
+ </div>
188
+ )}
189
+
190
+ {group.items.map((item) => (
191
+ <MenuItem key={item.id} item={item} current={currentItem === item.id} onSelect={onSelect} />
192
+ ))}
193
+ </>
194
+ );
195
+ };
196
+
197
+ //
198
+ // Menu Item
199
+ //
200
+
201
+ type MenuItemProps = {
202
+ item: EditorMenuItem;
203
+ current: boolean;
204
+ onSelect?: (item: EditorMenuItem) => void;
205
+ };
206
+
207
+ const MenuItem = ({ item, current, onSelect }: MenuItemProps) => {
208
+ const { tx } = useThemeContext();
209
+ const { t } = useTranslation();
210
+
211
+ const listRef = useRef<HTMLLIElement>(null);
212
+ useEffect(() => {
213
+ if (current && listRef.current) {
214
+ listRef.current.scrollIntoView({ behavior: 'smooth', block: 'nearest' });
215
+ }
216
+ }, [current]);
217
+
218
+ const handleSelect = useCallback(() => onSelect?.(item), [item, onSelect]);
219
+
220
+ return (
221
+ <li ref={listRef} className={tx('menu.item', {}, [current && 'bg-hover-surface'])} onClick={handleSelect}>
222
+ {item.icon && <Icon icon={item.icon} />}
223
+ <span className='grow truncate'>{toLocalizedString(item.label, t)}</span>
224
+ </li>
225
+ );
226
+ };
@@ -0,0 +1,10 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export * from './menu';
6
+ export * from './menu-presets';
7
+ export * from './popover';
8
+
9
+ export * from './EditorMenuProvider';
10
+ export * from './useEditorMenu';
@@ -0,0 +1,125 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { insertAtLineStart } from '@dxos/ui-editor';
6
+
7
+ import { type EditorMenuGroup } from './menu';
8
+ import { popoverRangeEffect } from './popover';
9
+
10
+ export const formattingCommands: EditorMenuGroup = {
11
+ id: 'markdown',
12
+ label: 'Markdown',
13
+ items: [
14
+ {
15
+ id: 'heading-1',
16
+ label: 'Heading 1',
17
+ icon: 'ph--text-h-one--regular',
18
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '# '),
19
+ },
20
+ {
21
+ id: 'heading-2',
22
+ label: 'Heading 2',
23
+ icon: 'ph--text-h-two--regular',
24
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '## '),
25
+ },
26
+ {
27
+ id: 'heading-3',
28
+ label: 'Heading 3',
29
+ icon: 'ph--text-h-three--regular',
30
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '### '),
31
+ },
32
+ {
33
+ id: 'heading-4',
34
+ label: 'Heading 4',
35
+ icon: 'ph--text-h-four--regular',
36
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '#### '),
37
+ },
38
+ {
39
+ id: 'heading-5',
40
+ label: 'Heading 5',
41
+ icon: 'ph--text-h-five--regular',
42
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '##### '),
43
+ },
44
+ {
45
+ id: 'heading-6',
46
+ label: 'Heading 6',
47
+ icon: 'ph--text-h-six--regular',
48
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '###### '),
49
+ },
50
+ {
51
+ id: 'bullet-list',
52
+ label: 'Bullet List',
53
+ icon: 'ph--list-bullets--regular',
54
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '- '),
55
+ },
56
+ {
57
+ id: 'numbered-list',
58
+ label: 'Numbered List',
59
+ icon: 'ph--list-numbers--regular',
60
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '1. '),
61
+ },
62
+ {
63
+ id: 'task-list',
64
+ label: 'Task List',
65
+ icon: 'ph--list-checks--regular',
66
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '- [ ] '),
67
+ },
68
+ {
69
+ id: 'quote',
70
+ label: 'Quote',
71
+ icon: 'ph--quotes--regular',
72
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '> '),
73
+ },
74
+ {
75
+ id: 'code-block',
76
+ label: 'Code Block',
77
+ icon: 'ph--code-block--regular',
78
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '```\n\n```'),
79
+ },
80
+ {
81
+ id: 'table',
82
+ label: 'Table',
83
+ icon: 'ph--table--regular',
84
+ onSelect: ({ view, head }) => insertAtLineStart(view, head, '| | | |\n|---|---|---|\n| | | |'),
85
+ },
86
+ ],
87
+ };
88
+
89
+ export const linkSlashCommands: EditorMenuGroup = {
90
+ id: 'link',
91
+ label: 'Link',
92
+ items: [
93
+ {
94
+ id: 'inline-link',
95
+ label: 'Inline link',
96
+ icon: 'ph--link--regular',
97
+ onSelect: ({ view, head }) => {
98
+ view.dispatch({
99
+ changes: { from: head, insert: '@' },
100
+ selection: { anchor: head + 1, head: head + 1 },
101
+ effects: popoverRangeEffect.of({
102
+ trigger: '@',
103
+ range: { from: head, to: head + 1 },
104
+ }),
105
+ });
106
+ },
107
+ },
108
+ {
109
+ id: 'block-embed',
110
+ label: 'Block embed',
111
+ icon: 'ph--lego--regular',
112
+ onSelect: ({ view, head }) => {
113
+ // Seed the same query shape as typing "@@" manually.
114
+ view.dispatch({
115
+ changes: { from: head, insert: '@@' },
116
+ selection: { anchor: head + 2, head: head + 2 },
117
+ effects: popoverRangeEffect.of({
118
+ trigger: '@',
119
+ range: { from: head, to: head + 2 },
120
+ }),
121
+ });
122
+ },
123
+ },
124
+ ],
125
+ };
@@ -0,0 +1,70 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type EditorView } from '@codemirror/view';
6
+
7
+ import { type Label } from '@dxos/react-ui';
8
+ import { insertAtCursor } from '@dxos/ui-editor';
9
+ import { type MaybePromise } from '@dxos/util';
10
+
11
+ export type EditorMenuGroup = {
12
+ id: string;
13
+ label?: Label;
14
+ items: EditorMenuItem[];
15
+ };
16
+
17
+ export type EditorMenuItem = {
18
+ id: string;
19
+ label: Label;
20
+ icon?: string;
21
+ onSelect?: (event: { view: EditorView; head: number }) => MaybePromise<void>;
22
+ };
23
+
24
+ export const getMenuItem = (groups: EditorMenuGroup[], id?: string): EditorMenuItem | undefined => {
25
+ return groups.flatMap((group) => group.items).find((item) => item.id === id);
26
+ };
27
+
28
+ export const getNextMenuItem = (groups: EditorMenuGroup[], id?: string): EditorMenuItem => {
29
+ const items = groups.flatMap((group) => group.items);
30
+ const index = items.findIndex((item) => item.id === id);
31
+ return index < items.length - 1 ? items[index + 1] : items[index];
32
+ };
33
+
34
+ export const getPreviousMenuItem = (groups: EditorMenuGroup[], id?: string): EditorMenuItem => {
35
+ const items = groups.flatMap((group) => group.items);
36
+ const index = items.findIndex((item) => item.id === id);
37
+ return index > 0 ? items[index - 1] : items[index];
38
+ };
39
+
40
+ export const createMenuGroup = ({
41
+ id = 'menu',
42
+ label,
43
+ filter,
44
+ items,
45
+ }: {
46
+ id?: string;
47
+ label?: Label;
48
+ filter?: string;
49
+ items: string[];
50
+ }): EditorMenuGroup => ({
51
+ id,
52
+ label,
53
+ items: items
54
+ .filter((item) => !filter || item.toLowerCase().includes(filter.toLowerCase()))
55
+ .map((item, i) => ({
56
+ id: `${id}-${i}`,
57
+ label: item,
58
+ onSelect: ({ view, head }) => insertAtCursor(view, head, item),
59
+ })),
60
+ });
61
+
62
+ export const filterMenuGroups = (
63
+ groups: EditorMenuGroup[],
64
+ filter: (item: EditorMenuItem) => boolean,
65
+ ): EditorMenuGroup[] => {
66
+ return groups.map((group) => ({
67
+ ...group,
68
+ items: group.items.filter(filter),
69
+ }));
70
+ };