Interface UiObjectConfig<T, TType, TTarget>

interface UiObjectConfig<
    T = any,
    TType extends UiObjectType = UiObjectType,
    TTarget = any,
> {
    binding?: ValOrFunc<[TTarget, Extract<keyof TTarget, string>]>;
    bounds?: ValOrFunc<number[]>;
    children?: (UiObjectConfig | Fof<ValOrArrOp<UiObjectConfig>>)[];
    disabled?: ValOrFunc<boolean>;
    dispatchMode?: TUiRefreshModes | "immediate";
    domChildren?: HTMLElement[] | () => HTMLElement[];
    expanded?: ValOrFunc<boolean>;
    getValue?: () => T;
    hidden?: ValOrFunc<boolean>;
    inlinePicker?: ValOrFunc<boolean>;
    label?: ValOrFunc<string>;
    onChange?:
        | (...args: ChangeArgs) => void
        | (undefined | (...args: ChangeArgs) => void)[]
        | () => void
        | (undefined | () => void)[];
    onClick?: (
        ...args: any[],
    ) =>
        | void
        | { action?: () => any; redo?: () => any; undo?: () => any }
        | () => any;
    onExpand?: (c: UiObjectConfig) => void;
    parentOnChange?: (...args: ChangeArgs) => void;
    parentProperty?: ValOrFunc<undefined | [any, string | number]>;
    path?: ValOrFunc<string>;
    property?: ValOrFunc<[TTarget, number | Extract<keyof TTarget, string>]>;
    readOnly?: ValOrFunc<boolean>;
    sendArgs?: ValOrFunc<boolean>;
    setValue?:
        | (value: T, ...args: ChangeArgs | never[]) => void
        | (value: T) => void;
    stepSize?: ValOrFunc<number>;
    tags?: ValOrArr<string>;
    type?: TType;
    uiRef?: any;
    uiRefresh?: (
        deep?: boolean,
        mode?: TUiRefreshModes | "immediate",
        delay?: number,
    ) => void;
    uiRefType?: string;
    uuid?: string;
    value?: T;
    [id: string]: any;
}

Type Parameters

Indexable

  • [id: string]: any

    Individual components can support custom options. These can be added to the config object.

Properties

binding?: ValOrFunc<[TTarget, Extract<keyof TTarget, string>]>

Alias for property

bounds?: ValOrFunc<number[]>

bounds for the value of the object. This is used for numeric inputs like number and sliders. This can be an array of [min, max] or a function that returns an array of [min, max].

children?: (UiObjectConfig | Fof<ValOrArrOp<UiObjectConfig>>)[]

Children of this object. This is used for folders and dropdowns. This can be an array of UiObjectConfig objects, or an array of functions that returns an array of UiObjectConfig objects. Note: it could be a function that returns an array as well, but its not added to the type yet.

disabled?: ValOrFunc<boolean>

The Ui input will be disabled if this is true, i.e. the user will not be able to change the value. This can be a boolean or a function that returns a boolean.

dispatchMode?: TUiRefreshModes | "immediate"

This is used to specify when to change the values and/or call the function(like onClick) or change events. Default is 'postFrame'

domChildren?: HTMLElement[] | () => HTMLElement[]

Extra HTMLElements to be added to the UI element. This is used for customizing the UI. This can be an array of HTMLElement or a function that returns an array of HTMLElement.

expanded?: ValOrFunc<boolean>

Only for folders. The Ui element will be expanded if this is true. This can be a boolean or a function that returns a boolean. If this is not set to a function, config.expanded can be read to get the current state.

getValue?: () => T

getValue function. This is used for inputs, if property, value is not specified. This is called to get the value of the input on each render/update. It is ignored if property or value is specified.

hidden?: ValOrFunc<boolean>

The Ui element will be hidden if this is true. This can be a boolean or a function that returns a boolean.

inlinePicker?: ValOrFunc<boolean>

Only for elements with inline picker support This can be a boolean or a function that returns a boolean.

label?: ValOrFunc<string>

The label to use for the object. This is used as the title for folders, and as the label for inputs. This can be a string or a function that returns a string. If not provided, the label will be determined automatically, by the key of the property or sets to defaults

