@xfu0401/form-generator 1.0.21 → 1.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/.eslintrc.js +0 -48
- package/@xfu0401/form-generator/package.json +0 -62
- package/LICENSE +0 -127
- package/README.md +0 -268
- package/babel.config.js +0 -22
- package/public/favicon.ico +0 -0
- package/public/img/show/PixPin_2024-07-17_16-25-59.gif +0 -0
- package/public/img/show/PixPin_2024-07-17_16-33-51.png +0 -0
- package/public/img/show/file.png +0 -0
- package/public/img/show/image.png +0 -0
- package/public/img/show/pc/347/253/257/346/270/262/346/237/223.png +0 -0
- package/public/img/show/pc/347/253/257/350/257/246/346/203/205.png +0 -0
- package/public/img/show//344/272/213/344/273/266.png +0 -0
- package/public/img/show//345/205/250/345/261/200/344/272/213/344/273/266.png +0 -0
- package/public/img/show//345/205/250/345/261/200/346/240/267/345/274/217.png +0 -0
- package/public/img/show//346/240/267/345/274/217/345/261/236/346/200/247.png +0 -0
- package/public/img/show//347/247/273/345/212/250/347/253/257/346/270/262/346/237/223.png +0 -0
- package/public/img/show//347/247/273/345/212/250/347/253/257/350/257/246/346/203/205.png +0 -0
- package/public/img/show//347/274/226/350/276/221/345/231/2502.png +0 -0
- package/public/img/show//347/274/226/350/276/221/345/231/2503.png +0 -0
- package/public/img/show//347/274/226/350/276/221/345/231/2504.png +0 -0
- package/public/img/temp//344/270/273/344/273/216/350/241/250/345/215/225.jpg +0 -0
- package/public/img/temp//345/210/206/347/273/204/350/241/250/345/215/225.jpg +0 -0
- package/public/img/temp//345/215/225/345/210/227/350/241/250/345/215/225.jpg +0 -0
- package/public/img/temp//345/233/272/345/256/232/350/241/250/346/240/274/350/241/250/345/215/225.jpg +0 -0
- package/public/img/temp//345/244/232/345/210/227/350/241/250/345/215/225.jpg +0 -0
- package/public/img/temp//346/240/207/347/255/276/351/241/265/350/241/250/345/215/225.jpg +0 -0
- package/public/index.html +0 -25
- package/public/static/js/config.js +0 -2
- package/src/App.vue +0 -18
- package/src/api/data.js +0 -52
- package/src/components/Layout/Layout.vue +0 -28
- package/src/components/Layout/LeftMenu.vue +0 -46
- package/src/components/SvgIcon/index.vue +0 -43
- package/src/components/code/Code.vue +0 -98
- package/src/components/common/FGDialog.vue +0 -100
- package/src/components/editor/CodeDialog.vue +0 -68
- package/src/components/editor/CodeEditor.vue +0 -191
- package/src/components/editor/CodeJson.vue +0 -130
- package/src/components/editor/CssEditor.vue +0 -84
- package/src/components/editor/EventEditor.vue +0 -84
- package/src/components/editor/JsonDialog.vue +0 -55
- package/src/components/editor/JsonEditor.vue +0 -58
- package/src/components/editor/components/EditorLeft.vue +0 -138
- package/src/components/fileComs/ExportExcel.vue +0 -49
- package/src/components/fileComs/ExportJson.vue +0 -52
- package/src/components/fileComs/ImportExcel.vue +0 -96
- package/src/components/fileComs/ImportJson.vue +0 -65
- package/src/components/formGenerator/components/formExport.vue +0 -52
- package/src/components/formGenerator/components/formGeneratorAttrField.vue +0 -1113
- package/src/components/formGenerator/components/formGeneratorAttrForm.vue +0 -98
- package/src/components/formGenerator/components/formGeneratorCom.vue +0 -108
- package/src/components/formGenerator/components/formGeneratorOutline.vue +0 -159
- package/src/components/formGenerator/components/formGeneratorTemp.vue +0 -77
- package/src/components/formGenerator/components/formImport.vue +0 -62
- package/src/components/formGenerator/components/formPreview.vue +0 -102
- package/src/components/formGenerator/configComponents/DataConfig.vue +0 -156
- package/src/components/formGenerator/configComponents/DataDialog.vue +0 -188
- package/src/components/formGenerator/configComponents/EventConfig.vue +0 -56
- package/src/components/formGenerator/configComponents/PageConfig.vue +0 -55
- package/src/components/formGenerator/configComponents/RegConfig.vue +0 -105
- package/src/components/formGenerator/configComponents/ShadowConfig.vue +0 -95
- package/src/components/formGenerator/configComponents/SpaceConfig.vue +0 -187
- package/src/components/formGenerator/configComponents/StyleConfig.vue +0 -258
- package/src/components/formGenerator/configComponents/TableConfig.vue +0 -75
- package/src/components/formGenerator/configComponents/TableHead.vue +0 -141
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formButton.vue +0 -25
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formDivider.vue +0 -49
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formHtml.vue +0 -37
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formLink.vue +0 -26
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formNotice.vue +0 -118
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formRemark.vue +0 -29
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formSwipe.vue +0 -39
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formTable.vue +0 -130
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formTableExport.vue +0 -311
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formTag.vue +0 -30
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formText.vue +0 -27
- package/src/components/formGenerator/formComponents/pcComponents/assistComs/formTree.vue +0 -47
- package/src/components/formGenerator/formComponents/pcComponents/components/emptyTips.vue +0 -24
- package/src/components/formGenerator/formComponents/pcComponents/components/esignDialog.vue +0 -86
- package/src/components/formGenerator/formComponents/pcComponents/components/filesShow.vue +0 -121
- package/src/components/formGenerator/formComponents/pcComponents/components/imageShow.vue +0 -148
- package/src/components/formGenerator/formComponents/pcComponents/components/nameShow.vue +0 -54
- package/src/components/formGenerator/formComponents/pcComponents/components/tableOptions.vue +0 -56
- package/src/components/formGenerator/formComponents/pcComponents/components/tableStyle.vue +0 -58
- package/src/components/formGenerator/formComponents/pcComponents/components/userPicker.vue +0 -440
- package/src/components/formGenerator/formComponents/pcComponents/inputComs/formAutocomplete.vue +0 -79
- package/src/components/formGenerator/formComponents/pcComponents/inputComs/formInput.vue +0 -56
- package/src/components/formGenerator/formComponents/pcComponents/inputComs/formInputNumber.vue +0 -51
- package/src/components/formGenerator/formComponents/pcComponents/inputComs/formRichText.vue +0 -138
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formCard.vue +0 -35
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formCollapse.vue +0 -79
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formRowContainer.vue +0 -337
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formSteps.vue +0 -90
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formSub.vue +0 -219
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formTableContainer.vue +0 -277
- package/src/components/formGenerator/formComponents/pcComponents/layoutComs/formTabsContainer.vue +0 -65
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formCascader.vue +0 -62
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formCheckboxGroup.vue +0 -70
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formColorPicker.vue +0 -39
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formDatePicker.vue +0 -43
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formDaterangePicker.vue +0 -40
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formImage.vue +0 -235
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formOrgPicker.vue +0 -131
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formRadioGroup.vue +0 -59
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formRate.vue +0 -50
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSelect.vue +0 -62
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSelectHis.vue +0 -66
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSelectProject.vue +0 -62
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSignature.vue +0 -98
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSlider.vue +0 -46
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formSwitch.vue +0 -37
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formTimePicker.vue +0 -41
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formTimerangePicker.vue +0 -40
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formUpload.vue +0 -253
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formUploadTemp.vue +0 -82
- package/src/components/formGenerator/formComponents/pcComponents/selectComs/formUserPicker.vue +0 -142
- package/src/components/formGenerator/formComponents/pcForm.vue +0 -155
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formButton.vue +0 -36
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formDivider.vue +0 -41
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formHtml.vue +0 -37
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formLink.vue +0 -49
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formNotice.vue +0 -43
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formRemark.vue +0 -39
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formSwipe.vue +0 -34
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formTable.vue +0 -132
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formTableExport.vue +0 -268
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formTag.vue +0 -147
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formText.vue +0 -27
- package/src/components/formGenerator/formComponents/phoneComponents/assistComs/formTree.vue +0 -21
- package/src/components/formGenerator/formComponents/phoneComponents/components/cascaderPicker.vue +0 -81
- package/src/components/formGenerator/formComponents/phoneComponents/components/datePicker.vue +0 -101
- package/src/components/formGenerator/formComponents/phoneComponents/components/esignDialog.vue +0 -156
- package/src/components/formGenerator/formComponents/phoneComponents/components/filesShow.vue +0 -128
- package/src/components/formGenerator/formComponents/phoneComponents/components/imageShow.vue +0 -123
- package/src/components/formGenerator/formComponents/phoneComponents/components/nameShow.vue +0 -84
- package/src/components/formGenerator/formComponents/phoneComponents/components/orgPicker.vue +0 -343
- package/src/components/formGenerator/formComponents/phoneComponents/components/tableShow.vue +0 -149
- package/src/components/formGenerator/formComponents/phoneComponents/components/textShow.vue +0 -25
- package/src/components/formGenerator/formComponents/phoneComponents/components/timePicker.vue +0 -90
- package/src/components/formGenerator/formComponents/phoneComponents/inputComs/formAutocomplete.vue +0 -163
- package/src/components/formGenerator/formComponents/phoneComponents/inputComs/formInput.vue +0 -111
- package/src/components/formGenerator/formComponents/phoneComponents/inputComs/formInputNumber.vue +0 -65
- package/src/components/formGenerator/formComponents/phoneComponents/inputComs/formRichText.vue +0 -147
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formCard.vue +0 -59
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formCollapse.vue +0 -71
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formRowContainer.vue +0 -94
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formSteps.vue +0 -112
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formSub.vue +0 -130
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formTableContainer.vue +0 -93
- package/src/components/formGenerator/formComponents/phoneComponents/layoutComs/formTabsContainer.vue +0 -64
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formCascader.vue +0 -210
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formCheckboxGroup.vue +0 -86
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formColorPicker.vue +0 -63
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formDatePicker.vue +0 -100
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formDateRangePicker.vue +0 -136
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formImage.vue +0 -278
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formOrgPicker.vue +0 -107
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formRadioGroup.vue +0 -93
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formRate.vue +0 -85
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSelect.vue +0 -138
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSelectHis.vue +0 -142
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSelectProject.vue +0 -138
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSignature.vue +0 -108
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSlider.vue +0 -79
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formSwitch.vue +0 -88
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formTimePicker.vue +0 -112
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formTimeRangePicker.vue +0 -155
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formUpload.vue +0 -310
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formUploadTemp.vue +0 -81
- package/src/components/formGenerator/formComponents/phoneComponents/selectComs/formUserPicker.vue +0 -114
- package/src/components/formGenerator/formComponents/phoneForm.vue +0 -134
- package/src/components/formGenerator/formGenerator.vue +0 -401
- package/src/components/formGenerator/styles/generator.scss +0 -271
- package/src/components/formGenerator/styles/index.scss +0 -136
- package/src/components/formGenerator/styles/left-coms.scss +0 -57
- package/src/components/formGenerator/styles/phone.scss +0 -269
- package/src/components/formGenerator/styles/theme.scss +0 -5
- package/src/components/formGenerator/utils/attribute.js +0 -107
- package/src/components/formGenerator/utils/comMixins.js +0 -148
- package/src/components/formGenerator/utils/component.js +0 -26
- package/src/components/formGenerator/utils/config.js +0 -1730
- package/src/components/formGenerator/utils/event.js +0 -82
- package/src/components/formGenerator/utils/formEvent.js +0 -43
- package/src/components/formGenerator/utils/index.js +0 -666
- package/src/components/formGenerator/utils/rules.js +0 -17
- package/src/components/formGenerator/utils/style.js +0 -75
- package/src/components/formGenerator/utils/table.js +0 -317
- package/src/components/formGenerator/utils/temps.js +0 -15303
- package/src/components/huComponents/FGBreadNav.vue +0 -86
- package/src/components/huComponents/FGCheckCell.vue +0 -107
- package/src/components/huComponents/FGCheckList.vue +0 -318
- package/src/components/huComponents/FGCheckPopUp.vue +0 -164
- package/src/components/huComponents/FGIconsDialog.vue +0 -124
- package/src/components/huComponents/FGNameImg.vue +0 -147
- package/src/components/huComponents/FGOptions.vue +0 -118
- package/src/components/huComponents/FGSelect.vue +0 -46
- package/src/components/huComponents/FGTreeNode.vue +0 -103
- package/src/components/huComponents/FGTreeNodeDialog.vue +0 -89
- package/src/components/huComponents/InputColor.vue +0 -117
- package/src/components/huComponents/InputNumber.vue +0 -78
- package/src/components/huComponents/LayoutTree.vue +0 -67
- package/src/components/huComponents/MenuButton.vue +0 -57
- package/src/components/index.js +0 -14
- package/src/icons/index.js +0 -10
- package/src/icons/svg/active.svg +0 -1
- package/src/icons/svg/addSold.svg +0 -1
- package/src/icons/svg/analyse.svg +0 -1
- package/src/icons/svg/button.svg +0 -1
- package/src/icons/svg/card.svg +0 -1
- package/src/icons/svg/cascader.svg +0 -1
- package/src/icons/svg/checkbox.svg +0 -1
- package/src/icons/svg/collapse.svg +0 -1
- package/src/icons/svg/color.svg +0 -1
- package/src/icons/svg/component.svg +0 -1
- package/src/icons/svg/date-range.svg +0 -1
- package/src/icons/svg/date.svg +0 -1
- package/src/icons/svg/default-dept.svg +0 -9
- package/src/icons/svg/default-role.svg +0 -5
- package/src/icons/svg/default-user.svg +0 -16
- package/src/icons/svg/dept.svg +0 -1
- package/src/icons/svg/divider.svg +0 -1
- package/src/icons/svg/ellipsis.svg +0 -2
- package/src/icons/svg/html.svg +0 -1
- package/src/icons/svg/image.svg +0 -1
- package/src/icons/svg/input.svg +0 -1
- package/src/icons/svg/link.svg +0 -1
- package/src/icons/svg/mp4.svg +0 -19
- package/src/icons/svg/notice.svg +0 -1
- package/src/icons/svg/noview.svg +0 -1
- package/src/icons/svg/number.svg +0 -1
- package/src/icons/svg/password.svg +0 -1
- package/src/icons/svg/pdf.svg +0 -18
- package/src/icons/svg/person.svg +0 -1
- package/src/icons/svg/png.svg +0 -18
- package/src/icons/svg/ppt.svg +0 -19
- package/src/icons/svg/process.svg +0 -1
- package/src/icons/svg/radio.svg +0 -1
- package/src/icons/svg/rate.svg +0 -1
- package/src/icons/svg/remark.svg +0 -1
- package/src/icons/svg/rich-text.svg +0 -1
- package/src/icons/svg/row.svg +0 -1
- package/src/icons/svg/select.svg +0 -1
- package/src/icons/svg/signature.svg +0 -1
- package/src/icons/svg/slider.svg +0 -1
- package/src/icons/svg/steps.svg +0 -1
- package/src/icons/svg/sub.svg +0 -1
- package/src/icons/svg/swipe.svg +0 -1
- package/src/icons/svg/switch.svg +0 -1
- package/src/icons/svg/table-edit.svg +0 -1
- package/src/icons/svg/table.svg +0 -1
- package/src/icons/svg/table2.svg +0 -1
- package/src/icons/svg/table3.svg +0 -1
- package/src/icons/svg/tabs.svg +0 -1
- package/src/icons/svg/tag.svg +0 -1
- package/src/icons/svg/text.svg +0 -1
- package/src/icons/svg/textarea.svg +0 -1
- package/src/icons/svg/time-range.svg +0 -1
- package/src/icons/svg/time.svg +0 -1
- package/src/icons/svg/tree.svg +0 -1
- package/src/icons/svg/unknow.svg +0 -20
- package/src/icons/svg/upload.svg +0 -1
- package/src/icons/svg/view.svg +0 -1
- package/src/icons/svg/word.svg +0 -20
- package/src/icons/svg/xlsx.svg +0 -18
- package/src/icons/svg/zip.svg +0 -20
- package/src/images/phone_bg.png +0 -0
- package/src/main.js +0 -26
- package/src/package/FGDesigner.vue +0 -114
- package/src/package/FGPcForm.vue +0 -100
- package/src/package/FGPcShow.vue +0 -69
- package/src/package/FGPhoneForm.vue +0 -106
- package/src/package/FGPhoneShow.vue +0 -69
- package/src/package/common/init.js +0 -23
- package/src/package/common/initPc.js +0 -26
- package/src/package/common/initPhone.js +0 -28
- package/src/package/common/mixins.js +0 -57
- package/src/package/index.js +0 -40
- package/src/plugins/richEditor/richEditorPc.vue +0 -478
- package/src/plugins/richEditor/richEditorPhone.vue +0 -520
- package/src/plugins/voiceTxtarea/voiceTxtarea.vue +0 -115
- package/src/router.js +0 -111
- package/src/store/index.js +0 -14
- package/src/store/modules/app.js +0 -54
- package/src/store/modules/user.js +0 -23
- package/src/style/color.scss +0 -10
- package/src/style/main.scss +0 -78
- package/src/utils/comsData.js +0 -279
- package/src/utils/defaultValue.js +0 -2288
- package/src/utils/drawingDefalut.js +0 -2749
- package/src/utils/iconData.js +0 -283
- package/src/utils/index.js +0 -6
- package/src/utils/progress.js +0 -96
- package/src/utils/request.js +0 -41
- package/src/views/coms/components/Attributes.vue +0 -28
- package/src/views/coms/components/ELink.vue +0 -23
- package/src/views/coms/components/Events.vue +0 -20
- package/src/views/coms/components/Example.vue +0 -42
- package/src/views/coms/components/Methods.vue +0 -20
- package/src/views/coms/components/VLink.vue +0 -23
- package/src/views/coms/comsDesiger.vue +0 -224
- package/src/views/coms/comsFormPc.vue +0 -76
- package/src/views/coms/comsFormPhone.vue +0 -103
- package/src/views/coms/comsShowPc.vue +0 -56
- package/src/views/coms/comsShowPhone.vue +0 -89
- package/src/views/config/components/configCell.vue +0 -111
- package/src/views/config/config.vue +0 -84
- package/src/views/demo/demo.vue +0 -235
- package/src/views/demo/demo2.vue +0 -131
- package/src/views/demo/table.js +0 -321
- package/src/views/document/index.vue +0 -140
- package/src/views/form/create.vue +0 -44
- package/vue.config.js +0 -72
- /package/{@xfu0401/form-generator/demo.html → demo.html} +0 -0
- /package/{@xfu0401/form-generator/form-generator.common.js → form-generator.common.js} +0 -0
- /package/{@xfu0401/form-generator/form-generator.common.js.map → form-generator.common.js.map} +0 -0
- /package/{@xfu0401/form-generator/form-generator.css → form-generator.css} +0 -0
- /package/{@xfu0401/form-generator/form-generator.umd.js → form-generator.umd.js} +0 -0
- /package/{@xfu0401/form-generator/form-generator.umd.js.map → form-generator.umd.js.map} +0 -0
- /package/{@xfu0401/form-generator/form-generator.umd.min.js → form-generator.umd.min.js} +0 -0
- /package/{@xfu0401/form-generator/form-generator.umd.min.js.map → form-generator.umd.min.js.map} +0 -0
- /package/{@xfu0401/form-generator/static → static}/fonts/element-icons.535877f5.woff +0 -0
- /package/{@xfu0401/form-generator/static → static}/fonts/element-icons.732389de.ttf +0 -0
- /package/{@xfu0401/form-generator/static → static}/img/phone_bg.7ead1463.png +0 -0
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<!-- 表单属性 -->
|
|
3
|
-
<el-form size="small" label-width="90px">
|
|
4
|
-
<el-form-item label="表单标识符">
|
|
5
|
-
<el-input v-model="formData.formCode" placeholder="请输入表单标识符" />
|
|
6
|
-
</el-form-item>
|
|
7
|
-
<!-- <el-form-item label="表单名">
|
|
8
|
-
<el-input v-model="formData.formRef" placeholder="请输入表单名(ref)" />
|
|
9
|
-
</el-form-item>-->
|
|
10
|
-
<el-form-item label="表单模型">
|
|
11
|
-
<el-input v-model="formData.formModel" placeholder="请输入数据模型" />
|
|
12
|
-
</el-form-item>
|
|
13
|
-
<el-form-item label="校验模型">
|
|
14
|
-
<el-input v-model="formData.formRules" placeholder="请输入校验模型" />
|
|
15
|
-
</el-form-item>
|
|
16
|
-
<el-form-item label="表单尺寸">
|
|
17
|
-
<el-radio-group v-model="formData.size">
|
|
18
|
-
<el-radio-button label="medium">中等</el-radio-button>
|
|
19
|
-
<el-radio-button label="small">较小</el-radio-button>
|
|
20
|
-
<el-radio-button label="mini">迷你</el-radio-button>
|
|
21
|
-
</el-radio-group>
|
|
22
|
-
</el-form-item>
|
|
23
|
-
<el-form-item label="标签对齐">
|
|
24
|
-
<el-radio-group v-model="formData.labelPosition">
|
|
25
|
-
<el-radio-button label="left">左对齐</el-radio-button>
|
|
26
|
-
<el-radio-button label="right">右对齐</el-radio-button>
|
|
27
|
-
<el-radio-button label="top">顶部对齐</el-radio-button>
|
|
28
|
-
</el-radio-group>
|
|
29
|
-
</el-form-item>
|
|
30
|
-
|
|
31
|
-
<el-form-item label="禁用表单">
|
|
32
|
-
<el-switch v-model="formData.disabled" />
|
|
33
|
-
</el-form-item>
|
|
34
|
-
<!-- <el-form-item label="表单按钮">
|
|
35
|
-
<el-switch v-model="formData.formBtns" />
|
|
36
|
-
</el-form-item>-->
|
|
37
|
-
<el-form-item label="显示未选中组件边框">
|
|
38
|
-
<el-switch v-model="formData.unFocusedComponentBorder" />
|
|
39
|
-
</el-form-item>
|
|
40
|
-
<el-form-item label="表单全局CSS" v-if="formData.cssList">
|
|
41
|
-
<el-button type="primary" @click="$refs.CssEditor.open(formData.cssList)">编写代码</el-button>
|
|
42
|
-
<CssEditor ref="CssEditor" v-model="formData.cssList" />
|
|
43
|
-
</el-form-item>
|
|
44
|
-
<el-form-item label="表单全局事件" v-if="formData.eventList">
|
|
45
|
-
<el-button type="primary" @click="$refs.EventEditor.open(formData.eventList)">编写代码</el-button>
|
|
46
|
-
<EventEditor ref="EventEditor" v-model="formData.eventList" />
|
|
47
|
-
</el-form-item>
|
|
48
|
-
</el-form>
|
|
49
|
-
</template>
|
|
50
|
-
|
|
51
|
-
<script>
|
|
52
|
-
import CssEditor from "@/components/editor/CssEditor.vue";
|
|
53
|
-
import EventEditor from "@/components/editor/EventEditor.vue";
|
|
54
|
-
import store from "@/store";
|
|
55
|
-
|
|
56
|
-
export default {
|
|
57
|
-
components: {
|
|
58
|
-
CssEditor,
|
|
59
|
-
EventEditor,
|
|
60
|
-
},
|
|
61
|
-
props: {
|
|
62
|
-
// 表单属性
|
|
63
|
-
formConf: {
|
|
64
|
-
type: Object,
|
|
65
|
-
default: () => {},
|
|
66
|
-
},
|
|
67
|
-
},
|
|
68
|
-
mounted() {
|
|
69
|
-
store.commit("SET_CSSLIST", this.formConf.cssList);
|
|
70
|
-
store.commit("SET_EVENTLIST", this.formConf.eventList);
|
|
71
|
-
},
|
|
72
|
-
computed: {
|
|
73
|
-
// 当前选中的表单组件
|
|
74
|
-
formData: {
|
|
75
|
-
get() {
|
|
76
|
-
let that = this;
|
|
77
|
-
return new Proxy(that.formConf, {
|
|
78
|
-
get(obj, key) {
|
|
79
|
-
return key in obj ? obj[key] : undefined;
|
|
80
|
-
},
|
|
81
|
-
set(obj, key, val) {
|
|
82
|
-
that.$emit("update:formConf", {
|
|
83
|
-
...obj,
|
|
84
|
-
[key]: val,
|
|
85
|
-
});
|
|
86
|
-
return true;
|
|
87
|
-
},
|
|
88
|
-
});
|
|
89
|
-
},
|
|
90
|
-
set(val) {
|
|
91
|
-
this.$emit("update:formConf", val);
|
|
92
|
-
},
|
|
93
|
-
},
|
|
94
|
-
},
|
|
95
|
-
};
|
|
96
|
-
</script>
|
|
97
|
-
|
|
98
|
-
<style lang="scss" scoped></style>
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<!-- 左侧组件 -->
|
|
3
|
-
<el-collapse v-model="activeNames" class="Fg-coms-list">
|
|
4
|
-
<template v-for="(item, index) in leftComponents">
|
|
5
|
-
<el-collapse-item
|
|
6
|
-
v-if="item && item.list?.length"
|
|
7
|
-
:title="item.title"
|
|
8
|
-
:key="index"
|
|
9
|
-
:name="index"
|
|
10
|
-
>
|
|
11
|
-
<template slot="title">
|
|
12
|
-
<div class="Fg-coms-title">
|
|
13
|
-
<svg-icon icon-class="component" />
|
|
14
|
-
{{ item.title }}
|
|
15
|
-
</div>
|
|
16
|
-
</template>
|
|
17
|
-
<draggable
|
|
18
|
-
:list="item.list"
|
|
19
|
-
:group="{ name: 'componentsGroup', pull: 'clone', put: false }"
|
|
20
|
-
:clone="cloneComponent"
|
|
21
|
-
draggable=".Fg-coms-item"
|
|
22
|
-
:sort="false"
|
|
23
|
-
@end="onEnd"
|
|
24
|
-
>
|
|
25
|
-
<div
|
|
26
|
-
v-for="(element, index) in item.list"
|
|
27
|
-
:key="index"
|
|
28
|
-
class="Fg-coms-item"
|
|
29
|
-
@click="addComponent(element)"
|
|
30
|
-
>
|
|
31
|
-
<div class="Fg-coms-body">
|
|
32
|
-
<svg-icon :icon-class="element.__config__.tagIcon" />
|
|
33
|
-
{{ element.__config__.label }}
|
|
34
|
-
</div>
|
|
35
|
-
</div>
|
|
36
|
-
</draggable>
|
|
37
|
-
</el-collapse-item>
|
|
38
|
-
</template>
|
|
39
|
-
</el-collapse>
|
|
40
|
-
</template>
|
|
41
|
-
|
|
42
|
-
<script>
|
|
43
|
-
import draggable from "vuedraggable";
|
|
44
|
-
import {
|
|
45
|
-
inputComponents,
|
|
46
|
-
selectComponents,
|
|
47
|
-
layoutComponents,
|
|
48
|
-
assistComponents,
|
|
49
|
-
} from "../utils/config";
|
|
50
|
-
import { createFormItem, deepClone } from "../utils/index";
|
|
51
|
-
export default {
|
|
52
|
-
components: {
|
|
53
|
-
draggable,
|
|
54
|
-
},
|
|
55
|
-
props: {
|
|
56
|
-
// 表单属性
|
|
57
|
-
formConf: {
|
|
58
|
-
type: Object,
|
|
59
|
-
default: () => {},
|
|
60
|
-
},
|
|
61
|
-
},
|
|
62
|
-
data() {
|
|
63
|
-
return {
|
|
64
|
-
activeNames: [0, 1, 2, 3],
|
|
65
|
-
leftComponents: [
|
|
66
|
-
{ title: "输入型组件", list: inputComponents },
|
|
67
|
-
{ title: "选择型组件", list: selectComponents },
|
|
68
|
-
{ title: "布局型组件", list: layoutComponents },
|
|
69
|
-
{ title: "辅助型组件", list: assistComponents },
|
|
70
|
-
],
|
|
71
|
-
tempActiveData: {}, // 当前进行拖拽的组件
|
|
72
|
-
};
|
|
73
|
-
},
|
|
74
|
-
methods: {
|
|
75
|
-
// 拖拽完成
|
|
76
|
-
onEnd(obj) {
|
|
77
|
-
// from 拖拽开始组件,to 拖拽结束组件
|
|
78
|
-
if (obj.from !== obj.to) {
|
|
79
|
-
// 判断是否为动态数据,即 dataType === "dynamic",选择动态数据需要进行处理
|
|
80
|
-
// this.fetchData(this.tempActiveData);
|
|
81
|
-
this.$emit("drag", this.tempActiveData);
|
|
82
|
-
}
|
|
83
|
-
},
|
|
84
|
-
addComponent(item) {
|
|
85
|
-
const clone = this.cloneComponent(item);
|
|
86
|
-
// this.fetchData(clone);
|
|
87
|
-
// this.drawingList.push(clone);
|
|
88
|
-
// 直接通过点击控件添加表单项,点击控件需要手动添加
|
|
89
|
-
this.$emit("add", clone);
|
|
90
|
-
},
|
|
91
|
-
// 对控件进行拖拽,拖拽会自动添加控件,无须手动添加
|
|
92
|
-
cloneComponent(origin) {
|
|
93
|
-
const clone = deepClone(origin); // 对选中的控件进行深度克隆
|
|
94
|
-
const config = clone.__config__;
|
|
95
|
-
config.span = this.formConf.span || config.span; // 生成代码时,会根据span做精简判断
|
|
96
|
-
// 给需要添加的控件添加自定义属性,即补充完整属性
|
|
97
|
-
createFormItem(clone);
|
|
98
|
-
clone.placeholder !== undefined && clone.placeholder;
|
|
99
|
-
this.tempActiveData = clone; // 当前进行拖拽的组件
|
|
100
|
-
return clone;
|
|
101
|
-
},
|
|
102
|
-
},
|
|
103
|
-
};
|
|
104
|
-
</script>
|
|
105
|
-
|
|
106
|
-
<style lang="scss">
|
|
107
|
-
@import "../styles/left-coms.scss";
|
|
108
|
-
</style>
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<!-- 左侧组件 -->
|
|
3
|
-
<div class="Fg-outline" :key="JSON.stringify(list)">
|
|
4
|
-
<el-tree
|
|
5
|
-
:data="layoutTree"
|
|
6
|
-
draggable
|
|
7
|
-
default-expand-all
|
|
8
|
-
:allow-drop="allowDrop"
|
|
9
|
-
:allow-drag="allowDrag"
|
|
10
|
-
@node-click="handleActive"
|
|
11
|
-
>
|
|
12
|
-
<div slot-scope="{ node, data }" class="Fg-outline--item">
|
|
13
|
-
<div :class="activeId==data?.__config__?.formId?'Fg-Blue':''">
|
|
14
|
-
<svg-icon
|
|
15
|
-
v-if="data.__config__"
|
|
16
|
-
style="margin-right:8px"
|
|
17
|
-
:icon-class="data.__config__.tagIcon"
|
|
18
|
-
/>
|
|
19
|
-
<span>{{ data.__config__?.label ||data.__config__?.componentName ||data.label || data.id}}</span>
|
|
20
|
-
</div>
|
|
21
|
-
<div>
|
|
22
|
-
<i v-if="data.isLock" class="el-icon-lock" />
|
|
23
|
-
<!-- <div class="Fg-cursor" style="margin-right:8px" @click.stop="handleLock(data)">
|
|
24
|
-
<i :class="data.isLock?'el-icon-lock':'el-icon-unlock'" />
|
|
25
|
-
</div>-->
|
|
26
|
-
<!-- <div class="Fg-cursor" style="margin-right:8px" @click.stop="handleHide(data)">
|
|
27
|
-
<svg-icon :icon-class="data.isHide?'noview':'view'" />
|
|
28
|
-
</div>
|
|
29
|
-
<el-dropdown
|
|
30
|
-
placement="bottom-start"
|
|
31
|
-
trigger="click"
|
|
32
|
-
@command="handleSelect($event,data)"
|
|
33
|
-
>
|
|
34
|
-
<div class="Fg-cursor">
|
|
35
|
-
<svg-icon icon-class="ellipsis" />
|
|
36
|
-
</div>
|
|
37
|
-
<el-dropdown-menu slot="dropdown" class="Fg-dropdown-menu">
|
|
38
|
-
<el-dropdown-item command="Copy">复制</el-dropdown-item>
|
|
39
|
-
<el-dropdown-item command="Delete">删除</el-dropdown-item>
|
|
40
|
-
</el-dropdown-menu>
|
|
41
|
-
</el-dropdown>-->
|
|
42
|
-
</div>
|
|
43
|
-
</div>
|
|
44
|
-
</el-tree>
|
|
45
|
-
</div>
|
|
46
|
-
</template>
|
|
47
|
-
|
|
48
|
-
<script>
|
|
49
|
-
import { traverseTree, deepClone, cleanTree } from "../utils/index";
|
|
50
|
-
import store from "@/store";
|
|
51
|
-
import { MessageBox } from "element-ui";
|
|
52
|
-
export default {
|
|
53
|
-
components: {},
|
|
54
|
-
props: {
|
|
55
|
-
// 表单列表
|
|
56
|
-
list: {
|
|
57
|
-
type: Array,
|
|
58
|
-
default: () => [],
|
|
59
|
-
},
|
|
60
|
-
},
|
|
61
|
-
data() {
|
|
62
|
-
return {};
|
|
63
|
-
},
|
|
64
|
-
computed: {
|
|
65
|
-
layoutTree() {
|
|
66
|
-
let list = [];
|
|
67
|
-
this.list.forEach((item) => {
|
|
68
|
-
const tree = cleanTree([deepClone(item)]);
|
|
69
|
-
traverseTree(tree, (node) => {
|
|
70
|
-
node.children = node?.children;
|
|
71
|
-
});
|
|
72
|
-
list = list.concat(tree);
|
|
73
|
-
});
|
|
74
|
-
return list;
|
|
75
|
-
},
|
|
76
|
-
activeId() {
|
|
77
|
-
return store.state.app.activeId;
|
|
78
|
-
},
|
|
79
|
-
},
|
|
80
|
-
methods: {
|
|
81
|
-
handleSelect(command, item) {
|
|
82
|
-
this[`handle${command}`](item);
|
|
83
|
-
},
|
|
84
|
-
|
|
85
|
-
// 锁定
|
|
86
|
-
handleLock(item) {
|
|
87
|
-
// const message = item.isLock
|
|
88
|
-
// ? "解锁后改组件可以修改任何配置"
|
|
89
|
-
// : "锁定后该组件将无法再修改任何配置";
|
|
90
|
-
// MessageBox.confirm(
|
|
91
|
-
// message,
|
|
92
|
-
// `确定要${item.isLock ? "解锁" : "锁定"}该组件吗?`,
|
|
93
|
-
// {
|
|
94
|
-
// type: "warning",
|
|
95
|
-
// }
|
|
96
|
-
// ).then(() => {
|
|
97
|
-
// item.isLock = !item.isLock;
|
|
98
|
-
// });
|
|
99
|
-
},
|
|
100
|
-
|
|
101
|
-
// 复制
|
|
102
|
-
handleCopy(item) {
|
|
103
|
-
// const clone = createFormItem(item);
|
|
104
|
-
// this.list.push(clone);
|
|
105
|
-
// this.$emit('update:list',)
|
|
106
|
-
},
|
|
107
|
-
// 删除
|
|
108
|
-
handleDelete(item) {
|
|
109
|
-
// this.drawingList.splice(index, 1);
|
|
110
|
-
// if (this.drawingList.length) {
|
|
111
|
-
// this.activeFormItem(this.drawingList[0]);
|
|
112
|
-
// } else {
|
|
113
|
-
// this.activeFormItem({});
|
|
114
|
-
// }
|
|
115
|
-
},
|
|
116
|
-
// 是否隐藏
|
|
117
|
-
handleHide(item) {
|
|
118
|
-
// item.isHide = !item.isHide;
|
|
119
|
-
},
|
|
120
|
-
// 选中
|
|
121
|
-
handleActive(item) {
|
|
122
|
-
if (item.__config__) store.commit("SET_ACTIVEDATA", item);
|
|
123
|
-
},
|
|
124
|
-
allowDrop(draggingNode, dropNode, type) {
|
|
125
|
-
return false; // 暂时改为全部不可拖拽
|
|
126
|
-
if (dropNode.data.allowDrop && type == "inner") return true;
|
|
127
|
-
if (dropNode.data.__config__ && type !== "inner") return true;
|
|
128
|
-
return false;
|
|
129
|
-
},
|
|
130
|
-
allowDrag(draggingNode) {
|
|
131
|
-
return false; // 暂时改为全部不可拖拽
|
|
132
|
-
return draggingNode.data.__config__ ? true : false;
|
|
133
|
-
},
|
|
134
|
-
},
|
|
135
|
-
};
|
|
136
|
-
</script>
|
|
137
|
-
|
|
138
|
-
<style lang="scss">
|
|
139
|
-
@import "../styles/generator.scss";
|
|
140
|
-
.Fg-outline {
|
|
141
|
-
.el-tree-node__content {
|
|
142
|
-
height: 36px;
|
|
143
|
-
}
|
|
144
|
-
.Fg-outline--item {
|
|
145
|
-
display: flex;
|
|
146
|
-
align-items: center;
|
|
147
|
-
justify-content: space-between;
|
|
148
|
-
width: 100%;
|
|
149
|
-
padding-right: 24px;
|
|
150
|
-
.svg-icon {
|
|
151
|
-
font-size: 20px;
|
|
152
|
-
}
|
|
153
|
-
> div {
|
|
154
|
-
display: flex;
|
|
155
|
-
align-items: center;
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
</style>
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<!-- 模板 -->
|
|
3
|
-
<div class="Fg-temps">
|
|
4
|
-
<template v-for="(item,i) in temps">
|
|
5
|
-
<div :key="i" class="Fg-temps-item">
|
|
6
|
-
<!-- 模板图片预览 -->
|
|
7
|
-
<!-- <el-popover placement="right" width="600" trigger="hover">
|
|
8
|
-
<el-image :src="item.image" slot="reference"></el-image>
|
|
9
|
-
<el-image :src="item.image" style='margin-bottom: 8px;'></el-image>
|
|
10
|
-
</el-popover>-->
|
|
11
|
-
<div class="Fg-temps-item--footer">
|
|
12
|
-
<span>#{{i+1}} {{item.name}}</span>
|
|
13
|
-
<span @click="handleLoad(item)">加载此模板</span>
|
|
14
|
-
</div>
|
|
15
|
-
</div>
|
|
16
|
-
</template>
|
|
17
|
-
</div>
|
|
18
|
-
</template>
|
|
19
|
-
|
|
20
|
-
<script>
|
|
21
|
-
import { MessageBox } from "element-ui";
|
|
22
|
-
// 模板数据
|
|
23
|
-
import temps from "../utils/temps";
|
|
24
|
-
import { createFormItem, deepClone } from "../utils";
|
|
25
|
-
export default {
|
|
26
|
-
data() {
|
|
27
|
-
return {
|
|
28
|
-
temps,
|
|
29
|
-
};
|
|
30
|
-
},
|
|
31
|
-
methods: {
|
|
32
|
-
// 加载此模板
|
|
33
|
-
handleLoad(item) {
|
|
34
|
-
MessageBox.confirm("是否加载这个模板?加载后会覆盖设计器当前表单。", {
|
|
35
|
-
type: "warning",
|
|
36
|
-
title: "提示",
|
|
37
|
-
}).then(() => {
|
|
38
|
-
const temps = [];
|
|
39
|
-
item.form.forEach((formItem) => {
|
|
40
|
-
temps.push(createFormItem(deepClone(formItem)));
|
|
41
|
-
});
|
|
42
|
-
this.$emit("change", temps);
|
|
43
|
-
});
|
|
44
|
-
},
|
|
45
|
-
},
|
|
46
|
-
};
|
|
47
|
-
</script>
|
|
48
|
-
|
|
49
|
-
<style lang="scss" scoped>
|
|
50
|
-
@import "../styles/generator.scss";
|
|
51
|
-
.Fg-temps {
|
|
52
|
-
padding: 8px;
|
|
53
|
-
font-size: 14px;
|
|
54
|
-
.Fg-temps-item {
|
|
55
|
-
margin-bottom: 8px;
|
|
56
|
-
border: 1px solid $borderColor;
|
|
57
|
-
border-radius: 4px;
|
|
58
|
-
padding: 12px 16px;
|
|
59
|
-
.el-image {
|
|
60
|
-
width: 100%;
|
|
61
|
-
}
|
|
62
|
-
.Fg-temps-item--footer {
|
|
63
|
-
display: flex;
|
|
64
|
-
justify-content: space-between;
|
|
65
|
-
align-items: center;
|
|
66
|
-
|
|
67
|
-
span:first-child {
|
|
68
|
-
font-weight: 700;
|
|
69
|
-
}
|
|
70
|
-
span:last-child {
|
|
71
|
-
color: $themeColor;
|
|
72
|
-
cursor: pointer;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
</style>
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div>
|
|
3
|
-
<el-button type="text" size="mini" @click="handleOpen">
|
|
4
|
-
<el-tooltip content="点击此处导入JSON数据生成表单" placement="top">
|
|
5
|
-
<i class="el-icon-download" style="font-size:14px"></i>
|
|
6
|
-
</el-tooltip>
|
|
7
|
-
</el-button>
|
|
8
|
-
<JsonDialog title="导入JSON" ref="JsonDialog" :value="defaultValue">
|
|
9
|
-
<template slot="footer">
|
|
10
|
-
<el-button size="small" @click="$refs.JsonDialog.close()">取消</el-button>
|
|
11
|
-
<ImportJson btnText="导入文件" style="margin:0 10px" @confirm="handleImport" />
|
|
12
|
-
<el-button type="primary" size="small" @click="onConfirm">确认</el-button>
|
|
13
|
-
</template>
|
|
14
|
-
</JsonDialog>
|
|
15
|
-
</div>
|
|
16
|
-
</template>
|
|
17
|
-
|
|
18
|
-
<script>
|
|
19
|
-
import JsonDialog from "@/components/editor/JsonDialog";
|
|
20
|
-
import { deepClone } from "../utils";
|
|
21
|
-
import ImportJson from "@/components/fileComs/ImportJson.vue";
|
|
22
|
-
|
|
23
|
-
export default {
|
|
24
|
-
components: {
|
|
25
|
-
JsonDialog,
|
|
26
|
-
ImportJson,
|
|
27
|
-
},
|
|
28
|
-
props: {
|
|
29
|
-
value: {
|
|
30
|
-
type: Object,
|
|
31
|
-
default: () => {},
|
|
32
|
-
},
|
|
33
|
-
},
|
|
34
|
-
data() {
|
|
35
|
-
return {
|
|
36
|
-
defaultValue: this.value,
|
|
37
|
-
};
|
|
38
|
-
},
|
|
39
|
-
|
|
40
|
-
methods: {
|
|
41
|
-
onConfirm() {
|
|
42
|
-
this.$refs.JsonDialog.confirm((value) => {
|
|
43
|
-
const formAttrs = deepClone(value);
|
|
44
|
-
delete formAttrs.list;
|
|
45
|
-
const formList = value.list;
|
|
46
|
-
this.$emit("confirm", formAttrs, formList);
|
|
47
|
-
});
|
|
48
|
-
},
|
|
49
|
-
handleOpen() {
|
|
50
|
-
this.defaultValue = this.value;
|
|
51
|
-
this.$refs.JsonDialog.open();
|
|
52
|
-
},
|
|
53
|
-
handleImport(data) {
|
|
54
|
-
this.defaultValue = data;
|
|
55
|
-
this.$refs.JsonDialog.jsonContent = data;
|
|
56
|
-
},
|
|
57
|
-
},
|
|
58
|
-
};
|
|
59
|
-
</script>
|
|
60
|
-
|
|
61
|
-
<style lang="scss" scoped>
|
|
62
|
-
</style>
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<el-dialog
|
|
3
|
-
class="form-dialog form-preview"
|
|
4
|
-
:visible.sync="visible"
|
|
5
|
-
v-if="visible"
|
|
6
|
-
modal-append-to-body
|
|
7
|
-
append-to-body
|
|
8
|
-
destroy-on-close
|
|
9
|
-
width="1000px"
|
|
10
|
-
z-index="1000"
|
|
11
|
-
>
|
|
12
|
-
<template #title>
|
|
13
|
-
<el-radio-group v-model="active" size="mini">
|
|
14
|
-
<el-radio-button label="pc">
|
|
15
|
-
<i class="el-icon-monitor" />
|
|
16
|
-
</el-radio-button>
|
|
17
|
-
<el-radio-button label="phone" v-if="!hidePhone">
|
|
18
|
-
<i class="el-icon-mobile" />
|
|
19
|
-
</el-radio-button>
|
|
20
|
-
</el-radio-group>
|
|
21
|
-
</template>
|
|
22
|
-
<template v-if="formList && formList.length">
|
|
23
|
-
<div v-if="active=='pc'" ref="PCFormImg">
|
|
24
|
-
<PCForm ref="PCForm" :formList="formList" :formConf="formConf" isPreview />
|
|
25
|
-
</div>
|
|
26
|
-
<div class="hu-form-phone" v-if="active=='phone'">
|
|
27
|
-
<div class="hu-form-phone-cont">
|
|
28
|
-
<PhoneForm :formList="formList" :formConf="formConf" />
|
|
29
|
-
</div>
|
|
30
|
-
</div>
|
|
31
|
-
</template>
|
|
32
|
-
</el-dialog>
|
|
33
|
-
</template>
|
|
34
|
-
|
|
35
|
-
<script>
|
|
36
|
-
import PCForm from "../formComponents/pcForm.vue";
|
|
37
|
-
import PhoneForm from "../formComponents/phoneForm.vue";
|
|
38
|
-
export default {
|
|
39
|
-
components: {
|
|
40
|
-
PCForm,
|
|
41
|
-
PhoneForm,
|
|
42
|
-
},
|
|
43
|
-
props: {
|
|
44
|
-
hidePhone: {
|
|
45
|
-
type: Boolean,
|
|
46
|
-
default: false,
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
data() {
|
|
50
|
-
return {
|
|
51
|
-
formList: [],
|
|
52
|
-
formConf: {},
|
|
53
|
-
visible: false,
|
|
54
|
-
active: "pc",
|
|
55
|
-
};
|
|
56
|
-
},
|
|
57
|
-
mounted() {},
|
|
58
|
-
methods: {
|
|
59
|
-
open(list, conf) {
|
|
60
|
-
this.visible = true;
|
|
61
|
-
this.formList = [];
|
|
62
|
-
this.formConf = {};
|
|
63
|
-
if (list) this.formList = this.$utils.deepClone(list);
|
|
64
|
-
if (conf) this.formConf = this.$utils.deepClone(conf);
|
|
65
|
-
},
|
|
66
|
-
},
|
|
67
|
-
};
|
|
68
|
-
</script>
|
|
69
|
-
|
|
70
|
-
<style lang="scss" >
|
|
71
|
-
.form-preview {
|
|
72
|
-
.el-dialog__header {
|
|
73
|
-
text-align: center;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
.hu-form-phone {
|
|
77
|
-
margin: -25px auto;
|
|
78
|
-
height: calc(100% + 30px);
|
|
79
|
-
aspect-ratio: 4/7;
|
|
80
|
-
position: relative;
|
|
81
|
-
|
|
82
|
-
background-image: url("../../../images/phone_bg.png");
|
|
83
|
-
background-repeat: no-repeat;
|
|
84
|
-
background-size: cover;
|
|
85
|
-
|
|
86
|
-
.hu-form-phone-cont {
|
|
87
|
-
z-index: 1;
|
|
88
|
-
background: #fff;
|
|
89
|
-
position: absolute;
|
|
90
|
-
top: 10%;
|
|
91
|
-
left: 18%;
|
|
92
|
-
right: 18%;
|
|
93
|
-
bottom: 16%;
|
|
94
|
-
overflow: auto;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
.pho-dialog {
|
|
98
|
-
.el-dialog .el-dialog__body {
|
|
99
|
-
overflow: hidden;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
</style>
|