silverbullet/web/cm_plugins/block_quote.ts

46 lines
1.1 KiB
TypeScript
Raw Normal View History

import {
Decoration,
DecorationSet,
EditorView,
ViewPlugin,
ViewUpdate,
} from "../deps.ts";
import {
2022-11-15 02:36:35 +08:00
invisibleDecoration,
isCursorInRange,
iterateTreeInVisibleRanges,
} from "./util.ts";
2022-11-15 02:36:35 +08:00
class BlockquotePlugin {
decorations: DecorationSet = Decoration.none;
constructor(view: EditorView) {
2022-11-15 02:36:35 +08:00
this.decorations = this.decorateLists(view);
}
update(update: ViewUpdate) {
2022-11-15 02:36:35 +08:00
if (update.docChanged || update.viewportChanged || update.selectionSet) {
this.decorations = this.decorateLists(update.view);
}
}
2022-11-15 02:36:35 +08:00
private decorateLists(view: EditorView) {
const widgets: any[] = [];
iterateTreeInVisibleRanges(view, {
2022-11-15 02:36:35 +08:00
enter: ({ type, from, to }) => {
if (isCursorInRange(view.state, [from, to])) return;
if (type.name === "QuoteMark") {
widgets.push(invisibleDecoration.range(from, to));
widgets.push(
Decoration.line({ class: "sb-blockquote-outside" }).range(from),
);
}
},
});
return Decoration.set(widgets, true);
}
}
2022-11-15 02:36:35 +08:00
export const blockquotePlugin = ViewPlugin.fromClass(
BlockquotePlugin,
{
decorations: (v) => v.decorations,
},
);