Example
let dbMasterConfig: T.IDBMasterConfig = {
    form: {
        fields: [
            [{
                control: T.EDBMasterFormControl.customHTML,
                customHTMLSettings: {
                    htmlCode: `
                        <h1 style="margin: 0;">Hello world</h1>
                    `
                }
            }]
        ]
    }
};
Interface Documentation
export interface IDBMasterConfigFormField {
    /** It is used to find element. */
    hiddenId?: string;
    label?: string;
    /** This text will be displayed under control in small. HTML supported. */
    helpText?: string;
    /** database field name, UI control value will be saved on this property in save/update object. */
    path?: string;
    /** UI control type */
    control?: EDBMasterFormControl;
    /**
     * Default : col-lg mt-4 col-md-{ 12 / ((columns.length === 2 ? 4 : columns.length) / 2) } <br/>
     * It will be applied to parent div which holds UI control in it.
     * */
    cssClassDiv?: string;
    /** if true, that control will take focus automatically. */
    autofocus?: boolean;
    /** if true, control will be disabled. If string provides, it will evaluate that string and enable/disable based on that. */
    disabled?: boolean | string;
    /** if true or undefined, control will be visible. If string provides, it will evaluate that string and make it visible/invisible based on that. */
    visible?: boolean | string;
    /** Generates UI controls. */
    fields?: IDBMasterConfigFormField[][];
    validations?: Pick<IPropertyValidation, 'required'> & {
        /** If requiredFun is present, that code will be executed when form data is getting changed and it sets value in required.<br/>
         * Value of required will be ignored when requiredFun is present because system will evaluate "requiredFun" and it's output will be value of "required"
         * */
        requiredFun?: string;
    };
    validationErrors?: {
        required?: string;
    };
    customHTMLSettings?: {
        htmlCode: string;
    };
}
export interface IPropertyValidation {
    required?: boolean; // Allowed Types : *
    min?: number; // Allowed Types : number | date
    max?: number; // Allowed Types : number | date
    minLength?: number; // Allowed Types : string
    maxLength?: number; // Allowed Types : string
    unique?: boolean;
    email?: boolean; // Allowed Types : string
    validatorFun?: Function;
    /** If value is present it should be from this array. */
    enum?: any[];
}
export enum EDBMasterCustomHtmlAppendTo {
    visible = 'visible',
}
export enum EDBMasterFormControl {
    input = 'input',
    inputNumber = 'inputNumber',
    inputMask = 'inputMask',
    inputOtp = 'inputOtp',
    password = 'password',
    date_picker = 'date_picker',
    textarea = 'textarea',
    editor = 'editor',
    checkbox = 'checkbox',
    radio = 'radio',
    color_picker = 'color_picker',
    dropdown = 'dropdown',
    auto_complete = 'auto_complete',
    multi_select = 'multi_select',
    file_upload = 'file_upload',
    grid = 'grid',
    divider = 'divider',
    rating = 'rating',
    knob = 'knob',
    // Field holder controls
    accordion = 'accordion',
    tab_view = 'tab_view',
    // utility controls
    button = 'button',
    image = 'image',
    customHTML = 'customHTML',
}
export enum EDBMasterCustomActionButtonAppendTo {
    click = 'click',
}