better up / down handling in FilterList (#232)

Better up/down handling in FilterList; fixes #230

Co-authored-by: Zef Hemel <zef@zef.me>
pull/277/head
Krzysztof Kowalczyk 2023-01-03 15:27:46 -05:00 committed by GitHub
parent fdc08d893a
commit c3d5f4275e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 44 additions and 5 deletions

View File

@ -150,9 +150,13 @@ export function FilterList({
updateFilter(text); updateFilter(text);
}} }}
onKeyUp={(view, e) => { onKeyUp={(view, e) => {
// This event is triggered after the key has been processed by CM already
if (onKeyPress) { if (onKeyPress) {
onKeyPress(e.key, view.state.sliceDoc()); onKeyPress(e.key, view.state.sliceDoc());
} }
return false;
}}
onKeyDown={(view, e) => {
switch (e.key) { switch (e.key) {
case "ArrowUp": case "ArrowUp":
setSelectionOption(Math.max(0, selectedOption - 1)); setSelectionOption(Math.max(0, selectedOption - 1));
@ -176,8 +180,7 @@ export function FilterList({
return true; return true;
case " ": { case " ": {
const text = view.state.sliceDoc(); const text = view.state.sliceDoc();
if (completePrefix && text === " ") { if (completePrefix && text === "") {
console.log("Doing the complete thing");
setText(completePrefix); setText(completePrefix);
updateFilter(completePrefix); updateFilter(completePrefix);
return true; return true;

View File

@ -27,6 +27,7 @@ type MiniEditorEvents = {
onBlur?: (newText: string) => void | Promise<void>; onBlur?: (newText: string) => void | Promise<void>;
onChange?: (newText: string) => void; onChange?: (newText: string) => void;
onKeyUp?: (view: EditorView, event: KeyboardEvent) => boolean; onKeyUp?: (view: EditorView, event: KeyboardEvent) => boolean;
onKeyDown?: (view: EditorView, event: KeyboardEvent) => boolean;
}; };
export function MiniEditor( export function MiniEditor(
@ -39,6 +40,7 @@ export function MiniEditor(
onBlur, onBlur,
onEscape, onEscape,
onKeyUp, onKeyUp,
onKeyDown,
onEnter, onEnter,
onChange, onChange,
focus, focus,
@ -85,7 +87,14 @@ export function MiniEditor(
}, [editorDiv]); }, [editorDiv]);
useEffect(() => { useEffect(() => {
callbacksRef.current = { onBlur, onEnter, onEscape, onKeyUp, onChange }; callbacksRef.current = {
onBlur,
onEnter,
onEscape,
onKeyUp,
onKeyDown,
onChange,
};
}); });
useEffect(() => { useEffect(() => {
@ -97,9 +106,35 @@ export function MiniEditor(
} }
}, [text, vimMode]); }, [text, vimMode]);
let onBlurred = false, onEntered = false; useEffect(() => {
// So, for some reason, CM doesn't propagate the keydown event, therefore we'll capture it here
// And check if it's the same editor element
function onKeyDown(e: KeyboardEvent) {
const parent = (e.target as any).parentElement.parentElement;
if (parent !== editorViewRef.current?.dom) {
// Different editor element
return;
}
let stopPropagation = false;
if (callbacksRef.current!.onKeyDown) {
stopPropagation = callbacksRef.current!.onKeyDown(
editorViewRef.current!,
e,
);
}
if (stopPropagation) {
e.preventDefault();
e.stopPropagation();
}
}
document.addEventListener("keydown", onKeyDown);
// console.log("Rendering editor"); return () => {
document.removeEventListener("keydown", onKeyDown);
};
}, []);
let onBlurred = false, onEntered = false;
return <div class="sb-mini-editor" ref={editorDiv} />; return <div class="sb-mini-editor" ref={editorDiv} />;
@ -180,6 +215,7 @@ export function MiniEditor(
onBlur(view); onBlur(view);
}, },
}), }),
ViewPlugin.fromClass( ViewPlugin.fromClass(
class { class {
update(update: ViewUpdate): void { update(update: ViewUpdate): void {