142 lines
3.1 KiB
JavaScript
142 lines
3.1 KiB
JavaScript
|
|
const zuerich_bounds = {
|
|
north: 47.41590970260092,
|
|
south: 47.315703309031846,
|
|
west: 8.45742642179812,
|
|
east: 8.600047733589026,
|
|
};
|
|
|
|
function initMap() {
|
|
const map = new google.maps.Map(document.getElementById('map'), {
|
|
mapId: "fd4581e1612d9ef",
|
|
center: {lat: 47.38109493760974, lng: 8.521861488204763},
|
|
restriction: {
|
|
latLngBounds: zuerich_bounds,
|
|
strictBounds: false,
|
|
},
|
|
zoom: 13,
|
|
disableDefaultUI: true,
|
|
gestureHandling: "greedy",
|
|
|
|
});
|
|
infoWindow = new google.maps.InfoWindow();
|
|
addMarkers();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function addMarkers(){
|
|
|
|
let url = "system/alleInfosHolen.php";
|
|
fetch(url)
|
|
.then((response) => {
|
|
return response.json();
|
|
})
|
|
.then((markerData) => {
|
|
for (let i = 0; i < markerData.length; i++) {
|
|
if (markerData[i].sichtbarkeit = 1) {
|
|
const marker = new google.maps.Marker({
|
|
position: {lat: markerData[i].koordinatenLat, lng: markerData[i].koordinatenLng},
|
|
map: map,
|
|
title: markerData[i].titel,
|
|
icon: {
|
|
url: "/images/ort.png",
|
|
scaledSize: new google.maps.Size(38+(markerData[i].likes), 38+(markerData[i].likes)),
|
|
},
|
|
animation: google.maps.Animation.DROP,
|
|
|
|
});
|
|
|
|
|
|
marker.addListener("click", () => {
|
|
ideeAnzeigen(markerData[i]);
|
|
|
|
})
|
|
}
|
|
else {
|
|
|
|
}
|
|
}
|
|
})
|
|
.catch(function(error) {
|
|
console.log('Error!: ' + error.message);
|
|
});
|
|
}
|
|
|
|
// NEUE IDEE ERFASSEN
|
|
|
|
map.addListener("click", (mapsMouseEvent) => {
|
|
newMarker(mapsMouseEvent.latLng);
|
|
|
|
formularErstellen(mapsMouseEvent.latLng);
|
|
})
|
|
|
|
|
|
function newMarker(mousePosition) {
|
|
const newMarker = new google.maps.Marker({
|
|
|
|
position: mousePosition,
|
|
map: map,
|
|
animation: google.maps.Animation.DROP,
|
|
|
|
});
|
|
|
|
newMarker.setMap(map);
|
|
|
|
let icon = {url:"/images/ort.png", size: new google.maps.Size(30, 30)};
|
|
|
|
newMarker.setIcon("/images/newMarker.jpg");
|
|
|
|
$("#cancel").click(function() {
|
|
document.getElementById("idee").innerHTML = "";
|
|
newMarker.setMap(null);
|
|
})
|
|
|
|
}
|
|
|
|
|
|
// CHANCEL location_button
|
|
|
|
// LOCATION BUTTON
|
|
|
|
let location_button = document.getElementById("currentLocation");
|
|
// map.controls[google.maps.ControlPosition.TOP_CENTER].push("location_button");
|
|
location_button.addEventListener("click", () => {
|
|
// Try HTML5 geolocation.
|
|
if (navigator.geolocation) {
|
|
navigator.geolocation.getCurrentPosition(
|
|
(position) => {
|
|
const pos = {
|
|
lat: position.coords.latitude,
|
|
lng: position.coords.longitude,
|
|
};
|
|
|
|
const marker = new google.maps.Marker({
|
|
position: pos,
|
|
map: map,
|
|
icon: {
|
|
url: "/images/current_location.png",
|
|
animation: google.maps.Animation.DROP,
|
|
scaledSize: new google.maps.Size(50, 50)
|
|
}});
|
|
|
|
map.setCenter(pos);
|
|
},
|
|
() => {
|
|
handleLocationError(true, infoWindow, map.getCenter());
|
|
}
|
|
);
|
|
} else {
|
|
// Browser doesn't support Geolocation
|
|
handleLocationError(false, infoWindow, map.getCenter());
|
|
}
|
|
|
|
});
|
|
}
|