@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
@@ -1,247 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { closeBrackets, closeBracketsKeymap } from '@codemirror/autocomplete';
6
- import { defaultKeymap, history, historyKeymap, indentWithTab, standardKeymap } from '@codemirror/commands';
7
- import { bracketMatching, defaultHighlightStyle, syntaxHighlighting } from '@codemirror/language';
8
- import { searchKeymap } from '@codemirror/search';
9
- import { EditorState, type Extension } from '@codemirror/state';
10
- import { oneDarkHighlightStyle } from '@codemirror/theme-one-dark';
11
- import {
12
- EditorView,
13
- type KeyBinding,
14
- ViewPlugin,
15
- drawSelection,
16
- dropCursor,
17
- highlightActiveLine,
18
- keymap,
19
- lineNumbers,
20
- placeholder,
21
- scrollPastEnd,
22
- } from '@codemirror/view';
23
- import defaultsDeep from 'lodash.defaultsdeep';
24
- import merge from 'lodash.merge';
25
-
26
- import { generateName } from '@dxos/display-name';
27
- import { log } from '@dxos/log';
28
- import { type DocAccessor, type Space } from '@dxos/react-client/echo';
29
- import { type Identity } from '@dxos/react-client/halo';
30
- import { type ThemeMode } from '@dxos/react-ui';
31
- import { type HuePalette } from '@dxos/react-ui-theme';
32
- import { hexToHue, isNotFalsy } from '@dxos/util';
33
-
34
- import { editorGutter, editorMonospace } from '../defaults';
35
- import { type ThemeStyles, defaultTheme } from '../styles';
36
-
37
- import { automerge } from './automerge';
38
- import { SpaceAwarenessProvider, awareness } from './awareness';
39
- import { focus } from './focus';
40
-
41
- //
42
- // Basic
43
- //
44
-
45
- export const preventNewline = EditorState.transactionFilter.of((tr) => (tr.newDoc.lines > 1 ? [] : tr));
46
-
47
- /**
48
- * https://codemirror.net/docs/extensions
49
- * https://github.com/codemirror/basic-setup
50
- * https://github.com/codemirror/basic-setup/blob/main/src/codemirror.ts
51
- * https://github.com/codemirror/theme-one-dark
52
- */
53
- export type BasicExtensionsOptions = {
54
- allowMultipleSelections?: boolean;
55
- bracketMatching?: boolean;
56
- closeBrackets?: boolean;
57
- dropCursor?: boolean;
58
- drawSelection?: boolean;
59
- editable?: boolean;
60
- focus?: boolean;
61
- highlightActiveLine?: boolean;
62
- history?: boolean;
63
- indentWithTab?: boolean;
64
- keymap?: null | 'default' | 'standard';
65
- lineNumbers?: boolean;
66
- /** If false then do not set a max-width or side margin on the editor. */
67
- lineWrapping?: boolean;
68
- monospace?: boolean;
69
- placeholder?: string;
70
- /** If true user cannot edit the text, but they can still select and copy it. */
71
- readOnly?: boolean;
72
- search?: boolean;
73
- scrollPastEnd?: boolean;
74
- standardKeymap?: boolean;
75
- tabSize?: number;
76
- };
77
-
78
- const defaultBasicOptions: BasicExtensionsOptions = {
79
- allowMultipleSelections: true,
80
- bracketMatching: true,
81
- closeBrackets: true,
82
- drawSelection: true,
83
- focus: true,
84
- history: true,
85
- keymap: 'standard',
86
- lineWrapping: true,
87
- search: false,
88
- } as const;
89
-
90
- const keymaps: { [key: string]: readonly KeyBinding[] } = {
91
- // https://codemirror.net/docs/ref/#commands.standardKeymap
92
- standard: standardKeymap,
93
- // https://codemirror.net/docs/ref/#commands.defaultKeymap
94
- default: defaultKeymap,
95
- };
96
-
97
- export const createBasicExtensions = (_props?: BasicExtensionsOptions): Extension => {
98
- const props = defaultsDeep({}, _props, defaultBasicOptions);
99
- return [
100
- // NOTE: Doesn't catch errors in keymap functions.
101
- EditorView.exceptionSink.of((err) => {
102
- log.catch(err);
103
- }),
104
-
105
- props.allowMultipleSelections && EditorState.allowMultipleSelections.of(true),
106
- props.bracketMatching && bracketMatching(),
107
- props.closeBrackets && closeBrackets(),
108
- props.dropCursor && dropCursor(),
109
- props.drawSelection && drawSelection({ cursorBlinkRate: 1_200 }),
110
- props.editable !== undefined && EditorView.editable.of(props.editable),
111
- props.focus && focus,
112
- props.highlightActiveLine && highlightActiveLine(),
113
- props.history && history(),
114
- props.lineNumbers && [lineNumbers(), editorGutter],
115
- props.lineWrapping && EditorView.lineWrapping,
116
- props.monospace && editorMonospace,
117
- props.placeholder && placeholder(props.placeholder),
118
- props.readOnly !== undefined && EditorState.readOnly.of(props.readOnly),
119
- props.scrollPastEnd && scrollPastEnd(),
120
- props.tabSize && EditorState.tabSize.of(props.tabSize),
121
-
122
- // https://codemirror.net/docs/ref/#view.KeyBinding
123
- keymap.of(
124
- [
125
- ...((props.keymap && keymaps[props.keymap]) ?? []),
126
- // NOTE: Tabs are also configured by markdown extension.
127
- // https://codemirror.net/docs/ref/#commands.indentWithTab
128
- ...(props.indentWithTab ? [indentWithTab] : []),
129
- // https://codemirror.net/docs/ref/#autocomplete.closeBracketsKeymap
130
- ...(props.closeBrackets ? closeBracketsKeymap : []),
131
- // https://codemirror.net/docs/ref/#commands.historyKeymap
132
- ...(props.history ? historyKeymap : []),
133
- // https://codemirror.net/docs/ref/#search.searchKeymap
134
- ...(props.search ? searchKeymap : []),
135
- // Disable bindings that conflict with system shortcuts.
136
- // TODO(burdon): Catalog global shortcuts.
137
- {
138
- key: 'Mod-Shift-k',
139
- preventDefault: true,
140
- run: () => true,
141
- },
142
- ].filter(isNotFalsy),
143
- ),
144
- ].filter(isNotFalsy);
145
- };
146
-
147
- //
148
- // Theme
149
- //
150
-
151
- export type ThemeExtensionsOptions = {
152
- themeMode?: ThemeMode;
153
- styles?: ThemeStyles;
154
- syntaxHighlighting?: boolean;
155
- slots?: {
156
- editor?: {
157
- className?: string;
158
- };
159
- scroll?: {
160
- className?: string;
161
- };
162
- content?: {
163
- className?: string;
164
- };
165
- };
166
- };
167
-
168
- export const grow: ThemeExtensionsOptions['slots'] = {
169
- editor: {
170
- className: 'is-full bs-full',
171
- },
172
- } as const;
173
-
174
- export const fullWidth: ThemeExtensionsOptions['slots'] = {
175
- editor: {
176
- className: 'is-full',
177
- },
178
- } as const;
179
-
180
- export const defaultThemeSlots = grow;
181
-
182
- /**
183
- * https://codemirror.net/examples/styling
184
- */
185
- export const createThemeExtensions = ({
186
- themeMode,
187
- styles,
188
- syntaxHighlighting: syntaxHighlightingProps,
189
- slots: _slots,
190
- }: ThemeExtensionsOptions = {}): Extension => {
191
- const slots = defaultsDeep({}, _slots, defaultThemeSlots);
192
- return [
193
- EditorView.darkTheme.of(themeMode === 'dark'),
194
- EditorView.baseTheme(styles ? merge({}, defaultTheme, styles) : defaultTheme),
195
- syntaxHighlightingProps && syntaxHighlighting(themeMode === 'dark' ? oneDarkHighlightStyle : defaultHighlightStyle),
196
- slots.editor?.className && EditorView.editorAttributes.of({ class: slots.editor.className }),
197
- slots.content?.className && EditorView.contentAttributes.of({ class: slots.content.className }),
198
- slots.scroll?.className &&
199
- ViewPlugin.fromClass(
200
- class {
201
- constructor(view: EditorView) {
202
- view.scrollDOM.classList.add(...slots.scroll.className.split(/\s+/));
203
- }
204
- },
205
- ),
206
- ].filter(isNotFalsy);
207
- };
208
-
209
- //
210
- // Data
211
- //
212
-
213
- export type DataExtensionsProps<T> = {
214
- id: string;
215
- text?: DocAccessor<T>;
216
- space?: Space;
217
- identity?: Identity | null;
218
- };
219
-
220
- // TODO(burdon): Move out of react-ui-editor (remove echo deps).
221
- export const createDataExtensions = <T>({ id, text, space, identity }: DataExtensionsProps<T>): Extension[] => {
222
- const extensions: Extension[] = [];
223
- if (text) {
224
- extensions.push(automerge(text));
225
- }
226
-
227
- if (space && identity) {
228
- const peerId = identity?.identityKey.toHex();
229
- const hue = (identity?.profile?.data?.hue as HuePalette | undefined) ?? hexToHue(peerId ?? '0');
230
- extensions.push(
231
- awareness(
232
- new SpaceAwarenessProvider({
233
- space,
234
- channel: `awareness.${id}`,
235
- peerId: identity.identityKey.toHex(),
236
- info: {
237
- darkColor: `var(--dx-${hue}Cursor)`,
238
- lightColor: `var(--dx-${hue}Cursor)`,
239
- displayName: identity.profile?.displayName ?? generateName(identity.identityKey.toHex()),
240
- },
241
- }),
242
- ),
243
- );
244
- }
245
-
246
- return extensions;
247
- };
@@ -1,35 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { StateEffect, StateField } from '@codemirror/state';
6
- import { EditorView } from '@codemirror/view';
7
-
8
- const focusEffect = StateEffect.define<boolean>();
9
-
10
- export const focusField = StateField.define<boolean>({
11
- create: () => false,
12
- update: (value, tr) => {
13
- for (const effect of tr.effects) {
14
- if (effect.is(focusEffect)) {
15
- return effect.value;
16
- }
17
- }
18
- return value;
19
- },
20
- });
21
-
22
- /**
23
- * Manage focus.
24
- */
25
- export const focus = [
26
- focusField,
27
- EditorView.domEventHandlers({
28
- focus: (event, view) => {
29
- setTimeout(() => view.dispatch({ effects: focusEffect.of(true) }));
30
- },
31
- blur: (event, view) => {
32
- setTimeout(() => view.dispatch({ effects: focusEffect.of(false) }));
33
- },
34
- }),
35
- ];
@@ -1,46 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { codeFolding, foldGutter } from '@codemirror/language';
6
- import { type Extension } from '@codemirror/state';
7
- import { EditorView } from '@codemirror/view';
8
- import React from 'react';
9
-
10
- import { Icon } from '@dxos/react-ui';
11
-
12
- import { Domino, renderRoot } from '../util';
13
-
14
- export type FoldingOptions = {};
15
-
16
- /**
17
- * https://codemirror.net/examples/gutter
18
- */
19
- // TODO(burdon): Remember folding state (to state).
20
- export const folding = (_props: FoldingOptions = {}): Extension => [
21
- codeFolding({
22
- placeholderDOM: () => {
23
- return document.createElement('span'); // Collapse content.
24
- },
25
- }),
26
- foldGutter({
27
- markerDOM: (open) => {
28
- // TODO(burdon): Use sprite directly.
29
- const el = Domino.of('div').classNames('flex h-full items-center').build();
30
- return renderRoot(
31
- el,
32
- <Icon icon='ph--caret-right--bold' size={3} classNames={['mx-3 cursor-pointer', open && 'rotate-90']} />,
33
- );
34
- },
35
- }),
36
- EditorView.theme({
37
- '.cm-foldGutter': {
38
- opacity: 0.3,
39
- transition: 'opacity 0.3s',
40
- width: '32px',
41
- },
42
- '.cm-foldGutter:hover': {
43
- opacity: 1,
44
- },
45
- }),
46
- ];
@@ -1,68 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type Extension } from '@codemirror/state';
6
- import {
7
- Decoration,
8
- type DecorationSet,
9
- EditorView,
10
- MatchDecorator,
11
- ViewPlugin,
12
- type ViewUpdate,
13
- WidgetType,
14
- } from '@codemirror/view';
15
-
16
- import { getHashColor, mx } from '@dxos/react-ui-theme';
17
-
18
- class TagWidget extends WidgetType {
19
- constructor(private _text: string) {
20
- super();
21
- }
22
-
23
- toDOM(): HTMLSpanElement {
24
- const span = document.createElement('span');
25
- span.className = mx('cm-tag', getHashColor(this._text).tag);
26
- span.textContent = this._text;
27
- return span;
28
- }
29
- }
30
-
31
- const tagMatcher = new MatchDecorator({
32
- regexp: /#(\w+)\W/g,
33
- decoration: (match) =>
34
- Decoration.replace({
35
- widget: new TagWidget(match[1]),
36
- }),
37
- });
38
-
39
- // TODO(burdon): Autocomplete from existing tags?
40
- export const hashtag = (): Extension => [
41
- ViewPlugin.fromClass(
42
- class {
43
- tags: DecorationSet;
44
- constructor(view: EditorView) {
45
- this.tags = tagMatcher.createDeco(view);
46
- }
47
-
48
- update(update: ViewUpdate) {
49
- this.tags = tagMatcher.updateDeco(update, this.tags);
50
- }
51
- },
52
- {
53
- decorations: (instance) => instance.tags,
54
- provide: (plugin) =>
55
- EditorView.atomicRanges.of((view) => {
56
- return view.plugin(plugin)?.tags || Decoration.none;
57
- }),
58
- },
59
- ),
60
-
61
- EditorView.theme({
62
- '.cm-tag': {
63
- borderRadius: '4px',
64
- marginRight: '6px',
65
- padding: '2px 6px',
66
- },
67
- }),
68
- ];
@@ -1,28 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export * from './annotations';
6
- export * from './autocomplete';
7
- export * from './autoscroll';
8
- export * from './automerge';
9
- export * from './awareness';
10
- export * from './blast';
11
- export * from './command';
12
- export * from './comments';
13
- export * from './debug';
14
- export * from './dnd';
15
- export * from './factories';
16
- export * from './focus';
17
- export * from './folding';
18
- export * from './hashtag';
19
- export * from './json';
20
- export * from './listener';
21
- export * from './markdown';
22
- export * from './mention';
23
- export * from './modes';
24
- export * from './outliner';
25
- export * from './preview';
26
- export * from './selection';
27
- export * from './tags';
28
- export * from './typewriter';
@@ -1,57 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { json, jsonParseLinter } from '@codemirror/lang-json';
6
- import { type LintSource, linter } from '@codemirror/lint';
7
- import { type Extension } from '@codemirror/state';
8
- import Ajv, { type ValidateFunction } from 'ajv';
9
-
10
- import { type JsonSchemaType } from '@dxos/echo-schema';
11
-
12
- export type JsonExtensionsOptions = {
13
- schema?: JsonSchemaType;
14
- };
15
-
16
- export const createJsonExtensions = ({ schema }: JsonExtensionsOptions = {}): Extension => {
17
- let lintSource: LintSource = jsonParseLinter();
18
- if (schema) {
19
- // NOTE: Relaxing strict mode to allow additional custom schema properties.
20
- const ajv = new Ajv({ allErrors: false, strict: false });
21
- const validate = ajv.compile(schema);
22
- lintSource = schemaLinter(validate);
23
- }
24
-
25
- return [json(), linter(lintSource)];
26
- };
27
-
28
- const schemaLinter =
29
- (validate: ValidateFunction): LintSource =>
30
- (view) => {
31
- try {
32
- const jsonText = view.state.doc.toString();
33
- const jsonData = JSON.parse(jsonText);
34
- const valid = validate(jsonData);
35
- if (valid) {
36
- return [];
37
- }
38
-
39
- return (
40
- validate.errors?.map((err: any) => ({
41
- from: 0,
42
- to: jsonText.length,
43
- severity: 'error',
44
- message: `${err.instancePath || '(root)'} ${err.message}`,
45
- })) ?? []
46
- );
47
- } catch (err: unknown) {
48
- return [
49
- {
50
- from: 0,
51
- to: view.state.doc.length,
52
- severity: 'error',
53
- message: 'Invalid JSON: ' + (err as Error).message,
54
- },
55
- ];
56
- }
57
- };
@@ -1,38 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import { type Extension } from '@codemirror/state';
6
- import { EditorView } from '@codemirror/view';
7
-
8
- import { documentId } from './selection';
9
-
10
- export type ListenerOptions = {
11
- onFocus?: (focusing: boolean) => void;
12
- onChange?: (text: string, id: string) => void;
13
- };
14
-
15
- /**
16
- * Event listener.
17
- * @deprecated Use EditorView.updateListener and listen for specific update events.
18
- */
19
- export const listener = ({ onFocus, onChange }: ListenerOptions): Extension => {
20
- const extensions: Extension[] = [];
21
-
22
- onFocus &&
23
- extensions.push(
24
- EditorView.focusChangeEffect.of((_, focusing) => {
25
- onFocus(focusing);
26
- return null;
27
- }),
28
- );
29
-
30
- onChange &&
31
- extensions.push(
32
- EditorView.updateListener.of((update) => {
33
- onChange(update.state.doc.toString(), update.state.facet(documentId));
34
- }),
35
- );
36
-
37
- return extensions;
38
- };
@@ -1,117 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type EditorView } from '@codemirror/view';
6
-
7
- import { type Action } from '@dxos/app-graph';
8
- import { type MenuActionProperties } from '@dxos/react-ui-menu';
9
-
10
- import { createComment } from '../comments';
11
-
12
- import {
13
- Inline,
14
- List,
15
- addBlockquote,
16
- addCodeblock,
17
- addLink,
18
- addList,
19
- insertTable,
20
- removeBlockquote,
21
- removeCodeblock,
22
- removeLink,
23
- removeList,
24
- setHeading,
25
- setStyle,
26
- toggleBlockquote,
27
- toggleList,
28
- toggleStyle,
29
- } from './formatting';
30
-
31
- export type PayloadType =
32
- | 'view-mode'
33
- | 'blockquote'
34
- | 'strong'
35
- | 'codeblock'
36
- | 'comment'
37
- | 'heading'
38
- | 'image'
39
- | 'emphasis'
40
- | 'code'
41
- | 'link'
42
- | 'list-bullet'
43
- | 'list-ordered'
44
- | 'list-task'
45
- | 'mention'
46
- | 'prompt'
47
- | 'search'
48
- | 'strikethrough'
49
- | 'table';
50
-
51
- export type EditorActionPayload = {
52
- type: PayloadType;
53
- data?: any;
54
- };
55
-
56
- export type EditorAction = Action<MenuActionProperties & EditorActionPayload>;
57
-
58
- export type EditorPayloadHandler = (view: EditorView, payload: EditorActionPayload) => void;
59
-
60
- export const processEditorPayload: EditorPayloadHandler = (view, { type, data }) => {
61
- let inlineType, listType;
62
- switch (type) {
63
- case 'heading':
64
- setHeading(parseInt(data))(view);
65
- break;
66
-
67
- case 'strong':
68
- case 'emphasis':
69
- case 'strikethrough':
70
- case 'code':
71
- inlineType =
72
- type === 'strong'
73
- ? Inline.Strong
74
- : type === 'emphasis'
75
- ? Inline.Emphasis
76
- : type === 'strikethrough'
77
- ? Inline.Strikethrough
78
- : Inline.Code;
79
- (typeof data === 'boolean' ? setStyle(inlineType, data) : toggleStyle(inlineType))(view);
80
- break;
81
-
82
- case 'list-ordered':
83
- case 'list-bullet':
84
- case 'list-task':
85
- listType = type === 'list-ordered' ? List.Ordered : type === 'list-bullet' ? List.Bullet : List.Task;
86
- (data === false ? removeList(listType) : data === true ? addList(listType) : toggleList(listType))(view);
87
- break;
88
-
89
- case 'blockquote':
90
- (data === false ? removeBlockquote : data === true ? addBlockquote : toggleBlockquote)(view);
91
- break;
92
- case 'codeblock':
93
- (data === false ? removeCodeblock : addCodeblock)(view);
94
- break;
95
- case 'table':
96
- insertTable(view);
97
- break;
98
-
99
- case 'link':
100
- (data === false ? removeLink : addLink())(view);
101
- break;
102
-
103
- case 'image':
104
- addLink({ url: data, image: true })(view);
105
- break;
106
-
107
- case 'comment':
108
- createComment(view);
109
- break;
110
- }
111
-
112
- requestAnimationFrame(() => {
113
- if (!view.hasFocus) {
114
- view.focus();
115
- }
116
- });
117
- };