// ==UserScript==
// @name WME Open Other Maps
// @namespace https://gf.qytechs.cn/users/30701-justins83-waze
// @version 2019.03.01.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*
// @exclude https://www.waze.com/user/editor*
// @include https://www.google.com/maps*
// @include *wv511.org/*
// @include http://www.511virginia.org/mobile/?menu_id=incidents
// @include https://mdotjboss.state.mi.us/MiDrive/map*
// @include http://pkk5.rosreestr.ru*
// @include /https?:\/\/www\.511pa\.com\/Traffic\.aspx.*/
// @include http://newengland511.org*
// @include https://www.mdottraffic.com*
// @include http://www.511nj.org/trafficmap*
// @include http://nmroads.com/mapIndex.html*
// @include https://gis.transportation.wv.gov/measures*
// @include https://www.mapwv.gov/flood/map*
// @include https://roadworks.org/*
// @exclude https://www.waze.com/*/user/editor*
// @require https://gf.qytechs.cn/scripts/24851-wazewrap/code/WazeWrap.js
// @require https://gf.qytechs.cn/scripts/13097-proj4js/code/Proj4js.js
// @grant none
// @contributionURL https://github.com/WazeDev/Thank-The-Authors
// ==/UserScript==
/* global $ */
/* global OL */
/* global WazeWrap */
/* global I18n */
/* global W */
/* ecmaVersion 2017 */
/* eslint curly: ["warn", "multi-or-nest"] */
(function() {
'use strict';
//var jqUI_CssSrc = GM_getResourceText("jqUI_CSS");
//GM_addStyle(jqUI_CssSrc);
const updateMessage = "Small fix for some MyMaps that came with an extra offset - would cause the pins to shift positions based on the WME zoom level.<br><br><h3>.01</h3>Added support to load a Google MyMap data into WME. This is a one-way load - it is not possible to delete the MyMap pins from WME. Don't ask.<br><br>Scroll to the bottom of the OOM tab and paste a Google MyMap URL into the box and press Load MyMap. The MyMap must be publicly accessible.";
var settings = {};
var wazerIcon = "";
var gmapsIcon = "";
var mapillaryIcon = "";
var terraIcon = "";
var wikimapiaIcon = "";
var bingIcon = "";
var osmIcon = "";
var yandexIcon = "";
var hereIcon = "";
var midriveIcon = "";
var NYFCIcon = "";
var rosreestrIcon = "";
var PA511Icon = "";
var Miss511Icon = "";
var LAFCIcon = "";
var RoadworksIcon = "";
//var NJ511Icon = "";
var NM511Icon = "";
var WVFloodIcon = "";
var GMDMIcon = "";
var PennDOTIcon = "";
var BogotaIcon = "";
var ZoomEarthIcon = "";
var WI511Icon = "";
var OHGOIcon = "";
function initInterface(){
var $section = $("<div>");
$section.html([
'<div>',
"<p>The below maps are legal to use and do not violate Waze's external sources policy</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>`,
`<div><input type="checkbox" id="chkPA511" class="OOMchk"><label for="chkPA511"><img src="${PA511Icon}" height = 18 width="18">511PA</label></div>`,
`<div><input type="checkbox" id="chkMiss511" class="OOMchk"><label for="chkMiss511"><img src="${Miss511Icon}" height=18 width="18">Mississippi 511</label></div>`,
`<div><input type="checkbox" id="chkLAFC" class="OOMchk"><label for="chkLAFC"><img src="${LAFCIcon}" height="18" width="18">Louisiana FC</label></div>`,
//`<div><input type="checkbox" id="chkNJ511" class="OOMchk"><label for="chkNJ511"><img src="${NJ511Icon}" height="18" width="18">New Jersey 511</label></div>`,//NJ does not directly use the map at this time
`<div><input type="checkbox" id="chkNM511" class="OOMchk"><label for="chkNM511"><img src="${NM511Icon}" height="18" width="18">New Mexico 511</label></div>`,
`<div><input type="checkbox" id="chkWVFlood" class="OOMchk"><label for="chkWVFlood"><img src="${WVFloodIcon}" height="18" width="18">WV Flood</label></div>`,
`<div><input type="checkbox" id="chkGMDM" class="OOMchk"><label for="chkGMDM"><img src="${GMDMIcon}" height="18" width="18">Gaia - Mexico</label></div>`,
`<div><input type="checkbox" id="chkPennDOT" class="OOMchk"><label for="chkPennDOT"><img src="${PennDOTIcon}" height="18" width="18">PennDOT One Map</label></div>`,
`<div><input type="checkbox" id="chkBogota" class="OOMchk"><label for="chkBogota"><img src="${BogotaIcon}" height="18" width ="18">Bogota</label></div>`,
`<div><input type="checkbox" id="chkWI511" class="OOMchk"><label for="chkWI511"><img src=${WI511Icon} height="18" width="18">WI 511</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 Waze's external sources policy.</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>`,
`<div><input type="checkbox" id="chkZoomEarth" class="OOMchk"><label for="chkZoomEarth"><img src="${ZoomEarthIcon}" height="18" width ="18">Zoom Earth</label></div>`,
`<div title='Roadworks (https://roadworks.org/)'><input type="checkbox" id="chkRoadworks" class="OOMchk"><label for="chkRoadworks"><img src="${RoadworksIcon}" height="18" width ="18">Roadworks</label></div>`,
`<div><input type="checkbox" id="chkOHGO" class="OOMchk"><label for="chkOHGO"><img src="${OHGOIcon}" height="18" width="18">OHGO</label></div>`,
'</br><div>',
'<fieldset style="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><fieldset style="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
'<legend style="margin-bottom: 0px; border-bottom-style:none; width: auto;"><h4>Overlay Google MyMap markers</h4></legend>',
'MyMap link: <input type="text" name="txtOOMMyMapLink" id="txtOOMMyMapLink"/>',
'<button id="OOMLoadMyMap">Load MyMap</button>',
'</fieldset></div>',
'</div>'
].join(' '));
new WazeWrap.Interface.Tab('OOM', $section.html(), init);
}
function getolControlAttributionDivRightValue(){
return parseInt($('.olControlAttribution').css("right").slice(0,-2));;
}
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);
setChecked('chkPA511', settings.PA511);
setChecked('chkMiss511', settings.Miss511);
setChecked('chkLAFC', settings.LAFC);
setChecked('chkNM511', settings.NM511);
//setChecked('chkNJ511', settings.NJ511);
setChecked('chkWVFlood', settings.WVFlood);
setChecked('chkGMDM', settings.GMDM);
setChecked('chkBogota', settings.Bogota);
setChecked('chkZoomEarth', settings.ZoomEarth);
setChecked('chkRoadworks', settings.Roadworks);
setChecked('chkWI511', settings.WI511);
setChecked('chkOHGO', settings.OHGO);
if(settings.LangSetting == 0)
setChecked("radOOMNoLang", true);
else if(settings.LangSetting == 1)
setChecked("radOOMWMELang", true);
else
setChecked("radOOMCustomLang", true);
$('#txtOOMLanguage')[0].value = settings.CustLang;
let annoyingDivRight = getolControlAttributionDivRightValue();
$('.olControlAttribution').css("right", `${annoyingDivRight+100}px`);
annoyingDivRight = getolControlAttributionDivRightValue();
let checkedBoxes = $('.OOMchk:Checked');
let totalButtonsWidth = 0;
for(let i=0; i<checkedBoxes.length;i++){
totalButtonsWidth += parseInt($(`label[for='${$(checkedBoxes[i]).attr('id')}'] img`).css('width').slice(0,-2));
}
$('.olControlAttribution').css("right", `${annoyingDivRight+totalButtonsWidth}px`);
LoadMapButtons();
$('.OOMchk').change(function() {
var settingName = $(this)[0].id.substr(3);
settings[settingName] = this.checked;
saveSettings();
LoadMapButtons();
let btnWidth = parseInt($(`label[for='${$(this).attr('id')}'] img`).css('width').slice(0,-2));
if(this.checked){ //add button width
let annoyingDivRight = getolControlAttributionDivRightValue();
$('.olControlAttribution').css("right", `${annoyingDivRight+btnWidth}px`);
}
else{ //subtract button width
let annoyingDivRight = getolControlAttributionDivRightValue();
$('.olControlAttribution').css("right", `${annoyingDivRight-btnWidth}px`);
}
});
$("[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();
});
$('#OOMLoadMyMap').click(loadMyMap);
injectOLMyMapKML();
WazeWrap.Interface.ShowScriptUpdate("WME Open Other Maps", GM_info.script.version, updateMessage);
}
async function getKML(url){
try{
return await $.get(url);
}
catch(err){
let patt = new RegExp(/^<\?xml(?:.|\n)*<\/kml>/);
let res = patt.test(err.responseText);
if(res)
return err.responseText;
else
console.log("Error retrieving the MyMap data\n\n" + err);
}
}
async function loadMyMap(){
let url = $('#txtOOMMyMapLink')[0].value;
if(!url.length > 0)
return;
let patt = new RegExp(/^(?:http(s)?:\/\/)?www.google.com\/maps+[\w\-\._~:\/?#[\]%@!\$&\'\(\)\*\+,;=.]+$/);
let res = patt.test(url);
if(!res){ //not a google mymap url
alert("This is not a valid Google MyMap URL");
return;
}
let mid = url.match(/mid=(.*?)(&|$)/)[1];
let mapKML = await getKML(`https://www.google.com/maps/d/kml?mid=${mid}&forcekml=1`);
let parser = new OL.Format.MyMapKML();
parser.extractStyles = true;
parser.internalProjection = W.map.getProjectionObject();
parser.externalProjection = new OL.Projection("EPSG:4326");
if(W.map.getLayersByName("Google MyMap").length > 0)
W.map.removeLayer(W.map.getLayersByName("Google MyMap")[0]);
var OOMMyMapLayer = new OL.Layer.Vector("Google MyMap", { rendererOptions: { zIndexing: true }, uniqueName: "wme_oommymap", layerGroup: 'wme_oommymap'});
OOMMyMapLayer.setZIndex(-9999);
var features;
if(mapKML.documentElement)
features = parser.read(new XMLSerializer().serializeToString(mapKML.documentElement));
else
features = parser.read(mapKML);
// check which attribute can be used for labels
/*let maxlabels = 5000;
var labelname = /^description|description$/;
if (features.length <= maxlabels) {
for (var attr in features[0].attributes) {
if (labelname.test(attr.toLowerCase()) === true) {
if (typeof features[0].attributes[attr] == 'string') {
//layerStyle.label = '${'+attr+'}';
break;
}
}
}
}*/
OOMMyMapLayer.addFeatures(features);
W.map.addLayer(OOMMyMapLayer);
}
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 center = W.map.getCenter().transform(W.map.projection, W.map.displayProjection);
window.open(`https://mdotjboss.state.mi.us/MiDrive/map?constZone=true&incidents=true&lat=${center.lat}&lon=${center.lon}&zoom=${W.map.zoom + 12}`, '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)}`);
});
}
$('#OOMPA511').remove();
if(settings.PA511){
let $sectionPA511 = $("<div>", {style:"padding:8px 16px"});
$sectionPA511.html([
'<span id="OOMPA511">',
`<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;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionPA511.html());
$('#OOMPA511Img').click(function(){
let latlon = get4326CenterPoint();
window.open(`http://www.511pa.com/Traffic.aspx?${latlon.lat},${latlon.lon},${(W.map.zoom + 12)}z`);
});
}
$('#OOMMiss511').remove();
if(settings.Miss511)
{
let $section = $("<div>", {style:"padding:8px 16px"});
$section.html([
'<span id="OOMMiss511">',
`<img src="${Miss511Icon}" alt="Mississippi 511" width="18" height="18" id="OOMMiss511Img" title="Open in Mississippi 511" 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());
$('#OOMMiss511Img').click(function(){
let latlon = get4326CenterPoint();
let lang = GetLanguage();
window.open(`https://www.mdottraffic.com/default.aspx?lat=${latlon.lat}&lon=${latlon.lon}&zoom=${(W.map.zoom + 12)}`, 'Mississippi 511');
});
}
$('#OOMLAFC').remove();
if(settings.LAFC){
let $sectionLAFC = $("<div>");
$sectionLAFC.html([
'<span id="OOMLAFC">',
`<img src="${LAFCIcon}" alt="LAFC" width="18" height="18" id="OOMLAFCImg" title="Open in Louisiana FC Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionLAFC.html());
$('#OOMLAFCImg').click(function(){
let latlon = get4326CenterPoint();
window.open(`http://www.arcgis.com/home/webmap/viewer.html?webmap=a37461260bec43dea7bcbf6b710a662e¢er=${latlon.lon},${latlon.lat}&level=${(W.map.zoom + 12)}`);
});
}
/*$('#OOMNJ511').remove();
if(settings.NJ511){
let $sectionNJ511 = $("<div>");
$sectionNJ511.html([
'<span id="OOMNJ511">',
`<img src="${LAFCIcon}" alt="LAFC" width="18" height="18" id="OOMNJ511Img" title="Open in New Jersey 511 Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNJ511.html());
$('#OOMNJ511Img').click(function(){
let latlon = get4326CenterPoint();
window.open(`http://www.511nj.org/trafficmap.aspx?X=${latlon.lat}&Y=${latlon.lon}&zoom=${(W.map.zoom + 12)}`);
});
}*/
$('#OOMNM511').remove();
if(settings.NM511){
let $sectionNM511 = $("<div>");
$sectionNM511.html([
'<span id="OOMNM511">',
`<img src="${NM511Icon}" alt="New Mexico 511" width="18" height="18" id="OOMNM511Img" title="Open in New Mexico 511 Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionNM511.html());
$('#OOMNM511Img').click(function(){
let latlon = W.map.center;
//http://nmroads.com/mapIndex.html?
window.open(`http://nmroads.com/mapIndex.html?X=${latlon.lon}&Y=${latlon.lat}&zoom=${(W.map.zoom + 12)}`);
});
}
$('#OOMWVFlood').remove();
if(settings.WVFlood){
let $sectionWVFlood = $("<div>");
$sectionWVFlood.html([
'<span id="OOMWVFlood">',
`<img src="${WVFloodIcon}" alt="WV Flood" width="18" height="18" id="OOMWVFloodImg" title="Open in WV Flood map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWVFlood.html());
$('#OOMWVFloodImg').click(function(){
let latlon = W.map.center;
//https://www.mapwv.gov/flood/map/?x=-8915274&y=4681300&l=4&v=0
window.open(`https://www.mapwv.gov/flood/map/?x=${latlon.lon}&y=${latlon.lat}&l=${(W.map.zoom+4)}`);
});
}
$('#OOMGMDM').remove();
if(settings.GMDM){
let $sectionGMDM = $("<div>");
$sectionGMDM.html([
'<span id="OOMGMDM">',
`<img src="${GMDMIcon}" alt="Gaia Mexico" width="18" height="18" id="OOMGMDMImg" title="Open in Gaia Digital Mapa de Mexico" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionGMDM.html());
$('#OOMGMDMImg').click(function(){
let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection);
window.open(`http://gaia.inegi.org.mx/mdm6/?v=${btoa("lat:"+latlon.lat+",lon:"+latlon.lon+",z:"+(W.map.zoom+8))}`);
});
}
$('#OOMPennDOT').remove();
if(settings.PennDOT){
let $sectionPennDOT = $("<div>");
$sectionPennDOT.html([
'<span id="OOMPennDOT">',
`<img src="${PennDOTIcon}" alt="Pennsylvania OneMap" width="18" height="18" id="OOMPennDOTImg" title="Open in Pennsylvania OneMap" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionPennDOT.html());
$('#OOMPennDOTImg').click(function(){
let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection);
window.open(`https://www.dot7.state.pa.us/OneMap?longitude=${latlon.lon}&latitude=${latlon.lat}`);
});
}
$('#OOMBogota').remove();
if(settings.Bogota){
let $sectionBogota = $("<div>");
$sectionBogota.html([
'<span id="OOMBogota">',
`<img src="${BogotaIcon}" alt="Bogota" width="18" height="18" id="OOMBogotaImg" title="Open in Mapas Bogota" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionBogota.html());
$('#OOMBogotaImg').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));
let source = new Proj4js.Proj('EPSG:900913');
var topleft4686 = new Proj4js.Point(parseFloat(topleft.lon), parseFloat(topleft.lat));
var bottomright4686 = new Proj4js.Point(parseFloat(bottomright.lon), parseFloat(bottomright.lat));
Proj4js.transform(source, Proj4js.WGS84, topleft4686);
Proj4js.transform(source, Proj4js.WGS84, bottomright4686);
let latlon = W.map.center.transform(W.map.projection, W.map.displayProjection);
window.open(`http://mapas.bogota.gov.co/?&e=${topleft4686.x},${bottomright4686.y},${bottomright4686.x},${topleft4686.y},4686&b=261`);
});
}
$('#OOMZoomEarth').remove();
if(settings.ZoomEarth)
{
let $section = $("<div>", {style:"padding:8px 16px"});
$section.html([
'<span id="OOMZoomEarth">',
`<img src="${ZoomEarthIcon}" alt="Zoom Earth" width="18" height="18" id="OOMZoomEarthImg" title="Open in Zoom Earth" 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());
$('#OOMZoomEarthImg').click(function(){
let latlon = get4326CenterPoint();
let lang = GetLanguage();
window.open(`https://zoom.earth/#${latlon.lat},${latlon.lon},${( W.map.zoom + 12)}z,map`, 'Zoom Earth');
});
}
$('#OOMRoadworks').remove();
if(settings.Roadworks)
{
let $section = $("<div>", {style:"padding:8px 16px"});
$section.html([
'<span id="OOMRoadworks">',
`<img src="${RoadworksIcon}" alt="Roadworks" width="18" height="18" id="OOMRoadworksImg" title="Open in Roadworks" 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());
$('#OOMRoadworksImg').click(function(){
let latlon = get4326CenterPoint();
window.open(`https://roadworks.org/?lng=${latlon.lon}&lat=${latlon.lat}&zoom=${( W.map.zoom + 12)}`, 'Roadworks');
});
}
$('#OOMWI511').remove();
if(settings.WI511){
let $sectionWI511 = $("<div>", {style:"padding:8px 16px"});
$sectionWI511.html([
'<span id="OOMWI511">',
`<img src="${WI511Icon}" alt="511WI" width="18" height="18" id="OOMWI511Img" title="Open in 511WI" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionWI511.html());
$('#OOMWI511Img').click(function(){
let latlon = get4326CenterPoint();
window.open(`https://511wi.gov/?Latitude=${latlon.lat}&Longitude=${latlon.lon}&Zoom=${(W.map.zoom + 12)}&SelectedLayers=WeatherAlerts,Incidents#:Alerts`);
});
}
$('#OOMOHGO').remove();
if(settings.OHGO){
let $sectionOHGO = $("<div>", {style:"padding:8px 16px"});
$sectionOHGO.html([
'<span id="OOMOHGO">',
`<img src="${OHGOIcon}" alt="511WI" width="18" height="18" id="OOMOHGOImg" title="Open in OHGO" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
'</span>'
].join(' '));
$('.view-area.olMap >div > div > div.WazeControlPermalink').append($sectionOHGO.html());
$('#OOMOHGOImg').click(function(){
let latlon = get4326CenterPoint();
window.open(`http://www.ohgo.com/central-ohio?lt=${latlon.lat}&ln=${latlon.lon}&z=${(W.map.zoom + 12)}&ls=incident,construction,camera`);
});
}
}
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,
PA511: false,
Miss511: false,
LAFC: false,
NM511: false,
WVFlood: false,
GMDM: false,
PennDOT: false,
Bogota: false,
ZoomEarth: false,
Roadworks: false,
WI511: false,
OHGO: false
//NJ511: 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,
PA511: settings.PA511,
Miss511: settings.Miss511,
LAFC: settings.LAFC,
NM511: settings.NM511,
WVFlood: settings.WVFlood,
GMDM: settings.GMDM,
PennDOT: settings.PennDOT,
Bogota: settings.Bogota,
ZoomEarth: settings.ZoomEarth,
Roadworks: settings.Roadworks,
WI511: settings.WI511,
OHGO: settings.OHGO
//NJ511: settings.NJ511
};
localStorage.setItem("OOM_Settings", JSON.stringify(localsettings));
}
}
function isChecked(checkboxId) {
return $('#' + checkboxId).is(':checked');
}
function setChecked(checkboxId, checked) {
$('#' + checkboxId).prop('checked', checked);
}
function bootstrapGeneral(initdelegate, tries = 1){
if(document.readyState !== 'complete' )
setTimeout(function() {bootstrapGeneral(initdelegate, tries++);}, 200);
else
initdelegate();
}
let is511PAloaded = false;
function bootstrap511PA(tries = 1){
if(iFrameVar.map){
iFrameVar.map.addListener('tilesloaded', function() {
//http://www.511pa.com/Traffic.aspx?40.85,-77.6,12z
if(!is511PAloaded){
if(location.search.indexOf("?") > -1){
let params = location.search.split("?")[1].slice(0,-1);
iFrameVar.recenterMap(params);
}
is511PAloaded = true;
}
});
}
else{
setTimeout(function(){bootstrap511PA(tries +=1);}, 100);
}
$(document).ready(function(){
init511PA();
});
}
function bootstrapNM511(tries = 1){
if(map && map.extent && map.loaded)
initNM511();
else
setTimeout(function() {bootstrapNM511(tries++);}, 100);
}
function bootstrapRoadworks(tries = 1){
if(Elgin && Elgin.map && Elgin.map.tilesloading === false)
initRoadworks();
else
setTimeout(function(){bootstrapRoadworks(tries++);}, 100);
}
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("https://mdotjboss.state.mi.us") > -1)
bootstrapGeneral(initmiDrive, 1);
else if(location.href.indexOf("http://pkk5.rosreestr.ru") > -1)
bootstrapRosreestr(1);
else if(location.href.indexOf("http://www.511pa.com/Traffic") > -1 || location.href.indexOf("https://www.511pa.com/Traffic") > -1)
bootstrap511PA(1);//bootstrapGeneral(init511PA, 1);
else if(location.href.indexOf("http://newengland511.org") > -1)
bootstrapGeneral(initNE511, 1);
else if(location.href.indexOf("https://www.mdottraffic.com") > -1){
if(document.getElementById("map_canvas") != null)
initMississipie511();
else if(tries < 1000)
setTimeout(function () {bootstrap(tries++);}, 200);
}
else if(location.href.indexOf("https://gis.transportation.wv.gov/measures") > -1){
bootstrapGeneral(initWVGIS, 1);
}
else if(location.href.indexOf("http://nmroads.com/mapIndex.html") > -1){
bootstrapNM511(1);
}
else if(location.href.indexOf("https://www.mapwv.gov/flood/map") > -1){
bootstrapGeneral(initWVFlood, 1);
}
else if(location.href.indexOf("https://roadworks.org/") > -1){
bootstrapRoadworks(1);
}
/*else if(location.href.indexOf("http://www.511nj.org/trafficmap") > -1){
bootstrapGeneral(initNJ511, 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(){
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if (mutation.type === "attributes" && mutation.target == document.getElementsByClassName("btn btn-default btn-tool-lg js-showList")[0]) insertWMELinkRosreestr();
});
});
observer.observe(document.getElementById("sidebar-region"), { childList: true, subtree: true, attributes:true});
insertWMELinkRosreestr();
}
function insertWMELinkRosreestr(){
if(document.getElementById("OOMWazeButton") !== null)
document.getElementById("OOMWazeButton").remove();
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(${wazerIcon}); background-size: 36px 36px; 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:36px; width:36px; position: fixed; right:30px; top:75px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; 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);
});
}
let isMiss511Loaded = false;
function initMississipie511(){
map.addListener('tilesloaded', function() {
//https://www.mdottraffic.com/default.aspx?lat=32.36435&lon=-88.70366&zoom=15
if(!isMiss511Loaded){
if(location.search.indexOf("?") > -1 && location.search.indexOf("loadAlertid") === -1){
let params = location.search.match(/lat=(-?\d*.\d*)&lon=(-?\d*.\d*)&zoom=(\d+)/);
map.setCenter({lat: parseFloat(params[1]), lng: parseFloat(params[2])});
map.setZoom(parseInt(params[3]));
}
isMiss511Loaded = true;
}
});
let $OOMWazeButton = document.createElement("div");
$OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; position: fixed; right:40px; top:83px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`;
//let parent = document.getElementById("content-container");
document.getElementById("map_canvas").appendChild($OOMWazeButton);
document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
let center = map.getCenter();
window.open(`https://www.waze.com/en-US/editor/?lon=${center.lng()}&lat=${center.lat()}&zoom=${(Math.max(0,Math.min(10,(map.getZoom() - 12))))}`);
});
}
/* function initNJ511(){
$(document).ready(function() {
if(location.search.indexOf("?") > -1){
let params = location.search.match(/X=(-?\d*.\d*)&Y=(-?\d*.\d*)&zoom=(\d+)/);
$("#EvetnsMap").attr('src', `http://icx1-map21x.lan.511nj.org/mapwidget/mapwidget.aspx?FullScreen=false&fss=0&njlegend=1&search=0&X=${parseFloat(params[1])}Y=${parseFloat(params[2])}&zoom=${parseFloat(params[3])}&maplegend=2&Weather=1&Congestion=1&Construction=1&Incident=1&Detour=1&SpecialEvents=1&AirportParking=0&height=100&width=100&ispercent=1&WinkCamera=2&zoom=14&refershcamera=1&refershevent=1&refershspeed=1`);
}
});
}*/
function insertWMELinkNM511(){
if(document.getElementById("OOMWazeButton") !== null)
document.getElementById("OOMWazeButton").remove();
let $OOMWazeButton = document.createElement("li");
$OOMWazeButton.innerHTML = `<span id="OOMWazeButton" style="background-image: url(${wazerIcon}); background-size: 36px 36px;"></span>`;
document.getElementsByClassName('mapSettingsList')[0].appendChild($OOMWazeButton);
document.getElementById("OOMWazeButton").addEventListener("click", function(){
let source = new Proj4js.Proj('EPSG:900913');
let center = map.extent.getCenter();
var point = new Proj4js.Point(parseFloat(center.x), parseFloat(center.y));
Proj4js.transform(source, Proj4js.WGS84, point);
window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${(Math.max(0,Math.min(10,(map.getZoom() - 12))))}`);
});
}
function initNM511(){
if(location.search.indexOf("?") > -1){
let params = location.search.match(/X=(-?\d*.\d*)&Y=(-?\d*.\d*)&zoom=(\d+)/);
setTimeout(function(){
try{
map.centerAt({x:parseFloat(params[1]), y:parseFloat(params[2])});
setTimeout(function(){map.setLevel(parseInt(params[3]));}, 500);
}
catch(err) {
console.log(err);
}
}, 1000);
}
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if (mutation.type === "attributes" && mutation.target == document.getElementsByClassName("mapSettingsList")[0]) insertWMELinkNM511();
});
});
observer.observe(document.getElementsByClassName('mapSettings')[0], { childList: true, subtree: true, attributes:true});
insertWMELinkNM511();
}
function insertWMELinkRoadworks(){
if(document.getElementById("OOMWazeButton") !== null)
document.getElementById("OOMWazeButton").remove();
let $OOMWazeButton = document.createElement("li");
$OOMWazeButton.style.minHeight = "60px";
$OOMWazeButton.id = "OOMWazeButton";
$OOMWazeButton.innerHTML = `<a href="#"><span style="background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat:no-repeat; background-position:center;"></span></a>`;
document.getElementById('nav-main').getElementsByTagName('ul')[0].appendChild($OOMWazeButton);
document.getElementById("OOMWazeButton").addEventListener("click", function(){
let source = new Proj4js.Proj('EPSG:900913');
let center = Elgin.map.getCenter();
window.open(`https://www.waze.com/en-US/editor/?lon=${center.lng()}&lat=${center.lat()}&zoom=${(Math.max(0,Math.min(10,(Elgin.map.zoom - 12))))}`);
});
}
function initRoadworks(){
if(location.search.indexOf("?") > -1){
let params = location.search.match(/lng=(-?\d*.\d*)&lat=(-?\d*.\d*)&zoom=(\d+)/);
setTimeout(function(){
try{
Elgin.map.setCenter({lng:parseFloat(params[1]), lat:parseFloat(params[2])});
setTimeout(function(){Elgin.map.setZoom(parseInt(params[3]));}, 500);
}
catch(err) {
console.log(err);
}
}, 1000);
}
insertWMELinkRoadworks();
}
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 init511PA(){
$('#OOMWazeButtonDiv').remove();
let $wazer = $("<div>", {style:"padding:8px 16px"});
$wazer.html([
'<li>',
`<div id="OOMWazeButtonDiv" style="height:36px; width:36px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`,
'</li>'
].join(' '));
$('#optMain').append($wazer.html());
$('#OOMWazeButtonDiv').click(function(){
let lon, lat, zoom;
let latlon = iFrameVar.getCenterOfMap().split(',');
lon = latlon[1];
lat = latlon[0];
zoom = iFrameVar.zoom;
window.open(`https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`);
});
}
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 initNE511(){
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if ($(mutation.target)[0] == $('.ol-overlay-container.ol-selectable')[0] && $(mutation.target).css('display') == "block") {
insertWMELinkNE511();
}
});
});
observer.observe($('.ol-overlay-container.ol-selectable').parent()[0], { childList: true, subtree: true, attributes:true});
}
function insertWMELinkNE511(){
//http://newengland511.org/
let selectedIncident = $('.popover-content > [data-ng-bind="item.Description"]')[0];
let incidentDesc = selectedIncident.innerHTML;
let incidents = Leidos.Traffic.Data.events.find(function(e){ return e.Description == incidentDesc;});
$(selectedIncident).append(`<br><a href='https://www.waze.com/en-US/editor/?env=usa&lon=${incidents.StartLongitude}&lat=${incidents.StartLatitude}&zoom=6' target="_blank">Open in WME</a>`);
}
function initmiDrive(){
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if ($(mutation.target).hasClass('esri-popup__content')) insertWMELinkMiDrive(mutation.target);
});
});
observer.observe($('.esri-component.esri-popup')[0], { childList: true, subtree: true });
$('#layerContainer').append(`<button tabindex="0" class="legendIcon layerIcon clickableLegendIcon ui-btn ui-btn-inline" title="Open in WME" id="oomOpenWME"><img tabindex="-1" class="focusRem" src="${wazerIcon}" alt="icons"></button>`);
$('#legendIconContainer').css('width', (325));
$('#oomOpenWME').click(function(){
window.open(`https://www.waze.com/en-US/editor/?lon=${mapView.center.longitude}&lat=${mapView.center.latitude}&zoom=${Math.max(mapView.zoom-12,0)}`);
});
}
function insertWMELinkMiDrive(changedDiv){
for(let i=0; i<incidents.graphics.items.length; i++){
let location = incidents.graphics.items[i].attributes.Message.match(/<strong>Location: <\/strong>(.*?)<\/div>/)[1];
if($(changedDiv).html().indexOf(location) > -1 && $(changedDiv).html().indexOf("Open in WME") === -1){
$('#newItemAdded').append(`<div><a href='https://www.waze.com/en-US/editor/?env=usa&lon=${incidents.graphics.items[i].attributes.XCoord}&lat=${incidents.graphics.items[i].attributes.YCoord}&zoom=6' target="_blank">Open in WME</a></div>`);
break;
}
}
}
function initWV511(){
if(document.getElementById("OOMWazeButtonDiv") !== null)
document.getElementById("OOMWazeButtonDiv").remove();
let $OOMWazeButton = document.createElement("div");
$OOMWazeButton.setAttribute("id", "OOMWazeButtonDiv");
$OOMWazeButton.setAttribute("style", `position:absolute; right:15px; top:190px; height:36px; width:36px; cursor:pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; 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`);
});
}
function initWVGIS(){
if(document.getElementById("OOMWazeButtonDiv") !== null)
document.getElementById("OOMWazeButtonDiv").remove();
$('#RoadLayerList').prepend(`<li><div id="OOMWazeButtonDiv" aria-hidden="true" style="cursor:pointer; margin-top:8px; height:36px; width:36px; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat:no-repeat;"></div></li>`);
$('#OOMWazeButtonDiv').click(function(){
let source = new Proj4js.Proj('EPSG:900913');
var point = new Proj4js.Point(parseFloat(view.center.x), parseFloat(view.center.y));
Proj4js.transform(source, Proj4js.WGS84, point);
window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${view.zoom-5}`);
});
}
function initWVFlood(){
if($("#OOMWazeButtonDiv") !== null)
$("#OOMWazeButtonDiv").remove();
$('#tools').prepend(`<button type="button" id="btnOpenWaze" class="btn btn-default btn-lg bootstrap_btn2" style="cursor:pointer; margin-left: 0px; min-width:32px; height=32px; background-image: url(${wazerIcon}); background-size: 32px 32px; background-repeat:no-repeat; background-size:100%;" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="click to open in Waze Map Editor"><span ></span></button>`);
$('#btnOpenWaze').click(function(){
let source = new Proj4js.Proj('EPSG:900913');
var point = new Proj4js.Point(parseFloat(Flood.map.extent.getCenter().x), parseFloat(Flood.map.extent.getCenter().y));
Proj4js.transform(source, Proj4js.WGS84, point);
let zoom = Flood.map.getLevel() - 4;
if(zoom < 0)
zoom = 0;
window.open(`https://www.waze.com/en-US/editor/?lon=${point.x}&lat=${point.y}&zoom=${zoom}`);
});
}
function injectOLMyMapKML(){
if(!OL.Format.MyMapKML){
OL.Format.MyMapKML = OL.Class(OL.Format.XML,{namespaces:{kml:"http://www.opengis.net/kml/2.2",gx:"http://www.google.com/kml/ext/2.2"},kmlns:"http://earth.google.com/kml/2.0",placemarksDesc:"No description available",foldersName:"OpenLayers export",foldersDesc:"Exported on "+new Date(),extractAttributes:!0,kvpAttributes:!1,extractStyles:!1,extractTracks:!1,trackAttributes:null,internalns:null,features:null,styles:null,styleBaseUrl:"",fetched:null,maxDepth:0,iconColorMap:{"#880e4f":"","#a52714":"","#e65100":"","#f9a825":"","#ffd600":"","#817717":"","#558b2f":"","#097138":"","#006064":"","#01579b":"","#1a237e":"","#673ab7":"","#4e342e":"","#c2185b":"","#ff5252":"","#f57c00":"","#fbc02d":"","#ffea00":"","#afb42b":"","#7cb342":"","#0f9d58":"","#0097a7":"","#0288d1":"","#3949ab":"","#9c27b0":"","#795548":"","#bdbdbd":"","#757575":"","#424242":"","#000000":""},initialize:function(options){this.regExes={trimSpace:(/^\s*|\s*$/g),removeSpace:(/\s*/g),splitSpace:(/\s+/),trimComma:(/\s*,\s*/g),kmlColor:(/(\w{2})(\w{2})(\w{2})(\w{2})/),kmlIconPalette:(/root:\/\/icons\/palette-(\d+)(\.\w+)/),straightBracket:(/\$\[(.*?)\]/g)};this.externalProjection=new OpenLayers.Projection("EPSG:4326");OpenLayers.Format.XML.prototype.initialize.apply(this,[options])},read:function(data){this.features=[];this.styles={};this.fetched={};var options={depth:0,styleBaseUrl:this.styleBaseUrl};return this.parseData(data,options)},parseData:function(data,options){if(typeof data=="string")
data=OpenLayers.Format.XML.prototype.read.apply(this,[data]);var types=["Link","NetworkLink","Style","StyleMap","Placemark"];for(var i=0,len=types.length;i<len;++i){var type=types[i];var nodes=this.getElementsByTagNameNS(data,"*",type);if(nodes.length==0)
continue;switch(type.toLowerCase()){case "link":case "networklink":this.parseLinks(nodes,options);break;case "style":if(this.extractStyles)
this.parseStyles(nodes,options);break;case "stylemap":if(this.extractStyles)
this.parseStyleMaps(nodes,options);break;case "placemark":this.parseFeatures(nodes,options);break}}
return this.features},parseLinks:function(nodes,options){if(options.depth>=this.maxDepth)
return!1;var newOptions=OpenLayers.Util.extend({},options);newOptions.depth++;for(var i=0,len=nodes.length;i<len;i++){var href=this.parseProperty(nodes[i],"*","href");if(href&&!this.fetched[href]){this.fetched[href]=!0;var data=this.fetchLink(href);if(data)
this.parseData(data,newOptions)}}},fetchLink:function(href){var request=OpenLayers.Request.GET({url:href,async:!1});if(request)
return request.responseText},parseStyles:function(nodes,options){for(var i=0,len=nodes.length;i<len;i++){var style=this.parseStyle(nodes[i]);if(style){var styleName=(options.styleBaseUrl||"")+"#"+style.id;this.styles[styleName]=style}}},parseKmlColor:function(kmlColor){var color=null;if(kmlColor){var matches=kmlColor.match(this.regExes.kmlColor);if(matches){color={color:'#'+matches[4]+matches[3]+matches[2],opacity:parseInt(matches[1],16)/255,r:parseInt(matches[4],16),g:parseInt(matches[3],16),b:parseInt(matches[2],16)}}}
return color},parseStyle:function(node){var style={};var types=["LineStyle","PolyStyle","IconStyle","BalloonStyle","LabelStyle"];var type,styleTypeNode,nodeList,geometry,parser;for(var i=0,len=types.length;i<len;++i){type=types[i];styleTypeNode=this.getElementsByTagNameNS(node,"*",type)[0];if(!styleTypeNode)
continue;var kmlColor=this.parseProperty(styleTypeNode,"*","color");var color=this.parseKmlColor(kmlColor);switch(type.toLowerCase()){case "linestyle":if(color){style.strokeColor=color.color;style.strokeOpacity=color.opacity}
var width=this.parseProperty(styleTypeNode,"*","width");if(width)
style.strokeWidth=width;break;case "polystyle":if(color){style.fillOpacity=color.opacity;style.fillColor=color.color}
var fill=this.parseProperty(styleTypeNode,"*","fill");if(fill=="0"){style.fillColor="none"}
var outline=this.parseProperty(styleTypeNode,"*","outline");if(outline=="0"){style.strokeWidth="0"}
break;case "iconstyle":var scale=parseFloat(this.parseProperty(styleTypeNode,"*","scale")||1);var width=32*scale;var height=32*scale;var iconNode=this.getElementsByTagNameNS(styleTypeNode,"*","Icon")[0];if(iconNode){var href=this.parseProperty(iconNode,"*","href");if(href){var w=this.parseProperty(iconNode,"*","w");var h=this.parseProperty(iconNode,"*","h");var google="http://maps.google.com/mapfiles/kml";if(OpenLayers.String.startsWith(href,google)&&!w&&!h){w=64;h=64;scale=scale/2}
w=w||h;h=h||w;if(w)
width=parseInt(w)*scale;if(h)
height=parseInt(h)*scale;var matches=href.match(this.regExes.kmlIconPalette);if(matches){var palette=matches[1];var file_extension=matches[2];var x=this.parseProperty(iconNode,"*","x");var y=this.parseProperty(iconNode,"*","y");var posX=x?x/32:0;var posY=y?(7-y/32):7;var pos=posY*8+posX;href="http://maps.google.com/mapfiles/kml/pal"+palette+"/icon"+pos+file_extension}
style.graphicOpacity=1;style.externalGraphic=this.iconColorMap[color.color];style.graphicYOffset=-32}}
style.graphicWidth=width;style.graphicHeight=height;break;case "balloonstyle":var balloonStyle=OpenLayers.Util.getXmlNodeValue(styleTypeNode);if(balloonStyle)
style.balloonStyle=balloonStyle.replace(this.regExes.straightBracket,"${$1}");break;case "labelstyle":var kmlColor=this.parseProperty(styleTypeNode,"*","color");var color=this.parseKmlColor(kmlColor);if(color){style.fontColor=color.color;style.fontOpacity=color.opacity}
break;default:}}
if(!style.strokeColor&&style.fillColor)
style.strokeColor=style.fillColor;var id=node.getAttribute("id");if(id&&style)
style.id=id;return style},parseStyleMaps:function(nodes,options){for(var i=0,len=nodes.length;i<len;i++){var node=nodes[i];var pairs=this.getElementsByTagNameNS(node,"*","Pair");var id=node.getAttribute("id");for(var j=0,jlen=pairs.length;j<jlen;j++){var pair=pairs[j];var key=this.parseProperty(pair,"*","key");var styleUrl=this.parseProperty(pair,"*","styleUrl");if(styleUrl&&key=="normal")
this.styles[(options.styleBaseUrl||"")+"#"+id]=this.styles[(options.styleBaseUrl||"")+styleUrl]}}},parseFeatures:function(nodes,options){var features=[];for(var i=0,len=nodes.length;i<len;i++){var featureNode=nodes[i];var feature=this.parseFeature.apply(this,[featureNode]);if(feature){if(this.extractStyles&&feature.attributes&&feature.attributes.styleUrl)
feature.style=this.getStyle(feature.attributes.styleUrl,options);if(this.extractStyles){var inlineStyleNode=this.getElementsByTagNameNS(featureNode,"*","Style")[0];if(inlineStyleNode){var inlineStyle=this.parseStyle(inlineStyleNode);if(inlineStyle)
feature.style=OpenLayers.Util.extend(feature.style,inlineStyle)}}
if(this.extractTracks){var tracks=this.getElementsByTagNameNS(featureNode,this.namespaces.gx,"Track");if(tracks&&tracks.length>0){var track=tracks[0];var container={features:[],feature:feature};this.readNode(track,container);if(container.features.length>0)
features.push.apply(features,container.features)}}else{features.push(feature)}}else{throw "Bad Placemark: "+i}}
this.features=this.features.concat(features)},readers:{"kml":{"when":function(node,container){container.whens.push(OpenLayers.Date.parse(this.getChildValue(node)))},"_trackPointAttribute":function(node,container){var name=node.nodeName.split(":").pop();container.attributes[name].push(this.getChildValue(node))}},"gx":{"Track":function(node,container){var obj={whens:[],points:[],angles:[]};if(this.trackAttributes){var name;obj.attributes={};for(var i=0,ii=this.trackAttributes.length;i<ii;++i){name=this.trackAttributes[i];obj.attributes[name]=[];if(!(name in this.readers.kml))
this.readers.kml[name]=this.readers.kml._trackPointAttribute}}
this.readChildNodes(node,obj);if(obj.whens.length!==obj.points.length){throw new Error("gx:Track with unequal number of when ("+obj.whens.length+") and gx:coord ("+obj.points.length+") elements.")}
var hasAngles=obj.angles.length>0;if(hasAngles&&obj.whens.length!==obj.angles.length){throw new Error("gx:Track with unequal number of when ("+obj.whens.length+") and gx:angles ("+obj.angles.length+") elements.")}
var feature,point,angles;for(var i=0,ii=obj.whens.length;i<ii;++i){feature=container.feature.clone();feature.fid=container.feature.fid||container.feature.id;point=obj.points[i];feature.geometry=point;if("z" in point){feature.attributes.altitude=point.z}
if(this.internalProjection&&this.externalProjection)
feature.geometry.transform(this.externalProjection,this.internalProjection);if(this.trackAttributes){for(var j=0,jj=this.trackAttributes.length;j<jj;++j){var name=this.trackAttributes[j];feature.attributes[name]=obj.attributes[name][i]}}
feature.attributes.when=obj.whens[i];feature.attributes.trackId=container.feature.id;if(hasAngles){angles=obj.angles[i];feature.attributes.heading=parseFloat(angles[0]);feature.attributes.tilt=parseFloat(angles[1]);feature.attributes.roll=parseFloat(angles[2])}
container.features.push(feature)}},"coord":function(node,container){var str=this.getChildValue(node);var coords=str.replace(this.regExes.trimSpace,"").split(/\s+/);var point=new OpenLayers.Geometry.Point(coords[0],coords[1]);if(coords.length>2){point.z=parseFloat(coords[2])}
container.points.push(point)},"angles":function(node,container){var str=this.getChildValue(node);var parts=str.replace(this.regExes.trimSpace,"").split(/\s+/);container.angles.push(parts)}}},parseFeature:function(node){var order=["MultiGeometry","Polygon","LineString","Point"];var type,nodeList,geometry,parser;for(var i=0,len=order.length;i<len;++i){type=order[i];this.internalns=node.namespaceURI?node.namespaceURI:this.kmlns;nodeList=this.getElementsByTagNameNS(node,this.internalns,type);if(nodeList.length>0){var parser=this.parseGeometry[type.toLowerCase()];if(parser){geometry=parser.apply(this,[nodeList[0]]);if(this.internalProjection&&this.externalProjection)
geometry.transform(this.externalProjection,this.internalProjection)}else throw new TypeError("Unsupported geometry type: "+type);break}}
var attributes;if(this.extractAttributes)
attributes=this.parseAttributes(node);var feature=new OpenLayers.Feature.Vector(geometry,attributes);var fid=node.getAttribute("id")||node.getAttribute("name");if(fid!=null)
feature.fid=fid;return feature},getStyle:function(styleUrl,options){var styleBaseUrl=OpenLayers.Util.removeTail(styleUrl);var newOptions=OpenLayers.Util.extend({},options);newOptions.depth++;newOptions.styleBaseUrl=styleBaseUrl;if(!this.styles[styleUrl]&&!OpenLayers.String.startsWith(styleUrl,"#")&&newOptions.depth<=this.maxDepth&&!this.fetched[styleBaseUrl]){var data=this.fetchLink(styleBaseUrl);if(data)
this.parseData(data,newOptions)}
var style=OpenLayers.Util.extend({},this.styles[styleUrl]);return style},parseGeometry:{point:function(node){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"coordinates");var coords=[];if(nodeList.length>0){var coordString=nodeList[0].firstChild.nodeValue;coordString=coordString.replace(this.regExes.removeSpace,"");coords=coordString.split(",")}
var point=null;if(coords.length>1){if(coords.length==2)
coords[2]=null;point=new OpenLayers.Geometry.Point(coords[0],coords[1],coords[2])}else throw "Bad coordinate string: "+coordString;return point},linestring:function(node,ring){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"coordinates");var line=null;if(nodeList.length>0){var coordString=this.getChildValue(nodeList[0]);coordString=coordString.replace(this.regExes.trimSpace,"");coordString=coordString.replace(this.regExes.trimComma,",");var pointList=coordString.split(this.regExes.splitSpace);var numPoints=pointList.length;var points=new Array(numPoints);var coords,numCoords;for(var i=0;i<numPoints;++i){coords=pointList[i].split(",");numCoords=coords.length;if(numCoords>1){if(coords.length==2)
coords[2]=null;points[i]=new OpenLayers.Geometry.Point(coords[0],coords[1],coords[2])}else throw "Bad LineString point coordinates: "+pointList[i]}
if(numPoints){if(ring)
line=new OpenLayers.Geometry.LinearRing(points);else line=new OpenLayers.Geometry.LineString(points)}else throw "Bad LineString coordinates: "+coordString}
return line},polygon:function(node){var nodeList=this.getElementsByTagNameNS(node,this.internalns,"LinearRing");var numRings=nodeList.length;var components=new Array(numRings);if(numRings>0){var ring;for(var i=0,len=nodeList.length;i<len;++i){ring=this.parseGeometry.linestring.apply(this,[nodeList[i],!0]);if(ring)
components[i]=ring;else throw "Bad LinearRing geometry: "+i}}
return new OpenLayers.Geometry.Polygon(components)},multigeometry:function(node){var child,parser;var parts=[];var children=node.childNodes;for(var i=0,len=children.length;i<len;++i){child=children[i];if(child.nodeType==1){var type=(child.prefix)?child.nodeName.split(":")[1]:child.nodeName;var parser=this.parseGeometry[type.toLowerCase()];if(parser)
parts.push(parser.apply(this,[child]))}}
return new OpenLayers.Geometry.Collection(parts)}},parseAttributes:function(node){var attributes={};var edNodes=node.getElementsByTagName("ExtendedData");if(edNodes.length)
attributes=this.parseExtendedData(edNodes[0]);var child,grandchildren,grandchild;var children=node.childNodes;for(var i=0,len=children.length;i<len;++i){child=children[i];if(child.nodeType==1){grandchildren=child.childNodes;if(grandchildren.length>=1&&grandchildren.length<=3){var grandchild;switch(grandchildren.length){case 1:grandchild=grandchildren[0];break;case 2:var c1=grandchildren[0];var c2=grandchildren[1];grandchild=(c1.nodeType==3||c1.nodeType==4)?c1:c2;break;case 3:default:grandchild=grandchildren[1];break}
if(grandchild.nodeType==3||grandchild.nodeType==4){var name=(child.prefix)?child.nodeName.split(":")[1]:child.nodeName;var value=OpenLayers.Util.getXmlNodeValue(grandchild);if(value){value=value.replace(this.regExes.trimSpace,"");attributes[name]=value}}}}}
return attributes},parseExtendedData:function(node){var attributes={};var i,len,data,key;var dataNodes=node.getElementsByTagName("Data");for(i=0,len=dataNodes.length;i<len;i++){data=dataNodes[i];key=data.getAttribute("name");var ed={};var valueNode=data.getElementsByTagName("value");if(valueNode.length)
ed.value=this.getChildValue(valueNode[0]);if(this.kvpAttributes)
attributes[key]=ed.value;else{var nameNode=data.getElementsByTagName("displayName");if(nameNode.length)
ed.displayName=this.getChildValue(nameNode[0]);attributes[key]=ed}}
var simpleDataNodes=node.getElementsByTagName("SimpleData");for(i=0,len=simpleDataNodes.length;i<len;i++){var ed={};data=simpleDataNodes[i];key=data.getAttribute("name");ed.value=this.getChildValue(data);if(this.kvpAttributes)
attributes[key]=ed.value;else{ed.displayName=key;attributes[key]=ed}}
return attributes},parseProperty:function(xmlNode,namespace,tagName){var value;var nodeList=this.getElementsByTagNameNS(xmlNode,namespace,tagName);try{value=OpenLayers.Util.getXmlNodeValue(nodeList[0])}catch(e){value=null}
return value},write:function(features){if(!(OpenLayers.Util.isArray(features)))
features=[features];var kml=this.createElementNS(this.kmlns,"kml");var folder=this.createFolderXML();for(var i=0,len=features.length;i<len;++i){folder.appendChild(this.createPlacemarkXML(features[i]))}
kml.appendChild(folder);return OpenLayers.Format.XML.prototype.write.apply(this,[kml])},createFolderXML:function(){var folder=this.createElementNS(this.kmlns,"Folder");if(this.foldersName){var folderName=this.createElementNS(this.kmlns,"name");var folderNameText=this.createTextNode(this.foldersName);folderName.appendChild(folderNameText);folder.appendChild(folderName)}
if(this.foldersDesc){var folderDesc=this.createElementNS(this.kmlns,"description");var folderDescText=this.createTextNode(this.foldersDesc);folderDesc.appendChild(folderDescText);folder.appendChild(folderDesc)}
return folder},createPlacemarkXML:function(feature){var placemarkName=this.createElementNS(this.kmlns,"name");var label=(feature.style&&feature.style.label)?feature.style.label:feature.id;var name=feature.attributes.name||label;placemarkName.appendChild(this.createTextNode(name));var placemarkDesc=this.createElementNS(this.kmlns,"description");var desc=feature.attributes.description||this.placemarksDesc;placemarkDesc.appendChild(this.createTextNode(desc));var placemarkNode=this.createElementNS(this.kmlns,"Placemark");if(feature.fid!=null)
placemarkNode.setAttribute("id",feature.fid);placemarkNode.appendChild(placemarkName);placemarkNode.appendChild(placemarkDesc);var geometryNode=this.buildGeometryNode(feature.geometry);placemarkNode.appendChild(geometryNode);if(feature.attributes){var edNode=this.buildExtendedData(feature.attributes);if(edNode)
placemarkNode.appendChild(edNode)}
return placemarkNode},buildGeometryNode:function(geometry){var className=geometry.CLASS_NAME;var type=className.substring(className.lastIndexOf(".")+1);var builder=this.buildGeometry[type.toLowerCase()];var node=null;if(builder)
node=builder.apply(this,[geometry]);return node},buildGeometry:{point:function(geometry){var kml=this.createElementNS(this.kmlns,"Point");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},multipoint:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},linestring:function(geometry){var kml=this.createElementNS(this.kmlns,"LineString");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},multilinestring:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},linearring:function(geometry){var kml=this.createElementNS(this.kmlns,"LinearRing");kml.appendChild(this.buildCoordinatesNode(geometry));return kml},polygon:function(geometry){var kml=this.createElementNS(this.kmlns,"Polygon");var rings=geometry.components;var ringMember,ringGeom,type;for(var i=0,len=rings.length;i<len;++i){type=(i==0)?"outerBoundaryIs":"innerBoundaryIs";ringMember=this.createElementNS(this.kmlns,type);ringGeom=this.buildGeometry.linearring.apply(this,[rings[i]]);ringMember.appendChild(ringGeom);kml.appendChild(ringMember)}
return kml},multipolygon:function(geometry){return this.buildGeometry.collection.apply(this,[geometry])},collection:function(geometry){var kml=this.createElementNS(this.kmlns,"MultiGeometry");var child;for(var i=0,len=geometry.components.length;i<len;++i){child=this.buildGeometryNode.apply(this,[geometry.components[i]]);if(child)
kml.appendChild(child)}
return kml}},buildCoordinatesNode:function(geometry){var coordinatesNode=this.createElementNS(this.kmlns,"coordinates");var path;var points=geometry.components;if(points){var point;var numPoints=points.length;var parts=new Array(numPoints);for(var i=0;i<numPoints;++i){point=points[i];parts[i]=this.buildCoordinates(point)}
path=parts.join(" ")}else{path=this.buildCoordinates(geometry)}
var txtNode=this.createTextNode(path);coordinatesNode.appendChild(txtNode);return coordinatesNode},buildCoordinates:function(point){if(this.internalProjection&&this.externalProjection){point=point.clone();point.transform(this.internalProjection,this.externalProjection)}
return point.x+","+point.y},buildExtendedData:function(attributes){var extendedData=this.createElementNS(this.kmlns,"ExtendedData");for(var attributeName in attributes){if(attributes[attributeName]&&attributeName!="name"&&attributeName!="description"&&attributeName!="styleUrl"){var data=this.createElementNS(this.kmlns,"Data");data.setAttribute("name",attributeName);var value=this.createElementNS(this.kmlns,"value");if(typeof attributes[attributeName]=="object"){if(attributes[attributeName].value){value.appendChild(this.createTextNode(attributes[attributeName].value))}
if(attributes[attributeName].displayName){var displayName=this.createElementNS(this.kmlns,"displayName");displayName.appendChild(this.getXMLDoc().createCDATASection(attributes[attributeName].displayName));data.appendChild(displayName)}}else value.appendChild(this.createTextNode(attributes[attributeName]));data.appendChild(value);extendedData.appendChild(data)}}
if(this.isSimpleContent(extendedData))
return null;else return extendedData},changeImageColor:function(img,r,g,b){function rgbToHsl(r,g,b){r/=255;g/=255;b/=255;let max=Math.max(r,g,b),min=Math.min(r,g,b);let h,s,l=(max+min)/2;if(max==min)
h=s=0;else{let d=max-min;s=l>0.5?d/(2-max-min):d/(max+min);switch(max){case r:h=(g-b)/d+(g<b?6:0);break;case g:h=(b-r)/d+2;break;case b:h=(r-g)/d+4;break}
h/=6}
return({h:h,s:s,l:l,})};let canvas=document.createElement('canvas');let ctx=canvas.getContext("2d");ctx.drawImage(img,0,0);let imgData=ctx.getImageData(0,0,32,32);let data=imgData.data;for(var i=0;i<data.length;i+=4){let red=data[i+0];let green=data[i+1];let blue=data[i+2];let alpha=data[i+3];if(alpha<10)
continue;let hsl=rgbToHsl(red,green,blue);let hue=hsl.h*360;if(hue<20){data[i+0]=r;data[i+1]=g;data[i+2]=b}}
let mycanvas=document.createElement('canvas');$(mycanvas).attr('width',32);$(mycanvas).attr('height',32);let newctx=mycanvas.getContext('2d');newctx.putImageData(imgData,0,0);return mycanvas.toDataURL()},CLASS_NAME:"OpenLayers.Format.KML"})
}
}
bootstrap();
})();