Editable owns the default browser event handlers for rich-text editing,
including copy, paste, drop, keyboard, native input, selection, focus, and drag
events.
Pass event handlers to Editable when app UI needs to run before Slate's
default behavior.
Use Editing Behavior when the behavior
belongs in transactions or extension transform middleware instead of one
Editable event prop.
Handler Return Values
Handler return values control whether Slate continues with its own handling:
- Return
trueto mark the event handled and skip Slate's default handler. - Return
falseto force Slate's default handler to run. - Return nothing to let Slate continue unless the event is default-prevented or propagation-stopped.
import type { DragEvent, MouseEvent } from "react";
import { Editable } from "@platejs/slate-react";
const MyEditor = () => {
const onClick = (event: MouseEvent<HTMLDivElement>) => {
trackEditorClick(event);
// Slate runs its click handler unless this handler prevents default,
// stops propagation, or returns true.
};
const onDrop = (event: DragEvent<HTMLDivElement>) => {
if (!isAppOwnedDrop(event)) return false;
insertAppOwnedDrop(event);
return true;
};
const onDragStart = (event: DragEvent<HTMLDivElement>) => {
annotateDragPayload(event);
return false;
};
return (
<Editable onClick={onClick} onDrop={onDrop} onDragStart={onDragStart} />
);
};import type { DragEvent, MouseEvent } from "react";
import { Editable } from "@platejs/slate-react";
const MyEditor = () => {
const onClick = (event: MouseEvent<HTMLDivElement>) => {
trackEditorClick(event);
// Slate runs its click handler unless this handler prevents default,
// stops propagation, or returns true.
};
const onDrop = (event: DragEvent<HTMLDivElement>) => {
if (!isAppOwnedDrop(event)) return false;
insertAppOwnedDrop(event);
return true;
};
const onDragStart = (event: DragEvent<HTMLDivElement>) => {
annotateDragPayload(event);
return false;
};
return (
<Editable onClick={onClick} onDrop={onDrop} onDragStart={onDragStart} />
);
};Editor-Aware Handlers
Use onKeyDown and onDOMBeforeInput when a handler needs editor context:
<Editable
onDOMBeforeInput={(event, { editor, inputType }) => {
if (inputType !== "formatBold") return false;
editor.update((tx) => {
tx.marks.toggle("bold");
});
return true;
}}
onKeyDown={(event, { editor }) => {
if (!(event.metaKey && event.key === "k")) return false;
editor.update((tx) => {
tx.text.insert("link");
});
return true;
}}
/><Editable
onDOMBeforeInput={(event, { editor, inputType }) => {
if (inputType !== "formatBold") return false;
editor.update((tx) => {
tx.marks.toggle("bold");
});
return true;
}}
onKeyDown={(event, { editor }) => {
if (!(event.metaKey && event.key === "k")) return false;
editor.update((tx) => {
tx.text.insert("link");
});
return true;
}}
/>