WME Simplex

Shows simplex icon in WME bottom right corner. When clicked, opens Simplex Maps on the same WME location.

// ==UserScript==
// @name         WME Simplex
// @description  Shows simplex icon in WME bottom right corner. When clicked, opens Simplex Maps on the same WME location.
// @namespace    https://greasyfork.org/users/gad_m/wme_simplex
// @version      0.1.17
// @author       gad_m
// @include 	 /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor.*$/
// @exclude      https://www.waze.com/user/*editor/*
// @exclude      https://www.waze.com/*/user/*editor/*
// @icon         
// @grant        GM_xmlhttpRequest
// @connect      raw.githubusercontent.com
// ==/UserScript==

/* global W */
/* global jQuery */
/* global OpenLayers */
/* global WazeWrap */

(function() {

    initCitiesJson();
    
    if (typeof W !== 'undefined' && W['userscripts'] && W['userscripts']['state'] && W['userscripts']['state']['isReady']) {
        console.debug('wme-simplex: WME is ready.');
        init();
    } else {
        console.debug('wme-simplex: WME is not ready. adding event listener.');
        document.addEventListener("wme-ready", init, {
            once: true,
        });
    }

    function initCitiesJson() {
        console.debug('wme-simplex: initCitiesJson()...');
        let fileURL = "https://raw.githubusercontent.com/melameg/public-resources/master/wme-simplex/cities.json";
        GM_xmlhttpRequest({
            method: "GET",
            url: fileURL,
            responseType: "json",
            onload: function (response) {
                if (response && response.status === 200) {
                    let citiesJson = response.response;
                    //console.debug('wme-simplex: initCitiesJson() citiesJson:\n' + JSON.stringify(citiesJson, null, 4));
                    window.citiesJson = citiesJson;
                    console.debug('wme-simplex: initCitiesJson() done. Number of supported cities: ' + Object.keys(citiesJson).length);
                } else {
                    console.error('wme-simplex: initCitiesJson() failed. response status: ' + response.status + " response text:\n" + response.responseText);
                }
            }
        });
    }

    function convertZoom(editorZoom) {
        let result;
        switch (editorZoom) {
            case 0:
            case 1:
            case 2:
            case 3:
                result = 4000;
                break;
            case 4:
                result = 3000;
                break;
            case 5:
                result = 1500;
                break;
            case 6:
                result = 500;
                break;
            case 7:
                result = 400;
                break;
            case 8:
            case 9:
            case 10:
                result = 300;
                break;
        }
        console.log('wme-simplex: convertZoom() converting: ' + editorZoom + ' returning: ' + result);
        return result;
    }

    function init() {
        console.log('wme-simplex: init()');
        let controlPermalink = jQuery('.WazeControlPermalink');
        let simplexLink = document.createElement('a');
        simplexLink.id = 'wme-simplex-a';
        simplexLink.title = "\u05e1\u05d9\u05de\u05e4\u05dc\u05e7\u05e1";
        simplexLink.style.display = "inline-block";
        simplexLink.style.marginRight = "2px";
        simplexLink.href = 'https://simplex-smart3d.com';
        simplexLink.target = '_blank';
        let simplexDiv = document.createElement('div');
        simplexDiv.class = 'icon';
        simplexDiv.style.width = "20px";
        simplexDiv.style.height = "20px";
        simplexDiv.style.backgroundImage = "url(https://static.wixstatic.com/ficons/73f1e3_99de9ff506204a51a87bac47171e2df2_fi.ico)";
        simplexDiv.style.backgroundSize = "20px 20px";
        simplexLink.appendChild(simplexDiv);
        controlPermalink.append(simplexLink);
        jQuery('#wme-simplex-a').click(function () {
            console.log('wme-simplex: click() map center: ' + JSON.stringify(W.map.getCenter()));
            let centerLonLat = new OpenLayers.LonLat(W.map.getCenter().lon,W.map.getCenter().lat);
            centerLonLat.transform(new OpenLayers.Projection(W['Config'].map['projection']['local']), new OpenLayers.Projection(W['Config'].map['projection'].remote));
            console.log('wme-simplex: click() centerLonLat: ' + centerLonLat);
            let height = convertZoom(parseInt(W.map.getZoom()) - 12);
            let cityObj = window.citiesJson?window.citiesJson[W.model.getTopCityId()]:null;
            let href;
            if (cityObj) {
                href = 'https://simplex-smart3d.com/ces/' + cityObj.appName + '/App/?pos=' + centerLonLat.lon.toFixed(5) + ',' + centerLonLat.lat.toFixed(5) + ',' + (height + cityObj.height) + '&ori=0,-40,0';
            } else {
                href = 'https://simplex-smart3d.com/ces/net/app-models/?pos=' + centerLonLat.lon.toFixed(5) + ',' + centerLonLat.lat.toFixed(5) + ',' + height + '&ori=0,-40,0';
            }
            console.log('wme-simplex: click() returning: ' + href);
            this.href = href;
        });
        console.log('wme-simplex: init() done!');
    } // end init()
}.call(this));