潘志宝
2024-09-25 f158183de34c89d791b445ff2f810e2976ddde63
Merge branch 'master' of ssh://172.16.8.100:29418/iailab-plat-ui-vue3
已修改3个文件
522 ■■■■■ 文件已修改
src/api/model/pre/predict/index.ts 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/model/pre/predict/MmPredictItemForm.vue 361 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/model/pre/predict/index.vue 159 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/model/pre/predict/index.ts
@@ -40,7 +40,7 @@
    modelname: string,
    itemid: string,
    arithid: string,
    trainsamplength: string,
    trainsamplength: number,
    predictsamplength: string,
    isonlinetrain: string,
    modelpath: string,
src/views/model/pre/predict/MmPredictItemForm.vue
@@ -10,21 +10,22 @@
      <el-divider content-position="left">基本信息</el-divider>
      <el-row>
        <el-col :span="12">
          <el-form-item label="预测项名" prop="itemname">
          <el-form-item label="预测项名">
            <el-input v-model="dataForm.mmPredictItem.itemname" placeholder="预测项名"/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="编号" prop="itemno">
          <el-form-item label="编号">
            <el-input v-model="dataForm.mmPredictItem.itemno" placeholder="编号" maxlength="50"/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="类型" prop="itemtypeid">
            <el-select v-model="dataForm.mmPredictItem.itemtypeid" @change="changeItemtype"
                       placeholder="请选择">
          <el-form-item label="类型">
            <el-select
              v-model="dataForm.mmPredictItem.itemtypeid" @change="changeItemtype"
              placeholder="请选择">
              <el-option
                v-for="item in itemTypeList"
                :key="item.id"
@@ -34,15 +35,16 @@
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="粒度" prop="granularity">
            <el-input v-model="dataForm.mmPredictItem.granularity" placeholder="粒度"
                      maxlength="5"/>
          <el-form-item label="粒度">
            <el-input
              v-model="dataForm.mmPredictItem.granularity" placeholder="粒度"
              maxlength="5"/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="是否检查" prop="workchecked">
          <el-form-item label="是否检查">
            <el-select v-model="dataForm.mmPredictItem.workchecked" placeholder="请选择">
              <el-option
                v-for="item in isList"
@@ -53,7 +55,7 @@
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="是否启用" prop="status">
          <el-form-item label="是否启用">
            <el-select v-model="dataForm.dmModuleItem.status" placeholder="请选择">
              <el-option
                v-for="item in isList"
@@ -66,7 +68,7 @@
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="管网" prop="moduleid">
          <el-form-item label="管网">
            <el-select v-model="dataForm.dmModuleItem.moduleid" placeholder="请选择">
              <el-option
                v-for="item in moduleList"
@@ -77,19 +79,19 @@
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="类别" prop="categoryid">
          <el-form-item label="类别">
            <el-input v-model="dataForm.dmModuleItem.categoryid" placeholder="类别" maxlength="64"/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="排序" prop="itemorder">
          <el-form-item label="排序">
            <el-input v-model="dataForm.dmModuleItem.itemorder" placeholder="排序" maxlength="36"/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="数据点" prop="pointid">
          <el-form-item label="数据点">
            <el-select
              v-model="dataForm.mmItemOutput.pointid"
              filterable
@@ -104,24 +106,25 @@
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="保存点位" prop="saveindex">
            <el-select v-model="dataForm.mmPredictItem.saveindex" placeholder="请选择">
              <el-option
                v-for="item in saveIndexList"
                :key="item.code"
                :label="item.name"
                :value="item.code"/>
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
      <!--      <el-row>
              <el-col :span="12">
                <el-form-item label="保存点位">
                  <el-select v-model="dataForm.mmPredictItem.saveindex" placeholder="请选择">
                    <el-option
                      v-for="item in saveIndexList"
                      :key="item.code"
                      :label="item.name"
                      :value="item.code"/>
                  </el-select>
                </el-form-item>
              </el-col>
            </el-row>-->
      <el-row v-if="dataForm.itemtypename === 'MergeItem'">
        <el-col :span="12">
          <el-form-item label="预测长度" prop="predictlength">
            <el-input v-model="dataForm.mmPredictItem.predictlength" placeholder="预测长度"
                      maxlength="5"/>
          <el-form-item label="预测长度">
            <el-input
              v-model="dataForm.mmPredictItem.predictlength" placeholder="预测长度"
              maxlength="5"/>
          </el-form-item>
        </el-col>
      </el-row>
