feat: form designer

pull/2/head
xingyu 2023-01-19 16:05:25 +08:00
parent bae44b4541
commit b90b297e6f
2 changed files with 78 additions and 2 deletions

View File

@ -51,7 +51,6 @@ declare module '@vue/runtime-core' {
ElRadioButton: typeof import('element-plus/es')['ElRadioButton'] ElRadioButton: typeof import('element-plus/es')['ElRadioButton']
ElRadioGroup: typeof import('element-plus/es')['ElRadioGroup'] ElRadioGroup: typeof import('element-plus/es')['ElRadioGroup']
ElRow: typeof import('element-plus/es')['ElRow'] ElRow: typeof import('element-plus/es')['ElRow']
ElScroll: typeof import('element-plus/es')['ElScroll']
ElScrollbar: typeof import('element-plus/es')['ElScrollbar'] ElScrollbar: typeof import('element-plus/es')['ElScrollbar']
ElSelect: typeof import('element-plus/es')['ElSelect'] ElSelect: typeof import('element-plus/es')['ElSelect']
ElSkeleton: typeof import('element-plus/es')['ElSkeleton'] ElSkeleton: typeof import('element-plus/es')['ElSkeleton']

View File

@ -1,8 +1,85 @@
<template> <template>
<ContentWrap> <ContentWrap>
<fc-designer ref="designer" height="780px" /> <el-row>
<el-col>
<div class="mb-2 float-right">
<el-button size="small" @click="setJson"> JSON</el-button>
<el-button size="small" @click="setOption"> Options</el-button>
<el-button size="small" type="primary" @click="showJson">JSON</el-button>
<el-button size="small" type="success" @click="showOption">Options</el-button>
<el-button size="small" type="danger" @click="showTemplate"></el-button>
<el-button size="small" @click="changeLocale"></el-button>
</div>
</el-col>
<el-col>
<fc-designer ref="designer" height="780px" />
</el-col>
</el-row>
<Dialog :title="dialogTitle" v-model="dialogVisible" maxHeight="600">
<div ref="editor" v-if="dialogVisible">{{ formValue }}</div>
<span style="color: red" v-if="err">!</span>
</Dialog>
</ContentWrap> </ContentWrap>
</template> </template>
<script setup lang="ts" name="Build"> <script setup lang="ts" name="Build">
import formCreate from '@form-create/element-ui'
const designer = ref() const designer = ref()
const dialogVisible = ref(false)
const dialogTitle = ref('')
const err = ref(false)
const type = ref(-1)
const formValue = ref('')
const openModel = (title: string) => {
dialogVisible.value = true
dialogTitle.value = title
}
const setJson = () => {
openModel('导入JSON')
}
const setOption = () => {
openModel('导入Options')
}
const showJson = () => {
openModel('生成JSON')
type.value = 0
formValue.value = designer.value.getRule()
}
const showOption = () => {
openModel('生成Options')
type.value = 1
formValue.value = designer.value.getOption()
}
const showTemplate = () => {
openModel('生成组件')
type.value = 2
formValue.value = makeTemplate()
}
const changeLocale = () => {
console.info('changeLocale')
}
const makeTemplate = () => {
const rule = designer.value.getRule()
const opt = designer.value.getOption()
return `<template>
<form-create
v-model="fapi"
:rule="rule"
:option="option"
@submit="onSubmit"
></form-create>
</template>
<script setup lang=ts>
import formCreate from "@form-create/element-ui";
const faps = ref(null)
const rule = formCreate.parseJson('${formCreate.toJson(rule).replaceAll('\\', '\\\\')}')
const option = formCreate.parseJson('${JSON.stringify(opt)}')
const onSubmit = (formData) => {
//todo
}
<\/script>`
}
</script> </script>