@dxos/react-ui-editor 0.8.4-main.3a94e84 → 0.8.4-main.406dc2a

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 (310) 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 +4239 -3098
  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 +4239 -3098
  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 +30 -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.map +1 -1
  22. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  23. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  25. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  27. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/util.d.ts +3 -3
  29. package/dist/types/src/components/EditorToolbar/util.d.ts.map +1 -1
  30. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +1 -1
  31. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  32. package/dist/types/src/components/index.d.ts +0 -1
  33. package/dist/types/src/components/index.d.ts.map +1 -1
  34. package/dist/types/src/defaults.d.ts.map +1 -1
  35. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +26 -0
  36. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +1 -0
  37. package/dist/types/src/extensions/autocomplete/index.d.ts +5 -0
  38. package/dist/types/src/extensions/autocomplete/index.d.ts.map +1 -0
  39. package/dist/types/src/extensions/autocomplete/match.d.ts +13 -0
  40. package/dist/types/src/extensions/autocomplete/match.d.ts.map +1 -0
  41. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +20 -0
  42. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +1 -0
  43. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +10 -0
  44. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +1 -0
  45. package/dist/types/src/extensions/automerge/automerge.d.ts +1 -1
  46. package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
  47. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +10 -19
  48. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
  49. package/dist/types/src/extensions/automerge/defs.d.ts +1 -1
  50. package/dist/types/src/extensions/automerge/defs.d.ts.map +1 -1
  51. package/dist/types/src/extensions/automerge/sync.d.ts +2 -2
  52. package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
  53. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
  54. package/dist/types/src/extensions/autoscroll.d.ts +10 -0
  55. package/dist/types/src/extensions/autoscroll.d.ts.map +1 -0
  56. package/dist/types/src/extensions/comments.d.ts +1 -1
  57. package/dist/types/src/extensions/comments.d.ts.map +1 -1
  58. package/dist/types/src/extensions/dnd.d.ts.map +1 -1
  59. package/dist/types/src/extensions/factories.d.ts +8 -8
  60. package/dist/types/src/extensions/factories.d.ts.map +1 -1
  61. package/dist/types/src/extensions/focus.d.ts.map +1 -1
  62. package/dist/types/src/extensions/folding.d.ts.map +1 -1
  63. package/dist/types/src/extensions/index.d.ts +4 -1
  64. package/dist/types/src/extensions/index.d.ts.map +1 -1
  65. package/dist/types/src/extensions/json.d.ts +1 -1
  66. package/dist/types/src/extensions/json.d.ts.map +1 -1
  67. package/dist/types/src/extensions/markdown/action.d.ts.map +1 -1
  68. package/dist/types/src/extensions/markdown/bundle.d.ts +8 -2
  69. package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
  70. package/dist/types/src/extensions/markdown/changes.d.ts +1 -1
  71. package/dist/types/src/extensions/markdown/changes.d.ts.map +1 -1
  72. package/dist/types/src/extensions/markdown/decorate.d.ts +9 -1
  73. package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
  74. package/dist/types/src/extensions/markdown/formatting.d.ts +1 -1
  75. package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
  76. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +1 -1
  77. package/dist/types/src/extensions/markdown/highlight.d.ts.map +1 -1
  78. package/dist/types/src/extensions/markdown/image.d.ts.map +1 -1
  79. package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
  80. package/dist/types/src/extensions/modes.d.ts +1 -1
  81. package/dist/types/src/extensions/modes.d.ts.map +1 -1
  82. package/dist/types/src/extensions/outliner/menu.d.ts +8 -0
  83. package/dist/types/src/extensions/outliner/menu.d.ts.map +1 -0
  84. package/dist/types/src/extensions/outliner/outliner.d.ts +1 -1
  85. package/dist/types/src/extensions/outliner/outliner.d.ts.map +1 -1
  86. package/dist/types/src/extensions/outliner/selection.d.ts.map +1 -1
  87. package/dist/types/src/extensions/outliner/tree.d.ts +2 -2
  88. package/dist/types/src/extensions/outliner/tree.d.ts.map +1 -1
  89. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts +36 -0
  90. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +1 -0
  91. package/dist/types/src/extensions/popover/index.d.ts +8 -0
  92. package/dist/types/src/extensions/popover/index.d.ts.map +1 -0
  93. package/dist/types/src/extensions/popover/menu-presets.d.ts +4 -0
  94. package/dist/types/src/extensions/popover/menu-presets.d.ts.map +1 -0
  95. package/dist/types/src/extensions/popover/menu.d.ts +24 -0
  96. package/dist/types/src/extensions/popover/menu.d.ts.map +1 -0
  97. package/dist/types/src/extensions/popover/modal.d.ts +7 -0
  98. package/dist/types/src/extensions/popover/modal.d.ts.map +1 -0
  99. package/dist/types/src/extensions/popover/popover.d.ts +47 -0
  100. package/dist/types/src/extensions/popover/popover.d.ts.map +1 -0
  101. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +34 -0
  102. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +1 -0
  103. package/dist/types/src/extensions/popover/util.d.ts +8 -0
  104. package/dist/types/src/extensions/popover/util.d.ts.map +1 -0
  105. package/dist/types/src/extensions/preview/preview.d.ts +2 -6
  106. package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
  107. package/dist/types/src/extensions/state.d.ts +2 -0
  108. package/dist/types/src/extensions/state.d.ts.map +1 -0
  109. package/dist/types/src/extensions/tags/extended-markdown.d.ts +10 -0
  110. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +1 -0
  111. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +2 -0
  112. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +1 -0
  113. package/dist/types/src/extensions/tags/index.d.ts +4 -0
  114. package/dist/types/src/extensions/tags/index.d.ts.map +1 -0
  115. package/dist/types/src/extensions/tags/streamer.d.ts +12 -0
  116. package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -0
  117. package/dist/types/src/extensions/tags/xml-tags.d.ts +72 -0
  118. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -0
  119. package/dist/types/src/extensions/tags/xml-util.d.ts +10 -0
  120. package/dist/types/src/extensions/tags/xml-util.d.ts.map +1 -0
  121. package/dist/types/src/hooks/useTextEditor.d.ts +4 -8
  122. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  123. package/dist/types/src/stories/CommandDialog.stories.d.ts +14 -0
  124. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  125. package/dist/types/src/stories/Comments.stories.d.ts +21 -10
  126. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  127. package/dist/types/src/stories/EditorToolbar.stories.d.ts +39 -3
  128. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  129. package/dist/types/src/stories/Experimental.stories.d.ts +22 -13
  130. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  131. package/dist/types/src/stories/Markdown.stories.d.ts +32 -43
  132. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  133. package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
  134. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  135. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  136. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  137. package/dist/types/src/stories/Preview.stories.d.ts +21 -7
  138. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  139. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  140. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  141. package/dist/types/src/stories/TextEditor.stories.d.ts +37 -52
  142. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  143. package/dist/types/src/stories/components/EditorStory.d.ts +6 -9
  144. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  145. package/dist/types/src/styles/theme.d.ts.map +1 -1
  146. package/dist/types/src/testing/PreviewPopover.d.ts +20 -0
  147. package/dist/types/src/testing/PreviewPopover.d.ts.map +1 -0
  148. package/dist/types/src/testing/index.d.ts +1 -0
  149. package/dist/types/src/testing/index.d.ts.map +1 -1
  150. package/dist/types/src/testing/util.d.ts +1 -0
  151. package/dist/types/src/testing/util.d.ts.map +1 -1
  152. package/dist/types/src/translations.d.ts +1 -1
  153. package/dist/types/src/types/types.d.ts +2 -2
  154. package/dist/types/src/types/types.d.ts.map +1 -1
  155. package/dist/types/src/util/cursor.d.ts.map +1 -1
  156. package/dist/types/src/util/debug.d.ts +1 -1
  157. package/dist/types/src/util/debug.d.ts.map +1 -1
  158. package/dist/types/src/util/decorations.d.ts +4 -0
  159. package/dist/types/src/util/decorations.d.ts.map +1 -0
  160. package/dist/types/src/util/dom.d.ts +2 -12
  161. package/dist/types/src/util/dom.d.ts.map +1 -1
  162. package/dist/types/src/util/index.d.ts +1 -0
  163. package/dist/types/src/util/index.d.ts.map +1 -1
  164. package/dist/types/src/util/react.d.ts +1 -1
  165. package/dist/types/src/util/react.d.ts.map +1 -1
  166. package/dist/types/tsconfig.tsbuildinfo +1 -1
  167. package/package.json +69 -61
  168. package/src/components/Editor/Editor.stories.tsx +72 -0
  169. package/src/components/Editor/Editor.tsx +58 -15
  170. package/src/components/EditorToolbar/EditorToolbar.tsx +41 -30
  171. package/src/components/EditorToolbar/blocks.ts +21 -24
  172. package/src/components/EditorToolbar/formatting.ts +22 -25
  173. package/src/components/EditorToolbar/headings.ts +10 -5
  174. package/src/components/EditorToolbar/image.ts +8 -4
  175. package/src/components/EditorToolbar/lists.ts +16 -19
  176. package/src/components/EditorToolbar/search.ts +8 -4
  177. package/src/components/EditorToolbar/util.ts +16 -5
  178. package/src/components/EditorToolbar/view-mode.ts +11 -6
  179. package/src/components/index.ts +0 -1
  180. package/src/defaults.ts +5 -2
  181. package/src/extensions/autocomplete/autocomplete.ts +220 -0
  182. package/src/extensions/autocomplete/index.ts +8 -0
  183. package/src/extensions/autocomplete/match.ts +46 -0
  184. package/src/extensions/{command → autocomplete}/placeholder.ts +22 -18
  185. package/src/extensions/{command → autocomplete}/typeahead.ts +8 -50
  186. package/src/extensions/automerge/automerge.stories.tsx +31 -24
  187. package/src/extensions/automerge/automerge.ts +31 -11
  188. package/src/extensions/automerge/defs.ts +1 -1
  189. package/src/extensions/automerge/sync.ts +8 -4
  190. package/src/extensions/automerge/update-automerge.ts +1 -1
  191. package/src/extensions/autoscroll.ts +157 -0
  192. package/src/extensions/awareness/awareness.ts +2 -2
  193. package/src/extensions/comments.ts +18 -13
  194. package/src/extensions/dnd.ts +1 -1
  195. package/src/extensions/factories.ts +48 -31
  196. package/src/extensions/focus.ts +5 -4
  197. package/src/extensions/folding.tsx +4 -6
  198. package/src/extensions/hashtag.tsx +2 -2
  199. package/src/extensions/index.ts +4 -1
  200. package/src/extensions/json.ts +1 -1
  201. package/src/extensions/markdown/action.ts +2 -1
  202. package/src/extensions/markdown/bundle.ts +29 -5
  203. package/src/extensions/markdown/changes.ts +1 -1
  204. package/src/extensions/markdown/decorate.ts +24 -14
  205. package/src/extensions/markdown/formatting.test.ts +6 -6
  206. package/src/extensions/markdown/formatting.ts +3 -3
  207. package/src/extensions/markdown/highlight.ts +1 -1
  208. package/src/extensions/markdown/image.ts +3 -4
  209. package/src/extensions/markdown/link.ts +3 -0
  210. package/src/extensions/markdown/table.ts +7 -1
  211. package/src/extensions/mention.ts +1 -1
  212. package/src/extensions/modes.ts +2 -2
  213. package/src/extensions/{command/floating-menu.ts → outliner/menu.ts} +16 -21
  214. package/src/extensions/outliner/outliner.test.ts +3 -2
  215. package/src/extensions/outliner/outliner.ts +7 -6
  216. package/src/extensions/outliner/selection.ts +1 -1
  217. package/src/extensions/outliner/tree.test.ts +2 -1
  218. package/src/extensions/outliner/tree.ts +2 -2
  219. package/src/extensions/popover/PopoverMenuProvider.tsx +221 -0
  220. package/src/extensions/popover/index.ts +12 -0
  221. package/src/extensions/popover/menu-presets.ts +124 -0
  222. package/src/extensions/popover/menu.ts +67 -0
  223. package/src/extensions/popover/modal.ts +24 -0
  224. package/src/extensions/popover/popover.ts +293 -0
  225. package/src/extensions/popover/usePopoverMenu.ts +173 -0
  226. package/src/extensions/popover/util.ts +29 -0
  227. package/src/extensions/preview/index.ts +1 -1
  228. package/src/extensions/preview/preview.ts +57 -62
  229. package/src/extensions/selection.ts +2 -2
  230. package/src/extensions/state.ts +7 -0
  231. package/src/extensions/tags/extended-markdown.test.ts +261 -0
  232. package/src/extensions/tags/extended-markdown.ts +78 -0
  233. package/src/extensions/tags/index.ts +7 -0
  234. package/src/extensions/tags/streamer.ts +243 -0
  235. package/src/extensions/tags/xml-tags.ts +393 -0
  236. package/src/extensions/tags/xml-util.ts +94 -0
  237. package/src/hooks/useTextEditor.ts +27 -39
  238. package/src/stories/CommandDialog.stories.tsx +78 -0
  239. package/src/stories/Comments.stories.tsx +14 -10
  240. package/src/stories/EditorToolbar.stories.tsx +13 -12
  241. package/src/stories/Experimental.stories.tsx +17 -13
  242. package/src/stories/Markdown.stories.tsx +25 -21
  243. package/src/stories/Outliner.stories.tsx +54 -35
  244. package/src/stories/Popover.stories.tsx +163 -0
  245. package/src/stories/Preview.stories.tsx +34 -33
  246. package/src/stories/Tags.stories.tsx +81 -0
  247. package/src/stories/TextEditor.stories.tsx +39 -58
  248. package/src/stories/components/EditorStory.tsx +16 -15
  249. package/src/styles/theme.ts +16 -12
  250. package/src/testing/PreviewPopover.tsx +80 -0
  251. package/src/testing/index.ts +1 -0
  252. package/src/testing/util.ts +2 -0
  253. package/src/translations.ts +1 -1
  254. package/src/types/types.ts +1 -1
  255. package/src/util/cursor.ts +2 -1
  256. package/src/util/debug.ts +2 -2
  257. package/src/util/decorations.ts +21 -0
  258. package/src/util/dom.ts +5 -27
  259. package/src/util/index.ts +1 -0
  260. package/src/util/react.tsx +1 -1
  261. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  262. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  263. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  264. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  265. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  266. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  267. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  268. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  269. package/dist/types/src/components/Popover/index.d.ts +0 -4
  270. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  271. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  272. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  273. package/dist/types/src/extensions/command/action.d.ts +0 -17
  274. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  275. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  276. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  277. package/dist/types/src/extensions/command/command.d.ts +0 -6
  278. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  279. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  280. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  281. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  282. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  283. package/dist/types/src/extensions/command/index.d.ts +0 -7
  284. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  285. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  286. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  287. package/dist/types/src/extensions/command/state.d.ts +0 -16
  288. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  289. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  290. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  291. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  292. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  293. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  294. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  295. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  296. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  297. package/src/components/Popover/CommandMenu.tsx +0 -279
  298. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  299. package/src/components/Popover/RefPopover.tsx +0 -99
  300. package/src/components/Popover/index.ts +0 -7
  301. package/src/extensions/autocomplete.ts +0 -69
  302. package/src/extensions/command/action.ts +0 -56
  303. package/src/extensions/command/command-menu.ts +0 -210
  304. package/src/extensions/command/command.ts +0 -34
  305. package/src/extensions/command/hint.ts +0 -102
  306. package/src/extensions/command/index.ts +0 -10
  307. package/src/extensions/command/state.ts +0 -89
  308. package/src/extensions/command/useCommandMenu.ts +0 -118
  309. package/src/stories/Command.stories.tsx +0 -97
  310. package/src/stories/CommandMenu.stories.tsx +0 -159
