add form build
This commit is contained in:
		| @ -22,6 +22,7 @@ | |||||||
|     "@vueuse/core": "9.5.0", |     "@vueuse/core": "9.5.0", | ||||||
|     "animate.css": "4.1.1", |     "animate.css": "4.1.1", | ||||||
|     "await-to-js": "^3.0.0", |     "await-to-js": "^3.0.0", | ||||||
|  |     "vform3-builds": "3.0.8", | ||||||
|     "axios": "^1.3.4", |     "axios": "^1.3.4", | ||||||
|     "echarts": "5.4.0", |     "echarts": "5.4.0", | ||||||
|     "element-plus": "2.2.27", |     "element-plus": "2.2.27", | ||||||
|  | |||||||
							
								
								
									
										66
									
								
								src/components/BuildCode/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/components/BuildCode/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,66 @@ | |||||||
|  | <!-- 代码构建 --> | ||||||
|  | <script setup lang="ts"> | ||||||
|  |  | ||||||
|  | import { ComponentInternalInstance } from "vue"; | ||||||
|  |  | ||||||
|  | const props = defineProps({ | ||||||
|  |   showBtn: { | ||||||
|  |     type: Boolean, | ||||||
|  |     default: false | ||||||
|  |   }, | ||||||
|  |   formJson: { | ||||||
|  |     type: Object, | ||||||
|  |     default: undefined | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||||
|  | const buildRef = ref(); | ||||||
|  | const emits = defineEmits(['reJson', 'saveDesign']); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | //获取表单json | ||||||
|  | const getJson = () => { | ||||||
|  |   const formJson = JSON.stringify(buildRef.value.getFormJson()) | ||||||
|  |   const fieldJson = JSON.stringify(buildRef.value.getFieldWidgets()) | ||||||
|  |   let data = { | ||||||
|  |     formJson, fieldJson | ||||||
|  |   } | ||||||
|  |   emits("saveDesign", data) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | onMounted(() => { | ||||||
|  |   if (props.formJson) { | ||||||
|  |     buildRef.value.setFormJson(props.formJson) | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div> | ||||||
|  |     <v-form-designer | ||||||
|  |       class="build" | ||||||
|  |       ref="buildRef" | ||||||
|  |       :designer-config="{ importJsonButton: true, exportJsonButton: true, exportCodeButton: true, generateSFCButton: true, formTemplates: true }" | ||||||
|  |     > | ||||||
|  |       <template #customToolButtons v-if="showBtn"> | ||||||
|  |         <el-button link type="primary" icon="Select" @click="getJson">保存</el-button> | ||||||
|  |       </template> | ||||||
|  |     </v-form-designer> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <style lang="scss"> | ||||||
|  | .build { | ||||||
|  |   margin: 0 !important; | ||||||
|  |   overflow-y: auto !important; | ||||||
|  |  | ||||||
|  |   & header.main-header { | ||||||
|  |     display: none; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   & .right-toolbar-con { | ||||||
|  |     text-align: right !important; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										62
									
								
								src/components/BuildCode/render.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/components/BuildCode/render.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,62 @@ | |||||||
|  | <!-- 动态表单渲染 --> | ||||||
|  | <script setup name="Render"> | ||||||
|  |  | ||||||
|  | const props = defineProps({ | ||||||
|  |   formJson: { | ||||||
|  |     type: [String, Object], | ||||||
|  |     default: {} | ||||||
|  |   }, | ||||||
|  |   formData: { | ||||||
|  |     type: [String, Object], | ||||||
|  |     default: {} | ||||||
|  |   }, | ||||||
|  |   isView: { | ||||||
|  |     type: Boolean, | ||||||
|  |     default: false | ||||||
|  |   } | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | const vFormRef = ref(null) | ||||||
|  | // 获取表单数据-异步 | ||||||
|  | const getFormData = () => { | ||||||
|  |   return vFormRef.value.getFormData() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 设置表单内容 | ||||||
|  |  * @param {表单配置} formConf | ||||||
|  |  * formConfig:{ formTemplate:表单模板,formData:表单数据,hiddenField:需要隐藏的字段字符串集合,disabledField:需要禁用的自读字符串集合} | ||||||
|  |  */ | ||||||
|  | const initForm = (formConf) => { | ||||||
|  |   const { formTemplate, formData, hiddenField, disabledField } = toRaw(formConf) | ||||||
|  |   if (formTemplate) { | ||||||
|  |     vFormRef.value.setFormJson(formTemplate) | ||||||
|  |     if (formData) { | ||||||
|  |       vFormRef.value.setFormData(formData) | ||||||
|  |     } | ||||||
|  |     if (disabledField && disabledField.length > 0) { | ||||||
|  |       setTimeout(() => { | ||||||
|  |         vFormRef.value.disableWidgets(disabledField) | ||||||
|  |       }, 200) | ||||||
|  |     } | ||||||
|  |     if (hiddenField && hiddenField.length > 0) { | ||||||
|  |       setTimeout(() => { | ||||||
|  |         vFormRef.value.hideWidgets(hiddenField) | ||||||
|  |       }, 200) | ||||||
|  |     } | ||||||
|  |     if (props.isView) { | ||||||
|  |       console.log(props.isView) | ||||||
|  |       setTimeout(() => { | ||||||
|  |         vFormRef.value.disableForm() | ||||||
|  |       }, 100) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | defineExpose({ getFormData, initForm }) | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <template> | ||||||
|  |   <div class=""> | ||||||
|  |     <v-form-render ref="vFormRef" :form-json="formJson" :form-data="formData" /> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
							
								
								
									
										4
									
								
								src/types/vform3-builds.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								src/types/vform3-builds.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,4 @@ | |||||||
|  | declare module 'vform3-builds' { | ||||||
|  |   const content: any; | ||||||
|  |   export = content; | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 LiuHao
					LiuHao