import { currentLocationIcon, targetLocationIcon, } from "@/components/Leaflet/icons" import { toast } from "@/lib/utils" import L from "leaflet" type TargetLocation = [lat: number, lng: number] | null const mapEl = document.getElementById("map") const targetLocation = mapEl?.dataset.targetLocation const data = targetLocation ? JSON.parse(targetLocation) : null const TARGET_LOCATION = data as TargetLocation var map = L.map("map") if (TARGET_LOCATION) map.setView(TARGET_LOCATION, 13) L.tileLayer("https://tile.openstreetmap.org/{z}/{x}/{y}.png", { maxZoom: 19, attribution: '© OpenStreetMap', }).addTo(map) let currentLocationMarker: L.Marker export function mapLocationSuccessCallback(position: GeolocationPosition) { const currentPos = { lat: position.coords.latitude, lng: position.coords.longitude, } if (currentLocationMarker) { currentLocationMarker.setLatLng(currentPos) } else { currentLocationMarker = L.marker(currentPos, { icon: currentLocationIcon }) currentLocationMarker.addTo(map) } } const CurrentLocation = L.Control.extend({ onAdd: function (map: L.Map) { const locationButton = document.createElement("button") locationButton.textContent = "Konumuma Git" locationButton.classList.add("custom-map-control-button", "disabled-button") locationButton.type = "button" locationButton.id = "current-location-control" locationButton.addEventListener("click", () => { if (currentLocationMarker) { map.setView(currentLocationMarker.getLatLng(), 12) } else { toast("Konumunuza erişilemiyor, lütfen biraz bekleyip tekrar deneyin.") } }) return locationButton }, }) const GoToTargetLocation = L.Control.extend({ onAdd: function (map: L.Map) { const locationButton = document.createElement("button") locationButton.textContent = "Hedefe Git" locationButton.classList.add("custom-map-control-button") locationButton.addEventListener("click", () => { if (TARGET_LOCATION) map.setView(TARGET_LOCATION, 12) }) return locationButton }, }) const goToCurrentLocationControl = new CurrentLocation({ position: "bottomleft", }) const targetLocationControl = new GoToTargetLocation({ position: "bottomleft", }) function addTargetLocationMarker(target: TargetLocation) { if (target) { L.marker(target, { icon: targetLocationIcon }).addTo(map) L.circle(target, { color: "blue", fillColor: "#30f", fillOpacity: 0.2, radius: 50, }).addTo(map) } } addTargetLocationMarker(TARGET_LOCATION) targetLocationControl.addTo(map) goToCurrentLocationControl.addTo(map)