{"remainingRequest":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js??vue-loader-options!/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Map/index.vue?vue&type=script&lang=js","dependencies":[{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/src/views/Map/index.vue","mtime":1748913931914},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/thread-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/babel-loader/lib/index.js","mtime":456789000000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/cache-loader/dist/cjs.js","mtime":499162500000},{"path":"/data/jenkins/workspace/badp-bcxin-web-5.x-staff/node_modules/vue-loader/lib/index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
import gcoord from "gcoord";
// import cityOptions from '@/assets/js/cityData.js'
import { getPlaceByTiandi } from "@/api/staffApi.js"
import VueAMap from "vue-amap";
let amapManager = new VueAMap.AMapManager();
import Clipboard from 'clipboard';
let Geocoder;
export default {
  name: "fence-manage",
  data() {
    let self = this;
    return {
      mapType: 'gaode',
      tiandiMap: null,
      district:'',//省市区
      attendanceSiteName:'',
      searchValue:'',
      userInfo: {},
      formList: {
        xy:'',  
        address:''   
      },
      longitude:'0',
      latitude:'0',
      // cityOptions:cityOptions,
      amapManager,
      zoom: 15,
      center: [116.400128, 39.947276],
      address: "", // 地址
      lng: 0, // 经度
      lat: 0, // 维度
      xy: "", //经纬合并
      searchOption: {
        city: "",
        citylimit: false,
      },
      markers: [], 
      events: {
        init:(o)=> {
          // debugger
          console.log(o)          
          // o 是高德地图定位插件实例
          // o.getCurrentPosition((status, result) => {
          //   console.log('55',result)
          //   if (result && result.position) {
          //     self.lng = result.position.lng;
          //     self.lat = result.position.lat;
          //     self.center = [self.lng, self.lat];
          //     self.loaded = true;
          //     self.$nextTick();
          //   }
          // });
        },
        click(e) {
          let { lng, lat } = e.lnglat;
          self.lng = lng;
          self.lat = lat;
          self.formList.xy = self.lng + "," + self.lat;
          self.longitude=self.lng;
          self.latitude=self.lat;
          // 这里通过高德 SDK 完成。
          var geocoder = new AMap.Geocoder({
            radius: 1000,
            extensions: "all",
          });
          geocoder.getAddress([lng, lat], function(status, result) {
            // debugger
            if (status === "complete" && result.info === "OK") {
              if (result && result.regeocode) {
                console.log(result)
                self.address = result.regeocode.formattedAddress;
                self.attendanceSiteName = result.regeocode.pois[0].name;
                let city=''
                if(result.regeocode.addressComponent.city==''){
                  city='市辖区'
                  if(result.regeocode.addressComponent.province.indexOf('重庆市')>-1&&result.regeocode.addressComponent.district.indexOf('县')>-1){
                    city='县'
                  }
                }else{
                  city=result.regeocode.addressComponent.city
                }
                self.district = result.regeocode.addressComponent.province + city + result.regeocode.addressComponent.district;
                self.$nextTick();
                self.markers = [];    //标记点先清空
                self.markers.push([lng,lat])
              }
            }
          });
        },
      },
      // 当前地图需要的拓展插件需在该内容下放置  Geocoder为通过坐标获取地址信息
      plugin: [{
              pName: 'Geocoder',
              events: {
                  init(o) {
                      Geocoder = o
                  }
              },
          }
      ]
    };
  },
  mounted() {
     console.log(this.$route.query)
     if(this.mapType === 'tiandimap') {
      this.initTiandiMap();
     }
     if(this.$route.query){
      this.longitude=this.$route.query.longitude&&this.$route.query.longitude
      this.latitude=this.$route.query.latitude&&this.$route.query.latitude
      this.address=this.$route.query.address&&this.$route.query.address
      this.attendanceSiteName=this.$route.query.attendanceSiteName&&this.$route.query.attendanceSiteName
      this.district=this.$route.query.district&&this.$route.query.district
      if(this.$route.query.longitude){
        this.markers=[]
        this.center=[this.longitude,this.latitude]//居中地图位置
        this.markers.push([this.longitude,this.latitude])
        if(this.mapType === 'tiandimap') {
          if(this.longitude && this.latitude) {
            const result = gcoord.transform(
              [this.longitude, this.latitude],    // 经纬度坐标
              gcoord.GCJ02,                       // 当前坐标系
              gcoord.WGS84,                       // 目标坐标系
            );
            this.addTiandiMarker(result[0], result[1]);
          }
        }    
      }
      // if(this.$route.query.attendanceSiteName){
      //   document.querySelector(".search-box-wrapper input").value=this.attendanceSiteName
      // }      
     }
  },
  methods: {
    // 清除天地图marker
    clearTiandiMap() {
      let newMarker = this.tiandiMap.getOverlays(); // 获取到了地图上的所有点
      for (let i = 0; i < newMarker.length; i++) {
        this.tiandiMap.removeOverLay(newMarker[i])
      };
    },
    // 添加天地图marker
    addTiandiMarker(lng, lat) {
      const marker = new T.Marker(new T.LngLat(lng, lat));
      //向地图上添加标注
      this.tiandiMap.addOverLay(marker);
      const _this = this;
      setTimeout(function () {
        _this.tiandiMap.panTo(new T.LngLat(Number(lng), Number(lat)));
      }, 500);
    },
    // 天地图逆地址编码
    getAddressZh(lng, lat, needAddr) {
      let geocoder = new T.Geocoder();
      geocoder.getLocation(new T.LngLat(lng, lat), (result) => {
        if(result.getStatus() == 0) {
          const { addressComponent } = result.getAddressComponent();
          if(needAddr){ // 点击地图获取经纬度需要给地址赋值
            this.address = addressComponent.address
            this.attendanceSiteName = addressComponent.poi;
          }
          this.district = addressComponent.province + addressComponent.city + addressComponent.county;
        }
      });
    },
    // 天地图搜索
    async onSearchMap() {
      const keywords = document.querySelector(".search-wraper input").value;
      const params = {
        keyWord: keywords,
        mapBound: '-180,-90,180,90',
        level: 12,
        queryType: 1,
        start: 0,
        count: 10
      }
      const { data } = await getPlaceByTiandi(params)
      if (data?.status?.infocode === 1000) {
        const { pois } = data;
        if (pois) {
          this.attendanceSiteName = document.querySelector(".search-wraper input").value;
          let latSum = 0;
          let lngSum = 0;
          if (pois.length > 0) {
            pois.forEach((poi) => {
              const lonlat = poi?.lonlat?.split(',');
              lngSum += lonlat[0] || 0;
              latSum += lonlat[1] || 0;
              this.address = pois[0].address
            });
            let center = {
              lng: lngSum / pois.length,
              lat: latSum / pois.length,
            };
            this.center = [center.lng, center.lat];
            this.clearTiandiMap(); // 清除天地图markers
            const markerPoi = pois[0].lonlat?.split(',');
            this.addTiandiMarker(markerPoi[0], markerPoi[1]);
            const result = gcoord.transform(
              [markerPoi[0], markerPoi[1]],   // 经纬度坐标
              gcoord.WGS84,                   // 当前坐标系
              gcoord.GCJ02,                   // 目标坐标系
            );
            this.formList.xy = result[0] + "," + result[1];
            this.longitude = result[0]?.toFixed(6);
            this.latitude = result[1]?.toFixed(6);
            this.getAddressZh(markerPoi[0], markerPoi[1])
          }
        }
      }
    },
    // 点击天地图事件
    onMapClick(e) {
      const result = gcoord.transform(
        [e.lnglat.getLng(), e.lnglat.getLat()],   // 经纬度坐标
        gcoord.WGS84,                             // 当前坐标系
        gcoord.GCJ02,                             // 目标坐标系
      );
      this.longitude = result[0]?.toFixed(6);
      this.latitude = result[1]?.toFixed(6);
      this.getAddressZh(e.lnglat.getLng(), e.lnglat.getLat(), true);
      this.clearTiandiMap();
      this.addTiandiMarker(e.lnglat.getLng(), e.lnglat.getLat());
    },
    // 天地图初始化
    initTiandiMap() {
      this.tiandiMap = new T.Map('mapDiv');
      const lnglat = new T.LngLat(116.40969,39.89945);
      this.tiandiMap.centerAndZoom(lnglat,12);
      this.tiandiMap.addEventListener("click", this.onMapClick);
    },
    onSave(){ 
      if(!this.longitude){
        this.$message({type: "warning",message: "请搜索，再点击确定"});
        return
      }
      console.log('hahahhah', this.longitude)
      window.parent.postMessage({longitude:this.longitude,latitude:this.latitude,address:this.address,attendanceSiteName:this.attendanceSiteName,district:this.district},'*')     
    },
    onCopylong(){
      console.log(this.longitude)
      if(!this.longitude){
        this.$message({type: "warning",message: "请搜索，再点击复制"});
        return
      }
      let link=JSON.stringify(this.longitude)
      this.$nextTick(()=>{
          let clipboard=new Clipboard('.copyTextlong', {
              text: function () {
                return link
              }
            });
            clipboard.on("success", e => {
                this.$message({
                  type: "success",
                  message: "复制成功"
                });
                clipboard.destroy(); // 释放内存
          });
          clipboard.on("error", e => {
              this.$message({
                type: "warning",
                message: "该浏览器不支持自动复制!"
              }); // 不支持复制
              clipboard.destroy(); // 释放内存
          });
      });  
    },
    onCopylat(){
      console.log(this.latitude)
      if(!this.latitude){
        this.$message({type: "warning",message: "请搜索，再点击复制"});
        return
      }
      let link=JSON.stringify(this.latitude)
      this.$nextTick(()=>{
          let clipboard=new Clipboard('.copyTextlat', {
              text: function () {
                return link
              }
            });
            clipboard.on("success", e => {
                this.$message({
                  type: "success",
                  message: "复制成功"
                });
                clipboard.destroy(); // 释放内存
          });
          clipboard.on("error", e => {
              this.$message({
                type: "warning",
                message: "该浏览器不支持自动复制!"
              }); // 不支持复制
              clipboard.destroy(); // 释放内存
          });
      });
    },
    onCopyaddress(){
      console.log(this.address)
      if(!this.address){
        this.$message({type: "warning",message: "请搜索，再点击复制"});
        return
      }
      let link=JSON.stringify(this.address)
      this.$nextTick(()=>{
          let clipboard=new Clipboard('.copyTextaddress', {
              text: function () {
                return link
              }
            });
            clipboard.on("success", e => {
                this.$message({
                  type: "success",
                  message: "复制成功"
                });
                clipboard.destroy(); // 释放内存
          });
          clipboard.on("error", e => {
              this.$message({
                type: "warning",
                message: "该浏览器不支持自动复制!"
              }); // 不支持复制
              clipboard.destroy(); // 释放内存
          });
      });
    },
    getRefVal(val) {
      console.log('22',val);
      this.formList = val;
      if(this.formList.longitude){
        let lgat=this.formList.longitude+","+this.formList.latitude
        this.$set(this.formList,'xy',lgat)     
        let centerArr=[this.formList.longitude,this.formList.latitude]
        this.center=[centerArr[0],centerArr[1]]
      }
    },
    // 搜索
    onSearchResult(pois) {
      this.attendanceSiteName=document.querySelector(".search-box-wrapper input").value
      console.log(pois);
      let latSum = 0;
      let lngSum = 0;
      if (pois.length > 0) {
        pois.forEach((poi) => {
          let { lng, lat } = poi;
          lngSum += lng;
          latSum += lat;
          this.address=pois[0].address
        });
        let center = {
          lng: lngSum / pois.length,
          lat: latSum / pois.length,
        };
        this.center = [center.lng, center.lat];       
        this.markers = [];    //标记点先清空  
        this.markers.push([pois[0].lng,pois[0].lat]) 
        this.formList.xy = pois[0].lng + "," + pois[0].lat;
        this.longitude=pois[0].lng;
        this.latitude=pois[0].lat;      
        this.$nextTick(()=>{
          this.$refs.map.$$getInstance().setFitView()//居中地图位置          
        })
        let self=this;
        // 这里通过高德 SDK 完成。
        var geocoder = new AMap.Geocoder({
            radius: 1000,
            extensions: "all",
          });
          geocoder.getAddress([this.longitude, this.latitude], function(status, result) {
            // debugger
            if (status === "complete" && result.info === "OK") {
              if (result && result.regeocode) {
                console.log(result)             
                let city=''
                if(result.regeocode.addressComponent.city==''){
                  city='市辖区'
                  if(result.regeocode.addressComponent.province.indexOf('重庆市')>-1&&result.regeocode.addressComponent.district.indexOf('县')>-1){
                    city='县'
                  }
                }else{
                  city=result.regeocode.addressComponent.city
                }  
                self.district = result.regeocode.addressComponent.province + city + result.regeocode.addressComponent.district;               
              }
            }
          });
      }
    },
  },
};
"},null]}