From 2e876ee0ba719df9a0008c2eb93de5a6d3697ee7 Mon Sep 17 00:00:00 2001
From: chenyabin <Chenab123!>
Date: 星期二, 13 四月 2021 11:01:20 +0800
Subject: [PATCH] 修改 图层控制和搜索组件联动。

---
 src/components/panel/LegendPanel.vue |  233 ++++++++++++++++-----------------------------------------
 1 files changed, 67 insertions(+), 166 deletions(-)

diff --git a/src/components/panel/LegendPanel.vue b/src/components/panel/LegendPanel.vue
index ed870b4..36e0efd 100644
--- a/src/components/panel/LegendPanel.vue
+++ b/src/components/panel/LegendPanel.vue
@@ -1,155 +1,70 @@
 <template>
   <div class="legend-panel">
-
     <transition name="fade">
-      <div class="legend-content" v-show="legendControl">
-        <div class="legend-content-box" v-for="(item,index) in legendContents" :key="index">
-          <p><span>{{ item.title }}</span></p>
-          <div :class="index === 5 ? '':'under-line'"></div>
-          <ul  >
-            <!--            <div >-->
-            <li v-for="(ite,inde) in item.items" :key="inde">
-              <img :src='ite.legendImage' alt=''>
-              <span>{{ ite.legendContent }}</span>
+      <div :class="'legend-content map-background'" v-show="isShow">
+        <div class="legend-content-box" v-for="(item,index) in serviceLayers" :key="index">
+          <p><span>{{ item.name }}</span></p>
+          <div class="map-under-line"></div>
+          <ul>
+            <li v-for="(ite,idx) in item.layers" :key="idx">
+              <img :src="ite.legendImage===undefined?'../.././assets/images/map-pages/setting.png':ite.legendImage" alt=''>
+              <span>{{ ite.name }}</span>
             </li>
-
-            <!--            </div>-->
           </ul>
-
         </div>
       </div>
     </transition>
-    <div class="legend-icon unactive" @click="legendChange()">
-      <i class="el-icon-more-outline"></i>
-      <span>鍥句緥</span>
-    </div>
+    <el-tooltip :popper-class="'map-tooltip'" effect="dark" content="鍥句緥" placement="left">
+      <div :class="this.isShow?'legend-btn map-btn-active':'legend-btn map-btn-unactive'"
+           @click="legendChange()">
+        <i class="el-icon-more-outline"></i>
+      </div>
+    </el-tooltip>
   </div>
 </template>
-
 <script>
+import { LayerWasteWater } from '../../conf/layers/LayerWasteWater'
+import { LayerWasteGas } from '../../conf/layers/LayerWasteGas'
+import { LayerWasteSolid } from '../../conf/layers/LayerWasteSolid'
+import { LayerAirQuality } from '../../conf/layers/LayerAirQuality'
+import { LayerEnvRisk } from '../../conf/layers/LayerEnvRisk'
+import { LayerSoilGroundWater } from '../../conf/layers/LayerSoilGroundWater'
+import { LayerPipeLines } from '../../conf/layers/LayerPipeLines'
+import { LayerPk } from '../../conf/layers/LayerPk'
+import { LayerArea } from '../../conf/layers/LayerArea'
+import bus from '@/eventBus'
 export default {
   name: 'LegendPanel',
   data () {
     return {
       // 鎺у埗鍥句緥 鍐呭鐨� 鏄剧ず/闅愯棌
-      legendControl: false,
-      // 鍥鹃噷瀛樺偍鏁版嵁
-      legendContents: [
-        {
-          title: '浼佷笟',
-          items: [
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '涓浗鐭冲寲'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '娌圭敯浼佷笟      '
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鐐煎寲浼佷笟'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '閿�鍞紒涓�'
-            }
-          ]
-        },
-        {
-          title: '姘存儏',
-          items: [
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '姘存枃绔�'
-            }
-          ]
-        },
-        {
-          title: '绠$嚎',
-          items: [
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '澶╃劧姘旂绾�'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '澶╃劧姘斿満绔�'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鎴愬搧娌圭绾�'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鎴愬搧娌瑰満绔�'
-            }
-          ]
-        },
-        {
-          title: '鍙伴',
-          items: [
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鍙伴瀹炴祴涓績'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鍙伴瀹炴祴璺緞'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鍙伴棰勬祴涓績'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鍙伴棰勬祴璺緞'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鍙伴褰撳墠涓績'
-            }
-          ]
-        },
-        {
-          title: '闄嶆按绛夌骇(鍗曚綅锛歮m)',
-          items: [
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '灏忛洦0-5'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '涓洦5-10'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '澶ч洦10-20'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '鏆撮洦20-50'
-            },
-            {
-              legendImage: '../.././assets/images/map-pages/setting.png',
-              legendContent: '澶ф毚闆�50-100'
-            }
-          ]
-        }
-      ]
+      isShow: false,
+      serviceLayers: [LayerSoilGroundWater, LayerEnvRisk, LayerAirQuality, LayerWasteSolid, LayerWasteGas, LayerWasteWater, LayerArea, LayerPk, LayerPipeLines]
     }
