2022-04-13 20:46:52 +08:00
|
|
|
import MarkdownIt from "markdown-it";
|
2022-04-25 17:24:13 +08:00
|
|
|
import {
|
|
|
|
getText,
|
2022-07-24 01:18:03 +08:00
|
|
|
showLhs,
|
2022-04-25 17:24:13 +08:00
|
|
|
showRhs,
|
2022-07-24 01:18:03 +08:00
|
|
|
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";
|
2022-04-13 20:46:52 +08:00
|
|
|
import { cleanMarkdown } from "./util";
|
2022-07-24 01:18:03 +08:00
|
|
|
import { readSettings, writeSettings } from "@silverbulletmd/plugs/lib/settings_page";
|
2022-04-13 20:46:52 +08:00
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2022-04-20 16:56:43 +08:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2022-04-13 20:46:52 +08:00
|
|
|
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);
|
2022-07-24 01:18:03 +08:00
|
|
|
const setting = await readSettings({previewOnRHS: true});
|
|
|
|
const show = setting.previewOnRHS ? showRhs : showLhs;
|
|
|
|
await show(
|
2022-04-13 20:46:52 +08:00
|
|
|
`<html><head>${css}</head><body>${md.render(cleanMd)}</body></html>`,
|
2022-05-09 20:59:12 +08:00
|
|
|
undefined,
|
2022-04-13 20:46:52 +08:00
|
|
|
2
|
|
|
|
);
|
|
|
|
}
|
2022-07-24 01:18:03 +08:00
|
|
|
|
|
|
|
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();
|
|
|
|
}
|
|
|
|
}
|