@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.
- package/dist/lib/browser/index.mjs +1103 -8137
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +1103 -8136
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/components/Editor/Editor.d.ts +43 -30
- package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
- package/dist/types/src/components/Editor/Editor.stories.d.ts +16 -20
- package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
- package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
- package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
- package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
- package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
- package/dist/types/src/components/EditorContent/index.d.ts +3 -0
- package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
- package/dist/types/src/{extensions/popover/PopoverMenuProvider.d.ts → components/EditorMenuProvider/EditorMenuProvider.d.ts} +6 -6
- package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
- package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
- package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
- package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
- package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
- package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
- package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
- package/dist/types/src/{extensions/popover → components/EditorMenuProvider}/popover.d.ts +1 -2
- package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
- package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
- package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
- package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
- package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
- package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
- package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
- package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +14 -3
- package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/actions.d.ts +24 -0
- package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
- package/dist/types/src/components/EditorToolbar/blocks.d.ts +8 -7
- package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/formatting.d.ts +8 -7
- package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/headings.d.ts +8 -7
- package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/image.d.ts +4 -11
- package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
- package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/search.d.ts +4 -11
- package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
- package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts +9 -8
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +4 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useTextEditor.d.ts +2 -2
- package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -8
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +5 -9
- package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
- package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Comments.stories.d.ts +4 -3
- package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
- package/dist/types/src/stories/EditorToolbar.stories.d.ts +4 -4
- package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Experimental.stories.d.ts +4 -3
- package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Markdown.stories.d.ts +4 -3
- package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Popover.stories.d.ts +2 -2
- package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Preview.stories.d.ts +5 -3
- package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
- package/dist/types/src/stories/TextEditor.stories.d.ts +4 -3
- package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Theme.stories.d.ts +8 -0
- package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
- package/dist/types/src/stories/components/EditorStory.d.ts +10 -19
- package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
- package/dist/types/src/stories/components/util.d.ts +3 -3
- package/dist/types/src/stories/components/util.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +5 -5
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/util/index.d.ts +0 -5
- package/dist/types/src/util/index.d.ts.map +1 -1
- package/dist/types/src/util/react.d.ts +5 -1
- package/dist/types/src/util/react.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +63 -69
- package/src/components/Editor/Editor.stories.tsx +76 -50
- package/src/components/Editor/Editor.tsx +160 -63
- package/src/components/EditorContent/EditorContent.tsx +83 -0
- package/src/components/EditorContent/controller.ts +50 -0
- package/src/components/EditorContent/index.ts +6 -0
- package/src/{extensions/popover/PopoverMenuProvider.tsx → components/EditorMenuProvider/EditorMenuProvider.tsx} +27 -14
- package/src/components/EditorMenuProvider/index.ts +10 -0
- package/src/{extensions/popover → components/EditorMenuProvider}/menu-presets.ts +19 -19
- package/src/{extensions/popover → components/EditorMenuProvider}/menu.ts +21 -18
- package/src/{extensions/popover → components/EditorMenuProvider}/popover.ts +3 -7
- package/src/{extensions/popover/usePopoverMenu.ts → components/EditorMenuProvider/useEditorMenu.ts} +21 -21
- package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +81 -0
- package/src/components/EditorPreviewProvider/index.ts +5 -0
- package/src/components/EditorToolbar/EditorToolbar.tsx +30 -17
- package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
- package/src/components/EditorToolbar/blocks.ts +5 -5
- package/src/components/EditorToolbar/formatting.ts +5 -5
- package/src/components/EditorToolbar/headings.ts +5 -4
- package/src/components/EditorToolbar/image.ts +9 -2
- package/src/components/EditorToolbar/index.ts +3 -7
- package/src/components/EditorToolbar/search.ts +9 -2
- package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
- package/src/components/EditorToolbar/view-mode.ts +5 -4
- package/src/components/index.ts +6 -1
- package/src/hooks/useTextEditor.ts +13 -7
- package/src/index.ts +0 -10
- package/src/stories/Automerge.stories.tsx +175 -0
- package/src/stories/CommandDialog.stories.tsx +12 -9
- package/src/stories/Comments.stories.tsx +47 -43
- package/src/stories/EditorToolbar.stories.tsx +31 -15
- package/src/stories/Experimental.stories.tsx +4 -6
- package/src/stories/Markdown.stories.tsx +14 -14
- package/src/stories/Outliner.stories.tsx +16 -24
- package/src/stories/Popover.stories.tsx +40 -45
- package/src/stories/Preview.stories.tsx +76 -74
- package/src/stories/Tags.stories.tsx +32 -9
- package/src/stories/TextEditor.stories.tsx +11 -17
- package/src/stories/Theme.stories.tsx +61 -0
- package/src/stories/components/EditorStory.tsx +34 -27
- package/src/stories/components/util.tsx +43 -11
- package/src/translations.ts +4 -4
- package/src/util/index.ts +1 -6
- package/src/util/react.tsx +6 -2
- package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
- package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
- package/dist/lib/browser/testing/index.mjs +0 -76
- package/dist/lib/browser/testing/index.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -13
- package/dist/lib/browser/types/index.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
- package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
- package/dist/lib/node-esm/testing/index.mjs +0 -78
- package/dist/lib/node-esm/testing/index.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -14
- package/dist/lib/node-esm/types/index.mjs.map +0 -7
- package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
- package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
- package/dist/types/src/components/EditorToolbar/util.d.ts +0 -37
- package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
- package/dist/types/src/defaults.d.ts +0 -14
- package/dist/types/src/defaults.d.ts.map +0 -1
- package/dist/types/src/extensions/annotations.d.ts +0 -9
- package/dist/types/src/extensions/annotations.d.ts.map +0 -1
- package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -26
- package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
- package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
- package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
- package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
- package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
- package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
- package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
- package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
- package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
- package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
- package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
- package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
- package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/index.d.ts +0 -2
- package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
- package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
- package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
- package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
- package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
- package/dist/types/src/extensions/autoscroll.d.ts +0 -10
- package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
- package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
- package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
- package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
- package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
- package/dist/types/src/extensions/awareness/index.d.ts +0 -3
- package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
- package/dist/types/src/extensions/blast.d.ts +0 -25
- package/dist/types/src/extensions/blast.d.ts.map +0 -1
- package/dist/types/src/extensions/comments.d.ts +0 -95
- package/dist/types/src/extensions/comments.d.ts.map +0 -1
- package/dist/types/src/extensions/debug.d.ts +0 -3
- package/dist/types/src/extensions/debug.d.ts.map +0 -1
- package/dist/types/src/extensions/dnd.d.ts +0 -9
- package/dist/types/src/extensions/dnd.d.ts.map +0 -1
- package/dist/types/src/extensions/factories.d.ts +0 -83
- package/dist/types/src/extensions/factories.d.ts.map +0 -1
- package/dist/types/src/extensions/focus.d.ts +0 -7
- package/dist/types/src/extensions/focus.d.ts.map +0 -1
- package/dist/types/src/extensions/folding.d.ts +0 -7
- package/dist/types/src/extensions/folding.d.ts.map +0 -1
- package/dist/types/src/extensions/hashtag.d.ts +0 -3
- package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
- package/dist/types/src/extensions/index.d.ts +0 -26
- package/dist/types/src/extensions/index.d.ts.map +0 -1
- package/dist/types/src/extensions/json.d.ts +0 -7
- package/dist/types/src/extensions/json.d.ts.map +0 -1
- package/dist/types/src/extensions/listener.d.ts +0 -13
- package/dist/types/src/extensions/listener.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/action.d.ts +0 -12
- package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
- package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
- package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
- package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
- package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
- package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/formatting.d.ts +0 -62
- package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
- package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
- package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/image.d.ts +0 -7
- package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/index.d.ts +0 -10
- package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/link.d.ts +0 -7
- package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
- package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
- package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
- package/dist/types/src/extensions/markdown/table.d.ts +0 -8
- package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
- package/dist/types/src/extensions/mention.d.ts +0 -7
- package/dist/types/src/extensions/mention.d.ts.map +0 -1
- package/dist/types/src/extensions/modes.d.ts +0 -10
- package/dist/types/src/extensions/modes.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
- package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
- package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
- package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/index.d.ts +0 -4
- package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
- package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
- package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
- package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
- package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
- package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
- package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
- package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/index.d.ts +0 -8
- package/dist/types/src/extensions/popover/index.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/menu-presets.d.ts +0 -4
- package/dist/types/src/extensions/popover/menu-presets.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/menu.d.ts +0 -24
- package/dist/types/src/extensions/popover/menu.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/modal.d.ts +0 -7
- package/dist/types/src/extensions/popover/modal.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/popover.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +0 -34
- package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +0 -1
- package/dist/types/src/extensions/popover/util.d.ts +0 -8
- package/dist/types/src/extensions/popover/util.d.ts.map +0 -1
- package/dist/types/src/extensions/preview/index.d.ts +0 -2
- package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
- package/dist/types/src/extensions/preview/preview.d.ts +0 -32
- package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
- package/dist/types/src/extensions/selection.d.ts +0 -24
- package/dist/types/src/extensions/selection.d.ts.map +0 -1
- package/dist/types/src/extensions/state.d.ts +0 -2
- package/dist/types/src/extensions/state.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
- package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
- package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/index.d.ts +0 -4
- package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
- package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -72
- package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
- package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
- package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
- package/dist/types/src/extensions/typewriter.d.ts +0 -10
- package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
- package/dist/types/src/styles/index.d.ts +0 -4
- package/dist/types/src/styles/index.d.ts.map +0 -1
- package/dist/types/src/styles/markdown.d.ts +0 -8
- package/dist/types/src/styles/markdown.d.ts.map +0 -1
- package/dist/types/src/styles/theme.d.ts +0 -38
- package/dist/types/src/styles/theme.d.ts.map +0 -1
- package/dist/types/src/styles/tokens.d.ts +0 -3
- package/dist/types/src/styles/tokens.d.ts.map +0 -1
- package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
- package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
- package/dist/types/src/testing/index.d.ts +0 -3
- package/dist/types/src/testing/index.d.ts.map +0 -1
- package/dist/types/src/testing/util.d.ts +0 -3
- package/dist/types/src/testing/util.d.ts.map +0 -1
- package/dist/types/src/types/index.d.ts +0 -2
- package/dist/types/src/types/index.d.ts.map +0 -1
- package/dist/types/src/types/types.d.ts +0 -21
- package/dist/types/src/types/types.d.ts.map +0 -1
- package/dist/types/src/util/cursor.d.ts +0 -31
- package/dist/types/src/util/cursor.d.ts.map +0 -1
- package/dist/types/src/util/debug.d.ts +0 -17
- package/dist/types/src/util/debug.d.ts.map +0 -1
- package/dist/types/src/util/decorations.d.ts +0 -4
- package/dist/types/src/util/decorations.d.ts.map +0 -1
- package/dist/types/src/util/dom.d.ts +0 -10
- package/dist/types/src/util/dom.d.ts.map +0 -1
- package/dist/types/src/util/facet.d.ts +0 -3
- package/dist/types/src/util/facet.d.ts.map +0 -1
- package/src/components/EditorToolbar/util.ts +0 -60
- package/src/defaults.ts +0 -52
- package/src/extensions/annotations.ts +0 -55
- package/src/extensions/autocomplete/autocomplete.ts +0 -220
- package/src/extensions/autocomplete/index.ts +0 -8
- package/src/extensions/autocomplete/match.ts +0 -46
- package/src/extensions/autocomplete/placeholder.ts +0 -117
- package/src/extensions/autocomplete/typeahead.ts +0 -87
- package/src/extensions/automerge/automerge.stories.tsx +0 -149
- package/src/extensions/automerge/automerge.test.tsx +0 -78
- package/src/extensions/automerge/automerge.ts +0 -105
- package/src/extensions/automerge/cursor.ts +0 -28
- package/src/extensions/automerge/defs.ts +0 -31
- package/src/extensions/automerge/index.ts +0 -5
- package/src/extensions/automerge/sync.ts +0 -79
- package/src/extensions/automerge/update-automerge.ts +0 -50
- package/src/extensions/automerge/update-codemirror.ts +0 -115
- package/src/extensions/autoscroll.ts +0 -157
- package/src/extensions/awareness/awareness-provider.ts +0 -127
- package/src/extensions/awareness/awareness.ts +0 -315
- package/src/extensions/awareness/index.ts +0 -6
- package/src/extensions/blast.ts +0 -363
- package/src/extensions/comments.ts +0 -597
- package/src/extensions/debug.ts +0 -15
- package/src/extensions/dnd.ts +0 -37
- package/src/extensions/factories.ts +0 -277
- package/src/extensions/focus.ts +0 -36
- package/src/extensions/folding.tsx +0 -44
- package/src/extensions/hashtag.tsx +0 -68
- package/src/extensions/index.ts +0 -29
- package/src/extensions/json.ts +0 -57
- package/src/extensions/listener.ts +0 -32
- package/src/extensions/markdown/action.ts +0 -117
- package/src/extensions/markdown/bundle.ts +0 -105
- package/src/extensions/markdown/changes.test.ts +0 -26
- package/src/extensions/markdown/changes.ts +0 -149
- package/src/extensions/markdown/debug.ts +0 -44
- package/src/extensions/markdown/decorate.ts +0 -601
- package/src/extensions/markdown/formatting.test.ts +0 -498
- package/src/extensions/markdown/formatting.ts +0 -1267
- package/src/extensions/markdown/highlight.ts +0 -183
- package/src/extensions/markdown/image.ts +0 -118
- package/src/extensions/markdown/index.ts +0 -13
- package/src/extensions/markdown/link.ts +0 -50
- package/src/extensions/markdown/parser.test.ts +0 -75
- package/src/extensions/markdown/styles.ts +0 -135
- package/src/extensions/markdown/table.ts +0 -150
- package/src/extensions/mention.ts +0 -41
- package/src/extensions/modes.ts +0 -41
- package/src/extensions/outliner/commands.ts +0 -270
- package/src/extensions/outliner/editor.test.ts +0 -33
- package/src/extensions/outliner/editor.ts +0 -184
- package/src/extensions/outliner/index.ts +0 -7
- package/src/extensions/outliner/menu.ts +0 -128
- package/src/extensions/outliner/outliner.test.ts +0 -100
- package/src/extensions/outliner/outliner.ts +0 -167
- package/src/extensions/outliner/selection.ts +0 -50
- package/src/extensions/outliner/tree.test.ts +0 -168
- package/src/extensions/outliner/tree.ts +0 -317
- package/src/extensions/popover/index.ts +0 -12
- package/src/extensions/popover/modal.ts +0 -24
- package/src/extensions/popover/util.ts +0 -29
- package/src/extensions/preview/index.ts +0 -5
- package/src/extensions/preview/preview.ts +0 -193
- package/src/extensions/selection.ts +0 -100
- package/src/extensions/state.ts +0 -7
- package/src/extensions/tags/extended-markdown.test.ts +0 -261
- package/src/extensions/tags/extended-markdown.ts +0 -78
- package/src/extensions/tags/index.ts +0 -7
- package/src/extensions/tags/streamer.ts +0 -243
- package/src/extensions/tags/xml-tags.ts +0 -393
- package/src/extensions/tags/xml-util.ts +0 -94
- package/src/extensions/typewriter.ts +0 -68
- package/src/styles/index.ts +0 -7
- package/src/styles/markdown.ts +0 -26
- package/src/styles/theme.ts +0 -269
- package/src/styles/tokens.ts +0 -17
- package/src/testing/PreviewPopover.tsx +0 -80
- package/src/testing/index.ts +0 -6
- package/src/testing/util.ts +0 -7
- package/src/types/index.ts +0 -5
- package/src/types/types.ts +0 -32
- package/src/util/cursor.ts +0 -56
- package/src/util/debug.ts +0 -64
- package/src/util/decorations.ts +0 -21
- package/src/util/dom.ts +0 -34
- package/src/util/facet.ts +0 -13
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { type EditorView } from '@codemirror/view';
|
|
2
|
-
import * as Schema from 'effect/Schema';
|
|
3
|
-
export type Range = {
|
|
4
|
-
from: number;
|
|
5
|
-
to: number;
|
|
6
|
-
};
|
|
7
|
-
export type Comment = {
|
|
8
|
-
id: string;
|
|
9
|
-
cursor?: string;
|
|
10
|
-
};
|
|
11
|
-
/**
|
|
12
|
-
* Callback that renders into a DOM element within the editor.
|
|
13
|
-
*/
|
|
14
|
-
export type RenderCallback<Props extends object> = (el: HTMLElement, props: Props, view: EditorView) => void;
|
|
15
|
-
export declare const EditorViewModes: readonly ["preview", "readonly", "source"];
|
|
16
|
-
export declare const EditorViewMode: Schema.Schema<"source" | "preview" | "readonly", "source" | "preview" | "readonly", never>;
|
|
17
|
-
export type EditorViewMode = Schema.Schema.Type<typeof EditorViewMode>;
|
|
18
|
-
export declare const EditorInputModes: readonly ["default", "vim", "vscode"];
|
|
19
|
-
export declare const EditorInputMode: Schema.Schema<"default" | "vim" | "vscode", "default" | "vim" | "vscode", never>;
|
|
20
|
-
export type EditorInputMode = Schema.Schema.Type<typeof EditorInputMode>;
|
|
21
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/types/types.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,KAAK,MAAM,MAAM,eAAe,CAAC;AAGxC,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAIF,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,CAAC,KAAK,SAAS,MAAM,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC;AAE7G,eAAO,MAAM,eAAe,4CAA6C,CAAC;AAC1E,eAAO,MAAM,cAAc,4FAAuE,CAAC;AACnG,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,cAAc,CAAC,CAAC;AAEvE,eAAO,MAAM,gBAAgB,uCAAwC,CAAC;AACtE,eAAO,MAAM,eAAe,kFAAwE,CAAC;AACrG,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,eAAe,CAAC,CAAC"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { type EditorState } from '@codemirror/state';
|
|
2
|
-
import { type Range } from '../types';
|
|
3
|
-
/**
|
|
4
|
-
* Determines if two ranges overlap.
|
|
5
|
-
* A range is considered to overlap if there is any intersection
|
|
6
|
-
* between the two ranges, inclusive of their boundaries.
|
|
7
|
-
*/
|
|
8
|
-
export declare const overlap: (a: Range, b: Range) => boolean;
|
|
9
|
-
/**
|
|
10
|
-
* Converts indexes into the text document into stable peer-independent cursors.
|
|
11
|
-
*
|
|
12
|
-
* See:
|
|
13
|
-
* - https://automerge.org/automerge/api-docs/js/functions/next.getCursor.html
|
|
14
|
-
* - https://github.com/yjs/yjs?tab=readme-ov-file#relative-positions
|
|
15
|
-
*
|
|
16
|
-
* @param {assoc} number Negative values will associate the cursor with the previous character
|
|
17
|
-
* while positive - with the next one.
|
|
18
|
-
*/
|
|
19
|
-
export interface CursorConverter {
|
|
20
|
-
toCursor(position: number, assoc?: -1 | 1 | undefined): string;
|
|
21
|
-
fromCursor(cursor: string): number;
|
|
22
|
-
}
|
|
23
|
-
export declare class Cursor {
|
|
24
|
-
static readonly converter: import("@codemirror/state").Facet<unknown, CursorConverter>;
|
|
25
|
-
static readonly getCursorFromRange: (state: EditorState, range: Range) => string;
|
|
26
|
-
static readonly getRangeFromCursor: (state: EditorState, cursor: string) => {
|
|
27
|
-
from: number;
|
|
28
|
-
to: number;
|
|
29
|
-
} | undefined;
|
|
30
|
-
}
|
|
31
|
-
//# sourceMappingURL=cursor.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cursor.d.ts","sourceRoot":"","sources":["../../../../src/util/cursor.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,UAAU,CAAC;AAItC;;;;GAIG;AACH,eAAO,MAAM,OAAO,GAAI,GAAG,KAAK,EAAE,GAAG,KAAK,KAAG,OAA2C,CAAC;AAEzF;;;;;;;;;GASG;AACH,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,GAAG,MAAM,CAAC;IAC/D,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;CACpC;AAOD,qBAAa,MAAM;IACjB,MAAM,CAAC,QAAQ,CAAC,SAAS,8DAA4C;IAErE,MAAM,CAAC,QAAQ,CAAC,kBAAkB,GAAI,OAAO,WAAW,EAAE,OAAO,KAAK,YAKpE;IAEF,MAAM,CAAC,QAAQ,CAAC,kBAAkB,GAAI,OAAO,WAAW,EAAE,QAAQ,MAAM;;;kBAOtE;CACH"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { type Transaction } from '@codemirror/state';
|
|
2
|
-
import { type EditorView } from '@codemirror/view';
|
|
3
|
-
export declare const wrapWithCatch: (fn: (...args: any[]) => any, label?: string) => (...args: any[]) => any;
|
|
4
|
-
/**
|
|
5
|
-
* CodeMirror callbacks swallow errors so wrap handlers.
|
|
6
|
-
*/
|
|
7
|
-
export declare const callbackWrapper: <T extends Function>(fn: T) => T;
|
|
8
|
-
/**
|
|
9
|
-
* Log all changes before dispatching them to the view.
|
|
10
|
-
* https://codemirror.net/docs/ref/#view.EditorView.dispatch
|
|
11
|
-
*/
|
|
12
|
-
export declare const debugDispatcher: (trs: readonly Transaction[], view: EditorView) => void;
|
|
13
|
-
/**
|
|
14
|
-
* Util to log transactions in update listener.
|
|
15
|
-
*/
|
|
16
|
-
export declare const logChanges: (trs: readonly Transaction[]) => void;
|
|
17
|
-
//# sourceMappingURL=debug.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"debug.d.ts","sourceRoot":"","sources":["../../../../src/util/debug.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAInD,eAAO,MAAM,aAAa,GAAI,IAAI,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EAAE,QAAQ,MAAM,MAC/D,GAAG,MAAM,GAAG,EAAE,QAOvB,CAAC;AAEF;;GAEG;AAEH,eAAO,MAAM,eAAe,GAAI,CAAC,SAAS,QAAQ,EAAE,IAAI,CAAC,KAAG,CAOxC,CAAC;AAErB;;;GAGG;AACH,eAAO,MAAM,eAAe,GAAI,KAAK,SAAS,WAAW,EAAE,EAAE,MAAM,UAAU,SAG5E,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,UAAU,GAAI,KAAK,SAAS,WAAW,EAAE,SAmBrD,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"decorations.d.ts","sourceRoot":"","sources":["../../../../src/util/decorations.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEvE,eAAO,MAAM,oBAAoB,GAAI,MAAM,aAAa,KAAG,SAAS,KAAK,CAAC,UAAU,CAAC,EAapF,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export type Rect = {
|
|
2
|
-
readonly left: number;
|
|
3
|
-
readonly right: number;
|
|
4
|
-
readonly top: number;
|
|
5
|
-
readonly bottom: number;
|
|
6
|
-
};
|
|
7
|
-
export declare const flattenRect: (rect: Rect, left: boolean) => Rect;
|
|
8
|
-
export declare const textRange: (node: Text, from: number, to?: number) => Range;
|
|
9
|
-
export declare const clientRectsFor: (dom: Node) => DOMRectList;
|
|
10
|
-
//# sourceMappingURL=dom.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dom.d.ts","sourceRoot":"","sources":["../../../../src/util/dom.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,IAAI,GAAG;IACjB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,eAAO,MAAM,WAAW,GAAI,MAAM,IAAI,EAAE,MAAM,OAAO,KAAG,IAGvD,CAAC;AAIF,eAAO,MAAM,SAAS,GAAI,MAAM,IAAI,EAAE,MAAM,MAAM,EAAE,WAAS,KAAG,KAK/D,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,KAAK,IAAI,KAAG,WAQ1C,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"facet.d.ts","sourceRoot":"","sources":["../../../../src/util/facet.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,eAAO,MAAM,gBAAgB,GAAI,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,eAAe,CAAC,gBAMvD,CAAC"}
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type EditorView } from '@codemirror/view';
|
|
6
|
-
import { type Rx } from '@effect-rx/rx-react';
|
|
7
|
-
import { useMemo } from 'react';
|
|
8
|
-
|
|
9
|
-
import { type Action } from '@dxos/app-graph';
|
|
10
|
-
import { type Live, live } from '@dxos/live-object';
|
|
11
|
-
import {
|
|
12
|
-
type ActionGraphProps,
|
|
13
|
-
type MenuActionProperties,
|
|
14
|
-
type MenuItemGroup,
|
|
15
|
-
type MenuSeparator,
|
|
16
|
-
type ToolbarMenuActionGroupProperties,
|
|
17
|
-
createMenuAction,
|
|
18
|
-
createMenuItemGroup,
|
|
19
|
-
} from '@dxos/react-ui-menu';
|
|
20
|
-
|
|
21
|
-
import type { EditorAction, Formatting } from '../../extensions';
|
|
22
|
-
import { translationKey } from '../../translations';
|
|
23
|
-
import { type EditorViewMode } from '../../types';
|
|
24
|
-
|
|
25
|
-
export type EditorToolbarState = { viewMode?: EditorViewMode } & Formatting;
|
|
26
|
-
|
|
27
|
-
export const useEditorToolbarState = (initialState: Partial<EditorToolbarState> = {}): Live<EditorToolbarState> => {
|
|
28
|
-
return useMemo(() => live<EditorToolbarState>(initialState), []);
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
export type EditorToolbarActionGraphProps = {
|
|
32
|
-
state: Live<EditorToolbarState>;
|
|
33
|
-
getView: () => EditorView;
|
|
34
|
-
// TODO(wittjosiah): Control positioning.
|
|
35
|
-
customActions?: Rx.Rx<ActionGraphProps>;
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
export type EditorToolbarItem = EditorAction | MenuItemGroup | MenuSeparator;
|
|
39
|
-
|
|
40
|
-
export const createEditorAction = (id: string, props: Partial<MenuActionProperties>, invoke: () => void) => {
|
|
41
|
-
const { label = [`${id} label`, { ns: translationKey }], ...rest } = props;
|
|
42
|
-
return createMenuAction(id, invoke, {
|
|
43
|
-
label,
|
|
44
|
-
...rest,
|
|
45
|
-
}) as Action<MenuActionProperties>;
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
export const createEditorActionGroup = (
|
|
49
|
-
id: string,
|
|
50
|
-
props: Omit<ToolbarMenuActionGroupProperties, 'icon'>,
|
|
51
|
-
icon?: string,
|
|
52
|
-
) => {
|
|
53
|
-
const { label = [`${id} label`, { ns: translationKey }], ...rest } = props;
|
|
54
|
-
return createMenuItemGroup(id, {
|
|
55
|
-
label,
|
|
56
|
-
icon,
|
|
57
|
-
iconOnly: true,
|
|
58
|
-
...rest,
|
|
59
|
-
});
|
|
60
|
-
};
|
package/src/defaults.ts
DELETED
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { EditorView } from '@codemirror/view';
|
|
6
|
-
|
|
7
|
-
import { mx } from '@dxos/react-ui-theme';
|
|
8
|
-
|
|
9
|
-
import { type ThemeExtensionsOptions } from './extensions';
|
|
10
|
-
import { fontMono } from './styles';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* CodeMirror content width.
|
|
14
|
-
* 40rem = 640px. Corresponds to initial plank width (Google docs, Stashpad, etc.)
|
|
15
|
-
* 50rem = 800px. Maximum content width for solo mode.
|
|
16
|
-
* NOTE: Max width - 4rem = 2rem left/right margin (or 2rem gutter plus 1rem left/right margin).
|
|
17
|
-
*/
|
|
18
|
-
export const editorWidth = '!mli-auto is-full max-is-[min(50rem,100%-4rem)]';
|
|
19
|
-
|
|
20
|
-
export const editorSlots: ThemeExtensionsOptions['slots'] = {
|
|
21
|
-
scroll: {
|
|
22
|
-
className: 'pbs-2',
|
|
23
|
-
},
|
|
24
|
-
content: {
|
|
25
|
-
className: editorWidth,
|
|
26
|
-
},
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
export const editorGutter = EditorView.theme({
|
|
30
|
-
'.cm-gutters': {
|
|
31
|
-
// NOTE: Color required to cover content if scrolling horizontally.
|
|
32
|
-
// TODO(burdon): Non-transparent background clips the focus ring.
|
|
33
|
-
background: 'var(--dx-baseSurface) !important',
|
|
34
|
-
paddingRight: '1rem',
|
|
35
|
-
},
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
export const editorMonospace = EditorView.theme({
|
|
39
|
-
'.cm-content': {
|
|
40
|
-
fontFamily: fontMono,
|
|
41
|
-
},
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
export const editorWithToolbarLayout =
|
|
45
|
-
'grid grid-cols-1 grid-rows-[min-content_1fr] data-[toolbar=disabled]:grid-rows-[1fr] justify-center content-start overflow-hidden';
|
|
46
|
-
|
|
47
|
-
// NOTE: Padding is added to the editor to account for the focus ring (since otherwise the CM gutter will clip it)
|
|
48
|
-
export const stackItemContentEditorClassNames = (role?: string) =>
|
|
49
|
-
mx(
|
|
50
|
-
'p-0.5 dx-focus-ring-inset attention-surface data-[toolbar=disabled]:pbs-2',
|
|
51
|
-
role === 'section' ? '[&_.cm-scroller]:overflow-hidden [&_.cm-scroller]:min-bs-24' : 'min-bs-0',
|
|
52
|
-
);
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2024 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Extension, RangeSetBuilder } from '@codemirror/state';
|
|
6
|
-
import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate } from '@codemirror/view';
|
|
7
|
-
|
|
8
|
-
const annotationMark = Decoration.mark({ class: 'cm-annotation' });
|
|
9
|
-
|
|
10
|
-
export type AnnotationOptions = {
|
|
11
|
-
match?: RegExp; // TODO(burdon): Update via hook (e.g., for search).
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
*
|
|
16
|
-
*/
|
|
17
|
-
export const annotations = ({ match }: AnnotationOptions = {}): Extension => {
|
|
18
|
-
return [
|
|
19
|
-
ViewPlugin.fromClass(
|
|
20
|
-
class {
|
|
21
|
-
decorations: DecorationSet = Decoration.none;
|
|
22
|
-
update(update: ViewUpdate) {
|
|
23
|
-
const builder = new RangeSetBuilder<Decoration>();
|
|
24
|
-
if (match) {
|
|
25
|
-
// Only process visible lines.
|
|
26
|
-
const { from, to } = update.view.viewport;
|
|
27
|
-
const text = update.state.doc.sliceString(from, to);
|
|
28
|
-
const matches = text.matchAll(match);
|
|
29
|
-
for (const m of matches) {
|
|
30
|
-
if (m.index !== undefined) {
|
|
31
|
-
// Adjust match position relative to viewport.
|
|
32
|
-
const start = from + m.index;
|
|
33
|
-
const end = start + m[0].length;
|
|
34
|
-
builder.add(start, end, annotationMark);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
this.decorations = builder.finish();
|
|
40
|
-
}
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
decorations: (v) => v.decorations,
|
|
44
|
-
},
|
|
45
|
-
),
|
|
46
|
-
|
|
47
|
-
EditorView.theme({
|
|
48
|
-
'.cm-annotation': {
|
|
49
|
-
textDecoration: 'underline',
|
|
50
|
-
textDecorationStyle: 'wavy',
|
|
51
|
-
textDecorationColor: 'var(--dx-errorText)',
|
|
52
|
-
},
|
|
53
|
-
}),
|
|
54
|
-
];
|
|
55
|
-
};
|
|
@@ -1,220 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Extension, Prec } from '@codemirror/state';
|
|
6
|
-
import {
|
|
7
|
-
Decoration,
|
|
8
|
-
type DecorationSet,
|
|
9
|
-
EditorView,
|
|
10
|
-
ViewPlugin,
|
|
11
|
-
type ViewUpdate,
|
|
12
|
-
WidgetType,
|
|
13
|
-
keymap,
|
|
14
|
-
} from '@codemirror/view';
|
|
15
|
-
|
|
16
|
-
export type AutocompleteOptions = {
|
|
17
|
-
fireIfEmpty?: boolean;
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Callback triggered when Enter is pressed.
|
|
21
|
-
* @param text The current text in the editor
|
|
22
|
-
* @returns true if the editor should reset the document.
|
|
23
|
-
*/
|
|
24
|
-
onSubmit?: (text: string) => boolean | void;
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Function that returns a list of suggestions based on the current text.
|
|
28
|
-
* @param text The current text before the cursor
|
|
29
|
-
* @returns Array of suggestion strings
|
|
30
|
-
*/
|
|
31
|
-
onSuggest?: (text: string) => string[];
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* ESC pressed.
|
|
35
|
-
*/
|
|
36
|
-
onCancel?: () => void;
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Creates an autocomplete extension that shows inline suggestions.
|
|
41
|
-
* Pressing Tab will complete the suggestion.
|
|
42
|
-
*/
|
|
43
|
-
// TODO(burdon): Reconcile with typeahead.
|
|
44
|
-
export const autocomplete = ({ fireIfEmpty, onSubmit, onSuggest, onCancel }: AutocompleteOptions = {}): Extension => {
|
|
45
|
-
const suggest = ViewPlugin.fromClass(
|
|
46
|
-
class {
|
|
47
|
-
_decorations: DecorationSet;
|
|
48
|
-
_currentSuggestion: string | null = null;
|
|
49
|
-
|
|
50
|
-
constructor(view: EditorView) {
|
|
51
|
-
this._decorations = this.computeDecorations(view);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
update(update: ViewUpdate) {
|
|
55
|
-
if (update.docChanged || update.selectionSet) {
|
|
56
|
-
this._decorations = this.computeDecorations(update.view);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
private computeDecorations(view: EditorView): DecorationSet {
|
|
61
|
-
const text = view.state.doc.toString();
|
|
62
|
-
const suggestions = onSuggest?.(text) ?? [];
|
|
63
|
-
if (!suggestions.length) {
|
|
64
|
-
this._currentSuggestion = null;
|
|
65
|
-
return Decoration.none;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// Get the first suggestion.
|
|
69
|
-
this._currentSuggestion = suggestions[0];
|
|
70
|
-
const suffix = this._currentSuggestion.slice(text.length);
|
|
71
|
-
if (!suffix) {
|
|
72
|
-
return Decoration.none;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// Always show ghost text at the end of the document.
|
|
76
|
-
return Decoration.set([
|
|
77
|
-
Decoration.widget({
|
|
78
|
-
widget: new InlineSuggestionWidget(suffix),
|
|
79
|
-
side: 1,
|
|
80
|
-
}).range(view.state.doc.length),
|
|
81
|
-
]);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
completeSuggestion(view: EditorView): boolean {
|
|
85
|
-
if (!this._currentSuggestion) {
|
|
86
|
-
return false;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
const text = view.state.doc.toString();
|
|
90
|
-
const suffix = this._currentSuggestion.slice(text.length);
|
|
91
|
-
if (!suffix) {
|
|
92
|
-
return false;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
view.dispatch({
|
|
96
|
-
changes: {
|
|
97
|
-
from: view.state.doc.length,
|
|
98
|
-
insert: suffix,
|
|
99
|
-
},
|
|
100
|
-
selection: {
|
|
101
|
-
anchor: view.state.doc.length + suffix.length,
|
|
102
|
-
},
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
return true;
|
|
106
|
-
}
|
|
107
|
-
},
|
|
108
|
-
{
|
|
109
|
-
decorations: (v) => v._decorations,
|
|
110
|
-
},
|
|
111
|
-
);
|
|
112
|
-
|
|
113
|
-
return [
|
|
114
|
-
suggest,
|
|
115
|
-
EditorView.theme({
|
|
116
|
-
'.cm-inline-suggestion': {
|
|
117
|
-
opacity: 0.4,
|
|
118
|
-
},
|
|
119
|
-
}),
|
|
120
|
-
|
|
121
|
-
Prec.highest(
|
|
122
|
-
keymap.of([
|
|
123
|
-
{
|
|
124
|
-
key: 'Tab',
|
|
125
|
-
preventDefault: true,
|
|
126
|
-
run: (view) => {
|
|
127
|
-
const plugin = view.plugin(suggest);
|
|
128
|
-
return plugin?.completeSuggestion(view) ?? false;
|
|
129
|
-
},
|
|
130
|
-
},
|
|
131
|
-
{
|
|
132
|
-
key: 'ArrowRight',
|
|
133
|
-
preventDefault: true,
|
|
134
|
-
run: (view) => {
|
|
135
|
-
// Only complete if cursor is at the end
|
|
136
|
-
if (view.state.selection.main.head !== view.state.doc.length) {
|
|
137
|
-
return false;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
const plugin = view.plugin(suggest);
|
|
141
|
-
return plugin?.completeSuggestion(view) ?? false;
|
|
142
|
-
},
|
|
143
|
-
},
|
|
144
|
-
{
|
|
145
|
-
key: 'Enter',
|
|
146
|
-
preventDefault: true,
|
|
147
|
-
run: (view) => {
|
|
148
|
-
const text = view.state.doc.toString().trim();
|
|
149
|
-
if (onSubmit && (fireIfEmpty || text.length > 0)) {
|
|
150
|
-
const reset = onSubmit(text);
|
|
151
|
-
|
|
152
|
-
// Clear the document after calling onEnter.
|
|
153
|
-
if (reset) {
|
|
154
|
-
view.dispatch({
|
|
155
|
-
changes: {
|
|
156
|
-
from: 0,
|
|
157
|
-
to: view.state.doc.length,
|
|
158
|
-
insert: '',
|
|
159
|
-
},
|
|
160
|
-
});
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
return true;
|
|
165
|
-
},
|
|
166
|
-
},
|
|
167
|
-
{
|
|
168
|
-
key: 'Shift-Enter',
|
|
169
|
-
preventDefault: true,
|
|
170
|
-
run: (view) => {
|
|
171
|
-
view.dispatch({
|
|
172
|
-
changes: {
|
|
173
|
-
from: view.state.selection.main.head,
|
|
174
|
-
insert: '\n',
|
|
175
|
-
},
|
|
176
|
-
selection: {
|
|
177
|
-
anchor: view.state.selection.main.head + 1,
|
|
178
|
-
head: view.state.selection.main.head + 1,
|
|
179
|
-
},
|
|
180
|
-
});
|
|
181
|
-
return true;
|
|
182
|
-
},
|
|
183
|
-
},
|
|
184
|
-
{
|
|
185
|
-
key: 'Escape',
|
|
186
|
-
preventDefault: true,
|
|
187
|
-
run: (view) => {
|
|
188
|
-
// Clear the entire document.
|
|
189
|
-
view.dispatch({
|
|
190
|
-
changes: {
|
|
191
|
-
from: 0,
|
|
192
|
-
to: view.state.doc.length,
|
|
193
|
-
insert: '',
|
|
194
|
-
},
|
|
195
|
-
});
|
|
196
|
-
onCancel?.();
|
|
197
|
-
return true;
|
|
198
|
-
},
|
|
199
|
-
},
|
|
200
|
-
]),
|
|
201
|
-
),
|
|
202
|
-
];
|
|
203
|
-
};
|
|
204
|
-
|
|
205
|
-
class InlineSuggestionWidget extends WidgetType {
|
|
206
|
-
constructor(private suffix: string) {
|
|
207
|
-
super();
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
override toDOM(): HTMLSpanElement {
|
|
211
|
-
const span = document.createElement('span');
|
|
212
|
-
span.textContent = this.suffix;
|
|
213
|
-
span.className = 'cm-inline-suggestion';
|
|
214
|
-
return span;
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
override eq(other: InlineSuggestionWidget): boolean {
|
|
218
|
-
return other.suffix === this.suffix;
|
|
219
|
-
}
|
|
220
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
export type CompoetionContext = { line: string };
|
|
6
|
-
|
|
7
|
-
export type CompletionOptions = {
|
|
8
|
-
default?: string;
|
|
9
|
-
minLength?: number;
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Util to match current line to a static list of completions.
|
|
14
|
-
*/
|
|
15
|
-
export const staticCompletion =
|
|
16
|
-
(completions: string[], options: CompletionOptions = {}) =>
|
|
17
|
-
({ line }: CompoetionContext) => {
|
|
18
|
-
if (line.length === 0 && options.default) {
|
|
19
|
-
return options.default;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
const parts = line.split(/\s+/).filter(Boolean);
|
|
23
|
-
if (parts.length) {
|
|
24
|
-
const str = parts.at(-1)!;
|
|
25
|
-
if (str.length >= (options.minLength ?? 0)) {
|
|
26
|
-
for (const completion of completions) {
|
|
27
|
-
const match = matchCompletion(completion, str);
|
|
28
|
-
if (match) {
|
|
29
|
-
return match;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
export const matchCompletion = (completion: string, str: string, minLength = 0): string | undefined => {
|
|
37
|
-
if (
|
|
38
|
-
str.length >= minLength &&
|
|
39
|
-
completion.length > str.length &&
|
|
40
|
-
completion.startsWith(str)
|
|
41
|
-
// TODO(burdon): If case insensitive, need to replace existing chars.
|
|
42
|
-
// completion.toLowerCase().startsWith(str.toLowerCase())
|
|
43
|
-
) {
|
|
44
|
-
return completion.slice(str.length);
|
|
45
|
-
}
|
|
46
|
-
};
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
// Based on https://github.com/codemirror/view/blob/main/src/placeholder.ts
|
|
4
|
-
//
|
|
5
|
-
|
|
6
|
-
import { type Extension } from '@codemirror/state';
|
|
7
|
-
import { Decoration, EditorView, ViewPlugin, type ViewUpdate, WidgetType } from '@codemirror/view';
|
|
8
|
-
|
|
9
|
-
import { clientRectsFor, flattenRect } from '../../util';
|
|
10
|
-
|
|
11
|
-
type Content = string | HTMLElement | ((view: EditorView) => HTMLElement);
|
|
12
|
-
|
|
13
|
-
export type PlaceholderOptions = {
|
|
14
|
-
content: Content;
|
|
15
|
-
delay?: number;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Shows a transient placeholder at the current cursor position.
|
|
20
|
-
*/
|
|
21
|
-
export const placeholder = ({ content, delay = 3_000 }: PlaceholderOptions): Extension => {
|
|
22
|
-
const plugin = ViewPlugin.fromClass(
|
|
23
|
-
class {
|
|
24
|
-
_timeout: ReturnType<typeof setTimeout> | undefined;
|
|
25
|
-
_decorations = Decoration.none;
|
|
26
|
-
|
|
27
|
-
update(update: ViewUpdate) {
|
|
28
|
-
if (this._timeout) {
|
|
29
|
-
window.clearTimeout(this._timeout);
|
|
30
|
-
this._timeout = undefined;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
// Check if the active line (where cursor is) is empty.
|
|
34
|
-
const activeLine = update.view.state.doc.lineAt(update.view.state.selection.main.head);
|
|
35
|
-
const isEmpty = activeLine.text.trim() === '';
|
|
36
|
-
if (isEmpty) {
|
|
37
|
-
// Create widget decoration at the start of the current line.
|
|
38
|
-
const lineStart = activeLine.from;
|
|
39
|
-
this._timeout = setTimeout(() => {
|
|
40
|
-
this._decorations = Decoration.set([
|
|
41
|
-
Decoration.widget({
|
|
42
|
-
widget: new PlaceholderWidget(content),
|
|
43
|
-
side: 1,
|
|
44
|
-
}).range(lineStart),
|
|
45
|
-
]);
|
|
46
|
-
|
|
47
|
-
update.view.update([]);
|
|
48
|
-
}, delay);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
this._decorations = Decoration.none;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
destroy() {
|
|
55
|
-
if (this._timeout) {
|
|
56
|
-
clearTimeout(this._timeout);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
},
|
|
60
|
-
{
|
|
61
|
-
provide: (plugin) => {
|
|
62
|
-
return [EditorView.decorations.of((view) => view.plugin(plugin)?._decorations ?? Decoration.none)];
|
|
63
|
-
},
|
|
64
|
-
},
|
|
65
|
-
);
|
|
66
|
-
|
|
67
|
-
return typeof content === 'string'
|
|
68
|
-
? [plugin, EditorView.contentAttributes.of({ 'aria-placeholder': content })]
|
|
69
|
-
: plugin;
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
export class PlaceholderWidget extends WidgetType {
|
|
73
|
-
constructor(readonly content: Content) {
|
|
74
|
-
super();
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
toDOM(view: EditorView) {
|
|
78
|
-
const wrap = document.createElement('span');
|
|
79
|
-
wrap.className = 'cm-placeholder';
|
|
80
|
-
wrap.style.pointerEvents = 'none';
|
|
81
|
-
wrap.setAttribute('aria-hidden', 'true');
|
|
82
|
-
wrap.appendChild(
|
|
83
|
-
typeof this.content === 'string'
|
|
84
|
-
? document.createTextNode(this.content)
|
|
85
|
-
: typeof this.content === 'function'
|
|
86
|
-
? this.content(view)
|
|
87
|
-
: this.content.cloneNode(true),
|
|
88
|
-
);
|
|
89
|
-
|
|
90
|
-
return wrap;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
override coordsAt(dom: HTMLElement) {
|
|
94
|
-
const rects = dom.firstChild ? clientRectsFor(dom.firstChild) : [];
|
|
95
|
-
if (!rects.length) {
|
|
96
|
-
return null;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
const style = getComputedStyle(dom.parentNode as HTMLElement);
|
|
100
|
-
const rect = flattenRect(rects[0], style.direction !== 'rtl');
|
|
101
|
-
const lineHeight = parseInt(style.lineHeight);
|
|
102
|
-
if (rect.bottom - rect.top > lineHeight * 1.5) {
|
|
103
|
-
return {
|
|
104
|
-
left: rect.left,
|
|
105
|
-
right: rect.right,
|
|
106
|
-
top: rect.top,
|
|
107
|
-
bottom: rect.top + lineHeight,
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
return rect;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
override ignoreEvent() {
|
|
115
|
-
return false;
|
|
116
|
-
}
|
|
117
|
-
}
|