From 08ffcf9d7ffafaa82d8de7f9b5fcfdb49e9c3688 Mon Sep 17 00:00:00 2001
From: riku <risaku@163.com>
Date: 星期三, 05 十一月 2025 17:33:54 +0800
Subject: [PATCH] 动态溯源 1. 修复CO因子文本没有正常显示的问题;

---
 src/views/historymode/component/MissionReport.vue |  680 +++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 641 insertions(+), 39 deletions(-)

diff --git a/src/views/historymode/component/MissionReport.vue b/src/views/historymode/component/MissionReport.vue
index 32fd62f..8e772be 100644
--- a/src/views/historymode/component/MissionReport.vue
+++ b/src/views/historymode/component/MissionReport.vue
@@ -14,6 +14,21 @@
         ></OptionLocation2>
       </el-form-item>
       <OptionTime v-model="formObj.timeArray"></OptionTime>
+      <el-form-item label="鍖哄幙绛涢��" prop="removeOtherDistrict">
+        <el-checkbox v-model="formObj.removeOtherDistrict"
+          >绉婚櫎鍏朵粬鍖哄幙</el-checkbox
+        >
+      </el-form-item>
+      <el-form-item label="姹℃煋婧愮瓫閫�" prop="removeNoPollutedSource">
+        <el-checkbox v-model="formObj.removeNoPollutedSource"
+          >绉婚櫎鏈彂鐜版薄鏌撴簮鐨勭嚎绱�</el-checkbox
+        >
+      </el-form-item>
+      <el-form-item label="闅愭偅鍖哄煙" prop="showPollutedArea">
+        <el-checkbox v-model="formObj.showPollutedArea"
+          >灏嗗吀鍨嬮殣鎮e尯鍩熻〃鏍间綔涓洪檮浠跺睍绀�</el-checkbox
+        >
+      </el-form-item>
       <el-form-item>
         <el-button
           type="primary"
@@ -23,6 +38,36 @@
         >
           涓嬭浇鎶ュ憡
         </el-button>
+        <!-- <el-button
+          type="primary"
+          class="el-button-custom"
+          @click="handleGenerateImg"
+          :loading="docLoading"
+        >
+          鐢熸垚鍥剧墖
+        </el-button> -->
+      </el-form-item>
+      <!-- <el-form-item>
+        <el-image :src="base64Url" fit="fill" :preview-src-list="[base64Url]" />
+      </el-form-item> -->
+      <el-form-item>
+        <el-button
+          type="primary"
+          class="el-button-custom"
+          @click="handleMixClick"
+          :loading="docLoading"
+        >
+          鐢熸垚缃戞牸鍥剧墖
+        </el-button>
+        <el-form-item>
+          <el-form-item>
+            <el-image
+              :src="gridBase64Url"
+              fit="fill"
+              :preview-src-list="[gridBase64Url]"
+            />
+          </el-form-item>
+        </el-form-item>
       </el-form-item>
     </el-form>
   </CardDialog>
@@ -31,14 +76,39 @@
 import { computed, ref } from 'vue';
 import moment from 'moment';
 import dataAnalysisApi from '@/api/dataAnalysisApi';
+import gridApi from '@/api/gridApi';
 import { exportDocx } from '@/utils/doc';
+import { radioOptions } from '@/constant/radio-options';
+import { TYPE0 } from '@/constant/device-type';
+import { FactorDatas } from '@/model/FactorDatas';
+import factorDataParser from '@/utils/chart/factor-data-parser';
+import chartToImg from '@/utils/chart/chart-to-img';
+import chartMap from '@/utils/chart/chart-map';
+import chartMapAmap from '@/utils/chart/chart-map-amap';
+import { Legend } from '@/model/Legend';
+import { getHexColor, getColorBetweenTwoColors } from '@/utils/color';
+import { getGridDataDetailFactorValue } from '@/model/GridDataDetail';
+import { factorName } from '@/constant/factor-name';
+
+// 鍊熺敤鍗槦閬ユ祴妯″潡涓殑100绫崇綉鏍�
+const props = defineProps({
+  groupId: {
+    type: Number,
+    default: import.meta.env.VITE_DATA_MODE == 'jingan' ? 2 : 3
+  }
+});
 
 const formObj = ref({
-  timeArray: [new Date('2025-07-01T00:00:00'), new Date('2025-08-31T23:59:59')],
+  timeArray: [new Date('2025-07-01T00:00:00'), new Date('2025-09-30T23:59:59')],
   location: {}
 });
 
 const docLoading = ref(false);
