1
0

Enable writing on the settings page from plugs

This commit is contained in:
Guillermo Vaya 2022-07-23 19:18:03 +02:00
parent 88121da341
commit dd3cfd8e98
5 changed files with 102 additions and 8 deletions

View File

@ -1,4 +1,5 @@
import { readYamlPage } from "./yaml_page"; import { flashNotification } from "@silverbulletmd/plugos-silverbullet-syscall/editor";
import { readYamlPage, writeYamlPage } from "./yaml_page";
/** /**
* Convenience function to read a specific set of settings from the `SETTINGS` page as well as default values * Convenience function to read a specific set of settings from the `SETTINGS` page as well as default values
@ -10,13 +11,16 @@ import { readYamlPage } from "./yaml_page";
* @returns an object with the same shape as `settings` but with non-default values override based on `SETTINGS` * @returns an object with the same shape as `settings` but with non-default values override based on `SETTINGS`
*/ */
const SETTINGS_PAGE = "SETTINGS";
const SETTINGS_TEMPLATE = `This page contains settings for configuring SilverBullet and its Plugs:\n\`\`\`yaml\n\`\`\``; // might need \r\n for windows?
export async function readSettings<T extends object>(settings: T): Promise<T> { export async function readSettings<T extends object>(settings: T): Promise<T> {
try { try {
let allSettings = (await readYamlPage("SETTINGS", ["yaml"])) || {}; let allSettings = (await readYamlPage(SETTINGS_PAGE, ["yaml"])) || {};
// TODO: I'm sure there's a better way to type this than "any" // TODO: I'm sure there's a better way to type this than "any"
let collectedSettings: any = {}; let collectedSettings: any = {};
for (let [key, defaultVal] of Object.entries(settings)) { for (let [key, defaultVal] of Object.entries(settings)) {
if (allSettings[key]) { if (key in allSettings) {
collectedSettings[key] = allSettings[key]; collectedSettings[key] = allSettings[key];
} else { } else {
collectedSettings[key] = defaultVal; collectedSettings[key] = defaultVal;
@ -31,3 +35,24 @@ export async function readSettings<T extends object>(settings: T): Promise<T> {
throw e; throw e;
} }
} }
/**
* Convenience function to write a specific set of settings from the `SETTINGS` page.
* If the SETTiNGS page doesn't exist it will create it.
* @param settings
*/
export async function writeSettings<T extends object>(settings: T) {
let readSettings = {};
try {
readSettings = (await readYamlPage(SETTINGS_PAGE, ["yaml"])) || {};
} catch (e: any) {
console.log("Couldn't read settings, generating a new settings page");
flashNotification("Creating a new SETTINGS page...", "info");
}
const writeSettings = {...readSettings, ...settings};
if(await writeYamlPage(SETTINGS_PAGE, writeSettings, SETTINGS_TEMPLATE)) {
flashNotification("SETTINGS page written successfully", "info");
} else {
flashNotification("SETTINGS page failed to update", "error");
}
}

View File

@ -1,6 +1,6 @@
import { findNodeOfType, traverseTree } from "@silverbulletmd/common/tree"; import { findNodeOfType, ParseTree, renderToText, replaceNodesMatching, traverseTree } from "@silverbulletmd/common/tree";
import { parseMarkdown } from "@silverbulletmd/plugos-silverbullet-syscall/markdown"; import { parseMarkdown } from "@silverbulletmd/plugos-silverbullet-syscall/markdown";
import { readPage } from "@silverbulletmd/plugos-silverbullet-syscall/space"; import { readPage, writePage } from "@silverbulletmd/plugos-silverbullet-syscall/space";
import YAML from "yaml"; import YAML from "yaml";
export async function readYamlPage( export async function readYamlPage(
@ -40,3 +40,42 @@ export async function readYamlPage(
return data; return data;
} }
export async function writeYamlPage(
pageName: string,
properties: any,
templateOnEmpty: string,
): Promise<Boolean> {
let text;
try {
const page = await readPage(pageName);
text = page.text;
} catch {
// page doesn't exist, so let's create one.
text = templateOnEmpty;
}
const tree = await parseMarkdown(text);
// if we use any other language than yaml... how to create it?
const doc = new YAML.Document();
doc.contents = properties;
// generate a new node for the properties
const newCode = `\`\`\`yaml\n${doc.toString()}\n\`\`\``;
const subtree = await parseMarkdown(newCode);
// find the original set of properties and replace
let replaced = false;
replaceNodesMatching(tree, (node: ParseTree) => {
if (node.type !== 'FencedCode') {
return;
}
const codeinfoNode = findNodeOfType(node, "CodeInfo");
if (!codeinfoNode || codeinfoNode.children![0].text! !== "yaml") {
return;
}
replaced = true;
return subtree;
});
if (replaced) {
await writePage(pageName, renderToText(tree));
}
return replaced;
}

View File

@ -14,3 +14,7 @@ functions:
- editor:updated - editor:updated
- editor:pageLoaded - editor:pageLoaded
- editor:pageReloaded - editor:pageReloaded
switchSide:
path: "./preview.ts:switchSide"
command:
name: "Swith Preview to other Sidebar"

View File

@ -1,6 +1,8 @@
import { hideRhs } from "@silverbulletmd/plugos-silverbullet-syscall/editor"; import { hideRhs, hideLhs } from "@silverbulletmd/plugos-silverbullet-syscall/editor";
import { invokeFunction } from "@silverbulletmd/plugos-silverbullet-syscall/system"; import { invokeFunction } from "@silverbulletmd/plugos-silverbullet-syscall/system";
import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore"; import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore";
import { readSettings, writeSettings } from "@silverbulletmd/plugs/lib/settings_page";;
export async function togglePreview() { export async function togglePreview() {
let currentValue = !!(await clientStore.get("enableMarkdownPreview")); let currentValue = !!(await clientStore.get("enableMarkdownPreview"));
@ -13,5 +15,7 @@ export async function togglePreview() {
} }
async function hideMarkdownPreview() { async function hideMarkdownPreview() {
await hideRhs(); const setting = await readSettings({previewOnRHS: true});
const hide = setting.previewOnRHS ? hideRhs : hideLhs;
await hide();
} }

View File

@ -1,10 +1,14 @@
import MarkdownIt from "markdown-it"; import MarkdownIt from "markdown-it";
import { import {
getText, getText,
showLhs,
showRhs, showRhs,
hideRhs,
hideLhs,
} from "@silverbulletmd/plugos-silverbullet-syscall/editor"; } from "@silverbulletmd/plugos-silverbullet-syscall/editor";
import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore"; import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore";
import { cleanMarkdown } from "./util"; import { cleanMarkdown } from "./util";
import { readSettings, writeSettings } from "@silverbulletmd/plugs/lib/settings_page";
const css = ` const css = `
<style> <style>
@ -76,9 +80,27 @@ export async function updateMarkdownPreview() {
} }
let text = await getText(); let text = await getText();
let cleanMd = await cleanMarkdown(text); let cleanMd = await cleanMarkdown(text);
await showRhs( const setting = await readSettings({previewOnRHS: true});
const show = setting.previewOnRHS ? showRhs : showLhs;
await show(
`<html><head>${css}</head><body>${md.render(cleanMd)}</body></html>`, `<html><head>${css}</head><body>${md.render(cleanMd)}</body></html>`,
undefined, undefined,
2 2
); );
} }
export async function switchSide() {
const {previewOnRHS} = await readSettings({previewOnRHS: true});
const isVisible = await clientStore.get("enableMarkdownPreview");
if (isVisible) {
if (previewOnRHS){
hideRhs();
} else {
hideLhs();
}
}
await writeSettings({previewOnRHS: !previewOnRHS});
if (isVisible) {
updateMarkdownPreview();
}
}