Просмотр исходного кода

增加天气功能,修改弹框展示方式 增加单个柱状图模块 城市消防体征页面完成

夜仔 3 лет назад
Родитель
Сommit
d586ae2b9e

+ 1 - 1
.env.prod

@@ -1,3 +1,3 @@
 NODE_ENV='production'
-VUE_APP_BASE_URL = '/'
+VUE_APP_BASE_URL = 'http://120.55.70.156:80/api'
 VUE_APP_ENV_DESC = '正式环境'

+ 1 - 0
.gitignore

@@ -21,3 +21,4 @@ pnpm-debug.log*
 *.njsproj
 *.sln
 *.sw?
+package-lock.json

+ 79 - 81
package-lock.json

@@ -1773,6 +1773,44 @@
                     "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==",
                     "dev": true
                 },
+                "ansi-styles": {
+                    "version": "4.3.0",
+                    "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+                    "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "color-convert": "^2.0.1"
+                    }
+                },
+                "chalk": {
+                    "version": "4.1.1",
+                    "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz",
+                    "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "ansi-styles": "^4.1.0",
+                        "supports-color": "^7.1.0"
+                    }
+                },
+                "color-convert": {
+                    "version": "2.0.1",
+                    "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+                    "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "color-name": "~1.1.4"
+                    }
+                },
+                "color-name": {
+                    "version": "1.1.4",
+                    "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+                    "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+                    "dev": true,
+                    "optional": true
+                },
                 "find-cache-dir": {
                     "version": "2.1.0",
                     "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz",
@@ -1793,6 +1831,25 @@
                         "locate-path": "^3.0.0"
                     }
                 },
+                "has-flag": {
+                    "version": "4.0.0",
+                    "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+                    "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+                    "dev": true,
+                    "optional": true
+                },
+                "loader-utils": {
+                    "version": "2.0.0",
+                    "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.0.tgz",
+                    "integrity": "sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "big.js": "^5.2.2",
+                        "emojis-list": "^3.0.0",
+                        "json5": "^2.1.2"
+                    }
+                },
                 "locate-path": {
                     "version": "3.0.0",
                     "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz",
@@ -1863,6 +1920,16 @@
                         "minipass": "^3.1.1"
                     }
                 },
+                "supports-color": {
+                    "version": "7.2.0",
+                    "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+                    "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "has-flag": "^4.0.0"
+                    }
+                },
                 "terser-webpack-plugin": {
                     "version": "1.4.5",
                     "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz",
@@ -1879,6 +1946,18 @@
                         "webpack-sources": "^1.4.0",
                         "worker-farm": "^1.7.0"
                     }
+                },
+                "vue-loader-v16": {
+                    "version": "npm:vue-loader@16.2.0",
+                    "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.2.0.tgz",
+                    "integrity": "sha512-TitGhqSQ61RJljMmhIGvfWzJ2zk9m1Qug049Ugml6QP3t0e95o0XJjk29roNEiPKJQBEi8Ord5hFuSuELzSp8Q==",
+                    "dev": true,
+                    "optional": true,
+                    "requires": {
+                        "chalk": "^4.1.0",
+                        "hash-sum": "^2.0.0",
+                        "loader-utils": "^2.0.0"
+                    }
                 }
             }
         },
@@ -12287,87 +12366,6 @@
                 }
             }
         },
