WME Open Other Maps

Links for opening external resources at the WME location and WME from external resources

当前为 2018-02-21 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name WME Open Other Maps
  3. // @namespace https://greasyfork.org/users/30701-justins83-waze
  4. // @version 2018.02.21.01
  5. // @description Links for opening external resources at the WME location and WME from external resources
  6. // @author JustinS83
  7. // @include https://www.waze.com/editor*
  8. // @include https://www.waze.com/*/editor*
  9. // @include https://beta.waze.com*
  10. // @include https://www.google.com/maps*
  11. // @include *wv511.org/*
  12. // @include http://www.511virginia.org/mobile/?menu_id=incidents
  13. // @exclude https://www.waze.com/user/editor*
  14. // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
  15. // @require https://greasyfork.org/scripts/13097-proj4js/code/Proj4js.js
  16. // @grant none
  17. // ==/UserScript==
  18.  
  19. (function() {
  20. 'use strict';
  21. //var jqUI_CssSrc = GM_getResourceText("jqUI_CSS");
  22. //GM_addStyle(jqUI_CssSrc);
  23.  
  24. var settings = {};
  25. var gmapsIcon = "";
  26. var mapillaryIcon = "";
  27. var terraIcon = "";
  28. var wikimapiaIcon = "";
  29. var bingIcon = "";
  30. var osmIcon = "";
  31. var yandexIcon = "";
  32. var hereIcon = "";
  33. var midriveIcon = "";
  34. var NYFCIcon = "";
  35.  
  36. function initInterface(){
  37. var $section = $("<div>");
  38. $section.html([
  39. '<div>',
  40. '<p>The below maps are legal to use and do not violate copyright</p>',
  41. `<div><input type="checkbox" id="chkMiDrive" class="OOMchk"><label for="chkMiDrive"><img src="${midriveIcon}" height="18" width="18">MiDrive</label></div>`,
  42. `<div><input type="checkbox" id="chkNYFC" class="OOMchk"><img src="${NYFCIcon}" height="18" width="18">NY FC</div>`,
  43. '</br>',
  44. "<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>",
  45. `<div><input type="checkbox" id="chkGMaps" class="OOMchk"><label for="chkGMaps"><img src="${gmapsIcon}" height="18" width="18">Google Maps</label></div>`,
  46. `<div><input type="checkbox" id="chkMapillary" class="OOMchk"><label for="chkMapillary"><img src="${mapillaryIcon}" height="18" width="18">Mapillary</label></div>`,
  47. `<div><input type="checkbox" id="chkTerraserver" class="OOMchk"><label for="chkTerraserver"><img src="${terraIcon}" height="18" width="18">Terraserver</label></div>`,
  48. `<div><input type="checkbox" id="chkWikimapia" class="OOMchk"><label for="chkWikimapia"><img src="${wikimapiaIcon}" height="18" width="18">Wikimapia</label></div>`,
  49. `<div><input type="checkbox" id="chkBing" class="OOMchk"><label for="chkBing"><img src="${bingIcon}" height="18" width="18">Bing Maps</label></div>`,
  50. `<div><input type="checkbox" id="chkOSM" class="OOMchk"><label for="chkOSM"><img src="${osmIcon}" height="18" width ="18">Open Street Map</label></div>`,
  51. `<div><input type="checkbox" id="chkYandex" class="OOMchk"><label for="chkYandex"><img src="${yandexIcon}" height="18" width ="18">Yandex</label></div>`,
  52. `<div><input type="checkbox" id="chkHere" class="OOMchk"><label for="chkHere"><img src="${hereIcon}" height="18" width ="18">Here</label></div>`,
  53. '</br><div>',
  54. '<fieldsetstyle="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
  55. '<legend style="margin-bottom:0px; border-bottom-style:none;width:auto;"><h4>Map Language (where applicable)</h4></legend>',
  56. '<input type="radio" name="radOOMLanguage" id="radOOMNoLang">Do not set a language</br>',
  57. '<input type="radio" name="radOOMLanguage" id="radOOMWMELang">Use WME language</br>',
  58. '<input type="radio" name="radOOMLanguage" id="radOOMCustomLang">Custom language <input type="text" name="txtOOMLanguage" id="txtOOMLanguage" style="border: 1px solid #000000;" size="4"/>',
  59. '</fieldset>',
  60. '</div>',
  61. '</div>'
  62. ].join(' '));
  63.  
  64. new WazeWrap.Interface.Tab('OOM', $section.html(), init);
  65. }
  66.  
  67. function init(){
  68. loadSettings();
  69. setChecked('chkGMaps', settings.GMaps);
  70. setChecked('chkMapillary', settings.Mapillary);
  71. setChecked('chkTerraserver', settings.Terraserver);
  72. setChecked('chkWikimapia', settings.Wikimapia);
  73. setChecked('chkBing', settings.Bing);
  74. setChecked('chkOSM', settings.OSM);
  75. setChecked('chkYandex', settings.Yandex);
  76. setChecked('chkHere', settings.Here);
  77. setChecked('chkMiDrive', settings.MiDrive);
  78. setChecked('chkNYFC', settings.NYFC);
  79.  
  80. if(settings.LangSetting == 0)
  81. setChecked("radOOMNoLang", true);
  82. else if(settings.LangSetting == 1)
  83. setChecked("radOOMWMELang", true);
  84. else
  85. setChecked("radOOMCustomLang", true);
  86.  
  87. $('#txtOOMLanguage')[0].value = settings.CustLang;
  88.  
  89. $('.olControlAttribution').css("right", "400px");
  90.  
  91. LoadMapButtons();
  92. $('.OOMchk').change(function() {
  93. var settingName = $(this)[0].id.substr(3);
  94. settings[settingName] = this.checked;
  95. saveSettings();
  96. LoadMapButtons();
  97. });
  98. $("[id^='rad']").change(function() {
  99. if(isChecked("radOOMNoLang"))
  100. settings.LangSetting = 0;
  101. else if(isChecked("radOOMWMELang"))
  102. settings.LangSetting = 1;
  103. else
  104. settings.LangSetting = 2;
  105. saveSettings();
  106. });
  107. $('#txtOOMLanguage').focusout(function(){
  108. settings.CustLang = $('#txtOOMLanguage').val();
  109. saveSettings();
  110. });
  111. }
  112.  
  113. function GetLanguage()
  114. {
  115. if(isChecked("radOOMNoLang"))
  116. return "";
  117. else if(isChecked("radOOMWMELang"))
  118. return I18n.currentLocale().replace("en-US", "en");
  119. else //Custom Language
  120. return $('#txtOOMLanguage').val();
  121. }
  122.  
  123. function LoadMapButtons()
  124. {
  125. $('#OOMMiDrive').remove();
  126. if(settings.MiDrive)
  127. {
  128. let $section = $("<div>", {style:"padding:8px 16px"});
  129. $section.html([
  130. '<span id="OOMMiDrive">',
  131. `<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;">`,
  132. '</span>'
  133. ].join(' '));
  134.  
  135. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
  136.  
  137. $('#OOMMiDriveImg').click(function(){
  138. var topleft= (new OpenLayers.LonLat(Waze.map.getExtent().left,Waze.map.getExtent().top));
  139. var bottomright= (new OpenLayers.LonLat(Waze.map.getExtent().right,Waze.map.getExtent().bottom));
  140. var xmin = topleft.lon;
  141. var xmax = bottomright.lon;
  142. var ymin = bottomright.lat;
  143. var ymax = topleft.lat;
  144.  
  145. 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');
  146. });
  147. }
  148.  
  149. $('#OOMGMaps').remove();
  150. if(settings.GMaps)
  151. {
  152. let $section = $("<div>", {style:"padding:8px 16px"});
  153. $section.html([
  154. '<span id="OOMGMaps">',
  155. `<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;">`,
  156. '</span>'
  157. ].join(' '));
  158.  
  159. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
  160.  
  161. $('#OOMGMapsImg').click(function(){
  162. let projI = new OpenLayers.Projection("EPSG:900913");
  163. let projE = new OpenLayers.Projection("EPSG:4326");
  164. let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  165. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  166. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  167. let lang = GetLanguage();
  168.  
  169. window.open('https://www.google.com/maps/@' + lat + ',' + lon + ',' + ( W.map.zoom + 12) + 'z' + (lang != "" ? "?hl=" + lang : ""), 'Google Maps');
  170. });
  171. }
  172.  
  173.  
  174. //************** Mapillary *****************
  175. $('#OOMMapillary').remove();
  176. if(settings.Mapillary){
  177. let $sectionMapillary = $("<div>", {style:"padding:8px 16px"});
  178. $sectionMapillary.html([
  179. '<span id="OOMMapillary">',
  180. `<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;">`,
  181. '</span>'
  182. ].join(' '));
  183.  
  184. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionMapillary.html());
  185. $('#OOMMapillaryImg').click(function(){
  186. var projI=new OpenLayers.Projection("EPSG:900913");
  187. var projE=new OpenLayers.Projection("EPSG:4326");
  188. var center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  189. var lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  190. var lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  191.  
  192. window.open(`https://www.mapillary.com/app/?lat=${lat}&lng=${lon}&z=${( W.map.zoom + 11)}`, 'Mapillary');
  193. });
  194. }
  195.  
  196.  
  197. //****************** Terraserver *********************
  198. $('#OOMTerraserver').remove();
  199. if(settings.Terraserver){
  200. var $sectionTerraserver = $("<div>", {style:"padding:8px 16px"});
  201. $sectionTerraserver.html([
  202. '<span id="OOMTerraserver">',
  203. `<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;">`,
  204. '</span>'
  205. ].join(' '));
  206.  
  207. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionTerraserver.html());
  208. $('#OOMTerraserverImg').click(function(){
  209. var center_lonlat=OpenLayers.Layer.SphericalMercator.inverseMercator(Waze.map.getCenter().lon,Waze.map.getCenter().lat);
  210. window.open(`http://www.terraserver.com/view?utf8=✓&searchLng=${center_lonlat.lon}&searchLat=${center_lonlat.lat}`);
  211. });
  212. }
  213.  
  214.  
  215. //********************* Wikimapia *********************
  216. $('#OOMWikimapia').remove();
  217. if(settings.Wikimapia){
  218. let $sectionWikimapia = $("<div>", {style:"padding:8px 16px"});
  219. $sectionWikimapia.html([
  220. '<span id="OOMWikimapia">',
  221. `<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;">`,
  222. '</span>'
  223. ].join(' '));
  224.  
  225. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWikimapia.html());
  226. $('#OOMWikimapiaImg').click(function(){
  227. //var center_lonlat=OpenLayers.Layer.SphericalMercator.inverseMercator(Waze.map.getCenter().lon,Waze.map.getCenter().lat);
  228. var projI=new OpenLayers.Projection("EPSG:900913");
  229. var projE=new OpenLayers.Projection("EPSG:4326");
  230. var center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  231. var lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  232. var lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  233. let lang = GetLanguage();
  234. if(lang === "")
  235. lang = "en";
  236. window.open(`http://wikimapia.org/#${(lang !== "" ? "lang=" + lang : "")}&lat=${lat}&lon=${lon}&z=${( W.map.zoom + 12)}&m=b`);
  237. });
  238. }
  239.  
  240. $('#OOMBing').remove();
  241. if(settings.Bing)
  242. {
  243. let $sectionBing = $("<div>", {style:"padding:8px 16px"});
  244. $sectionBing.html([
  245. '<span id="OOMBing">',
  246. `<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;">`,
  247. '</span>'
  248. ].join(' '));
  249.  
  250. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBing.html());
  251.  
  252. $('#OOMBingImg').click(function(){
  253. let projI = new OpenLayers.Projection("EPSG:900913");
  254. let projE = new OpenLayers.Projection("EPSG:4326");
  255. let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  256. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  257. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  258. //let lang = I18n.currentLocale().replace("en-US", "en");
  259.  
  260. window.open(`https://www.bing.com/maps?&cp=${lat}~${lon}&lvl=${( W.map.zoom + 12)}`);
  261. });
  262. }
  263.  
  264. $('#OOMOSM').remove();
  265. if(settings.OSM){
  266. //https://www.openstreetmap.org/#map=16/39.5588/-84.2365
  267. let $sectionOSM = $("<div>", {style:"padding:8px 16px"});
  268. $sectionOSM.html([
  269. '<span id="OOMOSM">',
  270. `<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;">`,
  271. '</span>'
  272. ].join(' '));
  273.  
  274. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOSM.html());
  275.  
  276. $('#OOMOSMImg').click(function(){
  277. let projI = new OpenLayers.Projection("EPSG:900913");
  278. let projE = new OpenLayers.Projection("EPSG:4326");
  279. let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  280. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  281. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  282. //let lang = I18n.currentLocale().replace("en-US", "en");
  283.  
  284. window.open(`https://www.openstreetmap.org/#map=${(W.map.zoom + 12)}/${lat}/${lon}`);
  285. });
  286. }
  287.  
  288. $('#OOMYandex').remove();
  289. if(settings.Yandex){
  290. //https://n.maps.yandex.ru/#!/?z=14&ll=46.019795%2C51.505120&l=nk%23sat
  291. let $sectionYandex = $("<div>", {style:"padding:8px 16px"});
  292. $sectionYandex.html([
  293. '<span id="OOMYandex">',
  294. `<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;">`,
  295. '</span>'
  296. ].join(' '));
  297.  
  298. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionYandex.html());
  299.  
  300. $('#OOMYandexImg').click(function(){
  301. let projI = new OpenLayers.Projection("EPSG:900913");
  302. let projE = new OpenLayers.Projection("EPSG:4326");
  303. let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  304. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  305. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  306. //let lang = I18n.currentLocale().replace("en-US", "en");
  307.  
  308. window.open(`https://n.maps.yandex.ru/#!/?z=${(W.map.zoom + 12)}&ll=${lon}%2C${lat}&l=nk%23sat`);
  309. });
  310. }
  311.  
  312. $('#OOMHere').remove();
  313. if(settings.Here){
  314. //https://wego.here.com/?map=39.56508,-84.26224,16,normal&x=ep
  315. let $sectionHere = $("<div>", {style:"padding:8px 16px"});
  316. $sectionHere.html([
  317. '<span id="OOMHere">',
  318. `<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;">`,
  319. '</span>'
  320. ].join(' '));
  321.  
  322. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionHere.html());
  323.  
  324. $('#OOMHereImg').click(function(){
  325. let projI = new OpenLayers.Projection("EPSG:900913");
  326. let projE = new OpenLayers.Projection("EPSG:4326");
  327. let center_lonlat = (new OpenLayers.LonLat(Waze.map.center.lon, Waze.map.center.lat)).transform(projI,projE);
  328. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  329. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  330. //let lang = I18n.currentLocale().replace("en-US", "en");
  331.  
  332. window.open(`https://wego.here.com/?map=${lat},${lon},${(W.map.zoom + 12)},satellite&x=ep`);
  333. });
  334. }
  335.  
  336. $('#OOMNYFC').remove();
  337. if(settings.NYFC){
  338. let $sectionNYFC = $("<div>", {style:"padding:8px 16px"});
  339. $sectionNYFC.html([
  340. '<span id="OOMNYFC">',
  341. `<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;">`,
  342. '</span>'
  343. ].join(' '));
  344.  
  345. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNYFC.html());
  346.  
  347. $('#OOMNYFCImg').click(function(){
  348. let e=W.map.getExtent();
  349. let geoNW=new OL.Geometry.Point(e.left,e.top);
  350. let geoSE=new OL.Geometry.Point(e.right,e.bottom);
  351.  
  352. Proj4js.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs";
  353.  
  354. let source = new Proj4js.Proj('EPSG:900913');
  355. let dest = new Proj4js.Proj('EPSG:26918');
  356.  
  357. geoNW = new Proj4js.Point(geoNW.x,geoNW.y);
  358. geoSE = new Proj4js.Point(geoSE.x,geoSE.y);
  359.  
  360. Proj4js.transform(source, dest, geoNW);
  361. Proj4js.transform(source, dest, geoSE);
  362.  
  363. let mapScale = 36111.909643;
  364.  
  365. switch (W.map.zoom) {
  366. case 0:
  367. case 1:
  368. mapScale = 72223.819286;
  369. break;
  370. case 2:
  371. mapScale = 36111.909643;
  372. break;
  373. case 3:
  374. mapScale = 18055.954822;
  375. break;
  376. default:
  377. mapScale = 9027.977411;
  378. break;
  379. }
  380.  
  381. let URL='http://gis3.dot.ny.gov/html5viewer/?viewer=FC&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y;
  382. window.open(URL,"_blank");
  383. });
  384. }
  385. }
  386.  
  387. function loadSettings() {
  388. var loadedSettings = $.parseJSON(localStorage.getItem("OOM_Settings"));
  389. var defaultSettings = {
  390. GMaps: true,
  391. Mapillary: true,
  392. Terraserver: true,
  393. Wikimapia: false,
  394. Bing: false,
  395. OSM: false,
  396. LangSetting: 1,
  397. CustLang: "",
  398. Yandex: false,
  399. Here: false,
  400. MiDrive: false,
  401. NYFC: false
  402. };
  403. settings = loadedSettings ? loadedSettings : defaultSettings;
  404. for (var prop in defaultSettings) {
  405. if (!settings.hasOwnProperty(prop))
  406. settings[prop] = defaultSettings[prop];
  407. }
  408. }
  409.  
  410. function saveSettings() {
  411. if (localStorage) {
  412. var localsettings = {
  413. GMaps: settings.GMaps,
  414. Mapillary: settings.Mapillary,
  415. Terraserver: settings.Terraserver,
  416. Wikimapia: settings.Wikimapia,
  417. Bing: settings.Bing,
  418. OSM: settings.OSM,
  419. LangSetting: settings.LangSetting,
  420. CustLang: settings.CustLang,
  421. Yandex: settings.Yandex,
  422. Here: settings.Here,
  423. MiDrive: settings.MiDrive,
  424. NYFC: settings.NYFC
  425. };
  426.  
  427. localStorage.setItem("OOM_Settings", JSON.stringify(localsettings));
  428. }
  429. }
  430.  
  431. function isChecked(checkboxId) {
  432. return $('#' + checkboxId).is(':checked');
  433. }
  434.  
  435. function setChecked(checkboxId, checked) {
  436. $('#' + checkboxId).prop('checked', checked);
  437. }
  438.  
  439. function bootstrap(tries = 1) {
  440. if(location.href.indexOf("google.com/maps") > -1)
  441. bootstrapGeneral(initGoogleMaps, 1);
  442. else if(location.href.indexOf("wv511.org") > -1)
  443. bootstrapGeneral(initWV511, 1);
  444. else if(location.href.indexOf("511virginia.org") > -1)
  445. bootstrapGeneral(init511virginia, 1);
  446. else{
  447. if (W &&
  448. W.map &&
  449. W.model &&
  450. $ && WazeWrap.Ready) {
  451. initInterface();
  452. } else if (tries < 1000) {
  453. setTimeout(function () {bootstrap(tries++);}, 200);
  454. }}
  455. }
  456.  
  457. function initGoogleMaps(){
  458. let $OOMWazeButton = document.createElement("div");
  459. $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>';
  460. let parent = document.getElementById("content-container");
  461. parent.appendChild($OOMWazeButton);
  462.  
  463. document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
  464. window.open(GMToWaze());
  465. });
  466.  
  467. document.getElementById('OOMWazeButtonDiv').addEventListener("mouseenter",function(e) {
  468. document.addEventListener('keydown', copyPLHotkeyEvent);
  469. document.getElementsByClassName('widget-scene-canvas')[0].addEventListener('keydown', copyPLHotkeyEvent);
  470. });
  471.  
  472. document.getElementById('OOMWazeButtonDiv').addEventListener('mouseleave', function() {
  473. document.removeEventListener('keydown', copyPLHotkeyEvent);
  474. document.getElementsByClassName('widget-scene-canvas')[0].removeEventListener('keydown', copyPLHotkeyEvent);
  475. });
  476. }
  477.  
  478. var copyToClipboard = function(str) {
  479. var temp = document.createElement("input");
  480. document.body.append(temp);
  481. temp.value = str;
  482. temp.select();
  483. document.execCommand('copy');
  484. document.body.removeChild(temp);
  485. };
  486.  
  487. var copyPLHotkeyEvent = function(e) {
  488. if ((e.metaKey || e.ctrlKey) && (e.which === 67))
  489. copyToClipboard(GMToWaze());
  490. };
  491.  
  492. function GMToWaze(){
  493. let lon, lat, zoom;
  494. let curURL = location.href.split('@').pop().split(',');
  495. lon = curURL[1];
  496. lat = curURL[0];
  497. zoom = parseInt(curURL[2]);
  498. return `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`;
  499. }
  500.  
  501. function bootstrapGeneral(initdelegate, tries = 1){
  502. if(document.readyState !== 'complete' )
  503. setTimeout(function() {bootstrapGeneral(initdelegate, tries++);}, 200);
  504. else
  505. initdelegate();
  506. }
  507.  
  508. function init511virginia(){
  509. $('#incident_table_paginate > a').click(insertWazeLinks511Virginia);
  510. insertWazeLinks511Virginia();
  511. }
  512.  
  513. function insertWazeLinks511Virginia(){
  514. $('#incident_table > tbody > tr > td > a').parent().append(function(){
  515. if($(this).find("a").length === 1){
  516. let latlons = $(this).find("a")[0].href.match(/lon1=(.*)&lat1=(.*)&lon2=(.*)&lat2=(.*)/);
  517.  
  518. let lonCenter = Math.min(latlons[1],latlons[3]) + (Math.abs(latlons[1] - latlons[3])/2);
  519. let latCenter = Math.min(latlons[2], latlons[4]) + (Math.abs(latlons[2] - latlons[4])/2);
  520. return ` <a href='https://www.waze.com/editor/?env=usa&lon=${lonCenter}&lat=${latCenter}&zoom=4' target='_blank'>Open in WME</a>`;
  521. }
  522. return "";
  523. });
  524. }
  525.  
  526. function initWV511(){
  527. if(document.getElementById("OOMWazeButtonDi") !== null)
  528. document.getElementById("OOMWazeButtonDi").remove();
  529.  
  530. let $OOMWazeButton = document.createElement("div");
  531. $OOMWazeButton.setAttribute("id", "OOMWazeButtonDiv");
  532. $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;");
  533. $OOMWazeButton.setAttribute("title", "Open in WME");
  534. document.body.appendChild($OOMWazeButton);
  535.  
  536. document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
  537. let lon1, lon2, lonCenter, lat1, lat2, latCenter;
  538. let latlon = location.href.split(":");
  539. lon1 = latlon[2];
  540. lat1 = latlon[3];
  541. lon2 = latlon[4];
  542. lat2 = latlon[5];
  543.  
  544. lonCenter = Math.min(lon1,lon2) + (Math.abs(lon1 - lon2)/2);
  545. latCenter = Math.min(lat1, lat2) + (Math.abs(lat1 - lat2)/2);
  546. window.open(`https://www.waze.com/en-US/editor/?lon=${lonCenter}&lat=${latCenter}&zoom=5`);
  547. });
  548. }
  549.  
  550. bootstrap();
  551. })();