silverbullet/web/cm_plugins/preface_ps.ts

74 lines
1.9 KiB
TypeScript
Raw Normal View History

import { Decoration, EditorState, WidgetType } from "../deps.ts";
import type { Client } from "../client.ts";
import { decoratorStateField } from "./util.ts";
import { PanelConfig } from "../types.ts";
import { createWidgetSandboxIFrame } from "../components/widget_sandbox_iframe.ts";
class IFrameWidget extends WidgetType {
2023-11-25 20:40:56 +08:00
widgetHeightCacheKey: string;
constructor(
readonly editor: Client,
readonly panel: PanelConfig,
2023-11-25 20:40:56 +08:00
readonly className: string,
) {
super();
2023-11-25 20:40:56 +08:00
this.widgetHeightCacheKey = `${this.editor.currentPage!}#${this.className}`;
}
toDOM(): HTMLElement {
2023-11-25 20:40:56 +08:00
const iframe = createWidgetSandboxIFrame(
this.editor,
this.widgetHeightCacheKey,
this.panel,
);
iframe.classList.add(this.className);
return iframe;
}
2023-11-25 20:40:56 +08:00
get estimatedHeight(): number {
2023-11-25 21:31:39 +08:00
return this.editor.space.getCachedWidgetHeight(
2023-11-25 20:40:56 +08:00
this.widgetHeightCacheKey,
);
}
eq(other: WidgetType): boolean {
return this.panel.html ===
(other as IFrameWidget).panel.html &&
this.panel.script ===
(other as IFrameWidget).panel.script;
}
}
2023-11-25 20:40:56 +08:00
export function postScriptPrefacePlugin(editor: Client) {
return decoratorStateField((state: EditorState) => {
const widgets: any[] = [];
2023-11-25 20:40:56 +08:00
if (editor.ui.viewState.panels.preface.html) {
widgets.push(
Decoration.widget({
widget: new IFrameWidget(
editor,
editor.ui.viewState.panels.preface,
"sb-preface-iframe",
),
side: -1,
block: true,
}).range(0),
);
}
if (editor.ui.viewState.panels.ps.html) {
widgets.push(
Decoration.widget({
widget: new IFrameWidget(
editor,
editor.ui.viewState.panels.ps,
2023-11-25 20:40:56 +08:00
"sb-ps-iframe",
),
side: 1,
block: true,
}).range(state.doc.length),
);
}
return Decoration.set(widgets);
});
}