silverbullet/packages/plugs/markdown/preview.ts

106 lines
2.0 KiB
TypeScript
Raw Normal View History

import MarkdownIt from "markdown-it";
2022-04-25 17:24:13 +08:00
import {
getText,
showLhs,
2022-04-25 17:24:13 +08:00
showRhs,
hideRhs,
hideLhs,
2022-04-25 17:24:13 +08:00
} from "@silverbulletmd/plugos-silverbullet-syscall/editor";
import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore";
import { cleanMarkdown } from "./util";
import { readSettings, writeSettings } from "@silverbulletmd/plugs/lib/settings_page";
const css = `
<style>
body {
font-family: georgia,times,serif;
font-size: 14pt;
max-width: 800px;
margin-left: auto;
margin-right: auto;
padding-left: 20px;
padding-right: 20px;
}
table {
width: 100%;
border-spacing: 0;
}
thead tr {
background-color: #333;
color: #eee;
}
th, td {
padding: 8px;
}
tbody tr:nth-of-type(even) {
background-color: #f3f3f3;
}
a[href] {
text-decoration: none;
}
blockquote {
border-left: 1px solid #333;
margin-left: 2px;
padding-left: 10px;
}
hr {
margin: 1em 0 1em 0;
text-align: center;
border-color: #777;
border-width: 0;
border-style: dotted;
}
hr:after {
content: "···";
letter-spacing: 1em;
}
</style>
`;
var taskLists = require("markdown-it-task-lists");
const md = new MarkdownIt({
linkify: true,
html: false,
typographer: true,
}).use(taskLists);
export async function updateMarkdownPreview() {
if (!(await clientStore.get("enableMarkdownPreview"))) {
return;
}
let text = await getText();
let cleanMd = await cleanMarkdown(text);
const setting = await readSettings({previewOnRHS: true});
const show = setting.previewOnRHS ? showRhs : showLhs;
await show(
`<html><head>${css}</head><body>${md.render(cleanMd)}</body></html>`,
2022-05-09 20:59:12 +08:00
undefined,
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();
}
}