@@ -129,21 +132,23 @@
      </el-divider>
      <el-row v-if="dataForm.itemtypename === 'NormalItem'">
        <el-col :span="24">
          <el-form-item label="模型名称" prop="modelname">
            <el-input v-model="dataForm.mmPredictModel.modelname" placeholder="模型名称"
                      maxlength="50"/>
          <el-form-item label="模型名称">
            <el-input
              v-model="dataForm.mmPredictModel.modelname" placeholder="模型名称"
              maxlength="50"/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="编号" prop="modelno" v-if="!!dataForm.id">
            <el-input v-model="dataForm.mmPredictModel.modelno" placeholder="编号" maxlength="32"
                      disabled/>
          <el-form-item label="编号" v-if="!!dataForm.id">
            <el-input
              v-model="dataForm.mmPredictModel.modelno" placeholder="编号" maxlength="32"
              disabled/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row v-if="dataForm.itemtypename === 'NormalItem'">
        <el-col :span="12">
          <el-form-item label="上传模型" prop="itemorder">
          <el-form-item label="上传模型">
            <el-upload
              class="upload-demo"
              :limit="1"
@@ -154,14 +159,15 @@
              :action="uploadModelUrl">
              <el-button size="small" type="primary" @click="setReplaceModelOnly(0)">点击上传
              </el-button>
              <el-button size="small" type="primary" @click="setReplaceModelOnly(1)"
                         v-if="!!dataForm.id">只替换模型
              <el-button
                size="small" type="primary" @click="setReplaceModelOnly(1)"
                v-if="!!dataForm.id">只替换模型
              </el-button>
            </el-upload>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="结果" prop="resultstrid">
          <el-form-item label="结果">
            <el-select v-model="dataForm.mmPredictModel.resultstrid" placeholder="请选择">
              <el-option
                v-for="item in resultstridList"
@@ -174,35 +180,38 @@
      </el-row>
      <el-row v-if="dataForm.itemtypename === 'NormalItem'">
        <el-col :span="24">
          <el-form-item label="路径" prop="modelpath">
            <el-input v-model="dataForm.mmPredictModel.modelpath" placeholder="路径" maxlength="32"
                      disabled/>
          <el-form-item label="路径">
            <el-input
              v-model="dataForm.mmPredictModel.modelpath" placeholder="路径" maxlength="32"
              disabled/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row v-if="dataForm.itemtypename === 'NormalItem'">
        <el-col :span="24">
          <el-form-item label="类名" prop="classname">
            <el-input v-model="dataForm.mmPredictModel.classname" placeholder="类名" maxlength="32"
                      disabled/>
          <el-form-item label="类名">
            <el-input
              v-model="dataForm.mmPredictModel.classname" placeholder="类名" maxlength="32"
              disabled/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row v-if="dataForm.itemtypename === 'NormalItem'">
        <el-col :span="12">
          <el-form-item label="方法名" prop="methodname">
            <el-input v-model="dataForm.mmPredictModel.methodname" placeholder="方法名"
                      maxlength="32" disabled/>
          <el-form-item label="方法名">
            <el-input
              v-model="dataForm.mmPredictModel.methodname" placeholder="方法名"
              maxlength="32" disabled/>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="参数" prop="modelparamstructure">
            <el-input v-model="dataForm.mmPredictModel.modelparamstructure" placeholder="参数"
                      maxlength="32" disabled/>
          <el-form-item label="参数">
            <el-input
              v-model="dataForm.mmPredictModel.modelparamstructure" placeholder="参数"
              maxlength="32" disabled/>
          </el-form-item>
        </el-col>
      </el-row>
      <el-table
        v-if="dataForm.itemtypename === 'NormalItem'"
        :data="dataForm.mmModelArithSettingsList"
@@ -221,6 +230,7 @@
      <el-divider content-position="left" v-if="dataForm.itemtypename === 'NormalItem'">输入参数
      </el-divider>
      <el-table
        v-if="dataForm.itemtypename === 'NormalItem'"
        :data="dataForm.mmModelParamList"
        border
        style="width: 100%; margin-top: 5px;">
