pull/184/head
Zef Hemel 2022-12-09 17:13:26 +01:00
parent c8c4271aeb
commit 850077bad0
3 changed files with 59 additions and 44 deletions

View File

@ -1,44 +1,62 @@
import { Decoration, EditorState, syntaxTree } from "../deps.ts"; import { Decoration, EditorState, syntaxTree } from "../deps.ts";
import { decoratorStateField, isCursorInRange } from "./util.ts"; import {
decoratorStateField,
function getDirectives(state: EditorState) { invisibleDecoration,
const widgets: any[] = []; isCursorInRange,
} from "./util.ts";
syntaxTree(state).iterate({
enter: ({ type, from, to }) => {
if (type.name !== "CommentBlock") {
return;
}
const text = state.sliceDoc(from, to);
if (/<!--\s*#/.exec(text)) {
// Open directive
widgets.push(
Decoration.line({
class: "sb-directive-start",
}).range(from),
);
} else if (/<!--\s*\//.exec(text)) {
widgets.push(
Decoration.line({
class: "sb-directive-end",
}).range(from),
);
} else {
return;
}
if (!isCursorInRange(state, [from, to])) {
widgets.push(
Decoration.line({
class: "sb-directive-outside",
}).range(from),
);
}
},
});
return Decoration.set(widgets, true);
}
// Does a few things: hides the directives when the cursor is not placed inside
// Adds a class to the start and end of the directive when the cursor is placed inside
export function directivePlugin() { export function directivePlugin() {
return decoratorStateField(getDirectives); return decoratorStateField((state: EditorState) => {
const widgets: any[] = [];
const cursorPos = state.selection.main.head;
// TODO: This doesn't handle nested directives properly
let posOfLastOpen = { from: 0, to: 0 };
syntaxTree(state).iterate({
enter: ({ type, from, to }) => {
if (type.name !== "CommentBlock") {
return;
}
const text = state.sliceDoc(from, to);
if (/<!--\s*#/.exec(text)) {
// Open directive
posOfLastOpen = { from, to };
} else if (/<!--\s*\//.exec(text)) {
// Close directive
if (
(cursorPos > to || cursorPos < posOfLastOpen.from) &&
!isCursorInRange(state, [posOfLastOpen.from, to])
) {
widgets.push(
invisibleDecoration.range(
posOfLastOpen.from,
posOfLastOpen.to + 1,
),
);
widgets.push(
invisibleDecoration.range(from - 1, to),
);
} else {
widgets.push(
Decoration.line({
class: "sb-directive-start",
}).range(posOfLastOpen.from),
);
widgets.push(
Decoration.line({
class: "sb-directive-end",
}).range(from),
);
}
} else {
return;
}
},
});
return Decoration.set(widgets, true);
});
} }

View File

@ -146,10 +146,6 @@
left: -20px; left: -20px;
} }
.sb-directive-outside {
opacity: 0.4;
}
.sb-line-frontmatter-outside, .sb-line-code-outside { .sb-line-frontmatter-outside, .sb-line-code-outside {
display: none; display: none;
} }

View File

@ -7,6 +7,7 @@ release.
* Replaced the `--password` flag with `--user` taking a basic auth combination of username and password, e.g. `--user pete:1234`. Authentication now uses standard basic auth. This should fix attachments not working with password-protected setups. * Replaced the `--password` flag with `--user` taking a basic auth combination of username and password, e.g. `--user pete:1234`. Authentication now uses standard basic auth. This should fix attachments not working with password-protected setups.
* Added support for ~~strikethrough~~ syntax. * Added support for ~~strikethrough~~ syntax.
* Directives are now hidden unless the cursor is placed inside them for an even cleaner look
* New logo! Contributed by [petercoyne](https://github.com/silverbulletmd/silverbullet/pull/177) * New logo! Contributed by [petercoyne](https://github.com/silverbulletmd/silverbullet/pull/177)
* New button icons, from [feather](https://feathericons.com/) * New button icons, from [feather](https://feathericons.com/)
* UI font tweaks * UI font tweaks