From 0338c167e908d0c7809fa4b92ac6ff258ebd9761 Mon Sep 17 00:00:00 2001 From: dengzedong <dengzedong@email> Date: 星期三, 04 六月 2025 08:38:13 +0800 Subject: [PATCH] 快照点位下拉选择 --- src/views/model/sche/snapshotConf/det/index.vue | 18 ++++---- src/api/model/sche/model/index.ts | 6 ++- src/views/model/sche/snapshotConf/det/configDetForm.vue | 56 +++++++++++++++++++++++++--- 3 files changed, 63 insertions(+), 17 deletions(-) diff --git a/src/api/model/sche/model/index.ts b/src/api/model/sche/model/index.ts index 39a1184..92d9b8a 100644 --- a/src/api/model/sche/model/index.ts +++ b/src/api/model/sche/model/index.ts @@ -125,7 +125,8 @@ planList.push( { id: item.id, - name: item.itemName + name: item.itemName, + itemNo: item.itemNo } ) }) @@ -153,7 +154,8 @@ indList.push( { id: item.id, - name: item.itemName + name: item.itemName, + itemNo: item.itemNo } ) }) diff --git a/src/views/model/sche/snapshotConf/det/configDetForm.vue b/src/views/model/sche/snapshotConf/det/configDetForm.vue index 4051e8c..d1ba51c 100644 --- a/src/views/model/sche/snapshotConf/det/configDetForm.vue +++ b/src/views/model/sche/snapshotConf/det/configDetForm.vue @@ -10,9 +10,9 @@ <el-row :gutter="24"> <el-col :span="12"> <el-form-item label="数据类型" prop="dataType"> - <el-select v-model="formData.dataType" placeholder="请选择"> + <el-select v-model="formData.dataType" placeholder="请选择" @change="changeDataType()"> <el-option - v-for="dict in getStrDictOptions(DICT_TYPE.SUGGEST_SNAPSHOT_DATA_TYPE)" + v-for="dict in getStrDictOptions(DICT_TYPE.SUGGEST_SNAPSHOT_DATA_TYPE)" :key="dict.value" :label="dict.label" :value="dict.value" @@ -21,15 +21,34 @@ </el-form-item> </el-col> <el-col :span="12"> - <el-form-item label="数据名称" prop="dataName"> - <el-input v-model="formData.dataName" placeholder=""/> + <el-form-item label="数据编号" prop="dataNo"> + <el-select-v2 v-if="formData.dataType === 'PREDICT_ITEM_N' || formData.dataType === 'PREDICT_ITEM_L' || formData.dataType === 'PREDICT_ITEM_CUR'" + v-model="formData.dataNo" + :options="modelparamListMap['NormalItem'] || []" + placeholder="请选择" + :props="{value:'value',label:'label',options:'children'}" + clearable + filterable + :fit-input-width="false" + @change="changeDataNo" + /> + <el-select-v2 v-else + v-model="formData.dataNo" + :options="modelparamListMap[formData.dataType] || []" + placeholder="请选择" + :props="{value:'itemNo',label:'name'}" + clearable + filterable + :fit-input-width="false" + @change="changeDataNo" + /> </el-form-item> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="12"> - <el-form-item label="数据编号" prop="dataNo"> - <el-input v-model="formData.dataNo" placeholder=""/> + <el-form-item label="数据名称" prop="dataName"> + <el-input v-model="formData.dataName" placeholder="" disabled/> </el-form-item> </el-col> <el-col :span="12"> @@ -92,6 +111,7 @@ import * as ConfigDetApi from '@/api/model/sche/suggest/snapshotConfigDet' import {deleteIcon} from "@/api/model/mpk/icon"; import {DICT_TYPE, getIntDictOptions, getStrDictOptions} from '@/utils/dict' + import * as ScheduleModelApi from "@/api/model/sche/model"; defineOptions({name: 'ConfigDetForm'}) const {t} = useI18n() // 国际化 @@ -125,6 +145,8 @@ }) const formRef = ref() // 表单 Ref + const modelparamListMap = ref({}) + /** 打开弹窗 */ const open = async (type: string, id?: string, confId?: string) => { dialogVisible.value = true @@ -132,6 +154,8 @@ formType.value = type resetForm() formData.value.confId = confId + // 加载参数列表 + modelparamListMap.value = await ScheduleModelApi.getModelParamList(id) // 修改时,设置数据 if (id) { formLoading.value = true @@ -188,4 +212,24 @@ } formRef.value?.resetFields() } + + function changeDataType() { + formData.value.dataNo = undefined + formData.value.dataName = undefined + } + const changeDataNo = (value) => { + let dataName = undefined; + if (formData.value.dataType === 'PREDICT_ITEM_N' || formData.value.dataType === 'PREDICT_ITEM_L' || formData.value.dataType === 'PREDICT_ITEM_CUR') { + for (let item of modelparamListMap.value['NormalItem']) { + dataName = item.children?.find(e => e.value === value)?.label; + if (dataName != undefined) { + break + } + } + }else { + dataName = modelparamListMap.value?.[formData.value.dataType]?.find(e => e.itemNo === value)?.name; + } + console.log(dataName) + formData.value.dataName = dataName + } </script> diff --git a/src/views/model/sche/snapshotConf/det/index.vue b/src/views/model/sche/snapshotConf/det/index.vue index 4d9516b..5ec4f28 100644 --- a/src/views/model/sche/snapshotConf/det/index.vue +++ b/src/views/model/sche/snapshotConf/det/index.vue @@ -60,21 +60,21 @@ :data="list" row-key="id" > - <el-table-column prop="dataType" align="center" label="数据类型"> + <el-table-column prop="dataType" align="center" label="数据类型" width="110px"> <template #default="scope"> <dict-tag :type="DICT_TYPE.SUGGEST_SNAPSHOT_DATA_TYPE" :value="scope.row.dataType"/> </template> </el-table-column> <el-table-column prop="dataName" label="数据名称"/> <el-table-column prop="dataNo" label="数据编号"/> - <el-table-column prop="leftLength" label="左侧长度(min)"/> - <el-table-column prop="rightLength" label="右侧侧长度(min)"/> - <el-table-column prop="sort" label="排序"/> - <el-table-column prop="ext1" label="拓展字段1"/> - <el-table-column prop="ext2" label="拓展字段2"/> - <el-table-column prop="ext3" label="拓展字段3"/> - <el-table-column prop="ext4" label="拓展字段4"/> - <el-table-column prop="ext5" label="拓展字段5"/> + <el-table-column prop="leftLength" label="左侧长度(min)" width="80"/> + <el-table-column prop="rightLength" label="右侧长度(min)" width="80"/> + <el-table-column prop="sort" label="排序" width="80"/> +<!-- <el-table-column prop="ext1" label="拓展字段1"/>--> +<!-- <el-table-column prop="ext2" label="拓展字段2"/>--> +<!-- <el-table-column prop="ext3" label="拓展字段3"/>--> +<!-- <el-table-column prop="ext4" label="拓展字段4"/>--> +<!-- <el-table-column prop="ext5" label="拓展字段5"/>--> <el-table-column label="操作" align="center" width="150px"> <template #default="scope"> <div class="flex items-center justify-center"> -- Gitblit v1.9.3