WME Status

Show map build information

// ==UserScript==
// @name         WME Status
// @description  Show map build information
// @namespace    https://gf.qytechs.cn/users/gad_m/wme_status
// @version      0.1.18
// @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/*
// @connect      storage.googleapis.com
// @grant        GM_xmlhttpRequest
// @icon         
// ==/UserScript==

/* global jQuery */
/* global W */
/* global I18n */

/******************************************
 *******************************************
 Based on WME Map Tiles Update (by Sebiseba)
 *******************************************
 ******************************************/

(function() {

    let locationCode;
    let dateOptions = {year: '2-digit', month: '2-digit',day: '2-digit', hour:'numeric', minute:'2-digit'};
    const regionToURL = {'il':'il','usa':'na','row':'intl'};

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

    function init() {
        console.debug("wme-status: init()");
        locationCode = W['app'].getAppRegionCode();
        console.info("wme-status: init() Location Code: '" + locationCode + "' url parameter: '" + regionToURL[locationCode] + "'");
        let url = 'https://storage.googleapis.com/waze-tile-build-public/current-build/' + regionToURL[locationCode] + '-status.json';
        console.debug('wme-status: init() Status URL: ' + url);
        GM_xmlhttpRequest({
            method: 'GET',
            synchronous: false,
            timeout: 5000,
            url: url,
            onerror: function (res) {
                console.error('wme-status: init() error reading status feed URL: ' + url + ' responseText: ' + res.responseText + ' statusText: ' + res.statusText);
            },
            ontimeout: function () {
                console.error('wme-status: init() timeout reading status feed URL: ' + url);
            },
            onload: function (res) {
                // per IL request - always display he format
                let localeBy = (W['app'].getAppRegionCode() === 'il')?'he':I18n.locale;
                console.debug("wme-status: init() localeBy: " + localeBy);
                let asJSON = JSON.parse(res.responseText);
                let previousBuild = asJSON['previous_build'];
                let mapReleaseAsDate = new Date(previousBuild['release_time']);
                console.info("wme-status: init() mapReleaseAsDate: " + mapReleaseAsDate);
                let lastEditStr = previousBuild['last_edit_time'];
                console.debug("wme-status: init() lastEditStr: '" + lastEditStr + "'");
                let lastEditTimeAsDate = new Date(lastEditStr);
                console.info("wme-status: init() lastEditTimeAsDate: '" + lastEditTimeAsDate + "'");
                let gapInMs = Date.now() - lastEditTimeAsDate.getTime();
                // add UI
                let topBar = jQuery('.topbar')[0];
                let lastEditDiv = document.createElement('div');
                lastEditDiv.id = "wme_last_edit";
                lastEditDiv.style.backgroundColor = "#3d3d3d";
                lastEditDiv.style.color = "white";
                let additionalText = ''; //  default: no text (less than 24 hours) - OK
                if (gapInMs > 1000*60*60*24*3) { // 3 days
                    console.info("wme-status: init() last edit time older than 3 days.");
                    lastEditDiv.style.backgroundColor = "#3d3d3d";
                    lastEditDiv.style.color = "red";
                    lastEditDiv.style.fontWeight = "bold";
                    additionalText = ' (older than 3 days)';
                } else if (gapInMs > 1000*60*60*(24+8)) { // 1 day + 8 hours between build start and status updated
                    console.info("wme-status: init() last edit time older than 1 day.");
                    lastEditDiv.style.backgroundColor = "#3d3d3d";
                    lastEditDiv.style.color = "yellow";
                    lastEditDiv.style.fontWeight = "bold";
                    additionalText = ' (1-3 days old)';
                }
                lastEditDiv.style.float = "left";
                lastEditDiv.style.paddingLeft = "10px";
                lastEditDiv.innerHTML = "Last Edit: " + lastEditTimeAsDate.toLocaleString(localeBy, dateOptions) + additionalText;
                topBar.appendChild(lastEditDiv);

                let releaseDiv = document.createElement('div');
                releaseDiv.id = "wme_status_release";
                releaseDiv.style.float = "left";
                releaseDiv.style.paddingLeft = "10px";
                releaseDiv.style.backgroundColor = "#3d3d3d";
                releaseDiv.style.color = "white";
                releaseDiv.innerHTML = "Map Release: " + mapReleaseAsDate.toLocaleString(localeBy, dateOptions);
                topBar.appendChild(releaseDiv);
                if (asJSON['current_build']) {
                    let inProgressMsg = "Build In Progress: " + asJSON['current_build']['progress_percent'] + "%";
                    console.info("wme-status: init() " + inProgressMsg);
                    let currentBuildingDiv = document.createElement('div');
                    currentBuildingDiv.id = "wme_current_building";
                    currentBuildingDiv.style.backgroundColor = "#3d3d3d";
                    currentBuildingDiv.style.color = "lightgreen";
                    currentBuildingDiv.style.fontWeight = "bold";
                    currentBuildingDiv.style.float = "left";
                    currentBuildingDiv.style.paddingLeft = "10px";
                    currentBuildingDiv.innerHTML = inProgressMsg;
                    topBar.appendChild(currentBuildingDiv);
                } else {
                    let nextBuild = asJSON['next_build'];
                    let nextBuildAsDate = new Date(nextBuild['estimated_start_time']);
                    let nextBuildWillStartInMinutes = Math.ceil((nextBuildAsDate.getTime() - Date.now())/1000/60);
                    console.info("wme-status: init() Next build in " + nextBuildWillStartInMinutes + " minutes");
                    if (nextBuildWillStartInMinutes < 60) {
                        let nextBuildDiv = document.createElement('div');
                        nextBuildDiv.id = "wme_next_build";
                        nextBuildDiv.style.backgroundColor = "#3d3d3d";
                        nextBuildDiv.style.color = (nextBuildWillStartInMinutes<10)?"red":"yellow";
                        nextBuildDiv.style.fontWeight = "bold";
                        nextBuildDiv.style.float = "left";
                        nextBuildDiv.style.paddingLeft = "10px";
                        nextBuildDiv.innerHTML = "Next build in: " + nextBuildWillStartInMinutes + " minutes";
                        topBar.appendChild(nextBuildDiv);
                    }
                }
            } // end onload
        }); // end http request
    } // end init()
}.call(this));

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址