您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Links for opening external resources at the WME location and WME from external resources
当前为
// ==UserScript== // @name WME Open Other Maps // @namespace https://greasyfork.org/users/30701-justins83-waze // @version 2018.02.23.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/* // @include http://www.511virginia.org/mobile/?menu_id=incidents // @include https://mdotnetpublic.state.mi.us/drive/ // @include http://pkk5.rosreestr.ru* // @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 = ""; var rosreestrIcon = ""; 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>`, `<div><input type="checkbox" id="chkrosreestr" class="OOMchk"><label for="chkrosreestr"><img src="${rosreestrIcon}" height ="18" width="18">Rosreestr</label></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); setChecked('chkrosreestr', settings.rosreestr); 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 get4326CenterPoint(){ let projI = new OL.Projection("EPSG:900913"); let projE = new OL.Projection("EPSG:4326"); let center_lonlat = (new OL.LonLat(W.map.center.lon, W.map.center.lat)).transform(projI,projE); let lat = Math.round(center_lonlat.lat * 1000000) / 1000000; let lon = Math.round(center_lonlat.lon * 1000000) / 1000000; return new OL.LonLat(lon, lat); } 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 OL.LonLat(W.map.getExtent().left,W.map.getExtent().top)); var bottomright= (new OL.LonLat(W.map.getExtent().right,W.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 latlon = get4326CenterPoint(); let lang = GetLanguage(); window.open('https://www.google.com/maps/@' + latlon.lat + ',' + latlon.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(){ let latlon = get4326CenterPoint(); window.open(`https://www.mapillary.com/app/?lat=${latlon.lat}&lng=${latlon.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=OL.Layer.SphericalMercator.inverseMercator(W.map.getCenter().lon,W.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(){ let latlon = get4326CenterPoint(); let lang = GetLanguage(); if(lang === "") lang = "en"; window.open(`http://wikimapia.org/#${(lang !== "" ? "lang=" + lang : "")}&lat=${latlon.lat}&lon=${latlon.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 latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://www.bing.com/maps?&cp=${latlon.lat}~${latlon.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 latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://www.openstreetmap.org/#map=${(W.map.zoom + 12)}/${latlon.lat}/${latlon.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 latlon = get4326CenterPoint(); //let lang = I18n.currentLocale().replace("en-US", "en"); window.open(`https://n.maps.yandex.ru/#!/?z=${(W.map.zoom + 12)}&ll=${latlon.lon}%2C${latlon.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 latlon = get4326CenterPoint(); window.open(`https://wego.here.com/?map=${latlon.lat},${latlon.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"); }); } $('#OOMrosreestr').remove(); if(settings.rosreestr){ let $sectionRosreestr = $("<div>", {style:"padding:8px 16px"}); $sectionRosreestr.html([ '<span id="OOMrosreestr">', `<img src="${rosreestrIcon}" alt="Rosreestr" width="18" height="18" id="OOMrosreestrImg" title="Open in Rosreestr" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`, '</span>' ].join(' ')); $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionRosreestr.html()); $('#OOMrosreestrImg').click(function(){ window.open(`http://pkk5.rosreestr.ru/#x=${W.map.center.lon}&y=${W.map.center.lat}&z=${(W.map.zoom + 12)}`); }); } } 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, rosreestr: 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, rosreestr: settings.rosreestr }; 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(location.href.indexOf("511virginia.org") > -1) bootstrapGeneral(init511virginia, 1); else if(location.href.indexOf("mdotnetpublic.state.mi.us") > -1) bootstrapGeneral(initmiDrive, 1); else if(location.href.indexOf("http://pkk5.rosreestr.ru") > -1) bootstrapRosreestr(1); else{ if (W && W.map && W.model && $ && WazeWrap.Ready) { initInterface(); } else if (tries < 1000) { setTimeout(function () {bootstrap(tries++);}, 200); }} } function RosreestrToWaze(){ let lon, lat, zoom; let curURL = location.href.match(/x=(\d*.\d*)&y=(\d*.\d*)&z=(\d+)/); lon = curURL[1]; lat = curURL[2]; zoom = parseInt(curURL[3]); let source = new Proj4js.Proj('EPSG:900913'); var point = new Proj4js.Point(parseFloat(lon), parseFloat(lat)); Proj4js.transform(source, Proj4js.WGS84, point); return `https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`; } function initRosreestr(){ let $OOMWazeButton = document.createElement("div"); $OOMWazeButton.innerHTML = '<button type="button" class="btn btn-default btn-tool-lg" data-toggle="tooltip" data-placement="right" title="" id="OOMWazeButton" style="background-image: url(https://imgur.com/NTLWfFz.png); background-repeat: no-repeat; background-position: center;"></button>'; //'<div id="OOMWazeButtonDiv" style="height:30px; width:34px; position: fixed; right:30px; top:75px; cursor: pointer; ></div>'; document.getElementsByClassName('btn-group-vertical js-appList')[0].appendChild($OOMWazeButton); document.getElementById("OOMWazeButton").addEventListener("click", function(){ window.open(RosreestrToWaze()); }); } function bootstrapRosreestr(tries=1){ if (document.getElementsByClassName('btn-group-vertical js-appList').length > 0) { initRosreestr(); } else if (tries < 1000) { setTimeout(function () {bootstrapRosreestr(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 init511virginia(){ $('#incident_table_paginate > a').click(insertWazeLinks511Virginia); insertWazeLinks511Virginia(); } function insertWazeLinks511Virginia(){ $('#incident_table > tbody > tr > td > a').parent().append(function(){ if($(this).find("a").length === 1){ let latlons = $(this).find("a")[0].href.match(/lon1=(.*)&lat1=(.*)&lon2=(.*)&lat2=(.*)/); let lonCenter = Math.min(latlons[1],latlons[3]) + (Math.abs(latlons[1] - latlons[3])/2); let latCenter = Math.min(latlons[2], latlons[4]) + (Math.abs(latlons[2] - latlons[4])/2); return ` <a href='https://www.waze.com/editor/?env=usa&lon=${lonCenter}&lat=${latCenter}&zoom=4' target='_blank'>Open in WME</a>`; } return ""; }); } function initmiDrive(){ //g$('#dialog') var observer = new MutationObserver(function(mutations) { mutations.forEach(function(mutation) { if (g$(mutation.target).is("#dialog")) insertWMELinkMiDrive(mutation.target); }); }); observer.observe(g$('#dialog').parent()[0], { childList: true, subtree: true }); } function insertWMELinkMiDrive(changedDiv){ for(let i=0; i<incidents.graphics.length; i++){ if(incidents.graphics[i].attributes.Message.replace("<br/>", "<br>").indexOf(g$(changedDiv).html().replace("<br/>", "<br>").replace("&", "&")) > -1 && g$(changedDiv).html().indexOf("Open in WME") === -1){ g$(changedDiv).append(`<br><a href='https://www.waze.com/en-US/editor/?env=usa&lon=${incidents.graphics[i].attributes.XCoord}&lat=${incidents.graphics[i].attributes.YCoord}&zoom=6' target="_blank">Open in WME</a>`); break; } } } 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(); })();