2023-10-03 20:16:33 +08:00
|
|
|
import { ObjectValue } from "$sb/types.ts";
|
|
|
|
import { indexObjects } from "./api.ts";
|
|
|
|
import { AttributeObject } from "./attributes.ts";
|
|
|
|
import { TagObject } from "./tags.ts";
|
|
|
|
|
|
|
|
export const builtinPseudoPage = ":builtin:";
|
|
|
|
|
2023-12-22 01:37:50 +08:00
|
|
|
// Types marked with a ! are read-only, they cannot be set by the user
|
2023-10-03 20:16:33 +08:00
|
|
|
export const builtins: Record<string, Record<string, string>> = {
|
|
|
|
page: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
displayName: "string",
|
|
|
|
aliases: "array",
|
|
|
|
created: "!date",
|
|
|
|
lastModified: "!date",
|
|
|
|
perm: "!rw|ro",
|
|
|
|
contentType: "!string",
|
|
|
|
size: "!number",
|
2023-10-03 20:16:33 +08:00
|
|
|
tags: "array",
|
|
|
|
},
|
|
|
|
task: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
done: "!boolean",
|
|
|
|
page: "!string",
|
|
|
|
state: "!string",
|
2023-10-03 20:16:33 +08:00
|
|
|
deadline: "string",
|
2023-12-22 01:37:50 +08:00
|
|
|
pos: "!number",
|
2023-10-03 20:16:33 +08:00
|
|
|
tags: "array",
|
|
|
|
},
|
2023-10-13 23:10:57 +08:00
|
|
|
taskstate: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
tags: "!array",
|
|
|
|
state: "!string",
|
|
|
|
count: "!number",
|
|
|
|
page: "!string",
|
2023-10-13 23:10:57 +08:00
|
|
|
},
|
2023-10-03 20:16:33 +08:00
|
|
|
tag: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
page: "!string",
|
|
|
|
context: "!string",
|
2023-10-03 20:16:33 +08:00
|
|
|
},
|
|
|
|
attribute: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
attributeType: "!string",
|
|
|
|
type: "!string",
|
|
|
|
page: "!string",
|
2023-12-22 18:27:07 +08:00
|
|
|
readOnly: "!boolean",
|
2023-10-03 20:16:33 +08:00
|
|
|
},
|
|
|
|
anchor: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
page: "!string",
|
|
|
|
pos: "!number",
|
2023-10-03 20:16:33 +08:00
|
|
|
},
|
|
|
|
link: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
name: "!string",
|
|
|
|
page: "!string",
|
|
|
|
pos: "!number",
|
|
|
|
alias: "!string",
|
|
|
|
asTemplate: "!boolean",
|
2023-10-03 20:16:33 +08:00
|
|
|
},
|
2023-10-13 02:30:47 +08:00
|
|
|
paragraph: {
|
2023-12-22 01:37:50 +08:00
|
|
|
text: "!string",
|
|
|
|
page: "!string",
|
|
|
|
pos: "!number",
|
2023-10-13 02:30:47 +08:00
|
|
|
},
|
2023-11-11 21:28:46 +08:00
|
|
|
template: {
|
2023-12-22 01:37:50 +08:00
|
|
|
ref: "!string",
|
|
|
|
page: "!string",
|
|
|
|
pageName: "string",
|
|
|
|
pos: "!number",
|
|
|
|
type: "string",
|
2023-11-11 21:28:46 +08:00
|
|
|
trigger: "string",
|
|
|
|
},
|
2023-10-03 20:16:33 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
export async function loadBuiltinsIntoIndex() {
|
|
|
|
console.log("Loading builtins attributes into index");
|
|
|
|
const allTags: ObjectValue<TagObject>[] = [];
|
|
|
|
for (const [tag, attributes] of Object.entries(builtins)) {
|
|
|
|
allTags.push({
|
|
|
|
ref: tag,
|
|
|
|
tags: ["tag"],
|
|
|
|
name: tag,
|
|
|
|
page: builtinPseudoPage,
|
|
|
|
parent: "builtin",
|
|
|
|
});
|
|
|
|
await indexObjects<AttributeObject>(
|
|
|
|
builtinPseudoPage,
|
|
|
|
Object.entries(attributes).map(([name, attributeType]) => {
|
|
|
|
return {
|
|
|
|
ref: `${tag}:${name}`,
|
|
|
|
tags: ["attribute"],
|
|
|
|
tag,
|
|
|
|
name,
|
2023-12-22 01:37:50 +08:00
|
|
|
attributeType: attributeType.startsWith("!")
|
|
|
|
? attributeType.substring(1)
|
|
|
|
: attributeType,
|
|
|
|
readOnly: attributeType.startsWith("!"),
|
2023-10-03 20:16:33 +08:00
|
|
|
page: builtinPseudoPage,
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
await indexObjects(builtinPseudoPage, allTags);
|
|
|
|
}
|