1
0
mirror of https://github.com/hotomoe/hotomoe synced 2024-12-15 23:28:08 +09:00
hotomoe/packages/frontend/src/scripts/collect-page-vars.ts

69 lines
1.3 KiB
TypeScript
Raw Normal View History

interface StringPageVar {
name: string,
type: 'string',
value: string
}
interface NumberPageVar {
name: string,
type: 'number',
value: number
}
interface BooleanPageVar {
name: string,
type: 'boolean',
value: boolean
}
type PageVar = StringPageVar | NumberPageVar | BooleanPageVar;
export function collectPageVars(content): PageVar[] {
const pageVars: PageVar[] = [];
const collect = (xs: any[]): void => {
for (const x of xs) {
2019-04-30 12:15:41 +09:00
if (x.type === 'textInput') {
pageVars.push({
name: x.name,
2019-04-30 12:15:41 +09:00
type: 'string',
value: x.default || '',
2019-04-30 12:15:41 +09:00
});
} else if (x.type === 'textareaInput') {
pageVars.push({
name: x.name,
type: 'string',
value: x.default || '',
2019-04-30 12:15:41 +09:00
});
} else if (x.type === 'numberInput') {
pageVars.push({
name: x.name,
type: 'number',
value: x.default || 0,
});
} else if (x.type === 'switch') {
pageVars.push({
name: x.name,
type: 'boolean',
value: x.default || false,
});
2019-05-02 17:55:59 +09:00
} else if (x.type === 'counter') {
pageVars.push({
name: x.name,
type: 'number',
value: 0,
2019-05-02 17:55:59 +09:00
});
2019-07-10 18:30:51 +09:00
} else if (x.type === 'radioButton') {
pageVars.push({
name: x.name,
type: 'string',
value: x.default || '',
2019-07-10 18:30:51 +09:00
});
} else if (x.children) {
collect(x.children);
}
}
};
collect(content);
return pageVars;
}