feat 删除多余的组件
This commit is contained in:
parent
589d693d6b
commit
15c6076a8b
|
|
@ -1,162 +0,0 @@
|
||||||
<template>
|
|
||||||
<div class="edit-popup">
|
|
||||||
<popup
|
|
||||||
ref="popupRef"
|
|
||||||
:title="popupTitle"
|
|
||||||
:async="true"
|
|
||||||
width="550px"
|
|
||||||
@confirm="handleSubmit"
|
|
||||||
@close="handleClose"
|
|
||||||
>
|
|
||||||
<el-form ref="formRef" :model="formData" label-width="84px" :rules="formRules">
|
|
||||||
<el-form-item label="关联类型" prop="type">
|
|
||||||
<el-select class="flex-1" v-model="formData.type" placeholder="请选择关联类型">
|
|
||||||
<el-option
|
|
||||||
v-for="(item, index) in types"
|
|
||||||
:key="index"
|
|
||||||
:label="item.name"
|
|
||||||
:value="item.value"
|
|
||||||
/>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="关联名称" prop="name">
|
|
||||||
<el-input v-model="formData.name" placeholder="请输入关联名称" />
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="关联模型" prop="model">
|
|
||||||
<el-select class="flex-1" v-model="formData.model" placeholder="请选择关联模型">
|
|
||||||
<el-option
|
|
||||||
v-for="item in optionsData.models"
|
|
||||||
:label="item"
|
|
||||||
:value="item"
|
|
||||||
:key="item"
|
|
||||||
/>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="关联健" prop="local_key">
|
|
||||||
<el-select
|
|
||||||
class="flex-1"
|
|
||||||
v-model="formData.local_key"
|
|
||||||
clearable
|
|
||||||
placeholder="请选择关联健"
|
|
||||||
>
|
|
||||||
<el-option
|
|
||||||
v-for="item in column"
|
|
||||||
:key="item.id"
|
|
||||||
:value="item.column_name"
|
|
||||||
:label="`${item.column_name}:${item.column_comment}`"
|
|
||||||
/>
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="外键" prop="foreign_key">
|
|
||||||
<el-input
|
|
||||||
v-model="formData.foreign_key"
|
|
||||||
placeholder="关联表外键或中间表的外键"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
</popup>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
<script lang="ts" setup>
|
|
||||||
import type { FormInstance } from 'element-plus'
|
|
||||||
import type { PropType } from 'vue'
|
|
||||||
|
|
||||||
import { getModels } from '@/api/tools/code'
|
|
||||||
import Popup from '@/components/popup/index.vue'
|
|
||||||
import { useDictOptions } from '@/hooks/useDictOptions'
|
|
||||||
|
|
||||||
defineProps({
|
|
||||||
column: {
|
|
||||||
type: Array as PropType<any[]>,
|
|
||||||
default: () => []
|
|
||||||
},
|
|
||||||
types: {
|
|
||||||
type: Array as PropType<any[]>,
|
|
||||||
default: () => []
|
|
||||||
}
|
|
||||||
})
|
|
||||||
const emit = defineEmits(['add', 'close', 'edit'])
|
|
||||||
const formRef = shallowRef<FormInstance>()
|
|
||||||
const popupRef = shallowRef<InstanceType<typeof Popup>>()
|
|
||||||
const mode = ref<'add' | 'edit'>('add')
|
|
||||||
const popupTitle = computed(() => {
|
|
||||||
return mode.value == 'edit' ? '编辑关联' : '新增关联'
|
|
||||||
})
|
|
||||||
const formData = reactive({
|
|
||||||
name: '',
|
|
||||||
model: '',
|
|
||||||
type: '',
|
|
||||||
local_key: '',
|
|
||||||
foreign_key: ''
|
|
||||||
})
|
|
||||||
|
|
||||||
const formRules = {
|
|
||||||
name: [
|
|
||||||
{
|
|
||||||
required: true,
|
|
||||||
message: '请输入关联名称'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
type: [
|
|
||||||
{
|
|
||||||
required: true,
|
|
||||||
message: '请选择关联类型'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
model: [
|
|
||||||
{
|
|
||||||
required: true,
|
|
||||||
message: '请选择关联模型'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
local_key: [
|
|
||||||
{
|
|
||||||
required: true,
|
|
||||||
message: '请选择关联健'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
foreign_key: [
|
|
||||||
{
|
|
||||||
required: true,
|
|
||||||
message: '请输入外键'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
const { optionsData } = useDictOptions<{
|
|
||||||
models: any[]
|
|
||||||
}>({
|
|
||||||
models: {
|
|
||||||
api: getModels
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
const handleSubmit = async () => {
|
|
||||||
await formRef.value?.validate()
|
|
||||||
popupRef.value?.close()
|
|
||||||
emit(mode.value, formData)
|
|
||||||
}
|
|
||||||
|
|
||||||
const open = (type = 'add') => {
|
|
||||||
mode.value = type as 'add' | 'edit'
|
|
||||||
popupRef.value?.open()
|
|
||||||
}
|
|
||||||
|
|
||||||
const setFormData = (data: Record<any, any>) => {
|
|
||||||
for (const key in formData) {
|
|
||||||
if (data[key] != null && data[key] != undefined) {
|
|
||||||
//@ts-ignore
|
|
||||||
formData[key] = data[key]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const handleClose = () => {
|
|
||||||
emit('close')
|
|
||||||
}
|
|
||||||
|
|
||||||
defineExpose({
|
|
||||||
open,
|
|
||||||
setFormData
|
|
||||||
})
|
|
||||||
</script>
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name" : "",
|
"name" : "likeadminJ-uniapp",
|
||||||
"appid" : "",
|
"appid" : "__UNI__E8F2641",
|
||||||
"description" : "",
|
"description" : "",
|
||||||
"versionName" : "1.0.0",
|
"versionName" : "1.0.0",
|
||||||
"versionCode" : "100",
|
"versionCode" : "100",
|
||||||
|
|
@ -56,7 +56,7 @@
|
||||||
"es6" : true,
|
"es6" : true,
|
||||||
"minified" : true
|
"minified" : true
|
||||||
},
|
},
|
||||||
"__usePrivacyCheck__": true,
|
"__usePrivacyCheck__" : true,
|
||||||
"usingComponents" : true
|
"usingComponents" : true
|
||||||
},
|
},
|
||||||
"mp-alipay" : {
|
"mp-alipay" : {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue