AutosuggestPlugin: update when suggestions updates

This commit is contained in:
Alex Gleason 2023-09-23 14:22:27 -05:00
parent 8f49446a15
commit aa4992e716
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7

View file

@ -293,13 +293,11 @@ const AutosuggestPlugin = ({
const handleSelectSuggestion: React.MouseEventHandler<HTMLDivElement> = (e) => { const handleSelectSuggestion: React.MouseEventHandler<HTMLDivElement> = (e) => {
e.preventDefault(); e.preventDefault();
const index = Number(e.currentTarget.getAttribute('data-index'));
const index = e.currentTarget.getAttribute('data-index');
return onSelectSuggestion(index); return onSelectSuggestion(index);
}; };
const onSelectSuggestion = (index: any) => { const onSelectSuggestion = (index: number) => {
const suggestion = suggestions.get(index) as AutoSuggestion; const suggestion = suggestions.get(index) as AutoSuggestion;
editor.update(() => { editor.update(() => {
@ -349,15 +347,12 @@ const AutosuggestPlugin = ({
if (['mention', 'hashtag'].includes(node.getType())) { if (['mention', 'hashtag'].includes(node.getType())) {
const matchingString = node.getTextContent(); const matchingString = node.getTextContent();
return { leadOffset: 0, matchingString }; return { leadOffset: 0, matchingString };
} }
if (node.getType() === 'text') { if (node.getType() === 'text') {
const [leadOffset, matchingString] = textAtCursorMatchesToken(node.getTextContent(), (state._selection as RangeSelection)?.anchor?.offset, [':']); const [leadOffset, matchingString] = textAtCursorMatchesToken(node.getTextContent(), (state._selection as RangeSelection)?.anchor?.offset, [':']);
if (!leadOffset || !matchingString) return null; if (!leadOffset || !matchingString) return null;
return { leadOffset, matchingString }; return { leadOffset, matchingString };
} }
@ -536,7 +531,7 @@ const AutosuggestPlugin = ({
COMMAND_PRIORITY_LOW, COMMAND_PRIORITY_LOW,
), ),
); );
}, [editor, selectedSuggestion, resolution]); }, [editor, suggestions, selectedSuggestion, resolution]);
return resolution === null || editor === null ? null : ( return resolution === null || editor === null ? null : (
<LexicalPopoverMenu <LexicalPopoverMenu