@dxos/react-ui-editor 0.8.4-main.c4373fc → 0.8.4-main.c85a9c8dae

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 (422) hide show
  1. package/dist/lib/browser/index.mjs +1143 -8424
  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 +1143 -8423
  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 -21
  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 +25 -0
  36. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +9 -7
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +9 -7
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +9 -7
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +5 -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 +5 -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 +10 -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 +4 -8
  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} +5 -8
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -1
  62. package/dist/types/src/stories/Comments.stories.d.ts +4 -3
  63. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  64. package/dist/types/src/stories/EditorToolbar.stories.d.ts +4 -4
  65. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  66. package/dist/types/src/stories/Experimental.stories.d.ts +4 -3
  67. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  68. package/dist/types/src/stories/Markdown.stories.d.ts +4 -3
  69. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  70. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -5
  72. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  73. package/dist/types/src/stories/Preview.stories.d.ts +5 -3
  74. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  76. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -4
  77. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  78. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  79. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  80. package/dist/types/src/stories/components/EditorStory.d.ts +9 -18
  81. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  82. package/dist/types/src/stories/components/util.d.ts +3 -3
  83. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  84. package/dist/types/src/translations.d.ts +5 -5
  85. package/dist/types/src/translations.d.ts.map +1 -1
  86. package/dist/types/src/util/index.d.ts +0 -5
  87. package/dist/types/src/util/index.d.ts.map +1 -1
  88. package/dist/types/src/util/react.d.ts +6 -5
  89. package/dist/types/src/util/react.d.ts.map +1 -1
  90. package/dist/types/tsconfig.tsbuildinfo +1 -1
  91. package/package.json +68 -72
  92. package/src/components/Editor/Editor.stories.tsx +95 -0
  93. package/src/components/Editor/Editor.tsx +167 -56
  94. package/src/components/EditorContent/EditorContent.tsx +83 -0
  95. package/src/components/EditorContent/controller.ts +50 -0
  96. package/src/components/EditorContent/index.ts +6 -0
  97. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +228 -0
  98. package/src/components/EditorMenuProvider/index.ts +10 -0
  99. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  100. package/src/components/EditorMenuProvider/menu.ts +70 -0
  101. package/src/components/EditorMenuProvider/popover.ts +285 -0
  102. package/src/components/EditorMenuProvider/useEditorMenu.ts +179 -0
  103. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  104. package/src/components/EditorPreviewProvider/index.ts +5 -0
  105. package/src/components/EditorToolbar/EditorToolbar.tsx +102 -105
  106. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  107. package/src/components/EditorToolbar/blocks.ts +7 -7
  108. package/src/components/EditorToolbar/formatting.ts +7 -7
  109. package/src/components/EditorToolbar/headings.ts +20 -17
  110. package/src/components/EditorToolbar/image.ts +10 -3
  111. package/src/components/EditorToolbar/index.ts +3 -7
  112. package/src/components/EditorToolbar/search.ts +10 -3
  113. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  114. package/src/components/EditorToolbar/view-mode.ts +7 -6
  115. package/src/components/index.ts +6 -2
  116. package/src/hooks/useTextEditor.ts +33 -27
  117. package/src/index.ts +0 -10
  118. package/src/stories/Automerge.stories.tsx +174 -0
  119. package/src/stories/CommandDialog.stories.tsx +18 -26
  120. package/src/stories/Comments.stories.tsx +48 -44
  121. package/src/stories/EditorToolbar.stories.tsx +36 -21
  122. package/src/stories/Experimental.stories.tsx +6 -8
  123. package/src/stories/Markdown.stories.tsx +16 -16
  124. package/src/stories/Outliner.stories.tsx +20 -21
  125. package/src/stories/Popover.stories.tsx +158 -0
  126. package/src/stories/Preview.stories.tsx +100 -81
  127. package/src/stories/Tags.stories.tsx +36 -13
  128. package/src/stories/TextEditor.stories.tsx +16 -48
  129. package/src/stories/Theme.stories.tsx +61 -0
  130. package/src/stories/components/EditorStory.tsx +32 -25
  131. package/src/stories/components/util.tsx +60 -31
  132. package/src/translations.ts +4 -4
  133. package/src/util/index.ts +1 -6
  134. package/src/util/react.tsx +8 -13
  135. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  136. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  137. package/dist/lib/browser/testing/index.mjs +0 -76
  138. package/dist/lib/browser/testing/index.mjs.map +0 -7
  139. package/dist/lib/browser/types/index.mjs +0 -13
  140. package/dist/lib/browser/types/index.mjs.map +0 -7
  141. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
  142. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  143. package/dist/lib/node-esm/testing/index.mjs +0 -78
  144. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  145. package/dist/lib/node-esm/types/index.mjs +0 -14
  146. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  147. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts +0 -38
  148. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +0 -1
  149. package/dist/types/src/components/CommandMenu/index.d.ts +0 -2
  150. package/dist/types/src/components/CommandMenu/index.d.ts.map +0 -1
  151. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  152. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  153. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  154. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  155. package/dist/types/src/defaults.d.ts +0 -14
  156. package/dist/types/src/defaults.d.ts.map +0 -1
  157. package/dist/types/src/extensions/annotations.d.ts +0 -9
  158. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  159. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  160. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  161. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  162. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  163. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  164. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  165. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  166. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  167. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  168. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  169. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  170. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  171. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  172. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  173. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  174. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  175. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  176. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  177. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  178. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  179. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  180. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  181. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  182. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  183. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  184. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  185. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  186. package/dist/types/src/extensions/blast.d.ts +0 -25
  187. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  188. package/dist/types/src/extensions/command-dialog/action.d.ts +0 -17
  189. package/dist/types/src/extensions/command-dialog/action.d.ts.map +0 -1
  190. package/dist/types/src/extensions/command-dialog/command-dialog.d.ts +0 -6
  191. package/dist/types/src/extensions/command-dialog/command-dialog.d.ts.map +0 -1
  192. package/dist/types/src/extensions/command-dialog/hint.d.ts +0 -19
  193. package/dist/types/src/extensions/command-dialog/hint.d.ts.map +0 -1
  194. package/dist/types/src/extensions/command-dialog/index.d.ts +0 -4
  195. package/dist/types/src/extensions/command-dialog/index.d.ts.map +0 -1
  196. package/dist/types/src/extensions/command-dialog/state.d.ts +0 -16
  197. package/dist/types/src/extensions/command-dialog/state.d.ts.map +0 -1
  198. package/dist/types/src/extensions/command-dialog/typeahead.d.ts +0 -22
  199. package/dist/types/src/extensions/command-dialog/typeahead.d.ts.map +0 -1
  200. package/dist/types/src/extensions/command-menu/command-menu.d.ts +0 -20
  201. package/dist/types/src/extensions/command-menu/command-menu.d.ts.map +0 -1
  202. package/dist/types/src/extensions/command-menu/index.d.ts +0 -3
  203. package/dist/types/src/extensions/command-menu/index.d.ts.map +0 -1
  204. package/dist/types/src/extensions/command-menu/placeholder.d.ts +0 -10
  205. package/dist/types/src/extensions/command-menu/placeholder.d.ts.map +0 -1
  206. package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts +0 -24
  207. package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts.map +0 -1
  208. package/dist/types/src/extensions/comments.d.ts +0 -95
  209. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  210. package/dist/types/src/extensions/debug.d.ts +0 -3
  211. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  212. package/dist/types/src/extensions/dnd.d.ts +0 -9
  213. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  214. package/dist/types/src/extensions/factories.d.ts +0 -83
  215. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  216. package/dist/types/src/extensions/floating-menu.d.ts +0 -7
  217. package/dist/types/src/extensions/floating-menu.d.ts.map +0 -1
  218. package/dist/types/src/extensions/focus.d.ts +0 -7
  219. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  220. package/dist/types/src/extensions/folding.d.ts +0 -7
  221. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  222. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  223. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  224. package/dist/types/src/extensions/index.d.ts +0 -27
  225. package/dist/types/src/extensions/index.d.ts.map +0 -1
  226. package/dist/types/src/extensions/json.d.ts +0 -7
  227. package/dist/types/src/extensions/json.d.ts.map +0 -1
  228. package/dist/types/src/extensions/listener.d.ts +0 -11
  229. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  230. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  231. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  232. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  233. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  234. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  235. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  236. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  237. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  238. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  239. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  240. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  241. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  242. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  243. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  244. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  245. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  246. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  247. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  248. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  249. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  250. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  251. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  252. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  253. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  254. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  255. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  256. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  257. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  258. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  259. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  260. package/dist/types/src/extensions/mention.d.ts +0 -7
  261. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  262. package/dist/types/src/extensions/modes.d.ts +0 -10
  263. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  264. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  265. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  266. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  267. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  268. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  269. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  270. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  271. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  272. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  273. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  274. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  275. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  276. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  277. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  278. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  279. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  280. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  281. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  282. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  283. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  284. package/dist/types/src/extensions/preview/preview.d.ts +0 -29
  285. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  286. package/dist/types/src/extensions/selection.d.ts +0 -24
  287. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  288. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  289. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  290. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  291. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  292. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  293. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  294. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  295. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  296. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -72
  297. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  298. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  299. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  300. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  301. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  302. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  303. package/dist/types/src/styles/index.d.ts +0 -4
  304. package/dist/types/src/styles/index.d.ts.map +0 -1
  305. package/dist/types/src/styles/markdown.d.ts +0 -8
  306. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  307. package/dist/types/src/styles/theme.d.ts +0 -38
  308. package/dist/types/src/styles/theme.d.ts.map +0 -1
  309. package/dist/types/src/styles/tokens.d.ts +0 -3
  310. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  311. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  312. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  313. package/dist/types/src/testing/index.d.ts +0 -3
  314. package/dist/types/src/testing/index.d.ts.map +0 -1
  315. package/dist/types/src/testing/util.d.ts +0 -3
  316. package/dist/types/src/testing/util.d.ts.map +0 -1
  317. package/dist/types/src/types/index.d.ts +0 -2
  318. package/dist/types/src/types/index.d.ts.map +0 -1
  319. package/dist/types/src/types/types.d.ts +0 -21
  320. package/dist/types/src/types/types.d.ts.map +0 -1
  321. package/dist/types/src/util/cursor.d.ts +0 -31
  322. package/dist/types/src/util/cursor.d.ts.map +0 -1
  323. package/dist/types/src/util/debug.d.ts +0 -17
  324. package/dist/types/src/util/debug.d.ts.map +0 -1
  325. package/dist/types/src/util/decorations.d.ts +0 -4
  326. package/dist/types/src/util/decorations.d.ts.map +0 -1
  327. package/dist/types/src/util/dom.d.ts +0 -10
  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/CommandMenu/CommandMenu.tsx +0 -348
  332. package/src/components/CommandMenu/index.ts +0 -5
  333. package/src/components/EditorToolbar/util.ts +0 -76
  334. package/src/defaults.ts +0 -52
  335. package/src/extensions/annotations.ts +0 -55
  336. package/src/extensions/autocomplete.ts +0 -219
  337. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  338. package/src/extensions/automerge/automerge.test.tsx +0 -78
  339. package/src/extensions/automerge/automerge.ts +0 -86
  340. package/src/extensions/automerge/cursor.ts +0 -28
  341. package/src/extensions/automerge/defs.ts +0 -31
  342. package/src/extensions/automerge/index.ts +0 -5
  343. package/src/extensions/automerge/sync.ts +0 -75
  344. package/src/extensions/automerge/update-automerge.ts +0 -50
  345. package/src/extensions/automerge/update-codemirror.ts +0 -115
  346. package/src/extensions/autoscroll.ts +0 -157
  347. package/src/extensions/awareness/awareness-provider.ts +0 -127
  348. package/src/extensions/awareness/awareness.ts +0 -315
  349. package/src/extensions/awareness/index.ts +0 -6
  350. package/src/extensions/blast.ts +0 -363
  351. package/src/extensions/command-dialog/action.ts +0 -55
  352. package/src/extensions/command-dialog/command-dialog.ts +0 -34
  353. package/src/extensions/command-dialog/hint.ts +0 -103
  354. package/src/extensions/command-dialog/index.ts +0 -7
  355. package/src/extensions/command-dialog/state.ts +0 -90
  356. package/src/extensions/command-dialog/typeahead.ts +0 -129
  357. package/src/extensions/command-menu/command-menu.ts +0 -210
  358. package/src/extensions/command-menu/index.ts +0 -6
  359. package/src/extensions/command-menu/placeholder.ts +0 -113
  360. package/src/extensions/command-menu/useCommandMenu.ts +0 -134
  361. package/src/extensions/comments.ts +0 -597
  362. package/src/extensions/debug.ts +0 -15
  363. package/src/extensions/dnd.ts +0 -37
  364. package/src/extensions/factories.ts +0 -284
  365. package/src/extensions/floating-menu.ts +0 -126
  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/index.ts +0 -30
  370. package/src/extensions/json.ts +0 -57
  371. package/src/extensions/listener.ts +0 -38
  372. package/src/extensions/markdown/action.ts +0 -117
  373. package/src/extensions/markdown/bundle.ts +0 -93
  374. package/src/extensions/markdown/changes.test.ts +0 -26
  375. package/src/extensions/markdown/changes.ts +0 -149
  376. package/src/extensions/markdown/debug.ts +0 -44
  377. package/src/extensions/markdown/decorate.ts +0 -601
  378. package/src/extensions/markdown/formatting.test.ts +0 -498
  379. package/src/extensions/markdown/formatting.ts +0 -1267
  380. package/src/extensions/markdown/highlight.ts +0 -183
  381. package/src/extensions/markdown/image.ts +0 -118
  382. package/src/extensions/markdown/index.ts +0 -13
  383. package/src/extensions/markdown/link.ts +0 -50
  384. package/src/extensions/markdown/parser.test.ts +0 -75
  385. package/src/extensions/markdown/styles.ts +0 -135
  386. package/src/extensions/markdown/table.ts +0 -150
  387. package/src/extensions/mention.ts +0 -41
  388. package/src/extensions/modes.ts +0 -41
  389. package/src/extensions/outliner/commands.ts +0 -270
  390. package/src/extensions/outliner/editor.test.ts +0 -33
  391. package/src/extensions/outliner/editor.ts +0 -184
  392. package/src/extensions/outliner/index.ts +0 -7
  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/preview/index.ts +0 -5
  399. package/src/extensions/preview/preview.ts +0 -190
  400. package/src/extensions/selection.ts +0 -100
  401. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  402. package/src/extensions/tags/extended-markdown.ts +0 -78
  403. package/src/extensions/tags/index.ts +0 -7
  404. package/src/extensions/tags/streamer.ts +0 -243
  405. package/src/extensions/tags/xml-tags.ts +0 -393
  406. package/src/extensions/tags/xml-util.ts +0 -94
  407. package/src/extensions/typewriter.ts +0 -68
  408. package/src/stories/CommandMenu.stories.tsx +0 -158
  409. package/src/styles/index.ts +0 -7
  410. package/src/styles/markdown.ts +0 -26
  411. package/src/styles/theme.ts +0 -268
  412. package/src/styles/tokens.ts +0 -17
  413. package/src/testing/PreviewPopover.tsx +0 -78
  414. package/src/testing/index.ts +0 -6
  415. package/src/testing/util.ts +0 -7
  416. package/src/types/index.ts +0 -5
  417. package/src/types/types.ts +0 -32
  418. package/src/util/cursor.ts +0 -56
  419. package/src/util/debug.ts +0 -64
  420. package/src/util/decorations.ts +0 -21
  421. package/src/util/dom.ts +0 -34
  422. package/src/util/facet.ts +0 -13
