Undo frontmatter templates
This commit is contained in:
parent
bfdc8383b1
commit
8230330ed0
@ -22,7 +22,7 @@ export function cleanModePlugins(client: Client) {
|
|||||||
hideMarksPlugin(),
|
hideMarksPlugin(),
|
||||||
hideHeaderMarkPlugin(),
|
hideHeaderMarkPlugin(),
|
||||||
cleanBlockPlugin(),
|
cleanBlockPlugin(),
|
||||||
frontmatterPlugin(client),
|
frontmatterPlugin(),
|
||||||
fencedCodePlugin(client),
|
fencedCodePlugin(client),
|
||||||
taskListPlugin({
|
taskListPlugin({
|
||||||
// TODO: Move this logic elsewhere?
|
// TODO: Move this logic elsewhere?
|
||||||
|
@ -1,60 +1,40 @@
|
|||||||
import { Client } from "../client.ts";
|
import { Decoration, EditorState, foldedRanges, syntaxTree } from "../deps.ts";
|
||||||
import { Decoration, EditorState, syntaxTree } from "../deps.ts";
|
|
||||||
import { MarkdownWidget } from "./markdown_widget.ts";
|
|
||||||
import { decoratorStateField, HtmlWidget, isCursorInRange } from "./util.ts";
|
import { decoratorStateField, HtmlWidget, isCursorInRange } from "./util.ts";
|
||||||
|
|
||||||
export function frontmatterPlugin(client: Client) {
|
export function frontmatterPlugin() {
|
||||||
const panelWidgetHook = client.system.panelWidgetHook;
|
|
||||||
const frontmatterCallback = panelWidgetHook.callbacks.get("frontmatter");
|
|
||||||
return decoratorStateField(
|
return decoratorStateField(
|
||||||
(state: EditorState) => {
|
(state: EditorState) => {
|
||||||
const widgets: any[] = [];
|
const widgets: any[] = [];
|
||||||
|
const foldRanges = foldedRanges(state);
|
||||||
|
|
||||||
syntaxTree(state).iterate({
|
syntaxTree(state).iterate({
|
||||||
enter(node) {
|
enter(node) {
|
||||||
if (
|
if (
|
||||||
node.name === "FrontMatter"
|
node.name === "FrontMatterMarker"
|
||||||
) {
|
) {
|
||||||
if (!isCursorInRange(state, [node.from, node.to])) {
|
const parent = node.node.parent!;
|
||||||
if (frontmatterCallback) {
|
|
||||||
// Render as a widget
|
|
||||||
const text = state.sliceDoc(node.from, node.to);
|
|
||||||
const lineStrings = text.split("\n");
|
|
||||||
|
|
||||||
const lines: { from: number; to: number }[] = [];
|
const folded = foldRanges.iter();
|
||||||
let fromIt = node.from;
|
let shouldShowFrontmatterBanner = false;
|
||||||
for (const line of lineStrings) {
|
while (folded.value) {
|
||||||
lines.push({
|
// Check if cursor is in the folded range
|
||||||
from: fromIt,
|
if (isCursorInRange(state, [folded.from, folded.to])) {
|
||||||
to: fromIt + line.length,
|
// console.log("Cursor is in folded area, ");
|
||||||
});
|
shouldShowFrontmatterBanner = true;
|
||||||
fromIt += line.length + 1;
|
break;
|
||||||
}
|
}
|
||||||
|
folded.next();
|
||||||
lines.slice(0, lines.length - 1).forEach((line) => {
|
}
|
||||||
|
if (!isCursorInRange(state, [parent.from, parent.to])) {
|
||||||
widgets.push(
|
widgets.push(
|
||||||
// Reusing line-table-outside here for laziness reasons
|
Decoration.line({
|
||||||
Decoration.line({ class: "sb-line-table-outside" }).range(
|
class: "sb-line-frontmatter-outside",
|
||||||
line.from,
|
}).range(node.from),
|
||||||
),
|
|
||||||
);
|
);
|
||||||
});
|
shouldShowFrontmatterBanner = true;
|
||||||
|
}
|
||||||
widgets.push(
|
if (shouldShowFrontmatterBanner && parent.from === node.from) {
|
||||||
Decoration.widget({
|
// Only put this on the first line of the frontmatter
|
||||||
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(
|
widgets.push(
|
||||||
Decoration.widget({
|
Decoration.widget({
|
||||||
widget: new HtmlWidget(
|
widget: new HtmlWidget(
|
||||||
@ -63,17 +43,6 @@ export function frontmatterPlugin(client: Client) {
|
|||||||
),
|
),
|
||||||
}).range(node.from),
|
}).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),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -172,8 +172,7 @@
|
|||||||
color: var(--editor-heading-meta-color);
|
color: var(--editor-heading-meta-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
.sb-hashtag,
|
.sb-hashtag {
|
||||||
.sb-markdown-frontmatter-widget span.hashtag {
|
|
||||||
color: var(--editor-hashtag-color);
|
color: var(--editor-hashtag-color);
|
||||||
background-color: var(--editor-hashtag-background-color);
|
background-color: var(--editor-hashtag-background-color);
|
||||||
border: 1px solid var(--editor-hashtag-border-color);
|
border: 1px solid var(--editor-hashtag-border-color);
|
||||||
@ -314,10 +313,6 @@
|
|||||||
color: var(--editor-frontmatter-color);
|
color: var(--editor-frontmatter-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
.sb-markdown-frontmatter-widget {
|
|
||||||
background-color: var(--editor-frontmatter-background-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sb-frontmatter-marker {
|
.sb-frontmatter-marker {
|
||||||
color: var(--editor-frontmatter-marker-color);
|
color: var(--editor-frontmatter-marker-color);
|
||||||
}
|
}
|
||||||
|
@ -429,33 +429,9 @@
|
|||||||
margin-top: 10px;
|
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-widget,
|
||||||
.sb-markdown-frontmatter-widget,
|
|
||||||
.sb-markdown-top-widget:has(*),
|
.sb-markdown-top-widget:has(*),
|
||||||
.sb-markdown-bottom-widget:has(*) {
|
.sb-markdown-bottom-widget:has(*) {
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
@ -579,6 +555,12 @@
|
|||||||
padding-right: 8px;
|
padding-right: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.sb-frontmatter-marker {
|
||||||
|
float: right;
|
||||||
|
font-size: 80%;
|
||||||
|
padding-right: 7px;
|
||||||
|
}
|
||||||
|
|
||||||
.cm-scroller {
|
.cm-scroller {
|
||||||
// Give some breathing space at the bottom of the screen
|
// Give some breathing space at the bottom of the screen
|
||||||
padding-bottom: 20em;
|
padding-bottom: 20em;
|
||||||
|
Loading…
Reference in New Issue
Block a user