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

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 (321) hide show
  1. package/dist/lib/browser/{chunk-22UMM3QJ.mjs → chunk-HL3YF6WC.mjs} +2 -2
  2. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +4225 -3369
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +71 -1
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/browser/types/index.mjs +1 -1
  9. package/dist/lib/node-esm/{chunk-YXYQPV6R.mjs → chunk-YJZGD3LY.mjs} +2 -2
  10. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +7 -0
  11. package/dist/lib/node-esm/index.mjs +4225 -3369
  12. package/dist/lib/node-esm/index.mjs.map +4 -4
  13. package/dist/lib/node-esm/meta.json +1 -1
  14. package/dist/lib/node-esm/testing/index.mjs +71 -1
  15. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  16. package/dist/lib/node-esm/types/index.mjs +1 -1
  17. package/dist/types/src/components/Editor/Editor.d.ts +24 -9
  18. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  19. package/dist/types/src/components/Editor/Editor.stories.d.ts +27 -0
  20. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +17 -2
  22. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  23. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  25. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  27. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  29. package/dist/types/src/components/EditorToolbar/util.d.ts +6 -20
  30. package/dist/types/src/components/EditorToolbar/util.d.ts.map +1 -1
  31. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +1 -1
  32. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  33. package/dist/types/src/components/index.d.ts +0 -1
  34. package/dist/types/src/components/index.d.ts.map +1 -1
  35. package/dist/types/src/defaults.d.ts.map +1 -1
  36. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +26 -0
  37. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +1 -0
  38. package/dist/types/src/extensions/autocomplete/index.d.ts +5 -0
  39. package/dist/types/src/extensions/autocomplete/index.d.ts.map +1 -0
  40. package/dist/types/src/extensions/autocomplete/match.d.ts +13 -0
  41. package/dist/types/src/extensions/autocomplete/match.d.ts.map +1 -0
  42. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +20 -0
  43. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +1 -0
  44. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +10 -0
  45. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +1 -0
  46. package/dist/types/src/extensions/automerge/automerge.d.ts +1 -1
  47. package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
  48. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +10 -19
  49. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
  50. package/dist/types/src/extensions/automerge/cursor.d.ts +1 -1
  51. package/dist/types/src/extensions/automerge/cursor.d.ts.map +1 -1
  52. package/dist/types/src/extensions/automerge/defs.d.ts +1 -1
  53. package/dist/types/src/extensions/automerge/defs.d.ts.map +1 -1
  54. package/dist/types/src/extensions/automerge/sync.d.ts +3 -3
  55. package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
  56. package/dist/types/src/extensions/automerge/update-automerge.d.ts +1 -1
  57. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
  58. package/dist/types/src/extensions/autoscroll.d.ts +10 -0
  59. package/dist/types/src/extensions/autoscroll.d.ts.map +1 -0
  60. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +1 -1
  61. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +1 -1
  62. package/dist/types/src/extensions/comments.d.ts +1 -1
  63. package/dist/types/src/extensions/comments.d.ts.map +1 -1
  64. package/dist/types/src/extensions/dnd.d.ts.map +1 -1
  65. package/dist/types/src/extensions/factories.d.ts +20 -19
  66. package/dist/types/src/extensions/factories.d.ts.map +1 -1
  67. package/dist/types/src/extensions/focus.d.ts.map +1 -1
  68. package/dist/types/src/extensions/folding.d.ts.map +1 -1
  69. package/dist/types/src/extensions/index.d.ts +4 -1
  70. package/dist/types/src/extensions/index.d.ts.map +1 -1
  71. package/dist/types/src/extensions/json.d.ts +1 -1
  72. package/dist/types/src/extensions/json.d.ts.map +1 -1
  73. package/dist/types/src/extensions/listener.d.ts +8 -6
  74. package/dist/types/src/extensions/listener.d.ts.map +1 -1
  75. package/dist/types/src/extensions/markdown/action.d.ts.map +1 -1
  76. package/dist/types/src/extensions/markdown/bundle.d.ts +8 -2
  77. package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
  78. package/dist/types/src/extensions/markdown/changes.d.ts +1 -1
  79. package/dist/types/src/extensions/markdown/changes.d.ts.map +1 -1
  80. package/dist/types/src/extensions/markdown/decorate.d.ts +9 -1
  81. package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
  82. package/dist/types/src/extensions/markdown/formatting.d.ts +2 -3
  83. package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
  84. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +1 -1
  85. package/dist/types/src/extensions/markdown/highlight.d.ts.map +1 -1
  86. package/dist/types/src/extensions/markdown/image.d.ts.map +1 -1
  87. package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
  88. package/dist/types/src/extensions/modes.d.ts +1 -1
  89. package/dist/types/src/extensions/modes.d.ts.map +1 -1
  90. package/dist/types/src/extensions/outliner/menu.d.ts +8 -0
  91. package/dist/types/src/extensions/outliner/menu.d.ts.map +1 -0
  92. package/dist/types/src/extensions/outliner/outliner.d.ts +1 -1
  93. package/dist/types/src/extensions/outliner/outliner.d.ts.map +1 -1
  94. package/dist/types/src/extensions/outliner/selection.d.ts.map +1 -1
  95. package/dist/types/src/extensions/outliner/tree.d.ts +2 -2
  96. package/dist/types/src/extensions/outliner/tree.d.ts.map +1 -1
  97. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts +36 -0
  98. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +1 -0
  99. package/dist/types/src/extensions/popover/index.d.ts +8 -0
  100. package/dist/types/src/extensions/popover/index.d.ts.map +1 -0
  101. package/dist/types/src/extensions/popover/menu-presets.d.ts +4 -0
  102. package/dist/types/src/extensions/popover/menu-presets.d.ts.map +1 -0
  103. package/dist/types/src/extensions/popover/menu.d.ts +24 -0
  104. package/dist/types/src/extensions/popover/menu.d.ts.map +1 -0
  105. package/dist/types/src/extensions/popover/modal.d.ts +7 -0
  106. package/dist/types/src/extensions/popover/modal.d.ts.map +1 -0
  107. package/dist/types/src/extensions/popover/popover.d.ts +47 -0
  108. package/dist/types/src/extensions/popover/popover.d.ts.map +1 -0
  109. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +34 -0
  110. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +1 -0
  111. package/dist/types/src/extensions/popover/util.d.ts +8 -0
  112. package/dist/types/src/extensions/popover/util.d.ts.map +1 -0
  113. package/dist/types/src/extensions/preview/preview.d.ts +8 -8
  114. package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
  115. package/dist/types/src/extensions/state.d.ts +2 -0
  116. package/dist/types/src/extensions/state.d.ts.map +1 -0
  117. package/dist/types/src/extensions/tags/extended-markdown.d.ts +10 -0
  118. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +1 -0
  119. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +2 -0
  120. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +1 -0
  121. package/dist/types/src/extensions/tags/index.d.ts +4 -0
  122. package/dist/types/src/extensions/tags/index.d.ts.map +1 -0
  123. package/dist/types/src/extensions/tags/streamer.d.ts +12 -0
  124. package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -0
  125. package/dist/types/src/extensions/tags/xml-tags.d.ts +72 -0
  126. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -0
  127. package/dist/types/src/extensions/tags/xml-util.d.ts +10 -0
  128. package/dist/types/src/extensions/tags/xml-util.d.ts.map +1 -0
  129. package/dist/types/src/hooks/useTextEditor.d.ts +4 -8
  130. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  131. package/dist/types/src/stories/CommandDialog.stories.d.ts +14 -0
  132. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  133. package/dist/types/src/stories/Comments.stories.d.ts +21 -10
  134. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  135. package/dist/types/src/stories/EditorToolbar.stories.d.ts +39 -3
  136. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  137. package/dist/types/src/stories/Experimental.stories.d.ts +22 -13
  138. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  139. package/dist/types/src/stories/Markdown.stories.d.ts +32 -43
  140. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  141. package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
  142. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  143. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  144. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  145. package/dist/types/src/stories/Preview.stories.d.ts +21 -7
  146. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  147. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  148. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  149. package/dist/types/src/stories/TextEditor.stories.d.ts +37 -52
  150. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  151. package/dist/types/src/stories/components/EditorStory.d.ts +6 -9
  152. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  153. package/dist/types/src/styles/theme.d.ts.map +1 -1
  154. package/dist/types/src/testing/PreviewPopover.d.ts +20 -0
  155. package/dist/types/src/testing/PreviewPopover.d.ts.map +1 -0
  156. package/dist/types/src/testing/index.d.ts +1 -0
  157. package/dist/types/src/testing/index.d.ts.map +1 -1
  158. package/dist/types/src/testing/util.d.ts +1 -0
  159. package/dist/types/src/testing/util.d.ts.map +1 -1
  160. package/dist/types/src/translations.d.ts +1 -1
  161. package/dist/types/src/types/types.d.ts +2 -2
  162. package/dist/types/src/types/types.d.ts.map +1 -1
  163. package/dist/types/src/util/cursor.d.ts.map +1 -1
  164. package/dist/types/src/util/debug.d.ts +1 -1
  165. package/dist/types/src/util/debug.d.ts.map +1 -1
  166. package/dist/types/src/util/decorations.d.ts +4 -0
  167. package/dist/types/src/util/decorations.d.ts.map +1 -0
  168. package/dist/types/src/util/dom.d.ts +2 -12
  169. package/dist/types/src/util/dom.d.ts.map +1 -1
  170. package/dist/types/src/util/index.d.ts +1 -0
  171. package/dist/types/src/util/index.d.ts.map +1 -1
  172. package/dist/types/src/util/react.d.ts +1 -1
  173. package/dist/types/src/util/react.d.ts.map +1 -1
  174. package/dist/types/tsconfig.tsbuildinfo +1 -1
  175. package/package.json +71 -61
  176. package/src/components/Editor/Editor.stories.tsx +69 -0
  177. package/src/components/Editor/Editor.tsx +58 -15
  178. package/src/components/EditorToolbar/EditorToolbar.tsx +104 -93
  179. package/src/components/EditorToolbar/blocks.ts +22 -25
  180. package/src/components/EditorToolbar/formatting.ts +22 -25
  181. package/src/components/EditorToolbar/headings.ts +16 -9
  182. package/src/components/EditorToolbar/image.ts +8 -4
  183. package/src/components/EditorToolbar/lists.ts +16 -19
  184. package/src/components/EditorToolbar/search.ts +8 -4
  185. package/src/components/EditorToolbar/util.ts +18 -23
  186. package/src/components/EditorToolbar/view-mode.ts +11 -6
  187. package/src/components/index.ts +0 -1
  188. package/src/defaults.ts +5 -2
  189. package/src/extensions/autocomplete/autocomplete.ts +220 -0
  190. package/src/extensions/autocomplete/index.ts +8 -0
  191. package/src/extensions/autocomplete/match.ts +46 -0
  192. package/src/extensions/{command → autocomplete}/placeholder.ts +22 -18
  193. package/src/extensions/{command → autocomplete}/typeahead.ts +8 -50
  194. package/src/extensions/automerge/automerge.stories.tsx +31 -24
  195. package/src/extensions/automerge/automerge.ts +31 -11
  196. package/src/extensions/automerge/cursor.ts +1 -1
  197. package/src/extensions/automerge/defs.ts +1 -1
  198. package/src/extensions/automerge/sync.ts +9 -5
  199. package/src/extensions/automerge/update-automerge.ts +2 -2
  200. package/src/extensions/autoscroll.ts +157 -0
  201. package/src/extensions/awareness/awareness-provider.ts +2 -2
  202. package/src/extensions/awareness/awareness.ts +2 -2
  203. package/src/extensions/comments.ts +18 -13
  204. package/src/extensions/dnd.ts +1 -1
  205. package/src/extensions/factories.ts +55 -37
  206. package/src/extensions/focus.ts +5 -4
  207. package/src/extensions/folding.tsx +4 -6
  208. package/src/extensions/hashtag.tsx +2 -2
  209. package/src/extensions/index.ts +4 -1
  210. package/src/extensions/json.ts +1 -1
  211. package/src/extensions/listener.ts +14 -20
  212. package/src/extensions/markdown/action.ts +2 -1
  213. package/src/extensions/markdown/bundle.ts +40 -6
  214. package/src/extensions/markdown/changes.ts +1 -1
  215. package/src/extensions/markdown/decorate.ts +24 -14
  216. package/src/extensions/markdown/formatting.test.ts +6 -6
  217. package/src/extensions/markdown/formatting.ts +11 -11
  218. package/src/extensions/markdown/highlight.ts +1 -1
  219. package/src/extensions/markdown/image.ts +3 -4
  220. package/src/extensions/markdown/link.ts +3 -0
  221. package/src/extensions/markdown/table.ts +7 -1
  222. package/src/extensions/mention.ts +1 -1
  223. package/src/extensions/modes.ts +2 -2
  224. package/src/extensions/{command/floating-menu.ts → outliner/menu.ts} +16 -21
  225. package/src/extensions/outliner/outliner.test.ts +3 -2
  226. package/src/extensions/outliner/outliner.ts +7 -6
  227. package/src/extensions/outliner/selection.ts +1 -1
  228. package/src/extensions/outliner/tree.test.ts +2 -1
  229. package/src/extensions/outliner/tree.ts +2 -2
  230. package/src/extensions/popover/PopoverMenuProvider.tsx +220 -0
  231. package/src/extensions/popover/index.ts +12 -0
  232. package/src/extensions/popover/menu-presets.ts +124 -0
  233. package/src/extensions/popover/menu.ts +67 -0
  234. package/src/extensions/popover/modal.ts +24 -0
  235. package/src/extensions/popover/popover.ts +289 -0
  236. package/src/extensions/popover/usePopoverMenu.ts +173 -0
  237. package/src/extensions/popover/util.ts +29 -0
  238. package/src/extensions/preview/index.ts +1 -1
  239. package/src/extensions/preview/preview.ts +67 -67
  240. package/src/extensions/selection.ts +2 -2
  241. package/src/extensions/state.ts +7 -0
  242. package/src/extensions/tags/extended-markdown.test.ts +261 -0
  243. package/src/extensions/tags/extended-markdown.ts +78 -0
  244. package/src/extensions/tags/index.ts +7 -0
  245. package/src/extensions/tags/streamer.ts +243 -0
  246. package/src/extensions/tags/xml-tags.ts +393 -0
  247. package/src/extensions/tags/xml-util.ts +94 -0
  248. package/src/hooks/useTextEditor.ts +27 -39
  249. package/src/stories/CommandDialog.stories.tsx +78 -0
  250. package/src/stories/Comments.stories.tsx +14 -10
  251. package/src/stories/EditorToolbar.stories.tsx +17 -17
  252. package/src/stories/Experimental.stories.tsx +17 -13
  253. package/src/stories/Markdown.stories.tsx +25 -21
  254. package/src/stories/Outliner.stories.tsx +54 -35
  255. package/src/stories/Popover.stories.tsx +163 -0
  256. package/src/stories/Preview.stories.tsx +49 -41
  257. package/src/stories/Tags.stories.tsx +81 -0
  258. package/src/stories/TextEditor.stories.tsx +41 -60
  259. package/src/stories/components/EditorStory.tsx +17 -16
  260. package/src/styles/theme.ts +18 -15
  261. package/src/testing/PreviewPopover.tsx +80 -0
  262. package/src/testing/index.ts +1 -0
  263. package/src/testing/util.ts +2 -0
  264. package/src/translations.ts +1 -1
  265. package/src/types/types.ts +1 -1
  266. package/src/util/cursor.ts +2 -1
  267. package/src/util/debug.ts +2 -2
  268. package/src/util/decorations.ts +21 -0
  269. package/src/util/dom.ts +5 -27
  270. package/src/util/index.ts +1 -0
  271. package/src/util/react.tsx +1 -1
  272. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  273. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  274. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  275. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  276. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  277. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  278. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  279. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  280. package/dist/types/src/components/Popover/index.d.ts +0 -4
  281. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  282. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  283. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  284. package/dist/types/src/extensions/command/action.d.ts +0 -17
  285. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  286. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  287. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  288. package/dist/types/src/extensions/command/command.d.ts +0 -6
  289. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  290. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  291. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  292. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  293. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  294. package/dist/types/src/extensions/command/index.d.ts +0 -7
  295. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  296. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  297. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  298. package/dist/types/src/extensions/command/state.d.ts +0 -16
  299. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  300. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  301. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  302. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  303. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  304. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  305. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  306. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  307. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  308. package/src/components/Popover/CommandMenu.tsx +0 -279
  309. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  310. package/src/components/Popover/RefPopover.tsx +0 -99
  311. package/src/components/Popover/index.ts +0 -7
  312. package/src/extensions/autocomplete.ts +0 -69
  313. package/src/extensions/command/action.ts +0 -56
  314. package/src/extensions/command/command-menu.ts +0 -210
  315. package/src/extensions/command/command.ts +0 -34
  316. package/src/extensions/command/hint.ts +0 -102
  317. package/src/extensions/command/index.ts +0 -10
  318. package/src/extensions/command/state.ts +0 -89
  319. package/src/extensions/command/useCommandMenu.ts +0 -118
  320. package/src/stories/Command.stories.tsx +0 -97
  321. package/src/stories/CommandMenu.stories.tsx +0 -159
