mirror of
https://github.com/kou029w/quot.git
synced 2025-01-19 00:18:09 +00:00
47 lines
1.2 KiB
TypeScript
47 lines
1.2 KiB
TypeScript
import {
|
|
$createLineBreakNode,
|
|
$createParagraphNode,
|
|
$createTextNode,
|
|
$getRoot,
|
|
createEditor,
|
|
} from "lexical";
|
|
import { registerPlainText } from "@lexical/plain-text";
|
|
import { onCleanup, onMount } from "solid-js";
|
|
import type Pages from "../../protocol/pages";
|
|
import "./editor.css";
|
|
|
|
const editor = createEditor();
|
|
|
|
function ref(el: HTMLElement) {
|
|
editor.setRootElement(el);
|
|
}
|
|
|
|
export default (props: {
|
|
id: number;
|
|
title: string;
|
|
text: string;
|
|
onUpdatePage: (content: Pages.RequestContentPage) => void;
|
|
}) => {
|
|
const initialEditorState = () => {
|
|
const root = $getRoot();
|
|
if (root.getFirstChild()) return;
|
|
const paragraphNode = $createParagraphNode();
|
|
const text = props.text
|
|
.split("\n")
|
|
.flatMap((line) => [$createTextNode(line), $createLineBreakNode()])
|
|
.slice(0, -1);
|
|
paragraphNode.append(...text);
|
|
root.append(paragraphNode);
|
|
};
|
|
onCleanup(registerPlainText(editor, initialEditorState));
|
|
onMount(() => {
|
|
onCleanup(
|
|
editor.registerTextContentListener((text) => {
|
|
const [title] = text.split("\n");
|
|
props.onUpdatePage({ id: props.id, title: title ?? "", text });
|
|
})
|
|
);
|
|
editor.focus();
|
|
});
|
|
return <article ref={ref} class="editor" contenteditable />;
|
|
};
|