@dxos/react-ui-editor 0.8.4-main.ae835ea → 0.8.4-main.bc674ce

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 (416) hide show
  1. package/dist/lib/browser/index.mjs +1103 -8137
  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 +1103 -8136
  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 -30
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +16 -20
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
  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/{extensions/popover/PopoverMenuProvider.d.ts → components/EditorMenuProvider/EditorMenuProvider.d.ts} +6 -6
  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/{extensions/popover → components/EditorMenuProvider}/popover.d.ts +1 -2
  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 +14 -3
  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 -1
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/hooks/useTextEditor.d.ts +2 -2
  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 -9
  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/Popover.stories.d.ts +2 -2
  72. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
  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 -3
  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 +10 -19
  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 +5 -1
  89. package/dist/types/src/util/react.d.ts.map +1 -1
  90. package/dist/types/tsconfig.tsbuildinfo +1 -1
  91. package/package.json +63 -69
  92. package/src/components/Editor/Editor.stories.tsx +76 -50
  93. package/src/components/Editor/Editor.tsx +160 -63
  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/{extensions/popover/PopoverMenuProvider.tsx → components/EditorMenuProvider/EditorMenuProvider.tsx} +27 -14
  98. package/src/components/EditorMenuProvider/index.ts +10 -0
  99. package/src/{extensions/popover → components/EditorMenuProvider}/menu-presets.ts +19 -19
  100. package/src/{extensions/popover → components/EditorMenuProvider}/menu.ts +21 -18
  101. package/src/{extensions/popover → components/EditorMenuProvider}/popover.ts +3 -7
  102. package/src/{extensions/popover/usePopoverMenu.ts → components/EditorMenuProvider/useEditorMenu.ts} +21 -21
  103. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +81 -0
  104. package/src/components/EditorPreviewProvider/index.ts +5 -0
  105. package/src/components/EditorToolbar/EditorToolbar.tsx +30 -17
  106. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  107. package/src/components/EditorToolbar/blocks.ts +5 -5
  108. package/src/components/EditorToolbar/formatting.ts +5 -5
  109. package/src/components/EditorToolbar/headings.ts +5 -4
  110. package/src/components/EditorToolbar/image.ts +9 -2
  111. package/src/components/EditorToolbar/index.ts +3 -7
  112. package/src/components/EditorToolbar/search.ts +9 -2
  113. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  114. package/src/components/EditorToolbar/view-mode.ts +5 -4
  115. package/src/components/index.ts +6 -1
  116. package/src/hooks/useTextEditor.ts +13 -7
  117. package/src/index.ts +0 -10
  118. package/src/stories/Automerge.stories.tsx +175 -0
  119. package/src/stories/CommandDialog.stories.tsx +12 -9
  120. package/src/stories/Comments.stories.tsx +47 -43
  121. package/src/stories/EditorToolbar.stories.tsx +31 -15
  122. package/src/stories/Experimental.stories.tsx +4 -6
  123. package/src/stories/Markdown.stories.tsx +14 -14
  124. package/src/stories/Outliner.stories.tsx +16 -24
  125. package/src/stories/Popover.stories.tsx +40 -45
  126. package/src/stories/Preview.stories.tsx +76 -74
  127. package/src/stories/Tags.stories.tsx +32 -9
  128. package/src/stories/TextEditor.stories.tsx +11 -17
  129. package/src/stories/Theme.stories.tsx +61 -0
  130. package/src/stories/components/EditorStory.tsx +34 -27
  131. package/src/stories/components/util.tsx +43 -11
  132. package/src/translations.ts +4 -4
  133. package/src/util/index.ts +1 -6
  134. package/src/util/react.tsx +6 -2
  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/EditorToolbar/lists.d.ts +0 -19
  148. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  149. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -37
  150. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  151. package/dist/types/src/defaults.d.ts +0 -14
  152. package/dist/types/src/defaults.d.ts.map +0 -1
  153. package/dist/types/src/extensions/annotations.d.ts +0 -9
  154. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  155. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -26
  156. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
  157. package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
  158. package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
  159. package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
  160. package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
  161. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
  162. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
  163. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
  164. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
  165. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  166. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  167. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  168. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  169. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  170. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  171. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  172. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  173. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  174. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  175. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  176. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  177. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  178. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  179. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  180. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  181. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  182. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  183. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  184. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  185. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  186. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  187. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  188. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  189. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  190. package/dist/types/src/extensions/blast.d.ts +0 -25
  191. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  192. package/dist/types/src/extensions/comments.d.ts +0 -95
  193. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  194. package/dist/types/src/extensions/debug.d.ts +0 -3
  195. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  196. package/dist/types/src/extensions/dnd.d.ts +0 -9
  197. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  198. package/dist/types/src/extensions/factories.d.ts +0 -83
  199. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  200. package/dist/types/src/extensions/focus.d.ts +0 -7
  201. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  202. package/dist/types/src/extensions/folding.d.ts +0 -7
  203. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  204. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  205. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  206. package/dist/types/src/extensions/index.d.ts +0 -26
  207. package/dist/types/src/extensions/index.d.ts.map +0 -1
  208. package/dist/types/src/extensions/json.d.ts +0 -7
  209. package/dist/types/src/extensions/json.d.ts.map +0 -1
  210. package/dist/types/src/extensions/listener.d.ts +0 -13
  211. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  212. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  213. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  214. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  215. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  216. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  217. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  218. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  219. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  220. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  221. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  222. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  223. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  224. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -62
  225. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  226. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  227. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  228. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  229. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  230. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  231. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  232. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  233. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  234. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  235. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  236. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  237. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  238. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  239. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  240. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  241. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  242. package/dist/types/src/extensions/mention.d.ts +0 -7
  243. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  244. package/dist/types/src/extensions/modes.d.ts +0 -10
  245. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  246. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  247. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  248. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  249. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  250. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  251. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  252. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  253. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  254. package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
  255. package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
  256. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  257. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  258. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  259. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  260. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  261. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  262. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  263. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  264. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  265. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  266. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +0 -1
  267. package/dist/types/src/extensions/popover/index.d.ts +0 -8
  268. package/dist/types/src/extensions/popover/index.d.ts.map +0 -1
  269. package/dist/types/src/extensions/popover/menu-presets.d.ts +0 -4
  270. package/dist/types/src/extensions/popover/menu-presets.d.ts.map +0 -1
  271. package/dist/types/src/extensions/popover/menu.d.ts +0 -24
  272. package/dist/types/src/extensions/popover/menu.d.ts.map +0 -1
  273. package/dist/types/src/extensions/popover/modal.d.ts +0 -7
  274. package/dist/types/src/extensions/popover/modal.d.ts.map +0 -1
  275. package/dist/types/src/extensions/popover/popover.d.ts.map +0 -1
  276. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +0 -34
  277. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +0 -1
  278. package/dist/types/src/extensions/popover/util.d.ts +0 -8
  279. package/dist/types/src/extensions/popover/util.d.ts.map +0 -1
  280. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  281. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  282. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  283. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  284. package/dist/types/src/extensions/selection.d.ts +0 -24
  285. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  286. package/dist/types/src/extensions/state.d.ts +0 -2
  287. package/dist/types/src/extensions/state.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/styles/index.d.ts +0 -4
  303. package/dist/types/src/styles/index.d.ts.map +0 -1
  304. package/dist/types/src/styles/markdown.d.ts +0 -8
  305. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  306. package/dist/types/src/styles/theme.d.ts +0 -38
  307. package/dist/types/src/styles/theme.d.ts.map +0 -1
  308. package/dist/types/src/styles/tokens.d.ts +0 -3
  309. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  310. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  311. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  312. package/dist/types/src/testing/index.d.ts +0 -3
  313. package/dist/types/src/testing/index.d.ts.map +0 -1
  314. package/dist/types/src/testing/util.d.ts +0 -3
  315. package/dist/types/src/testing/util.d.ts.map +0 -1
  316. package/dist/types/src/types/index.d.ts +0 -2
  317. package/dist/types/src/types/index.d.ts.map +0 -1
  318. package/dist/types/src/types/types.d.ts +0 -21
  319. package/dist/types/src/types/types.d.ts.map +0 -1
  320. package/dist/types/src/util/cursor.d.ts +0 -31
  321. package/dist/types/src/util/cursor.d.ts.map +0 -1
  322. package/dist/types/src/util/debug.d.ts +0 -17
  323. package/dist/types/src/util/debug.d.ts.map +0 -1
  324. package/dist/types/src/util/decorations.d.ts +0 -4
  325. package/dist/types/src/util/decorations.d.ts.map +0 -1
  326. package/dist/types/src/util/dom.d.ts +0 -10
  327. package/dist/types/src/util/dom.d.ts.map +0 -1
  328. package/dist/types/src/util/facet.d.ts +0 -3
  329. package/dist/types/src/util/facet.d.ts.map +0 -1
  330. package/src/components/EditorToolbar/util.ts +0 -60
  331. package/src/defaults.ts +0 -52
  332. package/src/extensions/annotations.ts +0 -55
  333. package/src/extensions/autocomplete/autocomplete.ts +0 -220
  334. package/src/extensions/autocomplete/index.ts +0 -8
  335. package/src/extensions/autocomplete/match.ts +0 -46
  336. package/src/extensions/autocomplete/placeholder.ts +0 -117
  337. package/src/extensions/autocomplete/typeahead.ts +0 -87
  338. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  339. package/src/extensions/automerge/automerge.test.tsx +0 -78
  340. package/src/extensions/automerge/automerge.ts +0 -105
  341. package/src/extensions/automerge/cursor.ts +0 -28
  342. package/src/extensions/automerge/defs.ts +0 -31
  343. package/src/extensions/automerge/index.ts +0 -5
  344. package/src/extensions/automerge/sync.ts +0 -79
  345. package/src/extensions/automerge/update-automerge.ts +0 -50
  346. package/src/extensions/automerge/update-codemirror.ts +0 -115
  347. package/src/extensions/autoscroll.ts +0 -157
  348. package/src/extensions/awareness/awareness-provider.ts +0 -127
  349. package/src/extensions/awareness/awareness.ts +0 -315
  350. package/src/extensions/awareness/index.ts +0 -6
  351. package/src/extensions/blast.ts +0 -363
  352. package/src/extensions/comments.ts +0 -597
  353. package/src/extensions/debug.ts +0 -15
  354. package/src/extensions/dnd.ts +0 -37
  355. package/src/extensions/factories.ts +0 -277
  356. package/src/extensions/focus.ts +0 -36
  357. package/src/extensions/folding.tsx +0 -44
  358. package/src/extensions/hashtag.tsx +0 -68
  359. package/src/extensions/index.ts +0 -29
  360. package/src/extensions/json.ts +0 -57
  361. package/src/extensions/listener.ts +0 -32
  362. package/src/extensions/markdown/action.ts +0 -117
  363. package/src/extensions/markdown/bundle.ts +0 -105
  364. package/src/extensions/markdown/changes.test.ts +0 -26
  365. package/src/extensions/markdown/changes.ts +0 -149
  366. package/src/extensions/markdown/debug.ts +0 -44
  367. package/src/extensions/markdown/decorate.ts +0 -601
  368. package/src/extensions/markdown/formatting.test.ts +0 -498
  369. package/src/extensions/markdown/formatting.ts +0 -1267
  370. package/src/extensions/markdown/highlight.ts +0 -183
  371. package/src/extensions/markdown/image.ts +0 -118
  372. package/src/extensions/markdown/index.ts +0 -13
  373. package/src/extensions/markdown/link.ts +0 -50
  374. package/src/extensions/markdown/parser.test.ts +0 -75
  375. package/src/extensions/markdown/styles.ts +0 -135
  376. package/src/extensions/markdown/table.ts +0 -150
  377. package/src/extensions/mention.ts +0 -41
  378. package/src/extensions/modes.ts +0 -41
  379. package/src/extensions/outliner/commands.ts +0 -270
  380. package/src/extensions/outliner/editor.test.ts +0 -33
  381. package/src/extensions/outliner/editor.ts +0 -184
  382. package/src/extensions/outliner/index.ts +0 -7
  383. package/src/extensions/outliner/menu.ts +0 -128
  384. package/src/extensions/outliner/outliner.test.ts +0 -100
  385. package/src/extensions/outliner/outliner.ts +0 -167
  386. package/src/extensions/outliner/selection.ts +0 -50
  387. package/src/extensions/outliner/tree.test.ts +0 -168
  388. package/src/extensions/outliner/tree.ts +0 -317
  389. package/src/extensions/popover/index.ts +0 -12
  390. package/src/extensions/popover/modal.ts +0 -24
  391. package/src/extensions/popover/util.ts +0 -29
  392. package/src/extensions/preview/index.ts +0 -5
  393. package/src/extensions/preview/preview.ts +0 -193
  394. package/src/extensions/selection.ts +0 -100
  395. package/src/extensions/state.ts +0 -7
  396. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  397. package/src/extensions/tags/extended-markdown.ts +0 -78
  398. package/src/extensions/tags/index.ts +0 -7
  399. package/src/extensions/tags/streamer.ts +0 -243
  400. package/src/extensions/tags/xml-tags.ts +0 -393
  401. package/src/extensions/tags/xml-util.ts +0 -94
  402. package/src/extensions/typewriter.ts +0 -68
  403. package/src/styles/index.ts +0 -7
  404. package/src/styles/markdown.ts +0 -26
  405. package/src/styles/theme.ts +0 -269
  406. package/src/styles/tokens.ts +0 -17
  407. package/src/testing/PreviewPopover.tsx +0 -80
  408. package/src/testing/index.ts +0 -6
  409. package/src/testing/util.ts +0 -7
  410. package/src/types/index.ts +0 -5
  411. package/src/types/types.ts +0 -32
  412. package/src/util/cursor.ts +0 -56
  413. package/src/util/debug.ts +0 -64
  414. package/src/util/decorations.ts +0 -21
  415. package/src/util/dom.ts +0 -34
  416. package/src/util/facet.ts +0 -13
