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