+
+const base64Url = ref(null);
+const gridBase64Url = ref(null);
+
+const gridCellList = ref([]);
 
 const params = computed(() => {
   return {
@@ -53,7 +123,10 @@
       cityName: formObj.value.location.cName,
       districtCode: formObj.value.location.dCode,
       districtName: formObj.value.location.dName
-    }
+    },
+    removeOtherDistrict: formObj.value.removeOtherDistrict,
+    removeNoPollutedSource: formObj.value.removeNoPollutedSource,
+    factorTypes: radioOptions(TYPE0).map((e) => e.name)
   };
 });
 
@@ -68,6 +141,7 @@
   srySceneCount: 5,
   sryProbByFactor:
     '棰楃矑鐗╋紙PM锛夌浉鍏砐澶勶紝鍗犳瘮 %锛屼富瑕佹秹鍙婂伐鍦版壃灏樻薄鏌撻棶棰樸�侀亾璺壃灏樻薄鏌撻棶棰樼瓑锛沄OC鐩稿叧X澶勶紝鍗犳瘮 %锛屼富瑕佹秹鍙婂姞娌圭珯娌规皵娉勯湶銆侀楗补鐑熸薄鏌撶瓑',
+  sryFocusRegion: '鑱氱劍鍖哄煙',
   missionInfoList: [
     {
       missionCode: '',
@@ -76,31 +150,115 @@
       _airQulity: 'AQI锛�30锛堜紭锛�',
       mainFactor: '',
       _abnormalFactors: '',
-      sceneCount: 0
+      sceneCount: 0,
+      _kilometres: '1000',
+      _keyScene: '1涓浗鎺х偣锛堥潤瀹夌洃娴嬬珯锛夊拰2涓競鎺х偣锛堝拰鐢颁腑瀛︺�佸競鍖楅珮鏂帮級',
+      exceptionCount: 0,
+      _focusScene: ''
     }
   ],
   missionDetailList: [
     {
+      _index: 1,
+      missionCode: '',
       _startTime: '2025骞�07鏈�29鏃�',
       _time: '09:00鑷�14:30',
       _kilometres: '1000',
-      _keyScene: '1涓浗鎺х偣锛堥潤瀹夌洃娴嬬珯锛夊拰2涓競鎺х偣锛堝拰鐢颁腑瀛︺�佸競鍖楅珮鏂帮級',
-      _dataStat:
-        'PM鈧�.鈧咃紙鑼冨洿30鈥�35 渭g/m鲁锛屽潎鍊�35.51 渭g/m鲁锛夈�丳M鈧佲個锛堣寖鍥�25鈥�68 渭g/m鲁锛屽潎鍊�38 渭g/m鲁锛夈�丯O鈧傦紙鑼冨洿22鈥�54 渭g/m鲁锛屽潎鍊�32 渭g/m鲁锛夈�丆O锛堣寖鍥�2.08鈥�6.39 mg/m鲁锛屽潎鍊�3.398 mg/m鲁锛夊拰NO锛堣寖鍥�1鈥�106 渭g/m鲁锛屽潎鍊�20.97 渭g/m鲁锛�',
+      _dataStatistics: [
+        {
+          factor: 'PM10',
+          minValue: 25,
+          maxValue: 68,
+          avgValue: 38
+        }
+      ],
+      _airQulity: 'AQI锛�30锛堜紭锛�',
       aqi: 30,
       pollutionDegree: '浼�'
+    }
+  ],
+  clueByAreaList: [
+    {
+      _index: 1,
+      _area: '鏌愭煇鍖哄煙鍛ㄨ竟',
+      clueByFactorList: [
+        {
+          factor: 'PM鈧�.鈧�',
+          clues: [
+            {
+              _factorNames: 'PM2.5',
+              _time: '10:22:28 - 10:22:34',
+              _riskRegion: '闀垮畞鍖烘竻婧矾鍙箰涓滆矾',
+              _exceptionType: '蹇�熶笂鍗�',
+              _chart: '',
+              _conclusion:
+                '鍦�10:22:28鑷�10:22:34涔嬮棿锛屽嚭鐜板揩閫熶笂鍗囷紝VOC鏈�浣庡�间负135.95渭g/m鲁锛屾渶楂樺�间负135.95渭g/m鲁锛屽潎鍊间负135.95渭g/m鲁锛屽彂鐜�3涓闄╂簮锛屽寘鍚�2涓姞娌圭珯锛�1涓苯淇��',
+              _scenes:
+                '1.涓婃捣渚濆痉姹借溅缁翠慨鏈夐檺鍏徃锛屾苯淇紒涓氾紝浣嶄簬涓婃捣甯傞暱瀹佸尯鍖楄櫣璺�1079鍙凤紝璺濅粰闇炵珯1887绫炽�俓r\n鈥︹��'
+            }
+          ]
+        }
+      ],
+      clueList: [
+        {
+          _factorNames: 'PM2.5',
+          _time: '10:22:28 - 10:22:34',
+          _riskRegion: '闀垮畞鍖烘竻婧矾鍙箰涓滆矾',
+          _exceptionType: '蹇�熶笂鍗�',
+          _chart: '',
+          _conclusion:
+            '鍦�10:22:28鑷�10:22:34涔嬮棿锛屽嚭鐜板揩閫熶笂鍗囷紝VOC鏈�浣庡�间负135.95渭g/m鲁锛屾渶楂樺�间负135.95渭g/m鲁锛屽潎鍊间负135.95渭g/m鲁锛屽彂鐜�3涓闄╂簮锛屽寘鍚�2涓姞娌圭珯锛�1涓苯淇��',
+          _scenes:
+            '1.涓婃捣渚濆痉姹借溅缁翠慨鏈夐檺鍏徃锛屾苯淇紒涓氾紝浣嶄簬涓婃捣甯傞暱瀹佸尯鍖楄櫣璺�1079鍙凤紝璺濅粰闇炵珯1887绫炽�俓r\n鈥︹��'
+        }
+      ]
+    }
+  ],
+  gridFusionByAQIList: [
+    {
+      pollutionDegree: '浼�',
+      _areaDes: '璧拌埅鍖哄煙澶у皬',
+      _gridDes: '100绫虫鏂瑰舰缃戞牸',
+      _missionDes: '20250729銆�20250730涓ゆ',
+      highRiskGridList: [
+        {
+          index: 1,
+          factor: 'PM2.5',
+          // 鏍囧噯鑹茬綉鏍煎浘
+          gridImgUrl1: '',
+          // 瀵规瘮鑹茬綉鏍煎浘
+          gridImgUrl2: '',
+          factorValue: 20,
+          // 鍥涜嚦鑼冨洿锛岄『搴忎负鏈�灏忕粡搴︼紝鏈�澶х粡搴︼紝鏈�灏忕含搴︼紝鏈�澶х含搴�
+          bounds: [121.4945, 121.4955, 31.2304, 31.2314],
+          _boundsDes: '鍥涜嚦鑼冨洿',
+          // 娑夊強琛楅晣
+          town: '',
+          _scenesDes: '娑夊強鐨勬薄鏌撳満鏅�'
+        }
+      ]
     }
   ]
 };
 
 const handleClick = () => {
-  generateMissionSummary(params.value).then((res) => {
-    // generateDocx();
-    generateMissionList(params.value).then((res) => {
-      generateMissionDetail(params.value).then((res) => {
-        //     generateClueByRiskArea(params.value).then((res) => {});
+  docLoading.value = true;
+  generateMissionSummary(params.value).then(() => {
+    generateMissionList(params.value).then(() => {
+      generateMissionDetail(params.value).then(() => {
+        generateClueByRiskArea(params.value).then(() => {
+          generateGridFusion(params.value).then(() => {
+            generateDocx();
+          });
+        });
       });
     });
+  });
+};
+
+const handleGenerateImg = () => {
+  generateClueByRiskArea(params.value).then(() => {
+    generateDocx();
   });
 };
 
@@ -110,6 +268,10 @@
       new Date(res.data.startTime),
       new Date(res.data.endTime)
     );
+    templateParam.subTitle =
+      templateParam.sryTime.indexOf('瀛e害') !== -1
+        ? templateParam.sryTime.replace(/锛�.*锛�/, '')
+        : templateParam.sryTime;
     templateParam.sryArea = res.data.area.districtName;
     templateParam.sryCount = res.data.count;
     templateParam.sryKm = Math.round(res.data.kilometres / 1000);
@@ -127,6 +289,7 @@
         return `${item.first}鐩稿叧${item.second}澶勶紝鍗犳瘮 ${Math.round(item.third * 1000) / 10}%锛屼富瑕佹秹鍙�${getPollutingProblemTypes(item.first)}绛塦;
       })
       .join('锛�');
+    templateParam.sryFocusRegion = res.data.focusRegion.join('銆�');
   });
 }
 
@@ -134,21 +297,10 @@
   return dataAnalysisApi.fetchMissionList(param).then((res) => {
     templateParam.missionInfoList = res.data.map((item) => {
       item._time = formatDateTimeRange(item.startTime, item.endTime);
-      item._airQulity = `AQI锛�${item.aqi}锛�${item.pollutionDegree}锛塦;
+      item._airQulity = `${item.aqi}锛�${item.pollutionDegree}锛塦;
       item._abnormalFactors = item.abnormalFactors
-        .map((factor) => factor.des)
+        .map((factor) => factorName[factor])
         .join('銆�');
-      return item;
-    });
-  });
-}
-
-function generateMissionDetail(param) {
-  return dataAnalysisApi.fetchMissionDetail(param).then((res) => {
-    templateParam.missionDetailList = res.data.map((item) => {
-      const t = formatDateTimeRange(item.startTime, item.endTime).split(' ');
-      item._startTime = t[0];
-      item._time = t[1];
       item._kilometres = Math.round(item.kilometres / 1000);
 
       const keySceneMap = new Map();
@@ -156,7 +308,7 @@
         if (!keySceneMap.has(e.type)) {
           keySceneMap.set(e.type, { scenes: [], count: 0 });
         }
-        keySceneMap.get(e.type).scenes.push(e.scene);
+        keySceneMap.get(e.type).scenes.push(e);
         keySceneMap.get(e.type).count++;
       });
       item._keyScene = [...keySceneMap]
@@ -165,12 +317,36 @@
             `${info.count}涓�${type}锛�${info.scenes.map((s) => s.name).join('銆�')}锛塦
         )
         .join('銆�');
-      item._dataStat = item.dataStatistic
-        .map(
-          (e) =>
-            `${e.factor.des}锛堣寖鍥�${e.minValue}鈥�${e.maxValue}渭g/m鲁锛屽潎鍊�${e.avgValue}渭g/m鲁锛塦
-        )
-        .join('銆�');
+      item._focusScene =
+        item.scenes.length > 0
+          ? item.scenes.map((s) => s.name).join('銆�')
+          : '閬撹矾浜ら�氬瘑闆嗗尯鍜岄儴鍒嗘柦宸ュ懆杈�';
+      return item;
+    });
+  });
+}
+
+function generateMissionDetail(param) {
+  return dataAnalysisApi.fetchMissionDetail(param).then((res) => {
+    templateParam.missionDetailList = res.data.map((item, index) => {
+      const t = formatDateTimeRange(item.startTime, item.endTime).split(' ');
+      item._index = index + 1;
+      item._startTime = t[0];
+      item._time = t[1];
+      item._kilometres = Math.round(item.kilometres / 1000);
+      item._airQulity = `${item.aqi}锛�${item.pollutionDegree}锛塦;
+
+      const factorNames = radioOptions(TYPE0).map((e) => e.name);
+      item._dataStatistics = item.dataStatistics.filter((e) => {
+        return factorNames.indexOf(e.factor) != -1;
+      });
+
+      radioOptions(TYPE0).forEach((f) => {
+        const _factor = item.dataStatistics.find((e) => e.factor == f.name);
+        item[`avgValue_${f.name}`] = _factor?.avgValue.toFixed(0) ?? '-';
+        item[`maxValue_${f.name}`] = _factor?.maxValue.toFixed(0) ?? '-';
+        item[`minValue_${f.name}`] = _factor?.minValue.toFixed(0) ?? '-';
+      });
 
       return item;
     });
@@ -178,19 +354,431 @@
 }
 
 function generateClueByRiskArea(param) {
-  return dataAnalysisApi.fetchClueByRiskArea(param).then((res) => {});
+  const indexArr = [
+    'A',
+    'B',
+    'C',
+    'D',
+    'E',
+    'F',
+    'G',
+    'H',
+    'I',
+    'J',
+    'K',
+    'L',
+    'M',
+    'N',
+    'O',
+    'P',
+    'Q',
+    'R',
+    'S',
+    'T',
+    'U',
+    'V',
+    'W',
+    'X',
+    'Y',
+    'Z'
+  ];
+  const _param = {
+    area: param.area,
+    startTime: param.startTime,
+    endTime: param.endTime,
+    removeOtherDistrict: param.removeOtherDistrict,
+    removeNoPollutedSource: param.removeNoPollutedSource
+  };
+  return dataAnalysisApi.fetchClueByRiskArea(_param).then((res) => {
+    templateParam.showPollutedArea = formObj.value.showPollutedArea;
+    templateParam.clueByAreaList = res.data
+      .groupBy((e) => e.township)
+      .map((item, index) => {
+        const { key: township, values: clues } = item;
+        let typeCount = {};
+        let lastSceneType;
+        let sceneIndex = 0;
+
+        const _scenes = clues.flatMap((e) =>
+          e.clue.pollutedSource.sceneList.map((s, index) => {
+            const i = lastSceneType == s.type ? ++sceneIndex : 0;
+            typeCount[s.type] = typeCount[s.type] ? typeCount[s.type] + 1 : 1;
+            lastSceneType = s.type;
+            return {
+              des: `${s.type}${i + 1}锛�${s.name}锛屼綅浜�${s.location}锛岃窛${s.closestStation.name}${parseInt(s.length)}绫筹紱`
+            };
+          })
+        );
+        let _sceneDes = `璧拌埅杩囩▼涓函婧愬埌${_scenes.length}涓闄╂簮`;
+        if (_scenes.length > 0) {
+          _sceneDes += '锛屽叾绫诲瀷鏄�';
+          _sceneDes += Object.keys(typeCount)
+            .map((e) => `${e}锛�${typeCount[e]}涓級`)
+            .join('銆�');
+          _sceneDes += '锛�';
+        } else {
+          _sceneDes = '璧拌埅杩囩▼涓湭婧簮鍒伴闄╂簮銆�';
+        }
+        return {
+          _index: index + 1,
+          // _area: `${item.sceneInfo.type}${item.sceneInfo.name}鍛ㄨ竟`,
+          _area: `${township}`,
+          _sceneDes,
+          _scenes,
+          clueList: clues.map((item3, index3) => {
+            const clue = item3.clue;
+            let _riskRegion = '';
+            if (
+              clue.pollutedArea.address.indexOf(
+                clue.pollutedArea.streetNumber
+              ) == -1
+            ) {
+              // _riskRegion +=
+              //   (clue.pollutedArea.address ?? '') +
+              //   '锛�' +
+              //   (clue.pollutedArea.street ?? '') +
+              //   (clue.pollutedArea.streetNumber ?? '') +
+              //   (clue.pollutedArea.direction ?? '') +
+              //   '锛�';
+              _riskRegion = clue.pollutedArea.address;
+            } else {
+              _riskRegion = clue.pollutedArea.address;
+            }
+            return {
+              index: indexArr[index3],
+              showPollutedArea: formObj.value.showPollutedArea,
+              _title: _riskRegion,
+              _factorNames: Object.keys(clue.pollutedData.statisticMap)
+                .map((e) => factorName[e])
+                .join('銆�'),
+              _date: moment(clue.pollutedData.startTime).format('YYYY-MM-DD'),
+              _time:
+                moment(clue.pollutedData.startTime).format('HH:mm:ss') +
+                ' - ' +
+                moment(clue.pollutedData.endTime).format('HH:mm:ss'),
+              _riskRegion: _riskRegion,
+              _exceptionType: clue.pollutedData.exception,
+              _images: generateChartImg(clue.pollutedData),
+              _conclusion: clue.pollutedSource.conclusion.replace(
+                /锛屽彂鐜癧0-9]*涓闄╂簮锛屽寘鍚玔0-9]*涓�.*銆�/,
+                '銆�'
+              ),
+              _hasScene: clue.pollutedSource.sceneList.length > 0
+            };
+          })
+          // clueByFactorList: clues
+          //   .groupBy((e) => e.factorTag)
+          //   .map((item2, index2) => {
+          //     const { key: factorTag, values: clues2 } = item2;
+          //     const factorNames = [...new Set(clues2.flatMap((e) => e.factors))]
+          //       .map((e) => factorName[e])
+          //       .join('銆�');
+          //     return {
+          //       index: index2 + 1,
+          //       factor: factorNames,
+          //       clues: clues2.map((item3, index3) => {
+          //         const clue = item3.clue;
+          //         let _riskRegion = '';
+          //         if (
+          //           clue.pollutedArea.address.indexOf(
+          //             clue.pollutedArea.streetNumber
+          //           ) == -1
+          //         ) {
+          //           _riskRegion +=
+          //             (clue.pollutedArea.address ?? '') +
+          //             '锛�' +
+          //             (clue.pollutedArea.street ?? '') +
+          //             (clue.pollutedArea.streetNumber ?? '') +
+          //             (clue.pollutedArea.direction ?? '') +
+          //             '锛�';
+          //         } else {
+          //           _riskRegion = clue.pollutedArea.address;
+          //         }
+          //         return {
+          //           index: index3 + 1 + '',
+          //           showPollutedArea: formObj.value.showPollutedArea,
+          //           _title:
+          //             (clue.pollutedArea.street ?? '') +
+          //             (clue.pollutedArea.streetNumber ?? '') +
+          //             (clue.pollutedArea.direction ?? ''),
+          //           _factorNames: Object.keys(clue.pollutedData.statisticMap)
+          //             .map((e) => factorName[e])
+          //             .join('銆�'),
+          //           _time:
+          //             moment(clue.pollutedData.startTime).format(
+          //               'YYYY-MM-DD HH:mm:ss'
+          //             ) +
+          //             ' - ' +
+          //             moment(clue.pollutedData.endTime).format('HH:mm:ss'),
+          //           _riskRegion: _riskRegion,
+          //           _exceptionType: clue.pollutedData.exception,
+          //           _images: generateChartImg(clue.pollutedData),
+          //           _conclusion: clue.pollutedSource.conclusion,
+          //           _hasScene: clue.pollutedSource.sceneList.length > 0,
+          //           // _scenes:
+          //           //   clue.pollutedSource.sceneList.length > 0
+          //           //     ? clue.pollutedSource.sceneList
+          //           //         .map(
+          //           //           (s, index) =>
+          //           //             `${index + 1}. ${s.name}锛�${s.type}锛屼綅浜�${s.location}锛岃窛${s.closestStation.name}${parseInt(s.length)}绫筹紱`
+          //           //         )
+          //           //         .join('\r\n')
+          //           //     : '鏃�',
+          //           _scenes: clue.pollutedSource.sceneList.map((s, index) => {
+          //             return {
+          //               des: `${index + 1}. ${s.name}锛�${s.type}锛屼綅浜�${s.location}锛岃窛${s.closestStation.name}${parseInt(s.length)}绫筹紱`
+          //             };
+          //           })
+          //         };
+          //       })
+          //     };
+          //   })
+        };
+      });
+  });
+}
+
+function generateChartImg(pollutedData) {
+  const exceptionIndexArr = [];
+  pollutedData.dataVoList.forEach((e) => {
+    const i = pollutedData.historyDataList.findIndex((v) => v.time == e.time);
+    exceptionIndexArr.push([i - 1 < 0 ? 0 : i - 1, i]);
+  });
+
+  const factorDatas = new FactorDatas();
+  const images = [];
+  factorDatas.setData(pollutedData.historyDataList, 0, () => {
+    for (const key in pollutedData.statisticMap) {
+      const value = pollutedData.statisticMap[key];
+      const _chartOptions = factorDataParser.parseData(
+        factorDatas,
+        [
+          {
+            label: value.factorName,
+            name: value.factorName,
+            value: value.factorId + ''
+          }
+        ],
+        false
+      );
+      _chartOptions.forEach((o) => {
+        images.push({
+          url: chartToImg.generateEchartsImage(o, exceptionIndexArr, 20)
+        });
+      });
+
+      if (base64Url.value == null) {
+        base64Url.value = images[0].url;
+      }
+    }
+  });
+  return images;
+}
+
+function generateGridFusion(param) {
+  return dataAnalysisApi.fetchGridFusion(param).then((res) => {
+    const promiseList = [];
+    templateParam.gridFusionByAQIList = [];
+
+    res.data.forEach((item) => {
+      const scenes = [];
+      item.missionList.forEach((m) => {
+        m.keyScene.map((s) => {
+          if (scenes.indexOf(s.name) == -1) {
+            scenes.push(s.name);
+          }
+        });
+      });
+      const gfbAQI = {
+        pollutionDegree: item.pollutionDegree,
+        _areaDes: `璧拌埅鍖哄煙缁忚繃${scenes.join('銆�')}`,
+        _gridDes: `${item.gridLen}绫虫鏂瑰舰缃戞牸`,
+        _missionDes: `${item.missionList.map((m) => m.missionCode).join('銆�')}鍏�${item.missionList.length}娆
+      };
+      const _highRiskGridList = [];
+      Object.keys(item.highRiskGridMap).forEach((key, i) => {
+        const g = item.highRiskGridMap[key][0];
+
+        const infoDes = item.highRiskGridMap[key].map((e) => {
+          return {
+            factorValue: e.factorValue,
+            // 鍥涜嚦鑼冨洿锛岄『搴忎负鏈�灏忕粡搴︼紝鏈�澶х粡搴︼紝鏈�灏忕含搴︼紝鏈�澶х含搴�
+            _boundsDes: `缁忓害${e.bounds[0]}鑷�${e.bounds[1]}锛岀含搴�${e.bounds[2]}鑷�${e.bounds[3]}`,
+            // 娑夊強琛楅晣
+            town: e.town,
+            _scenesDes:
+              e.highRiskScenes.length > 0
+                ? `娑夊強鐨勬薄鏌撳満鏅寘鎷�${e.highRiskScenes.map((s) => s.name).join('銆�')}`
+                : '缃戞牸鍐呭彲鑳藉瓨鍦ㄩ殣钘忛闄╂簮'
+          };
+        });
+        const infoDes2 = item.highRiskGridMap2[key].map((e) => {
+          return {
+            factorValue: e.factorValue,
+            // 鍥涜嚦鑼冨洿锛岄『搴忎负鏈�灏忕粡搴︼紝鏈�澶х粡搴︼紝鏈�灏忕含搴︼紝鏈�澶х含搴�
+            _boundsDes: `缁忓害${e.bounds[0]}鑷�${e.bounds[1]}锛岀含搴�${e.bounds[2]}鑷�${e.bounds[3]}`,
+            // 娑夊強琛楅晣
+            town: e.town,
+            _scenesDes:
+              e.highRiskScenes.length > 0
+                ? `娑夊強鐨勬薄鏌撳満鏅寘鎷�${e.highRiskScenes.map((s) => s.name).join('銆�')}`
+                : '缃戞牸鍐呭彲鑳藉瓨鍦ㄩ殣钘忛闄╂簮'
+          };
+        });
+        // })
+        // item.highRiskGridList.forEach((g, i) => {
+        // const g = item.highRiskGridList[0];
+        // const i = 0;
+        const p = generateGridFusionImg(g.factorType, item.gridFusionList).then(
+          (url) => {
+            const { url1, url2 } = url;
+            _highRiskGridList.push({
+              index: i + 1,
+              factor: factorName[g.factorType],
+              // 鏍囧噯鑹茬綉鏍煎浘
+              gridImgUrl1: url1,
+              // 瀵规瘮鑹茬綉鏍煎浘
+              gridImgUrl2: url2,
+              infoDes: infoDes,
+              infoDes2: infoDes2
+            });
+          }
+        );
+        promiseList.push(p);
+      });
+      gfbAQI.highRiskGridList = _highRiskGridList;
+      templateParam.gridFusionByAQIList.push(gfbAQI);
+    });
+    return Promise.all(promiseList).then(() => {
+      return templateParam.gridFusionByAQIList;
+    });
+    // templateParam.gridFusionByAQIList = res.data.map((item) => {
+    //   const scenes = [];
+    //   item.missionList.forEach((m) => {
+    //     m.keyScene.map((s) => {
+    //       if (scenes.indexOf(s.name) == -1) {
+    //         scenes.push(s.name);
+    //       }
+    //     });
+    //   });
+    //   return {
+    //     pollutionDegree: item.pollutionDegree,
+    //     _areaDes: `璧拌埅鍖哄煙缁忚繃${scenes.join('銆�')}`,
+    //     _gridDes: `${item.gridLen}绫虫鏂瑰舰缃戞牸`,
+    //     _missionDes: `${item.missionList.map((m) => m.missioncode).join('銆�')}${item.missionList.length}娆,
+    //     highRiskGridList: item.highRiskGridList.map(async (g, i) => {
+    //       const { url1, url2 } = await generateGridFusionImg(
+    //         g.factorType,
+    //         item.gridFusionList
+    //       );
+    //       return {
+    //         index: i + 1,
+    //         factor: g.factorType,
+    //         // 鏍囧噯鑹茬綉鏍煎浘
+    //         gridImgUrl1: url1,
+    //         // 瀵规瘮鑹茬綉鏍煎浘
+    //         gridImgUrl2: url2,
+    //         factorValue: g.factorValue,
+    //         // 鍥涜嚦鑼冨洿锛岄『搴忎负鏈�灏忕粡搴︼紝鏈�澶х粡搴︼紝鏈�灏忕含搴︼紝鏈�澶х含搴�
+    //         _boundsDes: `缁忓害${g.bounds[0]}鑷�${g.bounds[1]}锛岀含搴�${g.bounds[2]}鑷�${g.bounds[3]}`,
+    //         // 娑夊強琛楅晣
+    //         town: g.town,
+    //         _scenesDes: g.highRiskScenes.map((s) => s.name).join('銆�')
+    //       };
+    //     })
+    //   };
+    // });
+  });
+}
+
+async function generateGridFusionImg(factorName, dataList) {
+  let min = 1000000;
+  let max = 0;
+  dataList.forEach((v) => {
+    min = Math.min(min, getGridDataDetailFactorValue(v.data, factorName));
+    max = Math.max(max, getGridDataDetailFactorValue(v.data, factorName));
+  });
+
+  const gridDataStand = [];
+  const gridDataCustom = [];
+  dataList.forEach((v) => {
+    const data = getGridDataDetailFactorValue(v.data, factorName);
+    const grid = v.cell;
+
+    // 鏍囧噯鑹�
+    const {
+      color: color1,
+      nextColor: nextColor1,
+      range: range1,
+      nextRange: nextRange1
+    } = Legend.getStandardColorAndNext(factorName, data);
+    const ratio1 = (data - range1) / (nextRange1 - range1);
+    const _color1 = getColorBetweenTwoColors(
+      color1.map((v) => v * 255),
+      nextColor1.map((v) => v * 255),
+      ratio1
+    );
+
+    // 瀵规瘮鑹�
+    const { color, nextColor, range, nextRange } = Legend.getCustomColorAndNext(
+      data,
+      min,
+      max
+    );
+    const ratio = (data - range) / (nextRange - range);
+    const _color = getColorBetweenTwoColors(
+      color.map((v) => v * 255),
+      nextColor.map((v) => v * 255),
+      ratio
+    );
+
+    gridDataStand.push({
+      centerLng: grid.longitude,
+      centerLat: grid.latitude,
+      value: _color1,
+      coordinates: [
+        [grid.point1Lon, grid.point1Lat],
+        [grid.point2Lon, grid.point2Lat],
+        [grid.point3Lon, grid.point3Lat],
+        [grid.point4Lon, grid.point4Lat]
+      ]
+    });
+    gridDataCustom.push({
+      centerLng: grid.longitude,
+      centerLat: grid.latitude,
+      value: _color,
+      coordinates: [
+        [grid.point1Lon, grid.point1Lat],
+        [grid.point2Lon, grid.point2Lat],
+        [grid.point3Lon, grid.point3Lat],
+        [grid.point4Lon, grid.point4Lat]
+      ]
+    });
+  });
+  const url1 = await chartMap.generateGridMap(gridDataStand);
+  const url2 = await chartMap.generateGridMap(gridDataCustom);
+  if (gridBase64Url.value == null) {
+    gridBase64Url.value = url1;
+  }
+  return {
+    url1,
+    url2
+  };
+}
+
+function handleMixClick({ tags = [10, 11], factorName = 'PM25' }) {
+  generateGridFusion(params.value).then(() => {});
 }
 
 function generateDocx() {
-  docLoading.value = true;
   exportDocx(
     '/underway_season_report.docx',
     templateParam,
     `璧拌埅瀛e害鎶ュ憡.docx`,
     {
-      horizontalHeight: 368,
-      verticalWidth: 266,
-      scale: 1.367
+      horizontalHeight: 250,
+      verticalWidth: 568,
+      scale: 2
     }
   ).finally(() => (docLoading.value = false));
 }
@@ -233,19 +821,28 @@
 
   // 涓嶆槸瀛e害绗竴澶╁垯杩斿洖鍏蜂綋鏃ユ湡鑼冨洿
   if (!quarter) {
-    return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    // return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    return startYear == endYear
+      ? `${startYear}骞�${startMonth + 1}鏈�-${endMonth + 1}鏈坄
+      : `${startYear}骞�${startMonth + 1}鏈�-${endYear}骞�${endMonth + 1}鏈坄;
   }
 
   // 楠岃瘉鏄惁涓哄搴斿搴︽渶鍚庝竴涓湀
   const expectedEndMonth = quarter * 3 - 1; // Q1:2(3鏈�), Q2:5(6鏈�), Q3:8(9鏈�), Q4:11(12鏈�)
   if (endMonth !== expectedEndMonth) {
-    return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    // return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    return startYear == endYear
+      ? `${startYear}骞�${startMonth + 1}鏈�-${endMonth + 1}鏈坄
+      : `${startYear}骞�${startMonth + 1}鏈�-${endYear}骞�${endMonth + 1}鏈坄;
   }
 
   // 楠岃瘉鏄惁涓哄搴︽渶鍚庝竴澶�
   const lastDayOfEndMonth = new Date(endYear, endMonth + 1, 0).getDate();
   if (endDate !== lastDayOfEndMonth) {
-    return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    // return `${startYear}骞�${startMonth + 1}鏈�${startDate}鏃�-${endYear}骞�${endMonth + 1}鏈�${endDate}鏃;
+    return startYear == endYear
+      ? `${startYear}骞�${startMonth + 1}鏈�-${endMonth + 1}鏈坄
+      : `${startYear}骞�${startMonth + 1}鏈�-${endYear}骞�${endMonth + 1}鏈坄;
   }
 
   const quarterNames = ['', '绗竴瀛e害', '绗簩瀛e害', '绗笁瀛e害', '绗洓瀛e害'];
@@ -312,3 +909,8 @@
   return `${datePart} ${startTimePart}鑷�${endTimePart}`;
 }
 </script>
+<style scoped>
+.el-checkbox {
+  --el-checkbox-text-color: white;
+}
+</style>

--
Gitblit v1.9.3