Jay
7 天以前 47ee647ad4b08891d1cba06449577b3b3aaae5ef
提交 | 用户 | 时间
1f93e9 1 <template>
2   <Dialog v-model="dialogVisible" :title="dialogTitle">
3     <el-form
4       ref="formRef"
5       v-loading="formLoading"
6       :model="formData"
7       :rules="formRules"
8       label-width="80px"
9     >
10       <el-form-item label="名称" prop="name">
11         <el-input v-model="formData.name" placeholder="请输入名称" />
12       </el-form-item>
13       <el-form-item label="数据源" prop="dataSource">
14         <el-select v-model="formData.dataSource" clearable placeholder="请选择数据源">
15           <el-option
16             v-for="item in dataSourceList"
17             :key="item.id"
18             :label="item.name"
19             :value="item.id + ''"
20           />
21         </el-select>
22       </el-form-item>
23       <el-form-item label="查询语句" prop="querySql">
b9ca75 24         <el-input v-model="formData.querySql" placeholder="请输入内容" type="textarea" maxlength="500"
25                   :rows="6"
1f93e9 26                   show-word-limit spellcheck="false"/>
27       </el-form-item>
28       <el-form-item label="备注" prop="remark">
29         <el-input v-model="formData.remark" placeholder="请输入内容" type="textarea" maxlength="100"
30                   show-word-limit/>
31       </el-form-item>
32     </el-form>
33     <template #footer>
34       <el-button :disabled="formLoading" type="primary" @click="submitForm">确 定</el-button>
35       <el-button @click="dialogVisible = false">取 消</el-button>
36     </template>
37   </Dialog>
38 </template>
39 <script lang="ts" setup>
40   import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
41   import * as DataSetApi from '@/api/data/ind/data/data.set'
42   import { CommonStatusEnum } from '@/utils/constants'
43   import * as DataSourceConfigApi from "@/api/infra/dataSourceConfig";
44
45   defineOptions({ name: 'IndDataSetForm' })
46
47   const { t } = useI18n() // 国际化
48   const message = useMessage() // 消息弹窗
49
50   const dialogVisible = ref(false) // 弹窗的是否展示
51   const dialogTitle = ref('') // 弹窗的标题
52   const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
53   const formType = ref('') // 表单的类型:create - 新增;update - 修改
54   const formData = ref({
55     id: undefined,
56     name: '',
57     dataSource: '',
58     querySql: '',
59     remark: ''
60   })
61   const formRules = reactive({
62     name: [{ required: true, message: '名称不能为空', trigger: 'blur' }],
63     dataSource: [{ required: true, message: '数据源不能为空', trigger: 'blur' }],
64     querySql: [{ required: true, message: '查询语句不能为空', trigger: 'change' }]
65   })
66   const formRef = ref() // 表单 Ref
67   const dataSourceList = ref([] as DataSourceConfigApi.DataSourceConfigVO[])
68
69   /** 打开弹窗 */
70   const open = async (type: string, id?: number) => {
71     dialogVisible.value = true
72     dialogTitle.value = t('action.' + type)
73     formType.value = type
74     resetForm()
75
76     // 加载数据源列表
77     dataSourceList.value = await DataSourceConfigApi.getDataSourceConfigList()
78
79     // 修改时,设置数据
80     if (id) {
81       formLoading.value = true
82       try {
83         formData.value = await DataSetApi.getDataSet(id)
84       } finally {
85         formLoading.value = false
86       }
87     }
88
89
90   }
91   defineExpose({ open }) // 提供 open 方法,用于打开弹窗
92
93   /** 提交表单 */
94   const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调
95   const submitForm = async () => {
96     // 校验表单
97     if (!formRef) return
98     const valid = await formRef.value.validate()
99     if (!valid) return
100     // 提交请求
101     formLoading.value = true
102     try {
103       const data = formData.value as DataSetApi.DataSetVO
104       if (formType.value === 'create') {
105         await DataSetApi.createDataSet(data)
106         message.success(t('common.createSuccess'))
107       } else {
108         await DataSetApi.updateDataSet(data)
109         message.success(t('common.updateSuccess'))
110       }
111       dialogVisible.value = false
112       // 发送操作成功的事件
113       emit('success')
114     } finally {
115       formLoading.value = false
116     }
117   }
118
119   /** 重置表单 */
120   const resetForm = () => {
121     formData.value = {
122       id: undefined,
123       name: '',
124       dataSource: '',
125       querySql: '',
126       remark: ''
127     }
128     formRef.value?.resetFields()
129   }
130 </script>