You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							820 lines
						
					
					
						
							23 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							820 lines
						
					
					
						
							23 KiB
						
					
					
				
								<template>
							 | 
						|
								  <div class="warning-box">
							 | 
						|
								    <cpt-card>
							 | 
						|
								      <div class="card-title">
							 | 
						|
								        <img class="title-icon"
							 | 
						|
								             src="../../../../assets/img/shuju/title-tip.png" />
							 | 
						|
								        <div class="title-label">
							 | 
						|
								          志愿者服务分析  
							 | 
						|
								          <el-cascader v-model="selectAgency"
							 | 
						|
								                       :options="propTree"
							 | 
						|
								                       :props="{ checkStrictly: true }"
							 | 
						|
								                       :show-all-levels="false"
							 | 
						|
								                       clearable
							 | 
						|
								                       @change="handleCascader">
							 | 
						|
								          </el-cascader>
							 | 
						|
								        </div>
							 | 
						|
								      </div>
							 | 
						|
								      <div class="box-wr">
							 | 
						|
								        <div class="card-wr">
							 | 
						|
								          <div class="card-title">
							 | 
						|
								            <!-- <img class="title-icon"
							 | 
						|
								                 src="../../../../assets/img/shuju/title-tip.png" /> -->
							 | 
						|
								            <div class="card-left-title">
							 | 
						|
								              志愿者服务情况
							 | 
						|
								            </div>
							 | 
						|
								          </div>
							 | 
						|
								
							 | 
						|
								          <div class="card-echart">
							 | 
						|
								            <div class="card-left">
							 | 
						|
								              <div class="card-count">
							 | 
						|
								                <div class="card-count-item">
							 | 
						|
								                  <div class="card-count-content">
							 | 
						|
								                    <div class="card-count-num">{{ vInfo.partyTotal || 0 }}</div>
							 | 
						|
								                    <div class="card-count-label">党员数量</div>
							 | 
						|
								                  </div>
							 | 
						|
								                </div>
							 | 
						|
								                <div class="card-count-item">
							 | 
						|
								                  <div class="card-count-content">
							 | 
						|
								                    <div class="card-count-num">{{ vInfo.resiTotal || 0 }}</div>
							 | 
						|
								                    <div class="card-count-label">居民数量</div>
							 | 
						|
								                  </div>
							 | 
						|
								                </div>
							 | 
						|
								              </div>
							 | 
						|
								              <div class="echart-wr">
							 | 
						|
								                <!-- <div class="echart-cicle"></div> -->
							 | 
						|
								                <div id="echartService"
							 | 
						|
								                     class="echart-org"></div>
							 | 
						|
								              </div>
							 | 
						|
								
							 | 
						|
								            </div>
							 | 
						|
								
							 | 
						|
								          </div>
							 | 
						|
								
							 | 
						|
								          <div class="card-echart">
							 | 
						|
								            <div class="card-left">
							 | 
						|
								              <div class="card-count">
							 | 
						|
								                <div class="card-count-item">
							 | 
						|
								                  <div class="card-count-content">
							 | 
						|
								                    <div class="card-count-num">{{ vInfo.partyServiceTotal || 0 }}</div>
							 | 
						|
								                    <div class="card-count-label">党员数量</div>
							 | 
						|
								                  </div>
							 | 
						|
								                </div>
							 | 
						|
								                <div class="card-count-item">
							 | 
						|
								                  <div class="card-count-content">
							 | 
						|
								                    <div class="card-count-num">{{ vInfo.resiServiceTotal || 0 }}</div>
							 | 
						|
								                    <div class="card-count-label">居民数量</div>
							 | 
						|
								                  </div>
							 | 
						|
								                </div>
							 | 
						|
								              </div>
							 | 
						|
								              <div class="echart-wr">
							 | 
						|
								                <!-- <div class="echart-cicle"></div> -->
							 | 
						|
								                <div id="echartCount"
							 | 
						|
								                     class="echart-org"></div>
							 | 
						|
								              </div>
							 | 
						|
								
							 | 
						|
								            </div>
							 | 
						|
								
							 | 
						|
								          </div>
							 | 
						|
								
							 | 
						|
								        </div>
							 | 
						|
								        <div class="card-wr card-wr-map">
							 | 
						|
								          <div class="card-title">
							 | 
						|
								            <!-- <img class="title-icon"
							 | 
						|
								                 src="../../../../assets/img/shuju/title-tip.png" /> -->
							 | 
						|
								            <div class="card-left-title">
							 | 
						|
								              多元化治理平面图
							 | 
						|
								            </div>
							 | 
						|
								          </div>
							 | 
						|
								
							 | 
						|
								          <div class="card-map">
							 | 
						|
								            <screen-map class="map"
							 | 
						|
								                        ref="map"
							 | 
						|
								                        @clickFeature="clickMapVolunteer"
							 | 
						|
								                        :showIconLayer="true"
							 | 
						|
								                        :clickType="'popup'"
							 | 
						|
								                        :isAddOpenlay="true"></screen-map>
							 | 
						|
								          </div>
							 | 
						|
								          <div class="map-tips">
							 | 
						|
								
							 | 
						|
								            <div class="map-tips-item"
							 | 
						|
								                 v-for="item in legendArray"
							 | 
						|
								                 :key="item.optionValue">
							 | 
						|
								
							 | 
						|
								              <img class="title-icon"
							 | 
						|
								                   :src="item.url" />
							 | 
						|
								              <div class="map-tips-label">{{item.optionLabel}}</div>
							 | 
						|
								            </div>
							 | 
						|
								
							 | 
						|
								          </div>
							 | 
						|
								
							 | 
						|
								        </div>
							 | 
						|
								      </div>
							 | 
						|
								    </cpt-card>
							 | 
						|
								  </div>
							 | 
						|
								</template>
							 | 
						|
								
							 | 
						|
								<script>
							 | 
						|
								import { requestPost } from "@/js/dai/request";
							 | 
						|
								import screenTable from "../components/screen-table/index";
							 | 
						|
								import cptCard from "@/views/modules/visual/cpts/card";
							 | 
						|
								import nextTick from "dai-js/tools/nextTick";
							 | 
						|
								import screenMap from "@/views/modules/visual/components/screen-map";
							 | 
						|
								
							 | 
						|
								import * as echarts from 'echarts';
							 | 
						|
								export default {
							 | 
						|
								  name: "warning-box",
							 | 
						|
								  components: {
							 | 
						|
								    cptCard,
							 | 
						|
								    screenTable,
							 | 
						|
								    screenMap
							 | 
						|
								  },
							 | 
						|
								  data () {
							 | 
						|
								    return {
							 | 
						|
								      warningList: [],
							 | 
						|
								      headerList: [
							 | 
						|
								        { title: "序号", coulmn: 'index' },
							 | 
						|
								        { title: "需求类型", coulmn: 'gridName' },
							 | 
						|
								        { title: "具体内容", coulmn: 'buildingName' },
							 | 
						|
								        { title: "上报情况", coulmn: 'neighborhoodName' },
							 | 
						|
								        { title: "上报人", coulmn: 'residentNames' },
							 | 
						|
								        { title: "上报时间", coulmn: 'residentNames' },
							 | 
						|
								        { title: "是否认领", coulmn: 'residentNames' },
							 | 
						|
								        { title: "认领方", coulmn: 'residentNames' },
							 | 
						|
								        { title: "认领时间", coulmn: 'residentNames' }
							 | 
						|
								      ],
							 | 
						|
								      tableData: [
							 | 
						|
								        // [1,'商丘路社区第一网格','商丘路小区','2号楼','杨颖、王平、刘佳敏、丁辉、杨萍'],
							 | 
						|
								      ],
							 | 
						|
								      value2: '',
							 | 
						|
								      selectAgency: '',
							 | 
						|
								      propTree: [],
							 | 
						|
								      visibleLoading: true,
							 | 
						|
								      pageNo: 1,
							 | 
						|
								      pageSize: 10,
							 | 
						|
								      total: 0,
							 | 
						|
								      activeIndex: 0,
							 | 
						|
								      activeLevel: "1",
							 | 
						|
								
							 | 
						|
								      //地图相关数据
							 | 
						|
								      isfirstInit: true,//记录是否是首次加载地图
							 | 
						|
								      agencyInfo: {},//登陆者的组织信息:主要为了获取地图中心点和level
							 | 
						|
								      distributionsList: [],
							 | 
						|
								
							 | 
						|
								      legendArray: [],
							 | 
						|
								
							 | 
						|
								      iconUrlArray: [
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer1.png'),//文化队伍
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer2.png'),//楼委会
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer3.png'),//能人达人
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer4.png'),//老友俱乐部
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer5.png'),//代办员
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer6.png'),//调解员
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer7.png'),//采集员
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer8.png'),//治安巡逻
							 | 
						|
								        require('../../../../assets/img/shuju/volunteer9.png'),//其他
							 | 
						|
								      ],
							 | 
						|
								      vPersonal: [],
							 | 
						|
								      vCount: [],
							 | 
						|
								      vpTotal: 0,
							 | 
						|
								      vcTotal: 0,
							 | 
						|
								      vInfo: {}
							 | 
						|
								    };
							 | 
						|
								  },
							 | 
						|
								  async mounted () {
							 | 
						|
								    await nextTick(100);
							 | 
						|
								    await this.getAgencyList()
							 | 
						|
								    this.getPie(this.$store.state.user.agencyId)
							 | 
						|
								    // this.initCharts()
							 | 
						|
								    // this.initCount()
							 | 
						|
								
							 | 
						|
								    await this.getWorkUserInfo()
							 | 
						|
								    await this.getMapUnitList(this.$store.state.user.agencyId)
							 | 
						|
								  },
							 | 
						|
								  methods: {
							 | 
						|
								    initCharts (total, data) {
							 | 
						|
								      const eId = document.getElementById('echartService')
							 | 
						|
								      let _charts = echarts.init(eId)
							 | 
						|
								      let option = {
							 | 
						|
								        tooltip: {
							 | 
						|
								          trigger: 'item'
							 | 
						|
								        },
							 | 
						|
								        legend: {
							 | 
						|
								          show: true,
							 | 
						|
								          top: 'bottom',
							 | 
						|
								          left: 'center',
							 | 
						|
								          textStyle: {
							 | 
						|
								            color: '#fff'
							 | 
						|
								          }
							 | 
						|
								        },
							 | 
						|
								        title: {
							 | 
						|
								          text: total,  //图形标题,配置在中间对应效果图的80%
							 | 
						|
								          subtext: '志愿者总数',
							 | 
						|
								          left: "center",
							 | 
						|
								          top: "center",
							 | 
						|
								          textStyle: {
							 | 
						|
								            color: "#fff",
							 | 
						|
								            fontSize: 28,
							 | 
						|
								            align: "center"
							 | 
						|
								          },
							 | 
						|
								          subtextStyle: {
							 | 
						|
								            fontSize: 16,
							 | 
						|
								            color: '#fff'
							 | 
						|
								          }
							 | 
						|
								        },
							 | 
						|
								        series: [
							 | 
						|
								          {
							 | 
						|
								            // name: 'Access From',
							 | 
						|
								            type: 'pie',
							 | 
						|
								            radius: ['50%', '60%'],
							 | 
						|
								            avoidLabelOverlap: false,
							 | 
						|
								            left: 'center',
							 | 
						|
								            width: 400,
							 | 
						|
								            label: {
							 | 
						|
								              show: false,
							 | 
						|
								            },
							 | 
						|
								            emphasis: {
							 | 
						|
								              label: {
							 | 
						|
								                show: false,
							 | 
						|
								                fontSize: '14',
							 | 
						|
								                fontWeight: 'bold'
							 | 
						|
								              }
							 | 
						|
								            },
							 | 
						|
								
							 | 
						|
								            data: data
							 | 
						|
								          }
							 | 
						|
								        ]
							 | 
						|
								      }
							 | 
						|
								      option && _charts.setOption(option);
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								    initCount (total, data) {
							 | 
						|
								      const eId = document.getElementById('echartCount')
							 | 
						|
								      let _charts = echarts.init(eId)
							 | 
						|
								      let option = {
							 | 
						|
								        tooltip: {
							 | 
						|
								          trigger: 'item'
							 | 
						|
								        },
							 | 
						|
								        legend: {
							 | 
						|
								          show: true,
							 | 
						|
								          top: 'bottom',
							 | 
						|
								          left: 'center',
							 | 
						|
								          textStyle: {
							 | 
						|
								            color: '#fff'
							 | 
						|
								          }
							 | 
						|
								        },
							 | 
						|
								        title: {
							 | 
						|
								          text: total,  //图形标题,配置在中间对应效果图的80%
							 | 
						|
								          subtext: '志愿者服务总数',
							 | 
						|
								          left: "center",
							 | 
						|
								          top: "center",
							 | 
						|
								          textStyle: {
							 | 
						|
								            color: "#fff",
							 | 
						|
								            fontSize: 28,
							 | 
						|
								            align: "center"
							 | 
						|
								          },
							 | 
						|
								          subtextStyle: {
							 | 
						|
								            fontSize: 16,
							 | 
						|
								            color: '#fff'
							 | 
						|
								          }
							 | 
						|
								        },
							 | 
						|
								        series: [
							 | 
						|
								          {
							 | 
						|
								            // name: 'Access From',
							 | 
						|
								            type: 'pie',
							 | 
						|
								            // center: ['10%', '50%'],
							 | 
						|
								            radius: ['50%', '60%'],
							 | 
						|
								            avoidLabelOverlap: false,
							 | 
						|
								            // top: top + '%',
							 | 
						|
								            // height: '80%',
							 | 
						|
								            left: 'center',
							 | 
						|
								            width: 400,
							 | 
						|
								            label: {
							 | 
						|
								              show: false,
							 | 
						|
								            },
							 | 
						|
								            emphasis: {
							 | 
						|
								              label: {
							 | 
						|
								                show: false,
							 | 
						|
								                fontSize: '14',
							 | 
						|
								                fontWeight: 'bold'
							 | 
						|
								              }
							 | 
						|
								            },
							 | 
						|
								
							 | 
						|
								            data: data
							 | 
						|
								          }
							 | 
						|
								        ]
							 | 
						|
								      }
							 | 
						|
								      option && _charts.setOption(option);
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								    async getPie (agencyId) {
							 | 
						|
								      const url = "/data/report/heart/demand/volunteer/service";
							 | 
						|
								      let params = {
							 | 
						|
								        agencyId,
							 | 
						|
								      };
							 | 
						|
								      const { data, code, msg } = await requestPost(url, params);
							 | 
						|
								      if (code === 0) {
							 | 
						|
								        console.log('data-ddd', data)
							 | 
						|
								        this.vInfo = data
							 | 
						|
								        const arr = [{
							 | 
						|
								          name: '党员数量',
							 | 
						|
								          value: data.partyTotal,
							 | 
						|
								          itemStyle: {
							 | 
						|
								            color: 'rgba(26, 178, 255, 1)'
							 | 
						|
								          }
							 | 
						|
								        }, {
							 | 
						|
								          name: '居民数量',
							 | 
						|
								          value: data.resiTotal,
							 | 
						|
								          itemStyle: {
							 | 
						|
								            color: 'rgba(250, 193, 38, 1)'
							 | 
						|
								          }
							 | 
						|
								        }]
							 | 
						|
								        const arr1 = [{
							 | 
						|
								          name: '党员数量',
							 | 
						|
								          value: data.partyServiceTotal,
							 | 
						|
								          itemStyle: {
							 | 
						|
								            color: 'rgba(26, 178, 255, 1)'
							 | 
						|
								          }
							 | 
						|
								        }, {
							 | 
						|
								          name: '居民数量',
							 | 
						|
								          value: data.resiServiceTotal,
							 | 
						|
								          itemStyle: {
							 | 
						|
								            color: 'rgba(250, 193, 38, 1)'
							 | 
						|
								          }
							 | 
						|
								        }]
							 | 
						|
								        this.vPersonal = [...arr]
							 | 
						|
								        this.vCount = [...arr1]
							 | 
						|
								        this.vpTotal = data.volunteerTotal
							 | 
						|
								        this.vcTotal = data.serviceTotal
							 | 
						|
								        this.initCharts(data.volunteerTotal, arr)
							 | 
						|
								        this.initCount(data.serviceTotal, arr1)
							 | 
						|
								      } else {
							 | 
						|
								        this.$message.error(msg)
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								    async getAgencyList () {
							 | 
						|
								      // const url = "/gov/org/customeragency/staffinagencylist";
							 | 
						|
								      // const url = '/gov/org/customeragency/agencygridtree'
							 | 
						|
								      const url = '/gov/org/customeragency/staffinagencylist'
							 | 
						|
								      // let params = {
							 | 
						|
								      //   agencyId: this.$store.state.user.agencyId,
							 | 
						|
								      // };
							 | 
						|
								      const { data, code, msg } = await requestPost(url);
							 | 
						|
								      if (code === 0) {
							 | 
						|
								        console.log('data-org----o', data)
							 | 
						|
								        let { agencyList, subAgencyList } = data
							 | 
						|
								        this.selectAgency = [`${agencyList.agencyId}-${agencyList.level}`]
							 | 
						|
								        let arr = []
							 | 
						|
								        agencyList.subAgencyList = subAgencyList
							 | 
						|
								        arr.push(agencyList)
							 | 
						|
								        this.propTree = arr && this.getTreeData(arr)
							 | 
						|
								
							 | 
						|
								      } else {
							 | 
						|
								        this.$message.error(msg)
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								    getTreeData (data) {
							 | 
						|
								      if (!Array.isArray(data)) return []
							 | 
						|
								      let arr = data.map(item => {
							 | 
						|
								        let _item = {}
							 | 
						|
								        if (item.subAgencyList) {
							 | 
						|
								          if (item.subAgencyList.length === 0) {
							 | 
						|
								            _item = {
							 | 
						|
								              label: item.agencyName,
							 | 
						|
								              value: item.agencyId + '-' + item.level,
							 | 
						|
								              level: item.level,
							 | 
						|
								              children: undefined
							 | 
						|
								            }
							 | 
						|
								          } else _item = {
							 | 
						|
								            label: item.agencyName,
							 | 
						|
								            value: item.agencyId + '-' + item.level,
							 | 
						|
								            level: item.level,
							 | 
						|
								            children: this.getTreeData(item.subAgencyList)
							 | 
						|
								          }
							 | 
						|
								        } else {
							 | 
						|
								          _item = {
							 | 
						|
								            label: item.agencyName,
							 | 
						|
								            value: item.agencyId + '-' + item.level,
							 | 
						|
								            level: item.level,
							 | 
						|
								          }
							 | 
						|
								        }
							 | 
						|
								        return _item
							 | 
						|
								      })
							 | 
						|
								      return arr
							 | 
						|
								    },
							 | 
						|
								    // 【人员预警】 楼宇预警数量列表
							 | 
						|
								    pageSizeChangeHandleNew (val) {
							 | 
						|
								      this.pageNo = 1;
							 | 
						|
								      this.pageSize = val;
							 | 
						|
								    },
							 | 
						|
								    pageCurrentChangeHandleNew (val) {
							 | 
						|
								      this.pageNo = val;
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    // 获取当前管理员信息
							 | 
						|
								    getWorkUserInfo () {
							 | 
						|
								      const url = '/epmetuser/customerstaff/staffbasicinfo'
							 | 
						|
								      let params = {}
							 | 
						|
								      window.app.ajax.post(
							 | 
						|
								        url,
							 | 
						|
								        params,
							 | 
						|
								        (data, rspMsg) => {
							 | 
						|
								          this.agencyInfo = data
							 | 
						|
								          if (!data.latitude) {
							 | 
						|
								            this.agencyInfo.latitude = 36.072227
							 | 
						|
								          }
							 | 
						|
								          if (!data.longitude) {
							 | 
						|
								            this.agencyInfo.longitude = 120.389455
							 | 
						|
								          }
							 | 
						|
								          if (!data.level) {
							 | 
						|
								            this.agencyInfo.level = 'street'
							 | 
						|
								          }
							 | 
						|
								
							 | 
						|
								        },
							 | 
						|
								        (rspMsg, data) => {
							 | 
						|
								          this.$message.error(rspMsg)
							 | 
						|
								        }
							 | 
						|
								      )
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								    //获取联建单位分布图
							 | 
						|
								    async getMapUnitList (agencyId) {
							 | 
						|
								      const url = "/epmetuser/volunteer/distribution"
							 | 
						|
								      // const url = "http://yapi.elinkservice.cn/mock/245/heart/icpartyunit/distribution"
							 | 
						|
								
							 | 
						|
								      let params = {
							 | 
						|
								        customerId: this.$store.state.user.customerId,
							 | 
						|
								        agencyId
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								      const { data, code, msg } = await requestPost(url, params)
							 | 
						|
								
							 | 
						|
								      if (code === 0) {
							 | 
						|
								        this.legendArray = data.legends
							 | 
						|
								
							 | 
						|
								        this.legendArray.forEach((legendTtem, index) => {
							 | 
						|
								          if (index < this.iconUrlArray.length) {
							 | 
						|
								            legendTtem.url = this.iconUrlArray[index]
							 | 
						|
								          } else {//超过原型数量的都默认为第一个图标
							 | 
						|
								            legendTtem.url = this.iconUrlArray[0]
							 | 
						|
								          }
							 | 
						|
								
							 | 
						|
								        });
							 | 
						|
								        this.legendArray.push({
							 | 
						|
								          optionValue: 'other',
							 | 
						|
								          optionLabel: '其他',
							 | 
						|
								          url: this.iconUrlArray[8]
							 | 
						|
								        })
							 | 
						|
								
							 | 
						|
								        this.distributionsList = data.distributions
							 | 
						|
								
							 | 
						|
								        this.distributionsList.forEach(item => {
							 | 
						|
								          let typeShow = ''
							 | 
						|
								          if (item.volunteerCategories.length > 0) {
							 | 
						|
								            typeShow = item.volunteerCategories[0]
							 | 
						|
								          } else {
							 | 
						|
								            typeShow = 'other'
							 | 
						|
								          }
							 | 
						|
								          item.urlIndex = 0
							 | 
						|
								          for (let i = 0; i < this.legendArray.length; i++) {
							 | 
						|
								            if (typeShow === this.legendArray[i].optionValue) {
							 | 
						|
								              item.urlIndex = i
							 | 
						|
								              break;
							 | 
						|
								            }
							 | 
						|
								          }
							 | 
						|
								
							 | 
						|
								        });
							 | 
						|
								        console.log(this.distributionsList)
							 | 
						|
								
							 | 
						|
								        //第一次加载完置为false
							 | 
						|
								        this.loadMap()
							 | 
						|
								        this.isfirstInit = false
							 | 
						|
								
							 | 
						|
								      } else {
							 | 
						|
								        this.$message.error(msg)
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    handleCascader (val) {
							 | 
						|
								      console.log('val-vvv', val)
							 | 
						|
								      if (val.length > 0) {
							 | 
						|
								        const _arr = val[val.length - 1].split('-')
							 | 
						|
								        const orgType = _arr[1] !== 'grid' ? 'agency' : 'grid'
							 | 
						|
								        // this.getServicePie(_arr[0], orgType)
							 | 
						|
								        this.getPie(_arr[0])
							 | 
						|
								        this.getMapUnitList(_arr[0])
							 | 
						|
								      }
							 | 
						|
								
							 | 
						|
								    },
							 | 
						|
								    //加载地图数据
							 | 
						|
								    loadMap () {
							 | 
						|
								      if (this.isfirstInit) {
							 | 
						|
								        //mapInfo, polygonArray, polIconUrlArray, iconArrays, iconUrlArray
							 | 
						|
								        this.$refs.map.loadMap(this.agencyInfo, null, null, this.distributionsList, this.iconUrlArray, null)
							 | 
						|
								      } else {
							 | 
						|
								        this.$refs.map.refreshMap(null, this.distributionsList)
							 | 
						|
								
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    //点击项目
							 | 
						|
								    async clickMapVolunteer (feature) {
							 | 
						|
								      console.log('标注信息', feature.values_.properties)
							 | 
						|
								      if (!feature.values_.properties.info.icResiUserId) {
							 | 
						|
								        return false
							 | 
						|
								      }
							 | 
						|
								      const info = feature.values_.properties.info
							 | 
						|
								      const url = "/epmetuser/icresiuser/resi-brief/" + info.icResiUserId
							 | 
						|
								      // const url = "http://yapi.elinkservice.cn/mock/245/heart/icpartyunit/distribution"
							 | 
						|
								
							 | 
						|
								      let params = {}
							 | 
						|
								
							 | 
						|
								      const { data, code, msg } = await requestPost(url, params)
							 | 
						|
								
							 | 
						|
								      if (code === 0) {
							 | 
						|
								        let coordinate = [info.longitude, info.latitude]
							 | 
						|
								        data.gridName = data.gridName ? data.gridName : '--'
							 | 
						|
								        data.villageName = data.villageName ? data.villageName : '--'
							 | 
						|
								        data.icUserName = data.icUserName ? data.icUserName : '--'
							 | 
						|
								        data.mobile = data.mobile ? data.mobile : '--'
							 | 
						|
								        data.idCard = data.idCard ? data.idCard : '--'
							 | 
						|
								        data.birthday = data.birthday ? data.birthday : '--'
							 | 
						|
								        data.contacts = data.contacts ? data.contacts : '--'
							 | 
						|
								        data.contactsMobile = data.contactsMobile ? data.contactsMobile : '--'
							 | 
						|
								
							 | 
						|
								        data.isBdhjShow = data.isBdhj ? data.isBdhj === '0' ? '否' : '是' : '--'
							 | 
						|
								        data.genderShow = data.gender ? data.gender === '0' ? '女' : '男' : '--'
							 | 
						|
								        let categoriesArray = []
							 | 
						|
								
							 | 
						|
								        for (let key in data.volunteerCategories) {
							 | 
						|
								          categoriesArray.push(data.volunteerCategories[key])
							 | 
						|
								
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								        if (categoriesArray.length > 0) {
							 | 
						|
								          data.categories = categoriesArray.join(',')
							 | 
						|
								        } else {
							 | 
						|
								          data.categories = '--'
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								        let showData = `
							 | 
						|
								                <div style='font-size:16px; color:#FFFFFF;'>居民信息</div>
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:10px'>所属网格:
							 | 
						|
								                  <span>`+ data.gridName + `</span>
							 | 
						|
								                </div>
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>所属小区:
							 | 
						|
								                  <span>`+ data.villageName + `</span>
							 | 
						|
								                </div>
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>本地户籍:
							 | 
						|
								                  <span>`+ data.isBdhjShow + `</span>
							 | 
						|
								                </div>
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>姓名:
							 | 
						|
								                  <span>`+ data.icUserName + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>手机:
							 | 
						|
								                  <span>`+ data.mobile + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>性别:
							 | 
						|
								                  <span>`+ data.genderShow + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>身份证号:
							 | 
						|
								                  <span>`+ data.idCard + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>出生日期:
							 | 
						|
								                  <span>`+ data.birthday + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>联系人:
							 | 
						|
								                  <span>`+ data.contacts + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>联系人手机:
							 | 
						|
								                  <span>`+ data.contactsMobile + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                <div style='font-size:12px; color:#FFFFFF;margin-top:5px'>志愿者类别:
							 | 
						|
								                  <span>`+ data.categories + `</span>
							 | 
						|
								                </div> 
							 | 
						|
								                `
							 | 
						|
								        // console.log(showData)
							 | 
						|
								        this.$refs.map.handleShowPopup(showData, coordinate)
							 | 
						|
								
							 | 
						|
								      } else {
							 | 
						|
								        this.$message.error(msg)
							 | 
						|
								      }
							 | 
						|
								    },
							 | 
						|
								  },
							 | 
						|
								};
							 | 
						|
								</script>
							 | 
						|
								
							 | 
						|
								<style
							 | 
						|
								  lang="scss"
							 | 
						|
								  src="@/assets/scss/modules/visual/warning.scss"
							 | 
						|
								  scoped
							 | 
						|
								></style>
							 | 
						|
								<style lang="scss" scoped>
							 | 
						|
								.warning-box {
							 | 
						|
								  // display: flex;
							 | 
						|
								  .box-wr {
							 | 
						|
								    display: flex;
							 | 
						|
								    margin-top: 40px;
							 | 
						|
								  }
							 | 
						|
								  .card-wr {
							 | 
						|
								    flex: 1;
							 | 
						|
								  }
							 | 
						|
								  .card-wr:last-child {
							 | 
						|
								    margin-left: 20px;
							 | 
						|
								  }
							 | 
						|
								  padding: 25px 21px 15px 24px;
							 | 
						|
								}
							 | 
						|
								.card-title {
							 | 
						|
								  display: flex;
							 | 
						|
								  align-items: center;
							 | 
						|
								  cursor: pointer;
							 | 
						|
								  margin-bottom: 10px;
							 | 
						|
								  .title-icon {
							 | 
						|
								    display: block;
							 | 
						|
								    width: 36px;
							 | 
						|
								    height: 29px;
							 | 
						|
								    box-sizing: border-box;
							 | 
						|
								    margin-right: 3px;
							 | 
						|
								  }
							 | 
						|
								  .title-label {
							 | 
						|
								    font-size: 20px;
							 | 
						|
								    font-weight: 800;
							 | 
						|
								
							 | 
						|
								    ::v-deep .el-input {
							 | 
						|
								      width: 180px;
							 | 
						|
								      .el-input__inner {
							 | 
						|
								        font-size: 18px;
							 | 
						|
								        // font-weight: 800;
							 | 
						|
								        color: #fff;
							 | 
						|
								        background: #06186d;
							 | 
						|
								        border: 1px solid #1a64cc;
							 | 
						|
								      }
							 | 
						|
								      .el-icon-arrow-down::before {
							 | 
						|
								        content: "\e790";
							 | 
						|
								      }
							 | 
						|
								    }
							 | 
						|
								  }
							 | 
						|
								  ::v-deep .el-dropdown {
							 | 
						|
								    font-size: 16px;
							 | 
						|
								    color: #fff;
							 | 
						|
								    font-weight: 800;
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								.card-echart {
							 | 
						|
								  display: flex;
							 | 
						|
								  margin-top: 40px;
							 | 
						|
								
							 | 
						|
								  .card-left {
							 | 
						|
								    position: relative;
							 | 
						|
								    flex: 1;
							 | 
						|
								    display: flex;
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								.card-echart:last-child {
							 | 
						|
								  padding-bottom: 40px;
							 | 
						|
								}
							 | 
						|
								.echart-wr {
							 | 
						|
								  position: relative;
							 | 
						|
								  flex-shrink: 0;
							 | 
						|
								  width: 50%;
							 | 
						|
								  height: 320px;
							 | 
						|
								  box-sizing: border-box;
							 | 
						|
								  .echart-org {
							 | 
						|
								    width: 100%;
							 | 
						|
								    height: 100%;
							 | 
						|
								  }
							 | 
						|
								  .echart-cicle {
							 | 
						|
								    position: absolute;
							 | 
						|
								    top: 50%;
							 | 
						|
								    left: 50%;
							 | 
						|
								    width: 240px;
							 | 
						|
								    height: 240px;
							 | 
						|
								    box-sizing: border-box;
							 | 
						|
								    margin-top: -120px;
							 | 
						|
								    margin-left: -120px;
							 | 
						|
								    border: 1px dashed rgba(0, 96, 240, 1);
							 | 
						|
								    border-radius: 50%;
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								.card-count {
							 | 
						|
								  flex: 1;
							 | 
						|
								  .card-count-item {
							 | 
						|
								    display: flex;
							 | 
						|
								    align-items: center;
							 | 
						|
								    justify-content: center;
							 | 
						|
								    width: 418px;
							 | 
						|
								    height: 124px;
							 | 
						|
								    box-sizing: border-box;
							 | 
						|
								    margin-top: 20px;
							 | 
						|
								    // padding-left: 192px;
							 | 
						|
								    background: url("../../../../assets/img/shuju/measure/dangyuan.png") center
							 | 
						|
								      no-repeat;
							 | 
						|
								    background-size: cover;
							 | 
						|
								    .card-count-content {
							 | 
						|
								      position: relative;
							 | 
						|
								      box-sizing: border-box;
							 | 
						|
								      padding-left: 30px;
							 | 
						|
								      color: #fff;
							 | 
						|
								      cursor: pointer;
							 | 
						|
								      .card-count-num {
							 | 
						|
								        font-size: 32px;
							 | 
						|
								        font-weight: bold;
							 | 
						|
								      }
							 | 
						|
								      .card-count-label {
							 | 
						|
								        margin-top: 6px;
							 | 
						|
								        font-size: 16px;
							 | 
						|
								        color: rgba(255, 255, 255, 0.72);
							 | 
						|
								      }
							 | 
						|
								    }
							 | 
						|
								    .card-count-content::after {
							 | 
						|
								      position: absolute;
							 | 
						|
								      top: 50%;
							 | 
						|
								      left: 0;
							 | 
						|
								      content: "";
							 | 
						|
								      width: 1px;
							 | 
						|
								      height: 50px;
							 | 
						|
								      margin-top: -25px;
							 | 
						|
								      background: rgba(98, 162, 205, 1);
							 | 
						|
								    }
							 | 
						|
								  }
							 | 
						|
								  .card-count-item:last-child {
							 | 
						|
								    background: url("../../../../assets/img/shuju/measure/jumin.png") center
							 | 
						|
								      no-repeat;
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								.map-tips {
							 | 
						|
								  width: 100%;
							 | 
						|
								  display: flex;
							 | 
						|
								  // justify-content: center;
							 | 
						|
								  align-items: center;
							 | 
						|
								  flex-wrap: wrap;
							 | 
						|
								  box-sizing: border-box;
							 | 
						|
								  padding: 6px 0 0 100px;
							 | 
						|
								  // padding-top: 10px;
							 | 
						|
								  // padding-bottom: 10px;
							 | 
						|
								
							 | 
						|
								  .map-tips-item {
							 | 
						|
								    display: flex;
							 | 
						|
								
							 | 
						|
								    align-items: center;
							 | 
						|
								    margin-top: 10px;
							 | 
						|
								    margin-right: 40px;
							 | 
						|
								
							 | 
						|
								    .map-tips-icon {
							 | 
						|
								      width: 20px;
							 | 
						|
								      height: 10px;
							 | 
						|
								      box-sizing: border-box;
							 | 
						|
								      margin-right: 10px;
							 | 
						|
								      background: #dd2719;
							 | 
						|
								      border-radius: 2px;
							 | 
						|
								    }
							 | 
						|
								    .map-tips-label {
							 | 
						|
								      font-size: 16px;
							 | 
						|
								      color: #fff;
							 | 
						|
								    }
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								.card-wr-map {
							 | 
						|
								  // height: calc(100vh - 120px);
							 | 
						|
								  text-align: center;
							 | 
						|
								
							 | 
						|
								  .card-map {
							 | 
						|
								    margin-top: 30px;
							 | 
						|
								    width: 100%;
							 | 
						|
								    // height: calc(100vh - 285px);
							 | 
						|
								    height: calc(100vh - 335px);
							 | 
						|
								    padding-left: 20px;
							 | 
						|
								    .map {
							 | 
						|
								      width: 100%;
							 | 
						|
								      height: 100%;
							 | 
						|
								    }
							 | 
						|
								  }
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								.card-left-title {
							 | 
						|
								  position: relative;
							 | 
						|
								  padding-left: 40px;
							 | 
						|
								  font-size: 16px;
							 | 
						|
								  font-weight: 500;
							 | 
						|
								  color: #fff;
							 | 
						|
								}
							 | 
						|
								.card-left-title::after {
							 | 
						|
								  content: '';
							 | 
						|
								  position: absolute;
							 | 
						|
								  top: 50%;
							 | 
						|
								  left: 20px;
							 | 
						|
								  width: 12px;
							 | 
						|
								  height: 12px;
							 | 
						|
								  box-sizing: border-box;
							 | 
						|
								  margin-top: -6px;
							 | 
						|
								  background: #2865FA;
							 | 
						|
								  border-radius: 50%;
							 | 
						|
								}
							 | 
						|
								</style>
							 | 
						|
								
							 |