@dxos/react-ui-editor 0.8.4-main.84f28bd → 0.8.4-main.a4bbb77
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 +3068 -1957
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +71 -1
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/index.mjs +3068 -1957
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +71 -1
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/components/{Popover → CommandMenu}/CommandMenu.d.ts +10 -6
- package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +1 -0
- package/dist/types/src/components/CommandMenu/index.d.ts +2 -0
- package/dist/types/src/components/CommandMenu/index.d.ts.map +1 -0
- package/dist/types/src/components/Editor/Editor.d.ts +15 -9
- package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/util.d.ts +5 -5
- package/dist/types/src/components/EditorToolbar/util.d.ts.map +1 -1
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts +1 -1
- package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/defaults.d.ts.map +1 -1
- package/dist/types/src/extensions/autocomplete.d.ts +20 -7
- package/dist/types/src/extensions/autocomplete.d.ts.map +1 -1
- package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
- package/dist/types/src/extensions/automerge/automerge.stories.d.ts +10 -19
- package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
- package/dist/types/src/extensions/automerge/defs.d.ts +1 -1
- package/dist/types/src/extensions/automerge/defs.d.ts.map +1 -1
- package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
- package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
- package/dist/types/src/extensions/autoscroll.d.ts +10 -0
- package/dist/types/src/extensions/autoscroll.d.ts.map +1 -0
- package/dist/types/src/extensions/{command → command-dialog}/action.d.ts +1 -1
- package/dist/types/src/extensions/command-dialog/action.d.ts.map +1 -0
- package/dist/types/src/extensions/{command/command.d.ts → command-dialog/command-dialog.d.ts} +2 -2
- package/dist/types/src/extensions/command-dialog/command-dialog.d.ts.map +1 -0
- package/dist/types/src/extensions/{command → command-dialog}/hint.d.ts +2 -7
- package/dist/types/src/extensions/command-dialog/hint.d.ts.map +1 -0
- package/dist/types/src/extensions/command-dialog/index.d.ts +4 -0
- package/dist/types/src/extensions/command-dialog/index.d.ts.map +1 -0
- package/dist/types/src/extensions/{command → command-dialog}/state.d.ts +1 -1
- package/dist/types/src/extensions/command-dialog/state.d.ts.map +1 -0
- package/dist/types/src/extensions/command-dialog/typeahead.d.ts.map +1 -0
- package/dist/types/src/extensions/{command → command-menu}/command-menu.d.ts +3 -3
- package/dist/types/src/extensions/command-menu/command-menu.d.ts.map +1 -0
- package/dist/types/src/extensions/command-menu/index.d.ts +3 -0
- package/dist/types/src/extensions/command-menu/index.d.ts.map +1 -0
- package/dist/types/src/extensions/command-menu/placeholder.d.ts.map +1 -0
- package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts +24 -0
- package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts.map +1 -0
- package/dist/types/src/extensions/comments.d.ts +1 -1
- package/dist/types/src/extensions/comments.d.ts.map +1 -1
- package/dist/types/src/extensions/dnd.d.ts.map +1 -1
- package/dist/types/src/extensions/factories.d.ts +12 -16
- package/dist/types/src/extensions/factories.d.ts.map +1 -1
- package/dist/types/src/extensions/floating-menu.d.ts.map +1 -0
- package/dist/types/src/extensions/focus.d.ts.map +1 -1
- package/dist/types/src/extensions/folding.d.ts.map +1 -1
- package/dist/types/src/extensions/index.d.ts +5 -1
- package/dist/types/src/extensions/index.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/action.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/bundle.d.ts +8 -2
- package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/changes.d.ts +1 -1
- package/dist/types/src/extensions/markdown/changes.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/decorate.d.ts +9 -1
- package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/formatting.d.ts +1 -1
- package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/highlight.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/image.d.ts.map +1 -1
- package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
- package/dist/types/src/extensions/outliner/outliner.d.ts +1 -1
- package/dist/types/src/extensions/outliner/outliner.d.ts.map +1 -1
- package/dist/types/src/extensions/outliner/selection.d.ts.map +1 -1
- package/dist/types/src/extensions/outliner/tree.d.ts +2 -2
- package/dist/types/src/extensions/outliner/tree.d.ts.map +1 -1
- package/dist/types/src/extensions/preview/preview.d.ts +3 -6
- package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
- package/dist/types/src/extensions/tags/extended-markdown.d.ts +10 -0
- package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +1 -0
- package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +2 -0
- package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +1 -0
- package/dist/types/src/extensions/tags/index.d.ts +4 -0
- package/dist/types/src/extensions/tags/index.d.ts.map +1 -0
- package/dist/types/src/extensions/tags/streamer.d.ts +12 -0
- package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -0
- package/dist/types/src/extensions/tags/xml-tags.d.ts +72 -0
- package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -0
- package/dist/types/src/extensions/tags/xml-util.d.ts +10 -0
- package/dist/types/src/extensions/tags/xml-util.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/stories/CommandDialog.stories.d.ts +14 -0
- package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
- package/dist/types/src/stories/CommandMenu.stories.d.ts +10 -4
- package/dist/types/src/stories/CommandMenu.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Comments.stories.d.ts +21 -10
- package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
- package/dist/types/src/stories/EditorToolbar.stories.d.ts +39 -3
- package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Experimental.stories.d.ts +22 -13
- package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Markdown.stories.d.ts +32 -43
- package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
- package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Preview.stories.d.ts +21 -7
- package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
- package/dist/types/src/stories/Tags.stories.d.ts +16 -0
- package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
- package/dist/types/src/stories/TextEditor.stories.d.ts +38 -52
- package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
- package/dist/types/src/stories/components/EditorStory.d.ts +5 -8
- package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
- package/dist/types/src/styles/theme.d.ts.map +1 -1
- package/dist/types/src/testing/PreviewPopover.d.ts +20 -0
- package/dist/types/src/testing/PreviewPopover.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/util.d.ts +1 -0
- package/dist/types/src/testing/util.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +1 -1
- package/dist/types/src/types/types.d.ts +1 -1
- package/dist/types/src/util/cursor.d.ts.map +1 -1
- package/dist/types/src/util/debug.d.ts +1 -1
- package/dist/types/src/util/debug.d.ts.map +1 -1
- package/dist/types/src/util/decorations.d.ts +4 -0
- package/dist/types/src/util/decorations.d.ts.map +1 -0
- package/dist/types/src/util/dom.d.ts +2 -12
- package/dist/types/src/util/dom.d.ts.map +1 -1
- package/dist/types/src/util/index.d.ts +1 -0
- package/dist/types/src/util/index.d.ts.map +1 -1
- package/dist/types/src/util/react.d.ts +1 -1
- package/dist/types/src/util/react.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +67 -60
- package/src/components/{Popover → CommandMenu}/CommandMenu.tsx +95 -26
- package/src/components/{Popover → CommandMenu}/index.ts +0 -2
- package/src/components/Editor/Editor.tsx +50 -15
- package/src/components/EditorToolbar/EditorToolbar.tsx +40 -30
- package/src/components/EditorToolbar/blocks.ts +22 -25
- package/src/components/EditorToolbar/formatting.ts +22 -25
- package/src/components/EditorToolbar/headings.ts +10 -5
- package/src/components/EditorToolbar/image.ts +8 -4
- package/src/components/EditorToolbar/lists.ts +16 -19
- package/src/components/EditorToolbar/search.ts +8 -4
- package/src/components/EditorToolbar/util.ts +16 -5
- package/src/components/EditorToolbar/view-mode.ts +11 -6
- package/src/components/index.ts +1 -1
- package/src/defaults.ts +5 -2
- package/src/extensions/autocomplete.ts +204 -54
- package/src/extensions/automerge/automerge.stories.tsx +31 -24
- package/src/extensions/automerge/automerge.ts +4 -3
- package/src/extensions/automerge/defs.ts +1 -1
- package/src/extensions/automerge/sync.ts +1 -1
- package/src/extensions/automerge/update-automerge.ts +1 -1
- package/src/extensions/autoscroll.ts +157 -0
- package/src/extensions/awareness/awareness.ts +2 -2
- package/src/extensions/{command → command-dialog}/action.ts +2 -3
- package/src/extensions/{command/command.ts → command-dialog/command-dialog.ts} +4 -4
- package/src/extensions/{command → command-dialog}/hint.ts +2 -1
- package/src/extensions/command-dialog/index.ts +7 -0
- package/src/extensions/{command → command-dialog}/state.ts +4 -3
- package/src/extensions/{command → command-dialog}/typeahead.ts +2 -2
- package/src/extensions/{command → command-menu}/command-menu.ts +9 -9
- package/src/extensions/command-menu/index.ts +6 -0
- package/src/extensions/{command → command-menu}/placeholder.ts +1 -1
- package/src/extensions/{command → command-menu}/useCommandMenu.ts +35 -19
- package/src/extensions/comments.ts +18 -13
- package/src/extensions/dnd.ts +1 -1
- package/src/extensions/factories.ts +39 -29
- package/src/extensions/{command/floating-menu.ts → floating-menu.ts} +12 -19
- package/src/extensions/focus.ts +5 -4
- package/src/extensions/folding.tsx +4 -6
- package/src/extensions/index.ts +5 -1
- package/src/extensions/markdown/action.ts +2 -1
- package/src/extensions/markdown/bundle.ts +27 -5
- package/src/extensions/markdown/changes.ts +1 -1
- package/src/extensions/markdown/decorate.ts +24 -14
- package/src/extensions/markdown/formatting.test.ts +6 -6
- package/src/extensions/markdown/formatting.ts +3 -3
- package/src/extensions/markdown/highlight.ts +1 -1
- package/src/extensions/markdown/image.ts +3 -4
- package/src/extensions/markdown/link.ts +3 -0
- package/src/extensions/markdown/table.ts +7 -1
- package/src/extensions/mention.ts +1 -1
- package/src/extensions/outliner/outliner.test.ts +3 -2
- package/src/extensions/outliner/outliner.ts +6 -5
- package/src/extensions/outliner/selection.ts +1 -1
- package/src/extensions/outliner/tree.test.ts +2 -1
- package/src/extensions/outliner/tree.ts +2 -2
- package/src/extensions/preview/preview.ts +59 -62
- package/src/extensions/selection.ts +2 -2
- package/src/extensions/tags/extended-markdown.test.ts +261 -0
- package/src/extensions/tags/extended-markdown.ts +78 -0
- package/src/extensions/tags/index.ts +7 -0
- package/src/extensions/tags/streamer.ts +243 -0
- package/src/extensions/tags/xml-tags.ts +393 -0
- package/src/extensions/tags/xml-util.ts +94 -0
- package/src/hooks/useTextEditor.ts +8 -20
- package/src/stories/CommandDialog.stories.tsx +89 -0
- package/src/stories/CommandMenu.stories.tsx +34 -35
- package/src/stories/Comments.stories.tsx +14 -10
- package/src/stories/EditorToolbar.stories.tsx +13 -12
- package/src/stories/Experimental.stories.tsx +17 -13
- package/src/stories/Markdown.stories.tsx +25 -21
- package/src/stories/Outliner.stories.tsx +46 -34
- package/src/stories/Preview.stories.tsx +35 -34
- package/src/stories/Tags.stories.tsx +81 -0
- package/src/stories/TextEditor.stories.tsx +45 -38
- package/src/stories/components/EditorStory.tsx +12 -13
- package/src/styles/theme.ts +17 -15
- package/src/testing/PreviewPopover.tsx +78 -0
- package/src/testing/index.ts +1 -0
- package/src/testing/util.ts +2 -0
- package/src/translations.ts +1 -1
- package/src/util/cursor.ts +2 -1
- package/src/util/debug.ts +2 -2
- package/src/util/decorations.ts +21 -0
- package/src/util/dom.ts +5 -27
- package/src/util/index.ts +1 -0
- package/src/util/react.tsx +1 -1
- package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
- package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
- package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
- package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
- package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
- package/dist/types/src/components/Popover/index.d.ts +0 -4
- package/dist/types/src/components/Popover/index.d.ts.map +0 -1
- package/dist/types/src/extensions/command/action.d.ts.map +0 -1
- package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
- package/dist/types/src/extensions/command/command.d.ts.map +0 -1
- package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
- package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
- package/dist/types/src/extensions/command/index.d.ts +0 -7
- package/dist/types/src/extensions/command/index.d.ts.map +0 -1
- package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
- package/dist/types/src/extensions/command/state.d.ts.map +0 -1
- package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
- package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
- package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
- package/dist/types/src/stories/Command.stories.d.ts +0 -7
- package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
- package/src/components/Popover/RefDropdownMenu.tsx +0 -85
- package/src/components/Popover/RefPopover.tsx +0 -99
- package/src/extensions/command/index.ts +0 -10
- package/src/stories/Command.stories.tsx +0 -97
- /package/dist/types/src/extensions/{command → command-dialog}/typeahead.d.ts +0 -0
- /package/dist/types/src/extensions/{command → command-menu}/placeholder.d.ts +0 -0
- /package/dist/types/src/extensions/{command/floating-menu.d.ts → floating-menu.d.ts} +0 -0
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { createContext } from '@radix-ui/react-context';
|
|
6
|
-
import React, { type PropsWithChildren, useRef, useState, useEffect, useCallback, type RefObject } from 'react';
|
|
7
|
-
|
|
8
|
-
import { addEventListener } from '@dxos/async';
|
|
9
|
-
import { type DxRefTag, type DxRefTagActivate } from '@dxos/lit-ui';
|
|
10
|
-
import { DropdownMenu } from '@dxos/react-ui';
|
|
11
|
-
|
|
12
|
-
import { type PreviewLinkRef, type PreviewLinkTarget, type PreviewLookup } from '../../extensions';
|
|
13
|
-
|
|
14
|
-
// TODO(burdon): Reconcile this file with RefPopover?
|
|
15
|
-
|
|
16
|
-
const customEventOptions = { capture: true, passive: false };
|
|
17
|
-
|
|
18
|
-
// Create a context for the dxn value.
|
|
19
|
-
type RefDropdownMenuValue = Partial<{
|
|
20
|
-
link: PreviewLinkRef;
|
|
21
|
-
target: PreviewLinkTarget;
|
|
22
|
-
pending: boolean;
|
|
23
|
-
}>;
|
|
24
|
-
|
|
25
|
-
const REF_DROPDOWN_MENU = 'RefDropdownMenu';
|
|
26
|
-
const [RefDropdownMenuContextProvider, useRefDropdownMenu] = createContext<RefDropdownMenuValue>(REF_DROPDOWN_MENU, {});
|
|
27
|
-
|
|
28
|
-
type RefDropdownMenuProviderProps = PropsWithChildren<{
|
|
29
|
-
onLookup?: PreviewLookup;
|
|
30
|
-
}>;
|
|
31
|
-
|
|
32
|
-
const RefDropdownMenuProvider = ({ children, onLookup }: RefDropdownMenuProviderProps) => {
|
|
33
|
-
const trigger = useRef<DxRefTag | null>(null);
|
|
34
|
-
const [value, setValue] = useState<RefDropdownMenuValue>({});
|
|
35
|
-
const [rootRef, setRootRef] = useState<HTMLDivElement | null>(null);
|
|
36
|
-
const [open, setOpen] = useState(false);
|
|
37
|
-
|
|
38
|
-
const handleDxRefTagActivate = useCallback(
|
|
39
|
-
(event: DxRefTagActivate) => {
|
|
40
|
-
const { refId, label, trigger: dxTrigger } = event;
|
|
41
|
-
setValue((value) => ({
|
|
42
|
-
...value,
|
|
43
|
-
link: { label, ref: refId },
|
|
44
|
-
pending: true,
|
|
45
|
-
}));
|
|
46
|
-
trigger.current = dxTrigger;
|
|
47
|
-
queueMicrotask(() => setOpen(true));
|
|
48
|
-
void onLookup?.({ label, ref: refId }).then((target) =>
|
|
49
|
-
setValue((value) => ({
|
|
50
|
-
...value,
|
|
51
|
-
target: target ?? undefined,
|
|
52
|
-
pending: false,
|
|
53
|
-
})),
|
|
54
|
-
);
|
|
55
|
-
},
|
|
56
|
-
[onLookup],
|
|
57
|
-
);
|
|
58
|
-
|
|
59
|
-
useEffect(() => {
|
|
60
|
-
if (!rootRef) {
|
|
61
|
-
return;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return addEventListener(rootRef, 'dx-ref-tag-activate' as any, handleDxRefTagActivate, customEventOptions);
|
|
65
|
-
}, [rootRef]);
|
|
66
|
-
|
|
67
|
-
return (
|
|
68
|
-
<RefDropdownMenuContextProvider pending={value.pending} link={value.link} target={value.target}>
|
|
69
|
-
<DropdownMenu.Root open={open} onOpenChange={setOpen}>
|
|
70
|
-
<DropdownMenu.VirtualTrigger virtualRef={trigger as unknown as RefObject<HTMLButtonElement>} />
|
|
71
|
-
<div role='none' className='contents' ref={setRootRef}>
|
|
72
|
-
{children}
|
|
73
|
-
</div>
|
|
74
|
-
</DropdownMenu.Root>
|
|
75
|
-
</RefDropdownMenuContextProvider>
|
|
76
|
-
);
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
export const RefDropdownMenu = {
|
|
80
|
-
Provider: RefDropdownMenuProvider,
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
export { useRefDropdownMenu };
|
|
84
|
-
|
|
85
|
-
export type { RefDropdownMenuProviderProps, RefDropdownMenuValue };
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { createContext } from '@radix-ui/react-context';
|
|
6
|
-
import React, {
|
|
7
|
-
type PropsWithChildren,
|
|
8
|
-
useRef,
|
|
9
|
-
useState,
|
|
10
|
-
useEffect,
|
|
11
|
-
useCallback,
|
|
12
|
-
type RefObject,
|
|
13
|
-
forwardRef,
|
|
14
|
-
} from 'react';
|
|
15
|
-
|
|
16
|
-
import { addEventListener } from '@dxos/async';
|
|
17
|
-
import { type DxRefTag, type DxRefTagActivate } from '@dxos/lit-ui';
|
|
18
|
-
import { Popover } from '@dxos/react-ui';
|
|
19
|
-
|
|
20
|
-
import { type PreviewLinkRef, type PreviewLinkTarget, type PreviewLookup } from '../../extensions';
|
|
21
|
-
|
|
22
|
-
const customEventOptions = { capture: true, passive: false };
|
|
23
|
-
|
|
24
|
-
export type RefPopoverProps = PropsWithChildren<{
|
|
25
|
-
modal?: boolean;
|
|
26
|
-
open?: boolean;
|
|
27
|
-
onOpenChange?: (open: boolean) => void;
|
|
28
|
-
onActivate?: (event: DxRefTagActivate) => void;
|
|
29
|
-
}>;
|
|
30
|
-
|
|
31
|
-
export const RefPopover = forwardRef<DxRefTag | null, RefPopoverProps>(
|
|
32
|
-
({ children, open, onOpenChange, modal, onActivate }, ref) => {
|
|
33
|
-
const [rootRef, setRootRef] = useState<HTMLDivElement | null>(null);
|
|
34
|
-
|
|
35
|
-
useEffect(() => {
|
|
36
|
-
if (!rootRef || !onActivate) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return addEventListener(rootRef, 'dx-ref-tag-activate' as any, onActivate, customEventOptions);
|
|
41
|
-
}, [rootRef, onActivate]);
|
|
42
|
-
|
|
43
|
-
return (
|
|
44
|
-
<Popover.Root open={open} onOpenChange={onOpenChange} modal={modal}>
|
|
45
|
-
<Popover.VirtualTrigger virtualRef={ref as unknown as RefObject<HTMLButtonElement>} />
|
|
46
|
-
<div role='none' className='contents' ref={setRootRef}>
|
|
47
|
-
{children}
|
|
48
|
-
</div>
|
|
49
|
-
</Popover.Root>
|
|
50
|
-
);
|
|
51
|
-
},
|
|
52
|
-
);
|
|
53
|
-
|
|
54
|
-
// Create a context for the dxn value.
|
|
55
|
-
type RefPopoverValue = Partial<{ link: PreviewLinkRef; target: PreviewLinkTarget; pending: boolean }>;
|
|
56
|
-
|
|
57
|
-
const REF_POPOVER = 'RefPopover';
|
|
58
|
-
const [RefPopoverContextProvider, useRefPopover] = createContext<RefPopoverValue>(REF_POPOVER, {});
|
|
59
|
-
|
|
60
|
-
type PreviewProviderProps = PropsWithChildren<{ onLookup?: PreviewLookup }>;
|
|
61
|
-
|
|
62
|
-
const PreviewProvider = ({ children, onLookup }: PreviewProviderProps) => {
|
|
63
|
-
const trigger = useRef<DxRefTag | null>(null);
|
|
64
|
-
const [value, setValue] = useState<RefPopoverValue>({});
|
|
65
|
-
const [open, setOpen] = useState(false);
|
|
66
|
-
|
|
67
|
-
const handleDxRefTagActivate = useCallback(
|
|
68
|
-
(event: DxRefTagActivate) => {
|
|
69
|
-
const { refId, label, trigger: dxTrigger } = event;
|
|
70
|
-
setValue((value) => ({
|
|
71
|
-
...value,
|
|
72
|
-
link: { label, ref: refId },
|
|
73
|
-
pending: true,
|
|
74
|
-
}));
|
|
75
|
-
trigger.current = dxTrigger;
|
|
76
|
-
queueMicrotask(() => setOpen(true));
|
|
77
|
-
void onLookup?.({ label, ref: refId }).then((target) =>
|
|
78
|
-
setValue((value) => ({
|
|
79
|
-
...value,
|
|
80
|
-
target: target ?? undefined,
|
|
81
|
-
pending: false,
|
|
82
|
-
})),
|
|
83
|
-
);
|
|
84
|
-
},
|
|
85
|
-
[onLookup],
|
|
86
|
-
);
|
|
87
|
-
|
|
88
|
-
return (
|
|
89
|
-
<RefPopoverContextProvider pending={value.pending} link={value.link} target={value.target}>
|
|
90
|
-
<RefPopover ref={trigger} open={open} onOpenChange={setOpen} onActivate={handleDxRefTagActivate}>
|
|
91
|
-
{children}
|
|
92
|
-
</RefPopover>
|
|
93
|
-
</RefPopoverContextProvider>
|
|
94
|
-
);
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
export { PreviewProvider, useRefPopover };
|
|
98
|
-
|
|
99
|
-
export type { PreviewProviderProps, RefPopoverValue };
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import '@dxos-theme';
|
|
6
|
-
|
|
7
|
-
import React, { useState, type KeyboardEvent } from 'react';
|
|
8
|
-
|
|
9
|
-
import { Button, Icon, Input, DropdownMenu } from '@dxos/react-ui';
|
|
10
|
-
import { mx } from '@dxos/react-ui-theme';
|
|
11
|
-
import { withLayout, withTheme, type Meta } from '@dxos/storybook-utils';
|
|
12
|
-
|
|
13
|
-
import { EditorStory } from './components';
|
|
14
|
-
import { RefDropdownMenu } from '../components';
|
|
15
|
-
import { editorWidth } from '../defaults';
|
|
16
|
-
import { command, type Action, floatingMenu } from '../extensions';
|
|
17
|
-
import { str } from '../testing';
|
|
18
|
-
import { createRenderer } from '../util';
|
|
19
|
-
|
|
20
|
-
const CommandDialog = ({ onAction }: { onAction: (action?: Action) => void }) => {
|
|
21
|
-
const [text, setText] = useState('');
|
|
22
|
-
|
|
23
|
-
const handleInsert = () => {
|
|
24
|
-
// TODO(burdon): Use queue ref.
|
|
25
|
-
const link = `[${text}](dxn:queue:data:123)`;
|
|
26
|
-
onAction(text.length ? { type: 'insert', text: link } : undefined);
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {
|
|
30
|
-
switch (event.key) {
|
|
31
|
-
case 'Enter': {
|
|
32
|
-
handleInsert();
|
|
33
|
-
break;
|
|
34
|
-
}
|
|
35
|
-
case 'Escape': {
|
|
36
|
-
onAction();
|
|
37
|
-
break;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
return (
|
|
43
|
-
<div className='flex w-full justify-center'>
|
|
44
|
-
<div
|
|
45
|
-
className={mx(
|
|
46
|
-
'flex w-full p-2 gap-2 items-center bg-modalSurface border border-separator rounded-md',
|
|
47
|
-
editorWidth,
|
|
48
|
-
)}
|
|
49
|
-
>
|
|
50
|
-
<Input.Root>
|
|
51
|
-
<Input.TextInput
|
|
52
|
-
autoFocus={true}
|
|
53
|
-
placeholder='Ask a question...'
|
|
54
|
-
value={text}
|
|
55
|
-
onChange={(ev) => setText(ev.target.value)}
|
|
56
|
-
onKeyDown={handleKeyDown}
|
|
57
|
-
/>
|
|
58
|
-
</Input.Root>
|
|
59
|
-
<Button variant='ghost' classNames='pli-0' onClick={() => onAction({ type: 'cancel' })}>
|
|
60
|
-
<Icon icon='ph--x--regular' size={5} />
|
|
61
|
-
</Button>
|
|
62
|
-
</div>
|
|
63
|
-
</div>
|
|
64
|
-
);
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
const meta: Meta<typeof EditorStory> = {
|
|
68
|
-
title: 'ui/react-ui-editor/Command',
|
|
69
|
-
decorators: [withTheme, withLayout({ fullscreen: true })],
|
|
70
|
-
render: () => (
|
|
71
|
-
<RefDropdownMenu.Provider>
|
|
72
|
-
<EditorStory
|
|
73
|
-
text={str('# Command', '', '', '')}
|
|
74
|
-
extensions={[
|
|
75
|
-
floatingMenu(),
|
|
76
|
-
command({
|
|
77
|
-
renderDialog: createRenderer(CommandDialog),
|
|
78
|
-
onHint: () => "Press '/' for commands",
|
|
79
|
-
}),
|
|
80
|
-
]}
|
|
81
|
-
/>
|
|
82
|
-
<DropdownMenu.Portal>
|
|
83
|
-
<DropdownMenu.Content>
|
|
84
|
-
<DropdownMenu.Viewport>
|
|
85
|
-
<DropdownMenu.Item onClick={() => console.log('!')}>Test</DropdownMenu.Item>
|
|
86
|
-
</DropdownMenu.Viewport>
|
|
87
|
-
<DropdownMenu.Arrow />
|
|
88
|
-
</DropdownMenu.Content>
|
|
89
|
-
</DropdownMenu.Portal>
|
|
90
|
-
</RefDropdownMenu.Provider>
|
|
91
|
-
),
|
|
92
|
-
parameters: { layout: 'fullscreen' },
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
export default meta;
|
|
96
|
-
|
|
97
|
-
export const Default = {};
|
|
File without changes
|
|
File without changes
|
|
File without changes
|