Greasy Fork is available in English.

WME Open Other Maps

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

// ==UserScript==
// @name         WME Open Other Maps
// @namespace    https://greasyfork.org/users/30701-justins83-waze
// @version      2023.08.14.01
// @description  Links for opening external resources at the WME location and WME from external resources
// @author       JustinS83
// @match        https://www.waze.com/editor*
// @match        https://www.waze.com/*/editor*
// @match        https://beta.waze.com*
// @match        *://www.google.com/maps/*
// @match        *wv511.org/*
// @match        http://www.511virginia.org/mobile/?menu_id=incidents
// @match        https://mdotjboss.state.mi.us/MiDrive/map*
// @match        http://pkk5.rosreestr.ru*
// @match        https://www.511pa.com/Traffic.aspx.*
// @match        http://newengland511.org*
// @match        https://www.mdottraffic.com*
// @match        http://www.511nj.org/trafficmap*
// @match        http://nmroads.com/mapIndex.html*
// @match        https://gis.transportation.wv.gov/measures*
// @match        https://www.mapwv.gov/flood/map*
// @match        https://roadworks.org/*
// @match        https://www.idrivearkansas.com*
// @match        http://bridgereports.com/*
// @match        http://www.deldot.gov/map*
// @match        https://bagviewer.kadaster.nl/lvbag/bag-viewer/index.html*
// @match        http://www.trimarc.org*
// @match        http://traffic.houstontranstar.org/layers/layers_ve.aspx*
// @match        https://drivetexas.org/*
// @match        https://www.511la.org/
// @exclude      https://www.waze.com/user/editor*
// @exclude      https://www.waze.com/*/user/editor*
// @require      https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
// @require      https://greasyfork.org/scripts/383120-proj4-wazedev/code/proj4-Wazedev.js
// @grant           GM_xmlhttpRequest
// @noframes
// @contributionURL https://github.com/WazeDev/Thank-The-Authors
// ==/UserScript==

/* global $ */
/* global OpenLayers */
/* global WazeWrap */
/* global I18n */
/* global W */
/* global proj4 */
/* ecmaVersion 2017 */
/* eslint curly: ["warn", "multi-or-nest"] */

