WME Zoom Level

Places a numeric zoom level indicator on top of the WME zoom slider.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==UserScript==
// @name            WME Zoom Level
// @namespace       https://greasyfork.org/users/11629-TheLastTaterTot
// @version         0.2.4
// @description     Places a numeric zoom level indicator on top of the WME zoom slider.
// @author          TheLastTaterTot
// @include         https://editor-beta.waze.com/*editor/*
// @include         https://www.waze.com/*editor/*
// @exclude         https://www.waze.com/*user/editor/*
// @grant           none
// @icon            
// @run-at          document-body
// ==/UserScript==
/* jshint -W097 */
'use strict';
var updateZoom = function () {
    document.getElementById("zoomIndicator").innerHTML = Waze.map.zoom;
};

var ZoomLevelIndicator = function () {
    var zoomSlider = document.getElementsByClassName("slider")[0],
        insertZoom = document.createElement('span');

    insertZoom.style.position = "relative";
    insertZoom.style.top = "-5px";
    insertZoom.style.width = "100%";
    insertZoom.style.display = "inline-block";
    insertZoom.style.alignContent = "center";
    insertZoom.style.verticalAlign = "middle";
    insertZoom.style.lineHeight = "14px";
    insertZoom.innerHTML =
        '<div id="zoomIndicator" style="position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); ' +
        'background: rgba(0,0,0,.5); border-radius: 100%; border: 2px solid #FFF; box-shadow: 0px 0px 5px #888; ' +
        'margin: 0; padding: auto; width: 25px; height: 25px; vertical-align: middle; text-align: center; ' +
        'color: #FFF; font-weight: bold; font-size: 14px; line-height: 22px;">#</div>';
    zoomSlider.appendChild(insertZoom);

    updateZoom();

    Waze.map.events.register("zoomend", Waze.map, updateZoom);
};

var waitCount = 0,
    maxWait = 60; //60 seconds

var tryInit_WMEZL = function () {
    try {
        if ("undefined" !== typeof Waze && Waze.map && Waze.map.zoom &&
                Waze.map.events && Waze.map.events.register &&
                document.getElementsByClassName("slider")) {
            ZoomLevelIndicator();
        } else if (waitCount++ < maxWait) {
            setTimeout(tryInit_WMEZL, 1000);
        } else {
            console.error('WMEZL:',
                'Zoom Level Indicator could not find necessary Waze map objects.');
        }
    } catch (err) {
        console.error(
            'WMEZL:',
            'WME Zoom Level Indicator failed to load due to some kind of technical script error. :(');
        console.error(err);
    }
};

tryInit_WMEZL();