2022-04-21 19:57:45 +08:00
|
|
|
import {
|
|
|
|
flashNotification,
|
|
|
|
getCurrentPage,
|
|
|
|
getText,
|
|
|
|
reloadPage,
|
2022-04-25 16:33:38 +08:00
|
|
|
save,
|
2022-04-25 17:24:13 +08:00
|
|
|
} from "@silverbulletmd/plugos-silverbullet-syscall/editor";
|
2022-04-01 23:07:08 +08:00
|
|
|
|
2022-04-25 17:24:13 +08:00
|
|
|
import {
|
|
|
|
readPage,
|
|
|
|
writePage,
|
|
|
|
} from "@silverbulletmd/plugos-silverbullet-syscall/space";
|
|
|
|
import { invokeFunction } from "@silverbulletmd/plugos-silverbullet-syscall/system";
|
2022-04-28 17:55:38 +08:00
|
|
|
import { parseQuery, renderQuery } from "./engine";
|
2022-04-13 20:46:52 +08:00
|
|
|
import { replaceTemplateVars } from "../core/template";
|
2022-04-28 17:55:38 +08:00
|
|
|
import { jsonToMDTable, queryRegex, removeQueries } from "./util";
|
2022-04-25 16:33:38 +08:00
|
|
|
import { dispatch } from "@plugos/plugos-syscall/event";
|
2022-04-20 16:56:43 +08:00
|
|
|
import { replaceAsync } from "../lib/util";
|
2022-03-29 23:02:28 +08:00
|
|
|
|
|
|
|
export async function updateMaterializedQueriesCommand() {
|
2022-04-01 23:07:08 +08:00
|
|
|
const currentPage = await getCurrentPage();
|
|
|
|
await save();
|
2022-05-20 17:29:14 +08:00
|
|
|
// await flashNotification("Updating materialized queries...");
|
2022-05-17 21:54:55 +08:00
|
|
|
if (
|
|
|
|
await invokeFunction(
|
|
|
|
"server",
|
|
|
|
"updateMaterializedQueriesOnPage",
|
|
|
|
currentPage
|
|
|
|
)
|
|
|
|
) {
|
|
|
|
await reloadPage();
|
|
|
|
}
|
2022-04-20 16:56:43 +08:00
|
|
|
}
|
|
|
|
|
2022-03-29 23:02:28 +08:00
|
|
|
// Called from client, running on server
|
2022-05-17 21:54:55 +08:00
|
|
|
export async function updateMaterializedQueriesOnPage(
|
|
|
|
pageName: string
|
|
|
|
): Promise<boolean> {
|
2022-04-01 23:07:08 +08:00
|
|
|
let { text } = await readPage(pageName);
|
2022-04-08 23:46:09 +08:00
|
|
|
|
2022-05-17 21:54:55 +08:00
|
|
|
let newText = await replaceAsync(
|
2022-04-12 19:33:07 +08:00
|
|
|
text,
|
|
|
|
queryRegex,
|
|
|
|
async (fullMatch, startQuery, query, body, endQuery) => {
|
2022-04-19 22:54:47 +08:00
|
|
|
let parsedQuery = parseQuery(replaceTemplateVars(query, pageName));
|
2022-04-06 21:39:20 +08:00
|
|
|
|
2022-04-12 19:33:07 +08:00
|
|
|
console.log("Parsed query", parsedQuery);
|
2022-04-19 22:54:47 +08:00
|
|
|
// Let's dispatch an event and see what happens
|
|
|
|
let results = await dispatch(
|
|
|
|
`query:${parsedQuery.table}`,
|
|
|
|
{ query: parsedQuery, pageName: pageName },
|
2022-04-20 16:56:43 +08:00
|
|
|
10 * 1000
|
2022-04-19 22:54:47 +08:00
|
|
|
);
|
|
|
|
if (results.length === 0) {
|
|
|
|
return `${startQuery}\n${endQuery}`;
|
|
|
|
} else if (results.length === 1) {
|
2022-04-28 17:55:38 +08:00
|
|
|
if (parsedQuery.render) {
|
|
|
|
let rendered = await renderQuery(parsedQuery, results[0]);
|
|
|
|
return `${startQuery}\n${rendered.trim()}\n${endQuery}`;
|
|
|
|
} else {
|
|
|
|
return `${startQuery}\n${jsonToMDTable(results[0])}\n${endQuery}`;
|
|
|
|
}
|
2022-04-19 22:54:47 +08:00
|
|
|
} else {
|
|
|
|
console.error("Too many query results", results);
|
|
|
|
return fullMatch;
|
2022-04-12 19:33:07 +08:00
|
|
|
}
|
2022-03-29 23:02:28 +08:00
|
|
|
}
|
2022-04-12 19:33:07 +08:00
|
|
|
);
|
2022-05-17 21:54:55 +08:00
|
|
|
if (text !== newText) {
|
|
|
|
await writePage(pageName, newText);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
2022-03-29 23:02:28 +08:00
|
|
|
}
|