@@ -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;
@@ -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,21 @@
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';
7
+ import { markdown, markdownLanguage } from '@codemirror/lang-markdown';
8
8
  import { syntaxHighlighting } from '@codemirror/language';
9
9
  import { languages } from '@codemirror/language-data';
10
10
  import { type Extension } from '@codemirror/state';
11
11
  import { keymap } from '@codemirror/view';
12
+ import { type MarkdownConfig } from '@lezer/markdown';
12
13
 
13
- import { type ThemeMode } from '@dxos/react-ui';
14
- import { isNotFalsy } from '@dxos/util';
14
+ import { isTruthy } from '@dxos/util';
15
15
 
16
16
  import { markdownHighlightStyle, markdownTagsExtensions } from './highlight';
17
17
 
18
18
  export type MarkdownBundleOptions = {
19
- themeMode?: ThemeMode;
19
+ extensions?: MarkdownConfig[];
20
20
  indentWithTab?: boolean;
21
+ setextHeading?: boolean;
21
22
  };
22
23
 
23
24
  /**
@@ -51,6 +52,7 @@ export const createMarkdownExtensions = (options: MarkdownBundleOptions = {}): E
51
52
  extensions: [
52
53
  // GFM provided by default.
53
54
  markdownTagsExtensions,
55
+ ...(options.extensions ?? defaultExtensions()),
54
56
  ],
55
57
  }),
56
58
 
@@ -64,8 +66,30 @@ export const createMarkdownExtensions = (options: MarkdownBundleOptions = {}): E
64
66
 
65
67
  // https://codemirror.net/docs/ref/#commands.defaultKeymap
66
68
  ...defaultKeymap,
69
+
70
+ // TODO(burdon): Remove?
67
71
  ...completionKeymap,
68
- ].filter(isNotFalsy),
72
+ ].filter(isTruthy),
69
73
  ),
70
74
  ];
71
75
  };
76
+
77
+ /**
78
+ * Default customizations.
79
+ * https://github.com/lezer-parser/markdown/blob/main/src/markdown.ts
80
+ */
81
+ export const defaultExtensions = (): MarkdownConfig[] => [noSetExtHeading, noHtml];
82
+
83
+ /**
84
+ * Remove SetextHeading (e.g., headings created from "---").
85
+ */
86
+ const noSetExtHeading: MarkdownConfig = {
87
+ remove: ['SetextHeading'],
88
+ };
89
+
90
+ /**
91
+ * Remove HTML and XML parsing.
92
+ */
93
+ const noHtml: MarkdownConfig = {
94
+ remove: ['HTMLBlock', 'HTMLTag'],
95
+ };
@@ -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.
@@ -3,20 +3,21 @@
3
3
  //
