mirror of
https://gitee.com/niucloud-team/niucloud-admin.git
synced 2026-01-28 05:48:10 +00:00
169 lines
5.5 KiB
Vue
169 lines
5.5 KiB
Vue
<template>
|
|
<el-dialog v-model="showDialog" :title="title" width="500px" :before-close="beforeClose" :destroy-on-close="true">
|
|
<el-form :model="formData" label-width="120px" ref="formRef" :rules="formRules" class="page-form">
|
|
<el-form-item :label="t('associatedType')" prop="type">
|
|
<el-select :placeholder="t('associatedTypePlaceholder')" v-model="formData.type" class="input-width">
|
|
<el-option :label="t('hasOne')" value="has_one" />
|
|
<el-option :label="t('hasMany')" value="has_many" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item :label="t('associatedName')" prop="name">
|
|
<el-input v-model="formData.name" :placeholder="t('associatedNamePlaceholder')" class="input-width" />
|
|
</el-form-item>
|
|
<el-form-item :label="t('addons')" prop="addon">
|
|
<el-select v-model="formData.addon" :placeholder="t('addonsPlaceholder')" class="input-width" @change="addonChange">
|
|
<el-option v-for="(item, index) in addonLst" :label="item.title" :value="item.key" :key="index" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item :label="t('associatedModel')" prop="model">
|
|
<el-select :placeholder="t('associatedModelPlaceholder')" v-model="formData.model" class="input-width">
|
|
<el-option v-for="item in modelList" :label="item" :value="item" :key="item" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item prop="local_key" :label="t('localKey')">
|
|
<el-select class="input-width" :placeholder="t('localKeyPlaceholder')"
|
|
v-model="formData.local_key">
|
|
<el-option :label="`${item.name}:${item.comment}`" :value="item.name"
|
|
v-for="(item, index) in localKeyList " :key="index" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item :label="t('foreignKey')" prop="foreign_key">
|
|
<el-input v-model="formData.foreign_key" :placeholder="t('foreignKeyPlaceholder')" class="input-width" />
|
|
</el-form-item>
|
|
</el-form>
|
|
<template #footer>
|
|
<span class="dialog-footer">
|
|
<el-button @click="showDialog = false">{{ t('cancel') }}</el-button>
|
|
<el-button type="primary" @click="confirm(formRef)">{{ t('confirm') }}</el-button>
|
|
</span>
|
|
</template>
|
|
</el-dialog>
|
|
</template>
|
|
|
|
<script lang="ts" setup async>
|
|
import { ref, reactive, computed, toRaw, } from 'vue'
|
|
import { t } from '@/lang'
|
|
import type { FormInstance } from 'element-plus'
|
|
import { getGeneratorAllModel, getGeneratorTableColumn,getAddonDevelop } from '@/app/api/tools'
|
|
import { cloneDeep } from 'lodash-es'
|
|
|
|
const showDialog = ref(false)
|
|
const loading = ref(false)
|
|
const title = ref('')
|
|
const prop = defineProps({
|
|
table_name: {
|
|
type: String,
|
|
required: true,
|
|
}
|
|
})
|
|
/**
|
|
* 表单数据
|
|
*/
|
|
const initialFormData = {
|
|
type: "has_one",
|
|
name: "",
|
|
addon:"system",
|
|
model: "",
|
|
local_key: "",
|
|
foreign_key: ""
|
|
}
|
|
const formData: Record<string, any> = ref({ ...initialFormData })
|
|
|
|
const formRef = ref<FormInstance>()
|
|
|
|
// 表单验证规则
|
|
const formRules = computed(() => {
|
|
return {
|
|
type: [
|
|
{ required: true, message: t('associatedTypePlaceholder'), trigger: 'change' }
|
|
],
|
|
name: [
|
|
{ required: true, message: t('associatedNamePlaceholder'), trigger: 'blur' }
|
|
],
|
|
addon: [
|
|
{ required: true, message: t('addonsPlaceholder'), trigger: 'change' }
|
|
],
|
|
model: [
|
|
{ required: true, message: t('associatedModelPlaceholder'), trigger: 'change' }
|
|
],
|
|
local_key: [
|
|
{ required: true, message: t('localKeyPlaceholder'), trigger: 'change' }
|
|
],
|
|
foreign_key: [
|
|
{ required: true, message: t('foreignKeyPlaceholder'), trigger: 'blur' }
|
|
],
|
|
}
|
|
})
|
|
|
|
|
|
/**
|
|
* 获取关联模型
|
|
*/
|
|
const modelList = ref([])
|
|
const getGeneratorAllModelFn = (params:any) => {
|
|
getGeneratorAllModel(params).then(res => {
|
|
modelList.value = res.data
|
|
})
|
|
}
|
|
|
|
/**
|
|
* 获取关联键
|
|
*/
|
|
const localKeyList = ref([])
|
|
const getGeneratorTableColumnFn = (key: any) => {
|
|
getGeneratorTableColumn({ table_name: key }).then(res => {
|
|
localKeyList.value = res.data
|
|
})
|
|
}
|
|
//获取插件列表
|
|
const addonLst = ref<Array<any>>([])
|
|
const getAddonDevelopFn = async () => {
|
|
let { data } = await getAddonDevelop({})
|
|
addonLst.value = [{ title: "系统", key: "system" }]
|
|
addonLst.value.push(...data)
|
|
getGeneratorAllModelFn({addon:'system'})
|
|
}
|
|
getAddonDevelopFn()
|
|
//选择应用
|
|
const addonChange =(val:any)=>{
|
|
formData.value.model = ''
|
|
getGeneratorAllModelFn({addon:val})
|
|
}
|
|
const beforeClose=(next:any)=>{
|
|
formRef.value?.clearValidate()
|
|
next()
|
|
}
|
|
const emit = defineEmits(['complete'])
|
|
/**
|
|
* 确认
|
|
* @param formEl
|
|
*/
|
|
const confirm = async (formEl: FormInstance | undefined) => {
|
|
if (!formEl) return
|
|
|
|
await formEl.validate(async (valid) => {
|
|
if (valid) {
|
|
emit('complete',toRaw(formData.value))
|
|
showDialog.value = false
|
|
}
|
|
})
|
|
}
|
|
|
|
const setFormData = async (row: any = null) => {
|
|
getGeneratorTableColumnFn(prop.table_name)
|
|
if (row) {
|
|
formData.value = cloneDeep(row)
|
|
} else {
|
|
formData.value = cloneDeep(initialFormData)
|
|
}
|
|
showDialog.value = true
|
|
}
|
|
|
|
defineExpose({
|
|
showDialog,
|
|
setFormData
|
|
})
|
|
</script>
|
|
|
|
<style lang="scss" scoped></style>
|