@@ -5,25 +5,26 @@
5
5
  import { invertedEffects } from '@codemirror/commands';
6
6
  import { type ChangeDesc, type Extension, StateEffect, StateField, type Text } from '@codemirror/state';
7
7
  import {
8
- hoverTooltip,
9
- keymap,
10
8
  type Command,
11
9
  Decoration,
12
10
  EditorView,
13
- type Rect,
14
11
  type PluginValue,
12
+ type Rect,
15
13
  ViewPlugin,
14
+ hoverTooltip,
15
+ keymap,
16
16
  } from '@codemirror/view';
17
17
  import sortBy from 'lodash.sortby';
18
18
  import { useEffect } from 'react';
19
19
 
20
- import { debounce, type CleanupFn } from '@dxos/async';
20
+ import { type CleanupFn, debounce } from '@dxos/async';
21
21
  import { log } from '@dxos/log';
22
22
  import { isNonNullable } from '@dxos/util';
23
23
 
24
+ import { type Comment, type Range, type RenderCallback } from '../types';
25
+ import { Cursor, callbackWrapper, singleValueFacet } from '../util';
26
+
24
27
  import { documentId } from './selection';
25
- import { type RenderCallback, type Comment, type Range } from '../types';
26
- import { Cursor, singleValueFacet, callbackWrapper } from '../util';
27
28
 
