81 lines
1.4 KiB
TypeScript
81 lines
1.4 KiB
TypeScript
|
import MarkdownIt from "markdown-it";
|
||
|
import { getText, showRhs } from "@silverbulletmd/plugos-silverbullet-syscall/editor";
|
||
|
import * as clientStore from "@silverbulletmd/plugos-silverbullet-syscall/clientStore";
|
||
|
import { cleanMarkdown } from "./util";
|
||
|
|
||
|
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);
|
||
|
await showRhs(
|
||
|
`<html><head>${css}</head><body>${md.render(cleanMd)}</body></html>`,
|
||
|
2
|
||
|
);
|
||
|
}
|