@@ -1,55 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { StateEffect } from '@codemirror/state';
6
- import { type Command, type EditorView, type KeyBinding } from '@codemirror/view';
7
-
8
- import { commandState } from './state';
9
-
10
- export type Action =
11
- | {
12
- type: 'insert';
13
- text: string;
14
- }
15
- | {
16
- type: 'cancel';
17
- };
18
-
19
- export type ActionHandler = (action: Action) => void;
20
-
21
- export const openEffect = StateEffect.define<{ pos: number; fullWidth?: boolean }>();
22
- export const closeEffect = StateEffect.define<null>();
23
-
24
- export const openCommand: Command = (view: EditorView) => {
25
- if (view.state.field(commandState, false)) {
26
- const selection = view.state.selection.main;
27
- const line = view.state.doc.lineAt(selection.from);
28
- if (line.from === selection.from && line.from === line.to) {
29
- view.dispatch({ effects: openEffect.of({ pos: selection.anchor, fullWidth: true }) });
30
- return true;
31
- }
32
- }
33
-
34
- return false;
35
- };
36
-
37
- export const closeCommand: Command = (view: EditorView) => {
38
- if (view.state.field(commandState, false)) {
39
- view.dispatch({ effects: closeEffect.of(null) });
40
- return true;
41
- }
42
-
43
- return false;
44
- };
45
-
46
- export const commandKeyBindings: readonly KeyBinding[] = [
47
- {
48
- key: '?',
49
- run: openCommand,
50
- },
51
- {
52
- key: 'Escape',
53
- run: closeCommand,
54
- },
55
- ];
@@ -1,34 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type Extension, Prec } from '@codemirror/state';
6
- import { EditorView, keymap } from '@codemirror/view';
7
-
8
- import { isNonNullable } from '@dxos/util';
9
-
10
- import { closeEffect, commandKeyBindings } from './action';
11
- import { type HintOptions, hint } from './hint';
12
- import { type PopupOptions, commandConfig, commandState } from './state';
13
-
14
- // TODO(burdon): Create knowledge base for CM notes and ideas.
15
- // https://discuss.codemirror.net/t/inline-code-hints-like-vscode/5533/4
16
- // https://github.com/saminzadeh/codemirror-extension-inline-suggestion
17
- // https://github.com/ChromeDevTools/devtools-frontend/blob/main/front_end/ui/components/text_editor/config.ts#L370
18
-
19
- export type CommandOptions = Partial<PopupOptions & HintOptions>;
20
-
21
- export const commandDialog = (options: CommandOptions = {}): Extension => {
22
- return [
23
- Prec.highest(keymap.of(commandKeyBindings)),
24
- commandConfig.of(options),
25
- commandState,
26
- options.onHint && hint(options),
27
- EditorView.focusChangeEffect.of((_, focusing) => (focusing ? closeEffect.of(null) : null)),
28
- EditorView.theme({
29
- '.cm-tooltip': {
30
- background: 'transparent',
31
- },
32
- }),
33
- ].filter(isNonNullable);
34
- };
@@ -1,103 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- // Based on https://github.com/codemirror/view/blob/main/src/placeholder.ts
4
- //
5
-
6
- import { RangeSetBuilder } from '@codemirror/state';
7
- import { Decoration, EditorView, ViewPlugin, type ViewUpdate, WidgetType } from '@codemirror/view';
8
-
9
- import { clientRectsFor, flattenRect } from '../../util';
10
-
11
- import { commandState } from './state';
12
-
13
- export type HintOptions = {
14
- delay?: number;
15
- onHint?: () => string | undefined;
16
- };
17
-
18
- export const hint = ({ delay = 3_000, onHint }: HintOptions) => {
19
- return ViewPlugin.fromClass(
20
- class {
21
- decorations = Decoration.none;
22
- timeout: ReturnType<typeof setTimeout> | undefined;
23
-
24
- update(update: ViewUpdate) {
25
- if (this.timeout) {
26
- clearTimeout(this.timeout);
27
- this.timeout = undefined;
28
- }
29
-
30
- const builder = new RangeSetBuilder<Decoration>();
31
- const cState = update.view.state.field(commandState, false);
32
- if (!cState?.tooltip) {
33
- const selection = update.view.state.selection.main;
34
- const line = update.view.state.doc.lineAt(selection.from);
35
- // Only show if blank line.
36
- if (selection.from === selection.to && line.from === line.to) {
37
- // Set timeout to add decoration after delay.
38
- this.timeout = setTimeout(() => {
39
- const hint = onHint?.();
40
- if (hint) {
41
- const builder = new RangeSetBuilder<Decoration>();
42
- builder.add(selection.from, selection.to, Decoration.widget({ widget: new Hint(hint) }));
43
- this.decorations = builder.finish();
44
- update.view.update([]);
45
- }
46
- }, delay);
47
- }
48
- }
49
-
50
- this.decorations = builder.finish();
51
- }
52
-
53
- destroy() {
54
- if (this.timeout) {
55
- clearTimeout(this.timeout);
56
- }
57
- }
58
- },
59
- {
60
- provide: (plugin) => [EditorView.decorations.of((view) => view.plugin(plugin)?.decorations ?? Decoration.none)],
61
- },
62
- );
63
- };
64
-
65
- export class Hint extends WidgetType {
66
- constructor(readonly content: string | HTMLElement) {
67
- super();
68
- }
69
-
70
- toDOM(): HTMLSpanElement {
71
- const wrap = document.createElement('span');
72
- wrap.className = 'cm-placeholder';
73
- wrap.style.pointerEvents = 'none';
74
- wrap.appendChild(typeof this.content === 'string' ? document.createTextNode(this.content) : this.content);
75
- if (typeof this.content === 'string') {
76
- wrap.setAttribute('aria-label', 'placeholder ' + this.content);
77
- } else {
78
- wrap.setAttribute('aria-hidden', 'true');
79
- }
80
-
81
- return wrap;
82
- }
83
-
84
- override coordsAt(dom: HTMLElement) {
85
- const rects = dom.firstChild ? clientRectsFor(dom.firstChild) : [];
86
- if (!rects.length) {
87
- return null;
88
- }
89
-
90
- const style = window.getComputedStyle(dom.parentNode as HTMLElement);
91
- const rect = flattenRect(rects[0], style.direction !== 'rtl');
92
- const lineHeight = parseInt(style.lineHeight);
93
- if (rect.bottom - rect.top > lineHeight * 1.5) {
94
- return { left: rect.left, right: rect.right, top: rect.top, bottom: rect.top + lineHeight };
95
- }
96
-
97
- return rect;
98
- }
99
-
100
- override ignoreEvent(): boolean {
101
- return false;
102
- }
103
- }
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- export * from './command-dialog';
6
- export { type Action } from './action';
7
- export * from './typeahead';
@@ -1,90 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { StateField } from '@codemirror/state';
6
- import { type EditorView, type Tooltip, type TooltipView, showTooltip } from '@codemirror/view';
7
-
8
- import { type RenderCallback } from '../../types';
9
- import { singleValueFacet } from '../../util';
10
-
11
- import { type Action, closeEffect, openEffect } from './action';
12
- import { type CommandOptions } from './command-dialog';
13
-
14
- export const commandConfig = singleValueFacet<CommandOptions>();
15
-
16
- export type PopupOptions = {
17
- renderDialog: RenderCallback<{ onAction: (action?: Action) => void }>;
18
- };
19
-
20
- type CommandState = {
21
- tooltip?: Tooltip;
22
- };
23
-
24
- export const commandState = StateField.define<CommandState>({
25
- create: () => ({}),
26
- update: (state, tr) => {
27
- for (const effect of tr.effects) {
28
- if (effect.is(closeEffect)) {
29
- return {};
30
- }
31
-
32
- const { renderDialog } = tr.state.facet(commandConfig);
33
- if (effect.is(openEffect) && renderDialog) {
34
- const { pos, fullWidth } = effect.value;
35
- const tooltip: Tooltip = {
36
- pos,
37
- above: false,
38
- arrow: false,
39
- strictSide: true,
40
- create: (view: EditorView) => {
41
- const root = document.createElement('div');
42
- const tooltipView: TooltipView = {
43
- dom: root,
44
- mount: (view: EditorView) => {
45
- if (fullWidth) {
46
- const parent = root.parentElement!;
47
- const { paddingLeft, paddingRight } = window.getComputedStyle(parent);
48
- const widthWithoutPadding = parent.clientWidth - parseFloat(paddingLeft) - parseFloat(paddingRight);
49
- root.style.width = `${widthWithoutPadding}px`;
50
- }
51
-
52
- // Render react component.
53
- renderDialog(
54
- root,
55
- {
56
- onAction: (action) => {
57
- view.dispatch({ effects: closeEffect.of(null) });
58
- switch (action?.type) {
59
- case 'insert': {
60
- // Insert into editor.
61
- const text = action.text + '\n';
62
- view.dispatch({
63
- changes: { from: pos, insert: text },
64
- selection: { anchor: pos + text.length },
65
- });
66
- break;
67
- }
68
- }
69
-
70
- // NOTE: Truncates text if set focus immediately.
71
- requestAnimationFrame(() => view.focus());
72
- },
73
- },
74
- view,
75
- );
76
- },
77
- };
78
-
79
- return tooltipView;
80
- },
81
- };
82
-
83
- return { tooltip };
84
- }
85
- }
86
-
87
- return state;
88
- },
89
- provide: (field) => [showTooltip.from(field, (value) => value.tooltip ?? null)],
90
- });
@@ -1,129 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { EditorSelection, type Extension, Prec, RangeSetBuilder } from '@codemirror/state';
6
- import {
7
- type Command,
8
- Decoration,
9
- type DecorationSet,
10
- type EditorView,
11
- ViewPlugin,
12
- type ViewUpdate,
13
- keymap,
14
- } from '@codemirror/view';
15
-
16
- import { Hint } from './hint';
17
-
18
- export type TypeaheadContext = { line: string };
19
-
20
- // TODO(burdon): Option to complete only at end of line?
21
- export type TypeaheadOptions = {
22
- onComplete?: (context: TypeaheadContext) => string | undefined;
23
- };
24
-
25
- /**
26
- * CodeMirror extension for typeahead completion.
27
- */
28
- export const typeahead = ({ onComplete }: TypeaheadOptions = {}): Extension => {
29
- let hint: string | undefined;
30
-
31
- const complete: Command = (view: EditorView) => {
32
- if (!hint) {
33
- return false;
34
- }
35
-
36
- const selection = view.state.selection.main;
37
- view.dispatch({
38
- changes: [{ from: selection.from, to: selection.to, insert: hint }],
39
- selection: EditorSelection.cursor(selection.from + hint.length),
40
- });
41
-
42
- return true;
43
- };
44
-
45
- return [
46
- ViewPlugin.fromClass(
47
- class {
48
- decorations: DecorationSet = Decoration.none;
49
- update(update: ViewUpdate) {
50
- const builder = new RangeSetBuilder<Decoration>();
51
- const selection = update.view.state.selection.main;
52
- const line = update.view.state.doc.lineAt(selection.from);
53
-
54
- // TODO(burdon): Check at end of line and matches start of previous word.
55
- // TODO(burdon): Context grammar.
56
- if (selection.from === selection.to && selection.from === line.to) {
57
- const str = update.state.sliceDoc(line.from, selection.from);
58
- hint = onComplete?.({ line: str });
59
- if (hint) {
60
- builder.add(selection.from, selection.to, Decoration.widget({ widget: new Hint(hint) }));
61
- }
62
- }
63
-
64
- this.decorations = builder.finish();
65
- }
66
- },
67
- {
68
- decorations: (v) => v.decorations,
69
- },
70
- ),
71
-
72
- // Keys.
73
- Prec.highest(
74
- keymap.of([
75
- {
76
- key: 'Tab',
77
- preventDefault: true,
78
- run: complete,
79
- },
80
- {
81
- key: 'ArrowRight',
82
- preventDefault: true,
83
- run: complete,
84
- },
85
- ]),
86
- ),
87
- ];
88
- };
89
-
90
- type CompletionOptions = {
91
- default?: string;
92
- minLength?: number;
93
- };
94
-
95
- /**
96
- * Util to match current line to a static list of completions.
97
- */
98
- export const staticCompletion =
99
- (completions: string[], options: CompletionOptions = {}) =>
100
- ({ line }: TypeaheadContext) => {
101
- if (line.length === 0 && options.default) {
102
- return options.default;
103
- }
104
-
105
- const parts = line.split(/\s+/).filter(Boolean);
106
- if (parts.length) {
107
- const str = parts.at(-1)!;
108
- if (str.length >= (options.minLength ?? 0)) {
109
- for (const completion of completions) {
110
- const match = matchCompletion(completion, str);
111
- if (match) {
112
- return match;
113
- }
114
- }
115
- }
116
- }
117
- };
118
-
119
- export const matchCompletion = (completion: string, str: string, minLength = 0): string | undefined => {
120
- if (
121
- str.length >= minLength &&
122
- completion.length > str.length &&
123
- completion.startsWith(str)
124
- // TODO(burdon): If case insensitive, need to replace existing chars.
125
- // completion.toLowerCase().startsWith(str.toLowerCase())
126
- ) {
127
- return completion.slice(str.length);
128
- }
129
- };
@@ -1,210 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type Extension, Prec, RangeSetBuilder, StateEffect, StateField } from '@codemirror/state';
6
- import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate, keymap } from '@codemirror/view';
7
-
8
- import { type Range } from '../../types';
9
-
10
- import { type PlaceholderOptions, placeholder } from './placeholder';
11
-
12
- export type CommandMenuOptions = {
13
- trigger: string | string[];
14
- placeholder?: Partial<PlaceholderOptions>;
15
-
16
- // TODO(burdon): Replace with onKey?
17
- onClose?: () => void;
18
- onArrowDown?: () => void;
19
- onArrowUp?: () => void;
20
- onEnter?: () => void;
21
-
22
- onTextChange?: (trigger: string, text: string) => void;
23
- };
24
-
25
- export const commandMenu = (options: CommandMenuOptions): Extension => {
26
- const commandMenuPlugin = ViewPlugin.fromClass(
27
- class {
28
- decorations: DecorationSet = Decoration.none;
29
-
30
- constructor(readonly view: EditorView) {}
31
-
32
- // TODO(wittjosiah): The decorations are repainted on every update, this occasionally causes menu to flicker.
33
- update(update: ViewUpdate) {
34
- const builder = new RangeSetBuilder<Decoration>();
35
- const selection = update.view.state.selection.main;
36
- const { range: activeRange, trigger } = update.view.state.field(commandMenuState) ?? {};
37
-
38
- // Check if we should show the widget - only if cursor is within the active command range.
39
- const shouldShowWidget = activeRange && selection.head >= activeRange.from && selection.head <= activeRange.to;
40
- if (shouldShowWidget) {
41
- // Create mark decoration that wraps the entire line content in a dx-anchor.
42
- builder.add(
43
- activeRange.from,
44
- activeRange.to,
45
- Decoration.mark({
46
- tagName: 'dx-anchor',
47
- class: 'cm-floating-menu-trigger',
48
- attributes: {
49
- 'data-visible-focus': 'false',
50
- 'data-auto-trigger': 'true',
51
- 'data-trigger': trigger!,
52
- },
53
- }),
54
- );
55
- }
56
-
57
- const activeRangeChanged = update.transactions.some((tr) =>
58
- tr.effects.some((effect) => effect.is(commandRangeEffect)),
59
- );
60
- if (activeRange && activeRangeChanged && trigger) {
61
- const content = update.view.state.sliceDoc(
62
- activeRange.from + 1, // Skip the trigger character.
63
- activeRange.to,
64
- );
65
- options.onTextChange?.(trigger, content);
66
- }
67
-
68
- this.decorations = builder.finish();
69
- }
70
- },
71
- {
72
- decorations: (v) => v.decorations,
73
- },
74
- );
75
-
76
- const triggers = Array.isArray(options.trigger) ? options.trigger : [options.trigger];
77
-
78
- const commandKeymap = keymap.of([
79
- ...triggers.map((trigger) => ({
80
- key: trigger,
81
- run: (view: EditorView) => {
82
- const selection = view.state.selection.main;
83
- const line = view.state.doc.lineAt(selection.head);
84
- // Check if we should trigger the command menu:
85
- // 1. Empty lines or at the beginning of a line
86
- // 2. When there's a preceding space
87
- if (
88
- line.text.trim() === '' ||
89
- selection.head === line.from ||
90
- (selection.head > line.from && line.text[selection.head - line.from - 1] === ' ')
91
- ) {
92
- // Insert and select the trigger.
93
- view.dispatch({
94
- changes: { from: selection.head, insert: trigger },
95
- selection: { anchor: selection.head + 1, head: selection.head + 1 },
96
- effects: commandRangeEffect.of({ trigger, range: { from: selection.head, to: selection.head + 1 } }),
97
- });
98
-
99
- return true;
100
- }
101
-
102
- return false;
103
- },
104
- })),
105
- {
106
- key: 'Enter',
107
- run: (view) => {
108
- const activeRange = view.state.field(commandMenuState)?.range;
109
- if (activeRange) {
110
- view.dispatch({ changes: { from: activeRange.from, to: activeRange.to, insert: '' } });
111
- options.onEnter?.();
112
- return true;
113
- }
114
-
115
- return false;
116
- },
117
- },
118
- {
119
- key: 'ArrowDown',
120
- run: (view) => {
121
- const activeRange = view.state.field(commandMenuState)?.range;
122
- if (activeRange) {
123
- options.onArrowDown?.();
124
- return true;
125
- }
126
-
127
- return false;
128
- },
129
- },
130
- {
131
- key: 'ArrowUp',
132
- run: (view) => {
133
- const activeRange = view.state.field(commandMenuState)?.range;
134
- if (activeRange) {
135
- options.onArrowUp?.();
136
- return true;
137
- }
138
-
139
- return false;
140
- },
141
- },
142
- ]);
143
-
144
- // Listen for selection and document changes to clean up the command menu.
145
- const updateListener = EditorView.updateListener.of((update) => {
146
- const { trigger, range: activeRange } = update.view.state.field(commandMenuState) ?? {};
147
- if (!activeRange || !trigger) {
148
- return;
149
- }
150
-
151
- const selection = update.view.state.selection.main;
152
- const firstChar = update.view.state.doc.sliceString(activeRange.from, activeRange.from + 1);
153
- const shouldRemove =
154
- firstChar !== trigger || // Trigger deleted.
155
- selection.head < activeRange.from || // Cursor moved before the range.
156
- selection.head > activeRange.to + 1; // Cursor moved after the range (+1 to handle selection changing before doc).
157
-
158
- const nextRange = shouldRemove
159
- ? null
160
- : update.docChanged
161
- ? { from: activeRange.from, to: selection.head }
162
- : activeRange;
163
- if (nextRange !== activeRange) {
164
- update.view.dispatch({ effects: commandRangeEffect.of(nextRange ? { trigger, range: nextRange } : null) });
165
- }
166
-
167
- // TODO(burdon): Should delete if user presses escape? How else to insert the trigger character?
168
- if (shouldRemove) {
169
- options.onClose?.();
170
- }
171
- });
172
-
173
- return [
174
- Prec.highest(commandKeymap),
175
- placeholder(
176
- Object.assign(
177
- {
178
- content: `Press '${Array.isArray(options.trigger) ? options.trigger[0] : options.trigger}' for commands`,
179
- },
180
- options.placeholder,
181
- ),
182
- ),
183
- updateListener,
184
- commandMenuState,
185
- commandMenuPlugin,
186
- ];
187
- };
188
-
189
- type CommandState = {
190
- trigger: string;
191
- range: Range;
192
- };
193
-
194
- // State effects for managing command menu state.
195
- export const commandRangeEffect = StateEffect.define<CommandState | null>();
196
-
197
- // State field to track the active command menu range.
198
- const commandMenuState = StateField.define<CommandState | null>({
199
- create: () => null,
200
- update: (value, tr) => {
201
- let newValue = value;
202
- for (const effect of tr.effects) {
203
- if (effect.is(commandRangeEffect)) {
204
- newValue = effect.value;
205
- }
206
- }
207
-
208
- return newValue;
209
- },
210
- });
@@ -1,6 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export * from './command-menu';
6
- export * from './useCommandMenu';