UNPKG

@form-create/tdesign

Version:

TDesign版本低代码表单|FormCreate 是一个可以通过 JSON 生成具有动态渲染、数据收集、验证和提交功能的低代码表单生成组件。支持6个UI框架,适配移动端,并且支持生成任何 Vue 组件。内置20种常用表单组件和自定义组件,再复杂的表单都可以轻松搞定。

103 lines (79 loc) 2.73 kB
import {FormData, VNodeRule} from "@form-create/core"; import {ButtonProps, ColProps, RowProps, TooltipProps, PopupProps, FormItemProps, FormProps} from "tdesign-vue-next"; import {Api} from "./index"; import {ComponentInternalInstance} from "@vue/runtime-core"; export interface OptionAttrs { col?: Boolean | Partial<ColProps & { labelWidth?: number | string; show?: Boolean; }>; row?: Boolean | Partial<RowProps & { show?: Boolean; }>; info?: Boolean | Partial<VNodeRule & (TooltipProps | PopupProps) & { show?: Boolean; native?: Boolean; icon?: string; align?: 'left' | 'right'; info?: string; }>; wrap?: Boolean | Partial<VNodeRule & FormItemProps & { show?: Boolean; }>; form?: Partial<FormProps & { className?: any; col?: Boolean; }>; submitBtn?: Boolean | Partial<ButtonProps & { click?: Function; innerText?: string; show?: Boolean; }>; resetBtn?: Boolean | Partial<ButtonProps & { click?: Function; innerText?: string; show?: Boolean; }>; } declare const optionAttrs: Partial<OptionAttrs & { title?: Boolean | Partial<VNodeRule & { show?: Boolean; native?: Boolean; title: string; }>; }>; export interface CreatorAttrs { col(props: typeof optionAttrs.col): this; wrap(props: typeof optionAttrs.wrap): this; title(props: string | typeof optionAttrs.title): this; info(props: string | typeof optionAttrs.info): this; className(prop: string): this; } export interface RuleAttrs { col?: typeof optionAttrs.col; wrap?: typeof optionAttrs.wrap; title?: string | typeof optionAttrs.title; info?: string | typeof optionAttrs.info; className?: string; } export interface ApiAttrs { btn: { loading(loading: boolean): void; disabled(disabled: boolean): void; show(show: boolean): void; } resetBtn: { loading(loading: boolean): void; disabled(disabled: boolean): void; show(show: boolean): void; } formEl(): undefined | ComponentInternalInstance; wrapEl(id: string): undefined | ComponentInternalInstance; submit(success: (formData: FormData, $f: Api) => void, fail: ($f: Api) => void): Promise<any>; clearValidateState(fields?: string | string[], clearSub?: Boolean): void; clearSubValidateState(fields?: string | string[]): void; validate(callback?: (state: any) => void): Promise<any>; validateField(field: string, callback?: (state: any) => void): Promise<any>; submitBtnProps(props: ButtonProps): void; resetBtnProps(props: ButtonProps): void; }