Newer
Older
xc-business-system / src / views / equipement / standard / checkData / components / seventh / checkDataCom.vue
lyg on 7 Aug 34 KB 精密漏点仪核查
<!-- 核查数据管理详情--核查项---第7套:精密漏点仪标准装置 -->
<script lang="ts" setup name="checkDataDetail">
import { ref, watch } from 'vue'
import { ElLoading, ElMessage } from 'element-plus'
import saveCheckRecord from '../../dialog/saveCheckRecord.vue'
import { clearDateValue, handleDetailTableTableHead, handleSaveDateParams, solveHistoryIndicationTableData } from '../useStabilityCaculate'
import type { IList } from './seventh-interface'
import type { TableColumn } from '@/components/NormalTable/table_interface'
import useUserStore from '@/store/modules/user'
import type { dictType } from '@/global'
import { getDictByCode } from '@/api/system/dict'
import { useCheckList } from '@/commonMethods/useCheckList'
import multiTable from '@/components/MultiHeaderTable/index.vue'
import { addCheckData, calculateHandle, getHistoryIndication, getInfo, updateCheckData } from '@/api/equipment/standard/checkData'
import { getCheckItemDetail, getJobInstructionList } from '@/api/equipment/standard/book'
import { useScientificNotation } from '@/commonMethods/useScientificNotation'
import { uniqueArray } from '@/utils/Array'
const props = defineProps({
  selectStandardId: { // 选择的标准装置id
    type: String,
  },
  pageType: { // 页面类型
    type: String,
  },
  checkDate: { // 核查日期
    type: String,
  },
})

const emits = defineEmits(['isConfigCheck'])

const user = useUserStore() // 用户信息
const $router = useRouter() // 关闭页面使用
const $route = useRoute() // 路由参数
const infoId = ref('')
const belongStandardEquipment = ref('7')
const itemCategoryId = ref('') // 核查项分类id
const itemCategoryName = ref('') // 核查项分类名称
const form = ref({
  remark: '/', // 备注
  qualified: '', // 稳定性考核是否合格
})
const equipmentId = ref('') // 设备id
const dateArrStability = ref<string[]>([]) // 稳定性日期数组
const currentDate = ref('') // 要查询历史稳定性的日期

