@dxos/react-ui-editor 0.8.4-main.ead640a → 0.8.4-main.effb148878
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/LICENSE +102 -5
- package/README.md +1 -1
- package/dist/lib/browser/index.mjs +1105 -8387
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/translations.mjs +39 -0
- package/dist/lib/browser/translations.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +1105 -8386
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/translations.mjs +41 -0
- package/dist/lib/node-esm/translations.mjs.map +7 -0
- package/dist/types/src/components/Editor/Editor.d.ts +53 -29
- 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/Editor/EditorView.d.ts +31 -0
- package/dist/types/src/components/Editor/EditorView.d.ts.map +1 -0
- package/dist/types/src/components/Editor/controller.d.ts +10 -0
- package/dist/types/src/components/Editor/controller.d.ts.map +1 -0
- package/dist/types/src/{extensions/popover/PopoverMenuProvider.d.ts → components/EditorMenuProvider/EditorMenuProvider.d.ts} +7 -9
- 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 +2 -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 +28 -2
- package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/blocks.d.ts +4 -17
- package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/formatting.d.ts +4 -17
- package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/headings.d.ts +4 -17
- package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/image.d.ts +3 -15
- package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
- package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/lists.d.ts +4 -17
- package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/search.d.ts +3 -15
- package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/types.d.ts +6 -0
- package/dist/types/src/components/EditorToolbar/types.d.ts.map +1 -0
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts +5 -18
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +2 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions/Assistant.stories.d.ts +10 -0
- package/dist/types/src/extensions/Assistant.stories.d.ts.map +1 -0
- package/dist/types/src/extensions/assistant-extension.d.ts +24 -0
- package/dist/types/src/extensions/assistant-extension.d.ts.map +1 -0
- package/dist/types/src/extensions/index.d.ts +1 -25
- package/dist/types/src/extensions/index.d.ts.map +1 -1
- package/dist/types/src/hooks/index.d.ts +1 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts +25 -0
- package/dist/types/src/hooks/useBasicMarkdownExtensions.d.ts.map +1 -0
- 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 -9
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/stories/Automerge.stories.d.ts +44 -0
- package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
- 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 +29 -27
- package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Experimental.stories.d.ts +5 -4
- 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 +2 -2
- package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Popover.stories.d.ts +3 -3
- 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 +11 -20
- package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
- package/dist/types/src/stories/components/util.d.ts +4 -3
- package/dist/types/src/stories/components/util.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +26 -26
- 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 +6 -5
- package/dist/types/src/util/react.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +94 -90
- package/src/components/Editor/Editor.stories.tsx +69 -49
- package/src/components/Editor/Editor.tsx +165 -61
- package/src/components/Editor/EditorView.tsx +102 -0
- package/src/components/Editor/controller.ts +50 -0
- package/src/{extensions/popover/PopoverMenuProvider.tsx → components/EditorMenuProvider/EditorMenuProvider.tsx} +49 -44
- package/src/components/EditorMenuProvider/index.ts +10 -0
- package/src/{extensions/popover → components/EditorMenuProvider}/menu-presets.ts +20 -19
- package/src/{extensions/popover → components/EditorMenuProvider}/menu.ts +21 -18
- package/src/{extensions/popover → components/EditorMenuProvider}/popover.ts +5 -9
- package/src/{extensions/popover/usePopoverMenu.ts → components/EditorMenuProvider/useEditorMenu.ts} +29 -22
- package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
- package/src/components/EditorPreviewProvider/index.ts +5 -0
- package/src/components/EditorToolbar/EditorToolbar.tsx +90 -112
- package/src/components/EditorToolbar/blocks.ts +55 -47
- package/src/components/EditorToolbar/formatting.ts +44 -45
- package/src/components/EditorToolbar/headings.ts +47 -50
- package/src/components/EditorToolbar/image.ts +16 -14
- package/src/components/EditorToolbar/index.ts +2 -7
- package/src/components/EditorToolbar/lists.ts +42 -40
- package/src/components/EditorToolbar/search.ts +16 -14
- package/src/components/EditorToolbar/types.ts +8 -0
- package/src/components/EditorToolbar/view-mode.ts +37 -42
- package/src/components/index.ts +3 -1
- package/src/extensions/Assistant.stories.tsx +112 -0
- package/src/extensions/assistant-extension.tsx +223 -0
- package/src/extensions/index.ts +2 -26
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useBasicMarkdownExtensions.ts +55 -0
- package/src/hooks/useTextEditor.ts +13 -7
- package/src/index.ts +0 -13
- package/src/stories/Automerge.stories.tsx +177 -0
- package/src/stories/Comments.stories.tsx +49 -45
- package/src/stories/EditorToolbar.stories.tsx +42 -55
- package/src/stories/Experimental.stories.tsx +14 -16
- package/src/stories/Markdown.stories.tsx +16 -16
- package/src/stories/Outliner.stories.tsx +20 -29
- package/src/stories/Popover.stories.tsx +48 -54
- package/src/stories/Preview.stories.tsx +103 -85
- package/src/stories/Tags.stories.tsx +36 -13
- package/src/stories/TextEditor.stories.tsx +15 -21
- package/src/stories/Theme.stories.tsx +61 -0
- package/src/stories/components/EditorStory.tsx +46 -32
- package/src/stories/components/util.tsx +90 -59
- package/src/translations.ts +30 -25
- package/src/util/index.ts +1 -6
- package/src/util/react.tsx +8 -13
- 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/util.d.ts +0 -51
- 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 +0 -47
- 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/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 -11
- 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 -63
- 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 -28
- 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/stories/CommandDialog.stories.d.ts +0 -14
- package/dist/types/src/stories/CommandDialog.stories.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 -76
- 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 -276
- package/src/extensions/focus.ts +0 -36
- package/src/extensions/folding.tsx +0 -44
- package/src/extensions/hashtag.tsx +0 -68
- package/src/extensions/json.ts +0 -57
- package/src/extensions/listener.ts +0 -38
- 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 -188
- 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/stories/CommandDialog.stories.tsx +0 -78
- 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
|
@@ -4,62 +4,59 @@
|
|
|
4
4
|
|
|
5
5
|
import { type EditorView } from '@codemirror/view';
|
|
6
6
|
|
|
7
|
-
import { type
|
|
8
|
-
import {
|
|
7
|
+
import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
|
|
8
|
+
import { setHeading } from '@dxos/ui-editor';
|
|
9
9
|
|
|
10
|
-
import {
|
|
11
|
-
import { translationKey } from '../../translations';
|
|
10
|
+
import { translationKey } from '#translations';
|
|
12
11
|
|
|
13
|
-
import { type EditorToolbarState
|
|
12
|
+
import { type EditorToolbarState } from './types';
|
|
14
13
|
|
|
15
|
-
const
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
'ph--text-h--regular',
|
|
25
|
-
);
|
|
26
|
-
|
|
27
|
-
const createHeadingActions = (getView: () => EditorView) =>
|
|
28
|
-
Object.entries({
|
|
29
|
-
'0': 'ph--paragraph--regular',
|
|
30
|
-
'1': 'ph--text-h-one--regular',
|
|
31
|
-
'2': 'ph--text-h-two--regular',
|
|
32
|
-
'3': 'ph--text-h-three--regular',
|
|
33
|
-
'4': 'ph--text-h-four--regular',
|
|
34
|
-
'5': 'ph--text-h-five--regular',
|
|
35
|
-
'6': 'ph--text-h-six--regular',
|
|
36
|
-
}).map(([levelStr, icon]) => {
|
|
37
|
-
const level = parseInt(levelStr);
|
|
38
|
-
return createEditorAction(
|
|
39
|
-
`heading--${levelStr}`,
|
|
40
|
-
{
|
|
41
|
-
label: ['heading level label', { count: level, ns: translationKey }],
|
|
42
|
-
icon,
|
|
43
|
-
},
|
|
44
|
-
() => setHeading(level)(getView()),
|
|
45
|
-
);
|
|
46
|
-
});
|
|
14
|
+
const headingIcons: Record<string, string> = {
|
|
15
|
+
0: 'ph--paragraph--regular',
|
|
16
|
+
1: 'ph--text-h-one--regular',
|
|
17
|
+
2: 'ph--text-h-two--regular',
|
|
18
|
+
3: 'ph--text-h-three--regular',
|
|
19
|
+
4: 'ph--text-h-four--regular',
|
|
20
|
+
5: 'ph--text-h-five--regular',
|
|
21
|
+
6: 'ph--text-h-six--regular',
|
|
22
|
+
};
|
|
47
23
|
|
|
48
24
|
const computeHeadingValue = (state: EditorToolbarState) => {
|
|
49
25
|
const blockType = state ? state.blockType : 'paragraph';
|
|
50
|
-
const
|
|
51
|
-
return
|
|
26
|
+
const heading = blockType && /heading(\d)/.exec(blockType);
|
|
27
|
+
return heading ? heading[1] : blockType === 'paragraph' || !blockType ? '0' : '';
|
|
52
28
|
};
|
|
53
29
|
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
{
|
|
62
|
-
|
|
63
|
-
|
|
30
|
+
/** Add heading actions to the builder. */
|
|
31
|
+
export const addHeadings =
|
|
32
|
+
(state: EditorToolbarState, getView: () => EditorView): ActionGroupBuilderFn =>
|
|
33
|
+
(builder) => {
|
|
34
|
+
const headingValue = computeHeadingValue(state);
|
|
35
|
+
builder.group(
|
|
36
|
+
'heading',
|
|
37
|
+
{
|
|
38
|
+
label: ['heading.label', { ns: translationKey }],
|
|
39
|
+
icon: 'ph--text-h--regular',
|
|
40
|
+
iconOnly: true,
|
|
41
|
+
variant: 'dropdownMenu',
|
|
42
|
+
applyActive: true,
|
|
43
|
+
selectCardinality: 'single',
|
|
44
|
+
// TODO(wittjosiah): Remove? Not sure this does anything.
|
|
45
|
+
value: headingValue,
|
|
46
|
+
} as ToolbarMenuActionGroupProperties,
|
|
47
|
+
(group) => {
|
|
48
|
+
for (const [levelStr, icon] of Object.entries(headingIcons)) {
|
|
49
|
+
const level = parseInt(levelStr);
|
|
50
|
+
group.action(
|
|
51
|
+
`heading--${levelStr}`,
|
|
52
|
+
{
|
|
53
|
+
label: ['heading-level.label', { count: level, ns: translationKey }],
|
|
54
|
+
icon,
|
|
55
|
+
checked: levelStr === headingValue,
|
|
56
|
+
},
|
|
57
|
+
() => setHeading(level)(getView()),
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
);
|
|
64
62
|
};
|
|
65
|
-
};
|
|
@@ -2,19 +2,21 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { type ActionGroupBuilderFn } from '@dxos/react-ui-menu';
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
createEditorAction(
|
|
9
|
-
'image',
|
|
10
|
-
{
|
|
11
|
-
testId: 'editor.toolbar.image',
|
|
12
|
-
icon: 'ph--image-square--regular',
|
|
13
|
-
},
|
|
14
|
-
onImageUpload,
|
|
15
|
-
);
|
|
7
|
+
import { translationKey } from '#translations';
|
|
16
8
|
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
9
|
+
/** Add image upload action to the builder. */
|
|
10
|
+
export const addImageUpload =
|
|
11
|
+
(onImageUpload: () => void): ActionGroupBuilderFn =>
|
|
12
|
+
(builder) => {
|
|
13
|
+
builder.action(
|
|
14
|
+
'image',
|
|
15
|
+
{
|
|
16
|
+
label: ['image.label', { ns: translationKey }],
|
|
17
|
+
testId: 'editor.toolbar.image',
|
|
18
|
+
icon: 'ph--image-square--regular',
|
|
19
|
+
},
|
|
20
|
+
onImageUpload,
|
|
21
|
+
);
|
|
22
|
+
};
|
|
@@ -2,11 +2,6 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
+
export * from './types';
|
|
6
|
+
|
|
5
7
|
export * from './EditorToolbar';
|
|
6
|
-
export {
|
|
7
|
-
type EditorToolbarState,
|
|
8
|
-
type EditorToolbarActionGraphProps,
|
|
9
|
-
useEditorToolbarState,
|
|
10
|
-
createEditorAction,
|
|
11
|
-
createEditorActionGroup,
|
|
12
|
-
} from './util';
|
|
@@ -4,12 +4,12 @@
|
|
|
4
4
|
|
|
5
5
|
import { type EditorView } from '@codemirror/view';
|
|
6
6
|
|
|
7
|
-
import { type
|
|
8
|
-
import {
|
|
7
|
+
import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
|
|
8
|
+
import { List, addList, removeList } from '@dxos/ui-editor';
|
|
9
9
|
|
|
10
|
-
import {
|
|
10
|
+
import { translationKey } from '#translations';
|
|
11
11
|
|
|
12
|
-
import { type EditorToolbarState
|
|
12
|
+
import { type EditorToolbarState } from './types';
|
|
13
13
|
|
|
14
14
|
const listStyles = {
|
|
15
15
|
bullet: 'ph--list-bullets--regular',
|
|
@@ -17,40 +17,42 @@ const listStyles = {
|
|
|
17
17
|
task: 'ph--list-checks--regular',
|
|
18
18
|
};
|
|
19
19
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
value
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
20
|
+
/** Add list actions to the builder. */
|
|
21
|
+
export const addLists =
|
|
22
|
+
(state: EditorToolbarState, getView: () => EditorView): ActionGroupBuilderFn =>
|
|
23
|
+
(builder) => {
|
|
24
|
+
const value = state.listStyle ?? '';
|
|
25
|
+
builder.group(
|
|
26
|
+
'list',
|
|
27
|
+
{
|
|
28
|
+
label: ['list.label', { ns: translationKey }],
|
|
29
|
+
iconOnly: true,
|
|
30
|
+
variant: 'toggleGroup',
|
|
31
|
+
selectCardinality: 'single',
|
|
32
|
+
value,
|
|
33
|
+
} as ToolbarMenuActionGroupProperties,
|
|
34
|
+
(group) => {
|
|
35
|
+
for (const [listStyle, icon] of Object.entries(listStyles)) {
|
|
36
|
+
const checked = value === listStyle;
|
|
37
|
+
group.action(
|
|
38
|
+
`list-${listStyle}`,
|
|
39
|
+
{ label: [`list.${listStyle}.label`, { ns: translationKey }], checked, icon },
|
|
40
|
+
() => {
|
|
41
|
+
const view = getView();
|
|
42
|
+
if (!view) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
const listType =
|
|
47
|
+
listStyle === 'ordered' ? List.Ordered : listStyle === 'bullet' ? List.Bullet : List.Task;
|
|
48
|
+
if (checked) {
|
|
49
|
+
removeList(listType)(view);
|
|
50
|
+
} else {
|
|
51
|
+
addList(listType)(view);
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
);
|
|
55
58
|
};
|
|
56
|
-
};
|
|
@@ -5,19 +5,21 @@
|
|
|
5
5
|
import { openSearchPanel } from '@codemirror/search';
|
|
6
6
|
import { type EditorView } from '@codemirror/view';
|
|
7
7
|
|
|
8
|
-
import {
|
|
8
|
+
import { type ActionGroupBuilderFn } from '@dxos/react-ui-menu';
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
createEditorAction(
|
|
12
|
-
'search',
|
|
13
|
-
{
|
|
14
|
-
testId: 'editor.toolbar.search',
|
|
15
|
-
icon: 'ph--magnifying-glass--regular',
|
|
16
|
-
},
|
|
17
|
-
() => openSearchPanel(getView()),
|
|
18
|
-
);
|
|
10
|
+
import { translationKey } from '#translations';
|
|
19
11
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
12
|
+
/** Add search action to the builder. */
|
|
13
|
+
export const addSearch =
|
|
14
|
+
(getView: () => EditorView): ActionGroupBuilderFn =>
|
|
15
|
+
(builder) => {
|
|
16
|
+
builder.action(
|
|
17
|
+
'search',
|
|
18
|
+
{
|
|
19
|
+
label: ['search.label', { ns: translationKey }],
|
|
20
|
+
testId: 'editor.toolbar.search',
|
|
21
|
+
icon: 'ph--magnifying-glass--regular',
|
|
22
|
+
},
|
|
23
|
+
() => openSearchPanel(getView()),
|
|
24
|
+
);
|
|
25
|
+
};
|
|
@@ -2,53 +2,48 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { type
|
|
6
|
-
import { type
|
|
5
|
+
import { type ActionGroupBuilderFn, type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
|
|
6
|
+
import { type EditorViewMode } from '@dxos/ui-editor/types';
|
|
7
7
|
|
|
8
|
-
import { translationKey } from '
|
|
9
|
-
import { type EditorViewMode } from '../../types';
|
|
8
|
+
import { translationKey } from '#translations';
|
|
10
9
|
|
|
11
|
-
import { type EditorToolbarState
|
|
10
|
+
import { type EditorToolbarState } from './types';
|
|
12
11
|
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
applyActive: true,
|
|
19
|
-
selectCardinality: 'single',
|
|
20
|
-
value,
|
|
21
|
-
} as ToolbarMenuActionGroupProperties,
|
|
22
|
-
'ph--eye--regular',
|
|
23
|
-
);
|
|
12
|
+
const viewModes = {
|
|
13
|
+
preview: 'ph--eye--regular',
|
|
14
|
+
source: 'ph--pencil-simple--regular',
|
|
15
|
+
readonly: 'ph--pencil-slash--regular',
|
|
16
|
+
};
|
|
24
17
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
return createEditorAction(
|
|
33
|
-
`view-mode--${viewMode}`,
|
|
18
|
+
/** Add view mode actions to the builder. */
|
|
19
|
+
export const addViewMode =
|
|
20
|
+
(state: EditorToolbarState, onViewModeChange: (mode: EditorViewMode) => void): ActionGroupBuilderFn =>
|
|
21
|
+
(builder) => {
|
|
22
|
+
const value = state.viewMode ?? 'source';
|
|
23
|
+
builder.group(
|
|
24
|
+
'viewMode',
|
|
34
25
|
{
|
|
35
|
-
label: [
|
|
36
|
-
|
|
37
|
-
|
|
26
|
+
label: ['view-mode.label', { ns: translationKey }],
|
|
27
|
+
icon: 'ph--eye--regular',
|
|
28
|
+
iconOnly: true,
|
|
29
|
+
variant: 'dropdownMenu',
|
|
30
|
+
applyActive: true,
|
|
31
|
+
selectCardinality: 'single',
|
|
32
|
+
value,
|
|
33
|
+
} as ToolbarMenuActionGroupProperties,
|
|
34
|
+
(group) => {
|
|
35
|
+
for (const [viewMode, icon] of Object.entries(viewModes)) {
|
|
36
|
+
const checked = viewMode === value;
|
|
37
|
+
group.action(
|
|
38
|
+
`view-mode--${viewMode}`,
|
|
39
|
+
{
|
|
40
|
+
label: [`view-mode.${viewMode}.label`, { ns: translationKey }],
|
|
41
|
+
checked,
|
|
42
|
+
icon,
|
|
43
|
+
},
|
|
44
|
+
() => onViewModeChange(viewMode as EditorViewMode),
|
|
45
|
+
);
|
|
46
|
+
}
|
|
38
47
|
},
|
|
39
|
-
() => onViewModeChange(viewMode as EditorViewMode),
|
|
40
48
|
);
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
export const createViewMode = (state: EditorToolbarState, onViewModeChange: (mode: EditorViewMode) => void) => {
|
|
44
|
-
const value = state.viewMode ?? 'source';
|
|
45
|
-
const viewModeGroupAction = createViewModeGroupAction(value);
|
|
46
|
-
const viewModeActions = createViewModeActions(value, onViewModeChange);
|
|
47
|
-
return {
|
|
48
|
-
nodes: [viewModeGroupAction as NodeArg<any>, ...viewModeActions],
|
|
49
|
-
edges: [
|
|
50
|
-
{ source: 'root', target: 'viewMode' },
|
|
51
|
-
...viewModeActions.map(({ id }) => ({ source: viewModeGroupAction.id, target: id })),
|
|
52
|
-
],
|
|
53
49
|
};
|
|
54
|
-
};
|
package/src/components/index.ts
CHANGED
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as LanguageModel from '@effect/ai/LanguageModel';
|
|
6
|
+
import type { Meta, StoryObj } from '@storybook/react-vite';
|
|
7
|
+
import * as Effect from 'effect/Effect';
|
|
8
|
+
import * as Layer from 'effect/Layer';
|
|
9
|
+
import * as ManagedRuntime from 'effect/ManagedRuntime';
|
|
10
|
+
import React, { useEffect, useMemo, useState } from 'react';
|
|
11
|
+
|
|
12
|
+
import { AiService } from '@dxos/ai';
|
|
13
|
+
import { AiServiceTestingPreset } from '@dxos/ai/testing';
|
|
14
|
+
import { useThemeContext } from '@dxos/react-ui';
|
|
15
|
+
import { Loading, withLayout, withTheme } from '@dxos/react-ui/testing';
|
|
16
|
+
import { compactSlots, createBasicExtensions, createThemeExtensions } from '@dxos/ui-editor';
|
|
17
|
+
import { trim } from '@dxos/util';
|
|
18
|
+
|
|
19
|
+
import { translations } from '#translations';
|
|
20
|
+
|
|
21
|
+
import { Editor, type EditorViewProps } from '../components';
|
|
22
|
+
import { assistant, type AssistantOptions } from './assistant-extension';
|
|
23
|
+
|
|
24
|
+
// TODO(burdon): Factor out.
|
|
25
|
+
const useTestGenerate = () => {
|
|
26
|
+
const [generate, setGenerate] = useState<AssistantOptions['generate']>();
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
let disposed = false;
|
|
29
|
+
const rt = ManagedRuntime.make(
|
|
30
|
+
AiService.model('@anthropic/claude-haiku-4-5').pipe(
|
|
31
|
+
Layer.provide(AiServiceTestingPreset('edge-remote')),
|
|
32
|
+
Layer.orDie,
|
|
33
|
+
),
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
if (!disposed) {
|
|
37
|
+
setGenerate(
|
|
38
|
+
() =>
|
|
39
|
+
({ instructions, content }: { instructions: string; content: string }) =>
|
|
40
|
+
rt.runPromise(
|
|
41
|
+
Effect.gen(function* () {
|
|
42
|
+
const prompt = [instructions, content].join('\n\n');
|
|
43
|
+
const response = yield* LanguageModel.generateText({ prompt });
|
|
44
|
+
return response.text;
|
|
45
|
+
}),
|
|
46
|
+
),
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return () => {
|
|
51
|
+
disposed = true;
|
|
52
|
+
void rt.dispose();
|
|
53
|
+
};
|
|
54
|
+
}, []);
|
|
55
|
+
|
|
56
|
+
return generate;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
type DefaultStoryProps = Pick<EditorViewProps, 'value'>;
|
|
60
|
+
|
|
61
|
+
const DefaultStory = (props: DefaultStoryProps) => {
|
|
62
|
+
const { themeMode } = useThemeContext();
|
|
63
|
+
const generate = useTestGenerate();
|
|
64
|
+
const extensions = useMemo(
|
|
65
|
+
() =>
|
|
66
|
+
generate
|
|
67
|
+
? [
|
|
68
|
+
createBasicExtensions({ placeholder: 'Type here...' }),
|
|
69
|
+
createThemeExtensions({ themeMode, slots: compactSlots }),
|
|
70
|
+
assistant({ generate }),
|
|
71
|
+
]
|
|
72
|
+
: [],
|
|
73
|
+
[generate, themeMode],
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
if (extensions.length === 0) {
|
|
77
|
+
return <Loading />;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
return (
|
|
81
|
+
<Editor.Root>
|
|
82
|
+
<Editor.View {...props} classNames='dx-container border border-subdued-separator' extensions={extensions} />
|
|
83
|
+
</Editor.Root>
|
|
84
|
+
);
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
const meta: Meta<typeof DefaultStory> = {
|
|
88
|
+
title: 'ui/react-ui-editor/Assistant',
|
|
89
|
+
render: DefaultStory,
|
|
90
|
+
decorators: [withTheme(), withLayout({ layout: 'column' })],
|
|
91
|
+
tags: ['experimental'],
|
|
92
|
+
parameters: {
|
|
93
|
+
layout: 'fullscreen',
|
|
94
|
+
translations,
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
export default meta;
|
|
99
|
+
|
|
100
|
+
type Story = StoryObj<typeof meta>;
|
|
101
|
+
|
|
102
|
+
export const Default: Story = {
|
|
103
|
+
args: {
|
|
104
|
+
value: trim`
|
|
105
|
+
This text has a speling mistake.
|
|
106
|
+
|
|
107
|
+
And it grammatical errors.
|
|
108
|
+
|
|
109
|
+
But we can fix it.
|
|
110
|
+
`,
|
|
111
|
+
},
|
|
112
|
+
};
|