dengzedong
2025-06-10 a52ca1c83e77f366fe56a3af1d0ae38f46beb85d
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_C'"
              v-model="formData.dataNo"
              :options="modelparamListMap['allPredictItemList'] || []"
              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=""/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
@@ -47,6 +66,18 @@
        <el-col :span="12">
          <el-form-item label="排序" prop="sort">
            <el-input v-model="formData.sort" placeholder=""/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row :gutter="20">
        <el-col :span="12">
          <el-form-item label="上限" prop="limitH">
            <el-input-number v-model="formData.limitH" placeholder=""/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="下限" prop="limitL">
            <el-input-number v-model="formData.limitL" placeholder=""/>
          </el-form-item>
        </el-col>
      </el-row>
@@ -92,6 +123,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() // 国际化
@@ -109,6 +141,8 @@
    dataNo: undefined,
    leftLength: undefined,
    rightLength: undefined,
    limitH: undefined,
    limitL: undefined,
    sort: undefined,
    ext1: undefined,
    ext2: undefined,
@@ -120,8 +154,12 @@
    dataType: [{required: true, message: '不能为空', trigger: 'blur'}],
    dataName: [{required: true, message: '不能为空', trigger: 'blur'}],
    dataNo: [{required: true, message: '不能为空', trigger: 'blur'}],
    leftLength: [{required: true, message: '不能为空', trigger: 'blur'}],
    rightLength: [{required: true, message: '不能为空', trigger: 'blur'}],
  })
  const formRef = ref() // 表单 Ref
  const modelparamListMap = ref({})
  /** 打开弹窗 */
  const open = async (type: string, id?: string, confId?: string) => {
@@ -130,6 +168,8 @@
    formType.value = type
    resetForm()
    formData.value.confId = confId
    // 加载参数列表
    modelparamListMap.value = await ScheduleModelApi.getModelParamList(id)
    // 修改时,设置数据
    if (id) {
      formLoading.value = true
@@ -177,6 +217,8 @@
      dataNo: undefined,
      leftLength: undefined,
      rightLength: undefined,
      limitH: undefined,
      limitL: undefined,
      sort: undefined,
      ext1: undefined,
      ext2: undefined,
@@ -186,4 +228,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_C') {
      for (let item of modelparamListMap.value['allPredictItemList']) {
        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>