4
4
 
5
5
  import { syntaxTree } from '@codemirror/language';
6
- import { RangeSetBuilder, type EditorState, StateEffect } from '@codemirror/state';
7
- import { EditorView, Decoration, type DecorationSet, WidgetType, ViewPlugin, type ViewUpdate } from '@codemirror/view';
6
+ import { type EditorState, Prec, RangeSetBuilder, StateEffect } from '@codemirror/state';
7
+ import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate, WidgetType } from '@codemirror/view';
8
8
  import { type SyntaxNodeRef } from '@lezer/common';
9
9
 
10
10
  import { invariant } from '@dxos/invariant';
11
11
  import { mx } from '@dxos/react-ui-theme';
12
12
 
13
+ import { type HeadingLevel, theme } from '../../styles';
14
+ import { type RenderCallback } from '../../types';
15
+ import { wrapWithCatch } from '../../util';
16
+
13
17
  import { adjustChanges } from './changes';
14
18
  import { image } from './image';
15
- import { formattingStyles, bulletListIndentationWidth, orderedListIndentationWidth } from './styles';
19
+ import { bulletListIndentationWidth, formattingStyles, orderedListIndentationWidth } from './styles';
16
20
  import { table } from './table';
17
- import { theme, type HeadingLevel } from '../../styles';
18
- import { type RenderCallback } from '../../types';
19
- import { wrapWithCatch } from '../../util';
20
21
 
