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 |  303 ++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 228 insertions(+), 75 deletions(-)

diff --git a/src/views/historymode/component/MissionReport.vue b/src/views/historymode/component/MissionReport.vue
index 9eb05e6..8e772be 100644
--- a/src/views/historymode/component/MissionReport.vue
+++ b/src/views/historymode/component/MissionReport.vue
@@ -14,14 +14,19 @@
         ></OptionLocation2>
       </el-form-item>
       <OptionTime v-model="formObj.timeArray"></OptionTime>
-      <el-form-item label="绉婚櫎鍏朵粬鍖哄幙" prop="removeOtherDistrict">
+      <el-form-item label="鍖哄幙绛涢��" prop="removeOtherDistrict">
         <el-checkbox v-model="formObj.removeOtherDistrict"
           >绉婚櫎鍏朵粬鍖哄幙</el-checkbox
         >
       </el-form-item>
-      <el-form-item label="绉婚櫎鏈薄鏌撴簮" prop="removeNoPollutedSource">
+      <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>
@@ -45,7 +50,7 @@
       <!-- <el-form-item>
         <el-image :src="base64Url" fit="fill" :preview-src-list="[base64Url]" />
       </el-form-item> -->
-      <!-- <el-form-item>
+      <el-form-item>
         <el-button
           type="primary"
           class="el-button-custom"
@@ -63,7 +68,7 @@
             />
           </el-form-item>
         </el-form-item>
-      </el-form-item> -->
+      </el-form-item>
     </el-form>
   </CardDialog>
 </template>
@@ -193,6 +198,19 @@
             }
           ]
         }
+      ],
+      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鈥︹��'
+        }
       ]
     }
   ],
@@ -250,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);
@@ -275,7 +297,7 @@
   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) => factorName[factor])
         .join('銆�');
@@ -312,7 +334,7 @@
       item._startTime = t[0];
       item._time = t[1];
       item._kilometres = Math.round(item.kilometres / 1000);
-      item._airQulity = `AQI锛�${item.aqi}锛�${item.pollutionDegree}锛塦;
+      item._airQulity = `${item.aqi}锛�${item.pollutionDegree}锛塦;
 
       const factorNames = radioOptions(TYPE0).map((e) => e.name);
       item._dataStatistics = item.dataStatistics.filter((e) => {
@@ -332,6 +354,34 @@
 }
 
 function generateClueByRiskArea(param) {
+  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,
@@ -340,73 +390,149 @@
     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}`,
-          clueByFactorList: clues
-            .groupBy((e) => e.factorTag)
-            .map((item2, index2) => {
-              const { key: factorTag, values: clues2 } = item2;
-              const factorNames = [...new Set(clues2.flatMap((e) => e.factors))]
+          _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('銆�');
-              return {
-                index: index2 + 1,
-                factor: factorNames,
-                clues: clues2.map((item3, index3) => {
-                  // const _riskRegion = [];
-                  // if (clue.pollutedArea.address) {
-                  //   _riskRegion.push(clue.pollutedArea.address);
-                  // }
-                  // if (clue.pollutedArea.streetNumber) {
-                  //   _riskRegion.push(clue.pollutedArea.streetNumber);
-                  // }
-                  // if (clue.pollutedArea.roadinter) {
-                  //   _riskRegion.push(clue.pollutedArea.roadinter);
-                  // }
-                  const clue = item3.clue
-                  return {
-                    index: index3+1,
-                    _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:
-                      (clue.pollutedArea.address ?? '') +
-                      (clue.pollutedArea.street ?? '') +
-                      (clue.pollutedArea.streetNumber ?? '') +
-                      (clue.pollutedArea.direction ?? ''),
-                    _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('\n')
-                        : '鏃�'
-                  };
-                })
-              };
-            })
+                .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)}绫筹紱`
+          //             };
+          //           })
+          //         };
+          //       })
+          //     };
+          //   })
         };
       });
   });
@@ -424,13 +550,17 @@
   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 + ''
-        }
-      ]);
+      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)
@@ -482,6 +612,19 @@
                 : '缃戞牸鍐呭彲鑳藉瓨鍦ㄩ殣钘忛闄╂簮'
           };
         });
+        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];
@@ -496,7 +639,8 @@
               gridImgUrl1: url1,
               // 瀵规瘮鑹茬綉鏍煎浘
               gridImgUrl2: url2,
-              infoDes: infoDes
+              infoDes: infoDes,
+              infoDes2: infoDes2
             });
           }
         );
@@ -677,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害'];

--
Gitblit v1.9.3