From dca26bac2c05fcfc9c7ed477b32a7fab1295a688 Mon Sep 17 00:00:00 2001
From: riku <risaku@163.com>
Date: 星期二, 21 十月 2025 17:48:10 +0800
Subject: [PATCH] 2025.10.21 修改嫉妒报告生成逻辑

---
 src/utils/chart/factor-data-parser.js             |   14 ++-
 src/utils/chart/chart-option.js                   |   11 ++
 src/views/sourcetrace/SourceTrace.vue             |   18 ++-
 public/underway_season_report.docx                |    0 
 src/api/index.js                                  |    8 +-
 src/components.d.ts                               |    1 
 src/utils/chart/chart-to-img.js                   |    3 
 src/views/historymode/component/MissionReport.vue |  131 ++++++++++++++++++++++----------
 src/components/chart/RealTimeLineChart.vue        |    4 
 9 files changed, 125 insertions(+), 65 deletions(-)

diff --git a/public/underway_season_report.docx b/public/underway_season_report.docx
index 57705e6..786aef8 100644
--- a/public/underway_season_report.docx
+++ b/public/underway_season_report.docx
Binary files differ
diff --git a/src/api/index.js b/src/api/index.js
index 8eac640..19b0941 100644
--- a/src/api/index.js
+++ b/src/api/index.js
@@ -13,10 +13,10 @@
 }
 
 if (debug) {
-  // ip1 = 'http://192.168.0.103:8084/';
-  ip1 = 'http://localhost:8084/';
-  // ws = `192.168.0.103:9031`;
-  ws = `localhost:9031`;
+  ip1 = 'http://192.168.0.103:8084/';
+  // ip1 = 'http://localhost:8084/';
+  ws = `192.168.0.103:9031`;
+  // ws = `localhost:9031`;
 }
 
 const $http = axios.create({
diff --git a/src/components.d.ts b/src/components.d.ts
index 462a661..0fc11c1 100644
--- a/src/components.d.ts
+++ b/src/components.d.ts
@@ -37,6 +37,7 @@
     ElForm: typeof import('element-plus/es')['ElForm']
     ElFormItem: typeof import('element-plus/es')['ElFormItem']
     ElIcon: typeof import('element-plus/es')['ElIcon']
+    ElImage: typeof import('element-plus/es')['ElImage']
     ElInput: typeof import('element-plus/es')['ElInput']
     ElLink: typeof import('element-plus/es')['ElLink']
     ElOption: typeof import('element-plus/es')['ElOption']
diff --git a/src/components/chart/RealTimeLineChart.vue b/src/components/chart/RealTimeLineChart.vue
index bd75435..5ed46c8 100644
--- a/src/components/chart/RealTimeLineChart.vue
+++ b/src/components/chart/RealTimeLineChart.vue
@@ -33,7 +33,9 @@
       default: 1
     },
     // 寮傚父鏁版嵁绱㈠紩鑼冨洿闆嗗悎锛孾[i1,i2], [i3,i4],...]
-    exceptionIndexArr: Array
+    exceptionIndexArr: Array,
+    // 鑷畾涔塝杞磋寖鍥�
+    customRange: Boolean
   },
   data() {
     return {
diff --git a/src/utils/chart/chart-option.js b/src/utils/chart/chart-option.js
index 89a9380..2048725 100644
--- a/src/utils/chart/chart-option.js
+++ b/src/utils/chart/chart-option.js
@@ -161,7 +161,8 @@
   tag,
   animation = true,
   defaultGrid,
-  title
+  title,
+  customRange
 ) {
   var fontSize = fGetChartFontSize();
   const _grid = defaultGrid
@@ -248,10 +249,14 @@
         minInterval: yMinInterval ? yMinInterval : 1,
         intervel: 1,
         min: function (value) {
-          return Math.floor(value.min);
+          if (customRange != false) {
+            return Math.floor(value.min);
+          }
         },
         max: function (value) {
-          return Math.ceil(value.max);
+          if (customRange != false) {
+            return Math.ceil(value.max);
+          }
         }
       },
       {
diff --git a/src/utils/chart/chart-to-img.js b/src/utils/chart/chart-to-img.js
index 71e197c..921a4ca 100644
--- a/src/utils/chart/chart-to-img.js
+++ b/src/utils/chart/chart-to-img.js
@@ -27,7 +27,8 @@
     true,
     false,
     { left: '7%', right: '7%', top: '10%', bottom: '10%' },
-    series.name
+    series.name,
+    false
   );
   if (exceptionIndexArr) {
     const visualMap = baseVisualMap(exceptionIndexArr);
diff --git a/src/utils/chart/factor-data-parser.js b/src/utils/chart/factor-data-parser.js
index 0eb8dfb..1b45a7c 100644
--- a/src/utils/chart/factor-data-parser.js
+++ b/src/utils/chart/factor-data-parser.js
@@ -9,7 +9,7 @@
   });
   return newTimes;
 }
