2023-12-28 23:14:30 +08:00
|
|
|
import { Decoration, EditorState } from "../deps.ts";
|
2023-10-03 20:16:33 +08:00
|
|
|
import type { Client } from "../client.ts";
|
|
|
|
import { decoratorStateField } from "./util.ts";
|
2023-12-28 01:05:47 +08:00
|
|
|
import { MarkdownWidget } from "./markdown_widget.ts";
|
2023-10-03 20:16:33 +08:00
|
|
|
|
2023-12-28 01:05:47 +08:00
|
|
|
export function postScriptPrefacePlugin(
|
|
|
|
editor: Client,
|
|
|
|
) {
|
|
|
|
const panelWidgetHook = editor.system.panelWidgetHook;
|
2023-10-03 20:16:33 +08:00
|
|
|
return decoratorStateField((state: EditorState) => {
|
|
|
|
const widgets: any[] = [];
|
2023-12-28 01:05:47 +08:00
|
|
|
const topCallback = panelWidgetHook.callbacks.get("top");
|
|
|
|
if (topCallback) {
|
2023-11-25 20:40:56 +08:00
|
|
|
widgets.push(
|
|
|
|
Decoration.widget({
|
2023-12-28 01:05:47 +08:00
|
|
|
widget: new MarkdownWidget(
|
|
|
|
undefined,
|
2023-11-25 20:40:56 +08:00
|
|
|
editor,
|
2023-12-28 01:05:47 +08:00
|
|
|
`top:${editor.currentPage}`,
|
2024-01-09 00:08:26 +08:00
|
|
|
"top",
|
2023-12-28 01:05:47 +08:00
|
|
|
topCallback,
|
|
|
|
"sb-markdown-top-widget",
|
2023-11-25 20:40:56 +08:00
|
|
|
),
|
|
|
|
side: -1,
|
|
|
|
block: true,
|
|
|
|
}).range(0),
|
|
|
|
);
|
|
|
|
}
|
2023-12-28 01:05:47 +08:00
|
|
|
const bottomCallback = panelWidgetHook.callbacks.get("bottom");
|
|
|
|
if (bottomCallback) {
|
2023-10-03 20:16:33 +08:00
|
|
|
widgets.push(
|
|
|
|
Decoration.widget({
|
2023-12-28 01:05:47 +08:00
|
|
|
widget: new MarkdownWidget(
|
|
|
|
undefined,
|
2023-10-03 20:16:33 +08:00
|
|
|
editor,
|
2023-12-28 01:05:47 +08:00
|
|
|
`bottom:${editor.currentPage}`,
|
2024-01-09 00:08:26 +08:00
|
|
|
"bottom",
|
2023-12-28 01:05:47 +08:00
|
|
|
bottomCallback,
|
|
|
|
"sb-markdown-bottom-widget",
|
2023-10-03 20:16:33 +08:00
|
|
|
),
|
|
|
|
side: 1,
|
|
|
|
block: true,
|
|
|
|
}).range(state.doc.length),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return Decoration.set(widgets);
|
|
|
|
});
|
|
|
|
}
|