pull/569/head
Zef Hemel 2023-11-15 10:27:37 +01:00
parent 8a7c50599d
commit 35e2afc18b
3 changed files with 56 additions and 1 deletions

View File

@ -1,6 +1,7 @@
import { editor, markdown, mq, space, sync } from "$sb/syscalls.ts"; import { editor, markdown, mq, space, sync } from "$sb/syscalls.ts";
import { import {
addParentPointers, addParentPointers,
collectNodesOfType,
findParentMatching, findParentMatching,
nodeAtPos, nodeAtPos,
ParseTree, ParseTree,
@ -264,3 +265,53 @@ export async function convertToLive() {
}); });
} }
} }
export async function convertSpaceToLive() {
if (
!await editor.confirm(
"This will convert all directives in the space to live queries. Are you sure?",
)
) {
return;
}
const pages = await space.listPages();
for (const page of pages) {
console.log("Now converting", page);
const text = await space.readPage(page.name);
const newText = await convertDirectivesOnPage(text);
if (text !== newText) {
console.log("Changes were made, writing", page.name);
await space.writePage(page.name, newText);
}
}
await editor.flashNotification("All done!");
}
export async function convertDirectivesOnPage(text: string) {
const tree = await markdown.parseMarkdown(text);
collectNodesOfType(tree, "Directive").forEach((directive) => {
const directiveText = renderToText(directive);
console.log("Got this directive", directiveText);
const startNode = directive.children![0];
const startNodeText = renderToText(startNode);
if (startNodeText.includes("#query")) {
const queryText = renderToText(startNode.children![1]);
text = text.replace(directiveText, "```query\n" + queryText + "\n```");
} else if (
startNodeText.includes("#use") || startNodeText.includes("#include")
) {
const pageRefMatch = /\[\[([^\]]+)\]\]\s*([^\-]+)?/.exec(startNodeText);
if (!pageRefMatch) {
return;
}
const val = pageRefMatch[2];
text = text.replace(
directiveText,
'```template\npage: "[[' + pageRefMatch[1] + ']]"\n' +
(val ? `val: ${val}\n` : "") + "```",
);
}
});
// console.log("Converted page", text);
return text;
}

View File

@ -33,3 +33,8 @@ functions:
path: command.ts:convertToLive path: command.ts:convertToLive
command: command:
name: "Directive: Convert to Live Query/Template" name: "Directive: Convert to Live Query/Template"
convertSpaceToLive:
path: command.ts:convertSpaceToLive
command:
name: "Directive: Convert Entire Space to Live/Templates"

View File

@ -35,7 +35,6 @@ export function PageNavigator({
// And deprioritize federated pages too // And deprioritize federated pages too
if (isFederationPath(pageMeta.name)) { if (isFederationPath(pageMeta.name)) {
orderId = Math.round(orderId / 10); // Just 10x lower the timestamp to push them down, should work orderId = Math.round(orderId / 10); // Just 10x lower the timestamp to push them down, should work
console.log("Deprioritizing", pageMeta);
} }
options.push({ options.push({
...pageMeta, ...pageMeta,