@dxos/react-ui-editor 0.8.4-main.66e292d → 0.8.4-main.69d29f4

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 (397) hide show
  1. package/dist/lib/browser/index.mjs +466 -8269
  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 +465 -8267
  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 +8 -2
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +4 -1
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +4 -2
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -1
  13. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +1 -1
  14. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -1
  15. package/dist/types/src/components/EditorMenuProvider/index.d.ts +0 -1
  16. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -1
  17. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -1
  18. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -1
  19. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +1 -2
  20. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -1
  21. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -1
  22. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +1 -1
  23. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +7 -5
  25. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/actions.d.ts +8 -23
  27. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/blocks.d.ts +6 -5
  29. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  30. package/dist/types/src/components/EditorToolbar/formatting.d.ts +6 -5
  31. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  32. package/dist/types/src/components/EditorToolbar/headings.d.ts +6 -5
  33. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  34. package/dist/types/src/components/EditorToolbar/image.d.ts +4 -11
  35. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  36. package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
  37. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  38. package/dist/types/src/components/EditorToolbar/search.d.ts +4 -11
  39. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  40. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +4 -4
  41. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -1
  42. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +7 -6
  43. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  44. package/dist/types/src/components/index.d.ts.map +1 -1
  45. package/dist/types/src/hooks/useTextEditor.d.ts +1 -1
  46. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  47. package/dist/types/src/index.d.ts +0 -8
  48. package/dist/types/src/index.d.ts.map +1 -1
  49. package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +5 -9
  50. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  51. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -1
  52. package/dist/types/src/stories/Comments.stories.d.ts +3 -2
  53. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  54. package/dist/types/src/stories/EditorToolbar.stories.d.ts +4 -4
  55. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  56. package/dist/types/src/stories/Experimental.stories.d.ts +3 -2
  57. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  58. package/dist/types/src/stories/Markdown.stories.d.ts +3 -2
  59. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  60. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  61. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
  62. package/dist/types/src/stories/Preview.stories.d.ts +3 -2
  63. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  64. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/TextEditor.stories.d.ts +3 -2
  66. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  68. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  69. package/dist/types/src/stories/components/EditorStory.d.ts +8 -20
  70. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  71. package/dist/types/src/stories/components/util.d.ts +3 -3
  72. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  73. package/dist/types/src/translations.d.ts +5 -5
  74. package/dist/types/src/translations.d.ts.map +1 -1
  75. package/dist/types/src/util/index.d.ts +0 -5
  76. package/dist/types/src/util/index.d.ts.map +1 -1
  77. package/dist/types/src/util/react.d.ts +5 -1
  78. package/dist/types/src/util/react.d.ts.map +1 -1
  79. package/dist/types/tsconfig.tsbuildinfo +1 -1
  80. package/package.json +61 -63
  81. package/src/components/Editor/Editor.stories.tsx +14 -8
  82. package/src/components/Editor/Editor.tsx +9 -4
  83. package/src/components/EditorContent/EditorContent.tsx +19 -6
  84. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +2 -2
  85. package/src/components/EditorMenuProvider/index.ts +0 -1
  86. package/src/components/EditorMenuProvider/menu-presets.ts +2 -1
  87. package/src/components/EditorMenuProvider/menu.ts +1 -2
  88. package/src/components/EditorMenuProvider/popover.ts +1 -3
  89. package/src/components/EditorMenuProvider/useEditorMenu.ts +1 -3
  90. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +1 -2
  91. package/src/components/EditorToolbar/EditorToolbar.tsx +18 -14
  92. package/src/components/EditorToolbar/actions.ts +8 -7
  93. package/src/components/EditorToolbar/blocks.ts +3 -4
  94. package/src/components/EditorToolbar/formatting.ts +3 -4
  95. package/src/components/EditorToolbar/headings.ts +3 -3
  96. package/src/components/EditorToolbar/image.ts +8 -1
  97. package/src/components/EditorToolbar/index.ts +1 -1
  98. package/src/components/EditorToolbar/search.ts +8 -1
  99. package/src/components/EditorToolbar/useEditorToolbar.ts +6 -6
  100. package/src/components/EditorToolbar/view-mode.ts +3 -3
  101. package/src/components/index.ts +0 -2
  102. package/src/hooks/useTextEditor.ts +9 -3
  103. package/src/index.ts +0 -10
  104. package/src/stories/Automerge.stories.tsx +175 -0
  105. package/src/stories/CommandDialog.stories.tsx +3 -5
  106. package/src/stories/Comments.stories.tsx +44 -39
  107. package/src/stories/EditorToolbar.stories.tsx +28 -13
  108. package/src/stories/Experimental.stories.tsx +4 -6
  109. package/src/stories/Markdown.stories.tsx +14 -14
  110. package/src/stories/Outliner.stories.tsx +4 -5
  111. package/src/stories/Popover.stories.tsx +17 -21
  112. package/src/stories/Preview.stories.tsx +51 -46
  113. package/src/stories/Tags.stories.tsx +19 -10
  114. package/src/stories/TextEditor.stories.tsx +11 -17
  115. package/src/stories/Theme.stories.tsx +61 -0
  116. package/src/stories/components/EditorStory.tsx +17 -19
  117. package/src/stories/components/util.tsx +3 -3
  118. package/src/translations.ts +4 -4
  119. package/src/util/index.ts +1 -6
  120. package/src/util/react.tsx +6 -2
  121. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  122. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  123. package/dist/lib/browser/types/index.mjs +0 -13
  124. package/dist/lib/browser/types/index.mjs.map +0 -7
  125. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
  126. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  127. package/dist/lib/node-esm/types/index.mjs +0 -14
  128. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  129. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts +0 -26
  130. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts.map +0 -1
  131. package/dist/types/src/components/EditorMenuProvider/util.d.ts +0 -8
  132. package/dist/types/src/components/EditorMenuProvider/util.d.ts.map +0 -1
  133. package/dist/types/src/defaults.d.ts +0 -14
  134. package/dist/types/src/defaults.d.ts.map +0 -1
  135. package/dist/types/src/extensions/annotations.d.ts +0 -9
  136. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  137. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -17
  138. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
  139. package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
  140. package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
  141. package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
  142. package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
  143. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
  144. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
  145. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
  146. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
  147. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  148. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  149. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  150. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  151. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  152. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  153. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  154. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  155. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  156. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  157. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  158. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  159. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  160. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  161. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  162. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  163. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  164. package/dist/types/src/extensions/autoscroll.d.ts +0 -20
  165. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  166. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  167. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  168. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  169. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  170. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  171. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  172. package/dist/types/src/extensions/blast.d.ts +0 -25
  173. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  174. package/dist/types/src/extensions/blocks.d.ts +0 -2
  175. package/dist/types/src/extensions/blocks.d.ts.map +0 -1
  176. package/dist/types/src/extensions/bookmarks.d.ts +0 -12
  177. package/dist/types/src/extensions/bookmarks.d.ts.map +0 -1
  178. package/dist/types/src/extensions/comments.d.ts +0 -95
  179. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  180. package/dist/types/src/extensions/debug.d.ts +0 -3
  181. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  182. package/dist/types/src/extensions/dnd.d.ts +0 -9
  183. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  184. package/dist/types/src/extensions/factories.d.ts +0 -84
  185. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  186. package/dist/types/src/extensions/focus.d.ts +0 -7
  187. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  188. package/dist/types/src/extensions/folding.d.ts +0 -7
  189. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  190. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  191. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  192. package/dist/types/src/extensions/index.d.ts +0 -32
  193. package/dist/types/src/extensions/index.d.ts.map +0 -1
  194. package/dist/types/src/extensions/json.d.ts +0 -7
  195. package/dist/types/src/extensions/json.d.ts.map +0 -1
  196. package/dist/types/src/extensions/listener.d.ts +0 -13
  197. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  198. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  199. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  200. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  201. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  202. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  203. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  204. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  205. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  206. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  207. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  208. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  209. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  210. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -61
  211. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  212. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  213. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  214. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  215. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  216. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  217. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  218. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  219. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  220. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  221. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  222. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  223. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  224. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  225. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  226. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  227. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  228. package/dist/types/src/extensions/mention.d.ts +0 -7
  229. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  230. package/dist/types/src/extensions/modal.d.ts +0 -7
  231. package/dist/types/src/extensions/modal.d.ts.map +0 -1
  232. package/dist/types/src/extensions/modes.d.ts +0 -10
  233. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  234. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  235. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  236. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  237. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  238. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  239. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  240. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  241. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  242. package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
  243. package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
  244. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  245. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  246. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  247. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  248. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  249. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  250. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  251. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  252. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  253. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  254. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  255. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  256. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  257. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  258. package/dist/types/src/extensions/replacer.d.ts +0 -21
  259. package/dist/types/src/extensions/replacer.d.ts.map +0 -1
  260. package/dist/types/src/extensions/replacer.test.d.ts +0 -2
  261. package/dist/types/src/extensions/replacer.test.d.ts.map +0 -1
  262. package/dist/types/src/extensions/scrolling.d.ts +0 -78
  263. package/dist/types/src/extensions/scrolling.d.ts.map +0 -1
  264. package/dist/types/src/extensions/selection.d.ts +0 -24
  265. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  266. package/dist/types/src/extensions/state.d.ts +0 -2
  267. package/dist/types/src/extensions/state.d.ts.map +0 -1
  268. package/dist/types/src/extensions/submit.d.ts +0 -10
  269. package/dist/types/src/extensions/submit.d.ts.map +0 -1
  270. package/dist/types/src/extensions/tab.d.ts +0 -4
  271. package/dist/types/src/extensions/tab.d.ts.map +0 -1
  272. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  273. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  274. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  275. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  276. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  277. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  278. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  279. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  280. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -97
  281. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  282. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  283. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  284. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  285. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  286. package/dist/types/src/styles/index.d.ts +0 -4
  287. package/dist/types/src/styles/index.d.ts.map +0 -1
  288. package/dist/types/src/styles/markdown.d.ts +0 -8
  289. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  290. package/dist/types/src/styles/theme.d.ts +0 -38
  291. package/dist/types/src/styles/theme.d.ts.map +0 -1
  292. package/dist/types/src/styles/tokens.d.ts +0 -3
  293. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  294. package/dist/types/src/types/index.d.ts +0 -2
  295. package/dist/types/src/types/index.d.ts.map +0 -1
  296. package/dist/types/src/types/types.d.ts +0 -21
  297. package/dist/types/src/types/types.d.ts.map +0 -1
  298. package/dist/types/src/util/cursor.d.ts +0 -31
  299. package/dist/types/src/util/cursor.d.ts.map +0 -1
  300. package/dist/types/src/util/debug.d.ts +0 -21
  301. package/dist/types/src/util/debug.d.ts.map +0 -1
  302. package/dist/types/src/util/decorations.d.ts +0 -4
  303. package/dist/types/src/util/decorations.d.ts.map +0 -1
  304. package/dist/types/src/util/dom.d.ts +0 -10
  305. package/dist/types/src/util/dom.d.ts.map +0 -1
  306. package/dist/types/src/util/facet.d.ts +0 -3
  307. package/dist/types/src/util/facet.d.ts.map +0 -1
  308. package/src/components/EditorContent/EditorContent.stories.tsx +0 -70
  309. package/src/components/EditorMenuProvider/util.ts +0 -31
  310. package/src/defaults.ts +0 -52
  311. package/src/extensions/annotations.ts +0 -55
  312. package/src/extensions/autocomplete/autocomplete.ts +0 -151
  313. package/src/extensions/autocomplete/index.ts +0 -8
  314. package/src/extensions/autocomplete/match.ts +0 -46
  315. package/src/extensions/autocomplete/placeholder.ts +0 -117
  316. package/src/extensions/autocomplete/typeahead.ts +0 -87
  317. package/src/extensions/automerge/automerge.stories.tsx +0 -150
  318. package/src/extensions/automerge/automerge.test.tsx +0 -78
  319. package/src/extensions/automerge/automerge.ts +0 -105
  320. package/src/extensions/automerge/cursor.ts +0 -28
  321. package/src/extensions/automerge/defs.ts +0 -31
  322. package/src/extensions/automerge/index.ts +0 -5
  323. package/src/extensions/automerge/sync.ts +0 -79
  324. package/src/extensions/automerge/update-automerge.ts +0 -50
  325. package/src/extensions/automerge/update-codemirror.ts +0 -115
  326. package/src/extensions/autoscroll.ts +0 -163
  327. package/src/extensions/awareness/awareness-provider.ts +0 -127
  328. package/src/extensions/awareness/awareness.ts +0 -315
  329. package/src/extensions/awareness/index.ts +0 -6
  330. package/src/extensions/blast.ts +0 -363
  331. package/src/extensions/blocks.ts +0 -131
  332. package/src/extensions/bookmarks.ts +0 -75
  333. package/src/extensions/comments.ts +0 -598
  334. package/src/extensions/debug.ts +0 -15
  335. package/src/extensions/dnd.ts +0 -37
  336. package/src/extensions/factories.ts +0 -282
  337. package/src/extensions/focus.ts +0 -36
  338. package/src/extensions/folding.tsx +0 -43
  339. package/src/extensions/hashtag.tsx +0 -68
  340. package/src/extensions/index.ts +0 -35
  341. package/src/extensions/json.ts +0 -57
  342. package/src/extensions/listener.ts +0 -32
  343. package/src/extensions/markdown/action.ts +0 -117
  344. package/src/extensions/markdown/bundle.ts +0 -105
  345. package/src/extensions/markdown/changes.test.ts +0 -26
  346. package/src/extensions/markdown/changes.ts +0 -149
  347. package/src/extensions/markdown/debug.ts +0 -44
  348. package/src/extensions/markdown/decorate.ts +0 -601
  349. package/src/extensions/markdown/formatting.test.ts +0 -498
  350. package/src/extensions/markdown/formatting.ts +0 -1265
  351. package/src/extensions/markdown/highlight.ts +0 -183
  352. package/src/extensions/markdown/image.ts +0 -118
  353. package/src/extensions/markdown/index.ts +0 -13
  354. package/src/extensions/markdown/link.ts +0 -50
  355. package/src/extensions/markdown/parser.test.ts +0 -75
  356. package/src/extensions/markdown/styles.ts +0 -135
  357. package/src/extensions/markdown/table.ts +0 -150
  358. package/src/extensions/mention.ts +0 -41
  359. package/src/extensions/modal.ts +0 -24
  360. package/src/extensions/modes.ts +0 -41
  361. package/src/extensions/outliner/commands.ts +0 -270
  362. package/src/extensions/outliner/editor.test.ts +0 -33
  363. package/src/extensions/outliner/editor.ts +0 -184
  364. package/src/extensions/outliner/index.ts +0 -7
  365. package/src/extensions/outliner/menu.ts +0 -128
  366. package/src/extensions/outliner/outliner.test.ts +0 -100
  367. package/src/extensions/outliner/outliner.ts +0 -167
  368. package/src/extensions/outliner/selection.ts +0 -50
  369. package/src/extensions/outliner/tree.test.ts +0 -168
  370. package/src/extensions/outliner/tree.ts +0 -317
  371. package/src/extensions/preview/index.ts +0 -5
  372. package/src/extensions/preview/preview.ts +0 -193
  373. package/src/extensions/replacer.test.ts +0 -75
  374. package/src/extensions/replacer.ts +0 -93
  375. package/src/extensions/scrolling.ts +0 -189
  376. package/src/extensions/selection.ts +0 -100
  377. package/src/extensions/state.ts +0 -7
  378. package/src/extensions/submit.ts +0 -62
  379. package/src/extensions/tab.ts +0 -29
  380. package/src/extensions/tags/extended-markdown.test.ts +0 -262
  381. package/src/extensions/tags/extended-markdown.ts +0 -78
  382. package/src/extensions/tags/index.ts +0 -7
  383. package/src/extensions/tags/streamer.ts +0 -243
  384. package/src/extensions/tags/xml-tags.ts +0 -500
  385. package/src/extensions/tags/xml-util.ts +0 -94
  386. package/src/extensions/typewriter.ts +0 -68
  387. package/src/styles/index.ts +0 -7
  388. package/src/styles/markdown.ts +0 -26
  389. package/src/styles/theme.ts +0 -269
  390. package/src/styles/tokens.ts +0 -17
  391. package/src/types/index.ts +0 -5
  392. package/src/types/types.ts +0 -32
  393. package/src/util/cursor.ts +0 -56
  394. package/src/util/debug.ts +0 -69
  395. package/src/util/decorations.ts +0 -21
  396. package/src/util/dom.ts +0 -34
  397. package/src/util/facet.ts +0 -13
