- // ==UserScript==
- // @name WME Open Other Maps
- // @namespace https://greasyfork.org/users/30701-justins83-waze
- // @version 2018.02.20.01
- // @description Links for opening external resources at the WME location and WME from external resources
- // @author JustinS83
- // @include https://www.waze.com/editor*
- // @include https://www.waze.com/*/editor*
- // @include https://beta.waze.com*
- // @include https://www.google.com/maps*
- // @include *wv511.org/*
- // @exclude https://www.waze.com/user/editor*
- // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
- // @require https://greasyfork.org/scripts/13097-proj4js/code/Proj4js.js
- // @grant none
- // ==/UserScript==
-
- (function() {
- 'use strict';
- //var jqUI_CssSrc = GM_getResourceText("jqUI_CSS");
- //GM_addStyle(jqUI_CssSrc);
-
- var settings = {};
- var gmapsIcon = "";
- var mapillaryIcon = "";
- var terraIcon = "";
- var wikimapiaIcon = "";
- var bingIcon = "";
- var osmIcon = "";
- var yandexIcon = "";
- var hereIcon = "";
- var midriveIcon = "";
- var NYFCIcon = "";
-
- function initInterface(){
- var $section = $("<div>");
- $section.html([
- '<div>',
- '<p>The below maps are legal to use and do not violate copyright</p>',
- `<div><input type="checkbox" id="chkMiDrive" class="OOMchk"><label for="chkMiDrive"><img src="${midriveIcon}" height="18" width="18">MiDrive</label></div>`,
- `<div><input type="checkbox" id="chkNYFC" class="OOMchk"><img src="${NYFCIcon}" height="18" width="18">NY FC</div>`,
- '</br>',
- "<p>The below maps are for <span style='color:red; font-weight:bold;'>reference only</span> and <b>no data</b> should be copied from them as it violates copyright.</p>",
- `<div><input type="checkbox" id="chkGMaps" class="OOMchk"><label for="chkGMaps"><img src="${gmapsIcon}" height="18" width="18">Google Maps</label></div>`,
- `<div><input type="checkbox" id="chkMapillary" class="OOMchk"><label for="chkMapillary"><img src="${mapillaryIcon}" height="18" width="18">Mapillary</label></div>`,
- `<div><input type="checkbox" id="chkTerraserver" class="OOMchk"><label for="chkTerraserver"><img src="${terraIcon}" height="18" width="18">Terraserver</label></div>`,
- `<div><input type="checkbox" id="chkWikimapia" class="OOMchk"><label for="chkWikimapia"><img src="${wikimapiaIcon}" height="18" width="18">Wikimapia</label></div>`,
- `<div><input type="checkbox" id="chkBing" class="OOMchk"><label for="chkBing"><img src="${bingIcon}" height="18" width="18">Bing Maps</label></div>`,
- `<div><input type="checkbox" id="chkOSM" class="OOMchk"><label for="chkOSM"><img src="${osmIcon}" height="18" width ="18">Open Street Map</label></div>`,
- `<div><input type="checkbox" id="chkYandex" class="OOMchk"><label for="chkYandex"><img src="${yandexIcon}" height="18" width ="18">Yandex</label></div>`,
- `<div><input type="checkbox" id="chkHere" class="OOMchk"><label for="chkHere"><img src="${hereIcon}" height="18" width ="18">Here</label></div>`,
- '</br><div>',
- '<fieldsetstyle="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
- '<legend style="margin-bottom:0px; border-bottom-style:none;width:auto;"><h4>Map Language (where applicable)</h4></legend>',
- '<input type="radio" name="radOOMLanguage" id="radOOMNoLang">Do not set a language</br>',
- '<input type="radio" name="radOOMLanguage" id="radOOMWMELang">Use WME language</br>',
- '<input type="radio" name="radOOMLanguage" id="radOOMCustomLang">Custom language <input type="text" name="txtOOMLanguage" id="txtOOMLanguage" style="border: 1px solid #000000;" size="4"/>',
- '</fieldset>',
- '</div>',
- '</div>'
- ].join(' '));
-
- new WazeWrap.Interface.Tab('OOM', $section.html(), init);
- }
-
- function init(){
- loadSettings();
- setChecked('chkGMaps', settings.GMaps);
- setChecked('chkMapillary', settings.Mapillary);
- setChecked('chkTerraserver', settings.Terraserver);
- setChecked('chkWikimapia', settings.Wikimapia);
- setChecked('chkBing', settings.Bing);
- setChecked('chkOSM', settings.OSM);
- setChecked('chkYandex', settings.Yandex);
- setChecked('chkHere', settings.Here);
- setChecked('chkMiDrive', settings.MiDrive);
- setChecked('chkNYFC', settings.NYFC);
-
- if(settings.LangSetting == 0)
- setChecked("radOOMNoLang", true);
- else if(settings.LangSetting == 1)
- setChecked("radOOMWMELang", true);
- else
- setChecked("radOOMCustomLang", true);
-
- $('#txtOOMLanguage')[0].value = settings.CustLang;
-
- $('.olControlAttribution').css("right", "400px");
-
- LoadMapButtons();
- $('.OOMchk').change(function() {
- var settingName = $(this)[0].id.substr(3);
- settings[settingName] = this.checked;
- saveSettings();
- LoadMapButtons();
- });
- $("[id^='rad']").change(function() {
- if(isChecked("radOOMNoLang"))
- settings.LangSetting = 0;
- else if(isChecked("radOOMWMELang"))
- settings.LangSetting = 1;
- else
- settings.LangSetting = 2;
- saveSettings();
- });
- $('#txtOOMLanguage').focusout(function(){
- settings.CustLang = $('#txtOOMLanguage').val();
- saveSettings();
- });
- }
-
- function GetLanguage()
- {
- if(isChecked("radOOMNoLang"))
- return "";
- else if(isChecked("radOOMWMELang"))
- return I18n.currentLocale().replace("en-US", "en");
- else //Custom Language
- return $('#txtOOMLanguage').val();
- }
-
- function LoadMapButtons()
- {
- $('#OOMMiDrive').remove();
- if(settings.MiDrive)
- {
- let $section = $("<div>", {style:"padding:8px 16px"});
- $section.html([
- '<span id="OOMMiDrive">',
- `<img src="${midriveIcon}" alt="MiDrive" width="18" height="18" id="OOMMiDriveImg" title="Open in MiDrive" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
-
- $('#OOMMiDriveImg').click(function(){
- var topleft= (new OpenLayers.LonLat(Waze.map.getExtent().left,Waze.map.getExtent().top));
- var bottomright= (new OpenLayers.LonLat(Waze.map.getExtent().right,Waze.map.getExtent().bottom));
- var xmin = topleft.lon;
- var xmax = bottomright.lon;
- var ymin = bottomright.lat;
- var ymax = topleft.lat;
-
- window.open('http://mdotnetpublic.state.mi.us/drive/Default.aspx?xmin=' + xmin + '&xmax=' + xmax + '&ymin=' + ymin + '&ymax=' + ymax + '&lc=true&cam=true&tb=false&bc=false&bh1=false&bh2=false&sensor=false&inc=true&mp=false&sign=false&mb=false&cps=false&aps=false&bing=false&source=social&rsp=false&rest=false&park=false&plow=false', 'MiDrive');
- });
- }
-
- $('#OOMGMaps').remove();
- if(settings.GMaps)
- {
- let $section = $("<div>", {style:"padding:8px 16px"});
- $section.html([
- '<span id="OOMGMaps">',
- `<img src="${gmapsIcon}" alt="Google Maps" width="18" height="18" id="OOMGMapsImg" title="Open in Google Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
-
- $('#OOMGMapsImg').click(function(){
- let projI = new OpenLayers.Projection("EPSG:900913");
- let projE = new OpenLayers.Projection("EPSG:4326");
- let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- let lang = GetLanguage();
-
- window.open('https://www.google.com/maps/@' + lat + ',' + lon + ',' + ( W.map.zoom + 12) + 'z' + (lang != "" ? "?hl=" + lang : ""), 'Google Maps');
- });
- }
-
-
- //************** Mapillary *****************
- $('#OOMMapillary').remove();
- if(settings.Mapillary){
- let $sectionMapillary = $("<div>", {style:"padding:8px 16px"});
- $sectionMapillary.html([
- '<span id="OOMMapillary">',
- `<img src="${mapillaryIcon}" alt="Mapillary" width="18" height="18" id="OOMMapillaryImg" title="Open in Mapillary" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionMapillary.html());
- $('#OOMMapillaryImg').click(function(){
- var projI=new OpenLayers.Projection("EPSG:900913");
- var projE=new OpenLayers.Projection("EPSG:4326");
- var center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- var lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- var lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
-
- window.open(`https://www.mapillary.com/app/?lat=${lat}&lng=${lon}&z=${( W.map.zoom + 11)}`, 'Mapillary');
- });
- }
-
-
- //****************** Terraserver *********************
- $('#OOMTerraserver').remove();
- if(settings.Terraserver){
- var $sectionTerraserver = $("<div>", {style:"padding:8px 16px"});
- $sectionTerraserver.html([
- '<span id="OOMTerraserver">',
- `<img src="${terraIcon}" alt="Terraserver" width="18" height="18" id="OOMTerraserverImg" title="Open in Terraserver" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionTerraserver.html());
- $('#OOMTerraserverImg').click(function(){
- var center_lonlat=OpenLayers.Layer.SphericalMercator.inverseMercator(Waze.map.getCenter().lon,Waze.map.getCenter().lat);
- window.open(`http://www.terraserver.com/view?utf8=✓&searchLng=${center_lonlat.lon}&searchLat=${center_lonlat.lat}`);
- });
- }
-
-
- //********************* Wikimapia *********************
- $('#OOMWikimapia').remove();
- if(settings.Wikimapia){
- let $sectionWikimapia = $("<div>", {style:"padding:8px 16px"});
- $sectionWikimapia.html([
- '<span id="OOMWikimapia">',
- `<img src="${wikimapiaIcon}" alt="Wikimapia" width="18" height="18" id="OOMWikimapiaImg" title="Open in Wikimapia" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWikimapia.html());
- $('#OOMWikimapiaImg').click(function(){
- //var center_lonlat=OpenLayers.Layer.SphericalMercator.inverseMercator(Waze.map.getCenter().lon,Waze.map.getCenter().lat);
- var projI=new OpenLayers.Projection("EPSG:900913");
- var projE=new OpenLayers.Projection("EPSG:4326");
- var center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- var lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- var lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- let lang = GetLanguage();
- if(lang === "")
- lang = "en";
- window.open(`http://wikimapia.org/#${(lang !== "" ? "lang=" + lang : "")}&lat=${lat}&lon=${lon}&z=${( W.map.zoom + 12)}&m=b`);
- });
- }
-
- $('#OOMBing').remove();
- if(settings.Bing)
- {
- let $sectionBing = $("<div>", {style:"padding:8px 16px"});
- $sectionBing.html([
- '<span id="OOMBing">',
- `<img src="${bingIcon}" alt="Bing Maps" width="18" height="18" id="OOMBingImg" title="Open in Bing Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBing.html());
-
- $('#OOMBingImg').click(function(){
- let projI = new OpenLayers.Projection("EPSG:900913");
- let projE = new OpenLayers.Projection("EPSG:4326");
- let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- //let lang = I18n.currentLocale().replace("en-US", "en");
-
- window.open(`https://www.bing.com/maps?&cp=${lat}~${lon}&lvl=${( W.map.zoom + 12)}`);
- });
- }
-
- $('#OOMOSM').remove();
- if(settings.OSM){
- //https://www.openstreetmap.org/#map=16/39.5588/-84.2365
- let $sectionOSM = $("<div>", {style:"padding:8px 16px"});
- $sectionOSM.html([
- '<span id="OOMOSM">',
- `<img src="${osmIcon}" alt="Open Street Map" width="18" height="18" id="OOMOSMImg" title="Open in Open Street Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOSM.html());
-
- $('#OOMOSMImg').click(function(){
- let projI = new OpenLayers.Projection("EPSG:900913");
- let projE = new OpenLayers.Projection("EPSG:4326");
- let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- //let lang = I18n.currentLocale().replace("en-US", "en");
-
- window.open(`https://www.openstreetmap.org/#map=${(W.map.zoom + 12)}/${lat}/${lon}`);
- });
- }
-
- $('#OOMYandex').remove();
- if(settings.Yandex){
- //https://n.maps.yandex.ru/#!/?z=14&ll=46.019795%2C51.505120&l=nk%23sat
- let $sectionYandex = $("<div>", {style:"padding:8px 16px"});
- $sectionYandex.html([
- '<span id="OOMYandex">',
- `<img src="${yandexIcon}" alt="Yandex" width="18" height="18" id="OOMYandexImg" title="Open in Yandex" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionYandex.html());
-
- $('#OOMYandexImg').click(function(){
- let projI = new OpenLayers.Projection("EPSG:900913");
- let projE = new OpenLayers.Projection("EPSG:4326");
- let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- //let lang = I18n.currentLocale().replace("en-US", "en");
-
- window.open(`https://n.maps.yandex.ru/#!/?z=${(W.map.zoom + 12)}&ll=${lon}%2C${lat}&l=nk%23sat`);
- });
- }
-
- $('#OOMHere').remove();
- if(settings.Here){
- //https://wego.here.com/?map=39.56508,-84.26224,16,normal&x=ep
- let $sectionHere = $("<div>", {style:"padding:8px 16px"});
- $sectionHere.html([
- '<span id="OOMHere">',
- `<img src="${hereIcon}" alt="Here" width="18" height="18" id="OOMHereImg" title="Open in Here" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionHere.html());
-
- $('#OOMHereImg').click(function(){
- let projI = new OpenLayers.Projection("EPSG:900913");
- let projE = new OpenLayers.Projection("EPSG:4326");
- let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
- let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
- let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
- //let lang = I18n.currentLocale().replace("en-US", "en");
-
- window.open(`https://wego.here.com/?map=${lat},${lon},${(W.map.zoom + 12)},satellite&x=ep`);
- });
- }
-
- $('#OOMNYFC').remove();
- if(settings.NYFC){
- let $sectionNYFC = $("<div>", {style:"padding:8px 16px"});
- $sectionNYFC.html([
- '<span id="OOMNYFC">',
- `<img src="${NYFCIcon}" alt="NY FC" width="18" height="18" id="OOMNYFCImg" title="Open in NY FC" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
- '</span>'
- ].join(' '));
-
- $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNYFC.html());
-
- $('#OOMNYFCImg').click(function(){
- let e=W.map.getExtent();
- let geoNW=new OL.Geometry.Point(e.left,e.top);
- let geoSE=new OL.Geometry.Point(e.right,e.bottom);
-
- Proj4js.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs";
-
- let source = new Proj4js.Proj('EPSG:900913');
- let dest = new Proj4js.Proj('EPSG:26918');
-
- geoNW = new Proj4js.Point(geoNW.x,geoNW.y);
- geoSE = new Proj4js.Point(geoSE.x,geoSE.y);
-
- Proj4js.transform(source, dest, geoNW);
- Proj4js.transform(source, dest, geoSE);
-
- let mapScale = 36111.909643;
-
- switch (W.map.zoom) {
- case 0:
- case 1:
- mapScale = 72223.819286;
- break;
- case 2:
- mapScale = 36111.909643;
- break;
- case 3:
- mapScale = 18055.954822;
- break;
- default:
- mapScale = 9027.977411;
- break;
- }
-
- let URL='http://gis3.dot.ny.gov/html5viewer/?viewer=FC&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y;
- window.open(URL,"_blank");
- });
- }
- }
-
- function loadSettings() {
- var loadedSettings = $.parseJSON(localStorage.getItem("OOM_Settings"));
- var defaultSettings = {
- GMaps: true,
- Mapillary: true,
- Terraserver: true,
- Wikimapia: false,
- Bing: false,
- OSM: false,
- LangSetting: 1,
- CustLang: "",
- Yandex: false,
- Here: false,
- MiDrive: false,
- NYFC: false
- };
- settings = loadedSettings ? loadedSettings : defaultSettings;
- for (var prop in defaultSettings) {
- if (!settings.hasOwnProperty(prop))
- settings[prop] = defaultSettings[prop];
- }
- }
-
- function saveSettings() {
- if (localStorage) {
- var localsettings = {
- GMaps: settings.GMaps,
- Mapillary: settings.Mapillary,
- Terraserver: settings.Terraserver,
- Wikimapia: settings.Wikimapia,
- Bing: settings.Bing,
- OSM: settings.OSM,
- LangSetting: settings.LangSetting,
- CustLang: settings.CustLang,
- Yandex: settings.Yandex,
- Here: settings.Here,
- MiDrive: settings.MiDrive,
- NYFC: settings.NYFC
- };
-
- localStorage.setItem("OOM_Settings", JSON.stringify(localsettings));
- }
- }
-
- function isChecked(checkboxId) {
- return $('#' + checkboxId).is(':checked');
- }
-
- function setChecked(checkboxId, checked) {
- $('#' + checkboxId).prop('checked', checked);
- }
-
- function bootstrap(tries = 1) {
- if(location.href.indexOf("google.com/maps") > -1)
- bootstrapGeneral(initGoogleMaps, 1);
- else if(location.href.indexOf("wv511.org") > -1)
- bootstrapGeneral(initWV511, 1);
- else{
- if (W &&
- W.map &&
- W.model &&
- $ && WazeWrap.Ready) {
- initInterface();
- } else if (tries < 1000) {
- setTimeout(function () {bootstrap(tries++);}, 200);
- }}
- }
-
- function initGoogleMaps(){
- let $OOMWazeButton = document.createElement("div");
- $OOMWazeButton.innerHTML = '<div id="OOMWazeButtonDiv" style="height:30px; width:34px; position: fixed; right:30px; top:75px; cursor: pointer; background-image: url(https://imgur.com/NTLWfFz.png); background-repeat: no-repeat;" title="Open in WME"></div>';
- let parent = document.getElementById("content-container");
- parent.appendChild($OOMWazeButton);
-
- document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
- window.open(GMToWaze());
- });
-
- document.getElementById('OOMWazeButtonDiv').addEventListener("mouseenter",function(e) {
- document.addEventListener('keydown', copyPLHotkeyEvent);
- document.getElementsByClassName('widget-scene-canvas')[0].addEventListener('keydown', copyPLHotkeyEvent);
- });
-
- document.getElementById('OOMWazeButtonDiv').addEventListener('mouseleave', function() {
- document.removeEventListener('keydown', copyPLHotkeyEvent);
- document.getElementsByClassName('widget-scene-canvas')[0].removeEventListener('keydown', copyPLHotkeyEvent);
- });
- }
-
- var copyToClipboard = function(str) {
- var temp = document.createElement("input");
- document.body.append(temp);
- temp.value = str;
- temp.select();
- document.execCommand('copy');
- document.body.removeChild(temp);
- };
-
- var copyPLHotkeyEvent = function(e) {
- if ((e.metaKey || e.ctrlKey) && (e.which === 67))
- copyToClipboard(GMToWaze());
- };
-
- function GMToWaze(){
- let lon, lat, zoom;
- let curURL = location.href.split('@').pop().split(',');
- lon = curURL[1];
- lat = curURL[0];
- zoom = parseInt(curURL[2]);
- return `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`;
- }
-
- function bootstrapGeneral(initdelegate, tries = 1){
- if(document.readyState !== 'complete' )
- setTimeout(function() {bootstrapGeneral(initdelegate, tries++);}, 200);
- else
- initdelegate();
- }
-
- function initWV511(){
- if(document.getElementById("OOMWazeButtonDi") !== null)
- document.getElementById("OOMWazeButtonDi").remove();
-
- let $OOMWazeButton = document.createElement("div");
- $OOMWazeButton.setAttribute("id", "OOMWazeButtonDiv");
- $OOMWazeButton.setAttribute("style", "position:absolute; right:15px; top:190px; height:30px; width:34px; cursor:pointer; background-image:url(https://imgur.com/NTLWfFz.png); background-repeat:no-repeat;");
- $OOMWazeButton.setAttribute("title", "Open in WME");
- document.body.appendChild($OOMWazeButton);
-
- document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
- let lon1, lon2, lonCenter, lat1, lat2, latCenter;
- let latlon = location.href.split(":");
- lon1 = latlon[2];
- lat1 = latlon[3];
- lon2 = latlon[4];
- lat2 = latlon[5];
-
- lonCenter = Math.min(lon1,lon2) + (Math.abs(lon1 - lon2)/2);
- latCenter = Math.min(lat1, lat2) + (Math.abs(lat1 - lat2)/2);
- window.open(`https://www.waze.com/en-US/editor/?lon=${lonCenter}&lat=${latCenter}&zoom=5`);
- });
- }
-
- bootstrap();
- })();