UNPKG

@form-create/vant-designer

Version:

基于Vant的移动端低代码可视化表单设计器,可以通过拖拽的方式快速创建表单,提高开发者对表单的开发效率。

146 lines (134 loc) 5.4 kB
import FcDesignerMobile from './components/FcDesigner.vue'; import DragTool from './components/DragTool.vue'; import Struct from './components/Struct.vue'; import Row from './components/Row.vue'; import HtmlEditor from './components/HtmlEditor.vue'; import FnEditor from './components/FnEditor.vue'; import FnInput from './components/FnInput.vue'; import FetchConfig from './components/FetchConfig.vue'; import ConfigItem from './components/style/ConfigItem.vue'; import FieldInput from './components/FieldInput.vue'; import EventConfig from './components/EventConfig.vue'; import FnConfig from './components/FnConfig.vue'; import TableView from './components/table/TableView.vue'; import Table from './components/table/Table.vue'; import Validate from './components/Validate.vue'; import DragBox from './components/DragBox.vue'; import Required from './components/Required.vue'; import TableOptions from './components/TableOptions.vue'; import TreeOptions from './components/TreeOptions.vue'; import TableFormView from './components/tableForm/TableFormView.vue'; import TableForm from './components/tableForm/TableForm.vue'; import SignaturePad from './components/SignaturePad.vue'; import FcTitle from './components/FcTitle.vue'; import TableFormColumnView from './components/tableForm/TableFormColumnView.vue'; import SizeInput from './components/style/SizeInput.vue'; import ColorInput from './components/style/ColorInput.vue'; import StyleConfig from './components/style/StyleConfig.vue'; import LanguageInput from './components/language/LanguageInput.vue'; import ValueInput from './components/ValueInput.vue'; import FcEditor from '@form-create/component-wangeditor'; import draggable from 'vuedraggable/src/vuedraggable'; import { compareVersion, copyTextToClipboard, getInjectArg, localeOptions, localeProps, makeOptionsRule, makeRequiredRule, makeTreeOptions, makeTreeOptionsRule, toJSON } from './utils/index'; import formCreate, {designerForm, elmFormCreate} from './utils/form'; import globalUseLocale, {t} from './utils/locale'; import './style/index.css'; import './style/icon.css'; import './utils/highlight/style.css'; const addComponent = (id, component, previewComponent) => { designerForm.component(id, previewComponent || component); formCreate.component(id, component); } designerForm.component('DragTool', DragTool); designerForm.component('DragBox', DragBox); elmFormCreate.component('draggable', draggable); elmFormCreate.component('DragTool', DragTool); elmFormCreate.component('DragBox', DragBox); elmFormCreate.component('Validate', Validate); elmFormCreate.component('Struct', Struct); elmFormCreate.component('HtmlEditor', HtmlEditor); elmFormCreate.component('FetchConfig', FetchConfig); elmFormCreate.component('FnEditor', FnEditor); elmFormCreate.component('FnInput', FnInput); elmFormCreate.component('Required', Required); elmFormCreate.component('TableOptions', TableOptions); elmFormCreate.component('TreeOptions', TreeOptions); elmFormCreate.component('TableFormColumn', TableFormColumnView); elmFormCreate.component('EventConfig', EventConfig); elmFormCreate.component('ColorInput', ColorInput); elmFormCreate.component('SizeInput', SizeInput); elmFormCreate.component('StyleConfig', StyleConfig); elmFormCreate.component('LanguageInput', LanguageInput); elmFormCreate.component('ConfigItem', ConfigItem); elmFormCreate.component('FieldInput', FieldInput); elmFormCreate.component('FnConfig', FnConfig); designerForm.component('FcRow', Row); designerForm.component('ValueInput', ValueInput); addComponent('FcEditor', FcEditor); addComponent('FcTitle', FcTitle); addComponent('SignaturePad', SignaturePad); addComponent('TableForm', TableForm, TableFormView); addComponent('FcTable', Table, TableView); const install = function (Vue) { Vue.component('FcDesignerMobile', FcDesignerMobile); }; FcDesignerMobile.install = install; FcDesignerMobile.makeOptionsRule = makeOptionsRule; FcDesignerMobile.copyTextToClipboard = copyTextToClipboard; FcDesignerMobile.getInjectArg = getInjectArg; FcDesignerMobile.localeOptions = localeOptions; FcDesignerMobile.localeProps = localeProps; FcDesignerMobile.makeRequiredRule = makeRequiredRule; FcDesignerMobile.makeTreeOptions = makeTreeOptions; FcDesignerMobile.makeTreeOptionsRule = makeTreeOptionsRule; FcDesignerMobile.toJSON = toJSON; FcDesignerMobile.formCreate = formCreate; FcDesignerMobile.designerForm = designerForm; FcDesignerMobile.component = addComponent; FcDesignerMobile.useLocale = globalUseLocale; FcDesignerMobile.t = t; FcDesignerMobile.utils = { copyTextToClipboard, getInjectArg, localeOptions, localeProps, makeOptionsRule, makeRequiredRule, makeTreeOptions, makeTreeOptionsRule, toJSON } const minVersion = '3.2.24'; if (compareVersion(minVersion, formCreate.version) === 1) { console.warn('Please use FormCreate version ' + minVersion + ' or greater, see https://github.com/xaboy/form-create.'); } FcDesignerMobile.version = '3.1.11'; if (typeof window !== 'undefined') { window.FcDesignerMobile = FcDesignerMobile; } export default FcDesignerMobile; export { formCreate, designerForm, install, copyTextToClipboard, getInjectArg, localeOptions, localeProps, makeOptionsRule, makeRequiredRule, makeTreeOptions, makeTreeOptionsRule, toJSON };