-function refreshY(factorDatas) {
+function refreshY(factorDatas, useRange) {
   const allSeries = new Map();
   for (const key in factorDatas.factor) {
     if (Object.hasOwnProperty.call(factorDatas.factor, key)) {
@@ -35,9 +35,11 @@
       const newSeries = e.datas.map((v) => v.factorData);
       series.data = series.data.concat(newSeries);
       // 璁$畻鏁版嵁鑼冨洿
-      const { min, max } = dataRange(series.data);
-      series.min = min;
-      series.max = max;
+      if (useRange != false) {
+        // const { min, max } = dataRange(series.data);
+        // series.min = min;
+        // series.max = max;
+      }
       // 璁板綍鏈�鏂版暟鎹�
       series.currentData =
         Math.round(series.data[series.data.length - 1] * 10) / 10;
@@ -72,9 +74,9 @@
 }
 
 export default {
-  parseData(factorDatas, selectedFactors) {
+  parseData(factorDatas, selectedFactors, useRange) {
     const xAxis = refreshX(factorDatas);
-    const allSeries = refreshY(factorDatas);
+    const allSeries = refreshY(factorDatas, useRange);
     return toList(xAxis, allSeries, selectedFactors);
   }
 };
diff --git a/src/views/historymode/component/MissionReport.vue b/src/views/historymode/component/MissionReport.vue
index 9eb05e6..12d1ae1 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>
@@ -250,6 +255,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 +284,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 +321,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) => {
@@ -340,6 +349,7 @@
     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) => {
@@ -359,19 +369,26 @@
                 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
+                  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,
+                    index: index3 + 1 + '',
+                    showPollutedArea: formObj.value.showPollutedArea,
                     _title:
                       (clue.pollutedArea.street ?? '') +
                       (clue.pollutedArea.streetNumber ?? '') +
@@ -385,24 +402,25 @@
                       ) +
                       ' - ' +
                       moment(clue.pollutedData.endTime).format('HH:mm:ss'),
-                    _riskRegion:
-                      (clue.pollutedArea.address ?? '') +
-                      (clue.pollutedArea.street ?? '') +
-                      (clue.pollutedArea.streetNumber ?? '') +
-                      (clue.pollutedArea.direction ?? ''),
+                    _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('\n')
-                        : '鏃�'
+                    // _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 +442,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 +504,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 +531,8 @@
               gridImgUrl1: url1,
               // 瀵规瘮鑹茬綉鏍煎浘
               gridImgUrl2: url2,
-              infoDes: infoDes
+              infoDes: infoDes,
+              infoDes2: infoDes2
             });
           }
         );
@@ -677,19 +713,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害'];
diff --git a/src/views/sourcetrace/SourceTrace.vue b/src/views/sourcetrace/SourceTrace.vue
index 73dcd07..1d6fb6d 100644
--- a/src/views/sourcetrace/SourceTrace.vue
+++ b/src/views/sourcetrace/SourceTrace.vue
@@ -510,13 +510,17 @@
   factorDatas.setData(obj.pollutedData.historyDataList, 0, () => {
     for (const key in obj.pollutedData.statisticMap) {
       const value = obj.pollutedData.statisticMap[key];
-      value._chartOptions = factorDataParser.parseData(factorDatas, [
-        {
-          label: value.factorName,
-          name: value.factorName,
-          value: value.factorId + ''
-        }
-      ]);
+      value._chartOptions = factorDataParser.parseData(
+        factorDatas,
+        [
+          {
+            label: value.factorName,
+            name: value.factorName,
+            value: value.factorId + ''
+          }
+        ],
+        false
+      );
     }
     // obj._chartOptions = factorDataParser.parseData(factorDatas, [
     //   {

--
Gitblit v1.9.3