2024-09-10 01:33:54 +08:00
|
|
|
import {EditorUiContext} from "../ui/framework/core";
|
|
|
|
import {
|
|
|
|
$isDecoratorNode,
|
|
|
|
COMMAND_PRIORITY_LOW,
|
|
|
|
KEY_BACKSPACE_COMMAND,
|
|
|
|
KEY_DELETE_COMMAND,
|
2024-09-10 19:14:26 +08:00
|
|
|
KEY_ENTER_COMMAND,
|
|
|
|
LexicalEditor,
|
|
|
|
LexicalNode
|
2024-09-10 01:33:54 +08:00
|
|
|
} from "lexical";
|
|
|
|
import {$isImageNode} from "../nodes/image";
|
|
|
|
import {$isMediaNode} from "../nodes/media";
|
|
|
|
import {getLastSelection} from "../utils/selection";
|
2024-09-10 19:14:26 +08:00
|
|
|
import {$getNearestNodeBlockParent} from "../utils/nodes";
|
|
|
|
import {$createCustomParagraphNode} from "../nodes/custom-paragraph";
|
|
|
|
|
|
|
|
function isSingleSelectedNode(nodes: LexicalNode[]): boolean {
|
|
|
|
if (nodes.length === 1) {
|
|
|
|
const node = nodes[0];
|
|
|
|
if ($isDecoratorNode(node) || $isImageNode(node) || $isMediaNode(node)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2024-09-10 01:33:54 +08:00
|
|
|
|
|
|
|
function deleteSingleSelectedNode(editor: LexicalEditor) {
|
|
|
|
const selectionNodes = getLastSelection(editor)?.getNodes() || [];
|
2024-09-10 19:14:26 +08:00
|
|
|
if (isSingleSelectedNode(selectionNodes)) {
|
|
|
|
editor.update(() => {
|
|
|
|
selectionNodes[0].remove();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function insertAfterSingleSelectedNode(editor: LexicalEditor, event: KeyboardEvent|null): boolean {
|
|
|
|
const selectionNodes = getLastSelection(editor)?.getNodes() || [];
|
|
|
|
if (isSingleSelectedNode(selectionNodes)) {
|
2024-09-10 01:33:54 +08:00
|
|
|
const node = selectionNodes[0];
|
2024-09-10 19:14:26 +08:00
|
|
|
const nearestBlock = $getNearestNodeBlockParent(node) || node;
|
|
|
|
if (nearestBlock) {
|
|
|
|
requestAnimationFrame(() => {
|
|
|
|
editor.update(() => {
|
|
|
|
const newParagraph = $createCustomParagraphNode();
|
|
|
|
nearestBlock.insertAfter(newParagraph);
|
|
|
|
newParagraph.select();
|
|
|
|
});
|
2024-09-10 01:33:54 +08:00
|
|
|
});
|
2024-09-10 19:14:26 +08:00
|
|
|
event?.preventDefault();
|
|
|
|
return true;
|
2024-09-10 01:33:54 +08:00
|
|
|
}
|
|
|
|
}
|
2024-09-10 19:14:26 +08:00
|
|
|
|
|
|
|
return false;
|
2024-09-10 01:33:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
export function registerKeyboardHandling(context: EditorUiContext): () => void {
|
|
|
|
const unregisterBackspace = context.editor.registerCommand(KEY_BACKSPACE_COMMAND, (): boolean => {
|
|
|
|
deleteSingleSelectedNode(context.editor);
|
|
|
|
return false;
|
|
|
|
}, COMMAND_PRIORITY_LOW);
|
|
|
|
|
|
|
|
const unregisterDelete = context.editor.registerCommand(KEY_DELETE_COMMAND, (): boolean => {
|
|
|
|
deleteSingleSelectedNode(context.editor);
|
|
|
|
return false;
|
|
|
|
}, COMMAND_PRIORITY_LOW);
|
|
|
|
|
2024-09-10 19:14:26 +08:00
|
|
|
const unregisterEnter = context.editor.registerCommand(KEY_ENTER_COMMAND, (event): boolean => {
|
|
|
|
return insertAfterSingleSelectedNode(context.editor, event);
|
|
|
|
}, COMMAND_PRIORITY_LOW);
|
|
|
|
|
2024-09-10 01:33:54 +08:00
|
|
|
return () => {
|
2024-09-10 19:14:26 +08:00
|
|
|
unregisterBackspace();
|
|
|
|
unregisterDelete();
|
|
|
|
unregisterEnter();
|
2024-09-10 01:33:54 +08:00
|
|
|
};
|
|
|
|
}
|