@@ -1,115 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- // Copyright 2024 Automerge
4
- // Ref: https://github.com/automerge/automerge-codemirror
5
- //
6
-
7
- import {
8
- type DelPatch,
9
- type InsertPatch,
10
- type Patch,
11
- type Prop,
12
- type PutPatch,
13
- type SpliceTextPatch,
14
- } from '@automerge/automerge';
15
- import { ChangeSet, type ChangeSpec, type EditorSelection, type EditorState } from '@codemirror/state';
16
- import { type EditorView } from '@codemirror/view';
17
-
18
- import { reconcileAnnotation } from './defs';
19
-
20
- export const updateCodeMirror = (view: EditorView, selection: EditorSelection, target: Prop[], patches: Patch[]) => {
21
- for (const patch of patches) {
22
- const changeSpec = handlePatch(patch, target, view.state);
23
- if (changeSpec != null) {
24
- const changeSet = ChangeSet.of(changeSpec, view.state.doc.length, '\n');
25
- selection = selection.map(changeSet, 1);
26
- view.dispatch({
27
- changes: changeSet,
28
- annotations: reconcileAnnotation.of(false),
29
- });
30
- }
31
- }
32
-
33
- view.dispatch({
34
- selection,
35
- annotations: reconcileAnnotation.of(false),
36
- });
37
- };
38
-
39
- const handlePatch = (patch: Patch, target: Prop[], state: EditorState): ChangeSpec | null => {
40
- if (patch.action === 'insert') {
41
- return handleInsert(target, patch);
42
- } else if (patch.action === 'splice') {
43
- return handleSplice(target, patch);
44
- } else if (patch.action === 'del') {
45
- return handleDel(target, patch);
46
- } else if (patch.action === 'put') {
47
- return handlePut(target, patch, state);
48
- } else {
49
- return null;
50
- }
51
- };
52
-
53
- const handleInsert = (target: Prop[], patch: InsertPatch): Array<ChangeSpec> => {
54
- const index = charPath(target, patch.path);
55
- if (index == null) {
56
- return [];
57
- }
58
-
59
- const text = patch.values.map((value) => (value ? value.toString() : '')).join('');
60
- return [{ from: index, to: index, insert: text }];
61
- };
62
-
63
- const handleSplice = (target: Prop[], patch: SpliceTextPatch): Array<ChangeSpec> => {
64
- const index = charPath(target, patch.path);
65
- if (index == null) {
66
- return [];
67
- }
68
-
69
- return [{ from: index, insert: patch.value }];
70
- };
71
-
72
- const handleDel = (target: Prop[], patch: DelPatch): Array<ChangeSpec> => {
73
- const index = charPath(target, patch.path);
74
- if (index == null) {
75
- return [];
76
- }
77
-
78
- const length = patch.length || 1;
79
- return [{ from: index, to: index + length }];
80
- };
81
-
82
- const handlePut = (target: Prop[], patch: PutPatch, state: EditorState): Array<ChangeSpec> => {
83
- const index = charPath(target, [...patch.path, 0]);
84
- if (index == null) {
85
- return [];
86
- }
87
-
88
- const length = state.doc.length;
89
- if (typeof patch.value !== 'string') {
90
- return []; // TODO(dmaretskyi): How to handle non-string values?
91
- }
92
-
93
- return [{ from: 0, to: length, insert: patch.value as any }];
94
- };
95
-
96
- // If the path of the patch is of the form [path, <index>] then we know this is a path to a character
97
- // within the sequence given by path.
98
- const charPath = (textPath: Prop[], candidatePath: Prop[]): number | null => {
99
- if (candidatePath.length !== textPath.length + 1) {
100
- return null;
101
- }
102
-
103
- for (let i = 0; i < textPath.length; i++) {
104
- if (textPath[i] !== candidatePath[i]) {
105
- return null;
106
- }
107
- }
108
-
109
- const index = candidatePath[candidatePath.length - 1];
110
- if (typeof index === 'number') {
111
- return index;
112
- }
113
-
114
- return null;
115
- };
@@ -1,157 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { StateEffect } from '@codemirror/state';
6
- import { EditorView, ViewPlugin } from '@codemirror/view';
7
-
8
- import { Domino } from '@dxos/react-ui';
9
-
10
- const lineHeight = 24;
11
-
12
- export const scrollToBottomEffect = StateEffect.define<any>();
13
-
14
- export type AutoScrollOptions = {
15
- overscroll?: number;
16
- throttle?: number;
17
- };
18
-
19
- /**
20
- * Extension that supports pinning the scroll position and automatically scrolls to the bottom when content is added.
21
- */
22
- // TODO(burdon): Reconcile with transcript-extension.
23
- export const autoScroll = ({ overscroll = 4 * lineHeight, throttle = 2_000 }: Partial<AutoScrollOptions> = {}) => {
24
- let isThrottled = false;
25
- let isPinned = true;
26
- let timeout: NodeJS.Timeout | undefined;
27
- let buttonContainer: HTMLDivElement | undefined;
28
- let lastScrollTop = 0;
29
- let scrollCounter = 0;
30
-
31
- const hideScrollbar = (view: EditorView) => {
32
- view.scrollDOM.classList.add('cm-hide-scrollbar');
33
- clearTimeout(timeout);
34
- timeout = setTimeout(() => {
35
- view.scrollDOM.classList.remove('cm-hide-scrollbar');
36
- }, 1_000);
37
- };
38
-
39
- const scrollToBottom = (view: EditorView) => {
40
- isPinned = true;
41
- scrollCounter = 0;
42
- buttonContainer?.classList.add('opacity-0');
43
- requestAnimationFrame(() => {
44
- hideScrollbar(view);
45
- view.scrollDOM.scrollTo({
46
- top: view.scrollDOM.scrollHeight,
47
- behavior: 'smooth',
48
- });
49
- });
50
- };
51
-
52
- return [
53
- // Update listener for logging when scrolling is needed.
54
- EditorView.updateListener.of((update) => {
55
- // Listen for effects.
56
- update.transactions.forEach((transaction) => {
57
- for (const effect of transaction.effects) {
58
- if (effect.is(scrollToBottomEffect)) {
59
- scrollToBottom(update.view);
60
- }
61
- }
62
- });
63
-
64
- // Maybe scroll if doc changed and pinned.
65
- if (update.docChanged && isPinned && !isThrottled) {
66
- const distanceFromBottom = calcDistance(update.view.scrollDOM);
67
- if (distanceFromBottom >= overscroll) {
68
- isThrottled = true;
69
- requestAnimationFrame(() => {
70
- scrollToBottom(update.view);
71
- });
72
-
73
- // Reset throttle.
74
- setTimeout(() => {
75
- isThrottled = false;
76
- scrollToBottom(update.view);
77
- }, throttle);
78
- }
79
- }
80
- }),
81
-
82
- // Detect user scroll.
83
- // NOTE: Multiple scroll events are triggered during programmatic smooth scrolling.
84
- EditorView.domEventHandlers({
85
- scroll: (event, view) => {
86
- const scroller = view.scrollDOM;
87
- // Suspect delta goes positive when rendering widgets, so count positive deltas.
88
- // TODO(burdon): Detect user scroll directly (wheel, touch, keys, etc.)
89
- if (lastScrollTop > scroller.scrollTop) {
90
- scrollCounter++;
91
- }
92
- lastScrollTop = scroller.scrollTop;
93
- const distanceFromBottom = calcDistance(scroller);
94
- if (distanceFromBottom === 0) {
95
- // Pin to bottom.
96
- isPinned = true;
97
- buttonContainer?.classList.add('opacity-0');
98
- scrollCounter = 0;
99
- } else if (scrollCounter > 3) {
100
- // Break pin if user scrolls up.
101
- isPinned = false;
102
- buttonContainer?.classList.remove('opacity-0');
103
- }
104
- },
105
- }),
106
-
107
- // Scroll button.
108
- ViewPlugin.fromClass(
109
- class {
110
- constructor(view: EditorView) {
111
- const scroller = view.scrollDOM.parentElement;
112
- buttonContainer = Domino.of('div')
113
- .classNames(true && 'cm-scroll-button transition-opacity duration-300 opacity-0')
114
- .children(
115
- Domino.of('button')
116
- .classNames('dx-button bg-accentSurface')
117
- .data('density', 'fine')
118
- .children(Domino.of<any>('dx-icon').attributes({ icon: 'ph--arrow-down--regular' }))
119
- .on('click', () => {
120
- scrollToBottom(view);
121
- }),
122
- )
123
- .build();
124
- scroller?.appendChild(buttonContainer);
125
- }
126
- },
127
- ),
128
-
129
- // Styles.
130
- EditorView.theme({
131
- '.cm-scroller': {
132
- paddingBottom: `${overscroll}px`,
133
- scrollbarWidth: 'thin',
134
- },
135
- '.cm-scroller.cm-hide-scrollbar': {
136
- scrollbarWidth: 'none',
137
- },
138
- '.cm-scroller.cm-hide-scrollbar::-webkit-scrollbar': {
139
- display: 'none',
140
- },
141
-
142
- '.cm-scroll-button': {
143
- position: 'absolute',
144
- bottom: '0.5rem',
145
- right: '1rem',
146
- },
147
- }),
148
- ];
149
- };
150
-
151
- const calcDistance = (scroller: HTMLElement) => {
152
- const scrollTop = scroller.scrollTop;
153
- const scrollHeight = scroller.scrollHeight;
154
- const clientHeight = scroller.clientHeight;
155
- const distanceFromBottom = scrollHeight - (scrollTop + clientHeight);
156
- return distanceFromBottom;
157
- };
@@ -1,127 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { DeferredTask, Event, sleep } from '@dxos/async';
6
- import { type Space } from '@dxos/client/echo';
7
- import { type GossipMessage } from '@dxos/client/mesh';
8
- import { Context } from '@dxos/context';
9
- import { invariant } from '@dxos/invariant';
10
- import { log } from '@dxos/log';
11
-
12
- import { type AwarenessInfo, type AwarenessPosition, type AwarenessProvider, type AwarenessState } from './awareness';
13
-
14
- type ProtocolMessage =
15
- | {
16
- kind: 'query';
17
- }
18
- | {
19
- kind: 'post';
20
- state: AwarenessState;
21
- };
22
-
23
- const DEBOUNCE_INTERVAL = 100; // ms
24
-
25
- export type AwarenessProviderParams = {
26
- space: Space;
27
- channel: string;
28
- peerId: string;
29
- info: AwarenessInfo;
30
- };
31
-
32
- /**
33
- * Receives and broadcasts profile and cursor position.
34
- */
35
- export class SpaceAwarenessProvider implements AwarenessProvider {
36
- private readonly _remoteStates = new Map<string, AwarenessState>();
37
-
38
- private readonly _space: Space;
39
- private readonly _channel: string;
40
- private readonly _peerId: string;
41
- private readonly _info: AwarenessInfo;
42
-
43
- private _ctx?: Context;
44
- private _postTask?: DeferredTask;
45
- private _localState?: AwarenessState;
46
-
47
- public readonly remoteStateChange = new Event<void>();
48
-
49
- constructor(params: AwarenessProviderParams) {
50
- this._space = params.space;
51
- this._channel = params.channel;
52
- this._peerId = params.peerId;
53
- this._info = params.info;
54
- }
55
-
56
- open(): void {
57
- this._ctx = new Context();
58
- this._postTask = new DeferredTask(this._ctx, async () => {
59
- if (this._localState) {
60
- await this._space.postMessage(this._channel, {
61
- kind: 'post',
62
- state: this._localState,
63
- } satisfies ProtocolMessage);
64
-
65
- // TODO(burdon): Replace with throttle.
66
- // TODO(burdon): Send heads?
67
- await sleep(DEBOUNCE_INTERVAL);
68
- }
69
- });
70
-
71
- this._ctx.onDispose(
72
- this._space.listen(this._channel, (message: GossipMessage) => {
73
- switch (message.payload.kind) {
74
- case 'query': {
75
- this._handleQueryMessage();
76
- break;
77
- }
78
- case 'post': {
79
- this._handlePostMessage(message.payload);
80
- break;
81
- }
82
- }
83
- }),
84
- );
85
-
86
- void this._space
87
- .postMessage(this._channel, {
88
- kind: 'query',
89
- } satisfies ProtocolMessage)
90
- .catch((err) => {
91
- log.debug('failed to query awareness', { err });
92
- });
93
- }
94
-
95
- close(): void {
96
- void this._ctx?.dispose();
97
- this._ctx = undefined;
98
- this._postTask = undefined;
99
- }
100
-
101
- getRemoteStates(): AwarenessState[] {
102
- return Array.from(this._remoteStates.values());
103
- }
104
-
105
- update(position: AwarenessPosition | undefined): void {
106
- invariant(this._postTask);
107
- this._localState = {
108
- peerId: this._peerId,
109
- position,
110
- info: this._info,
111
- };
112
-
113
- this._postTask.schedule();
114
- }
115
-
116
- private _handleQueryMessage(): void {
117
- invariant(this._postTask);
118
- this._postTask.schedule();
119
- }
120
-
121
- private _handlePostMessage(message: ProtocolMessage): void {
122
- invariant(message.kind === 'post');
123
- // TODO(wittjosiah): Is it helpful or confusing to show cursors for self on other devices?
124
- this._remoteStates.set(message.state.peerId, message.state);
125
- this.remoteStateChange.emit();
126
- }
127
- }
@@ -1,315 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { Annotation, type Extension, type Range, RangeSet } from '@codemirror/state';
6
- import {
7
- Decoration,
8
- type DecorationSet,
9
- EditorView,
10
- type PluginValue,
11
- ViewPlugin,
12
- type ViewUpdate,
13
- WidgetType,
14
- } from '@codemirror/view';
15
-
16
- import { Event } from '@dxos/async';
17
- import { Context } from '@dxos/context';
18
-
19
- import { Cursor, type CursorConverter, singleValueFacet } from '../../util';
20
-
21
- export interface AwarenessProvider {
22
- remoteStateChange: Event<void>;
23
-
24
- open(): void;
25
- close(): void;
26
-
27
- getRemoteStates(): AwarenessState[];
28
- update(position: AwarenessPosition | undefined): void;
29
- }
30
-
31
- const dummyProvider: AwarenessProvider = {
32
- remoteStateChange: new Event(),
33
-
34
- open: () => {},
35
- close: () => {},
36
-
37
- getRemoteStates: () => [],
38
- update: () => {},
39
- };
40
-
41
- export const awarenessProvider = singleValueFacet<AwarenessProvider>(dummyProvider);
42
-
43
- // TODO(dmaretskyi): Specify the users that actually changed. Currently, we recalculate positions for every user.
44
- const RemoteSelectionChangedAnnotation = Annotation.define();
45
-
46
- export type AwarenessPosition = {
47
- anchor?: string;
48
- head?: string;
49
- };
50
-
51
- export type AwarenessInfo = {
52
- displayName: string;
53
- darkColor: string;
54
- lightColor: string;
55
- };
56
-
57
- export type AwarenessState = {
58
- position?: AwarenessPosition;
59
- peerId: string;
60
- info: AwarenessInfo;
61
- };
62
-
63
- /**
64
- * Extension provides presence information about other peers.
65
- */
66
- export const awareness = (provider = dummyProvider): Extension => {
67
- return [
68
- awarenessProvider.of(provider),
69
- ViewPlugin.fromClass(RemoteSelectionsDecorator, {
70
- decorations: (value) => value.decorations,
71
- }),
72
- styles,
73
- ];
74
- };
75
-
76
- /**
77
- * Generates selection decorations from remote peers.
78
- */
79
- export class RemoteSelectionsDecorator implements PluginValue {
80
- private readonly _ctx = new Context();
81
- private readonly _cursorConverter: CursorConverter;
82
- private readonly _provider: AwarenessProvider;
83
-
84
- private _lastAnchor?: number;
85
- private _lastHead?: number;
86
-
87
- public decorations: DecorationSet = RangeSet.of([]);
88
-
89
- constructor(view: EditorView) {
90
- this._cursorConverter = view.state.facet(Cursor.converter);
91
- this._provider = view.state.facet(awarenessProvider);
92
- this._provider.open();
93
- this._provider.remoteStateChange.on(this._ctx, () => {
94
- view.dispatch({ annotations: [RemoteSelectionChangedAnnotation.of([])] });
95
- });
96
- }
97
-
98
- destroy(): void {
99
- void this._ctx.dispose();
100
- this._provider.close();
101
- }
102
-
103
- update(update: ViewUpdate): void {
104
- this._updateLocalSelection(update.view);
105
- this._updateRemoteSelections(update.view);
106
- }
107
-
108
- private _updateLocalSelection(view: EditorView): void {
109
- const hasFocus = view.hasFocus && view.dom.ownerDocument.hasFocus();
110
- const { anchor = undefined, head = undefined } = hasFocus ? view.state.selection.main : {};
111
- if (this._lastAnchor === anchor && this._lastHead === head) {
112
- return;
113
- }
114
-
115
- this._lastAnchor = anchor;
116
- this._lastHead = head;
117
-
118
- this._provider.update(
119
- anchor !== undefined && head !== undefined
120
- ? {
121
- anchor: this._cursorConverter.toCursor(anchor),
122
- head: this._cursorConverter.toCursor(head, -1),
123
- }
124
- : undefined,
125
- );
126
- }
127
-
128
- private _updateRemoteSelections(view: EditorView): void {
129
- const decorations: Range<Decoration>[] = [
130
- // TODO(burdon): Factor out for testing.
131
- // {
132
- // from: 0,
133
- // to: 0,
134
- // value: Decoration.widget({ side: 0, block: false, widget: new RemoteCaretWidget('Test', 'red') }),
135
- // },
136
- ];
137
-
138
- const awarenessStates = this._provider.getRemoteStates();
139
- for (const state of awarenessStates) {
140
- const anchor = state.position?.anchor ? this._cursorConverter.fromCursor(state.position.anchor) : null;
141
- const head = state.position?.head ? this._cursorConverter.fromCursor(state.position.head) : null;
142
- if (anchor == null || head == null) {
143
- continue;
144
- }
145
-
146
- const start = Math.min(Math.min(anchor, head), view.state.doc.length);
147
- const end = Math.min(Math.max(anchor, head), view.state.doc.length);
148
-
149
- const startLine = view.state.doc.lineAt(start);
150
- const endLine = view.state.doc.lineAt(end);
151
-
152
- const darkColor = state.info.darkColor;
153
- const lightColor = state.info.lightColor;
154
-
155
- if (startLine.number === endLine.number) {
156
- // Selected content in a single line.
157
- decorations.push({
158
- from: start,
159
- to: end,
160
- value: Decoration.mark({
161
- attributes: { style: `background-color: ${lightColor}` },
162
- class: 'cm-collab-selection',
163
- }),
164
- });
165
- } else {
166
- // Selected content in multiple lines; first, render text-selection in the first line.
167
- decorations.push({
168
- from: start,
169
- to: startLine.from + startLine.length,
170
- value: Decoration.mark({
171
- attributes: { style: `background-color: ${lightColor}` },
172
- class: 'cm-collab-selection',
173
- }),
174
- });
175
-
176
- // Render text-selection in the last line.
177
- decorations.push({
178
- from: endLine.from,
179
- to: end,
180
- value: Decoration.mark({
181
- attributes: { style: `background-color: ${lightColor}` },
182
- class: 'cm-collab-selection',
183
- }),
184
- });
185
-
186
- for (let i = startLine.number + 1; i < endLine.number; i++) {
187
- const linePos = view.state.doc.line(i).from;
188
- decorations.push({
189
- from: linePos,
190
- to: linePos,
191
- value: Decoration.line({
192
- attributes: { style: `background-color: ${lightColor}`, class: 'cm-collab-selectionLine' },
193
- }),
194
- });
195
- }
196
- }
197
-
198
- decorations.push({
199
- from: head,
200
- to: head,
201
- value: Decoration.widget({
202
- side: head - anchor > 0 ? -1 : 1, // The local cursor should be rendered outside the remote selection.
203
- block: false,
204
- widget: new RemoteCaretWidget(state.info.displayName ?? 'Anonymous', darkColor),
205
- }),
206
- });
207
- }
208
-
209
- this.decorations = Decoration.set(decorations, true);
210
- }
211
- }
212
-
213
- class RemoteCaretWidget extends WidgetType {
214
- constructor(
215
- private readonly _name: string,
216
- private readonly _color: string,
217
- ) {
218
- super();
219
- }
220
-
221
- override toDOM(): HTMLElement {
222
- const span = document.createElement('span');
223
- span.className = 'cm-collab-selectionCaret';
224
- span.style.backgroundColor = this._color;
225
- span.style.borderColor = this._color;
226
-
227
- const dot = document.createElement('div');
228
- dot.className = 'cm-collab-selectionCaretDot';
229
-
230
- const info = document.createElement('div');
231
- info.className = 'cm-collab-selectionInfo';
232
- info.innerText = this._name;
233
-
234
- span.appendChild(document.createTextNode('\u2060'));
235
- span.appendChild(dot);
236
- span.appendChild(document.createTextNode('\u2060'));
237
- span.appendChild(info);
238
- span.appendChild(document.createTextNode('\u2060'));
239
- return span;
240
- }
241
-
242
- override updateDOM(): boolean {
243
- return false;
244
- }
245
-
246
- override eq(widget: this): boolean {
247
- return widget._color === this._color;
248
- }
249
-
250
- override get estimatedHeight() {
251
- return -1;
252
- }
253
-
254
- override ignoreEvent(): boolean {
255
- return true;
256
- }
257
- }
258
-
259
- const styles = EditorView.theme({
260
- '.cm-collab-selection': {},
261
- '.cm-collab-selectionLine': {
262
- padding: 0,
263
- margin: '0px 2px 0px 4px',
264
- },
265
- '.cm-collab-selectionCaret': {
266
- position: 'relative',
267
- borderLeft: '1px solid black',
268
- borderRight: '1px solid black',
269
- marginLeft: '-1px',
270
- marginRight: '-1px',
271
- boxSizing: 'border-box',
272
- display: 'inline',
273
- cursor: 'pointer',
274
- },
275
- '.cm-collab-selectionCaretDot': {
276
- borderRadius: '50%',
277
- position: 'absolute',
278
- width: '.5em',
279
- height: '.5em',
280
- top: '-.25em',
281
- left: '-.25em',
282
- backgroundColor: 'inherit',
283
- transition: 'transform .3s ease-in-out',
284
- boxSizing: 'border-box',
285
- },
286
- '.cm-collab-selectionCaret:hover > .cm-collab-selectionCaretDot': {
287
- transform: 'scale(0)',
288
- transformOrigin: 'center',
289
- },
290
- '.cm-collab-selectionInfo': {
291
- position: 'absolute',
292
- transform: 'translate(-50%, 0)',
293
- top: '-20px',
294
- left: 0,
295
- fontSize: '.75em',
296
- fontFamily: 'sans-serif',
297
- fontStyle: 'normal',
298
- fontWeight: 'normal',
299
- lineHeight: 'normal',
300
- userSelect: 'none',
301
- color: 'white',
302
- padding: '2px 6px',
303
- zIndex: 101,
304
- transition: 'opacity .3s ease-in-out',
305
- backgroundColor: 'inherit',
306
- borderRadius: '2px',
307
- opacity: 0,
308
- transitionDelay: '0s',
309
- whiteSpace: 'nowrap',
310
- },
311
- '.cm-collab-selectionCaret:hover > .cm-collab-selectionInfo': {
312
- opacity: 1,
313
- transitionDelay: '0s',
314
- },
315
- });