UNPKG

@form-create/arco-design

Version:

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

115 lines (89 loc) 3.28 kB
import {FormData, VNodeRule} from "@form-create/core"; import {ButtonProps} from "@arco-design/web-vue/es/button"; import {TooltipInstance} from "@arco-design/web-vue/es/tooltip"; import {PopoverInstance} from "@arco-design/web-vue/es/popover"; import {FormItemInstance, FormInstance} from "@arco-design/web-vue/es/form"; import {Row, Col} from "@arco-design/web-vue/es/grid"; import {Api} from "./index"; import {ComponentInternalInstance} from "@vue/runtime-core"; declare type TooltipProps = TooltipInstance['$props']; declare type PopoverProps = PopoverInstance['$props']; declare type ColProps = (InstanceType<typeof Col>)['$props'] declare type RowProps = (InstanceType<typeof Row>)['$props'] declare type FormItemProps = FormItemInstance['$props'] declare type FormProps = FormInstance['$props'] export interface OptionAttrs { col?: Boolean | Partial<ColProps & { labelWidth?: number | string; show?: Boolean; }>; row?: Boolean | Partial<RowProps & { show?: Boolean; }>; info?: Boolean | Partial<(TooltipProps | PopoverProps) & VNodeRule & { 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; }