WME Open Other Maps

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

当前为 2018-03-08 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name WME Open Other Maps
  3. // @namespace https://greasyfork.org/users/30701-justins83-waze
  4. // @version 2018.03.08.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. // @include https://mdotnetpublic.state.mi.us/drive/
  14. // @include http://pkk5.rosreestr.ru*
  15. // @include http://www.511pa.com/Traffic.aspx*
  16. // @exclude https://www.waze.com/*/user/editor*
  17. // @require https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
  18. // @require https://greasyfork.org/scripts/13097-proj4js/code/Proj4js.js
  19. // @grant none
  20. // ==/UserScript==
  21.  
  22. (function() {
  23. 'use strict';
  24. //var jqUI_CssSrc = GM_getResourceText("jqUI_CSS");
  25. //GM_addStyle(jqUI_CssSrc);
  26.  
  27. var settings = {};
  28. var gmapsIcon = "";
  29. var mapillaryIcon = "";
  30. var terraIcon = "";
  31. var wikimapiaIcon = "";
  32. var bingIcon = "";
  33. var osmIcon = "";
  34. var yandexIcon = "";
  35. var hereIcon = "";
  36. var midriveIcon = "";
  37. var NYFCIcon = "";
  38. var rosreestrIcon = "";
  39. var PA511Icon = "";
  40.  
  41. function initInterface(){
  42. var $section = $("<div>");
  43. $section.html([
  44. '<div>',
  45. '<p>The below maps are legal to use and do not violate copyright</p>',
  46. `<div><input type="checkbox" id="chkMiDrive" class="OOMchk"><label for="chkMiDrive"><img src="${midriveIcon}" height="18" width="18">MiDrive</label></div>`,
  47. `<div><input type="checkbox" id="chkNYFC" class="OOMchk"><img src="${NYFCIcon}" height="18" width="18">NY FC</div>`,
  48. `<div><input type="checkbox" id="chkrosreestr" class="OOMchk"><label for="chkrosreestr"><img src="${rosreestrIcon}" height ="18" width="18">Rosreestr</label></div>`,
  49. `<div><input type="checkbox" id="chkPA511" class="OOMchk"><label for="chkPA511"><img src="${PA511Icon}" height = 18 width="18">511PA</label></div>`,
  50. '</br>',
  51. "<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>",
  52. `<div><input type="checkbox" id="chkGMaps" class="OOMchk"><label for="chkGMaps"><img src="${gmapsIcon}" height="18" width="18">Google Maps</label></div>`,
  53. `<div><input type="checkbox" id="chkMapillary" class="OOMchk"><label for="chkMapillary"><img src="${mapillaryIcon}" height="18" width="18">Mapillary</label></div>`,
  54. `<div><input type="checkbox" id="chkTerraserver" class="OOMchk"><label for="chkTerraserver"><img src="${terraIcon}" height="18" width="18">Terraserver</label></div>`,
  55. `<div><input type="checkbox" id="chkWikimapia" class="OOMchk"><label for="chkWikimapia"><img src="${wikimapiaIcon}" height="18" width="18">Wikimapia</label></div>`,
  56. `<div><input type="checkbox" id="chkBing" class="OOMchk"><label for="chkBing"><img src="${bingIcon}" height="18" width="18">Bing Maps</label></div>`,
  57. `<div><input type="checkbox" id="chkOSM" class="OOMchk"><label for="chkOSM"><img src="${osmIcon}" height="18" width ="18">Open Street Map</label></div>`,
  58. `<div><input type="checkbox" id="chkYandex" class="OOMchk"><label for="chkYandex"><img src="${yandexIcon}" height="18" width ="18">Yandex</label></div>`,
  59. `<div><input type="checkbox" id="chkHere" class="OOMchk"><label for="chkHere"><img src="${hereIcon}" height="18" width ="18">Here</label></div>`,
  60. '</br><div>',
  61. '<fieldsetstyle="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
  62. '<legend style="margin-bottom:0px; border-bottom-style:none;width:auto;"><h4>Map Language (where applicable)</h4></legend>',
  63. '<input type="radio" name="radOOMLanguage" id="radOOMNoLang">Do not set a language</br>',
  64. '<input type="radio" name="radOOMLanguage" id="radOOMWMELang">Use WME language</br>',
  65. '<input type="radio" name="radOOMLanguage" id="radOOMCustomLang">Custom language <input type="text" name="txtOOMLanguage" id="txtOOMLanguage" style="border: 1px solid #000000;" size="4"/>',
  66. '</fieldset>',
  67. '</div>',
  68. '</div>'
  69. ].join(' '));
  70.  
  71. new WazeWrap.Interface.Tab('OOM', $section.html(), init);
  72. }
  73.  
  74. function init(){
  75. loadSettings();
  76. setChecked('chkGMaps', settings.GMaps);
  77. setChecked('chkMapillary', settings.Mapillary);
  78. setChecked('chkTerraserver', settings.Terraserver);
  79. setChecked('chkWikimapia', settings.Wikimapia);
  80. setChecked('chkBing', settings.Bing);
  81. setChecked('chkOSM', settings.OSM);
  82. setChecked('chkYandex', settings.Yandex);
  83. setChecked('chkHere', settings.Here);
  84. setChecked('chkMiDrive', settings.MiDrive);
  85. setChecked('chkNYFC', settings.NYFC);
  86. setChecked('chkrosreestr', settings.rosreestr);
  87. setChecked('chkPA511', settings.PA511);
  88.  
  89. if(settings.LangSetting == 0)
  90. setChecked("radOOMNoLang", true);
  91. else if(settings.LangSetting == 1)
  92. setChecked("radOOMWMELang", true);
  93. else
  94. setChecked("radOOMCustomLang", true);
  95.  
  96. $('#txtOOMLanguage')[0].value = settings.CustLang;
  97.  
  98. $('.olControlAttribution').css("right", "400px");
  99.  
  100. LoadMapButtons();
  101. $('.OOMchk').change(function() {
  102. var settingName = $(this)[0].id.substr(3);
  103. settings[settingName] = this.checked;
  104. saveSettings();
  105. LoadMapButtons();
  106. });
  107. $("[id^='rad']").change(function() {
  108. if(isChecked("radOOMNoLang"))
  109. settings.LangSetting = 0;
  110. else if(isChecked("radOOMWMELang"))
  111. settings.LangSetting = 1;
  112. else
  113. settings.LangSetting = 2;
  114. saveSettings();
  115. });
  116. $('#txtOOMLanguage').focusout(function(){
  117. settings.CustLang = $('#txtOOMLanguage').val();
  118. saveSettings();
  119. });
  120. }
  121.  
  122. function GetLanguage()
  123. {
  124. if(isChecked("radOOMNoLang"))
  125. return "";
  126. else if(isChecked("radOOMWMELang"))
  127. return I18n.currentLocale().replace("en-US", "en");
  128. else //Custom Language
  129. return $('#txtOOMLanguage').val();
  130. }
  131.  
  132. function get4326CenterPoint(){
  133. let projI = new OL.Projection("EPSG:900913");
  134. let projE = new OL.Projection("EPSG:4326");
  135. let center_lonlat = (new OL.LonLat(W.map.center.lon, W.map.center.lat)).transform(projI,projE);
  136. let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
  137. let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
  138. return new OL.LonLat(lon, lat);
  139. }
  140.  
  141. function LoadMapButtons()
  142. {
  143. $('#OOMMiDrive').remove();
  144. if(settings.MiDrive)
  145. {
  146. let $section = $("<div>", {style:"padding:8px 16px"});
  147. $section.html([
  148. '<span id="OOMMiDrive">',
  149. `<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;">`,
  150. '</span>'
  151. ].join(' '));
  152.  
  153. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
  154.  
  155. $('#OOMMiDriveImg').click(function(){
  156. var topleft= (new OL.LonLat(W.map.getExtent().left,W.map.getExtent().top));
  157. var bottomright= (new OL.LonLat(W.map.getExtent().right,W.map.getExtent().bottom));
  158. var xmin = topleft.lon;
  159. var xmax = bottomright.lon;
  160. var ymin = bottomright.lat;
  161. var ymax = topleft.lat;
  162.  
  163. 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');
  164. });
  165. }
  166.  
  167. $('#OOMGMaps').remove();
  168. if(settings.GMaps)
  169. {
  170. let $section = $("<div>", {style:"padding:8px 16px"});
  171. $section.html([
  172. '<span id="OOMGMaps">',
  173. `<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;">`,
  174. '</span>'
  175. ].join(' '));
  176.  
  177. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($section.html());
  178.  
  179. $('#OOMGMapsImg').click(function(){
  180. let latlon = get4326CenterPoint();
  181. let lang = GetLanguage();
  182.  
  183. window.open('https://www.google.com/maps/@' + latlon.lat + ',' + latlon.lon + ',' + ( W.map.zoom + 12) + 'z' + (lang != "" ? "?hl=" + lang : ""), 'Google Maps');
  184. });
  185. }
  186.  
  187.  
  188. //************** Mapillary *****************
  189. $('#OOMMapillary').remove();
  190. if(settings.Mapillary){
  191. let $sectionMapillary = $("<div>", {style:"padding:8px 16px"});
  192. $sectionMapillary.html([
  193. '<span id="OOMMapillary">',
  194. `<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;">`,
  195. '</span>'
  196. ].join(' '));
  197.  
  198. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionMapillary.html());
  199. $('#OOMMapillaryImg').click(function(){
  200. let latlon = get4326CenterPoint();
  201.  
  202. window.open(`https://www.mapillary.com/app/?lat=${latlon.lat}&lng=${latlon.lon}&z=${( W.map.zoom + 11)}`, 'Mapillary');
  203. });
  204. }
  205.  
  206.  
  207. //****************** Terraserver *********************
  208. $('#OOMTerraserver').remove();
  209. if(settings.Terraserver){
  210. var $sectionTerraserver = $("<div>", {style:"padding:8px 16px"});
  211. $sectionTerraserver.html([
  212. '<span id="OOMTerraserver">',
  213. `<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;">`,
  214. '</span>'
  215. ].join(' '));
  216.  
  217. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionTerraserver.html());
  218. $('#OOMTerraserverImg').click(function(){
  219. var center_lonlat=OL.Layer.SphericalMercator.inverseMercator(W.map.getCenter().lon,W.map.getCenter().lat);
  220. window.open(`http://www.terraserver.com/view?utf8=✓&searchLng=${center_lonlat.lon}&searchLat=${center_lonlat.lat}`);
  221. });
  222. }
  223.  
  224.  
  225. //********************* Wikimapia *********************
  226. $('#OOMWikimapia').remove();
  227. if(settings.Wikimapia){
  228. let $sectionWikimapia = $("<div>", {style:"padding:8px 16px"});
  229. $sectionWikimapia.html([
  230. '<span id="OOMWikimapia">',
  231. `<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;">`,
  232. '</span>'
  233. ].join(' '));
  234.  
  235. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWikimapia.html());
  236. $('#OOMWikimapiaImg').click(function(){
  237. let latlon = get4326CenterPoint();
  238. let lang = GetLanguage();
  239. if(lang === "")
  240. lang = "en";
  241. window.open(`http://wikimapia.org/#${(lang !== "" ? "lang=" + lang : "")}&lat=${latlon.lat}&lon=${latlon.lon}&z=${( W.map.zoom + 12)}&m=b`);
  242. });
  243. }
  244.  
  245. $('#OOMBing').remove();
  246. if(settings.Bing)
  247. {
  248. let $sectionBing = $("<div>", {style:"padding:8px 16px"});
  249. $sectionBing.html([
  250. '<span id="OOMBing">',
  251. `<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;">`,
  252. '</span>'
  253. ].join(' '));
  254.  
  255. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBing.html());
  256.  
  257. $('#OOMBingImg').click(function(){
  258. let latlon = get4326CenterPoint();
  259. //let lang = I18n.currentLocale().replace("en-US", "en");
  260.  
  261. window.open(`https://www.bing.com/maps?&cp=${latlon.lat}~${latlon.lon}&lvl=${( W.map.zoom + 12)}`);
  262. });
  263. }
  264.  
  265. $('#OOMOSM').remove();
  266. if(settings.OSM){
  267. //https://www.openstreetmap.org/#map=16/39.5588/-84.2365
  268. let $sectionOSM = $("<div>", {style:"padding:8px 16px"});
  269. $sectionOSM.html([
  270. '<span id="OOMOSM">',
  271. `<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;">`,
  272. '</span>'
  273. ].join(' '));
  274.  
  275. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOSM.html());
  276.  
  277. $('#OOMOSMImg').click(function(){
  278. let latlon = get4326CenterPoint();
  279. //let lang = I18n.currentLocale().replace("en-US", "en");
  280.  
  281. window.open(`https://www.openstreetmap.org/#map=${(W.map.zoom + 12)}/${latlon.lat}/${latlon.lon}`);
  282. });
  283. }
  284.  
  285. $('#OOMYandex').remove();
  286. if(settings.Yandex){
  287. //https://n.maps.yandex.ru/#!/?z=14&ll=46.019795%2C51.505120&l=nk%23sat
  288. let $sectionYandex = $("<div>", {style:"padding:8px 16px"});
  289. $sectionYandex.html([
  290. '<span id="OOMYandex">',
  291. `<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;">`,
  292. '</span>'
  293. ].join(' '));
  294.  
  295. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionYandex.html());
  296.  
  297. $('#OOMYandexImg').click(function(){
  298. let latlon = get4326CenterPoint();
  299. //let lang = I18n.currentLocale().replace("en-US", "en");
  300.  
  301. window.open(`https://n.maps.yandex.ru/#!/?z=${(W.map.zoom + 12)}&ll=${latlon.lon}%2C${latlon.lat}&l=nk%23sat`);
  302. });
  303. }
  304.  
  305. $('#OOMHere').remove();
  306. if(settings.Here){
  307. //https://wego.here.com/?map=39.56508,-84.26224,16,normal&x=ep
  308. let $sectionHere = $("<div>", {style:"padding:8px 16px"});
  309. $sectionHere.html([
  310. '<span id="OOMHere">',
  311. `<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;">`,
  312. '</span>'
  313. ].join(' '));
  314.  
  315. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionHere.html());
  316.  
  317. $('#OOMHereImg').click(function(){
  318. let latlon = get4326CenterPoint();
  319.  
  320. window.open(`https://wego.here.com/?map=${latlon.lat},${latlon.lon},${(W.map.zoom + 12)},satellite&x=ep`);
  321. });
  322. }
  323.  
  324. $('#OOMNYFC').remove();
  325. if(settings.NYFC){
  326. let $sectionNYFC = $("<div>", {style:"padding:8px 16px"});
  327. $sectionNYFC.html([
  328. '<span id="OOMNYFC">',
  329. `<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;">`,
  330. '</span>'
  331. ].join(' '));
  332.  
  333. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNYFC.html());
  334.  
  335. $('#OOMNYFCImg').click(function(){
  336. let e=W.map.getExtent();
  337. let geoNW=new OL.Geometry.Point(e.left,e.top);
  338. let geoSE=new OL.Geometry.Point(e.right,e.bottom);
  339.  
  340. Proj4js.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs";
  341.  
  342. let source = new Proj4js.Proj('EPSG:900913');
  343. let dest = new Proj4js.Proj('EPSG:26918');
  344.  
  345. geoNW = new Proj4js.Point(geoNW.x,geoNW.y);
  346. geoSE = new Proj4js.Point(geoSE.x,geoSE.y);
  347.  
  348. Proj4js.transform(source, dest, geoNW);
  349. Proj4js.transform(source, dest, geoSE);
  350.  
  351. let mapScale = 36111.909643;
  352.  
  353. switch (W.map.zoom) {
  354. case 0:
  355. case 1:
  356. mapScale = 72223.819286;
  357. break;
  358. case 2:
  359. mapScale = 36111.909643;
  360. break;
  361. case 3:
  362. mapScale = 18055.954822;
  363. break;
  364. default:
  365. mapScale = 9027.977411;
  366. break;
  367. }
  368.  
  369. let URL='http://gis3.dot.ny.gov/html5viewer/?viewer=FC&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y;
  370. window.open(URL,"_blank");
  371. });
  372. }
  373.  
  374. $('#OOMrosreestr').remove();
  375. if(settings.rosreestr){
  376. let $sectionRosreestr = $("<div>", {style:"padding:8px 16px"});
  377. $sectionRosreestr.html([
  378. '<span id="OOMrosreestr">',
  379. `<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;">`,
  380. '</span>'
  381. ].join(' '));
  382.  
  383. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionRosreestr.html());
  384.  
  385. $('#OOMrosreestrImg').click(function(){
  386. window.open(`http://pkk5.rosreestr.ru/#x=${W.map.center.lon}&y=${W.map.center.lat}&z=${(W.map.zoom + 12)}`);
  387. });
  388. }
  389.  
  390. $('#OOMPA511').remove();
  391. if(settings.PA511){
  392. let $sectionPA511 = $("<div>", {style:"padding:8px 16px"});
  393. $sectionPA511.html([
  394. '<span id="OOMPA511">',
  395. `<img src="${PA511Icon}" alt="511PA" width="18" height="18" id="OOMPA511Img" title="Open in 511PA" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
  396. '</span>'
  397. ].join(' '));
  398.  
  399. $('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionPA511.html());
  400.  
  401. $('#OOMPA511Img').click(function(){
  402. let latlon = get4326CenterPoint();
  403. window.open(`http://www.511pa.com/Traffic.aspx?${latlon.lat},${latlon.lon},${(W.map.zoom + 12)}z`);
  404. });
  405. }
  406. }
  407.  
  408. function loadSettings() {
  409. var loadedSettings = $.parseJSON(localStorage.getItem("OOM_Settings"));
  410. var defaultSettings = {
  411. GMaps: true,
  412. Mapillary: true,
  413. Terraserver: true,
  414. Wikimapia: false,
  415. Bing: false,
  416. OSM: false,
  417. LangSetting: 1,
  418. CustLang: "",
  419. Yandex: false,
  420. Here: false,
  421. MiDrive: false,
  422. NYFC: false,
  423. rosreestr: false,
  424. PA511: false
  425. };
  426. settings = loadedSettings ? loadedSettings : defaultSettings;
  427. for (var prop in defaultSettings) {
  428. if (!settings.hasOwnProperty(prop))
  429. settings[prop] = defaultSettings[prop];
  430. }
  431. }
  432.  
  433. function saveSettings() {
  434. if (localStorage) {
  435. var localsettings = {
  436. GMaps: settings.GMaps,
  437. Mapillary: settings.Mapillary,
  438. Terraserver: settings.Terraserver,
  439. Wikimapia: settings.Wikimapia,
  440. Bing: settings.Bing,
  441. OSM: settings.OSM,
  442. LangSetting: settings.LangSetting,
  443. CustLang: settings.CustLang,
  444. Yandex: settings.Yandex,
  445. Here: settings.Here,
  446. MiDrive: settings.MiDrive,
  447. NYFC: settings.NYFC,
  448. rosreestr: settings.rosreestr,
  449. PA511: settings.PA511
  450. };
  451.  
  452. localStorage.setItem("OOM_Settings", JSON.stringify(localsettings));
  453. }
  454. }
  455.  
  456. function isChecked(checkboxId) {
  457. return $('#' + checkboxId).is(':checked');
  458. }
  459.  
  460. function setChecked(checkboxId, checked) {
  461. $('#' + checkboxId).prop('checked', checked);
  462. }
  463.  
  464. function bootstrapGeneral(initdelegate, tries = 1){
  465. if(document.readyState !== 'complete' )
  466. setTimeout(function() {bootstrapGeneral(initdelegate, tries++);}, 200);
  467. else
  468. initdelegate();
  469. }
  470.  
  471. let is511PAloaded = false;
  472. function bootstrap511PA(tries = 1){
  473. if(iFrameVar.map){
  474. iFrameVar.map.addListener('tilesloaded', function() {
  475. //http://www.511pa.com/Traffic.aspx?40.85,-77.6,12z
  476. if(!is511PAloaded){
  477. if(location.search.indexOf("?") > -1){
  478. let params = location.search.split("?")[1].slice(0,-1);
  479. iFrameVar.recenterMap(params);
  480. }
  481. is511PAloaded = true;
  482. }
  483. });
  484. }
  485. else{
  486. setTimeout(function(){bootstrap511PA(tries +=1);}, 100);
  487. }
  488.  
  489. $(document).ready(function(){
  490. init511PA();
  491. });
  492. }
  493.  
  494. function bootstrap(tries = 1) {
  495. if(location.href.indexOf("google.com/maps") > -1)
  496. bootstrapGeneral(initGoogleMaps, 1);
  497. else if(location.href.indexOf("wv511.org") > -1)
  498. bootstrapGeneral(initWV511, 1);
  499. else if(location.href.indexOf("511virginia.org") > -1)
  500. bootstrapGeneral(init511virginia, 1);
  501. else if(location.href.indexOf("mdotnetpublic.state.mi.us") > -1)
  502. bootstrapGeneral(initmiDrive, 1);
  503. else if(location.href.indexOf("http://pkk5.rosreestr.ru") > -1)
  504. bootstrapRosreestr(1);
  505. else if(location.href.indexOf("http://www.511pa.com/Traffic") > -1)
  506. bootstrap511PA(1);//bootstrapGeneral(init511PA, 1);
  507. else{
  508. if (W &&
  509. W.map &&
  510. W.model &&
  511. $ && WazeWrap.Ready) {
  512. initInterface();
  513. } else if (tries < 1000) {
  514. setTimeout(function () {bootstrap(tries++);}, 200);
  515. }}
  516. }
  517.  
  518. function RosreestrToWaze(){
  519. let lon, lat, zoom;
  520. let curURL = location.href.match(/x=(\d*.\d*)&y=(\d*.\d*)&z=(\d+)/);
  521. lon = curURL[1];
  522. lat = curURL[2];
  523. zoom = parseInt(curURL[3]);
  524.  
  525. let source = new Proj4js.Proj('EPSG:900913');
  526.  
  527. var point = new Proj4js.Point(parseFloat(lon), parseFloat(lat));
  528. Proj4js.transform(source, Proj4js.WGS84, point);
  529. return `https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`;
  530. }
  531.  
  532. function initRosreestr(){
  533. var observer = new MutationObserver(function(mutations) {
  534. mutations.forEach(function(mutation) {
  535. if (mutation.type === "attributes" && mutation.target == document.getElementsByClassName("btn btn-default btn-tool-lg js-showList")[0]) insertWMELinkRosreestr();
  536. });
  537. });
  538.  
  539. observer.observe(document.getElementById("sidebar-region"), { childList: true, subtree: true, attributes:true});
  540.  
  541. insertWMELinkRosreestr();
  542. }
  543.  
  544. function insertWMELinkRosreestr(){
  545. if(document.getElementById("OOMWazeButton") !== null)
  546. document.getElementById("OOMWazeButton").remove();
  547.  
  548. let $OOMWazeButton = document.createElement("div");
  549.  
  550. $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>';
  551. document.getElementsByClassName('btn-group-vertical js-appList')[0].appendChild($OOMWazeButton);
  552.  
  553. document.getElementById("OOMWazeButton").addEventListener("click", function(){
  554. window.open(RosreestrToWaze());
  555. });
  556. }
  557.  
  558. function bootstrapRosreestr(tries=1){
  559. if (document.getElementsByClassName('btn-group-vertical js-appList').length > 0) {
  560. initRosreestr();
  561. } else if (tries < 1000) {
  562. setTimeout(function () {bootstrapRosreestr(tries++);}, 200);
  563. }
  564. }
  565.  
  566. function initGoogleMaps(){
  567. let $OOMWazeButton = document.createElement("div");
  568. $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>';
  569. let parent = document.getElementById("content-container");
  570. parent.appendChild($OOMWazeButton);
  571.  
  572. document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
  573. window.open(GMToWaze());
  574. });
  575.  
  576. document.getElementById('OOMWazeButtonDiv').addEventListener("mouseenter",function(e) {
  577. document.addEventListener('keydown', copyPLHotkeyEvent);
  578. document.getElementsByClassName('widget-scene-canvas')[0].addEventListener('keydown', copyPLHotkeyEvent);
  579. });
  580.  
  581. document.getElementById('OOMWazeButtonDiv').addEventListener('mouseleave', function() {
  582. document.removeEventListener('keydown', copyPLHotkeyEvent);
  583. document.getElementsByClassName('widget-scene-canvas')[0].removeEventListener('keydown', copyPLHotkeyEvent);
  584. });
  585. }
  586.  
  587. var copyToClipboard = function(str) {
  588. var temp = document.createElement("input");
  589. document.body.append(temp);
  590. temp.value = str;
  591. temp.select();
  592. document.execCommand('copy');
  593. document.body.removeChild(temp);
  594. };
  595.  
  596. var copyPLHotkeyEvent = function(e) {
  597. if ((e.metaKey || e.ctrlKey) && (e.which === 67))
  598. copyToClipboard(GMToWaze());
  599. };
  600.  
  601. function GMToWaze(){
  602. let lon, lat, zoom;
  603. let curURL = location.href.split('@').pop().split(',');
  604. lon = curURL[1];
  605. lat = curURL[0];
  606. zoom = parseInt(curURL[2]);
  607. return `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`;
  608. }
  609.  
  610. function init511PA(){
  611. $('#OOMWazeButtonDiv').remove();
  612. let $wazer = $("<div>", {style:"padding:8px 16px"});
  613. $wazer.html([
  614. '<li>',
  615. '<div id="OOMWazeButtonDiv" style="height:30px; width:34px; cursor: pointer; background-image: url(https://imgur.com/NTLWfFz.png); background-repeat: no-repeat;" title="Open in WME"></div>',
  616. '</li>'
  617. ].join(' '));
  618.  
  619. $('#optMain').append($wazer.html());
  620.  
  621. $('#OOMWazeButtonDiv').click(function(){
  622. let lon, lat, zoom;
  623. let latlon = iFrameVar.getCenterOfMap().split(',');
  624. lon = latlon[1];
  625. lat = latlon[0];
  626. zoom = iFrameVar.zoom;
  627. window.open(`https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`);
  628. });
  629. }
  630.  
  631. function init511virginia(){
  632. $('#incident_table_paginate > a').click(insertWazeLinks511Virginia);
  633. insertWazeLinks511Virginia();
  634. }
  635.  
  636. function insertWazeLinks511Virginia(){
  637. $('#incident_table > tbody > tr > td > a').parent().append(function(){
  638. if($(this).find("a").length === 1){
  639. let latlons = $(this).find("a")[0].href.match(/lon1=(.*)&lat1=(.*)&lon2=(.*)&lat2=(.*)/);
  640.  
  641. let lonCenter = Math.min(latlons[1],latlons[3]) + (Math.abs(latlons[1] - latlons[3])/2);
  642. let latCenter = Math.min(latlons[2], latlons[4]) + (Math.abs(latlons[2] - latlons[4])/2);
  643. return ` <a href='https://www.waze.com/editor/?env=usa&lon=${lonCenter}&lat=${latCenter}&zoom=4' target='_blank'>Open in WME</a>`;
  644. }
  645. return "";
  646. });
  647. }
  648.  
  649. function initmiDrive(){
  650. //g$('#dialog')
  651. var observer = new MutationObserver(function(mutations) {
  652. mutations.forEach(function(mutation) {
  653. if (g$(mutation.target).is("#dialog")) insertWMELinkMiDrive(mutation.target);
  654. });
  655. });
  656.  
  657. observer.observe(g$('#dialog').parent()[0], { childList: true, subtree: true });
  658. }
  659.  
  660. function insertWMELinkMiDrive(changedDiv){
  661. for(let i=0; i<incidents.graphics.length; i++){
  662. if(incidents.graphics[i].attributes.Message.replace("<br/>", "<br>").indexOf(g$(changedDiv).html().replace("<br/>", "<br>").replace("&amp;", "&")) > -1 && g$(changedDiv).html().indexOf("Open in WME") === -1){
  663. 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>`);
  664. break;
  665. }
  666. }
  667. }
  668.  
  669. function initWV511(){
  670. if(document.getElementById("OOMWazeButtonDiv") !== null)
  671. document.getElementById("OOMWazeButtonDiv").remove();
  672.  
  673. let $OOMWazeButton = document.createElement("div");
  674. $OOMWazeButton.setAttribute("id", "OOMWazeButtonDiv");
  675. $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;");
  676. $OOMWazeButton.setAttribute("title", "Open in WME");
  677. document.body.appendChild($OOMWazeButton);
  678.  
  679. document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
  680. let lon1, lon2, lonCenter, lat1, lat2, latCenter;
  681. let latlon = location.href.split(":");
  682. lon1 = latlon[2];
  683. lat1 = latlon[3];
  684. lon2 = latlon[4];
  685. lat2 = latlon[5];
  686.  
  687. lonCenter = Math.min(lon1,lon2) + (Math.abs(lon1 - lon2)/2);
  688. latCenter = Math.min(lat1, lat2) + (Math.abs(lat1 - lat2)/2);
  689. window.open(`https://www.waze.com/en-US/editor/?lon=${lonCenter}&lat=${latCenter}&zoom=5`);
  690. });
  691. }
  692.  
  693. bootstrap();
  694. })();