<template id="app-map">
  <div class="app-map">
    <el-form label-width="80px" size="small">
      <el-row>
        <el-col :span="12">
          <el-form-item label="地址搜索">
            <el-input placeholder="请输入具体地址" @keyup.enter.native="mapSearch" v-model="mapKeyword">
              <el-button @click="mapSearch" slot="append" icon="el-icon-search">
              </el-button>
            </el-input>
          </el-form-item>
        </el-col>
      </el-row>
      <el-row>
        <el-col :span="12">
          <el-form-item label="地址">
            <el-input disabled v-model="newAddress"></el-input>
          </el-form-item>
        </el-col>
        <el-col :span="12">
          <el-form-item label="纬度|经度">
            <el-input disabled v-model="lat_long"></el-input>
          </el-form-item>
        </el-col>
      </el-row>
    </el-form>
    <div class="app-map" id="container" :style="style"></div>
    <span style="height:30px;display:none" id="city"></span>
    <div slot="footer" class="dialog-footer" style="text-align:right;margin-top:30px;">
      <el-button type="primary" size="small" @click="confirm">确 定</el-button>
    </div>
  </div>
</template>
<script>
  export default {
    props: {
      width: String,
      height: String,
      lat: String,
      long: String,
      address: {
        type: String,
        default: '',
      },
      title: String,
    },
    data() {
      return {
        longitude: '', // 经度(大)
        latitude: '', // 纬度(小)
        lat_long: '',
        markers: [],
        map: [],
        searchService: {},
        mapKeyword: '',
        dialogVisible: false,
        newAddress: '',
        city: '',
      };
    },
    created() {

    },
    methods: {
      // 初始化地图
      initMap() {
        let self = this;
        let center = new qq.maps.LatLng(self.latitude, self.longitude); // 默认坐标
        self.map = new qq.maps.Map(
          document.getElementById("container"), {
            center: center,
            zoom: 13, // 缩放级别
          }
        );

        let citylocation = new qq.maps.CityService({
          map: self.map,
          complete: function (results) {
            self.city = results.detail.name;
            self.map.setCenter(results.detail.latLng);
            let marker = self.setMarker(results.detail.latLng);
            self.markers.push(marker);
          }
        });

        // 搜索服务 默认获取当前地址
        if (!self.lat && !self.long) {
          citylocation.searchLocalCity()
        } else {
          self.latitude = self.lat;
          self.longitude = self.long;
          self.lat_long = self.lat + ',' + self.long;
          citylocation.searchCityByLatLng(new qq.maps.LatLng(self.latitude, self.longitude));
        }

        this.clickEvent(center);
        this.initSearch();
      },
      // 地图点击事件
      clickEvent(center) {
        let self = this;
        let listener = qq.maps.event.addListener(this.map, 'click', function (event) {
          self.longitude = event.latLng.getLng().toFixed(6);
          self.latitude = event.latLng.getLat().toFixed(6);
          self.lat_long = self.latitude + ',' + self.longitude;

          self.getAddressBylatLong();
          let coord = new qq.maps.LatLng(self.latitude, self.longitude);
          let marker = self.setMarker(coord);
          self.markers.push(marker);
        });
      },
      // 根据经纬度获取地址信息
      getAddressBylatLong() {
        let self = this;
        // 根据经纬度查询城市信息
        let geocoder = new qq.maps.Geocoder({
          complete: function (result) {
            self.newAddress = result.detail.address;
          }
        });
        let coord = new qq.maps.LatLng(self.latitude, self.longitude);
        geocoder.getAddress(coord);
      },
      // 添加标注
      setMarker(coord) {
        let self = this;
        // 添加标注
        let marker = new qq.maps.Marker({
          map: self.map,
          position: coord
        });
        //获取标记的点击事件
        qq.maps.event.addListener(marker, 'click', function (event) {
          self.longitude = event.latLng.getLng().toFixed(6);
          self.latitude = event.latLng.getLat().toFixed(6);
          self.lat_long = self.latitude + ',' + self.longitude;

          self.getAddressBylatLong();
        });

        return marker;
      },
      // 清除地址坐标
      clearOverLays() {
        //清除地图上的marker
        let overlay;
        while (overlay = this.markers.pop()) {
          overlay.setMap(null);
        }
      },
      initSearch() {
        let self = this;
        let latlngBounds = new qq.maps.LatLngBounds();
        //设置Poi检索服务,用于本地检索、周边检索
        self.searchService = new qq.maps.SearchService({
          //设置搜索范围为
          location: self.city,
          //设置动扩大检索区域。默认值true,会自动检索指定城市以外区域。
          autoExtend: true,
          //检索成功的回调函数
          complete: function (results) {
            //设置回调函数参数
            let pois = results.detail.pois;
            if (!pois) {
              alert("输入详细地址搜索更准确");
              return false;
            }
            for (let i = 0, l = pois.length; i < l; i++) {
              let poi = pois[i];
              //扩展边界范围,用来包含搜索到的Poi点
              latlngBounds.extend(poi.latLng);

              let marker = self.setMarker(poi.latLng)
              marker.setTitle(i + 1);
              self.markers.push(marker);
            }
            //调整地图视野
            self.map.fitBounds(latlngBounds);
          },
          //若服务请求失败,则运行以下函数
          error: function () {
            alert("出错了。");
          }
        });
      },
      // 地址搜索
      mapSearch() {
        this.clearOverLays();
        this.searchService.search(this.mapKeyword);
      },
      confirm() {
        this.$emit('map-submit', {
          lat: this.latitude,
          long: this.longitude,
          address: this.newAddress
        });
      },
    },
    computed: {
      style() {
        let width = '100%';
        let height = '400px';
        if (this.width) {
          width = this.width + (isNaN(this.width) ? '' : 'px');
        }
        if (this.height) {
          height = this.height + (isNaN(this.height) ? '' : 'px');
        }

        return `width:${width};height:${height};`;
      },
    },
    mounted() {
        this.newAddress = this.address ? this.address : '';
        this.mapKeyword = this.newAddress;
        this.initMap();
        if(this.mapKeyword!=''){
          this.mapSearch();
        }
    }
  };

</script>