onChange?:
    | (...args: ChangeArgs) => void
    | (undefined | (...args: ChangeArgs) => void)[]
    | () => void
    | (undefined | () => void)[]

onChange callbacks can be added to the config object to be called when the value of the object changes. This can be a function or an array of functions. When it's specified with a container(with children) object, it will be called when any of the children change, and the config of the child that's changed will be available in the arguments

onClick?: (
    ...args: any[],
) =>
    | void
    | { action?: () => any; redo?: () => any; undo?: () => any }
    | () => any

A function to be called when the Ui element is clicked. Only for buttons. This is an alias of config.value or config.property for buttons.

Return a function for undo, or (undo, redo) or (action, undo) for undo/redo support. action will be exec immediately and on undo

onExpand?: (c: UiObjectConfig) => void

Only for folders. The callback called when a folder is expanded or collapsed.

parentOnChange?: (...args: ChangeArgs) => void

Can be set by the parent, if this is a child object.

parentProperty?: ValOrFunc<undefined | [any, string | number]>

Can be set by the parent, if this is a child object.

path?: ValOrFunc<string>

Path of the binding inside the value. (dot separated json path) In case of property it is appended to the property path.

property?: ValOrFunc<[TTarget, number | Extract<keyof TTarget, string>]>

The property to bind to. This is used for inputs. This can be an array of [target, key] or a function that returns an array of [target, key]. key can be a number for arrays, or a dot separated path for json objects.

readOnly?: ValOrFunc<boolean>

The Ui input will be read-only if this is true, i.e. the user will not be able to change the value. This can be a boolean or a function that returns a boolean. This can also be achieved by setting specifying a getValue function, but not a setValue function. Or by setting disabled to true.

sendArgs?: ValOrFunc<boolean>

Specifies whether to send the click event etc to the onClick/value function. Only for buttons, and only if the value is a function. This can be a boolean or a function that returns a boolean. Default is false.

setValue?:
    | (value: T, ...args: ChangeArgs | never[]) => void
    | (value: T) => void

setValue function. This is used for inputs, if property, value is not specified. This is called when the value of the input changes. It is ignored if property or value is specified.

The value to set

other arguments like the config, renderer, etc. See source code for details.

stepSize?: ValOrFunc<number>

stepSize for specifying the min change in the value. This is used for numeric inputs like number and slider. The value will be rounded to the nearest multiple of stepSize. This can be a number or a function that returns a number.

tags?: ValOrArr<string>

tags can be added to the config object to be used for filtering, like rendering only objects with a certain tag. This can be a string or an array of strings.

type?: TType

The type of the object. This is used to determine the component to use. Examples: 'button', 'slider', 'dropdown', 'folder', 'input' etc

uiRef?: any

After initial rendering, config.uiRef will be set to the instance of the UI component that's created. The type of this will depend on the type of the component and the base UI library used. This can be used to access the UI component directly, for example to add event listeners. Note that the uiRef might change on render.

uiRefresh?: (
    deep?: boolean,
    mode?: TUiRefreshModes | "immediate",
    delay?: number,
) => void

After initial rendering, config.uiRefresh will be set to a function that can be used to re-render the UI.

Type declaration

    • (deep?: boolean, mode?: TUiRefreshModes | "immediate", delay?: number): void
    • Parameters

      • Optionaldeep: boolean

        If true, the UI will be re-rendered recursively, otherwise only the current object will be re-rendered.

      • Optionalmode: TUiRefreshModes | "immediate"

        The mode to re-render in. See TUiRefreshModes for details. Use when syncing with custom render loop

      • Optionaldelay: number

        The delay in ms to wait before re-rendering. This is useful if multiple changes are made in quick succession. If another refresh event is in the queue for the same object, it will be postponed by this amount. This is not exact for small values.

      Returns void

uiRefType?: string

The type of the UI component that's referenced by config.uiRef. This is set during rendering and used to re-render the UI if config.type changes.

uuid?: string

An optional uuid to identify this object. If not provided, one will be generated during first render. This must be provided if a new UiObjectConfig object is generated each time the config is rendered. This is similar to key in react.

value?: T

The value of the object. This is used for inputs, if property is not provided.