@@ -228,8 +238,9 @@
        <el-table-column prop="modelparamorder" label="序号" width="60" align="center"/>
        <el-table-column prop="" label="类型" width="200" align="center">
          <template #default="scope">
            <el-select v-model="scope.row.modelparamtype"
                       @change="changeModelparamtype(value, scope.row)" placeholder="请选择">
            <el-select
              v-model="scope.row.modelparamtype"
              @change="changeModelparamtype(value, scope.row)" placeholder="请选择">
              <el-option
                v-for="item in dataForm.modelparamtypeList"
                :key="item"
@@ -255,11 +266,12 @@
        </el-table-column>
        <el-table-column prop="" label="参数长度" width="120" align="center">
          <template #default="scope">
            <el-input v-model="scope.row.datalength" maxlength="50"
                      style="width:100%;hight:100%"/>
            <el-input
              v-model="scope.row.datalength" maxlength="50"
              style="width:100%;height:100%"/>
          </template>
        </el-table-column>
        <el-table-column prop="" label="操作" width="100" align="center">
        <el-table-column prop="" label="操作" width="140" align="center">
          <template #default="scope">
            <el-button
              @click="addRow(scope.$index, dataForm.mmModelParamList)"
@@ -279,6 +291,7 @@
      <el-divider content-position="left" v-if="dataForm.itemtypename === 'MergeItem'">表达式
      </el-divider>
      <el-table
        v-if="dataForm.itemtypename === 'MergeItem'"
        :data="expressionList"
        border
        style="width: 100%; margin-top: 5px;">
@@ -320,7 +333,7 @@
        <el-table-column
          prop=""
          label="操作"
          width="100"
          width="140"
          align="center">
          <template #default="scope">
            <el-button
@@ -368,8 +381,10 @@
const moduleList = ref([])
const resulttableList = ref([])
const resultstridList = ref([])
const pointNoList = ref([])
const pointList = ref([])
const pointMap = ref({})
const predictList = ref([])
const predictItemList = ref([])
const modelparamList = ref([])
const modelparamListMap = ref([])
@@ -393,7 +408,7 @@
    code: 1,
    name: '是'
  }])
