mirror of
https://github.com/Start9Labs/start-sdk.git
synced 2026-03-26 02:11:56 +00:00
feat: Add in the config tools, and move things around
This commit is contained in:
@@ -10,12 +10,15 @@ if (!Deno.isatty(Deno.stdin.rid)) {
|
||||
}
|
||||
|
||||
console.log(`
|
||||
import {Config, Value, List, Variants} from '${await Deno.args[0]}';
|
||||
import {configBuilder} from '${await Deno.args[0]}';
|
||||
const {Config, Value, List, Variants} = configBuilder;
|
||||
`);
|
||||
const data = JSON.parse(list.join("\n"));
|
||||
|
||||
const namedConsts = new Set(["Config", "Value", "List"]);
|
||||
newConst("config", convertConfigSpec(data));
|
||||
const configName = newConst("config", convertConfigSpec(data));
|
||||
const configMatcherName = newConst("matchConfig", `${configName}.validator()`);
|
||||
console.log(`export type Config = typeof ${configMatcherName}._TYPE;`);
|
||||
|
||||
function newConst(key: string, data: string) {
|
||||
const variableName = getNextConstName(camelCase(key));
|
||||
@@ -34,79 +37,68 @@ function convertConfigSpec(data: any) {
|
||||
function convertValueSpec(value: any): string {
|
||||
switch (value.type) {
|
||||
case "string": {
|
||||
return `Value.string(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
nullable: value.nullable || false,
|
||||
masked: value.masked || null,
|
||||
placeholder: value.placeholder || null,
|
||||
pattern: value.pattern || null,
|
||||
"pattern-description": value["pattern-description"] || null,
|
||||
textarea: value.textarea || null,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
return `Value.string(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
nullable: value.nullable || false,
|
||||
masked: value.masked || null,
|
||||
placeholder: value.placeholder || null,
|
||||
pattern: value.pattern || null,
|
||||
"pattern-description": value["pattern-description"] || null,
|
||||
textarea: value.textarea || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "number": {
|
||||
return `Value.number(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
nullable: value.nullable || false,
|
||||
range: value.range || null,
|
||||
integral: value.integral || false,
|
||||
units: value.units || null,
|
||||
placeholder: value.placeholder || null,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
return `Value.number(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
nullable: value.nullable || false,
|
||||
range: value.range || null,
|
||||
integral: value.integral || false,
|
||||
units: value.units || null,
|
||||
placeholder: value.placeholder || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "boolean": {
|
||||
return `Value.boolean(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || false,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
return `Value.boolean(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
default: value.default || false,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "enum": {
|
||||
return `Value.enum(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
default: value.default || null,
|
||||
values: value.values || null,
|
||||
"value-names": value["value-names"] || null,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
return `Value.enum(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
default: value.default || null,
|
||||
values: value.values || null,
|
||||
"value-names": value["value-names"] || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "object": {
|
||||
const specName = newConst(
|
||||
value.name + "_spec",
|
||||
convertConfigSpec(value.spec),
|
||||
);
|
||||
const specName = newConst(value.name + "_spec", convertConfigSpec(value.spec));
|
||||
return `Value.object({
|
||||
name: ${JSON.stringify(value.name || null)},
|
||||
description: ${JSON.stringify(value.description || null)},
|
||||
@@ -119,37 +111,27 @@ function convertValueSpec(value: any): string {
|
||||
})`;
|
||||
}
|
||||
case "union": {
|
||||
const variants = newConst(
|
||||
value.name + "_variants",
|
||||
convertVariants(value.variants),
|
||||
);
|
||||
const variants = newConst(value.name + "_variants", convertVariants(value.variants));
|
||||
return `Value.union({
|
||||
name: ${JSON.stringify(value.name || null)},
|
||||
description: ${JSON.stringify(value.description || null)},
|
||||
warning: ${JSON.stringify(value.warning || null)},
|
||||
default: ${JSON.stringify(value.default || null)},
|
||||
variants: ${variants},
|
||||
tag: ${
|
||||
JSON.stringify({
|
||||
"id": value?.tag?.["id"] || null,
|
||||
"name": value?.tag?.["name"] || null,
|
||||
"description": value?.tag?.["description"] || null,
|
||||
"warning": value?.tag?.["warning"] || null,
|
||||
tag: ${JSON.stringify({
|
||||
id: value?.tag?.["id"] || null,
|
||||
name: value?.tag?.["name"] || null,
|
||||
description: value?.tag?.["description"] || null,
|
||||
warning: value?.tag?.["warning"] || null,
|
||||
"variant-names": value?.tag?.["variant-names"] || {},
|
||||
})
|
||||
},
|
||||
})},
|
||||
"display-as": ${JSON.stringify(value["display-as"] || null)},
|
||||
"unique-by": ${JSON.stringify(value["unique-by"] || null)},
|
||||
"variant-names": ${
|
||||
JSON.stringify(value["variant-names"] as any || null)
|
||||
},
|
||||
"variant-names": ${JSON.stringify((value["variant-names"] as any) || null)},
|
||||
})`;
|
||||
}
|
||||
case "list": {
|
||||
const list = newConst(
|
||||
value.name + "_list",
|
||||
convertList(value),
|
||||
);
|
||||
const list = newConst(value.name + "_list", convertList(value));
|
||||
return `Value.list(${list})`;
|
||||
}
|
||||
case "pointer": {
|
||||
@@ -162,81 +144,69 @@ function convertValueSpec(value: any): string {
|
||||
function convertList(value: any) {
|
||||
switch (value.subtype) {
|
||||
case "string": {
|
||||
return `List.string(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
"masked": value?.spec?.["masked"] || null,
|
||||
"placeholder": value?.spec?.["placeholder"] || null,
|
||||
"pattern": value?.spec?.["pattern"] || null,
|
||||
"pattern-description": value?.spec?.["pattern-description"] ||
|
||||
null,
|
||||
"textarea": value?.spec?.["textarea"] || false,
|
||||
},
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
return `List.string(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
masked: value?.spec?.["masked"] || null,
|
||||
placeholder: value?.spec?.["placeholder"] || null,
|
||||
pattern: value?.spec?.["pattern"] || null,
|
||||
"pattern-description": value?.spec?.["pattern-description"] || null,
|
||||
textarea: value?.spec?.["textarea"] || false,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "number": {
|
||||
return `List.number(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
range: value?.spec?.range || null,
|
||||
integral: value?.spec?.integral || false,
|
||||
units: value?.spec?.units || null,
|
||||
placeholder: value?.spec?.placeholder || null,
|
||||
},
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
return `List.number(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
range: value?.spec?.range || null,
|
||||
integral: value?.spec?.integral || false,
|
||||
units: value?.spec?.units || null,
|
||||
placeholder: value?.spec?.placeholder || null,
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "enum": {
|
||||
return `List.enum(${
|
||||
JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
"values": value?.spec?.["values"] || null,
|
||||
"value-names": value?.spec?.["value-names"] || {},
|
||||
},
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
return `List.enum(${JSON.stringify(
|
||||
{
|
||||
name: value.name || null,
|
||||
range: value.range || null,
|
||||
spec: {
|
||||
values: value?.spec?.["values"] || null,
|
||||
"value-names": value?.spec?.["value-names"] || {},
|
||||
},
|
||||
null,
|
||||
2,
|
||||
)
|
||||
})`;
|
||||
default: value.default || null,
|
||||
description: value.description || null,
|
||||
warning: value.warning || null,
|
||||
},
|
||||
null,
|
||||
2
|
||||
)})`;
|
||||
}
|
||||
case "object": {
|
||||
const specName = newConst(
|
||||
value.name + "_spec",
|
||||
convertConfigSpec(value.spec.spec),
|
||||
);
|
||||
const specName = newConst(value.name + "_spec", convertConfigSpec(value.spec.spec));
|
||||
return `List.obj({
|
||||
name: ${JSON.stringify(value.name || null)},
|
||||
range: ${JSON.stringify(value.range || null)},
|
||||
spec: {
|
||||
spec: ${specName},
|
||||
"display-as": ${
|
||||
JSON.stringify(value?.spec?.["display-as"] || null)
|
||||
},
|
||||
"display-as": ${JSON.stringify(value?.spec?.["display-as"] || null)},
|
||||
"unique-by": ${JSON.stringify(value?.spec?.["unique-by"] || null)},
|
||||
},
|
||||
default: ${JSON.stringify(value.default || null)},
|
||||
@@ -245,10 +215,7 @@ function convertList(value: any) {
|
||||
})`;
|
||||
}
|
||||
case "union": {
|
||||
const variants = newConst(
|
||||
value.name + "_variants",
|
||||
convertConfigSpec(value.spec.variants),
|
||||
);
|
||||
const variants = newConst(value.name + "_variants", convertConfigSpec(value.spec.variants));
|
||||
return `List.union(
|
||||
{
|
||||
name:${JSON.stringify(value.name || null)},
|
||||
@@ -256,26 +223,14 @@ function convertList(value: any) {
|
||||
spec: {
|
||||
tag: {
|
||||
"id":${JSON.stringify(value?.spec?.tag?.["id"] || null)},
|
||||
"name": ${
|
||||
JSON.stringify(value?.spec?.tag?.["name"] || null)
|
||||
},
|
||||
"description": ${
|
||||
JSON.stringify(value?.spec?.tag?.["description"] || null)
|
||||
},
|
||||
"warning": ${
|
||||
JSON.stringify(value?.spec?.tag?.["warning"] || null)
|
||||
},
|
||||
"variant-names": ${
|
||||
JSON.stringify(value?.spec?.tag?.["variant-names"] || {})
|
||||
},
|
||||
"name": ${JSON.stringify(value?.spec?.tag?.["name"] || null)},
|
||||
"description": ${JSON.stringify(value?.spec?.tag?.["description"] || null)},
|
||||
"warning": ${JSON.stringify(value?.spec?.tag?.["warning"] || null)},
|
||||
"variant-names": ${JSON.stringify(value?.spec?.tag?.["variant-names"] || {})},
|
||||
},
|
||||
variants: ${variants},
|
||||
"display-as": ${
|
||||
JSON.stringify(value?.spec?.["display-as"] || null)
|
||||
},
|
||||
"unique-by": ${
|
||||
JSON.stringify(value?.spec?.["unique-by"] || null)
|
||||
},
|
||||
"display-as": ${JSON.stringify(value?.spec?.["display-as"] || null)},
|
||||
"unique-by": ${JSON.stringify(value?.spec?.["unique-by"] || null)},
|
||||
default: ${JSON.stringify(value?.spec?.["default"] || null)},
|
||||
},
|
||||
default: ${JSON.stringify(value.default || null)},
|
||||
|
||||
Reference in New Issue
Block a user