21
22
  /**
22
23
  * Unicode characters.
@@ -233,7 +234,7 @@ const buildDecorations = (view: EditorView, options: DecorateOptions, focus: boo
233
234
  const mark = node.node.firstChild!;
234
235
  if (mark?.name === 'HeaderMark') {
235
236
  const { from, to = 6 } = options.numberedHeadings ?? {};
236
- const text = view.state.sliceDoc(node.from, node.to);
237
+ const text = state.sliceDoc(node.from, node.to);
237
238
  const len = text.match(/[#\s]+/)![0].length;
238
239
  if (!from || level < from || level > to) {
239
240
  atomicDeco.add(mark.from, mark.from + len, hide);
@@ -426,6 +427,9 @@ const buildDecorations = (view: EditorView, options: DecorateOptions, focus: boo
426
427
  const editing = editingRange(state, node, focus);
427
428
  if (urlNode && marks.length >= 2) {
428
429
  const url = state.sliceDoc(urlNode.from, urlNode.to);
430
+ if (options.skip?.({ name: 'Link', url })) {
431
+ break;
432
+ }
429
433
  if (!editing) {
430
434
  atomicDeco.add(node.from, marks[0].to, hide);
431
435
  }
@@ -443,6 +447,7 @@ const buildDecorations = (view: EditorView, options: DecorateOptions, focus: boo
443
447
  },
444
448
  }),
445
449
  );
450
+
446
451
  if (!editing) {
447
452
  atomicDeco.add(
448
453
  marks[1].from,
@@ -493,15 +498,15 @@ const buildDecorations = (view: EditorView, options: DecorateOptions, focus: boo
493
498
  tree.iterate({
494
499
  from,
495
500
  to,
496
- enter: wrapWithCatch(enterNode),
497
- leave: wrapWithCatch(leaveNode),
501
+ enter: wrapWithCatch(enterNode, 'decorate.enter'),
502
+ leave: wrapWithCatch(leaveNode, 'decorate.leave'),
498
503
  });
499
504
  }
500
505
  } else {
501
506
  // NOTE: If line numbering then we must iterate from the start of document.
502
507
  tree.iterate({
503
- enter: wrapWithCatch(enterNode),
504
- leave: wrapWithCatch(leaveNode),
508
+ enter: wrapWithCatch(enterNode, 'decorate.enter'),
509
+ leave: wrapWithCatch(leaveNode, 'decorate.leave'),
505
510
  });
506
511
  }
507
512
 
@@ -513,15 +518,20 @@ const buildDecorations = (view: EditorView, options: DecorateOptions, focus: boo
513
518
 
514
519
  const forceUpdate = StateEffect.define<null>();
515
520
 
521
+ export type NodeData = { name: 'Link'; url: string } | { name: 'Image'; url: string };
522
+
516
523
  export interface DecorateOptions {
517
524
  /**
518
525
  * Prevents triggering decorations as the cursor moves through the document.
519
526
  */
