<!-- 核查数据管理详情--核查项---第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>