mirror of
https://github.com/Start9Labs/start-sdk.git
synced 2026-03-26 18:31:54 +00:00
177 lines
4.7 KiB
TypeScript
177 lines
4.7 KiB
TypeScript
export type InputSpec = Record<string, ValueSpec>;
|
|
|
|
export type ValueType =
|
|
| "string"
|
|
| "number"
|
|
| "boolean"
|
|
| "select"
|
|
| "multiselect"
|
|
| "list"
|
|
| "object"
|
|
| "file"
|
|
| "union";
|
|
export type ValueSpec = ValueSpecOf<ValueType>;
|
|
|
|
/** core spec types. These types provide the metadata for performing validations */
|
|
export type ValueSpecOf<T extends ValueType> = T extends "string"
|
|
? ValueSpecString
|
|
: T extends "number"
|
|
? ValueSpecNumber
|
|
: T extends "boolean"
|
|
? ValueSpecBoolean
|
|
: T extends "select"
|
|
? ValueSpecSelect
|
|
: T extends "multiselect"
|
|
? ValueSpecMultiselect
|
|
: T extends "list"
|
|
? ValueSpecList
|
|
: T extends "object"
|
|
? ValueSpecObject
|
|
: T extends "file"
|
|
? ValueSpecFile
|
|
: T extends "union"
|
|
? ValueSpecUnion
|
|
: never;
|
|
|
|
export interface ValueSpecString extends ListValueSpecString, WithStandalone {
|
|
type: "string";
|
|
default: null | DefaultString;
|
|
nullable: boolean;
|
|
textarea: null | boolean;
|
|
}
|
|
|
|
export interface ValueSpecNumber extends ListValueSpecNumber, WithStandalone {
|
|
type: "number";
|
|
nullable: boolean;
|
|
default: null | number;
|
|
}
|
|
|
|
export interface ValueSpecSelect extends SelectBase, WithStandalone {
|
|
type: "select";
|
|
nullable: boolean;
|
|
default: null | string;
|
|
}
|
|
|
|
export interface ValueSpecMultiselect extends SelectBase, WithStandalone {
|
|
type: "multiselect";
|
|
/**'[0,1]' (inclusive) OR '[0,*)' (right unbounded), normal math rules */
|
|
range: string;
|
|
default: string[];
|
|
}
|
|
|
|
export interface ValueSpecBoolean extends WithStandalone {
|
|
type: "boolean";
|
|
default: null | boolean;
|
|
}
|
|
|
|
export interface ValueSpecUnion extends WithStandalone {
|
|
type: "union";
|
|
variants: { [key: string]: { name: string; spec: InputSpec } };
|
|
default: null | string;
|
|
}
|
|
|
|
export interface ValueSpecFile extends WithStandalone {
|
|
type: "file";
|
|
placeholder: null | string;
|
|
nullable: boolean;
|
|
extensions: string[];
|
|
}
|
|
|
|
export interface ValueSpecObject extends WithStandalone {
|
|
type: "object";
|
|
spec: InputSpec;
|
|
}
|
|
|
|
export interface WithStandalone {
|
|
name: string;
|
|
description: null | string;
|
|
warning: null | string;
|
|
}
|
|
|
|
export interface SelectBase {
|
|
values: { [value: string]: string };
|
|
}
|
|
|
|
/** no lists of booleans, lists*/
|
|
export type ListValueSpecType = "string" | "number" | "object" | "union";
|
|
|
|
/** represents a spec for the values of a list */
|
|
export type ListValueSpecOf<T extends ListValueSpecType> = T extends "string"
|
|
? ListValueSpecString
|
|
: T extends "number"
|
|
? ListValueSpecNumber
|
|
: T extends "object"
|
|
? ListValueSpecObject
|
|
: T extends "union"
|
|
? ListValueSpecUnion
|
|
: never;
|
|
|
|
/** represents a spec for a list */
|
|
export type ValueSpecList = ValueSpecListOf<ListValueSpecType>;
|
|
export interface ValueSpecListOf<T extends ListValueSpecType>
|
|
extends WithStandalone {
|
|
type: "list";
|
|
subtype: T;
|
|
spec: ListValueSpecOf<T>;
|
|
range: string; // '[0,1]' (inclusive) OR '[0,*)' (right unbounded), normal math rules
|
|
default:
|
|
| string[]
|
|
| number[]
|
|
| DefaultString[]
|
|
| Record<string, unknown>[]
|
|
| readonly string[]
|
|
| readonly number[]
|
|
| readonly DefaultString[]
|
|
| readonly Record<string, unknown>[];
|
|
}
|
|
|
|
// sometimes the type checker needs just a little bit of help
|
|
export function isValueSpecListOf<S extends ListValueSpecType>(
|
|
t: ValueSpecList,
|
|
s: S
|
|
): t is ValueSpecListOf<S> {
|
|
return t.subtype === s;
|
|
}
|
|
|
|
export interface ListValueSpecString {
|
|
pattern: null | string;
|
|
patternDescription: null | string;
|
|
masked: boolean;
|
|
placeholder: null | string;
|
|
}
|
|
|
|
export interface ListValueSpecNumber {
|
|
/** '[0,1]' (inclusive) OR '[0,*)' (right unbounded), normal math rules */
|
|
range: string;
|
|
integral: boolean;
|
|
units: null | string;
|
|
placeholder: null | string;
|
|
}
|
|
|
|
export interface ListValueSpecObject {
|
|
/** this is a mapped type of the config object at this level, replacing the object's values with specs on those values */
|
|
spec: InputSpec;
|
|
/** indicates whether duplicates can be permitted in the list */
|
|
uniqueBy: UniqueBy;
|
|
/** this should be a handlebars template which can make use of the entire config which corresponds to 'spec' */
|
|
displayAs: null | string;
|
|
}
|
|
|
|
export type UniqueBy =
|
|
| null
|
|
| undefined
|
|
| string
|
|
| { any: readonly UniqueBy[] | UniqueBy[] }
|
|
| { all: readonly UniqueBy[] | UniqueBy[] };
|
|
|
|
export interface ListValueSpecUnion {
|
|
variants: { [key: string]: { name: string; spec: InputSpec } };
|
|
/** this may be a handlebars template which can conditionally (on tag.id) make use of each union's entries, or if left blank will display as tag.id*/
|
|
displayAs: null | string;
|
|
uniqueBy: UniqueBy;
|
|
/** this should be the variantName which one prefers a user to start with by default when creating a new union instance in a list*/
|
|
default: null | string;
|
|
}
|
|
|
|
export type DefaultString = string | { charset: string; len: number };
|