520
527
  selectionChangeDelay?: number;
521
528
  numberedHeadings?: { from: number; to?: number };
522
- renderLinkButton?: RenderCallback<{ url: string }>;
523
529
  // TODO(burdon): Additional padding for each line.
524
530
  listPaddingLeft?: number;
531
+ // TODO(burdon): Use consistently.
532
+ skip?: (node: NodeData) => boolean;
533
+ // TODO(burdon): Remove.
534
+ renderLinkButton?: RenderCallback<{ url: string }>;
525
535
  }
526
536
 
527
537
  export const decorateMarkdown = (options: DecorateOptions = {}) => {
@@ -577,9 +587,9 @@ export const decorateMarkdown = (options: DecorateOptions = {}) => {
577
587
  },
578
588
  {
579
589
  provide: (plugin) => [
580
- EditorView.atomicRanges.of((view) => view.plugin(plugin)?.atomicDeco ?? Decoration.none),
590
+ Prec.low(EditorView.decorations.of((view) => view.plugin(plugin)?.deco ?? Decoration.none)),
581
591
  EditorView.decorations.of((view) => view.plugin(plugin)?.atomicDeco ?? Decoration.none),
582
- EditorView.decorations.of((view) => view.plugin(plugin)?.deco ?? Decoration.none),
592
+ EditorView.atomicRanges.of((view) => view.plugin(plugin)?.atomicDeco ?? Decoration.none),
583
593
  ],
584
594
  },
585
595
  ),
