mirror of
https://github.com/Start9Labs/start-os.git
synced 2026-03-26 02:11:53 +00:00
- Add addKey() and add() builder methods to InputSpec with InputSpecTools - Move OuterType to last generic param on Value, List, and all dynamic methods - Plumb prefill through getActionInput end-to-end (core → container-runtime → SDK) - Filter port_forwards to enabled addresses only - Bump SDK to 0.4.0-beta.50
201 lines
5.0 KiB
TypeScript
201 lines
5.0 KiB
TypeScript
import { InputSpec, LazyBuild } from './inputSpec'
|
|
import {
|
|
ListValueSpecText,
|
|
Pattern,
|
|
RandomString,
|
|
UniqueBy,
|
|
ValueSpecList,
|
|
ValueSpecListOf,
|
|
} from '../inputSpecTypes'
|
|
import { Parser, arrayOf, string } from 'ts-matches'
|
|
|
|
export class List<
|
|
Type extends StaticValidatedAs,
|
|
StaticValidatedAs = Type,
|
|
OuterType = unknown,
|
|
> {
|
|
private constructor(
|
|
public build: LazyBuild<
|
|
{
|
|
spec: ValueSpecList
|
|
validator: Parser<unknown, Type>
|
|
},
|
|
OuterType
|
|
>,
|
|
public readonly validator: Parser<unknown, StaticValidatedAs>,
|
|
) {}
|
|
readonly _TYPE: Type = null as any
|
|
|
|
static text(
|
|
a: {
|
|
name: string
|
|
description?: string | null
|
|
warning?: string | null
|
|
default?: string[]
|
|
minLength?: number | null
|
|
maxLength?: number | null
|
|
},
|
|
aSpec: {
|
|
/**
|
|
* @description Mask (aka camouflage) text input with dots: ● ● ●
|
|
* @default false
|
|
*/
|
|
masked?: boolean
|
|
placeholder?: string | null
|
|
minLength?: number | null
|
|
maxLength?: number | null
|
|
/**
|
|
* @description A list of regular expressions to which the text must conform to pass validation. A human readable description is provided in case the validation fails.
|
|
* @default []
|
|
* @example
|
|
* ```
|
|
[
|
|
{
|
|
regex: "[a-z]",
|
|
description: "May only contain lower case letters from the English alphabet."
|
|
}
|
|
]
|
|
* ```
|
|
*/
|
|
patterns?: Pattern[]
|
|
/**
|
|
* @description Informs the browser how to behave and which keyboard to display on mobile
|
|
* @default "text"
|
|
*/
|
|
inputmode?: ListValueSpecText['inputmode']
|
|
/**
|
|
* @description Displays a button that will generate a random string according to the provided charset and len attributes.
|
|
*/
|
|
generate?: null | RandomString
|
|
},
|
|
) {
|
|
const validator = arrayOf(string)
|
|
return new List<string[]>(() => {
|
|
const spec = {
|
|
type: 'text' as const,
|
|
placeholder: null,
|
|
minLength: null,
|
|
maxLength: null,
|
|
masked: false,
|
|
inputmode: 'text' as const,
|
|
generate: null,
|
|
patterns: aSpec.patterns || [],
|
|
...aSpec,
|
|
}
|
|
const built: ValueSpecListOf<'text'> = {
|
|
description: null,
|
|
warning: null,
|
|
default: [],
|
|
type: 'list' as const,
|
|
minLength: null,
|
|
maxLength: null,
|
|
disabled: false,
|
|
...a,
|
|
spec,
|
|
}
|
|
return { spec: built, validator }
|
|
}, validator)
|
|
}
|
|
|
|
static dynamicText<OuterType = unknown>(
|
|
getA: LazyBuild<
|
|
{
|
|
name: string
|
|
description?: string | null
|
|
warning?: string | null
|
|
default?: string[]
|
|
minLength?: number | null
|
|
maxLength?: number | null
|
|
disabled?: false | string
|
|
generate?: null | RandomString
|
|
spec: {
|
|
masked?: boolean
|
|
placeholder?: string | null
|
|
minLength?: number | null
|
|
maxLength?: number | null
|
|
patterns?: Pattern[]
|
|
inputmode?: ListValueSpecText['inputmode']
|
|
}
|
|
},
|
|
OuterType
|
|
>,
|
|
) {
|
|
const validator = arrayOf(string)
|
|
return new List<string[], string[], OuterType>(async (options) => {
|
|
const { spec: aSpec, ...a } = await getA(options)
|
|
const spec = {
|
|
type: 'text' as const,
|
|
placeholder: null,
|
|
minLength: null,
|
|
maxLength: null,
|
|
masked: false,
|
|
inputmode: 'text' as const,
|
|
generate: null,
|
|
patterns: aSpec.patterns || [],
|
|
...aSpec,
|
|
}
|
|
const built: ValueSpecListOf<'text'> = {
|
|
description: null,
|
|
warning: null,
|
|
default: [],
|
|
type: 'list' as const,
|
|
minLength: null,
|
|
maxLength: null,
|
|
disabled: false,
|
|
...a,
|
|
spec,
|
|
}
|
|
|
|
return { spec: built, validator }
|
|
}, validator)
|
|
}
|
|
|
|
static obj<
|
|
Type extends StaticValidatedAs,
|
|
StaticValidatedAs extends Record<string, any>,
|
|
>(
|
|
a: {
|
|
name: string
|
|
description?: string | null
|
|
warning?: string | null
|
|
default?: []
|
|
minLength?: number | null
|
|
maxLength?: number | null
|
|
},
|
|
aSpec: {
|
|
spec: InputSpec<Type, StaticValidatedAs>
|
|
displayAs?: null | string
|
|
uniqueBy?: null | UniqueBy
|
|
},
|
|
) {
|
|
return new List<Type[], StaticValidatedAs[]>(async (options) => {
|
|
const { spec: previousSpecSpec, ...restSpec } = aSpec
|
|
const built = await previousSpecSpec.build(options)
|
|
const spec = {
|
|
type: 'object' as const,
|
|
displayAs: null,
|
|
uniqueBy: null,
|
|
...restSpec,
|
|
spec: built.spec,
|
|
}
|
|
const value = {
|
|
spec,
|
|
default: [],
|
|
...a,
|
|
}
|
|
return {
|
|
spec: {
|
|
description: null,
|
|
warning: null,
|
|
minLength: null,
|
|
maxLength: null,
|
|
type: 'list' as const,
|
|
disabled: false,
|
|
...value,
|
|
},
|
|
validator: arrayOf(built.validator),
|
|
}
|
|
}, arrayOf(aSpec.spec.validator))
|
|
}
|
|
}
|