UNPKG

@form-create/element-ui

Version:

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

121 lines (97 loc) 3.24 kB
import {Button, Col, Popover, Row, Tooltip} from "element-ui"; import {FormData, VNodeRule} from "@form-create/core"; import {ElementUIComponentSize} from "element-ui/types/component"; import {ElForm, FormItemLabelPosition, ValidateCallback, ValidateFieldCallback} from "element-ui/types/form"; import {ElFormItem} from "element-ui/types/form-item"; import {Api} from "./index"; export interface OptionAttrs { col?: Boolean | Partial<Col & { labelWidth?: number | string; show?: Boolean; }>; row?: Boolean | Partial<Row & { show?: Boolean; }>; info?: Boolean | Partial<(Tooltip | Popover) & VNodeRule & { show?: Boolean; native?: Boolean; icon?: string; align?: 'left' | 'right'; info?: string; }>; wrap?: Boolean | Partial<VNodeRule & { labelWidth?: string required?: boolean error?: string showMessage?: boolean inlineMessage?: boolean size?: ElementUIComponentSize show?: Boolean; }>; form?: Partial<{ inline?: boolean disabled?: boolean labelPosition?: FormItemLabelPosition labelWidth?: string labelSuffix?: string showMessage?: boolean inlineMessage?: boolean statusIcon?: boolean validateOnRuleChange?: boolean size?: ElementUIComponentSize className?: any; col?: Boolean; }>; submitBtn?: Boolean | Partial<Button & { click?: Function; innerText?: string; show?: Boolean; }>; resetBtn?: Boolean | Partial<Button & { 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 | ElForm; wrapEl(id: string): undefined | ElFormItem; submit(success: (formData: FormData, api: Api) => void, fail: (api: Api) => void): void; clearValidateState(fields?: string | string[], clearSub?: Boolean): void; clearSubValidateState(fields?: string | string[]): void; validate(callback?: ValidateCallback): Promise<any>; validateField(field: string, callback?: ValidateFieldCallback): Promise<any>; submitBtnProps(props: Button): void; resetBtnProps(props: Button): void; }