@@ -7,21 +7,21 @@ import { EditorState, type StateCommand } from '@codemirror/state';
7
7
  import { describe, expect, test } from 'vitest';
8
8
 
9
9
  import {
10
+ type Formatting,
11
+ Inline,
12
+ List,
10
13
  addBlockquote,
11
14
  addCodeblock,
12
15
  addLink,
13
16
  addList,
14
17
  addStyle,
15
18
  getFormatting,
16
- removeStyle,
17
- removeLink,
18
- removeList,
19
19
  removeBlockquote,
20
20
  removeCodeblock,
21
+ removeLink,
22
+ removeList,
23
+ removeStyle,
21
24
  setHeading,
22
- Inline,
23
- List,
24
- type Formatting,
25
25
  } from './formatting';
26
26
 
27
27
  export const emptyFormatting: Formatting = {
@@ -7,14 +7,14 @@ import { syntaxTree } from '@codemirror/language';
7
7
  import {
8
8
  type ChangeSpec,
9
9
  EditorSelection,
10
- type Extension,
11
10
  type EditorState,
11
+ type Extension,
12
12
  type Line,
13
13
  type StateCommand,
14
14
  type Text,
15
15
  } from '@codemirror/state';
16
- import { EditorView, keymap, type ViewUpdate } from '@codemirror/view';
17
- import { type SyntaxNodeRef, type SyntaxNode } from '@lezer/common';
16
+ import { EditorView, type ViewUpdate, keymap } from '@codemirror/view';
17
+ import { type SyntaxNode, type SyntaxNodeRef } from '@lezer/common';
18
18
  import { useCallback, useMemo } from 'react';
19
19
 
20
20
  import { debounceAndThrottle } from '@dxos/async';
@@ -4,7 +4,7 @@
4
4
 
5
5
  import { markdownLanguage } from '@codemirror/lang-markdown';
6
6
  import { HighlightStyle } from '@codemirror/language';
7
- import { tags, styleTags, Tag } from '@lezer/highlight';
7
+ import { Tag, styleTags, tags } from '@lezer/highlight';
8
8
  import { type MarkdownConfig, Table } from '@lezer/markdown';
9
9
 
10
10
  import { fontBody, theme } from '../../styles';
@@ -17,8 +17,7 @@ export const image = (_options: ImageOptions = {}): Extension => {
17
17
  return [
18
18
  StateField.define<DecorationSet>({
19
19
  create: (state) => {
20
- // Process all images.
21
- return Decoration.set(buildDecorations(0, state.doc.length, state));
20
+ return Decoration.set(buildDecorations(state, 0, state.doc.length));
22
21
  },
23
22
  update: (value: DecorationSet, tr: Transaction) => {
24
23
  if (!tr.docChanged && !tr.selection) {
@@ -43,7 +42,7 @@ export const image = (_options: ImageOptions = {}): Extension => {
43
42
  filterFrom: from,
44
43
  filterTo: to,
45
44
  filter: () => false,
46
- add: buildDecorations(from, to, tr.state),
45
+ add: buildDecorations(tr.state, from, to),
47
46
  });
48
47
  },
49
48
  provide: (field) => EditorView.decorations.from(field),
@@ -51,7 +50,7 @@ export const image = (_options: ImageOptions = {}): Extension => {
51
50
  ];
52
51
  };
53
52
 
54
- const buildDecorations = (from: number, to: number, state: EditorState) => {
53
+ const buildDecorations = (state: EditorState, from: number, to: number) => {
55
54
  const decorations: Range<Decoration>[] = [];
56
55
  const cursor = state.selection.main.head;
57
56
  syntaxTree(state).iterate({
@@ -26,6 +26,9 @@ export const linkTooltip = (renderTooltip: RenderCallback<{ url: string }>) => {
26
26
  }
27
27
 
28
28
  const urlText = view.state.sliceDoc(url.from, url.to);
29
+ if (urlText.startsWith('dxn')) {
30
+ return null;
31
+ }
29
32
  return {
30
33
  pos: link.from,
31
34
  end: link.to,
@@ -94,7 +94,13 @@ const update = (state: EditorState, _options: TableOptions) => {
94
94
  } else {
95
95
  // Add class for styling.
96
96
  // TODO(burdon): Apply to each line?
97
- builder.add(table.from, table.to, Decoration.mark({ class: 'cm-table' }));
97
+ builder.add(
98
+ table.from,
99
+ table.to,
100
+ Decoration.mark({
101
+ class: 'cm-table',
102
+ }),
103
+ );
98
104
  }
99
105
  });
100
106
 
@@ -2,7 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { autocompletion, type CompletionContext, type CompletionResult } from '@codemirror/autocomplete';
5
+ import { type CompletionContext, type CompletionResult, autocompletion } from '@codemirror/autocomplete';
6
6
  import type { Extension } from '@codemirror/state';
7
7
 
8
8
  import { log } from '@dxos/log';
@@ -11,7 +11,7 @@ import { singleValueFacet } from '../util';
11
11
 
12
12
  export type EditorInputConfig = {
13
13
  type?: string;
14
- noTabster?: boolean;
14
+ ignoreEscape?: boolean;
15
15
  };
16
16
 
17
17
  export const editorInputMode = singleValueFacet<EditorInputConfig>({});
@@ -26,7 +26,7 @@ export const InputModeExtensions: { [mode: string]: Extension } = {
26
26
  vim: [
27
27
  // https://github.com/replit/codemirror-vim
28
28
  vim(),
29
- editorInputMode.of({ type: 'vim', noTabster: true }),
29
+ editorInputMode.of({ type: 'vim', ignoreEscape: true }),
30
30
  keymap.of([
31
31
  {
32
32
  key: 'Alt-Escape',
@@ -2,19 +2,19 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
+ import { type Extension } from '@codemirror/state';
5
6
  import { EditorView, ViewPlugin, type ViewUpdate } from '@codemirror/view';
6
7
 
7
8
  import { type CleanupFn, addEventListener } from '@dxos/async';
8
9
 
9
- import { closeEffect, openEffect } from './action';
10
-
11
- export type FloatingMenuOptions = {
10
+ export type MenuOptions = {
12
11
  icon?: string;
13
12
  height?: number;
14
13
  padding?: number;
15
14
  };
16
15
 
17
- export const floatingMenu = (options: FloatingMenuOptions = {}) => [
16
+ // TODO(burdon): Replace with popover.
17
+ export const menu = (options: MenuOptions = {}): Extension => [
18
18
  ViewPlugin.fromClass(
19
19
  class {
20
20
  view: EditorView;
@@ -34,12 +34,10 @@ export const floatingMenu = (options: FloatingMenuOptions = {}) => [
34
34
  {
35
35
  const icon = document.createElement('dx-icon');
36
36
  icon.setAttribute('icon', options.icon ?? 'ph--dots-three-vertical--regular');
37
- const button = document.createElement('button');
38
- button.appendChild(icon);
39
37
 
40
- this.tag = document.createElement('dx-ref-tag');
41
- this.tag.classList.add('cm-ref-tag');
42
- this.tag.appendChild(button);
38
+ this.tag = document.createElement('dx-anchor');
39
+ this.tag.classList.add('cm-popover-trigger');
40
+ this.tag.appendChild(icon);
43
41
  }
44
42
 
45
43
  container.appendChild(this.tag);
@@ -65,12 +63,12 @@ export const floatingMenu = (options: FloatingMenuOptions = {}) => [
65
63
  }
66
64
 
67
65
  // TODO(burdon): Timer to fade in/out.
68
- if (update.transactions.some((tr) => tr.effects.some((effect) => effect.is(openEffect)))) {
66
+ /*if (update.transactions.some((tr) => tr.effects.some((effect) => effect.is(openEffect)))) {
69
67
  this.tag.style.display = 'none';
70
68
  this.tag.classList.add('opacity-10');
71
69
  } else if (update.transactions.some((tr) => tr.effects.some((effect) => effect.is(closeEffect)))) {
72
- this.tag.style.display = 'block';
73
- } else if (
70
+ this.tag.style.display = '';
71
+ } else */ if (
74
72
  update.docChanged ||
75
73
  update.focusChanged ||
76
74
  update.geometryChanged ||
@@ -99,7 +97,7 @@ export const floatingMenu = (options: FloatingMenuOptions = {}) => [
99
97
 
100
98
  this.tag.style.top = `${offsetTop}px`;
101
99
  this.tag.style.left = `${offsetLeft}px`;
102
- this.tag.style.display = 'block';
100
+ this.tag.style.display = '';
103
101
  }
104
102
 
105
103
  scheduleUpdate() {
@@ -113,21 +111,18 @@ export const floatingMenu = (options: FloatingMenuOptions = {}) => [
113
111
  ),
114
112
 
115
113
  EditorView.theme({
116
- '.cm-ref-tag': {
114
+ '.cm-popover-trigger': {
117
115
  position: 'fixed',
118
116
  padding: '0',
119
117
  border: 'none',
120
118
  opacity: '0',
121
- },
122
- '[data-has-focus] & .cm-ref-tag': {
123
- opacity: '1',
124
- },
125
- '.cm-ref-tag button': {
126
119
  display: 'grid',
127
- alignItems: 'center',
128
- justifyContent: 'center',
120
+ placeContent: 'center',
129
121
  width: '2rem',
130
122
  height: '2rem',
131
123
  },
124
+ '&:focus-within .cm-popover-trigger': {
125
+ opacity: '1',
126
+ },
132
127
  }),
133
128
  ];
@@ -6,11 +6,12 @@ import { EditorSelection, EditorState } from '@codemirror/state';
6
6
  import { EditorView } from '@codemirror/view';
7
7
  import { describe, test } from 'vitest';
8
8
 
9
- import { indentItemLess, indentItemMore, moveItemDown, moveItemUp } from './commands';
10
- import { listItemToString, outlinerTree, treeFacet } from './tree';
11
9
  import { str } from '../../testing';
12
10
  import { createMarkdownExtensions } from '../markdown';
13
11
 
12
+ import { indentItemLess, indentItemMore, moveItemDown, moveItemUp } from './commands';
13
+ import { listItemToString, outlinerTree, treeFacet } from './tree';
14
+
14
15
  const lines = [
15
16
  '- [ ] 1',
16
17
  '- [ ] 2',
@@ -7,12 +7,13 @@ import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate
7
7
 
8
8
  import { mx } from '@dxos/react-ui-theme';
9
9
 
10
+ import { decorateMarkdown } from '../markdown';
11
+
10
12
  import { commands } from './commands';
11
13
  import { editor } from './editor';
12
- import { selectionCompartment, selectionFacet, selectionEquals } from './selection';
14
+ import { menu } from './menu';
15
+ import { selectionCompartment, selectionEquals, selectionFacet } from './selection';
13
16
  import { outlinerTree, treeFacet } from './tree';
14
- import { floatingMenu } from '../command';
15
- import { decorateMarkdown } from '../markdown';
16
17
 
17
18
  // ISSUES:
18
19
  // TODO(burdon): Remove requirement for continuous lines to be indented (so that user's can't accidentally delete them and break the layout).
@@ -37,7 +38,7 @@ export type OutlinerProps = {};
37
38
  * - Constrains editor to outline structure.
38
39
  * - Supports smart cut-and-paste.
39
40
  */
40
- export const outliner = (options: OutlinerProps = {}): Extension => [
41
+ export const outliner = (_options: OutlinerProps = {}): Extension => [
41
42
  // Commands.
42
43
  Prec.highest(commands()),
43
44
 
@@ -51,7 +52,7 @@ export const outliner = (options: OutlinerProps = {}): Extension => [
51
52
  editor(),
52
53
 
53
54
  // Floating menu.
54
- floatingMenu(),
55
+ menu(),
55
56
 
56
57
  // Line decorations.
57
58
  decorations(),
@@ -158,7 +159,7 @@ const decorations = () => [
158
159
  '.cm-list-item-focused': {
159
160
  borderColor: 'var(--dx-accentFocusIndicator)',
160
161
  },
161
- '[data-has-focus] & .cm-list-item-selected': {
162
+ '&:focus-within .cm-list-item-selected': {
162
163
  borderColor: 'var(--dx-separator)',
163
164
  },
164
165
  }),
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { Compartment, type EditorState, Facet, type SelectionRange } from '@codemirror/state';
6
- import { type EditorView, type Command } from '@codemirror/view';
6
+ import { type Command, type EditorView } from '@codemirror/view';
7
7
 
8
8
  import { treeFacet } from './tree';
9
9
 
@@ -6,10 +6,11 @@ import { markdown, markdownLanguage } from '@codemirror/lang-markdown';
6
6
  import { EditorState } from '@codemirror/state';
7
7
  import { beforeEach, describe, test } from 'vitest';
8
8
 
9
- import { outlinerTree, treeFacet, listItemToString, type Item } from './tree';
10
9
  import { str } from '../../testing';
11
10
  import { type Range } from '../../types';
12
11
 
12
+ import { type Item, listItemToString, outlinerTree, treeFacet } from './tree';
13
+
13
14
  const lines = [
14
15
  '- [ ] 1',
15
16
  '- [ ] 2',
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { syntaxTree } from '@codemirror/language';
6
- import { StateField, type Transaction, type Extension, type EditorState } from '@codemirror/state';
6
+ import { type EditorState, type Extension, StateField, type Transaction } from '@codemirror/state';
7
7
  import { Facet } from '@codemirror/state';
8
8
  import { type SyntaxNode } from '@lezer/common';
9
9
 
@@ -195,7 +195,7 @@ export type TreeOptions = {};
195
195
  * This adds overhead relative to the markdown AST, but allows for efficient traversal of the list items.
196
196
  * NOTE: Requires markdown parser to be enabled.
197
197
  */
198
- export const outlinerTree = (options: TreeOptions = {}): Extension => {
198
+ export const outlinerTree = (_options: TreeOptions = {}): Extension => {
199
199
  const buildTree = (state: EditorState): Tree => {
200
200
  let tree: Tree | undefined;
201
201
  let parent: Item | undefined;