const saveIndexList = ref([
/*const saveIndexList = ref([
  {
    code: '2',
    name: 'T+2'
@@ -405,66 +420,66 @@
  {
    code: 'n',
    name: 'T+n'
  }])
  }])*/
const dataForm = ref({
  id: '',
  itemtypename: '',
  id: undefined,
  itemtypename: undefined,
  mmPredictItem: {
    id: '',
    itemno: '',
    itemname: '',
    caltypeid: '',
    itemtypeid: '',
    predictlength: '',
    granularity: '',
    status: '',
    isfuse: '',
    predictphase: '',
    workchecked: 0,
    unittransfactor: '',
    saveindex: ''
    id: undefined,
    itemno: undefined,
    itemname: undefined,
    caltypeid: undefined,
    itemtypeid: undefined,
    predictlength: undefined,
    granularity: undefined,
    status: undefined,
    isfuse: undefined,
    predictphase: undefined,
    workchecked: '',
    unittransfactor: undefined,
    saveindex: undefined
  },
  dmModuleItem: {
    id: '',
    moduleid: '',
    itemid: '',
    itemorder: '',
    status: 1,
    categoryid: ''
    id: undefined,
    moduleid: undefined,
    itemid: undefined,
    itemorder: undefined,
    status: undefined,
    categoryid: undefined
  },
  mmItemOutput: {
    id: '',
    itemid: '',
    pointid: '',
    resulttableid: '3cc2b483-3a01-40f7-a419-0c260210d8eb',
    tagname: '',
    outputorder: 1
    id: undefined,
    itemid: undefined,
    pointid: undefined,
    resulttableid: undefined,
    tagname: undefined,
    outputorder: undefined
  },
  mmPredictModel: {
    id: '',
    modelno: '',
    modelname: '',
    itemid: '',
    arithid: '',
    trainsamplength: '',
    predictsamplength: '',
    isonlinetrain: '',
    modelpath: '',
    isnormal: '',
    normalmax: '',
    normalmin: '',
    status: 1,
    classname: '',
    methodname: '',
    modelparamstructure: '',
    resultstrid: '',
    settingmap: ''
    id: undefined,
    modelno: undefined,
    modelname: undefined,
    itemid: undefined,
    arithid: undefined,
    trainsamplength: undefined,
    predictsamplength: undefined,
    isonlinetrain: undefined,
    modelpath: undefined,
    isnormal: undefined,
    normalmax: undefined,
    normalmin: undefined,
    status: undefined,
    classname: undefined,
    methodname: undefined,
    modelparamstructure: undefined,
    resultstrid: undefined,
    settingmap: undefined
  },
  mmPredictMergeItem: {
    id: '',
    itemid: '',
    expression: '',
    num: ''
    id: undefined,
    itemid: undefined,
    expression: undefined,
    num: undefined
  },
  modelparamtypeList: ['DATAPOINT', 'PREDICTITEM', 'DAYWORKPROCESSPLAN', 'MONTHWORKPROCESSPLAN', 'ST_PLAN_NQ', 'ST_PLAN_BQ', 'ST_PLAN_NQ_HI', 'ST_PLAN_BQ_HI'],
  mmModelArithSettingsList: [],
@@ -477,22 +492,26 @@
const formRef = ref() // 表单 Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
const open = async (type: string, id?: number, itemtypename?: string) => {
  dialogVisible.value = true
  dialogTitle.value = t('action.' + type)
  formType.value = type
  resetForm()
  dataForm.value.itemtypename = itemtypename || 'NormalItem'
  console.info(dataForm.value.itemtypename)
  // resetForm()
  resetFields(dataForm.value)
  setDefaultFields()
  // getItemTypeList()
  // getModuleList()
  getItemTypeList()
  getModuleList()
  getPointList()
  // getModelparamList()
  // getResulttableList()
  // getResultstridList()
  getModelparamList()
  getResulttableList()
  getResultstridList()
  // 修改时,设置数据
  if (id) {
    formLoading.value = true
    try {
      debugger
      getInfo(id)
    } finally {
      formLoading.value = false
@@ -512,6 +531,24 @@
  formLoading.value = true
  try {
    const data = dataForm.value as unknown as MmPredictItem.MmPredictItemVO
    debugger
    if (expressionList.value && expressionList.value.length > 0) {
      let expression = ''
      for (let i = 0; i < expressionList.value.length; i++) {
        let value = expressionList.value[i]
        expression = expression + value.point + (i === (expressionList.value.length - 1) ? '' : value.operator)
      }
      dataForm.value.mmPredictMergeItem.expression = expression
    } else {
      dataForm.value.mmPredictMergeItem.expression = ''
    }
    if (dataForm.value.mmModelArithSettingsList) {
      for (let item of dataForm.value.mmModelArithSettingsList) {
        if (item.key === 'lenpredict') {
          dataForm.value.mmPredictItem.predictlength = item.value
        }
      }
    }
    if (formType.value === 'create') {
      await MmPredictItem.createMmPredictItem(data)
      message.success(t('common.createSuccess'))
@@ -527,13 +564,26 @@
  }
}
function getInfo(id) {
  debugger
  const res = MmPredictItem.getMmPredictItem(id)
  console.info(res)
const resetFields = (obj) => {
  for (let key in obj) {
    if (key === 'itemtypename') {
      continue
    }
    if (obj[key] instanceof Array) {
      obj[key] = []
    } else if (obj[key] instanceof Object) {
      resetFields(obj[key])
    } else {
      obj[key] = ''
    }
  }
}
const getInfo = async (id) => {
  dataForm.value = await MmPredictItem.getMmPredictItem(id)
  expressionList.value = []
  if (res.mmPredictMergeItem && res.mmPredictMergeItem.expression) {
    let expression = res.mmPredictMergeItem.expression
  if (dataForm.value.mmPredictMergeItem && dataForm.value.mmPredictMergeItem.expression) {
    let expression = dataForm.value.mmPredictMergeItem.expression
    do {
      let indexPlus = expression.indexOf('+')
      let indexSub = expression.indexOf('-')
@@ -541,7 +591,7 @@
        let endIndex = (indexSub == -1 || (indexPlus < indexSub && indexPlus !== -1)) ? indexPlus : indexSub
        expressionList.value.push({
          point: expression.substring(0, endIndex),
          operator: expression.substr(endIndex, 1)
          operator: expression.substring(endIndex, 1)
        })
        expression = expression.substring(endIndex + 1)
      } else {
@@ -589,7 +639,7 @@
            value: value.value
          })
        }
      }, this)
      })
    }
    dataForm.value.mmPredictModel.classname = response.data.className
    dataForm.value.mmPredictModel.methodname = response.data.methodName
@@ -630,6 +680,7 @@
function changeItemtype(value) {
  dataForm.value.itemtypename = itemTypeMap[value]
  console.info(dataForm.value.itemtypename)
}
function changeModelparamtype(value, row) {
@@ -678,52 +729,52 @@
}
// 获取预测项类型列表
function getItemTypeList() {
const getItemTypeList = async () => {
  itemTypeList.value = []
  itemTypeList.value = MmItemType.getItemTypeList()
  itemTypeList.value = await MmItemType.getItemTypeList()
  itemTypeList.value.forEach(function (value) {
    itemTypeMap[value.id] = value.itemtypename
  })
  if (!dataForm.value.id) {
    // dataForm.value.mmPredictItem.itemtypeid = itemTypeList[0].id
    dataForm.value.mmPredictItem.itemtypeid = itemTypeList.value[0].id
  }
}
// 获取管网列表
function getModuleList() {
const getModuleList = async () => {
  moduleList.value = []
  moduleList.value = DmModule.getModuleList()
  moduleList.value = await DmModule.getModuleList()
}
function getResulttableList() {
const getResulttableList = async () => {
  resulttableList.value = []
  resulttableList.value = MmResultTable.getResulttableList()
  resulttableList.value = await MmResultTable.getResulttableList()
}
function getResultstridList() {
const getResultstridList = async () => {
  resultstridList.value = []
  resultstridList.value = MmResultTable.getResultstridList()
  resultstridList.value = await MmResultTable.getResultstridList()
}
function getPointList() {
const getPointList = async () => {
  pointLoading.value = true
  pointList.value = DaPoint.getPointList(queryParams)
  if (pointList.value.length > 0) {
    pointList.value.forEach(function (value) {
  pointNoList.value = await DaPoint.getPointList(queryParams)
  if (pointNoList.value.length > 0) {
    pointNoList.value.forEach(function (value) {
      pointList.value.push(value)
      pointMap[value.id] = value.pointname
    })
  }
}
function getModelparamList() {
const getModelparamList = async () => {
  modelparamListMap.value = []
  modelparamList.value = []
  predictItemList.value = []
  pointList.value = DaPoint.getPointList(queryParams)
  pointNoList.value = await DaPoint.getPointList(queryParams)
  let paramList = []
  if (pointList.value.length > 0) {
    pointList.value.forEach(function (value) {
  if (pointNoList.value.length > 0) {
    pointNoList.value.forEach(function (value) {
      paramList.push({
        id: value.id,
        code: value.pointno,
@@ -735,10 +786,10 @@
    modelparamListMap['DATAPOINT'] = paramList;
  }
  let predictRes = MmPredictItem.getMmPredictItemList
  predictList.value = await MmPredictItem.getMmPredictItemList()
  paramList = []
  if (predictRes.value.length > 0) {
    predictRes.forEach(function (value) {
  if (predictList.value.length > 0) {
    predictList.value.forEach(function (value) {
      paramList.push({
        id: value.id,
        code: value.itemno,
@@ -746,7 +797,7 @@
        type: 'PREDICTITEM'
      })
      if (value.id !== dataForm.value.id) {
        predictItemList.push({
        predictItemList.value.push({
          id: value.id,
          code: value.itemno,
          name: value.itemname
@@ -757,10 +808,10 @@
    modelparamListMap['PREDICTITEM'] = paramList;
  }
  const dayParams = {
  /*const dayParams = {
    'processType': '日计划'
  }
  let dayScheduleRes = ScheduleModelApi.getScheduleWorkPrecessList(dayParams)
  let dayScheduleRes = await ScheduleModelApi.getScheduleWorkPrecessList(dayParams)
  paramList = []
  if (dayScheduleRes !== null) {
    dayScheduleRes.forEach(function (value) {
@@ -778,7 +829,7 @@
  const monthParams = {
    'processType': '月计划'
  }
  let monthScheduleRes = ScheduleModelApi.getScheduleWorkPrecessList(monthParams)
  let monthScheduleRes = await ScheduleModelApi.getScheduleWorkPrecessList(monthParams)
  paramList = []
  if (monthScheduleRes !== null) {
    monthScheduleRes.forEach(function (value) {
@@ -791,12 +842,11 @@
      modelparamMap[value.id] = value.aliasName
    })
    modelparamListMap['MONTHWORKPROCESSPLAN'] = paramList;
  }
  }*/
}
function setDefaultFields() {
const setDefaultFields = () => {
  dataForm.value.mmPredictItem.workchecked = 0
  dataForm.value.mmPredictItem.predictlength = 60
  dataForm.value.mmPredictItem.status = 1
  dataForm.value.mmPredictItem.isfuse = 0
  dataForm.value.mmPredictItem.predictphase = 0
@@ -816,7 +866,7 @@
}
/** 重置表单 */
const resetForm = () => {
/*const resetForm = () => {
  dataForm.value = {
    mmModelArithSettingsList: [],
    mmModelParamList: [],
@@ -834,7 +884,7 @@
      status: '',
      isfuse: '',
      predictphase: '',
      workchecked: 0,
      workchecked: '',
      unittransfactor: '',
      saveindex: ''
    },
@@ -882,13 +932,12 @@
    }
  }
  formRef.value?.resetFields()
}
}*/
onMounted(() => {
  init()
})
function init() {
}
</script>
src/views/model/pre/predict/index.vue
@@ -28,11 +28,11 @@
      </el-form-item>
      <el-form-item>
        <el-button @click="handleQuery">
          <Icon icon="ep:search" class="mr-5px" />
          <Icon icon="ep:search" class="mr-5px"/>
          搜索
        </el-button>
        <el-button @click="resetQuery">
          <Icon icon="ep:refresh" class="mr-5px" />
          <Icon icon="ep:refresh" class="mr-5px"/>
          重置
        </el-button>
        <el-button
@@ -41,7 +41,7 @@
          @click="openForm('create')"
          v-hasPermi="['model:pre-predict:create']"
        >
          <Icon icon="ep:plus" class="mr-5px" />
          <Icon icon="ep:plus" class="mr-5px"/>
          新增
        </el-button>
      </el-form-item>
@@ -51,28 +51,28 @@
  <!-- 列表 -->
  <ContentWrap>
    <el-table v-loading="loading" :data="list">
      <el-table-column label="编号" align="center" prop="itemno" />
      <el-table-column label="预测项名" align="center" prop="itemname" />
<!--      <el-table-column label="类型ID" align="center" prop="itemtypeid" />-->
      <el-table-column label="类型名称" align="center" prop="itemtypename" />
      <el-table-column label="粒度" align="center" prop="granularity" />
      <el-table-column label="是否融合" align="center" prop="isfuse" />
      <el-table-column label="是否检查" align="center" prop="workchecked" />
<!--      <el-table-column label="模块ID" align="center" prop="moduleid" />-->
      <el-table-column label="排序" align="center" prop="itemorder" />
      <el-table-column label="是否启用" align="center" prop="status" />
<!--      <el-table-column label="类别ID" align="center" prop="categoryid" />-->
<!--      <el-table-column label="数据点ID" align="center" prop="pointid" />-->
      <el-table-column label="数据点名称" align="center" prop="tagname" />
<!--      <el-table-column label="存放表ID" align="center" prop="resulttableid" />-->
      <el-table-column label="存放表" align="center" prop="tablename" />
      <el-table-column label="编号" align="center" prop="itemno"/>
      <el-table-column label="预测项名" align="center" prop="itemname"/>
      <!--      <el-table-column label="类型ID" align="center" prop="itemtypeid" />-->
      <el-table-column label="类型名称" align="center" prop="itemtypename"/>
      <el-table-column label="粒度" align="center" prop="granularity"/>
      <el-table-column label="是否融合" align="center" prop="isfuse"/>
      <el-table-column label="是否检查" align="center" prop="workchecked"/>
      <!--      <el-table-column label="模块ID" align="center" prop="moduleid" />-->
      <!--      <el-table-column label="排序" align="center" prop="itemorder" />-->
      <el-table-column label="是否启用" align="center" prop="status"/>
      <!--      <el-table-column label="类别ID" align="center" prop="categoryid" />-->
      <!--      <el-table-column label="数据点ID" align="center" prop="pointid" />-->
      <el-table-column label="数据点名称" align="center" prop="tagname"/>
      <!--      <el-table-column label="存放表ID" align="center" prop="resulttableid" />-->
      <el-table-column label="存放表" align="center" prop="tablename"/>
      <el-table-column label="操作" align="center" min-width="110" fixed="right">
        <template #default="scope">
          <el-button
            link
            type="primary"
            @click="openForm('update', scope.row.id)"
            @click="openForm('update', scope.row.id, scope.row.itemtypename)"
            v-hasPermi="['model:pre-predict:update']"
          >
            编辑
@@ -98,7 +98,7 @@
  </ContentWrap>
  <!-- 表单弹窗:添加/修改 -->
  <MmPredictItemForm ref="formRef" @success="getList" />
  <MmPredictItemForm ref="formRef" @success="getList"/>
</template>
<script lang="ts" setup>
@@ -107,67 +107,76 @@
defineOptions({name: 'DataMmPredictItem'})
  const message = useMessage() // 消息弹窗
  const {t} = useI18n() // 国际化
const message = useMessage() // 消息弹窗
const {t} = useI18n() // 国际化
  const loading = ref(true) // 列表的加载中
  const total = ref(0) // 列表的总页数
  const list = ref([]) // 列表的数据
  const queryParams = reactive({
    pageNo: 1,
    pageSize: 10,
    itemno: undefined,
    itemname: undefined,
  })
  const queryFormRef = ref() // 搜索的表单
  const exportLoading = ref(false) // 导出的加载中
const loading = ref(true) // 列表的加载中
const total = ref(0) // 列表的总页数
const list = ref([]) // 列表的数据
const queryParams = reactive({
  pageNo: 1,
  pageSize: 10,
  itemno: undefined,
  itemname: undefined,
})
const isList = ref([
  {
    code: 0,
    name: '否'
  },
  {
    code: 1,
    name: '是'
  }])
const queryFormRef = ref() // 搜索的表单
const exportLoading = ref(false) // 导出的加载中
  /** 查询列表 */
  const getList = async () => {
    loading.value = true
    try {
      const page = await MmPredictItem.getMmPredictItemPage(queryParams)
      list.value = page.list
      total.value = page.total
    } finally {
      loading.value = false
    }
/** 查询列表 */
const getList = async () => {
  loading.value = true
  try {
    const page = await MmPredictItem.getMmPredictItemPage(queryParams)
    list.value = page.list
    total.value = page.total
  } finally {
    loading.value = false
  }
}
  /** 搜索按钮操作 */
  const handleQuery = () => {
    queryParams.pageNo = 1
    getList()
  }
/** 搜索按钮操作 */
const handleQuery = () => {
  queryParams.pageNo = 1
  getList()
}
  /** 重置按钮操作 */
  const resetQuery = () => {
    queryFormRef.value.resetFields()
    handleQuery()
  }
/** 重置按钮操作 */
const resetQuery = () => {
  queryFormRef.value.resetFields()
  handleQuery()
}
  /** 添加/修改操作 */
  const formRef = ref()
  const openForm = (type: string, id?: number) => {
    formRef.value.open(type, id)
  }
/** 添加/修改操作 */
const formRef = ref()
const openForm = (type: string, id?: number, itemtypename?: string) => {
  formRef.value.open(type, id, itemtypename)
}
  /** 删除按钮操作 */
  const handleDelete = async (id: number) => {
    try {
      // 删除的二次确认
      await message.delConfirm()
      // 发起删除
      await MmPredictItem.deleteMmPredictItem(id)
      message.success(t('common.delSuccess'))
      // 刷新列表
      await getList()
    } catch {
    }
  }
  /** 初始化 **/
  onMounted(async () => {
/** 删除按钮操作 */
const handleDelete = async (id: number) => {
  try {
    // 删除的二次确认
    await message.delConfirm()
    // 发起删除
    await MmPredictItem.deleteMmPredictItem(id)
    message.success(t('common.delSuccess'))
    // 刷新列表
    await getList()
  })
  } catch {
  }
}
/** 初始化 **/
onMounted(async () => {
  await getList()
})
</script>