+  },
+  mounted () {
+    const that = this
+    bus.$on('changeState', function (state) {
+      if (state.num !== 4 && state.type) {
+        that.isShow = false
+      }
+    })
   },
   methods: {
     // 鍥炬爣 鎺у埗鍐呭鐨勫睍绀轰笌闅愯棌
     legendChange () {
-      this.legendControl = !this.legendControl
+      this.isShow = !this.isShow
+      const state = {
+        type: this.isShow,
+        num: 4
+      }
+      bus.$emit('changeState', state)
     }
   }
 }
 </script>
 
-<style lang="less" scoped>
-@import '@assets/css/map/_map-variable';
+<style lang="less">
 .legend-panel {
   position: absolute;
   z-index: 502;
@@ -162,12 +77,13 @@
   -ms-flex-align: end;
   //align-items: flex-end;
   transition: all .5s;
-  .legend-icon {
-    width: .29167rem;
-    height: .31771rem;
+
+  .legend-btn {
+    width: .2rem;
+    height: .2rem;
     //font-size: .08333rem;
-    border: .00521rem solid rgba(0,255,246,.15);
-    border-radius: .03125rem;
+    border: .00521rem solid @background-color-light;
+    border-radius: @border-radius;
     text-align: center;
     display: -webkit-box;
     display: -ms-flexbox;
@@ -185,7 +101,7 @@
     background: @background-color;
     margin-top: .04167rem;
     cursor: pointer;
-    color: @color;
+    //color: @color;
     margin-left: auto;
     font-size: 0.08333rem;
   }
@@ -219,13 +135,11 @@
     -webkit-box-direction: reverse;
     -ms-flex-direction: row-reverse;
     flex-direction: row-reverse;
-    background: rgba(0,16,30,.9);
-    border-radius: .05208rem;
+
     width: -webkit-max-content;
     width: -moz-max-content;
     width: max-content;
-    border: .00521rem solid @color;
-    box-shadow: 0 0 .03rem @color;
+
     overflow: hidden;
     min-height: 1.28646rem;
 
@@ -233,6 +147,7 @@
       font-size: 0.07292rem;
       padding: .10417rem;
       border-left: .00521rem solid @background-color-split;
+
       p {
         text-align: center;
         margin: 0 !important;
@@ -243,6 +158,7 @@
         -webkit-margin-after: 0.2rem;
         margin-block-end: 0.2rem;
         margin-bottom: 0.05208rem !important;
+
         span {
           color: @color-title;
           font-size: .08333rem;
@@ -252,47 +168,32 @@
 
       ul {
         list-style: none;
-        //display: flex;
         flex-wrap: wrap;
         margin: 0 !important;
         padding: 0 !important;;
         padding-inline: 0;
-        //color: #00fff6;
-        //font-size: .07292rem;
         font-size: .08333rem;
 
-          li {
-            //width: 100%;
-            //display: flex;
-            //justify-content: space-around;
-            //margin-left: 15px;
-            //margin-right: 15px;
-            list-style: none;
-            display: flex;
-            -webkit-box-align: center;
-            align-items: center;
-            margin: 0.05208rem 0;
-            img {
-              width: .08333rem;
-              height: .08333rem;
-              margin-right: .01042rem;
-            }
+        li {
+          list-style: none;
+          display: flex;
+          -webkit-box-align: center;
+          align-items: center;
+          margin: 0.05208rem 0;
 
-            span {
-              //width: 80px;
-              //font-size: 12px;
-              color: @color;
-            }
+          img {
+            width: .08333rem;
+            height: .08333rem;
+            margin-right: .01042rem;
           }
+
+          span {
+            color: @color;
+          }
+        }
       }
     }
 
-    .under-line {
-      height: 1px;
-      background: @background-color-split;
-      margin-block-start: 0;
-      margin-block-end: 0;
-    }
   }
 }
 </style>

--
Gitblit v1.8.0