smeijer / leaflet-geosearch

A geocoding/address-lookup library supporting various api providers.
https://smeijer.github.io/leaflet-geosearch/
MIT License
1.04k stars 273 forks source link

How to access selected location ? #305

Closed muzammil17 closed 2 years ago

muzammil17 commented 2 years ago

Hi,

This is my complete code and I want to select a location on the result data, but I do not see any way of how to get the result and navigate my marker to that location. One thing more is that Icon is not loading or what I am not understanding, these are some errors in console

I am using vue 3 and leaflet.

under below errors my code is also mention.

GET ")marker-icon.png net::ERR_INVALID_URL ")marker-shadow.png:1 GET ")marker-shadow.png net::ERR_INVALID_URL leaflet-src.esm.js?1797:9617 Uncaught (in promise) TypeError: Failed to execute 'appendChild' on 'Node': parameter 1 is not of type 'Node'. at NewClass._updateContent (leaflet-src.esm.js?1797:9617) at NewClass.update (leaflet-src.esm.js?1797:9528) at NewClass.onAdd (leaflet-src.esm.js?1797:9465) at NewClass.onAdd (leaflet-src.esm.js?1797:9751) at NewClass._layerAdd (leaflet-src.esm.js?1797:6561) at Proxy.whenReady (leaflet-src.esm.js?1797:4422) at Proxy.addLayer (leaflet-src.esm.js?1797:6623) at Proxy.openPopup (leaflet-src.esm.js?1797:9975) at NewClass.openPopup (leaflet-src.js?7713:10069) at NewClass.addMarker (geosearch.module.js?2ba0:1)

<template>
  <div class="updateLocation">
    <!-- <q-btn color="primary" label="getLocation" @click="getCurrentLocation" /> -->
    <div class="updateLocation__title">Update Location</div>
    <l-map
      v-if="true"
      :zoom="zoom"
      :center="center"
      ref="myMap"

      @ready="onStart()"
      class="updateLocation__map window-height"
    >
      <l-tile-layer :url="url" :attribution="attribution" />
      <l-marker :lat-lng="withPopup" draggable @update:latLng="updateLatLng">
        <l-popup>
          <div>I am here: {{ currentCenter }}</div>
        </l-popup>
      </l-marker>
    </l-map>

    <div class="row updateAvatar__btn q-mt-lg">
      <q-btn
        color="primary"
        class="avatarBtn"
        no-caps
        @click="getCurrentLocation"
      >
        <span class="updateAvatar__btn--label">Current Location</span>
      </q-btn>
    </div>

    <div class="row updateAvatar__btn q-mt-lg">
      <q-btn color="primary" class="avatarBtn" no-caps>
        <span class="updateAvatar__btn--label">Save</span>
      </q-btn>
    </div>
  </div>
</template>

<script>
import { latLng } from "leaflet";
import {
  LMap,
  LMarker,
  LTileLayer,
  // LTooltip,
  LPopup,
} from "@vue-leaflet/vue-leaflet";
import "leaflet/dist/leaflet.css";
import "leaflet-geosearch/dist/geosearch.css";
import { Icon } from "leaflet";

import { GeoSearchControl, OpenStreetMapProvider } from "leaflet-geosearch";
export default {
  components: {
    LMap,
    LMarker,
    LTileLayer,
    // LTooltip,
    LPopup,
  },

  data() {
    return {
      url: "https://gis.malta1896.startdedicated.de/gis/{z}/{x}/{y}.png",
      zoom: 5,
      center: latLng(52.711989, 13.27886),
      attribution:
        '&copy; <a href="http://osm.org/copyright">OpenStreetMap</a> contributors',
      withPopup: latLng(52.701289, 13.27886),
      withTooltip: latLng(52.701289, 13.27286),
      currentZoom: 11.5,
      currentCenter: latLng(52.711989, 13.27886),
      showParagraph: false,
      mapOptions: {
        zoomSnap: 0,
      },
      map: null,
    };
  },

  methods: {
    updateCenter(center) {
      this.currentCenter = center;
    },

    onStart() {
      this.map = this.$refs.myMap.leafletObject;
      const lat = this.$store.getters.getUserStateData("latitude");
      const lng = this.$store.getters.getUserStateData("longitude");

      this.currentCenter = latLng(lat, lng);
      this.center = latLng(lat, lng);
      this.withPopup = latLng(lat, lng);
      this.withTooltip = latLng(lat, lng);
      // this.center = latLng(this.latitude, this.longitude);

      const searchControl = new GeoSearchControl({
        provider: new OpenStreetMapProvider(),
        style: "bar",
        retainZoomLevel: true,
        showMarker: true,
        showPopup: true,
        resultFormat: function(t) {
          console.log(t)
          return t.result.label
        }
        // marker: LMarker,
      });

      this.map.addControl(searchControl);
      console.log({...this.map._events})

      this.$nextTick(() => {
        this.map.panTo(this.currentCenter);
      });
    },

    getCurrentLocation() {
      navigator.geolocation.getCurrentPosition(
        (position) => {
          this.currentCenter = latLng(
            position.coords.latitude,
            position.coords.longitude
          );
          this.center = latLng(
            position.coords.latitude,
            position.coords.longitude
          );
          this.withPopup = latLng(
            position.coords.latitude,
            position.coords.longitude
          );
          this.withTooltip = latLng(
            position.coords.latitude,
            position.coords.longitude
          );

          this.$nextTick(() => {
            this.map.panTo(this.currentCenter);
          });
        },
        (error) => {
          console.error(error);
        }
      );
    },

    updateLatLng({ lat, lng }) {
      this.currentCenter = latLng(lat, lng);
      this.center = latLng(lat, lng);
      this.withPopup = latLng(lat, lng);
      this.withTooltip = latLng(lat, lng);

      this.$nextTick(() => {
        this.map.panTo(this.currentCenter);
      });
    },

    async saveLocation() {
      try {
        const res = await this.$store.dispatch("saveLocation", {
          lat: this.withPopup.lat,
          lng: this.withPopup.lng,
        });

        console.log(res);
      } catch (err) {
        console.error(err);
      }
    },
  },
};
</script>

<style lang="scss">
.updateLocation {
  &__title {
    text-align: left;
    font: normal normal bold 24px/32px Raleway;
    letter-spacing: 0px;
    color: $textColor;
    opacity: 1;
    padding-top: 20px;
    padding-left: 13px;
  }

  &__map {
    max-height: 500px !important;
    height: 100vh !important;
  }
}
</style>
smeijer commented 2 years ago

Sorry, I'm closing this as it doesn't feel like an issue in this library, and I don't know any vue.