Undo frontmatter templates

pull/624/head
Zef Hemel 2024-01-08 09:21:19 +01:00
parent bfdc8383b1
commit 8230330ed0
4 changed files with 41 additions and 95 deletions

View File

@ -22,7 +22,7 @@ export function cleanModePlugins(client: Client) {
hideMarksPlugin(),
hideHeaderMarkPlugin(),
cleanBlockPlugin(),
frontmatterPlugin(client),
frontmatterPlugin(),
fencedCodePlugin(client),
taskListPlugin({
// TODO: Move this logic elsewhere?

View File

@ -1,79 +1,48 @@
import { Client } from "../client.ts";
import { Decoration, EditorState, syntaxTree } from "../deps.ts";
import { MarkdownWidget } from "./markdown_widget.ts";
import { Decoration, EditorState, foldedRanges, syntaxTree } from "../deps.ts";
import { decoratorStateField, HtmlWidget, isCursorInRange } from "./util.ts";
export function frontmatterPlugin(client: Client) {
const panelWidgetHook = client.system.panelWidgetHook;
const frontmatterCallback = panelWidgetHook.callbacks.get("frontmatter");
export function frontmatterPlugin() {
return decoratorStateField(
(state: EditorState) => {
const widgets: any[] = [];
const foldRanges = foldedRanges(state);
syntaxTree(state).iterate({
enter(node) {
if (
node.name === "FrontMatter"
node.name === "FrontMatterMarker"
) {
if (!isCursorInRange(state, [node.from, node.to])) {
if (frontmatterCallback) {
// Render as a widget
const text = state.sliceDoc(node.from, node.to);
const lineStrings = text.split("\n");
const parent = node.node.parent!;
const lines: { from: number; to: number }[] = [];
let fromIt = node.from;
for (const line of lineStrings) {
lines.push({
from: fromIt,
to: fromIt + line.length,
});
fromIt += line.length + 1;
}
lines.slice(0, lines.length - 1).forEach((line) => {
widgets.push(
// Reusing line-table-outside here for laziness reasons
Decoration.line({ class: "sb-line-table-outside" }).range(
line.from,
),
);
});
widgets.push(
Decoration.widget({
widget: new MarkdownWidget(
undefined,
client,
`frontmatter:${client.currentPage}`,
"",
frontmatterCallback,
"sb-markdown-frontmatter-widget",
),
block: true,
}).range(lines[lines.length - 1].from),
);
} else if (!frontmatterCallback) {
// Not rendering as a widget
widgets.push(
Decoration.widget({
widget: new HtmlWidget(
`frontmatter`,
"sb-frontmatter-marker",
),
}).range(node.from),
);
widgets.push(
Decoration.line({
class: "sb-line-frontmatter-outside",
}).range(node.from),
);
widgets.push(
Decoration.line({
class: "sb-line-frontmatter-outside",
}).range(state.doc.lineAt(node.to).from),
);
const folded = foldRanges.iter();
let shouldShowFrontmatterBanner = false;
while (folded.value) {
// Check if cursor is in the folded range
if (isCursorInRange(state, [folded.from, folded.to])) {
// console.log("Cursor is in folded area, ");
shouldShowFrontmatterBanner = true;
break;
}
folded.next();
}
if (!isCursorInRange(state, [parent.from, parent.to])) {
widgets.push(
Decoration.line({
class: "sb-line-frontmatter-outside",
}).range(node.from),
);
shouldShowFrontmatterBanner = true;
}
if (shouldShowFrontmatterBanner && parent.from === node.from) {
// Only put this on the first line of the frontmatter
widgets.push(
Decoration.widget({
widget: new HtmlWidget(
`frontmatter`,
"sb-frontmatter-marker",
),
}).range(node.from),
);
}
}
},

View File

@ -172,8 +172,7 @@
color: var(--editor-heading-meta-color);
}
.sb-hashtag,
.sb-markdown-frontmatter-widget span.hashtag {
.sb-hashtag {
color: var(--editor-hashtag-color);
background-color: var(--editor-hashtag-background-color);
border: 1px solid var(--editor-hashtag-border-color);
@ -314,10 +313,6 @@
color: var(--editor-frontmatter-color);
}
.sb-markdown-frontmatter-widget {
background-color: var(--editor-frontmatter-background-color);
}
.sb-frontmatter-marker {
color: var(--editor-frontmatter-marker-color);
}

View File

@ -429,33 +429,9 @@
margin-top: 10px;
}
.sb-markdown-frontmatter-widget {
margin-bottom: -1.3ch;
padding: 8px;
.sb-banner {
position: absolute;
right: 5px;
bottom: 5px;
font-size: 80%;
color: var(--editor-frontmatter-marker-color);
}
span.hashtag {
border-radius: 6px;
padding: 0 3px;
margin: 0 1px 0 0;
font-size: 0.9em;
}
}
.sb-markdown-frontmatter-widget+.sb-frontmatter {
background-color: transparent;
color: transparent;
}
.sb-markdown-widget,
.sb-markdown-frontmatter-widget,
.sb-markdown-top-widget:has(*),
.sb-markdown-bottom-widget:has(*) {
overflow-y: auto;
@ -579,6 +555,12 @@
padding-right: 8px;
}
.sb-frontmatter-marker {
float: right;
font-size: 80%;
padding-right: 7px;
}
.cm-scroller {
// Give some breathing space at the bottom of the screen
padding-bottom: 20em;