2019-04-28 18:11:57 -06:00
|
|
|
export function collectPageVars(content) {
|
|
|
|
const pageVars = [];
|
|
|
|
const collect = (xs: any[]) => {
|
|
|
|
for (const x of xs) {
|
2023-01-12 21:40:33 -07:00
|
|
|
if (x.type === "textInput") {
|
2019-04-28 18:11:57 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "string",
|
|
|
|
value: x.default || "",
|
2019-04-29 21:15:41 -06:00
|
|
|
});
|
2023-01-12 21:40:33 -07:00
|
|
|
} else if (x.type === "textareaInput") {
|
2019-04-29 21:15:41 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "string",
|
|
|
|
value: x.default || "",
|
2019-04-29 21:15:41 -06:00
|
|
|
});
|
2023-01-12 21:40:33 -07:00
|
|
|
} else if (x.type === "numberInput") {
|
2019-04-29 21:15:41 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "number",
|
|
|
|
value: x.default || 0,
|
2019-04-28 18:11:57 -06:00
|
|
|
});
|
2023-01-12 21:40:33 -07:00
|
|
|
} else if (x.type === "switch") {
|
2019-04-28 18:11:57 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "boolean",
|
|
|
|
value: x.default,
|
2019-04-28 18:11:57 -06:00
|
|
|
});
|
2023-01-12 21:40:33 -07:00
|
|
|
} else if (x.type === "counter") {
|
2019-05-02 02:55:59 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "number",
|
|
|
|
value: 0,
|
2019-05-02 02:55:59 -06:00
|
|
|
});
|
2023-01-12 21:40:33 -07:00
|
|
|
} else if (x.type === "radioButton") {
|
2019-07-10 03:30:51 -06:00
|
|
|
pageVars.push({
|
|
|
|
name: x.name,
|
2023-01-12 21:40:33 -07:00
|
|
|
type: "string",
|
|
|
|
value: x.default || "",
|
2019-07-10 03:30:51 -06:00
|
|
|
});
|
2019-04-28 18:11:57 -06:00
|
|
|
} else if (x.children) {
|
|
|
|
collect(x.children);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
collect(content);
|
|
|
|
return pageVars;
|
|
|
|
}
|