(function() {
    'use strict';
    //var jqUI_CssSrc = GM_getResourceText("jqUI_CSS");
    //GM_addStyle(jqUI_CssSrc);

    const updateMessage = `Bug fix: Red Vial launching`;

    var settings = {};
    var wazerIcon = "";
    var gmapsIcon = "";
    var mapillaryIcon = "";
    var wikimapiaIcon = "";
    var bingIcon = "";
    var osmIcon = "";
    var yandexIcon = "";
    var hereIcon = "";
    var midriveIcon = "";
    var NYFCIcon = "";
    var NYCMapsIcon = "";
    var NYGISIcon = "";
    var NYSLIcon = "";
    var NY511Icon = "";
    var NexarIcon = "";
    var rosreestrIcon = "";
    var PA511Icon = "";
    var Miss511Icon = "";
    var LAFCIcon = "";
    var RoadworksIcon = "";
    //var NJ511Icon = "";
    var LA511Icon = "";
    var NM511Icon = "";
    var WVFloodIcon = "";
    var GMDMIcon = "";
    var PennDOTIcon = "";
    var BogotaIcon = "";
    var ZoomEarthIcon = "";
    var WI511Icon = "";
    var OHGOIcon = "";
    var ArkDOTIcon = "";
    var DelDOTIcon = "";
    var BagViewerIcon = "";
    var MelvinIcon = "";
    var NaviExpertIcon = "";
    var TranstarIcon = "";
    var MaineDOTIcon = "";
    var DriveTexasIcon = "";
    var RedVialIcon = "";
    var MapyCZIcon = "";
    var HamONIcon = "";
    var NiagONIcon = "";
    var MissONIcon = "";
    //    var BurlONIcon = "";
    //    var TorONIcon = "";
    //    var MiltONIcon = "";
    var BramONIcon = "";
    var HaltRLCIcon = "";
    var WV511Icon = "";

    function initInterface(){
        var $section = $("<div>");
        $section.html([
            '<fieldset style="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
            '<div>',
            "<p>The below maps are legal to use and do not violate Waze's external sources policy</p>",
            `<details><summary style="outline:none" ><strong>New York State Resources</strong></summary>`,
            `<div><input type="checkbox" id="chkNYFC" class="OOMchk" style="margin-left: 40px"><label for="chkNYFC"> <img src="${NYFCIcon}" height="18" width="18">NY FC</label></div>`,
            `<div><input type="checkbox" id="chkNYGIS" class="OOMchk" style="margin-left: 40px"><label for="chkNYGIS"> <img src="${NYGISIcon}" height="18" width="18">NY GIS</label></div>`,
            `<div><input type="checkbox" id="chkNYCMaps" class="OOMchk" style="margin-left: 40px"><label for="chkNYCMaps"> <img src="${NYCMapsIcon}" height="18" width="18">NYC Maps</label></div>`,
            `<div><input type="checkbox" id="chkNYSL" class="OOMchk" style="margin-left: 40px"><label for="chkNYSL"> <img src="${NYSLIcon}" height="18" width="18">NY Speedlimits</label></div>`,
            `<div><input type="checkbox" id="chkNY511" class="OOMchk" style="margin-left: 40px"><label for="chkNY511"> <img src="${NY511Icon}" height="18" width="18">511NY</label></div>`,
            `<div><input type="checkbox" id="chkNexar" class="OOMchk" style="margin-left: 40px"><label for="chkNexar"> <img src="${NexarIcon}" height="18" width="18">Nexar</label></div>`,
            `<hr></div></details><br>`,
            `<details><summary style="outline:none" ><strong>Ontario, Canada Resources</strong></summary>`,
            `<div><input type="checkbox" id="chkHamON" class="OOMchk" style="margin-left: 40px"><label for="chkHamON"><img src=${HamONIcon} height="18" width="18">Hamilton, ON</label></div>`,
            //             `<div><input type="checkbox" id="chkBurlON" class="OOMchk" style="margin-left: 40px"><label for="chkBurlON"><img src=${BurlONIcon} height="18" width="18">Burlington, ON</label></div>`,
            `<div><input type="checkbox" id="chkNiagON" class="OOMchk" style="margin-left: 40px"><label for="chkNiagON"><img src=${NiagONIcon} height="18" width="18">Niagara, ON</label></div>`,
            `<div><input type="checkbox" id="chkMissON" class="OOMchk" style="margin-left: 40px"><label for="chkMissON"><img src=${MissONIcon} height="18" width="18">Mississauga, ON</label></div>`,
            //             `<div><input type="checkbox" id="chkMiltON" class="OOMchk" style="margin-left: 40px"><label for="chkMiltON"><img src=${MiltONIcon} height="18" width="18">Milton, ON</label></div>`,
            //             `<div><input type="checkbox" id="chkTorON" class="OOMchk" style="margin-left: 40px"><label for="chkMissON"><img src=${TorONIcon} height="18" width="18">Toronto, ON</label></div>`,
            `<div><input type="checkbox" id="chkBramON" class="OOMchk" style="margin-left: 40px"><label for="chkBramON"><img src=${BramONIcon} height="18" width="18">Brampton, ON</label></div>`,
            `<div><input type="checkbox" id="chkHaltRLC" class="OOMchk" style="margin-left: 40px"><label for="chkHaltRLC"><img src=${HaltRLCIcon} height="18" width="18">Halton RLC's</label></div>`,
            `</div></details><br>`,
            `<details><summary style="outline:none" ><strong>Pennsylvania Resources</strong></summary>`,
            `<div><input type="checkbox" id="chkPA511" class="OOMchk" style="margin-left: 40px"><label for="chkPA511"><img src="${PA511Icon}" height = 18 width="18">511PA</label></div>`,
            `<div><input type="checkbox" id="chkPennDOT" class="OOMchk" style="margin-left: 40px"><label for="chkPennDOT"><img src="${PennDOTIcon}" height="18" width="18">PennDOT One Map</label></div>`,
            `</div></details><br>`,
            `<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="chkDriveTexas" class="OOMchk"><label for="chkDriveTexas"><img src=${DriveTexasIcon} height="18" width="18">DriveTexas</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="chkArkDOT" class="OOMchk"><label for="chkArkDOT"><img src=${ArkDOTIcon} height="18" width="18">IDrive Arkansas</label></div>`,
            `<div><input type="checkbox" id="chkBagViewer" class="OOMchk"><label for="chkBagViewer"><img src=${BagViewerIcon} height="18" width="18">Kadaster BAG Viewer</label></div>`,
            `<div><input type="checkbox" id="chkLA511" class="OOMchk"><label for="chkLA511"><img src=${LA511Icon} height="18" width="18">511 LA</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="chkMaineDOT" class="OOMchk"><label for="chkMaineDOT"><img src=${MaineDOTIcon} height="18" width="18">MaineDOT</label></div>`,
            `<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="chkMiss511" class="OOMchk"><label for="chkMiss511"><img src="${Miss511Icon}" height=18 width="18">Mississippi 511</label></div>`,
            `<div><input type="checkbox" id="chkNaviExpert" class="OOMchk"><label for="chkNaviExpert"><img src=${NaviExpertIcon} height="18" width="18">NaviExpert</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="chkRedVial" class="OOMchk"><label for="chkRedVial"><img src=${RedVialIcon} height="18" width="18">Red Vial Nacional (Chile)</label></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="chkWI511" class="OOMchk"><label for="chkWI511"><img src=${WI511Icon} height="18" width="18">WI 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="chkWV511" class="OOMchk"><label for="chkWV511"><img src="${WV511Icon}" height="18" width="18">WV 511</label></div>`,
            '</fieldset></br>',
            /*'<fieldset style="border: 1px solid silver; padding: 8px; border-radius: 4px;">',
            "<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="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>`,
            `<div><input type="checkbox" id="chkDelDOT" class="OOMchk"><label for="chkDelDOT"><img src="${DelDOTIcon}" height="18" width="18">DelDOT</label></div>`,
            `<div><input type="checkbox" id="chkMelvin" class="OOMchk"><label for="chkMelvin"><img src=${MelvinIcon} height="18" width="18">Melvin</label></div>`,
            `<div><input type="checkbox" id="chkTranstar" class="OOMchk"><label for="chkTranstar"><img src=${TranstarIcon} height="18" width="18">Transtar</label></div>`,
            `<div><input type="checkbox" id="chkMapyCZ" class="OOMchk"><label for="chkMapyCZ"><img src=${MapyCZIcon} height="18" width="18">Mapy.cz</label></div>`,
            '</br><div></fieldset>',*/
            '<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(' '));

        WazeWrap.Interface.Tab('OOM', $section.html(), init, 'OOM');
    }

    function getolControlAttributionDivRightValue(){
        return parseInt($('.wz-map-ol-control-attribution').css("right").slice(0,-2));;
    }

    function init(){
        loadSettings();
        setChecked('chkGMaps', settings.GMaps);
        setChecked('chkMapillary', settings.Mapillary);
        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('chkNYGIS', settings.NYGIS);
        setChecked('chkNYSL', settings.NYSL);
        setChecked('chkNYCMaps', settings.NYCMaps);
        setChecked('chkNY511', settings.NY511);
        setChecked('chkNexar', settings.Nexar);
        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('chkLA511', settings.LA511);
        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);
        setChecked('chkArkDOT', settings.ArkDOT);
        setChecked('chkDelDOT', settings.DelDOT);
        setChecked('chkBagViewer', settings.BagViewer);
        setChecked('chkMelvin', settings.Melvin);
        setChecked('chkNaviExpert', settings.NaviExpert);
        setChecked('chkTranstar', settings.Transtar);
        setChecked('chkMaineDOT', settings.MaineDOT);
        setChecked('chkDriveTexas', settings.DriveTexas);
        setChecked('chkRedVial', settings.RedVial);
        setChecked('chkMapyCZ', settings.MapyCZ);
        //        setChecked('chkBurlON', settings.BurlON);
        setChecked('chkHamlON', settings.HamON);
        setChecked('chkNiagON', settings.NiagON);
        setChecked('chkMissON', settings.MissON);
        //        setChecked('chkTorON', settings.TorON);
        //        setChecked('chkMiltON', settings.MiltON);
        setChecked('chkBramON', settings.BramON);
        setChecked('chkHaltRLC', settings.HaltRLC);
        setChecked('chkWV511', settings.WV511);

        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();
        $('.wz-map-ol-control-attribution').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));
        }
        $('.wz-map-ol-control-attribution').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();
                $('.wz-map-ol-control-attribution').css("right", `${annoyingDivRight+btnWidth}px`);
            }
            else{ //subtract button width
                let annoyingDivRight = getolControlAttributionDivRightValue();
                $('.wz-map-ol-control-attribution').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, "https://greasyfork.org/en/scripts/32758-wme-open-other-maps");
    }

    async function getKML(url){
        try{
            return await wrapGMXMLHTTP(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 wrapGMXMLHTTP(url){
        return new Promise((resolve, reject) => {
            GM_xmlhttpRequest({
                url,
                method: 'GET',
                onload(res) {
                    if (res.status < 400) {
                        resolve(res.responseText);
                    } else {
                        console.log("error");
                        console.log(res.status);
                        // handle errors here
                    }
                },
                onerror(res) {
                    // handle errors here
                    console.log("Error:");
                    console.log(res.text);
                }
            });
        });
    }

    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
            WazeWrap.Alerts.error(GM_info.script.name, "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 OpenLayers.Format.MyMapKML();
        parser.extractStyles = true;
        parser.internalProjection = W.Config.map.projection.local;
        parser.externalProjection = new OpenLayers.Projection("EPSG:4326");

        if(W.map.getLayersByName("Google MyMap").length > 0)
            W.map.removeLayer(W.map.getLayersByName("Google MyMap")[0]);
        var OOMMyMapLayer = new OpenLayers.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);
        WazeWrap.Interface.AddLayerCheckbox("display", "Google MyMap", true, function(visible){OOMMyMapLayer.setVisibility(visible);});
    }

    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 OpenLayers.Projection("EPSG:900913");
        let projE = new OpenLayers.Projection("EPSG:4326");
        let center_lonlat = (new OpenLayers.LonLat(W.map.getCenter().lon, W.map.getCenter().lat)).transform(projI,projE);
        let lat = Math.round(center_lonlat.lat * 1000000) / 1000000;
        let lon = Math.round(center_lonlat.lon * 1000000) / 1000000;
        return new OpenLayers.LonLat(lon, lat);
    }

    var insertPath = '.WazeControlPermalink';
    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(' '));

            $(insertPath).append($section.html());

            $('#OOMMiDriveImg').click(function(){
                var center = get4326CenterPoint();
                window.open(`https://mdotjboss.state.mi.us/MiDrive/map?constZone=true&incidents=true&lat=${center.lat}&lon=${center.lon}&zoom=${W.map.getZoom() -1 }`, '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(' '));

            $(insertPath).prepend($section.html());

            $('#OOMGMapsImg').click(function(){
                let latlon = get4326CenterPoint();
                let lang = GetLanguage();

                window.open('https://www.google.com/maps/@' + latlon.lat + ',' + latlon.lon + ',' + ( W.map.getZoom()) + '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(' '));

            $(insertPath).prepend($sectionMapillary.html());
            $('#OOMMapillaryImg').click(function(){
                let latlon = get4326CenterPoint();

                window.open(`https://www.mapillary.com/app/?lat=${latlon.lat}&lng=${latlon.lon}&z=${( W.map.getZoom() + 11)}`, 'Mapillary');
            });
        }


        //********************* 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($sectionHere.html());

            $('#OOMHereImg').click(function(){
                let latlon = get4326CenterPoint();

                window.open(`https://wego.here.com/?map=${latlon.lat},${latlon.lon},${(W.map.getZoom() + 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(' '));

            $(insertPath).prepend($sectionNYFC.html());

            $('#OOMNYFCImg').click(function(){
                let e=W.map.getExtent();
                let geoNW=new OpenLayers.Geometry.Point(e.left,e.top);
                let geoSE=new OpenLayers.Geometry.Point(e.right,e.bottom);

                //proj4.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs";
                proj4.defs("EPSG:26918", "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs")

                let source = new proj4.Proj('EPSG:900913');
                let dest = new proj4.Proj('EPSG:26918');

                geoNW = new proj4.toPoint([geoNW.x,geoNW.y]);
                geoSE = new proj4.toPoint([geoSE.x,geoSE.y]);

                geoNW = proj4.transform(source, dest, geoNW);
                geoSE = proj4.transform(source, dest, geoSE);

                let mapScale = 36111.909643;

                switch (W.map.getZoom()) {
                    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://gis.dot.ny.gov/html5viewer/?viewer=FC&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y;
                window.open(URL,"_blank");
            });
        }
        $('#OOMNYSL').remove();
        if(settings.NYSL){
            let $sectionNYSL = $("<div>", {style:"padding:8px 16px"});
            $sectionNYSL.html([
                '<span id="OOMNYSL">',
                `<img src="${NYSLIcon}" alt="NYS Speed Limits" width="18" height="18" id="OOMNYSLImg" title="Open in NYS speed limits Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNYSL.html());

            $('#OOMNYSLImg').click(function(){
                let e=W.map.getExtent();
                let geoNW=new OpenLayers.Geometry.Point(e.left,e.top);
                let geoSE=new OpenLayers.Geometry.Point(e.right,e.bottom);

                //proj4.defs["EPSG:26918"] = "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs";
                proj4.defs("EPSG:26918", "+proj=utm +zone=18 +ellps=GRS80 +datum=NAD83 +units=m +no_defs")
                let source = new proj4.Proj('EPSG:900913');
                let dest = new proj4.Proj('EPSG:26918');

                geoNW = new proj4.toPoint([geoNW.x,geoNW.y]);
                geoSE = new proj4.toPoint([geoSE.x,geoSE.y]);

                geoNW = proj4.transform(source, dest, geoNW);
                geoSE = proj4.transform(source, dest, geoSE);

                let mapScale = 36111.909643;

                switch (W.map.getZoom()) {
                    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='https://gis.dot.ny.gov/html5viewer/?viewer=risviewer&scale='+mapScale+'&extent='+geoNW.x+'%2C'+geoNW.y+'%2C'+geoSE.x+'%2C'+geoSE.y;
                window.open(URL,"_blank");
            });
        }

        $('#OOMNYGIS').remove();
        if(settings.NYGIS){
            let $sectionNYGIS = $("<div>", {style:"padding:8px 16px"});
            $sectionNYGIS.html([
                '<span id="OOMNYGIS">',
                `<img src="${NYGISIcon}" alt="NYGIS" width="18" height="18" id="OOMNYGISImg" title="Open in NY Orthos GIS" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNYGIS.html());

            $('#OOMNYGISImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://orthos.dhses.ny.gov/?lat=${latlon.lat}&long=${latlon.lon}&zoom=${(W.map.getZoom() + 12)}`);
            });
        }

        $('#OOMNY511').remove();
        if(settings.NY511){
            let $sectionNY511 = $("<div>", {style:"padding:8px 16px"});
            $sectionNY511.html([
                '<span id="OOMNY511">',
                `<img src="${NY511Icon}" alt="NY511" width="18" height="18" id="OOMNY511Img" title="Open in 511ny.org" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNY511.html());

            $('#OOMNY511Img').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://511ny.org/?latitude=${latlon.lat}&longitude=${latlon.lon}&zoom=${(W.map.getZoom() + 12)}`);
            });
        }
        $('#OOMLA511').remove();
        if(settings.LA511){
            let $sectionLA511 = $("<div>", {style:"padding:8px 16px"});
            $sectionLA511.html([
                '<span id="OOMLA511">',
                `<img src="${LA511Icon}" alt="LA511" width="18" height="18" id="OOMLA511Img" title="Open in 511la.org" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionLA511.html());

            $('#OOMLA511Img').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://511la.org/?latitude=${latlon.lat}&longitude=${latlon.lon}&zoom=${(W.map.getZoom() + 12)}`);
            });
        }

        $('#OOMWV511').remove();
        if(settings.WV511){
            let $sectionWV511 = $("<div>", {style:"padding:8px 16px"});
            $sectionWV511.html([
                '<span id="OOMWV511">',
                `<img src="${WV511Icon}" alt="WV511" width="18" height="18" id="OOMWV511Img" title="Open in WV511.org" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionWV511.html());

            $('#OOMWV511Img').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://WV511.org/?lat=${latlon.lat}&lng=${latlon.lon}&zoom=${W.map.getZoom()}`);
            });
        }

        $('#OOMNexar').remove();
        if(settings.Nexar){
            let $sectionNexar = $("<div>", {style:"padding:8px 16px"});
            $sectionNexar.html([
                '<span id="OOMNexar">',
                `<img src="${NexarIcon}" alt="Nexar" width="18" height="18" id="OOMNexarImg" title="Open in Nexar" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNexar.html());

            $('#OOMNexarImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://citystream.getnexar.com/virtualcam?center=%7B%22lng%22%3A${latlon.lon}%2C%22lat%22%3A${latlon.lat}%7D&zoom=${(W.map.getZoom() + 11)}`);
            });
        }

        $('#OOMNYCMaps').remove();
        if(settings.NYCMaps){
            let $sectionNYCMaps = $("<div>", {style:"padding:8px 16px"});
            $sectionNYCMaps.html([
                '<span id="OOMNYCMaps">',
                `<img src="${NYCMapsIcon}" alt="NYGIS" width="18" height="18" id="OOMNYCMapsImg" title="Open in NYC Maps" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNYCMaps.html());

            $('#OOMNYCMapsImg').click(function(){
                var geoPoint=new OpenLayers.Geometry.Point(W.map.getCenter().lon,W.map.getCenter().lat);

                proj4.defs("ESRI:102718", "+proj=lcc +lat_1=40.66666666666666 +lat_2=41.03333333333333 +lat_0=40.16666666666666 +lon_0=-74 +x_0=300000 +y_0=0 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 no_defs");

                var source = new proj4.Proj('EPSG:900913');
                var dest = new proj4.Proj('ESRI:102718');

                geoPoint = proj4.transform(source, dest, geoPoint);
                var zoom = (W.map.getZoom())+3;
                var URL='http://maps.nyc.gov/doitt/nycitymap/?z='+zoom+'&p='+(Math.round(geoPoint.x)*3.2808)+','+(Math.round(geoPoint.y)*3.2808)+'&c=GISBasic&f=DDC_PROJECTS';
                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(' '));

            $(insertPath).prepend($sectionRosreestr.html());

            $('#OOMrosreestrImg').click(function(){
                window.open(`http://pkk5.rosreestr.ru/#x=${W.map.getCenter().lon}&y=${W.map.getCenter().lat}&z=${(W.map.getZoom() + 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(' '));

            $(insertPath).prepend($sectionPA511.html());

            $('#OOMPA511Img').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`http://www.511pa.com/Traffic.aspx?${latlon.lat},${latlon.lon},${(W.map.getZoom() + 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($sectionLAFC.html());
            $('#OOMLAFCImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`http://www.arcgis.com/home/webmap/viewer.html?webmap=a37461260bec43dea7bcbf6b710a662e&center=${latlon.lon},${latlon.lat}&level=${(W.map.getZoom() + 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(' '));

            $(insertPath).prepend($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.getZoom() + 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(' '));

            $(insertPath).prepend($sectionNM511.html());
            $('#OOMNM511Img').click(function(){
                let latlon = W.map.getCenter();

                //http://nmroads.com/mapIndex.html?
                window.open(`http://nmroads.com/mapIndex.html?X=${latlon.lon}&Y=${latlon.lat}&zoom=${(W.map.getZoom() + 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(' '));

            $(insertPath).prepend($sectionWVFlood.html());
            $('#OOMWVFloodImg').click(function(){
                let latlon = W.map.getCenter();

                //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.getZoom()+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(' '));

            $(insertPath).prepend($sectionGMDM.html());
            $('#OOMGMDMImg').click(function(){
                let latlon = get4326CenterPoint();

                window.open(`http://gaia.inegi.org.mx/mdm6/?v=${btoa("lat:"+latlon.lat+",lon:"+latlon.lon+",z:"+(W.map.getZoom()+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(' '));

            $(insertPath).prepend($sectionPennDOT.html());
            $('#OOMPennDOTImg').click(function(){
                let latlon = W.map.getCenter().transform(W.Config.map.projection.remote, W.Config.map.projection.local);
                window.open(`https://gis.penndot.gov/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(' '));

            $(insertPath).prepend($sectionBogota.html());
            $('#OOMBogotaImg').click(function(){
                var topleft= (new OpenLayers.LonLat(W.map.getExtent().left,W.map.getExtent().top));
                var bottomright= (new OpenLayers.LonLat(W.map.getExtent().right,W.map.getExtent().bottom));

                let source = new proj4.Proj('EPSG:900913');
                var topleft4686 = new proj4.toPoint([parseFloat(topleft.lon), parseFloat(topleft.lat)]);
                var bottomright4686 = new proj4.toPoint([parseFloat(bottomright.lon), parseFloat(bottomright.lat)]);
                topleft4686 = proj4.transform(source, proj4.WGS84, topleft4686);
                bottomright4686 = proj4.transform(source, proj4.WGS84, bottomright4686);

                let latlon = W.map.getCenter().transform(W.Config.map.projection.remote, W.Config.map.projection.local);
                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(' '));

            $(insertPath).prepend($section.html());

            $('#OOMZoomEarthImg').click(function(){
                let latlon = get4326CenterPoint();
                let lang = GetLanguage();
                window.open(`https://zoom.earth/#${latlon.lat},${latlon.lon},${( W.map.getZoom() + 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(' '));

            $(insertPath).prepend($section.html());

            $('#OOMRoadworksImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://roadworks.org/?lng=${latlon.lon}&lat=${latlon.lat}&zoom=${( W.map.getZoom() + 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(' '));

            $(insertPath).prepend($sectionWI511.html());

            $('#OOMWI511Img').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://511wi.gov/?Latitude=${latlon.lat}&Longitude=${latlon.lon}&Zoom=${(W.map.getZoom() + 12)}&SelectedLayers=WeatherAlerts,Closures#: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(' '));

            $(insertPath).prepend($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.getZoom() + 12)}&ls=incident,construction,camera`);
            });
        }

        $('#OOMArkDOT').remove();
        if(settings.ArkDOT){
            let $sectionArkDOT = $("<div>", {style:"padding:8px 16px"});
            $sectionArkDOT.html([
                '<span id="OOMArkDOT">',
                `<img src="${ArkDOTIcon}" alt="IDrive Arkansas" width="18" height="18" id="OOMArkDOTImg" title="Open in IDrive Arkansas" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionArkDOT.html());

            $('#OOMArkDOTImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://www.idrivearkansas.com/?lat=${latlon.lat}&lon=${latlon.lon}&zoom=${(W.map.getZoom() + 12)}`);
            });
        }

        $('#OOMDelDOT').remove();
        if(settings.DelDOT)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMDelDOT">',
                `<img src="${DelDOTIcon}" alt="DelDOT" width="18" height="18" id="OOMDelDOTImg" title="Open in DelDOT Interactive Map" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMDelDOTImg').click(function(){
                let latlon = get4326CenterPoint();

                window.open(`http://www.deldot.gov/map/index.shtml?lat=${latlon.lat}&lon=${latlon.lon}&zoom=${(W.map.getZoom() + 12)}`, 'DelDOT Interactive Maps');
            });
        }

        $('#OOMBagViewer').remove();
        if(settings.BagViewer){
            let $sectionBagViewer = $("<div>", {style:"padding:8px 16px"});
            $sectionBagViewer.html([
                '<span id="OOMBagViewer">',
                `<img src="${BagViewerIcon}" alt="IDrive Arkansas" width="18" height="18" id="OOMBagViewerImg" title="Open in Kadaster BAG Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionBagViewer.html());

            $('#OOMBagViewerImg').click(function(){
                let e=W.map.getCenter();
                let centerPoint = new OpenLayers.Geometry.Point(e.lon,e.lat);

                proj4.defs("EPSG:28992", "+proj=sterea +lat_0=52.15616055555555 +lon_0=5.38763888888889 +k=0.9999079 +x_0=155000 +y_0=463000 +ellps=bessel +units=m +no_defs");
                let source = new proj4.Proj('EPSG:900913');
                let dest = new proj4.Proj('EPSG:28992');

                centerPoint = new proj4.toPoint([centerPoint.x,centerPoint.y]);

                centerPoint = proj4.transform(source, dest, centerPoint);
                let z;
                switch(W.map.getZoom()){
                    case 0,1:
                        z=2;
                        break;
                    case 2,3:
                        z=3;
                        break;
                    case 4:
                        z=4;
                        break;
                    case 5:
                        z=5;
                        break;
                    case 6:
                        z=6;
                        break;
                    default:
                        z=7;
                        break;
                }
                window.open(`https://bagviewer.kadaster.nl/lvbag/bag-viewer/index.html#?geometry.x=${centerPoint.x}&geometry.y=${centerPoint.y}&zoomlevel=${z}`);
            });
        }

        $('#OOMMelvin').remove();
        if(settings.Melvin)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMMelvin">',
                `<img src="${MelvinIcon}" alt="DelDOT" width="18" height="18" id="OOMMelvinImg" title="Open in Melvin" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMMelvinImg').click(function(){
                let extent = W.map.getExtent();

                let sw = WazeWrap.Geometry.ConvertTo4326(extent.left, extent.bottom);
                let ne = WazeWrap.Geometry.ConvertTo4326(extent.right, extent.top);
                window.open(`https://melvin.ndw.nu/public;sw=${sw.lat},${sw.lon};ne=${ne.lat},${ne.lon}`, 'Melvin');
            });
        }

        $('#OOMNaviExpert').remove();
        if(settings.NaviExpert)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMNaviExpert">',
                `<img src="${NaviExpertIcon}" alt="DelDOT" width="18" height="18" id="OOMNaviExpertImg" title="Open in NaviExpert" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMNaviExpertImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://traffic.naviexpert.pl/?cp=${latlon.lat},${latlon.lon},${(W.map.getZoom() + 12)}`, `NaviExpert`);
            });
        }

        $('#OOMTranstar').remove();
        if(settings.Transtar){
            let $sectionTranstar = $("<div>", {style:"padding:8px 16px"});
            $sectionTranstar.html([
                '<span id="OOMTranstar">',
                `<img src="${TranstarIcon}" alt="Transtar" width="18" height="18" id="OOMTranstarImg" title="Open in Transtar" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionTranstar.html());

            $('#OOMTranstarImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`http://traffic.houstontranstar.org/layers/layers_ve.aspx?x=${latlon.lat}&y=${latlon.lon}&z=${(W.map.getZoom() + 12)}`);
            });
        }
        $('#OOMMaineDOT').remove();
        if(settings.MaineDOT){
            let $sectionMaineDOT = $("<div>", {style:"padding:8px 16px"});
            $sectionMaineDOT.html([
                '<span id="OOMMaineDOT">',
                `<img src="${MaineDOTIcon}" alt="MaineDOT" width="18" height="18" id="OOMMaineDOTImg" title="Open in MaineDOT Public Map Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionMaineDOT.html());

            $('#OOMMaineDOTImg').click(function(){
                let latlon = get4326CenterPoint();
                let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
                let zoom = W.map.getZoom().toString();
                let scale = zoomtable[zoom];
                window.open(`https://www.maine.gov/mdot/mapviewer/?show=Conserved/Lands%2CContours%2CInterstate/Interchanges%2CRoads/General%2CState/Urban%2CTown/and/County/Boundaries%2CWater/Bodies%2CWetlands&hide=Contours/-/2/foot%2CFederal/Urban%2CMEDOT/Regions%2CMetropolitan/Planning/Areas/2015&added=Bridges/-/All%2CCulverts/-/Large%2CMajor/Signs%2CNodes%2CTraffic/Signals%2CAirports%2CFerry/Routes%2CRailroads%2CBuildings%2CLots%2CMost/Recent/Highway/Treatment%2CFederal/Functional/Class%2CHighway/Corridor/Priority%2CJurisdiction%2CNational/Highway/System%2CNAIP/2015&transparency=100&center=${latlon.lat}%2C${latlon.lon}&z=`+scale);
            });
        }
        $('#OOMDriveTexas').remove();
        if(settings.DriveTexas){
            let $sectionDriveTexas = $("<div>", {style:"padding:8px 16px"});
            $sectionDriveTexas.html([
                '<span id="OOMDriveTexas">',
                `<img src="${DriveTexasIcon}" alt="DriveTexas" width="18" height="18" id="OOMDriveTexasImg" title="Open in drivetexas.org" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionDriveTexas.html());

            $('#OOMDriveTexasImg').click(function(){
                let latlon = get4326CenterPoint();
                window.open(`https://drivetexas.org/#/${(W.map.getZoom() + 8)}/${latlon.lat}/${latlon.lon}?future=false`);
            });
        };

        $('#OOMRedVial').remove();
        if(settings.RedVial)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMRedVial">',
                `<img src="${RedVialIcon}" alt=""Red Vial Nacional (Chile)" width="18" height="18" id="OOMRedVialImg" title="Open in Red Vial Nacional (Chile)" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMRedVialImg').click(function(){
                var center = get4326CenterPoint();
                //https://sitministerial.maps.arcgis.com/apps/webappviewer/index.html?id=ccc8ce73d80d4b48a4cbce97ff89d74c&center=-72.86780,-40.07118&level=12

                window.open(`https://sitministerial.maps.arcgis.com/apps/webappviewer/index.html?id=ccc8ce73d80d4b48a4cbce97ff89d74c&center=${center.lon},${center.lat}&level=${W.map.getZoom() + 8}`, 'RedVial');
            });
        }

        $('#OOMMapyCZ').remove();
        if(settings.MapyCZ)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMMapyCZ">',
                `<img src="${MapyCZIcon}" alt="MapyCZ" width="18" height="18" id="OOMMapyCZImg" title="Open in Mapy.CZ" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMMapyCZImg').click(function(){
                let latlon = get4326CenterPoint();
                let lang = GetLanguage();

                window.open(`https://en.mapy.cz/zakladni?x=${latlon.lon}&y=${latlon.lat}&z=${W.map.getZoom() + 12}`, 'Mapy.CZ');
            });
        }

        $('#OOMHamON').remove();
        if(settings.HamON){
            let $sectionHamON = $("<div>", {style:"padding:8px 16px"});
            $sectionHamON.html([
                '<span id="OOMHamON">',
                `<img src="${HamONIcon}" alt="HamON" width="18" height="18" id="OOMHamONImg" title="Open in Hamilton Public Map Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionHamON.html());

            $('#OOMHamONImg').click(function(){
                let latlon = get4326CenterPoint();
                let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
                let zoom = W.map.getZoom().toString();
                let scale = zoomtable[zoom];
                window.open(`https://spatialsolutions.hamilton.ca/hamiltonmap/index.html?center=${latlon.lon},${latlon.lat}&scale=${scale}`);
            });
        }

        $('#OOMNiagON').remove();
        if(settings.NiagON){
            let $sectionNiagON = $("<div>", {style:"padding:8px 16px"});
            $sectionNiagON.html([
                '<span id="OOMNiagON">',
                `<img src="${NiagONIcon}" alt="NiagON" width="18" height="18" id="OOMNiagONImg" title="Open in Niagara Public Map Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionNiagON.html());

            $('#OOMNiagONImg').click(function(){
                let latlon = get4326CenterPoint();
                let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
                let zoom = W.map.getZoom().toString();
                let scale = zoomtable[zoom];
                window.open(`https://maps.niagararegion.ca/Navigator/?center=${latlon.lon},${latlon.lat},4326&scale=${scale}`);
            });
        }

        $('#OOMMissON').remove();
        if(settings.MissON){
            let $sectionMissON = $("<div>", {style:"padding:8px 16px"});
            $sectionMissON.html([
                '<span id="OOMMissON">',
                `<img src="${MissONIcon}" alt="MissON" width="18" height="18" id="OOMMissONImg" title="Open in Mississauga Public Map Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($sectionMissON.html());

            $('#OOMMissONImg').click(function(){
                window.open(`http://www6.mississauga.ca/missmaps/maps.aspx#map=${(W.map.getZoom() + 12)}/${W.map.getCenter().lon}/${W.map.getCenter().lat}/0`);

            });
        }

        //         $('#OOMTorON').remove();
        //                 let latlon = get4326CenterPoint();
        //                 let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
        //                 let zoom = W.map.getZoom().toString();
        //                 let scale = zoomtable[zoom];
        //         if(settings.TorON){
        //             let $sectionTorON = $("<div>", {style:"padding:8px 16px"});
        //             $sectionTorON.html([
        //                 '<span id="OOMTorON">',
        //                 `<img src="${TorONIcon}" alt="TorON" width="18" height="18" id="OOMTorONImg" title="Open in Toronto Public Map Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
        //                 '</span>'
        //             ].join(' '));

        //             $(insertPath).prepend($sectionTorON.html());

        //             $('#OOMTorONImg').click(function(){
        //                 window.open(`https://gis.toronto.ca/arcgis/rest/services/Utilities/Geometry/GeometryServer/project?f=json&outSR=3857&inSR=4326&geometries=%7B%22geometryType%22%3A%22esriGeometryPoint%22%2C%22geometries%22%3A%5B%7B%22x%22%3A${latlon.lon}%2C%22y%22%3A${latlon.lat}%2C%22spatialReference%22%3A%7B%22wkid%22%3A4326%7D%7D%5D%7D`);

        //             });
        //         }

        //         $('#OOMBurlON').remove();
        //         if(settings.BurlON)
        //         {
        //             let $section = $("<div>", {style:"padding:8px 16px"});
        //                 let e=W.map.getExtent();
        //                 let geoNW=new OpenLayers.Geometry.Point(e.left,e.top);
        //                 let geoSE=new OpenLayers.Geometry.Point(e.right,e.bottom);
        //             $section.html([
        //                 '<span id="OOMBurlON">',
        //                 `<img src="${BurlONIcon}" alt=""Burlington ON" width="18" height="18" id="OOMBurlONImg" title="Open in Burlington, ON" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
        //                 '</span>'
        //             ].join(' '));

        //             $(insertPath).prepend($section.html());
        //             $('#OOMBurlONImg').click(function(){
        //                 window.open(`https://www.arcgis.com/apps/webappviewer/index.html?appid=4ee645f32ecd412a9a756a318b390b82&extent=${geoNW.x},${geoNW.y},${geoSE.x},${geoSE.y},102100`, 'BurlON');
        //             });
        //         }

        //         $('#OOMMiltON').remove();
        //         if(settings.MiltON)
        //         {
        //             let $section = $("<div>", {style:"padding:8px 16px"});
        //                 let e=W.map.getExtent();
        //                 let geoNW=new OpenLayers.Geometry.Point(e.left,e.top);
        //                 let geoSE=new OpenLayers.Geometry.Point(e.right,e.bottom);
        //             $section.html([
        //                 '<span id="OOMMiltON">',
        //                 `<img src="${MiltONIcon}" alt=""Milton ON" width="18" height="18" id="OOMMiltONImg" title="Open in Milton Ontario Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
        //                 '</span>'
        //             ].join(' '));

        //             $(insertPath).prepend($section.html());
        //             $('#OOMMiltONImg').click(function(){
        //                 window.open(`http://maps.milton.ca/MGIS//UrlHandler.ashx?MINX=${geoNW.x}&MINY=${geoNW.y}&MAXX=${geoSE.x}&${geoSE.y}&SIZE=2087,1101&LABEL=%7c-8893397.4%7c5389213.86%7c103972%7c0%2c0%2c0%7c10%7cTRIANGLE%7c128%2c0%2c64%7c8%7c%7c&LAYERS_TO_SHOW=336737867,488968977,257339439,257339517,336737802`, 'MiltON');
        //             });
        //         }
        $('#OOMBramON').remove();
        if(settings.BramON)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMBramON">',
                `<img src="${BramONIcon}" alt=""Brampton, ON Roadworks" width="18" height="18" id="OOMBramONImg" title="Open in Brampton Roadworks" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMBramONImg').click(function(){
                let latlon = get4326CenterPoint();
                let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
                let zoom = W.map.getZoom().toString();
                let scale = zoomtable[zoom];

                window.open(`https://www.arcgis.com/apps/webappviewer/index.html?id=371691bf51754ca2bb146a395b6b55aa&center=${latlon.lon},${latlon.lat}&level=${W.map.getZoom() + 12}`, 'Brampton');
            });
        }

        $('#OOMHaltRLC').remove();
        if(settings.HaltRLC)
        {
            let $section = $("<div>", {style:"padding:8px 16px"});
            $section.html([
                '<span id="OOMHaltRLC">',
                `<img src="${HaltRLCIcon}" alt=""Halton,ON Red Light Cameras" width="18" height="18" id="OOMHaltRLCImg" title="Open in Halton Red Light Camera Viewer" style="cursor:pointer; float: left; display:inline-block; margin: 2px 5px 0 3px;">`,
                '</span>'
            ].join(' '));

            $(insertPath).prepend($section.html());

            $('#OOMHaltRLCImg').click(function(){
                let latlon = get4326CenterPoint();
                let zoomtable = [225000,115000,57000,28000,14000,7000,2000,1000,500,250,100];
                let zoom = W.map.getZoom().toString();
                let scale = zoomtable[zoom];

                window.open(`https://www.google.com/maps/d/u/0/viewer?mid=1Rdn5m1RzAyU8n0HCNntID1z8etfz7qxV&ll=${latlon.lat},${latlon.lon}&z=${W.map.getZoom() + 12}`, 'Halton RLC');
            });
        }

    }

        function loadSettings() {
            var loadedSettings = $.parseJSON(localStorage.getItem("OOM_Settings"));
            var defaultSettings = {
                GMaps: true,
                Mapillary: false,
                Wikimapia: false,
                Bing: false,
                OSM: false,
                LangSetting: 1,
                CustLang: "",
                Yandex: false,
                Here: false,
                MiDrive: false,
                NYFC: false,
                NYSL: false,
                NYGIS: false,
                NYCMaps: false,
                NY511: false,
                Nexar: false,
                rosreestr: false,
                PA511: false,
                LA511: false,
                Miss511: false,
                LAFC: false,
                NM511: false,
                WVFlood: false,
                GMDM: false,
                PennDOT: false,
                Bogota: false,
                ZoomEarth: false,
                Roadworks: false,
                WI511: false,
                OHGO: false,
                ArkDOT: false,
                DelDOT: false,
                BagViewer: false,
                Melvin: false,
                NaviExpert: false,
                Transtar: false,
                MaineDOT: false,
                DriveTexas: false,
                RedVial: false,
                MapyCZ: false,
                //NJ511: false
                //BurlON: false,
                NiagON: false,
                MissON: false,
                //TorON: false,
                HamON: false,
                //MiltON: false
                BramON: false,
                HaltRLC: false,
                WV511: 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,
                    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,
                    NYGIS: settings.NYGIS,
                    NYCMaps: settings.NYCMaps,
                    NYSL: settings.NYSL,
                    NY511: settings.NY511,
                    LA511: settings.LA511,
                    Nexar: settings.Nexar,
                    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,
                    ArkDOT: settings.ArkDOT,
                    DelDOT: settings.DelDOT,
                    BagViewer: settings.BagViewer,
                    Melvin: settings.Melvin,
                    NaviExpert: settings.NaviExpert,
                    Transtar: settings.Transtar,
                    MaineDOT: settings.MaineDOT,
                    DriveTexas: settings.DriveTexas,
                    RedVial: settings.RedVial,
                    MapyCZ: settings.MapyCZ,
                    //NJ511: settings.NJ511
                    //BurlON: settings.BurlON,
                    //TorON: settings.TorON,
                    //MiltON: settings.MiltON,
                    NiagON: settings.NiagON,
                    HamON: settings.HamON,
                    MissON: settings.MissON,
                    BramON: settings.BramON,
                    HaltRLC: settings.HaltRLC,
                    WV511: settings.WV511
                };

                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("https://www.idrivearkansas.com") > -1)
                bootstrapGeneral(initArkDOT, 1);
            else if(location.href.indexOf("http://www.deldot.gov/map") > -1)
                bootstrapGeneral(initDelDOT, 1);
            else if(location.href.indexOf("http://bridgereports.com") > -1)
                bootstrapGeneral(initBridgeReports);
            else if(location.href.indexOf("http://www.trimarc.org") > -1)
                bootstrapGeneral(initTrimarc);
            else if(location.href.indexOf("drivetexas.org") > -1)
                bootstrapGeneral(initDriveTexas);
            /*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 proj4.Proj('EPSG:900913');

            var point = new proj4.toPoint([parseFloat(lon), parseFloat(lat)]);
            point = proj4.transform(source, proj4.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 isArkDOTLoaded = false;
        function initArkDOT(){
            map.addListener('tilesloaded', function() {
                //https://www.mdottraffic.com/default.aspx?lat=32.36435&lon=-88.70366&zoom=15
                if(!isArkDOTLoaded){
                    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]));
                    }
                    isArkDOTLoaded = true;
                }
            });

            let $OOMWazeButton = document.createElement("div");
            $OOMWazeButton.innerHTML = `<li><div class="layer_page lean_right layer_page_hidden"></div><span class="tab_container"><span class="tab"><div id="OOMWazeButtonDiv" style="height:36px; width:36px; cursor: pointer; position:absolute; top:7px; left:11px; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div></span></span></li>`;
            $('#default_tabs > ul').append($OOMWazeButton);

            $('#OOMWazeButtonDiv').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))))}`);
            });
        }

        let isDelDOTLoaded = false;
        function initDelDOT(){
            deldotMap.map.addListener('tilesloaded', function(){
                if(!isDelDOTLoaded){
                    if(location.search.indexOf("?") > -1){
                        let params = location.search.match(/lat=(-?\d*.\d*)&lon=(-?\d*.\d*)&zoom=(\d+)/);
                        deldotMap.map.setCenter({lat: parseFloat(params[1]), lng: parseFloat(params[2])});
                        deldotMap.map.setZoom(parseInt(params[3]));
                    }
                    isDelDOTLoaded = true;
                }
            });

            let $OOMWazeButton = document.createElement("div");
            $OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; cursor: pointer; position: fixed; right:80px; top:190px;  background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`;
            $('#map-canvas').after($OOMWazeButton);

            $('#OOMWazeButtonDiv').click(function(){
                let center = deldotMap.map.getCenter();
                window.open(`https://www.waze.com/en-US/editor/?lon=${center.lng()}&lat=${center.lat()}&zoom=${(Math.max(0,Math.min(10,(deldotMap.map.getZoom() - 12))))}`);
            });
        }

        function initBridgeReports(){
            if(document.getElementById("mapctrls")){
                let gmapsLink =  document.querySelectorAll("a[href^='http://maps.google.com']")[0].href;
                let params = gmapsLink.match(/\?ll=(-?\d*.\d*),(-?\d*.\d*)/);
                let lon = params[2];
                let lat = params[1];
                let wazeURL = `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${6}`;
                let $li = document.createElement("li");
                $li.innerHTML = `<a href="${wazeURL}" target="_blank">Waze WME</a>`
            document.querySelector("#mapctrls > ul").prepend($li);
        }
    }

        function initTrimarc(){
            let $OOMWazeButton = document.createElement("div");
            $OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; position: absolute; right:12px; top:95px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`;

            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 initDriveTexas(){
            let $OOMWazeButton = document.createElement("div");
            $OOMWazeButton.innerHTML = `<div id="OOMWazeButtonDiv" style="height:36px; width:36px; position: fixed; left:10px; top:240px; cursor: pointer; background-image: url(${wazerIcon}); background-size: 36px 36px; background-repeat: no-repeat;" title="Open in WME"></div>`;
            let parent = document.getElementById("app");
            parent.appendChild($OOMWazeButton);

            document.getElementById("OOMWazeButtonDiv").addEventListener("click", function(){
                window.open(DriveTxToWaze());
            });

        }

        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 proj4.Proj('EPSG:900913');
                let center = map.extent.getCenter();
                var point = new proj4.toPoint([parseFloat(center.x), parseFloat(center.y)]);
                point = proj4.transform(source, proj4.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 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]);
            if(zoom > 21)
                zoom = 17;
            return `https://www.waze.com/en-US/editor/?lon=${lon}&lat=${lat}&zoom=${(Math.max(0,Math.min(10,(zoom - 12))))}`;
        }

        function DriveTxToWaze() {
            let lon, lat, zoom;
            let curURL = location.href.split('#').pop().split('/');
            lat = curURL[2];
            lon = curURL[3].split('?')[0]
            zoom = parseInt(curURL[1]);

            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(){
                var point = new proj4.toPoint([parseFloat(view.center.x), parseFloat(view.center.y)]);
                let source = new proj4.Proj('EPSG:900913');
                point = proj4('EPSG:900913', 'EPSG:4326', 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 proj4.Proj('EPSG:900913');
                var point = new proj4.toPoint([parseFloat(Flood.map.extent.getCenter().x), parseFloat(Flood.map.extent.getCenter().y)]);
                point = proj4.transform(source, proj4.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(!OpenLayers.Format.MyMapKML){
                OpenLayers.Format.MyMapKML = OpenLayers.Class(OpenLayers.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(A){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,[A])},read:function(A){this.features=[],this.styles={},this.fetched={};var e={depth:0,styleBaseUrl:this.styleBaseUrl};return this.parseData(A,e)},parseData:function(A,e){"string"==typeof A&&(A=OpenLayers.Format.XML.prototype.read.apply(this,[A]));for(var t=["Link","NetworkLink","Style","StyleMap","Placemark"],a=0,i=t.length;a<i;++a){var s=t[a],n=this.getElementsByTagNameNS(A,"*",s);if(0!=n.length)switch(s.toLowerCase()){case"link":case"networklink":this.parseLinks(n,e);break;case"style":this.extractStyles&&this.parseStyles(n,e);break;case"stylemap":this.extractStyles&&this.parseStyleMaps(n,e);break;case"placemark":this.parseFeatures(n,e)}}return this.features},parseLinks:function(A,e){if(e.depth>=this.maxDepth)return!1;var t=OpenLayers.Util.extend({},e);t.depth++;for(var a=0,i=A.length;a<i;a++){var s=this.parseProperty(A[a],"*","href");if(s&&!this.fetched[s]){this.fetched[s]=!0;var n=this.fetchLink(s);n&&this.parseData(n,t)}}},fetchLink:function(A){var e=OpenLayers.Request.GET({url:A,async:!1});if(e)return e.responseText},parseStyles:function(A,e){for(var t=0,a=A.length;t<a;t++){var i=this.parseStyle(A[t]);if(i){var s=(e.styleBaseUrl||"")+"#"+i.id;this.styles[s]=i}}},parseKmlColor:function(A){var e=null;if(A){var t=A.match(this.regExes.kmlColor);t&&(e={color:"#"+t[4]+t[3]+t[2],opacity:parseInt(t[1],16)/255,r:parseInt(t[4],16),g:parseInt(t[3],16),b:parseInt(t[2],16)})}return e},parseStyle:function(A){for(var e,t,a={},i=["LineStyle","PolyStyle","IconStyle","BalloonStyle","LabelStyle"],s=0,n=i.length;s<n;++s)if(e=i[s],t=this.getElementsByTagNameNS(A,"*",e)[0]){var r=this.parseProperty(t,"*","color"),h=this.parseKmlColor(r);switch(e.toLowerCase()){case"linestyle":h&&(a.strokeColor=h.color,a.strokeOpacity=h.opacity),(g=this.parseProperty(t,"*","width"))&&(a.strokeWidth=g);break;case"polystyle":h&&(a.fillOpacity=h.opacity,a.fillColor=h.color),"0"==this.parseProperty(t,"*","fill")&&(a.fillColor="none"),"0"==this.parseProperty(t,"*","outline")&&(a.strokeWidth="0");break;case"iconstyle":var o=parseFloat(this.parseProperty(t,"*","scale")||1),g=32*o,l=32*o,E=this.getElementsByTagNameNS(t,"*","Icon")[0];if(E){var B=this.parseProperty(E,"*","href");if(B){var d=this.parseProperty(E,"*","w"),c=this.parseProperty(E,"*","h");!OpenLayers.String.startsWith(B,"http://maps.google.com/mapfiles/kml")||d||c||(d=64,c=64,o/=2),d=d||c,c=c||d,d&&(g=parseInt(d)*o),c&&(l=parseInt(c)*o);var Q=B.match(this.regExes.kmlIconPalette);if(Q){var C=Q[1],f=Q[2],N=this.parseProperty(E,"*","x"),R=this.parseProperty(E,"*","y");B="http://maps.google.com/mapfiles/kml/pal"+C+"/icon"+(8*(R?7-R/32:7)+(N?N/32:0))+f}a.graphicOpacity=1,a.externalGraphic=this.iconColorMap[h.color],a.graphicYOffset=-32}}a.graphicWidth=g,a.graphicHeight=l;break;case"balloonstyle":var v=OpenLayers.Util.getXmlNodeValue(t);v&&(a.balloonStyle=v.replace(this.regExes.straightBracket,"${$1}"));break;case"labelstyle":r=this.parseProperty(t,"*","color");(h=this.parseKmlColor(r))&&(a.fontColor=h.color,a.fontOpacity=h.opacity)}}!a.strokeColor&&a.fillColor&&(a.strokeColor=a.fillColor);var u=A.getAttribute("id");return u&&a&&(a.id=u),a},parseStyleMaps:function(A,e){for(var t=0,a=A.length;t<a;t++)for(var i=A[t],s=this.getElementsByTagNameNS(i,"*","Pair"),n=i.getAttribute("id"),r=0,h=s.length;r<h;r++){var o=s[r],g=this.parseProperty(o,"*","key"),l=this.parseProperty(o,"*","styleUrl");l&&"normal"==g&&(this.styles[(e.styleBaseUrl||"")+"#"+n]=this.styles[(e.styleBaseUrl||"")+l])}},parseFeatures:function(A,e){for(var t=[],a=0,i=A.length;a<i;a++){var s=A[a],n=this.parseFeature.apply(this,[s]);if(!n)throw"Bad Placemark: "+a;if(this.extractStyles&&n.attributes&&n.attributes.styleUrl&&(n.style=this.getStyle(n.attributes.styleUrl,e)),this.extractStyles){var r=this.getElementsByTagNameNS(s,"*","Style")[0];if(r){var h=this.parseStyle(r);h&&(n.style=OpenLayers.Util.extend(n.style,h))}}if(this.extractTracks){var o=this.getElementsByTagNameNS(s,this.namespaces.gx,"Track");if(o&&o.length>0){var g=o[0],l={features:[],feature:n};this.readNode(g,l),l.features.length>0&&t.push.apply(t,l.features)}}else t.push(n)}this.features=this.features.concat(t)},readers:{kml:{when:function(A,e){e.whens.push(OpenLayers.Date.parse(this.getChildValue(A)))},_trackPointAttribute:function(A,e){var t=A.nodeName.split(":").pop();e.attributes[t].push(this.getChildValue(A))}},gx:{Track:function(A,e){var t={whens:[],points:[],angles:[]};if(this.trackAttributes){t.attributes={};for(var a=0,i=this.trackAttributes.length;a<i;++a)l=this.trackAttributes[a],t.attributes[l]=[],l in this.readers.kml||(this.readers.kml[l]=this.readers.kml._trackPointAttribute)}if(this.readChildNodes(A,t),t.whens.length!==t.points.length)throw new Error("gx:Track with unequal number of when ("+t.whens.length+") and gx:coord ("+t.points.length+") elements.");var s,n,r,h=t.angles.length>0;if(h&&t.whens.length!==t.angles.length)throw new Error("gx:Track with unequal number of when ("+t.whens.length+") and gx:angles ("+t.angles.length+") elements.");for(a=0,i=t.whens.length;a<i;++a){if((s=e.feature.clone()).fid=e.feature.fid||e.feature.id,n=t.points[a],s.geometry=n,"z"in n&&(s.attributes.altitude=n.z),this.internalProjection&&this.externalProjection&&s.geometry.transform(this.externalProjection,this.internalProjection),this.trackAttributes)for(var o=0,g=this.trackAttributes.length;o<g;++o){var l=this.trackAttributes[o];s.attributes[l]=t.attributes[l][a]}s.attributes.when=t.whens[a],s.attributes.trackId=e.feature.id,h&&(r=t.angles[a],s.attributes.heading=parseFloat(r[0]),s.attributes.tilt=parseFloat(r[1]),s.attributes.roll=parseFloat(r[2])),e.features.push(s)}},coord:function(A,e){var t=this.getChildValue(A).replace(this.regExes.trimSpace,"").split(/\s+/),a=new OpenLayers.Geometry.Point(t[0],t[1]);t.length>2&&(a.z=parseFloat(t[2])),e.points.push(a)},angles:function(A,e){var t=this.getChildValue(A).replace(this.regExes.trimSpace,"").split(/\s+/);e.angles.push(t)}}},parseFeature:function(A){for(var e,t,a,i,s=["MultiGeometry","Polygon","LineString","Point"],n=0,r=s.length;n<r;++n)if(e=s[n],this.internalns=A.namespaceURI?A.namespaceURI:this.kmlns,(t=this.getElementsByTagNameNS(A,this.internalns,e)).length>0){var h;if(!(h=this.parseGeometry[e.toLowerCase()]))throw new TypeError("Unsupported geometry type: "+e);a=h.apply(this,[t[0]]),this.internalProjection&&this.externalProjection&&a.transform(this.externalProjection,this.internalProjection);break}this.extractAttributes&&(i=this.parseAttributes(A));var o=new OpenLayers.Feature.Vector(a,i),g=A.getAttribute("id")||A.getAttribute("name");return null!=g&&(o.fid=g),o},getStyle:function(A,e){var t=OpenLayers.Util.removeTail(A),a=OpenLayers.Util.extend({},e);if(a.depth++,a.styleBaseUrl=t,!this.styles[A]&&!OpenLayers.String.startsWith(A,"#")&&a.depth<=this.maxDepth&&!this.fetched[t]){var i=this.fetchLink(t);i&&this.parseData(i,a)}return OpenLayers.Util.extend({},this.styles[A])},parseGeometry:{point:function(A){var e=this.getElementsByTagNameNS(A,this.internalns,"coordinates"),t=[];if(e.length>0){var a=e[0].firstChild.nodeValue;t=(a=a.replace(this.regExes.removeSpace,"")).split(",")}if(!(t.length>1))throw"Bad coordinate string: "+a;return 2==t.length&&(t[2]=null),new OpenLayers.Geometry.Point(t[0],t[1],t[2])},linestring:function(A,e){var t=this.getElementsByTagNameNS(A,this.internalns,"coordinates"),a=null;if(t.length>0){for(var i,s=this.getChildValue(t[0]),n=(s=(s=s.replace(this.regExes.trimSpace,"")).replace(this.regExes.trimComma,",")).split(this.regExes.splitSpace),r=n.length,h=new Array(r),o=0;o<r;++o){if(!((i=n[o].split(",")).length>1))throw"Bad LineString point coordinates: "+n[o];2==i.length&&(i[2]=null),h[o]=new OpenLayers.Geometry.Point(i[0],i[1],i[2])}if(!r)throw"Bad LineString coordinates: "+s;a=e?new OpenLayers.Geometry.LinearRing(h):new OpenLayers.Geometry.LineString(h)}return a},polygon:function(A){var e=this.getElementsByTagNameNS(A,this.internalns,"LinearRing"),t=e.length,a=new Array(t);if(t>0)for(var i,s=0,n=e.length;s<n;++s){if(!(i=this.parseGeometry.linestring.apply(this,[e[s],!0])))throw"Bad LinearRing geometry: "+s;a[s]=i}return new OpenLayers.Geometry.Polygon(a)},multigeometry:function(A){for(var e,t=[],a=A.childNodes,i=0,s=a.length;i<s;++i)if(1==(e=a[i]).nodeType){var n,r=e.prefix?e.nodeName.split(":")[1]:e.nodeName;(n=this.parseGeometry[r.toLowerCase()])&&t.push(n.apply(this,[e]))}return new OpenLayers.Geometry.Collection(t)}},parseAttributes:function(A){var e,t,a={},i=A.getElementsByTagName("ExtendedData");i.length&&(a=this.parseExtendedData(i[0]));for(var s=A.childNodes,n=0,r=s.length;n<r;++n)if(1==(e=s[n]).nodeType&&(t=e.childNodes).length>=1&&t.length<=3){var h;switch(t.length){case 1:h=t[0];break;case 2:var o=t[0],g=t[1];h=3==o.nodeType||4==o.nodeType?o:g;break;case 3:default:h=t[1]}if(3==h.nodeType||4==h.nodeType){var l=e.prefix?e.nodeName.split(":")[1]:e.nodeName,E=OpenLayers.Util.getXmlNodeValue(h);E&&(E=E.replace(this.regExes.trimSpace,""),a[l]=E)}}return a},parseExtendedData:function(A){var e,t,a,i,s={},n=A.getElementsByTagName("Data");for(e=0,t=n.length;e<t;e++){i=(a=n[e]).getAttribute("name");var r={},h=a.getElementsByTagName("value");if(h.length&&(r.value=this.getChildValue(h[0])),this.kvpAttributes)s[i]=r.value;else{var o=a.getElementsByTagName("displayName");o.length&&(r.displayName=this.getChildValue(o[0])),s[i]=r}}var g=A.getElementsByTagName("SimpleData");for(e=0,t=g.length;e<t;e++){r={};i=(a=g[e]).getAttribute("name"),r.value=this.getChildValue(a),this.kvpAttributes?s[i]=r.value:(r.displayName=i,s[i]=r)}return s},parseProperty:function(A,e,t){var a,i=this.getElementsByTagNameNS(A,e,t);try{a=OpenLayers.Util.getXmlNodeValue(i[0])}catch(A){a=null}return a},write:function(A){OpenLayers.Util.isArray(A)||(A=[A]);for(var e=this.createElementNS(this.kmlns,"kml"),t=this.createFolderXML(),a=0,i=A.length;a<i;++a)t.appendChild(this.createPlacemarkXML(A[a]));return e.appendChild(t),OpenLayers.Format.XML.prototype.write.apply(this,[e])},createFolderXML:function(){var A=this.createElementNS(this.kmlns,"Folder");if(this.foldersName){var e=this.createElementNS(this.kmlns,"name"),t=this.createTextNode(this.foldersName);e.appendChild(t),A.appendChild(e)}if(this.foldersDesc){var a=this.createElementNS(this.kmlns,"description"),i=this.createTextNode(this.foldersDesc);a.appendChild(i),A.appendChild(a)}return A},createPlacemarkXML:function(A){var e=this.createElementNS(this.kmlns,"name"),t=A.style&&A.style.label?A.style.label:A.id,a=A.attributes.name||t;e.appendChild(this.createTextNode(a));var i=this.createElementNS(this.kmlns,"description"),s=A.attributes.description||this.placemarksDesc;i.appendChild(this.createTextNode(s));var n=this.createElementNS(this.kmlns,"Placemark");null!=A.fid&&n.setAttribute("id",A.fid),n.appendChild(e),n.appendChild(i);var r=this.buildGeometryNode(A.geometry);if(n.appendChild(r),A.attributes){var h=this.buildExtendedData(A.attributes);h&&n.appendChild(h)}return n},buildGeometryNode:function(A){var e=A.CLASS_NAME,t=e.substring(e.lastIndexOf(".")+1),a=this.buildGeometry[t.toLowerCase()],i=null;return a&&(i=a.apply(this,[A])),i},buildGeometry:{point:function(A){var e=this.createElementNS(this.kmlns,"Point");return e.appendChild(this.buildCoordinatesNode(A)),e},multipoint:function(A){return this.buildGeometry.collection.apply(this,[A])},linestring:function(A){var e=this.createElementNS(this.kmlns,"LineString");return e.appendChild(this.buildCoordinatesNode(A)),e},multilinestring:function(A){return this.buildGeometry.collection.apply(this,[A])},linearring:function(A){var e=this.createElementNS(this.kmlns,"LinearRing");return e.appendChild(this.buildCoordinatesNode(A)),e},polygon:function(A){for(var e,t,a,i=this.createElementNS(this.kmlns,"Polygon"),s=A.components,n=0,r=s.length;n<r;++n)a=0==n?"outerBoundaryIs":"innerBoundaryIs",e=this.createElementNS(this.kmlns,a),t=this.buildGeometry.linearring.apply(this,[s[n]]),e.appendChild(t),i.appendChild(e);return i},multipolygon:function(A){return this.buildGeometry.collection.apply(this,[A])},collection:function(A){for(var e,t=this.createElementNS(this.kmlns,"MultiGeometry"),a=0,i=A.components.length;a<i;++a)(e=this.buildGeometryNode.apply(this,[A.components[a]]))&&t.appendChild(e);return t}},buildCoordinatesNode:function(A){var e,t=this.createElementNS(this.kmlns,"coordinates"),a=A.components;if(a){for(var i,s=a.length,n=new Array(s),r=0;r<s;++r)i=a[r],n[r]=this.buildCoordinates(i);e=n.join(" ")}else e=this.buildCoordinates(A);var h=this.createTextNode(e);return t.appendChild(h),t},buildCoordinates:function(A){return this.internalProjection&&this.externalProjection&&(A=A.clone()).transform(this.internalProjection,this.externalProjection),A.x+","+A.y},buildExtendedData:function(A){var e=this.createElementNS(this.kmlns,"ExtendedData");for(var t in A)if(A[t]&&"name"!=t&&"description"!=t&&"styleUrl"!=t){var a=this.createElementNS(this.kmlns,"Data");a.setAttribute("name",t);var i=this.createElementNS(this.kmlns,"value");if("object"==typeof A[t]){if(A[t].value&&i.appendChild(this.createTextNode(A[t].value)),A[t].displayName){var s=this.createElementNS(this.kmlns,"displayName");s.appendChild(this.getXMLDoc().createCDATASection(A[t].displayName)),a.appendChild(s)}}else i.appendChild(this.createTextNode(A[t]));a.appendChild(i),e.appendChild(a)}return this.isSimpleContent(e)?null:e},changeImageColor:function(A,e,t,a){function i(A,e,t){A/=255,e/=255,t/=255;let a,i,s=Math.max(A,e,t),n=Math.min(A,e,t),r=(s+n)/2;if(s==n)a=i=0;else{let h=s-n;switch(i=r>.5?h/(2-s-n):h/(s+n),s){case A:a=(e-t)/h+(e<t?6:0);break;case e:a=(t-A)/h+2;break;case t:a=(A-e)/h+4}a/=6}return{h:a,s:i,l:r}}let s=document.createElement("canvas").getContext("2d");s.drawImage(A,0,0);let n=s.getImageData(0,0,32,32),r=n.data;for(var h=0;h<r.length;h+=4){let A=r[h+0],s=r[h+1],n=r[h+2];r[h+3]<10||360*i(A,s,n).h<20&&(r[h+0]=e,r[h+1]=t,r[h+2]=a)}let o=document.createElement("canvas");return $(o).attr("width",32),$(o).attr("height",32),o.getContext("2d").putImageData(n,0,0),o.toDataURL()},CLASS_NAME:"OpenLayers.Format.KML"});
            }
        }


        bootstrap();
    })();