mirror of https://github.com/4xmen/xshop.git
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
114 lines
2.8 KiB
Vue
114 lines
2.8 KiB
Vue
5 months ago
|
<template>
|
||
|
<div id="latlng">
|
||
|
<div ref="mapContainer" :style="'height: 300px;'+mapStyle"></div>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
|
||
|
import L from 'leaflet';
|
||
|
import 'leaflet/dist/leaflet.css';
|
||
|
|
||
|
export default {
|
||
|
name: "latlng",
|
||
|
components: {},
|
||
|
data: () => {
|
||
|
return {
|
||
|
map: null,
|
||
|
marker: null,
|
||
|
zoom: 10,
|
||
|
address: '',
|
||
|
zip: '',
|
||
|
lat: null,
|
||
|
lng: null,
|
||
|
}
|
||
|
},
|
||
|
props: {
|
||
|
darkMode: {
|
||
|
type: Boolean,
|
||
|
default: false,
|
||
|
},
|
||
|
ilat: { // init lat
|
||
|
type: Number,
|
||
|
default: 35.83266000,
|
||
|
},
|
||
|
ilng: { // init lng
|
||
|
type: Number,
|
||
|
default: 50.99155000,
|
||
|
},
|
||
|
izoom:{
|
||
|
type: Number,
|
||
|
default: 10,
|
||
|
},
|
||
|
},
|
||
|
mounted() {
|
||
|
this.lat = this.ilat;
|
||
|
this.lng = this.ilng;
|
||
|
this.zoom = this.izoom;
|
||
|
this.initMap();
|
||
|
},
|
||
|
computed: {
|
||
|
mapStyle() {
|
||
|
if (this.darkMode) {
|
||
|
return 'filter: invert(100%) hue-rotate(120deg) brightness(95%) contrast(90%);';
|
||
|
}
|
||
|
return '';
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
initMap() {
|
||
|
this.map = L.map(this.$refs.mapContainer).setView([this.lat, this.lng], this.zoom);
|
||
|
|
||
|
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
||
|
attribution: '© openstreetmap',
|
||
|
attributionControl: false,
|
||
|
}).addTo(this.map);
|
||
|
|
||
|
this.map.on('click', this.onMapClick);
|
||
|
this.map.attributionControl.setPrefix('xShop');
|
||
|
|
||
|
},
|
||
|
onMapClick(e) {
|
||
|
if (this.marker) {
|
||
|
this.map.removeLayer(this.marker);
|
||
|
}
|
||
|
|
||
|
this.marker = L.marker(e.latlng).addTo(this.map);
|
||
|
// You can emit the selected location or perform any other desired action here
|
||
|
// console.log('Selected location:', e.latlng);
|
||
|
this.lat = e.latlng.lat;
|
||
|
this.lng = e.latlng.lng;
|
||
|
|
||
|
try {
|
||
|
document.querySelector('#lat').value = this.lat;
|
||
|
document.querySelector('#lng').value = this.lng;
|
||
|
} catch(e) {
|
||
|
console.log(e.message);
|
||
|
}
|
||
|
|
||
|
},
|
||
|
// changeMapCenter(lat, lng) {
|
||
|
// try {
|
||
|
//
|
||
|
// this.map.setView([lat, lng], this.zoom);
|
||
|
// } catch (e) {
|
||
|
// // console.log(e.message);
|
||
|
// setTimeout(() => {
|
||
|
// console.log('repeat');
|
||
|
// this.changeMapCenter(lat, lng);
|
||
|
// }, 10);
|
||
|
// }
|
||
|
//
|
||
|
// // Change the map center to [40.7128, -74.0059] (New York City) with zoom level 12
|
||
|
//
|
||
|
// },
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped>
|
||
|
#latlng {
|
||
|
|
||
|
}
|
||
|
</style>
|