28
29
  //
29
30
  // State management.
@@ -57,7 +58,11 @@ const setCommentState = StateEffect.define<CommentsState>();
57
58
  * The ranges are tracked as Automerge cursors from which the absolute indexed ranges can be computed.
58
59
  */
59
60
  export const commentsState = StateField.define<CommentsState>({
60
- create: (state) => ({ id: state.facet(documentId), comments: [], selection: {} }),
61
+ create: (state) => ({
62
+ id: state.facet(documentId),
63
+ comments: [],
64
+ selection: {},
65
+ }),
61
66
  update: (value, tr) => {
62
67
  for (const effect of tr.effects) {
63
68
  // Update selection.
@@ -98,16 +103,16 @@ export const commentsState = StateField.define<CommentsState>({
98
103
  */
99
104
  const styles = EditorView.theme({
100
105
  '.cm-comment, .cm-comment-current': {
101
- margin: '0 -3px',
102
- padding: '3px',
103
- borderRadius: '3px',
106
+ padding: '3px 0',
107
+ backgroundColor: 'var(--dx-cmCommentSurface)',
108
+ },
109
+ '.cm-comment > span, .cm-comment-current > span': {
110
+ boxDecorationBreak: 'clone',
111
+ boxShadow: '0 0 1px 3px var(--dx-cmCommentSurface)',
104
112
  backgroundColor: 'var(--dx-cmCommentSurface)',
105
113
  color: 'var(--dx-cmComment)',
106
114
  cursor: 'pointer',
107
115
  },
108
- '.cm-comment:hover, .cm-comment-current': {
109
- textDecoration: 'underline',
110
- },
111
116
  });
112
117
 
113
118
  const createCommentMark = (id: string, isCurrent: boolean) =>
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import type { Extension } from '@codemirror/state';
6
- import { dropCursor, EditorView } from '@codemirror/view';
6
+ import { EditorView, dropCursor } from '@codemirror/view';
7
7
 
8
8
  export type DNDOptions = { onDrop?: (view: EditorView, event: { files: FileList }) => void };
9
9
 
@@ -4,10 +4,9 @@
4
4
 
5
5
  import { closeBrackets, closeBracketsKeymap } from '@codemirror/autocomplete';
6
6
  import { defaultKeymap, history, historyKeymap, indentWithTab, standardKeymap } from '@codemirror/commands';
7
- import { bracketMatching, defaultHighlightStyle, syntaxHighlighting } from '@codemirror/language';
7
+ import { HighlightStyle, bracketMatching, syntaxHighlighting } from '@codemirror/language';
8
8
  import { searchKeymap } from '@codemirror/search';
9
- import { EditorState, type Extension } from '@codemirror/state';
10
- import { oneDarkHighlightStyle } from '@codemirror/theme-one-dark';
9
+ import { type ChangeSpec, EditorState, type Extension, type TransactionSpec } from '@codemirror/state';
11
10
  import {
12
11
  EditorView,
13
12
  type KeyBinding,
@@ -20,33 +19,58 @@ import {
20
19
  placeholder,
21
20
  scrollPastEnd,
22
21
  } from '@codemirror/view';
22
+ import { vscodeDarkStyle, vscodeLightStyle } from '@uiw/codemirror-theme-vscode';
23
23
  import defaultsDeep from 'lodash.defaultsdeep';
24
24
  import merge from 'lodash.merge';
25
25
 
26
+ import { type DocAccessor, type Space } from '@dxos/client/echo';
27
+ import { type Identity } from '@dxos/client/halo';
26
28
  import { generateName } from '@dxos/display-name';
27
29
  import { log } from '@dxos/log';
28
- import { type DocAccessor, type Space } from '@dxos/react-client/echo';
29
- import { type Identity } from '@dxos/react-client/halo';
30
30
  import { type ThemeMode } from '@dxos/react-ui';
31
31
  import { type HuePalette } from '@dxos/react-ui-theme';
32
- import { hexToHue, isNotFalsy } from '@dxos/util';
32
+ import { hexToHue, isTruthy } from '@dxos/util';
33
+
34
+ import { editorGutter, editorMonospace } from '../defaults';
35
+ import { type ThemeStyles, defaultTheme } from '../styles';
33
36
 
34
37
  import { automerge } from './automerge';
35
38
  import { SpaceAwarenessProvider, awareness } from './awareness';
36
39
  import { focus } from './focus';
37
- import { editorGutter, editorMonospace } from '../defaults';
38
- import { type ThemeStyles, defaultTheme } from '../styles';
39
40
 
40
41
  //
41
42
  // Basic
42
43
  //
43
44
 
44
- export const preventNewline = EditorState.transactionFilter.of((tr) => (tr.newDoc.lines > 1 ? [] : tr));
45
+ export const filterChars = (chars: RegExp) => {
46
+ return EditorState.transactionFilter.of((transaction) => {
47
+ if (!transaction.docChanged) return transaction;
48
+
49
+ const changes: ChangeSpec[] = [];
50
+ transaction.changes.iterChanges((fromA, toA, fromB, toB, text) => {
51
+ const inserted = text.toString();
52
+ const filtered = inserted.replace(chars, '');
53
+ if (inserted !== filtered) {
54
+ changes.push({
55
+ from: fromB,
56
+ to: toB,
57
+ insert: filtered,
58
+ });
59
+ }
60
+ });
61
+
62
+ if (changes.length) {
63
+ return [transaction, { changes, sequential: true } as TransactionSpec];
64
+ }
65
+ return transaction;
66
+ });
67
+ };
45
68
 
46
69
  /**
47
70
  * https://codemirror.net/docs/extensions
48
71
  * https://github.com/codemirror/basic-setup
49
72
  * https://github.com/codemirror/basic-setup/blob/main/src/codemirror.ts
73
+ * https://github.com/codemirror/theme-one-dark
50
74
  */
51
75
  export type BasicExtensionsOptions = {
52
76
  allowMultipleSelections?: boolean;
@@ -63,11 +87,11 @@ export type BasicExtensionsOptions = {
63
87
  lineNumbers?: boolean;
64
88
  /** If false then do not set a max-width or side margin on the editor. */
65
89
  lineWrapping?: boolean;
66
- monospace?: boolean;
67
90
  placeholder?: string;
68
91
  /** If true user cannot edit the text, but they can still select and copy it. */
69
92
  readOnly?: boolean;
70
93
  search?: boolean;
94
+ /** NOTE: Do not use with stack sections. */
71
95
  scrollPastEnd?: boolean;
72
96
  standardKeymap?: boolean;
73
97
  tabSize?: number;
@@ -82,7 +106,7 @@ const defaultBasicOptions: BasicExtensionsOptions = {
82
106
  history: true,
83
107
  keymap: 'standard',
84
108
  lineWrapping: true,
85
- search: true,
109
+ search: false,
86
110
  } as const;
87
111
 
88
112
  const keymaps: { [key: string]: readonly KeyBinding[] } = {
@@ -111,7 +135,6 @@ export const createBasicExtensions = (_props?: BasicExtensionsOptions): Extensio
111
135
  props.history && history(),
112
136
  props.lineNumbers && [lineNumbers(), editorGutter],
113
137
  props.lineWrapping && EditorView.lineWrapping,
114
- props.monospace && editorMonospace,
115
138
  props.placeholder && placeholder(props.placeholder),
116
139
  props.readOnly !== undefined && EditorState.readOnly.of(props.readOnly),
117
140
  props.scrollPastEnd && scrollPastEnd(),
@@ -137,9 +160,9 @@ export const createBasicExtensions = (_props?: BasicExtensionsOptions): Extensio
137
160
  preventDefault: true,
138
161
  run: () => true,
139
162
  },
140
- ].filter(isNotFalsy),
163
+ ].filter(isTruthy),
141
164
  ),
142
- ].filter(isNotFalsy);
165
+ ].filter(isTruthy);
143
166
  };
144
167
 
145
168
  //
@@ -148,6 +171,7 @@ export const createBasicExtensions = (_props?: BasicExtensionsOptions): Extensio
148
171
 
149
172
  export type ThemeExtensionsOptions = {
150
173
  themeMode?: ThemeMode;
174
+ monospace?: boolean;
151
175
  styles?: ThemeStyles;
152
176
  syntaxHighlighting?: boolean;
153
177
  slots?: {
@@ -157,22 +181,19 @@ export type ThemeExtensionsOptions = {
157
181
  scroll?: {
158
182
  className?: string;
159
183
  };
160
- scroller?: {
161
- className?: string;
162
- };
163
184
  content?: {
164
185
  className?: string;
165
186
  };
166
187
  };
167
188
  };
168
189
 
169
- export const grow = {
190
+ export const grow: ThemeExtensionsOptions['slots'] = {
170
191
  editor: {
171
192
  className: 'is-full bs-full',
172
193
  },
173
194
  } as const;
174
195
 
175
- export const fullWidth = {
196
+ export const fullWidth: ThemeExtensionsOptions['slots'] = {
176
197
  editor: {
177
198
  className: 'is-full',
178
199
  },
@@ -180,41 +201,39 @@ export const fullWidth = {
180
201
 
181
202
  export const defaultThemeSlots = grow;
182
203
 
204
+ export const defaultStyles = {
205
+ dark: vscodeDarkStyle,
206
+ light: vscodeLightStyle,
207
+ };
208
+
183
209
  /**
184
210
  * https://codemirror.net/examples/styling
185
211
  */
186
212
  export const createThemeExtensions = ({
187
213
  themeMode,
214
+ monospace,
188
215
  styles,
189
- syntaxHighlighting: _syntaxHighlighting,
190
- slots: _slots,
216
+ syntaxHighlighting: syntaxHighlightingProp,
217
+ slots: slotsParam,
191
218
  }: ThemeExtensionsOptions = {}): Extension => {
192
- const slots = defaultsDeep({}, _slots, defaultThemeSlots);
219
+ const slots = defaultsDeep({}, slotsParam, defaultThemeSlots);
193
220
  return [
194
221
  EditorView.darkTheme.of(themeMode === 'dark'),
195
222
  EditorView.baseTheme(styles ? merge({}, defaultTheme, styles) : defaultTheme),
196
- // https://github.com/codemirror/theme-one-dark
197
- _syntaxHighlighting &&
198
- (themeMode === 'dark' ? syntaxHighlighting(oneDarkHighlightStyle) : syntaxHighlighting(defaultHighlightStyle)),
223
+ monospace && editorMonospace,
224
+ syntaxHighlightingProp &&
225
+ syntaxHighlighting(HighlightStyle.define(themeMode === 'dark' ? defaultStyles.dark : defaultStyles.light)),
199
226
  slots.editor?.className && EditorView.editorAttributes.of({ class: slots.editor.className }),
200
227
  slots.content?.className && EditorView.contentAttributes.of({ class: slots.content.className }),
201
228
  slots.scroll?.className &&
202
229
  ViewPlugin.fromClass(
203
230
  class {
204
231
  constructor(view: EditorView) {
205
- view.scrollDOM.classList.add(slots.scroll.className);
232
+ view.scrollDOM.classList.add(...slots.scroll.className.split(/\s+/));
206
233
  }
207
234
  },
208
235
  ),
209
- slots.scroller?.className &&
210
- ViewPlugin.fromClass(
211
- class {
212
- constructor(view: EditorView) {
213
- view.dom.querySelector('.cm-scroller')?.classList.add(...slots.scroller.className.split(' '));
214
- }
215
- },
216
- ),
217
- ].filter(isNotFalsy);
236
+ ].filter(isTruthy);
218
237
  };
219
238
 
220
239
  //
@@ -238,7 +257,6 @@ export const createDataExtensions = <T>({ id, text, space, identity }: DataExten
238
257
  if (space && identity) {
239
258
  const peerId = identity?.identityKey.toHex();
240
259
  const hue = (identity?.profile?.data?.hue as HuePalette | undefined) ?? hexToHue(peerId ?? '0');
241
-
242
260
  extensions.push(
243
261
  awareness(
244
262
  new SpaceAwarenessProvider({
@@ -246,9 +264,9 @@ export const createDataExtensions = <T>({ id, text, space, identity }: DataExten
246
264
  channel: `awareness.${id}`,
247
265
  peerId: identity.identityKey.toHex(),
248
266
  info: {
249
- displayName: identity.profile?.displayName ?? generateName(identity.identityKey.toHex()),
250
267
  darkColor: `var(--dx-${hue}Cursor)`,
251
268
  lightColor: `var(--dx-${hue}Cursor)`,
269
+ displayName: identity.profile?.displayName ?? generateName(identity.identityKey.toHex()),
252
270
  },
253
271
  }),
254
272
  ),
@@ -15,6 +15,7 @@ export const focusField = StateField.define<boolean>({
15
15
  return effect.value;
16
16
  }
17
17
  }
18
+
18
19
  return value;
19
20
  },
20
21
  });
@@ -25,11 +26,11 @@ export const focusField = StateField.define<boolean>({
25
26
  export const focus = [
26
27
  focusField,
27
28
  EditorView.domEventHandlers({
28
- focus: (event, view) => {
29
- setTimeout(() => view.dispatch({ effects: focusEffect.of(true) }));
29
+ focus: (_event, view) => {
30
+ requestAnimationFrame(() => view.dispatch({ effects: focusEffect.of(true) }));
30
31
  },
31
- blur: (event, view) => {
32
- setTimeout(() => view.dispatch({ effects: focusEffect.of(false) }));
32
+ blur: (_event, view) => {
33
+ requestAnimationFrame(() => view.dispatch({ effects: focusEffect.of(false) }));
33
34
  },
34
35
  }),
35
36
  ];
@@ -7,16 +7,15 @@ import { type Extension } from '@codemirror/state';
7
7
  import { EditorView } from '@codemirror/view';
8
8
  import React from 'react';
9
9
 
10
- import { Icon } from '@dxos/react-ui';
10
+ import { Domino, Icon } from '@dxos/react-ui';
11
11
 
12
- import { createElement, renderRoot } from '../util';
12
+ import { renderRoot } from '../util';
13
13
 
14
14
  export type FoldingOptions = {};
15
15
 
16
16
  /**
17
17
  * https://codemirror.net/examples/gutter
18
18
  */
19
- // TODO(burdon): Remember folding state (to state).
20
19
  export const folding = (_props: FoldingOptions = {}): Extension => [
21
20
  codeFolding({
22
21
  placeholderDOM: () => {
@@ -25,10 +24,9 @@ export const folding = (_props: FoldingOptions = {}): Extension => [
25
24
  }),
26
25
  foldGutter({
27
26
  markerDOM: (open) => {
28
- // TODO(burdon): Use sprite directly.
29
- const el = createElement('div', { className: 'flex h-full items-center' });
30
27
  return renderRoot(
31
- el,
28
+ Domino.of('div').classNames('flex h-full items-center').build(),
29
+ // TODO(burdon): Use sprite directly.
32
30
  <Icon icon='ph--caret-right--bold' size={3} classNames={['mx-3 cursor-pointer', open && 'rotate-90']} />,
33
31
  );
34
32
  },
@@ -13,7 +13,7 @@ import {
13
13
  WidgetType,
14
14
  } from '@codemirror/view';
15
15
 
16
- import { getHashColor, mx } from '@dxos/react-ui-theme';
16
+ import { getHashStyles, mx } from '@dxos/react-ui-theme';
17
17
 
18
18
  class TagWidget extends WidgetType {
19
19
  constructor(private _text: string) {
@@ -22,7 +22,7 @@ class TagWidget extends WidgetType {
22
22
 
23
23
  toDOM(): HTMLSpanElement {
24
24
  const span = document.createElement('span');
25
- span.className = mx('cm-tag', getHashColor(this._text).tag);
25
+ span.className = mx('cm-tag', getHashStyles(this._text).surface);
26
26
  span.textContent = this._text;
27
27
  return span;
28
28
  }
@@ -4,10 +4,10 @@
4
4
 
5
5
  export * from './annotations';
6
6
  export * from './autocomplete';
7
+ export * from './autoscroll';
7
8
  export * from './automerge';
8
9
  export * from './awareness';
9
10
  export * from './blast';
10
- export * from './command';
11
11
  export * from './comments';
12
12
  export * from './debug';
13
13
  export * from './dnd';
@@ -21,6 +21,9 @@ export * from './markdown';
21
21
  export * from './mention';
22
22
  export * from './modes';
23
23
  export * from './outliner';
24
+ export * from './popover';
24
25
  export * from './preview';
25
26
  export * from './selection';
27
+ export * from './state';
28
+ export * from './tags';
26
29
  export * from './typewriter';
@@ -7,7 +7,7 @@ import { type LintSource, linter } from '@codemirror/lint';
7
7
  import { type Extension } from '@codemirror/state';
8
8
  import Ajv, { type ValidateFunction } from 'ajv';
9
9
 
10
- import { type JsonSchemaType } from '@dxos/echo-schema';
10
+ import { type JsonSchemaType } from '@dxos/echo/internal';
11
11
 
12
12
  export type JsonExtensionsOptions = {
13
13
  schema?: JsonSchemaType;
@@ -5,34 +5,28 @@
5
5
  import { type Extension } from '@codemirror/state';
6
6
  import { EditorView } from '@codemirror/view';
7
7
 
8
+ import { isNonNullable } from '@dxos/util';
9
+
8
10
  import { documentId } from './selection';
9
11
 
10
12
  export type ListenerOptions = {
11
- onFocus?: (focusing: boolean) => void;
12
- onChange?: (text: string, id: string) => void;
13
+ onFocus?: (event: { id: string; focusing: boolean }) => void;
14
+ onChange?: (event: { id: string; text: string }) => void;
13
15
  };
14
16
 
15
- /**
16
- * Event listener.
17
- * @deprecated Use EditorView.updateListener and listen for specific update events.
18
- */
19
17
  export const listener = ({ onFocus, onChange }: ListenerOptions): Extension => {
20
- const extensions: Extension[] = [];
21
-
22
- onFocus &&
23
- extensions.push(
24
- EditorView.focusChangeEffect.of((_, focusing) => {
25
- onFocus(focusing);
18
+ return [
19
+ onFocus &&
20
+ EditorView.focusChangeEffect.of((state, focusing) => {
21
+ onFocus({ id: state.facet(documentId), focusing });
26
22
  return null;
27
23
  }),
28
- );
29
24
 
30
- onChange &&
31
- extensions.push(
32
- EditorView.updateListener.of((update) => {
33
- onChange(update.state.doc.toString(), update.state.facet(documentId));
25
+ onChange &&
26
+ EditorView.updateListener.of(({ state, docChanged }) => {
27
+ if (docChanged) {
28
+ onChange({ id: state.facet(documentId), text: state.doc.toString() });
29
+ }
34
30
  }),
35
- );
36
-
37
- return extensions;
31
+ ].filter(isNonNullable);
38
32
  };
@@ -7,6 +7,8 @@ import { type EditorView } from '@codemirror/view';
7
7
  import { type Action } from '@dxos/app-graph';
8
8
  import { type MenuActionProperties } from '@dxos/react-ui-menu';
9
9
 
10
+ import { createComment } from '../comments';
11
+
10
12
  import {
11
13
  Inline,
12
14
  List,
@@ -25,7 +27,6 @@ import {
25
27
  toggleList,
26
28
  toggleStyle,
27
29
  } from './formatting';
28
- import { createComment } from '../comments';
29
30
 
30
31
  export type PayloadType =
31
32
  | 'view-mode'
@@ -4,20 +4,23 @@
4
4
 
5
5
  import { completionKeymap } from '@codemirror/autocomplete';
6
6
  import { defaultKeymap, indentWithTab } from '@codemirror/commands';
7
- import { markdownLanguage, markdown } from '@codemirror/lang-markdown';
8
- import { syntaxHighlighting } from '@codemirror/language';
7
+ import { jsonLanguage } from '@codemirror/lang-json';
8
+ import { markdown, markdownLanguage } from '@codemirror/lang-markdown';
9
+ import { xml } from '@codemirror/lang-xml';
10
+ import { LanguageDescription, syntaxHighlighting } from '@codemirror/language';
9
11
  import { languages } from '@codemirror/language-data';
10
12
  import { type Extension } from '@codemirror/state';
11
13
  import { keymap } from '@codemirror/view';
14
+ import { type MarkdownConfig } from '@lezer/markdown';
12
15
 
13
- import { type ThemeMode } from '@dxos/react-ui';
14
- import { isNotFalsy } from '@dxos/util';
16
+ import { isTruthy } from '@dxos/util';
15
17
 
16
18
  import { markdownHighlightStyle, markdownTagsExtensions } from './highlight';
17
19
 
18
20
  export type MarkdownBundleOptions = {
19
- themeMode?: ThemeMode;
21
+ extensions?: MarkdownConfig[];
20
22
  indentWithTab?: boolean;
23
+ setextHeading?: boolean;
21
24
  };
22
25
 
23
26
  /**
@@ -42,6 +45,7 @@ export const createMarkdownExtensions = (options: MarkdownBundleOptions = {}): E
42
45
  base: markdownLanguage,
43
46
 
44
47
  // Languages for syntax highlighting fenced code blocks.
48
+ defaultCodeLanguage: jsonLanguage,
45
49
  codeLanguages: languages,
46
50
 
47
51
  // Don't complete HTML tags.
@@ -51,6 +55,7 @@ export const createMarkdownExtensions = (options: MarkdownBundleOptions = {}): E
51
55
  extensions: [
52
56
  // GFM provided by default.
53
57
  markdownTagsExtensions,
58
+ ...(options.extensions ?? defaultExtensions()),
54
59
  ],
55
60
  }),
56
61
 
@@ -64,8 +69,37 @@ export const createMarkdownExtensions = (options: MarkdownBundleOptions = {}): E
64
69
 
65
70
  // https://codemirror.net/docs/ref/#commands.defaultKeymap
66
71
  ...defaultKeymap,
72
+
73
+ // TODO(burdon): Remove?
67
74
  ...completionKeymap,
68
- ].filter(isNotFalsy),
75
+ ].filter(isTruthy),
69
76
  ),
70
77
  ];
71
78
  };
79
+
80
+ const xmlLanguageDesc = LanguageDescription.of({
81
+ name: 'xml',
82
+ alias: ['html', 'xhtml'],
83
+ extensions: ['xml', 'xhtml'],
84
+ load: async () => xml(),
85
+ });
86
+
87
+ /**
88
+ * Default customizations.
89
+ * https://github.com/lezer-parser/markdown/blob/main/src/markdown.ts
90
+ */
91
+ export const defaultExtensions = (): MarkdownConfig[] => [noSetExtHeading, noHtml];
92
+
93
+ /**
94
+ * Remove SetextHeading (e.g., headings created from "---").
95
+ */
96
+ const noSetExtHeading: MarkdownConfig = {
97
+ remove: ['SetextHeading'],
98
+ };
99
+
100
+ /**
101
+ * Remove HTML and XML parsing.
102
+ */
103
+ const noHtml: MarkdownConfig = {
104
+ // remove: ['HTMLBlock', 'HTMLTag'],
105
+ };
@@ -4,7 +4,7 @@
4
4
 
5
5
  import { syntaxTree } from '@codemirror/language';
6
6
  import { type ChangeSpec, Transaction } from '@codemirror/state';
7
- import { ViewPlugin, type ViewUpdate, type PluginValue } from '@codemirror/view';
7
+ import { type PluginValue, ViewPlugin, type ViewUpdate } from '@codemirror/view';
8
8
 
9
9
  /**
10
10
  * Monitors and augments changes.