2023-10-03 20:16:33 +08:00
|
|
|
import { WidgetContent } from "$sb/app_event.ts";
|
2023-11-15 21:56:34 +08:00
|
|
|
import { markdown, space, system, YAML } from "$sb/syscalls.ts";
|
2023-11-06 16:14:16 +08:00
|
|
|
import { loadPageObject, replaceTemplateVars } from "../template/template.ts";
|
|
|
|
import { PageMeta } from "$sb/types.ts";
|
2023-11-15 21:56:34 +08:00
|
|
|
import { renderTemplate } from "../template/plug_api.ts";
|
2023-11-15 23:14:15 +08:00
|
|
|
import { renderToText } from "$sb/lib/tree.ts";
|
2023-11-16 20:55:02 +08:00
|
|
|
import { rewritePageRefs, rewritePageRefsInString } from "$sb/lib/resolve.ts";
|
2023-10-03 20:16:33 +08:00
|
|
|
|
|
|
|
type TemplateConfig = {
|
|
|
|
// Pull the template from a page
|
|
|
|
page?: string;
|
|
|
|
// Or use a string directly
|
|
|
|
template?: string;
|
|
|
|
// Optional argument to pass
|
|
|
|
value?: any;
|
|
|
|
// If true, don't render the template, just use it as-is
|
|
|
|
raw?: boolean;
|
|
|
|
};
|
|
|
|
|
2023-11-02 19:51:09 +08:00
|
|
|
export async function widget(
|
|
|
|
bodyText: string,
|
|
|
|
pageName: string,
|
|
|
|
): Promise<WidgetContent> {
|
2023-11-06 16:14:16 +08:00
|
|
|
const pageMeta: PageMeta = await loadPageObject(pageName);
|
2023-10-03 20:16:33 +08:00
|
|
|
|
|
|
|
try {
|
|
|
|
const config: TemplateConfig = await YAML.parse(bodyText);
|
|
|
|
let templateText = config.template || "";
|
2023-10-04 00:09:03 +08:00
|
|
|
let templatePage = config.page;
|
|
|
|
if (templatePage) {
|
2023-11-16 20:55:02 +08:00
|
|
|
// Rewrite federation page references
|
|
|
|
templatePage = rewritePageRefsInString(templatePage, pageName);
|
2023-10-04 00:09:03 +08:00
|
|
|
if (templatePage.startsWith("[[")) {
|
|
|
|
templatePage = templatePage.slice(2, -2);
|
2023-10-03 20:16:33 +08:00
|
|
|
}
|
2023-10-04 00:09:03 +08:00
|
|
|
templateText = await space.readPage(templatePage);
|
2023-10-03 20:16:33 +08:00
|
|
|
}
|
|
|
|
|
2023-10-06 20:40:09 +08:00
|
|
|
const value = config.value
|
|
|
|
? JSON.parse(
|
|
|
|
await replaceTemplateVars(JSON.stringify(config.value), pageMeta),
|
|
|
|
)
|
|
|
|
: undefined;
|
|
|
|
|
2023-11-15 21:56:34 +08:00
|
|
|
let { text: rendered } = config.raw
|
|
|
|
? { text: templateText }
|
|
|
|
: await renderTemplate(
|
|
|
|
templateText,
|
|
|
|
pageMeta,
|
|
|
|
value,
|
|
|
|
);
|
2023-10-04 00:09:03 +08:00
|
|
|
|
|
|
|
if (templatePage) {
|
2023-10-29 17:02:50 +08:00
|
|
|
const parsedMarkdown = await markdown.parseMarkdown(rendered);
|
2023-10-04 00:09:03 +08:00
|
|
|
rewritePageRefs(parsedMarkdown, templatePage);
|
2023-10-29 17:02:50 +08:00
|
|
|
rendered = renderToText(parsedMarkdown);
|
2023-10-04 00:09:03 +08:00
|
|
|
}
|
2023-10-03 20:16:33 +08:00
|
|
|
|
2023-10-29 17:02:50 +08:00
|
|
|
return system.invokeFunction(
|
|
|
|
"markdown.markdownContentWidget",
|
|
|
|
rendered,
|
2023-11-03 19:01:33 +08:00
|
|
|
pageName,
|
2023-10-29 17:02:50 +08:00
|
|
|
);
|
2023-10-03 20:16:33 +08:00
|
|
|
} catch (e: any) {
|
2023-10-29 17:02:50 +08:00
|
|
|
return system.invokeFunction(
|
|
|
|
"markdown.markdownContentWidget",
|
|
|
|
`**Error:** ${e.message}`,
|
2023-11-03 19:01:33 +08:00
|
|
|
pageName,
|
2023-10-29 17:02:50 +08:00
|
|
|
);
|
2023-10-03 20:16:33 +08:00
|
|
|
}
|
|
|
|
}
|