-        "vue-loader-v16": {
-            "version": "npm:vue-loader@16.2.0",
-            "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.2.0.tgz",
-            "integrity": "sha512-TitGhqSQ61RJljMmhIGvfWzJ2zk9m1Qug049Ugml6QP3t0e95o0XJjk29roNEiPKJQBEi8Ord5hFuSuELzSp8Q==",
-            "dev": true,
-            "optional": true,
-            "requires": {
-                "chalk": "^4.1.0",
-                "hash-sum": "^2.0.0",
-                "loader-utils": "^2.0.0"
-            },
-            "dependencies": {
-                "ansi-styles": {
-                    "version": "4.3.0",
-                    "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
-                    "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
-                    "dev": true,
-                    "optional": true,
-                    "requires": {
-                        "color-convert": "^2.0.1"
-                    }
-                },
-                "chalk": {
-                    "version": "4.1.1",
-                    "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz",
-                    "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==",
-                    "dev": true,
-                    "optional": true,
-                    "requires": {
-                        "ansi-styles": "^4.1.0",
-                        "supports-color": "^7.1.0"
-                    }
-                },
-                "color-convert": {
-                    "version": "2.0.1",
-                    "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
-                    "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
-                    "dev": true,
-                    "optional": true,
-                    "requires": {
-                        "color-name": "~1.1.4"
-                    }
-                },
-                "color-name": {
-                    "version": "1.1.4",
-                    "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
-                    "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
-                    "dev": true,
-                    "optional": true
-                },
-                "has-flag": {
-                    "version": "4.0.0",
-                    "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
-                    "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
-                    "dev": true,
-                    "optional": true
-                },
-                "loader-utils": {
-                    "version": "2.0.0",
-                    "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.0.tgz",
-                    "integrity": "sha512-rP4F0h2RaWSvPEkD7BLDFQnvSf+nK+wr3ESUjNTyAGobqrijmW92zc+SO6d4p4B1wh7+B/Jg1mkQe5NYUEHtHQ==",
-                    "dev": true,
-                    "optional": true,
-                    "requires": {
-                        "big.js": "^5.2.2",
-                        "emojis-list": "^3.0.0",
-                        "json5": "^2.1.2"
-                    }
-                },
-                "supports-color": {
-                    "version": "7.2.0",
-                    "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
-                    "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
-                    "dev": true,
-                    "optional": true,
-                    "requires": {
-                        "has-flag": "^4.0.0"
-                    }
-                }
-            }
-        },
         "vue-router": {
             "version": "4.0.8",
             "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.0.8.tgz",

BIN
src/assets/img/test/icon1.png


+ 1 - 1
src/assets/js/flexible.js

@@ -29,7 +29,7 @@
         setTimeout(() => {
             setRemUnit();
             time = true
-        }, 10)
+        }, 0)
     });
     window.addEventListener("pageshow", function(e) {
         if (e.persisted) {

+ 20 - 0
src/assets/scss/common.scss

@@ -55,6 +55,24 @@ body {
     border-radius: .0625rem;
 }
 
+.el-popover {
+    width: auto !important;
+    &.is-light {
+        background: #000;
+        border-radius: 3%;
+        box-shadow: inset 0 0 0.2rem 0.0125rem #30cfff;
+        background: rgba(0, 44, 110, 0.6);
+        font-size: 0.2rem;
+        padding: 0.1875rem;
+        border: none;
+        color: #FFF;
+        .el-popper__arrow::before {
+            background: #30cfff;
+            display: none;
+        }
+    }
+}
+
 .tableTooltip {
     height: auto;
     width: 4.375rem;
@@ -103,6 +121,7 @@ body {
     }
 }
 
+// 地图弹窗
 .mapTab {
     background: transparent;
     border-radius: 3%;
@@ -215,6 +234,7 @@ body {
     }
 }
 
+// 地图logo
 .amap-logo {
     display: none !important;
 }

+ 1 - 1
src/assets/scss/element-ui.scss

@@ -73,7 +73,7 @@
     // padding: 0;
     border-radius: 3%;
     box-shadow: inset 0 0 0.2rem 0.0125rem #30cfff;
-    background: rgba(0, 44, 110, 0.5);
+    background: rgba(0, 44, 110, 0.6);
     font-size: 0.2rem;
     padding: 0.1875rem;
     .el-popper__arrow::before {

+ 96 - 0
src/components/category-line/index.vue

@@ -0,0 +1,96 @@
+<template>
+  <div ref="echartD" style="width: 100%; height: 100%"></div>
+</template>
+
+<script>
+import * as echarts from "echarts";
+export default {
+  props: {
+    dataMap: { type: Array, default: () => [] },
+  },
+  data() {
+    return {};
+  },
+  watch: {
+    dataMap(val) {
+      this.getData(val);
+    },
+  },
+  mounted() {
+    this.getData();
+  },
+  methods: {
+    getData(val = this.dataMap) {
+      echarts.init(this.$refs.echartD).setOption({
+        grid: {
+          top: 30,
+          left: 30,
+          right: 30,
+          bottom: 50,
+        },
+        xAxis: {
+          type: "category",
+          data: [
+            "1月",
+            "2月",
+            "3月",
+            "4月",
+            "5月",
+            "6月",
+            "7月",
+            "8月",
+            "9月",
+            "10月",
+            "11月",
+            "12月",
+          ],
+          axisLabel: {
+            color: "#FFFFFF",
+          },
+        },
+        tooltip: {
+          trigger: "axis",
+          // axisPointer: {
+          //   // 坐标轴指示器,坐标轴触发有效
+          //   type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
+          // },
+        },
+        yAxis: {
+          type: "value",
+          axisLabel: {
+            color: "#FFFFFF",
+          },
+          splitLine: {
+            lineStyle: {
+              color: "#ccc",
+            },
+          },
+        },
+        series: [
+          {
+            type: "bar",
+            barWidth: 15,
+            itemStyle: {
+              color: "rgb(0,254,160)",
+              borderRadius: [15, 15, 12, 15],
+            },
+            data: val,
+          },{
+            data: val.map(val=>val+40),
+            itemStyle: {
+              color: "#fccf2a",
+            },
+            type: 'line'
+          }
+        ],
+      });
+    },
+    resize() {
+      echarts.init(this.$refs.echartD).resize();
+    },
+  },
+};
+</script>
+
+<style scoped>
+</style>

+ 4 - 9
src/components/category/index.vue

@@ -7,6 +7,7 @@ import * as echarts from "echarts";
 export default {
   props: {
     dataMap: { type: Array, default: () => [] },
+    color: { type: String, default: () => 'rgb(0,254,160)'},
   },
   data() {
     return {};
@@ -26,7 +27,7 @@ export default {
           top: 30,
           left: 30,
           right: 30,
-          bottom: 50,
+          bottom: 30,
         },
         xAxis: {
           type: "category",
@@ -71,17 +72,11 @@ export default {
             type: "bar",
             barWidth: 15,
             itemStyle: {
-              color: "rgb(0,254,160)",
+              color: this.color,
               borderRadius: [15, 15, 12, 15],
             },
             data: val,
-          },{
-            data: val.map(val=>val+40),
-            itemStyle: {
-              color: "#fccf2a",
-            },
-            type: 'line'
-          }
+          },
         ],
       });
     },

+ 1 - 1
src/components/mixins/linstener.js

@@ -38,7 +38,7 @@ export default {
 
                 this.resizeTime = true
                 this.windowWidth = document.documentElement.clientWidth + document.documentElement.clientHeight
-            }, 200);
+            }, 0);
 
         },
         vsClick(val) {

+ 8 - 5
src/components/radar/index.vue

@@ -21,13 +21,13 @@ export default {
   },
   methods: {
     getData() {
+      // let max = this.dataMap.reduce((a, b) => {return a + b.value}, 0)
+      // let totle = this.dataMap.slice().sort((n, m) => {return m.value - n.value})[0].value
       let indicator = this.dataMap.map((val) => {
         return {
           name: val.name,
-          value:val.value,
-          max:  this.dataMap.slice().sort((n, m) => {
-            return m.value - n.value;
-          })[0].value,
+          value: val.value,
+          // max: totle + +(totle * 0.1).toFixed(0),
         };
       });
       echarts.init(this.$refs.echartD).setOption({
@@ -39,6 +39,9 @@ export default {
         legend: {
           show: false,
         },
+        grid: {
+          height: "60%"
+        },
         label: {
           itemStyle: {
             color: "#FFFFFF",
@@ -54,7 +57,7 @@ export default {
         },
         radar: {
           shape: "circle",
-          // radius: ["0%", "100%"],
+          radius: ["0%", "65%"],
           name: {
             color: "#FFFFFF",
           },

+ 1 - 1
src/http/axios.js

@@ -16,7 +16,7 @@ axios.interceptors.response.use(response => {
     // 请求成功
     // 1. 根据自己项目需求定制自己的拦截
     // 2. 然后返回数据
-    if (response.data.status === 'SUCCESS') {
+    if (response.data.status === 'SUCCESS' || response.data.showapi_res_code === 0) {
         return response.data;
     } else {
         ElMessage({

+ 4 - 1
src/http/http.js

@@ -12,7 +12,10 @@ export default {
      * 	后端用户验证信息比如(token)
      */
     get(url, auth = false) {
-        if (auth) {
+        if (url === 'https://weather01.market.alicloudapi.com/area-to-weather') {
+            url += "?area=闵行区"
+            return axios.get(url, { headers: { Authorization: 'APPCODE 0f2b7fce6e104ba8835358b7b59b4fb6' } });
+        } else if (auth) {
             return axios.get(url, { headers: { Authorization: 'Your back-end user authenticates information' } });
         } else {
             return axios.get(url);

+ 4 - 4
src/views/Home.vue

@@ -35,7 +35,7 @@
       <img src="~@a/img/home/title1.png" class="titleLift" />
       <el-col class="flexJ">
         <h4>历史火灾趋势</h4>
-        <category ref="category" style="padding: 0 0.25rem; box-sizing: border-box" :dataMap="timeData"></category>
+        <category-line ref="categoryLine" style="padding: 0 0.25rem; box-sizing: border-box" :dataMap="timeData"></category-line>
       </el-col>
       <el-col class="flexJ">
         <h4>火灾原因占比</h4>
@@ -82,13 +82,13 @@
 <script>
 import treeMap from "@c/treemap";
 import pieThreeD from "@c/pie-3D";
-import category from "@c/category";
+import categoryLine from "@c/category-line";
 import seTable from "@c/se-table";
 import linstener from "@c/mixins/linstener";
 import barChart from "@c/bar";
 import lineSmooth from "@c/line-smooth";
 export default {
-  components: { treeMap, pieThreeD, barChart, lineSmooth, category, seTable },
+  components: { treeMap, pieThreeD, barChart, lineSmooth, categoryLine, seTable },
   data() {
     return {
       reportComplaintList: [],
@@ -128,7 +128,7 @@ export default {
           this.$refs.treeMap,
           this.$refs.pieThreeD1,
           this.$refs.pieThreeD2,
-          this.$refs.category,
+          this.$refs.categoryLine,
           this.$refs.lineSmooth,
           this.$refs.barChart,
         ]),

+ 4 - 4
src/views/fire-data-analysis.vue

@@ -25,7 +25,7 @@
               </el-form>
             </el-row>
             <el-row class="fireBar">
-              <category ref="category" :dataMap="timeData"></category>
+              <category-line ref="categoryLine" :dataMap="timeData"></category-line>
             </el-row>
           </el-row>
         </el-col>
@@ -191,13 +191,13 @@
 
 <script>
 import linstener from "@c/mixins/linstener";
-import category from "@c/category";
+import categoryLine from "@c/category-line";
 import pieThreeD from "@c/pie-3D";
 import seTable from "@c/se-table";
 import AMap from 'AMap'
 import map from "@c/mixins/map";
 export default {
-  components: { category, pieThreeD, seTable },
+  components: { categoryLine, pieThreeD, seTable },
   mixins: [linstener,map],
   data() {
     return {
@@ -336,7 +336,7 @@ export default {
       "resize",
       () =>
         this.resizeTimeActions([
-          this.$refs.category,
+          this.$refs.categoryLine,
           this.$refs.pieThreeD1,
           this.$refs.pieThreeD2,
         ]),

+ 419 - 10
src/views/fire-signs.vue

@@ -1,21 +1,430 @@
 <template>
-  <el-row></el-row>
+  <el-row class="contentBox">
+    <transition name="el-fade-in-linear">
+      <el-col class="leftBox" v-show="leftBtn">
+        <el-col class="leftTop">
+          <h4>风险等级对比图</h4>
+          <el-row class="threeBox">
+            <div class="flexBoxE">
+              <pie-three-d ref="pieThreeD" :dataMap="fireCauseRatioList" :distance="200"></pie-three-d>
+            </div>
+          </el-row>
+        </el-col>
+        <el-col class="leftBot">
+          <h4>火灾趋势图</h4>
+          <el-row class="leftBotContent">
+            <el-row class="selectBar">
+              <el-row>
+                <el-button size="mini" @click="searchTime('one')" :class="{ btnClick: timeArea === 'one' }">近一年</el-button>
+                <el-button size="mini" @click="searchTime('three')" :class="{ btnClick: timeArea === 'three' }">近三年</el-button>
+                <el-button size="mini" @click="searchTime('five')" :class="{ btnClick: timeArea === 'five' }">近五年</el-button>
+              </el-row>
+              <el-form :inline="true" size="mini" :model="barForm">
+                <el-form-item label="">
+                  <el-select v-model="barForm.address" @change="getTrend()" filterable clearable placeholder="街道" >
+                    <el-option :label="item" :value="item" v-for="(item,ind) in fireAddressList" :key="ind"></el-option>
+                  </el-select>
+                </el-form-item>
+                <el-form-item label="">
+                  <el-select @change="getTrend()" v-model="barForm.fireType" placeholder="火灾类型" filterable clearable >
+                    <el-option :value="item"  v-for="(item,ind) in fireTypeList" :key="ind" ></el-option>
+                  </el-select>
+                </el-form-item>
+              </el-form>
+            </el-row>
+            <el-row class="fireBar">
+              <category-line ref="categoryLine" :dataMap="timeData"></category-line>
+            </el-row>
+          </el-row>
+        </el-col>
+      </el-col>
+    </transition>
+    <transition name="el-fade-in-linear">
+      <el-col class="centerBox" :style="{'max-width':leftBtn && rightBtn ? '8rem' :!leftBtn &&  !rightBtn ? '100%' : leftBtn ||  rightBtn ? '16rem' : '8rem'}">
+        <el-row class="leftBtn btnW" @click="leftBtnClick()">
+          <i :class="leftBtn ? 'el-icon-arrow-left' : 'el-icon-arrow-right'"></i>
+        </el-row>
+        <el-row class="centerContent" id="mapF"></el-row>
+        <el-row class="rightBtn btnW" @click="rightBtnClick()">
+          <i :class="rightBtn ? 'el-icon-arrow-right' : 'el-icon-arrow-left'"></i>
+        </el-row>
+      </el-col>
+    </transition>
+    <transition name="el-fade-in-linear">
+      <el-col class="rightBox" v-show="rightBtn">
+        <div class="rightContent">
+          <el-col class="rightTop">
+            <h4>闵行区消防情况</h4>
+              <radar-chart
+                v-if="reportComplaintList.length > 0"
+                :dataMap="reportComplaintList"
+                ref="radarChart"
+              ></radar-chart>
+          </el-col>
+          <el-col class="rightTop">
+            <h4>各街镇单位情况</h4>
+             <category ref="category" :dataMap="timeData"></category>
+          </el-col>
+          <el-col class="rightBot">
+            <h4>挂牌督改情况</h4>
+            <se-table
+              ref="seTable"
+              :dataMap="tableData"
+              :headerData="headerData"
+              :key="windowWidth"
+            ></se-table>
+          </el-col>
+        </div>
+      </el-col>
+    </transition>
+  </el-row>
 </template>
 
 <script>
+import linstener from "@c/mixins/linstener";
+import categoryLine from "@c/category-line";
+import category from "@c/category";
+import pieThreeD from "@c/pie-3D";
+import seTable from "@c/se-table";
+import AMap from 'AMap'
+import map from "@c/mixins/map";
+import radarChart from "@c/radar";
 export default {
-  methods:{
-    getdata(){
-      
+  components: { categoryLine, pieThreeD, seTable, radarChart, category },
+  mixins: [linstener,map],
+  data() {
+    return {
+      tableData: [],
+      headerData: [
+        { prop: "address", name: "挂牌时间" },
+        { prop: "burnedArea", name: "单位名称" },
+        { prop: "propertyLoss", name: "单位地址" },
+        { prop: "deathToll", name: "预计完成" },
+        { prop: "nonFatal", name: "整改方案" },
+        { prop: "disasterHome", name: "当前处理情况" },
+      ],
+      fireAddressList: [],
+      fireTypeList: [],
+      reportComplaintList: [
+           {name: "查封情况",value: 34},
+           {name: "整改情况",value: 55},
+           {name: "消防隐患",value: 56},
+           {name: "设备设施",value: 58},
+           {name: "处罚情况",value: 12},
+           {name: "检查数量",value: 86},
+           {name: "接警处",value: 78},
+           {name: "出文情况",value: 41},
+      ],
+      fireCauseRatioList: [
+        {name: "挂牌督办",value: 34,itemStyle: {opacity: 0.9,}},
+        {name: "存在隐患",value: 22,itemStyle: {opacity: 0.9,}},
+        {name: "加强管理",value: 12,itemStyle: {opacity: 0.9,}},
+        {name: "相对安全",value: 32,itemStyle: {opacity: 0.9,}},
+      ],
+      timeData: [],
+      barForm: {
+        fireType: "",
+        address: "",
+      },
+      timeArea: 'one',
+    };
+  },
+  created() {
+    this.getData();
+  },
+  watch:{
+
+  },
+  mounted() {
+    window.addEventListener(
+      "resize",
+      () =>
+        this.resizeTimeActions([
+          this.$refs.categoryLine,
+          this.$refs.category,
+          this.$refs.radarChart,
+          this.$refs.pieThreeD,
+        ]),
+      true
+    );
+    this.initMap()
+  },
+  methods: {
+    // 添加标点
+    addMarkerInfo(position, content, value) {
+        // this.map.getIsOpen();
+        this.map.clearInfoWindow();
+        var infoWindow = new AMap.InfoWindow({
+            isCustom: true, //使用自定义窗体
+            closeWhenClickMap: true,
+            content: content || `
+                <div class="tableTooltip mapTab">
+                  <div class="tableTitle">
+                    <div>${'单位及执法情况'}</div>
+                  </div>
+                  <el-row class="tableContent">
+                    <div>单位名称:${value.callingUp}</div>
+                    <div>单位地址:${'XX路135弄'}</div>
+                    <div>法人:${'张三'}</div>
+                    <div>管理人:${'李四'}</div>
+                    <div>历史检查次数:<a>${'6次'}</a></div>
+                    <div class="divTitle">行政许可记录</div>
+                    <div>审核时间:${'2021-06-26'}</div>
+                    <div>验收时间:${'2021-06-26'}</div>
+                    <div>安检时间:${'2021-06-26'}</div>
+                    <div>历史隐患数:${'2处'}</div>
+                    <div class="divTitle">历史处罚情况</div>
+                    <div>历史火灾数:${'2'}</div>
+                    <div>单位自主管理情况:<a>点击查看</a></div>
+                  </el-row>
+                </div>`,
+            offset: new AMap.Pixel(16, -30)
+        });
+        infoWindow.open(this.map, position);
+    },
+    async getData() {
+      let res = await this.$axios.all([
+        this.$axios.get(this.$api.fire.fireType),
+        this.$axios.get(this.$api.fire.fireAddress),
+      ]);
+      if (res[0]) this.fireTypeList = res[0].data;
+      if (res[1]) this.fireAddressList = res[1].data;
+      this.getTrend();
+      // this.getFireCause();
+      this.getFireStatis();
+      // this.getPage();
+    },
+    // 火灾趋势图 柱状图
+    async getTrend() {
+      let res = await this.$axios.get(
+        this.$api.fire.trendQuery +
+          "?" +
+          this.$qs.stringify({
+            year: new Date().getFullYear(),
+            address: this.barForm.address,
+            fireType: this.barForm.fireType,
+            startTime: this.$store.state.timeList[0] || "",
+            endTime: this.$store.state.timeList[1] || "",
+          })
+      );
+      if (res) this.timeData = res.data;
+    },
+    // 占比图 饼图
+    async getFireCause() {
+      let res = await this.$axios.get(
+        this.$api.fire.fireCauseRatio +
+          "?" +
+          this.$qs.stringify({
+            startTime: this.$store.state.timeList[0] || "",
+            endTime: this.$store.state.timeList[1] || "",
+          })
+      );
+      if (res){
+        this.fireCauseRatioList = res.data.map((val) => {
+          return {
+            name: val.fireType || " ",
+            value: val.radio ? val.radio * 100 : 0,
+            itemStyle: {
+              opacity: 0.9,
+            },
+          };
+        })
+      }
+    },
+    // 详细火灾情况,表格val
+    async getFireStatis() {
+      let res = await this.$axios.get(
+        this.$api.fire.fireStatistics +
+          "?" +
+          this.$qs.stringify({
+            current: 1,
+            size: 1000,
+            startTime: this.$store.state.timeList[0] || "",
+            endTime: this.$store.state.timeList[1] || "",
+          })
+      );
+      if (res){ 
+          this.tableData = res.data.records;
+        // }
+      }
+    },
+    // 实时警情处理
+    async getPage() {
+      let res = await this.$axios.get(this.$api.house.page +
+          "?" +
+          this.$qs.stringify({
+            current: 1,
+            size: 100,
+            startTime: "2020-03-03 00:00:00",
+            endTime: "2020-03-03 23:59:59",
+          })
+      );
+      if (res) this.tableData = res.data;
+    },
+    searchTime(val){
+      this.timeArea = val
     }
-  }};
+  },
+};
 </script>
 
 <style lang="scss" scoped>
-.el-row {
-  width: 100%;
-  height: 100%;
-  background: url(~@a/img/test/bg6.png) no-repeat;
-  background-size: 100% 100%;
+.abc{
+  background: #000;
+}
+.contentBox {
+  font-family: "DS", "DS-B", "DS-BB", "DS-BS";
+  & > .el-col {
+    flex: 1;
+    height: 100%;
+    max-width: 8rem;
+  }
+  .leftBox {
+    display: flex;
+    justify-content: space-between;
+    flex-direction: column;
+    box-sizing: border-box;
+    & > .el-col {
+      flex: 1;
+      background: url(~@a/img/enforce/bg1.png) no-repeat;
+      background-size: 100% 100%;
+      position: relative;
+      max-height: 51%;
+      overflow: hidden;
+      h4 {
+        font-size: 0.2125rem;
+        position: absolute;
+        left: 0;
+        right: 0;
+        top: 0;
+        margin: 0 auto;
+        text-align: center;
+        color: #00ffff;
+      }
+    }
+    .leftTop {
+      padding: 0.375rem 0.45rem 0.1875rem;
+      margin-bottom: 0.125rem;
+      display: flex;
+      justify-content: center;
+      align-items: center;
+      .threeBox {
+        width: 100%;
+        height: 100%;
+        position: relative;
+        justify-content: space-between;
+        align-items: center;
+        flex-wrap: nowrap;
+        & > .flexBoxE {
+          flex: 1;
+          display: flex;
+          flex-direction: column;
+          justify-content: space-between;
+          width: 100%;
+          height: 100%;
+          box-sizing: border-box;
+          .el-form {
+            text-align: center;
+            .el-form-item {
+              margin: 0;
+            }
+          }
+        }
+        .line {
+          flex: none;
+          width: 1px;
+          height: 3.75rem;
+          opacity: 1;
+          background: linear-gradient(
+            rgba(255, 255, 255, 0),
+            #30cfff,
+            rgba(255, 255, 255, 0)
+          );
+          // box-shadow: 0 0 .125rem .0375rem #30cfff;
+        }
+      }
+    }
+    .leftBot {
+      display: flex;
+      justify-content: space-between;
+      align-items: center;
+      padding: 0.375rem 0.45rem 0.1875rem;
+      box-sizing: border-box;
+      width: 100%;
+      overflow: hidden;
+      .leftBotContent {
+        width: 100%;
+        height: 100%;
+        display: block;
+        .selectBar {
+          width: 100%;
+          display: flex;
+          justify-content: space-between;
+          height: 0.875rem;
+          padding: 0.25rem 0;
+          .el-row{
+            display: flex;
+            .el-button {
+              // width: 0.375rem;
+              height: 0.325rem;
+              min-height: auto;
+              padding: 0 .0625rem;
+              margin-right: 0.075rem;
+              margin-left: 0;
+              background: #000707;
+              color: #fff;
+              border: 1px solid;
+              box-sizing: border-box;
+              border-radius: .0375rem;
+              font-size: 0.15rem;
+              border-image: linear-gradient(0deg, #0461c2 0%, #0ecdf1 100%) 1 1;
+            }
+            .btnClick {
+              color: #fccf2a;
+              border-image: linear-gradient(0deg, #ff6800 0%, #fccf2a 100%) 1 1;
+            }
+          }
+        }
+        .fireBar {
+          height: calc(100% - 0.875rem);
+        }
+      }
+    }
+  }
+  
+  .rightBox {
+    box-sizing: border-box;
+    .rightContent{
+      display: flex;
+      justify-content: space-between;
+      flex-direction: column;
+      width: 100%;
+      height: 100%;
+      & > .el-col {
+        flex: 1;
+        max-height: 34%;
+        background: url('~@a/img/home/box-bg.png') no-repeat;
+        background-size: 100% 100%;
+        position: relative;
+        padding: .375rem .375rem .25rem;
+        box-sizing: border-box;
+        width: 100%;
+        overflow: hidden;
+        h4 {
+          font-size: 0.2125rem;
+          position: absolute;
+          left: 0;
+          right: 0;
+          top: 0;
+          margin: 0 auto;
+          text-align: center;
+          color: #00ffff;
+        }
+      }
+      .rightTop{
+        margin-bottom: 0.125rem;
+      }
+    }
+  }
 }
 </style>

+ 39 - 1
src/views/head.vue

@@ -3,6 +3,10 @@
     <span class="title">闵行区消防安全与综合救援管理平台</span>
     <div class="day">{{ dateDay }}</div>
     <div class="time">{{ dataTime }}</div>
+    <div class="weather">
+      <img v-if="weatherObj.weather_pic" :src="weatherObj.weather_pic || ''" alt="">
+      <span v-if="weatherObj.weather">{{weatherObj.weather}}   {{weatherObj.temperature}}℃</span>
+    </div>
     <el-row class="timeSelect">
       <img src="~@a/img/home/circle_box.png" alt="" class="timeImage" />
       <el-button size="mini" @click="timeTypeClick('day')">今日</el-button>
@@ -35,6 +39,7 @@ export default {
     return {
       dateDay: "",
       dataTime: "",
+      weatherObj:{},
       dataWeekList: ["一", "二", "三", "四", "五", "六", "七"],
       value1: [],
       defaultTime: [
@@ -47,6 +52,10 @@ export default {
     this.value1 = this.$store.state.timeList.map((val) => {
       return val;
     });
+    this.getWeather();
+    setInterval(() => {
+      this.getWeather();
+    },1000*60*30)
   },
   mounted() {
     setInterval(() => {
@@ -71,11 +80,23 @@ export default {
     }, 1000);
   },
   methods: {
+    async getWeather() {
+      let res = await this.$axios.get(
+        "https://weather01.market.alicloudapi.com/area-to-weather"
+      );
+      if(res.showapi_res_code === 0){
+        this.weatherObj = res.showapi_res_body.now
+        console.log(this.weatherObj)
+      }
+    },
     timeTypeClick(val) {
       this.$store.commit("changTypeTime", val);
     },
     dateTimeChange(val) {
-      this.$store.commit("changTimeList", val.map(val=>val.Format("yyyy-MM-dd hh:mm:ss")));
+      this.$store.commit(
+        "changTimeList",
+        val.map((val) => val.Format("yyyy-MM-dd hh:mm:ss"))
+      );
     },
   },
 };
@@ -115,6 +136,23 @@ export default {
     font-size: 0.35rem;
     line-height: 0.35rem;
     color: #fbb03b;
+    font-family: "DS", "DS-B", "DS-BB", "DS-BS";
+  }
+  .weather{
+    position: absolute;
+    left: 5.375rem;
+    top: 0.125rem;
+    display: flex;
+    justify-content: center;
+    align-items: center;
+    img{
+      display: block;
+      width: .375rem;
+    }
+    span{
+      font-size: .2rem;
+      margin-left: .125rem;
+    }
   }
   .timeSelect {
     position: absolute;

+ 4 - 4
src/views/water-sources.vue

@@ -123,8 +123,8 @@
               :label="item.name"
             >
               <template v-if="item.prop === 'type'" #default="scope">
-                <el-tooltip placement="left">
-                  <template #content>
+                <el-popover effect="dark" trigger="hover" placement="left">
+                  <template #default>
                     <div class="tableTooltip">
                       <div class="tableTitle">
                         <div>{{scope.row.type}}</div>
@@ -143,12 +143,12 @@
                       </el-row>
                     </div>
                   </template>
-                  <template>
+                  <template #reference>
                     <div>
                       {{ item.prop === 'status' ? (scope.row[item.prop] == 1 ? '可用' : '不可用') : scope.row[item.prop]}}
                     </div>
                   </template>
-                </el-tooltip>
+                </el-popover>
               </template>
               <template v-else #default="scope">
                   {{ item.prop === 'status' ? (scope.row[item.prop] == 1 ? '可用' : '不可用') : scope.row[item.prop]}}