50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import type { EditorState } from "@codemirror/state";
|
|
import { Decoration } from "@codemirror/view";
|
|
import type { Client } from "../client.ts";
|
|
import { decoratorStateField } from "./util.ts";
|
|
import { MarkdownWidget } from "./markdown_widget.ts";
|
|
|
|
export function postScriptPrefacePlugin(
|
|
editor: Client,
|
|
) {
|
|
const panelWidgetHook = editor.clientSystem.panelWidgetHook;
|
|
return decoratorStateField((state: EditorState) => {
|
|
const widgets: any[] = [];
|
|
const topCallback = panelWidgetHook.callbacks.get("top");
|
|
if (topCallback) {
|
|
widgets.push(
|
|
Decoration.widget({
|
|
widget: new MarkdownWidget(
|
|
undefined,
|
|
editor,
|
|
`top:${editor.currentPage}`,
|
|
"top",
|
|
topCallback,
|
|
"sb-markdown-top-widget",
|
|
),
|
|
side: -1,
|
|
block: true,
|
|
}).range(0),
|
|
);
|
|
}
|
|
const bottomCallback = panelWidgetHook.callbacks.get("bottom");
|
|
if (bottomCallback) {
|
|
widgets.push(
|
|
Decoration.widget({
|
|
widget: new MarkdownWidget(
|
|
undefined,
|
|
editor,
|
|
`bottom:${editor.currentPage}`,
|
|
"bottom",
|
|
bottomCallback,
|
|
"sb-markdown-bottom-widget",
|
|
),
|
|
side: 1,
|
|
block: true,
|
|
}).range(state.doc.length),
|
|
);
|
|
}
|
|
return Decoration.set(widgets);
|
|
});
|
|
}
|