// ----------------------------------路由参数------------------------------------------------
if ($route.params && $route.params.type) {
  if ($route.params.id) {
    infoId.value = $route.params.id as string
  }
}
// ----------------------------------------核查数据----------------------------------------------
const radioMenus = ref([ // 标签内容
  { name: '重复性', value: 'repeatability' },
  { name: '稳定性', value: 'stability' },
])
const current = ref('repeatability') // 选择的tab 默认基本信息
const columns_repeatability_attenuation_amount = ref<TableColumn[]>([ // 重复性表头--温湿度核查
  { text: '配套设备名称', value: 'equipmentName', align: 'center', width: '160', required: false, type: 'text' },
  { text: '类型', value: 'typeValue', align: 'center', width: '110', required: false, type: 'text' },
  { text: '相对湿度/温度', value: 'relativeDimension', width: '110', align: 'center', required: false, type: 'text', unit: 'relativeDimensionUnit' },
  { text: '相对湿度/温度点', value: 'checkPoint', width: '110', align: 'center', required: false, type: 'text', unit: 'checkPointUnit' },
  {
    text: '第1次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueOne', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueOne', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueOne', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '第2次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueTwo', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueTwo', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueTwo', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '第3次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueThree', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueThree', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueThree', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '第4次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueFour', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueFour', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueFour', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '第5次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueFive', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueFive', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueFive', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '第6次',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'recorderValueSix', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '露点仪示值', value: 'pointMeterValueSix', align: 'center', required: true, width: '160', type: props.pageType !== 'detail' ? 'inputNumber' : 'text' },
      { text: '差值', value: 'differentValueSix', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  {
    text: '平均值',
    value: '',
    align: 'center',
    required: false,
    children: [
      { text: '记录仪示值', value: 'averageRecordValue', align: 'center', required: false, width: '120', type: 'text' },
      { text: '露点仪示值', value: 'averagePointMeterValue', align: 'center', required: false, width: '120', type: 'text' },
      { text: '差值', value: 'averageValue', align: 'center', required: false, width: '120', type: 'text' },
    ],
  },
  { text: '重复性Sn', value: 'standardDeviation', align: 'center', width: '120', required: false, type: 'text' },
  { text: 'U(k=2)', value: 'urel', align: 'center', width: '120', required: false, type: 'text' },
  { text: '是否重复性Sn≤U', value: 'lessThanValue', align: 'center', width: '120', required: false, type: 'text' },
])

const columns_stability_attenuation_amount = ref<TableColumn[]>([ // 稳定性表头--温湿度核查
  { text: '配套设备名称', value: 'equipmentName', align: 'center', width: '160', required: false, type: 'text' },
  { text: '类型', value: 'typeValue', align: 'center', width: '110', required: false, type: 'text' },
  { text: '相对湿度/温度', value: 'relativeDimension', width: '110', align: 'center', required: false, type: 'text', unit: 'relativeDimensionUnit' },
  { text: '相对湿度/温度点', value: 'checkPoint', width: '110', align: 'center', required: false, type: 'text', unit: 'checkPointUnit' },
  {
    text: '核查差值',
    value: '-',
    align: 'center',
    required: false,
    children: [
      { width: '180', text: '-', value: 'testValueOne', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueTwo', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueThree', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueFour', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueFive', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueSix', align: 'center', required: false, type: 'text', customHeader: true },
    ],
  },
  { text: '平均值', value: 'averageValue', align: 'center', width: '120', required: false, type: 'text' },
  { text: '稳定性Sm', value: 'standardDeviation', align: 'center', width: '120', required: false, type: 'text' },
  { text: 'U(k=2)', value: 'urel', align: 'center', required: true, width: '120', type: 'text' },
  { text: '是否Sm≤U', value: 'lessThanValue', align: 'center', required: false, width: '120', type: 'text' },
])
const columns_stability_attenuation_amount_checkDate = ref<TableColumn[]>([ // 稳定性表头--温湿度核查
  { text: '配套设备名称', value: 'equipmentName', align: 'center', width: '160', required: false, type: 'text' },
  { text: '类型', value: 'typeValue', align: 'center', width: '110', required: false, type: 'text' },
  { text: '相对湿度/温度', value: 'relativeDimension', width: '110', align: 'center', required: false, type: 'text', unit: 'relativeDimensionUnit' },
  { text: '相对湿度/温度点', value: 'checkPoint', width: '110', align: 'center', required: false, type: 'text', unit: 'checkPointUnit' },
  {
    text: '核查差值',
    value: '-',
    align: 'center',
    required: false,
    children: [
      { width: '180', text: '-', value: 'testValueOne', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueTwo', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueThree', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueFour', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueFive', align: 'center', required: false, type: 'text', customHeader: true },
      { width: '180', text: '-', value: 'testValueSix', align: 'center', required: false, type: 'text', customHeader: true },
    ],
  },
  { text: '平均值', value: 'averageValue', align: 'center', required: false, width: '120', type: 'text' },
  { text: '稳定性Sm', value: 'standardDeviation', align: 'center', required: false, width: '120', type: 'text' },
  { text: 'U(k=2)', value: 'urel', align: 'center', required: true, width: '120', type: 'text' },
  { text: '是否Sm≤U', value: 'lessThanValue', align: 'center', required: false, width: '120', type: 'text' },
])

// 重复性
const listFrequencyRepeatability = ref<IList[]>([]) // 温湿度核查-重复性

// 重复性checkDate
const listFrequencyRepeatabilityCheckDate = ref<IList[]>([]) // 温湿度核查-重复性

// 重复性Loading
const listFrequencyRepeatabilityLoading = ref(false) // 温湿度核查-重复性
// 稳定性
const listFrequencyStability = ref<any[]>([]) // 温湿度核查-稳定性
// 稳定性checkDate
const listFrequencyStabilityCheckDate = ref<any[]>([]) // 温湿度核查-稳定性

// 稳定性Loading
const listFrequencyStabilityLoading = ref(false) // 温湿度核查-稳定性

// 获取配置详情
function fetchCheckItemDetail(equipmentId: string, belongStandardEquipmentParam: string, itemCategoryIdParam: string, itemCategoryNameParam: string) {
  belongStandardEquipment.value = belongStandardEquipmentParam // 检校标准装置
  itemCategoryId.value = itemCategoryIdParam // 核查分类id
  itemCategoryName.value = itemCategoryNameParam // 核查分类名称
  const loading = ElLoading.service({
    lock: true,
    background: 'rgba(255, 255, 255, 0.8)',
  })
  const params = {
    equipmentId, // 设备id
    belongStandardEquipment: belongStandardEquipment.value, // 检校标准装置code
    itemCategoryId: itemCategoryId.value, // 核查项分类id
    itemCategoryName: itemCategoryName.value, // 核查项分类名称
  }
  getCheckItemDetail(params).then((res) => {
    loading.close()
    if (!res.data) {
      emits('isConfigCheck', false)
    }
    else {
      handleData(res.data.checkItemDataPointMeterList)
      fetchHistoryIndication() // 重新拉取稳定性
    }
  })
}

// 初始化数据(查询配置检定项)
function handleData(list: any, type = 'edit') {
  // 整理数据设备名称 类型 相对湿度温度相同的放在一起
  let newData = [] as any[]
  const equipmentNames = uniqueArray(list.map((item: any) => item.equipmentName))
  equipmentNames.forEach((item: any) => {
    const typeData = list.filter((citem: any) => citem.equipmentName === item).map((citem: any) => citem.typeValue)
    let data = [] as any[]
    typeData.forEach((element: any) => {
      data = [...data, ...list.filter((citem: any) => citem.equipmentName === item).filter((citem: any) => citem.typeValue === element)]
    })
    newData = [...newData, ...data]
  })
  // 温湿度核查
  listFrequencyRepeatability.value = newData
  // 温湿度核查重复性
  listFrequencyRepeatability.value = listFrequencyRepeatability.value.map((e: any) => {
    return {
      paramsName: '温湿度核查',
      editable: type === 'edit',
      dataId: e.id, //	核查数据管理基础信息表id
      id: '', //	id,更新/删除使用参数
      checkType: '重复性',
      dataType: '1',
      params: '温湿度核查', // 核查项目
      equipmentName: e.equipmentName,
      typeValue: e.typeValue,
      relativeDimension: e.relativeDimension,
      relativeDimensionUnit: e.relativeDimensionUnit,
      checkPoint: e.dimensionPoint,
      checkPointUnit: e.dimensionPointUnit,
      averagePointMeterValue: '',
      averageRecordValue: '',
      averageValue: '',
      differentValueOne: '',
      differentValueTwo: '',
      differentValueThree: '',
      differentValueFour: '',
      differentValueFive: '',
      differentValueSix: '',
      pointMeterValueOne: '',
      pointMeterValueTwo: '',
      pointMeterValueThree: '',
      pointMeterValueFour: '',
      pointMeterValueFive: '',
      pointMeterValueSix: '',
      recorderValueOne: '',
      recorderValueTwo: '',
      recorderValueThree: '',
      recorderValueFour: '',
      recorderValueFive: '',
      recorderValueSix: '',
      standardDeviation: '',
      urel: e.urel,
      lessThan: '',
    }
  }) as any
  // 温湿度核查稳定性
  listFrequencyStability.value = listFrequencyRepeatability.value.map((e: any) => {
    return {
      paramsName: '温湿度核查',
      editable: props.pageType !== 'detail',
      dataId: e.dataId, //	核查数据管理基础信息表id
      id: '', //	id,更新/删除使用参数
      params: '温湿度核查', // 核查项目
      dataType: '1',
      checkType: '稳定性',
      equipmentName: e.equipmentName,
      typeValue: e.typeValue,
      relativeDimension: e.relativeDimension,
      relativeDimensionUnit: e.relativeDimensionUnit,
      checkPoint: e.checkPoint,
      checkPointUnit: e.checkPointUnit,
      standardDeviation: '',
      urel: e.urel,
      lessThan: '',
    }
  })
}
watch(() => listFrequencyRepeatability.value, (newVal) => {
  console.log(newVal, 'newVal')
}, {
  deep: true,
})
// 点击计算结果
const createResult = (type: string) => {
  let checkDataSignalGeneratorListParams: any // 要传的重复或者稳定性参数
  if (current.value === 'stability') { // 计算稳定性先校验重复性
    if (!checkList()) { return false }
    checkDataSignalGeneratorListParams = listFrequencyStability.value
  }

  if (current.value === 'repeatability') {
    switch (type) {
      case '温湿度核查':
        if (!useCheckList(listFrequencyRepeatability.value, columns_repeatability_attenuation_amount.value, `${type}-重复性`)) {
          return false
        }
        checkDataSignalGeneratorListParams = listFrequencyRepeatability.value
        break
    }
  }

  const params = {
    belongStandardEquipment: belongStandardEquipment.value, // 检校标准装置
    checkDataPointMeterList: checkDataSignalGeneratorListParams.map((item: { conclusion: string }) => {
      return {
        ...item,
        conclusion: '',
      }
    }),
    itemCategoryId: itemCategoryId.value, // 核查项分类id
    itemCategoryName: itemCategoryName.value, // 核查项分类id
  }
  // 重复性Loading
  listFrequencyRepeatabilityLoading.value = type === '温湿度核查' && current.value === 'repeatability'
  // 稳定性loading
  listFrequencyStabilityLoading.value = true // 温湿度核查-稳定性

  calculateHandle(params).then((res) => {
    const result = res.data.filter((item: { params: string }) => item.params === type).map((item: any) => {
      return {
        ...item,
        editable: props.pageType !== 'detail',
        paramsName: '温湿度核查',
        params: '温湿度核查',
      }
    })
    console.log(result, type)
    if (current.value === 'repeatability') { // 重复性
      switch (type) {
        case '温湿度核查':
          listFrequencyRepeatability.value = result.map((item: any) => ({
            ...item,
            paramsName: '温湿度核查',
            params: '温湿度核查',
            lessThanValue: (`${item.lessThan}` === '1') ? '合格' : '不合格',
          }))
          // 填充稳定性最后一列的日期和数值
          listFrequencyStability.value = listFrequencyStability.value.map((item, index: number) => {
            return {
              ...item,
              testValueSix: listFrequencyRepeatability.value[index].averageValue, //	测量差值
              testValueSixDate: props.checkDate, //	核查读数6日期(本次核查日期)
              lessThanValue: (`${item.lessThan}` === '1') ? '合格' : '不合格',
            }
          })
          break
      }
    }
    else if (current.value === 'stability') { // 稳定性
      const resultList = res.data.map((item: any) => {
        return {
          ...item,
          lessThanValue: (`${item.lessThan}` === '1' || `${item.lessThan}` === '') ? '合格' : '不合格',
          editable: props.pageType !== 'detail',
        }
      })
      listFrequencyStability.value = resultList.filter((item: { params: string }) => item.params === '温湿度核查')

      // 计算稳定性考核是否合格
      if (resultList.every((item: { lessThanValue: string | number }) => item.lessThanValue === '合格')) {
        form.value.qualified = '合格'
      }
      else {
        form.value.qualified = '不合格'
      }
    }

    // 重复性Loading
    listFrequencyRepeatabilityLoading.value = false
    // 稳定性loading
    listFrequencyStabilityLoading.value = false // 温湿度核查-稳定性
  }).catch(() => {
    // 重复性Loading
    listFrequencyRepeatabilityLoading.value = false
    // 稳定性loading
    listFrequencyStabilityLoading.value = false // 温湿度核查-稳定性
  })
}
// ------------------------------------------------------------------------------------------
// 处理详情数据
const solveGetDetailData = (responseList: any) => {
  console.log('处理详情数据', props.pageType)
  const list = responseList.map((item: any) => {
    return {
      ...item,
      editable: props.pageType !== 'detail',
      // checkPointDefineFront: item.checkPoint + item.unit, // 核查点
      // powerDefineFront: item.power + item.powerUnit, // 交流电压
      lessThanValue: `${item.lessThan}` === '1' ? '合格' : '不合格',
      testValueOne: item.checkType === '稳定性' ? item.testValueOne : Number(item.testValueOne), //	测量值1/测量值(上升时间)
      testValueTwo: item.checkType === '稳定性' ? item.testValueTwo : Number(item.testValueTwo), //	测量值2(示值)
      testValueThree: item.checkType === '稳定性' ? item.testValueThree : Number(item.testValueThree), //	测量值3(示值)
      testValueFour: item.checkType === '稳定性' ? item.testValueFour : Number(item.testValueFour), //	测量值4(示值)
      testValueFive: item.checkType === '稳定性' ? item.testValueFive : Number(item.testValueFive), //	测量值5(示值)
      testValueSix: item.checkType === '稳定性' ? item.testValueSix : Number(item.testValueSix), //	测量值6(本次示值)
      testValueSeven: item.checkType === '稳定性' ? item.testValueSeven : Number(item.testValueSeven), //	测量值7
      testValueEight: item.checkType === '稳定性' ? item.testValueEight : Number(item.testValueEight), //	测量值8
      testValueNine: item.checkType === '稳定性' ? item.testValueNine : Number(item.testValueNine), //	测量值9
      testValueTen: item.checkType === '稳定性' ? item.testValueTen : Number(item.testValueTen), //	测量值10
    }
  })
  const listFrequencyRepeatability = list.filter((item: { params: string; checkType: string }) => item.checkType === '重复性' && item.params === '温湿度核查') // 温湿度核查-重复性

  // 稳定性
  const listFrequencyStability = list.filter((item: { params: string; checkType: string }) => item.checkType === '稳定性' && item.params === '温湿度核查') // 温湿度核查-稳定性
  console.log(listFrequencyRepeatability, listFrequencyStability)
  form.value.qualified = listFrequencyStability.length < 4
    ? '合格'
    : listFrequencyStability.every((item: any) => `${responseList[0].lessThan}` === '1')
      ? '合格'
      : '不合格'
  return {
    templistFrequencyRepeatability: listFrequencyRepeatability,

    templistFrequencyStability: listFrequencyStability,
  }
}

// 获取详情
function fetchInfo(id = '') {
  const loading = ElLoading.service({
    lock: true,
    background: 'rgba(255, 255, 255, 0.8)',
  })
  getInfo({ id: id || infoId.value }).then((res) => {
    form.value = { ...res.data }
    equipmentId.value = res.data.equipmentId
    const {
      templistFrequencyRepeatability,
      templistFrequencyStability,
    } = solveGetDetailData(res.data.checkDataPointMeterList)
    if (id !== '') { // 查询的日期获得的数据
      listFrequencyRepeatabilityCheckDate.value = templistFrequencyRepeatability// 温湿度核查-重复性

      listFrequencyStabilityCheckDate.value = templistFrequencyStability// 温湿度核查-稳定性
    }
    else {
      listFrequencyRepeatability.value = templistFrequencyRepeatability// 温湿度核查-重复性

      listFrequencyStability.value = templistFrequencyStability// 温湿度核查-稳定性
    }

    nextTick(() => {
      if (id !== '') { // 稳定性表头---查询历史的稳定性日期数据
        const tempColumn = [
          { width: '180', text: '-', value: 'testValueOne', align: 'center', required: false, type: 'text', customHeader: true },
          { width: '180', text: '-', value: 'testValueTwo', align: 'center', required: false, type: 'text', customHeader: true },
          { width: '180', text: '-', value: 'testValueThree', align: 'center', required: false, type: 'text', customHeader: true },
          { width: '180', text: '-', value: 'testValueFour', align: 'center', required: false, type: 'text', customHeader: true },
          { width: '180', text: '-', value: 'testValueFive', align: 'center', required: false, type: 'text', customHeader: true },
          { width: '180', text: '-', value: 'testValueSix', align: 'center', required: false, type: 'text', customHeader: true },
        ] as any
        columns_stability_attenuation_amount.value[4].children = [...tempColumn]

        fetchHistoryIndication(currentDate.value) // 获取稳定性
      }
      else { // 正常核查数据处理表头
        columns_stability_attenuation_amount.value = handleDetailTableTableHead(columns_stability_attenuation_amount.value, listFrequencyStability.value, 4)
      }
    })

    if (props.pageType === 'edit' || props.pageType === 'detail') {
      fetchHistoryIndication() // 重新拉取稳定性日期
    }
    loading.close()
  })
}

/**
 * 获取稳定性示值
 * @param date 查询日期
 */
function fetchHistoryIndication(date = '') {
  if (!equipmentId.value || !props.selectStandardId) { return false }
  const params = {
    belongStandardEquipment: belongStandardEquipment.value,	// 检校标准装置(字典code)
    checkDate: date || props.checkDate!,	// 核查日期
    checkParam: '',	// 核查参数((直流稳压电源-直接电流(间接测量))
    conclusion: '合格',	// 结论
    equipmentId: equipmentId.value,	// 被核查设备id
    params: '',	// 核查项目
    stabilityExamine: '1',	// 是否用于稳定性考核(1/0)
    standardEquipmentId: props.selectStandardId!,	// 被核查标准装置id
  }
  if (props.selectStandardId && equipmentId.value) {
    // 稳定性Loading
    listFrequencyStabilityLoading.value = true // 温湿度核查-稳定性
  }
  getHistoryIndication(params).then((res) => {
    if (date === '') { // 正常核查数据
      const num = (props.pageType === 'edit' || props.pageType === 'detail') ? 5 : 4
      // '频率':
      listFrequencyStability.value = listFrequencyStability.value.map((item) => {
        const { itemData, columnsData } = solveHistoryIndicationTableData(res.data.data.filter((item: { params: string }) => item.params === '温湿度核查'), item, columns_stability_attenuation_amount.value, num, 4, '7')
        columns_stability_attenuation_amount.value = columnsData
        return item = itemData
      })
      listFrequencyStability.value = handleSaveDateParams(columns_stability_attenuation_amount.value, listFrequencyStability.value, 4)
    }
    else {
      initColumnsCheckDate()
      const num = 5
      // '频率':
      listFrequencyStabilityCheckDate.value = listFrequencyStabilityCheckDate.value.map((item) => {
        clearDateValue(item)
        const { itemData, columnsData } = solveHistoryIndicationTableData(res.data.data.filter((item: { params: string }) => item.params === '温湿度核查'), item, columns_stability_attenuation_amount_checkDate.value, num, 4, '7')
        columns_stability_attenuation_amount_checkDate.value = columnsData
        return item = itemData
      })
      listFrequencyStabilityCheckDate.value = handleSaveDateParams(columns_stability_attenuation_amount_checkDate.value, listFrequencyStabilityCheckDate.value, 2)
    }

    listFrequencyStabilityLoading.value = false // 温湿度核查-稳定性
  }).catch(() => {
    listFrequencyStabilityLoading.value = false // 温湿度核查-稳定性
  })
}

/**
 * 保存之前的校验
 */
function checkList() {
  // 新建核查数据的时候,在保存之前要先校验一下本次核查日期有没有数据,没有不允许保存
  if (listFrequencyRepeatability.value.length && `${listFrequencyRepeatability.value[0].averageValue}` === '') {
    ElMessage.warning('请先计算 温湿度核查 的重复性')
    return false
  }
  return true
}

// 保存之前处理数据
const solveDataBeforeSave = () => {
  // 数据处理
  let tempList = [] as any

  tempList = tempList.concat(
    // 重复性
    listFrequencyRepeatability.value, // 温湿度核查-重复性
    listFrequencyStability.value, // 温湿度核查-稳定性
  )
  return tempList
}

// 点击表头日期查询历史稳定性数据
const handleClickHeader = (val: any, checkDateDetailId: string) => {
  dateArrStability.value = ['核查数据', val.label]
  fetchInfo(checkDateDetailId) // 获取此次历史日期的详情
}

// 日期变化
const handleChangeRadio = (date: string) => {
  currentDate.value = date
}

// -------------------------------------钩子-----------------------------------------------------
// 统计日期
const dateCount = (columns: TableColumn[]) => {
  let dateNum = 0 // 稳定性表格有几个日期

  // 统计有几个日期
  columns[3].children?.forEach((item) => {
    if (item.text !== '-' && item.text !== '') {
      dateNum += 1
    }
  })
  return dateNum
}

watch(() => props.pageType, (newValue) => {
  if (newValue === 'detail') {
    listFrequencyRepeatability.value = listFrequencyRepeatability.value.map(item => ({ ...item, editable: false }))
  }
})
/**
 * 初始化表头
 * @param soveLastColumnDate 是否处理最后一列
 */
function initColumns() {
  const tempColumn = [
    { width: '180', text: '-', value: 'testValueOne', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueTwo', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueThree', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueFour', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueFive', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueSix', align: 'center', required: false, type: 'text', customHeader: true },
  ] as any
  columns_stability_attenuation_amount.value[4].children = [...tempColumn]

  columns_stability_attenuation_amount.value[4].children![5].text = props.checkDate! // 最后一列的表头日期
}
/**
 * 初始化CheckDate表头
 * @param soveLastColumnDate 是否处理最后一列
 */
function initColumnsCheckDate() {
  columns_stability_attenuation_amount_checkDate.value[4].children = [
    { width: '180', text: '-', value: 'testValueOne', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueTwo', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueThree', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueFour', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueFive', align: 'center', required: false, type: 'text', customHeader: true },
    { width: '180', text: '-', value: 'testValueSix', align: 'center', required: false, type: 'text', customHeader: true },
  ]
}
// 监听核查日期变化
watch(() => props.checkDate, (newValue) => {
  initColumns()
  nextTick(() => {
    fetchHistoryIndication() // 重新拉取稳定性日期
  })
}, { immediate: true })

onMounted(async () => {
  belongStandardEquipment.value = $route.query.belongStandardEquipment as string // 检校标准装置
  itemCategoryId.value = $route.query.itemCategoryId as string // 核查项分类id
  itemCategoryName.value = $route.query.itemCategoryName as string // 核查项分类名称
  if (props.pageType !== 'add') {
    fetchInfo()
  }
})
defineExpose({ fetchCheckItemDetail, checkList, solveDataBeforeSave, form })
</script>

<template>
  <!-- 核查数据 -->
  <detail-block :title="dateArrStability.length > 1 ? ' ' : '核查数据'" :title-menus="dateArrStability" @handle-change-radio="handleChangeRadio">
    <div style="display: flex;justify-content: space-between;">
      <el-radio-group v-model="current" style="margin-bottom: 20px;">
        <el-radio-button v-for="item in radioMenus" :key="item.value" :label="item.value">
          {{ item.name }}
        </el-radio-button>
      </el-radio-group>
    </div>
    <!-- 温湿度核查 -->
    <div style="display: flex;justify-content: space-between;align-items: center;">
      <h5>温湿度核查</h5>
      <el-button v-if="pageType !== 'detail' && current === 'repeatability'" type="primary" @click="createResult('温湿度核查')">
        计算结果
      </el-button>
      <el-button v-if="pageType !== 'detail' && current === 'stability'" type="primary" @click="createResult('stability')">
        计算结果
      </el-button>
    </div>
    <multi-table
      v-show="current === 'repeatability' && (currentDate === '核查数据' || currentDate === '')"
      v-loading="listFrequencyRepeatabilityLoading"
      :table-data="listFrequencyRepeatability"
      :table-header="columns_repeatability_attenuation_amount"
      :merge-rows="['equipmentName', 'typeValue']"
      :need-index="true"
      max-height="300"
    />
    <!-- 历史日期重复性数据 -->
    <multi-table
      v-show="current === 'repeatability' && (currentDate !== '核查数据' && currentDate !== '')"
      v-loading="listFrequencyRepeatabilityLoading"
      :table-data="listFrequencyRepeatabilityCheckDate"
      :table-header="columns_repeatability_attenuation_amount"
      :merge-rows="['equipmentName', 'typeValue']"
      :need-index="true"
      max-height="300"
    />

    <!-- 频率稳定性  -->
    <multi-table
      v-show="current === 'stability' && (currentDate === '核查数据' || currentDate === '')"
      v-loading="listFrequencyStabilityLoading"
      :table-data="listFrequencyStability"
      :table-header="columns_stability_attenuation_amount"
      :merge-rows="['equipmentName', 'typeValue']"
      :need-index="true"
      max-height="500"
      @handle-click-header="handleClickHeader"
    />
    <!-- 历史日期稳定性数据 -->
    <multi-table
      v-show="current === 'stability' && (currentDate !== '核查数据' && currentDate !== '')"
      v-loading="listFrequencyStabilityLoading"
      :table-data="listFrequencyStabilityCheckDate"
      :table-header="columns_stability_attenuation_amount_checkDate"
      :merge-rows="['equipmentName', 'typeValue']"
      :need-index="true"
      max-height="500"
      @handle-click-header="handleClickHeader"
    />

    <el-form
      v-if="current === 'stability'"
      style="margin-top: 20px;"
      :model="form"
      label-width="160"
      label-position="right"
    >
      <el-row :gutter="24">
        <el-col :span="12">
          <el-form-item label="稳定性考核是否合格:">
            <el-input v-model="form.qualified" class="full-width-input" disabled :placeholder="pageType === 'detail' ? ' ' : '稳定性考核是否合格'" />
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="备注:" prop="remark">
            <el-input
              v-model="form.remark"
              autosize
              type="textarea"
              :disabled="pageType === 'detail'"
            />
          </el-form-item>
        </el-col>
      </el-row>
    </el-form>

    <!-- 保存核查记录  -->
    <save-check-record ref="saveCheckRecordRef" />
  </detail-block>
</template>

<style lang="scss" scoped>
.link {
  text-decoration: underline;
  color: #3d7eff;
  cursor: pointer;
}

.file-area {
  display: flex;
  align-items: center;
  font-size: 14px;
  color: #60627f;
  margin-bottom: 10px;
  margin-left: 40px;
  white-space: nowrap;

  .tech-file {
    display: flex;
    align-items: center;
    margin-left: 20px;

    .file-text {
      margin-right: 10px;
    }
  }
}
</style>