您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Show map build information
// ==UserScript== // @name WME Status // @description Show map build information // @namespace https://greasyfork.org/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));