Browse Source

update to new mapbox lib

pull/43/head
Aaron Parecki 3 years ago
parent
commit
62de25ebef
1 changed files with 42 additions and 8 deletions
  1. +42
    -8
      compass/public/assets/share.js

+ 42
- 8
compass/public/assets/share.js View File

@ -1,13 +1,23 @@
var map = L.map('map', { zoomControl: false }).setView([45.516, -122.660], 14, null, null, 24); var map = L.map('map', { zoomControl: false }).setView([45.516, -122.660], 14, null, null, 24);
L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token={accessToken}', { var opts = {
attribution: 'Map data &copy; <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors, <a href="https://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, Imagery © <a href="https://www.mapbox.com/">Mapbox</a>', attribution: 'Map data &copy; <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors, <a href="https://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, Imagery © <a href="https://www.mapbox.com/">Mapbox</a>',
maxZoom: 18, maxZoom: 18,
id: 'mapbox.streets', zoomOffset: -1,
accessToken: 'pk.eyJ1IjoiYWFyb25wayIsImEiOiI1T0tpNjdzIn0.OQjXyI3xSt8Dj8na3l90Sg' tileSize: 512,
}).addTo(map); id: 'mapbox/light-v10',
accessToken: 'pk.eyJ1IjoiYWFyb25wayIsImEiOiJja3A0eXV2ZXIwMGt3MnVuc2Uzcm1yYzFuIn0.-_qwPOLRiQk8t56xs6vkfg'
};
if(getQueryVariable('attribution') == 0) {
opts.attribution = 'Mapbox';
}
new L.Control.Zoom({ position: 'topleft' }).addTo(map); L.tileLayer('https://api.mapbox.com/styles/v1/{id}/tiles/{z}/{x}/{y}?access_token={accessToken}', opts).addTo(map);
if(getQueryVariable('controls') != 0) {
new L.Control.Zoom({ position: 'topleft' }).addTo(map);
}
var geojsonLineOptions = { var geojsonLineOptions = {
color: "#0033ff", color: "#0033ff",
@ -24,14 +34,21 @@ var startIcon = L.icon({
// Load the current location and show on the map // Load the current location and show on the map
var currentLocationMarker; var currentLocationMarker;
var currentTrack;
function getCurrentLocation() { function getCurrentLocation() {
var interval = 5000;
if(getQueryVariable('interval')) {
interval = getQueryVariable('interval');
}
$.getJSON("/share/current.json?token="+$("#share_token").val(), function(data){ $.getJSON("/share/current.json?token="+$("#share_token").val(), function(data){
if(data.data) { if(data.data) {
moveMarkerToPosition(data.data); moveMarkerToPosition(data.data);
map.setView(currentLocationMarker.getLatLng()); map.setView(currentLocationMarker.getLatLng());
} }
setTimeout(getCurrentLocation, 5000); setTimeout(getCurrentLocation, interval);
}); });
} }
@ -46,6 +63,12 @@ function moveMarkerToPosition(feature) {
if(feature && feature.geometry) { if(feature && feature.geometry) {
var coord = pointFromGeoJSON(feature.geometry.coordinates); var coord = pointFromGeoJSON(feature.geometry.coordinates);
if(coord) { if(coord) {
if(!currentTrack) {
currentTrack = L.polyline([coord, coord]).addTo(map);
} else {
currentTrack.addLatLng(coord);
}
if(!currentLocationMarker) { if(!currentLocationMarker) {
currentLocationMarker = L.marker(coord).addTo(map); currentLocationMarker = L.marker(coord).addTo(map);
} else { } else {
@ -58,3 +81,14 @@ function moveMarkerToPosition(feature) {
function pointFromGeoJSON(geo) { function pointFromGeoJSON(geo) {
return L.latLng(geo[1], geo[0]) return L.latLng(geo[1], geo[0])
} }
function getQueryVariable(variable) {
var query = window.location.search.substring(1);
var vars = query.split('&');
for (var i = 0; i < vars.length; i++) {
var pair = vars[i].split('=');
if (decodeURIComponent(pair[0]) == variable) {
return decodeURIComponent(pair[1]);
}
}
}

|||||||
x
 
000:0
Loading…
Cancel
Save