@@ -1,282 +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 { HighlightStyle, bracketMatching, syntaxHighlighting } from '@codemirror/language';
8
- import { searchKeymap } from '@codemirror/search';
9
- import { type ChangeSpec, EditorState, type Extension, type TransactionSpec } from '@codemirror/state';
10
- import {
11
- EditorView,
12
- type KeyBinding,
13
- ViewPlugin,
14
- drawSelection,
15
- dropCursor,
16
- highlightActiveLine,
17
- keymap,
18
- lineNumbers,
19
- placeholder,
20
- scrollPastEnd,
21
- } from '@codemirror/view';
22
- import { vscodeDarkStyle, vscodeLightStyle } from '@uiw/codemirror-theme-vscode';
23
- import defaultsDeep from 'lodash.defaultsdeep';
24
- import merge from 'lodash.merge';
25
-
26
- import { generateName } from '@dxos/display-name';
27
- import { type DocAccessor } from '@dxos/echo-db';
28
- import { log } from '@dxos/log';
29
- import { type Messenger } from '@dxos/protocols';
30
- import { type Identity } from '@dxos/protocols/proto/dxos/client/services';
31
- import { type ThemeMode } from '@dxos/react-ui';
32
- import { type HuePalette } from '@dxos/react-ui-theme';
33
- import { hexToHue, isTruthy } from '@dxos/util';
34
-
35
- import { editorGutter, editorMonospace } from '../defaults';
36
- import { type ThemeStyles, defaultTheme } from '../styles';
37
-
38
- import { automerge } from './automerge';
39
- import { SpaceAwarenessProvider, awareness } from './awareness';
40
- import { focus } from './focus';
41
-
42
- //
43
- // Basic
44
- //
45
-
46
- export const filterChars = (chars: RegExp) => {
47
- return EditorState.transactionFilter.of((transaction) => {
48
- if (!transaction.docChanged) {
49
- return transaction;
50
- }
51
-
52
- const changes: ChangeSpec[] = [];
53
- transaction.changes.iterChanges((fromA, toA, fromB, toB, text) => {
54
- const inserted = text.toString();
55
- const filtered = inserted.replace(chars, '');
56
- if (inserted !== filtered) {
57
- changes.push({
58
- from: fromB,
59
- to: toB,
60
- insert: filtered,
61
- });
62
- }
63
- });
64
-
65
- if (changes.length) {
66
- return [transaction, { changes, sequential: true } as TransactionSpec];
67
- }
68
-
69
- return transaction;
70
- });
71
- };
72
-
73
- /**
74
- * https://codemirror.net/docs/extensions
75
- * https://github.com/codemirror/basic-setup
76
- * https://github.com/codemirror/basic-setup/blob/main/src/codemirror.ts
77
- * https://github.com/codemirror/theme-one-dark
78
- */
79
- export type BasicExtensionsOptions = {
80
- allowMultipleSelections?: boolean;
81
- bracketMatching?: boolean;
82
- closeBrackets?: boolean;
83
- dropCursor?: boolean;
84
- drawSelection?: boolean;
85
- editable?: boolean;
86
- focus?: boolean;
87
- highlightActiveLine?: boolean;
88
- history?: boolean;
89
- indentWithTab?: boolean;
90
- keymap?: null | 'default' | 'standard';
91
- lineNumbers?: boolean;
92
- /** If false then do not set a max-width or side margin on the editor. */
93
- lineWrapping?: boolean;
94
- placeholder?: string;
95
- /** If true user cannot edit the text, but they can still select and copy it. */
96
- readOnly?: boolean;
97
- search?: boolean;
98
- /** NOTE: Do not use with stack sections. */
99
- scrollPastEnd?: boolean;
100
- standardKeymap?: boolean;
101
- tabSize?: number;
102
- };
103
-
104
- const defaultBasicOptions: BasicExtensionsOptions = {
105
- allowMultipleSelections: true,
106
- bracketMatching: true,
107
- closeBrackets: true,
108
- drawSelection: true,
109
- focus: true,
110
- history: true,
111
- keymap: 'standard',
112
- lineWrapping: true,
113
- search: false,
114
- } as const;
115
-
116
- const keymaps: { [key: string]: readonly KeyBinding[] } = {
117
- // https://codemirror.net/docs/ref/#commands.standardKeymap
118
- standard: standardKeymap,
119
- // https://codemirror.net/docs/ref/#commands.defaultKeymap
120
- default: defaultKeymap,
121
- };
122
-
123
- export const createBasicExtensions = (_props?: BasicExtensionsOptions): Extension => {
124
- const props = defaultsDeep({}, _props, defaultBasicOptions);
125
- return [
126
- // NOTE: Doesn't catch errors in keymap functions.
127
- EditorView.exceptionSink.of((err) => {
128
- log.catch(err);
129
- }),
130
-
131
- props.allowMultipleSelections && EditorState.allowMultipleSelections.of(true),
132
- props.bracketMatching && bracketMatching(),
133
- props.closeBrackets && closeBrackets(),
134
- props.dropCursor && dropCursor(),
135
- props.drawSelection && drawSelection({ cursorBlinkRate: 1_200 }),
136
- props.editable !== undefined && EditorView.editable.of(props.editable),
137
- props.focus && focus,
138
- props.highlightActiveLine && highlightActiveLine(),
139
- props.history && history(),
140
- props.lineNumbers && [lineNumbers(), editorGutter],
141
- props.lineWrapping && EditorView.lineWrapping,
142
- props.placeholder && placeholder(props.placeholder),
143
- props.readOnly !== undefined && EditorState.readOnly.of(props.readOnly),
144
- props.scrollPastEnd && scrollPastEnd(),
145
- props.tabSize && EditorState.tabSize.of(props.tabSize),
146
-
147
- // https://codemirror.net/docs/ref/#view.KeyBinding
148
- keymap.of(
149
- [
150
- ...((props.keymap && keymaps[props.keymap]) ?? []),
151
- // NOTE: Tabs are also configured by markdown extension.
152
- // https://codemirror.net/docs/ref/#commands.indentWithTab
153
- ...(props.indentWithTab ? [indentWithTab] : []),
154
- // https://codemirror.net/docs/ref/#autocomplete.closeBracketsKeymap
155
- ...(props.closeBrackets ? closeBracketsKeymap : []),
156
- // https://codemirror.net/docs/ref/#commands.historyKeymap
157
- ...(props.history ? historyKeymap : []),
158
- // https://codemirror.net/docs/ref/#search.searchKeymap
159
- ...(props.search ? searchKeymap : []),
160
- // Disable bindings that conflict with system shortcuts.
161
- // TODO(burdon): Catalog global shortcuts.
162
- {
163
- key: 'Mod-Shift-k',
164
- preventDefault: true,
165
- run: () => true,
166
- },
167
- ].filter(isTruthy),
168
- ),
169
- ].filter(isTruthy);
170
- };
171
-
172
- //
173
- // Theme
174
- //
175
-
176
- export type ThemeExtensionsOptions = {
177
- themeMode?: ThemeMode;
178
- monospace?: boolean;
179
- styles?: ThemeStyles;
180
- syntaxHighlighting?: boolean;
181
- slots?: {
182
- editor?: {
183
- className?: string;
184
- };
185
- scroll?: {
186
- // NOTE: Do not apply vertical padding to scroll container.
187
- className?: string;
188
- };
189
- content?: {
190
- className?: string;
191
- };
192
- };
193
- };
194
-
195
- export const grow: ThemeExtensionsOptions['slots'] = {
196
- editor: {
197
- className: 'bs-full is-full',
198
- },
199
- } as const;
200
-
201
- export const fullWidth: ThemeExtensionsOptions['slots'] = {
202
- editor: {
203
- className: 'is-full',
204
- },
205
- } as const;
206
-
207
- export const defaultThemeSlots = grow;
208
-
209
- export const defaultStyles = {
210
- dark: vscodeDarkStyle,
211
- light: vscodeLightStyle,
212
- };
213
-
214
- /**
215
- * https://codemirror.net/examples/styling
216
- */
217
- export const createThemeExtensions = ({
218
- themeMode,
219
- monospace,
220
- styles,
221
- syntaxHighlighting: syntaxHighlightingProp,
222
- slots: slotsParam,
223
- }: ThemeExtensionsOptions = {}): Extension => {
224
- const slots = defaultsDeep({}, slotsParam, defaultThemeSlots);
225
- return [
226
- EditorView.darkTheme.of(themeMode === 'dark'),
227
- EditorView.baseTheme(styles ? merge({}, defaultTheme, styles) : defaultTheme),
228
- monospace && editorMonospace,
229
- syntaxHighlightingProp &&
230
- syntaxHighlighting(HighlightStyle.define(themeMode === 'dark' ? defaultStyles.dark : defaultStyles.light)),
231
- slots.editor?.className && EditorView.editorAttributes.of({ class: slots.editor.className }),
232
- slots.content?.className && EditorView.contentAttributes.of({ class: slots.content.className }),
233
- slots.scroll?.className &&
234
- ViewPlugin.fromClass(
235
- class {
236
- constructor(view: EditorView) {
237
- view.scrollDOM.classList.add(...slots.scroll.className.split(/\s+/));
238
- }
239
- },
240
- ),
241
- ].filter(isTruthy);
242
- };
243
-
244
- //
245
- // Data
246
- //
247
-
248
- export type DataExtensionsProps<T> = {
249
- id: string;
250
- text?: DocAccessor<T>;
251
- messenger?: Messenger;
252
- identity?: Identity | null;
253
- };
254
-
255
- // TODO(burdon): Move out of react-ui-editor?
256
- export const createDataExtensions = <T>({ id, text, messenger, identity }: DataExtensionsProps<T>): Extension[] => {
257
- const extensions: Extension[] = [];
258
- if (text) {
259
- extensions.push(automerge(text));
260
- }
261
-
262
- if (messenger && identity) {
263
- const peerId = identity?.identityKey.toHex();
264
- const hue = (identity?.profile?.data?.hue as HuePalette | undefined) ?? hexToHue(peerId ?? '0');
265
- extensions.push(
266
- awareness(
267
- new SpaceAwarenessProvider({
268
- messenger,
269
- channel: `awareness.${id}`,
270
- peerId: identity.identityKey.toHex(),
271
- info: {
272
- darkColor: `var(--dx-${hue}Cursor)`,
273
- lightColor: `var(--dx-${hue}Cursor)`,
274
- displayName: identity.profile?.displayName ?? generateName(identity.identityKey.toHex()),
275
- },
276
- }),
277
- ),
278
- );
279
- }
280
-
281
- return extensions;
282
- };
@@ -1,36 +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
-
19
- return value;
20
- },
21
- });
22
-
23
- /**
24
- * Manage focus.
25
- */
26
- export const focus = [
27
- focusField,
28
- EditorView.domEventHandlers({
29
- focus: (_event, view) => {
30
- requestAnimationFrame(() => view.dispatch({ effects: focusEffect.of(true) }));
31
- },
32
- blur: (_event, view) => {
33
- requestAnimationFrame(() => view.dispatch({ effects: focusEffect.of(false) }));
34
- },
35
- }),
36
- ];
@@ -1,43 +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 { Domino, Icon } from '@dxos/react-ui';
11
-
12
- import { renderRoot } from '../util';
13
-
14
- export type FoldingOptions = {};
15
-
16
- /**
17
- * https://codemirror.net/examples/gutter
18
- */
19
- export const folding = (_props: FoldingOptions = {}): Extension => [
20
- codeFolding({
21
- placeholderDOM: () => {
22
- return document.createElement('span'); // Collapse content.
23
- },
24
- }),
25
- foldGutter({
26
- markerDOM: (open) => {
27
- return renderRoot(
28
- Domino.of('div').classNames('flex bs-full items-center').build(),
29
- <Icon icon='ph--caret-right--bold' size={3} classNames={['mx-3 cursor-pointer', open && 'rotate-90']} />,
30
- );
31
- },
32
- }),
33
- EditorView.theme({
34
- '.cm-foldGutter': {
35
- opacity: 0.3,
36
- transition: 'opacity 0.3s',
37
- width: '32px',
38
- },
39
- '.cm-foldGutter:hover': {
40
- opacity: 1,
41
- },
42
- }),
43
- ];
@@ -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 { getHashStyles, 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', getHashStyles(this._text).surface);
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,35 +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 './blocks';
12
- export * from './bookmarks';
13
- export * from './comments';
14
- export * from './debug';
15
- export * from './dnd';
16
- export * from './factories';
17
- export * from './focus';
18
- export * from './folding';
19
- export * from './hashtag';
20
- export * from './json';
21
- export * from './listener';
22
- export * from './markdown';
23
- export * from './mention';
24
- export * from './modal';
25
- export * from './modes';
26
- export * from './outliner';
27
- export * from './preview';
28
- export * from './replacer';
29
- export * from './selection';
30
- export * from './scrolling';
31
- export * from './state';
32
- export * from './submit';
33
- export * from './tab';
34
- export * from './tags';
35
- 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/internal';
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,32 +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 { isNonNullable } from '@dxos/util';
9
-
10
- import { documentId } from './selection';
11
-
12
- export type ListenerOptions = {
13
- onFocus?: (event: { id: string; focusing: boolean }) => void;
14
- onChange?: (event: { id: string; text: string }) => void;
15
- };
16
-
17
- export const listener = ({ onFocus, onChange }: ListenerOptions): Extension => {
18
- return [
19
- onFocus &&
20
- EditorView.focusChangeEffect.of((state, focusing) => {
21
- onFocus({ id: state.facet(documentId), focusing });
22
- return null;
23
- }),
24
-
25
- onChange &&
26
- EditorView.updateListener.of(({ state, docChanged }) => {
27
- if (docChanged) {
28
- onChange({ id: state.facet(documentId), text: state.doc.toString() });
29
- }
30
- }),
31
- ].filter(isNonNullable);
32
- };
@@ -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
- };