// ==UserScript==
// @name WME Speedhelper
// @description Makes inputting speed data easier
// @namespace [email protected]
// @grant none
// @grant GM_info
// @version 0.2.2
// @match https://editor-beta.waze.com/*editor/*
// @match https://www.waze.com/*editor/*
// @author Broos Gert '2015
// @license MIT/BSD/X11
// @icon 
// ==/UserScript==
/* Changelog
*/
// Add Google Varela Round font to make sure signs look the same everywhere (less hassle)
WebFontConfig = {google:{families:['Varela+Round::latin' ]}};
(function() {
var wf = document.createElement('script');
wf.src = ('https:' == document.location.protocol ? 'https' : 'http') +
'://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js';
wf.type = 'text/javascript';
wf.async = 'true';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(wf, s);
})();
/* Borden base64 */
var mssimg = '';
var BGa = '';
var signConfig = {
NL: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 15, 30, 50, 60, 70, 80, 100, 120, 130 ]},
BE: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 50, 70, 90, 100, 120 ]},
LUX: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 50, 70, 90, 120 ]},
AU: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 40, 50, 60, 70, 80, 100, 110, 120, 130 ]},
FR: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 50, 70, 90, 110, 130 ]},
HU: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 130]},
MX: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 10, 60, 70, 80, 90, 100, 110]},
UK: {'sgn': BGa, 'dim':'36|36', 'ann':'mph', 'spd':[ 30, 40, 50, 60]},
SZ: {'sgn': BGa, 'dim':'36|36', 'ann':'kph', 'spd':[ 30, 40, 50, 60, 80, 100, 120]},
GM: {'sgn': BGa, 'dim':'36|36', 'ann':'kph', 'spd':[ 7, 30, 50, 60, 70, 80, 100, 120, 130]},
LG: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 20, 30, 50, 70, 90, 100 ]},
LT: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 110, 120, 130 ]},
RU: {'sgn': BGa, 'dim':'36|36', 'ann':'kmh', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 110, 120, 130 ]}
};
// initialize WMESpeedhelper and do some checks
function WMESpeedhelper_bootstrap() {
WMESpeedhelper_init();
}
function WMESpeedhelper_init() {
//create the WMESpeedhelper object
var WMESpeedhelper = {};
var editpanel = $("#edit-panel");
// Check initialisation
if (typeof Waze == 'undefined' || typeof I18n == 'undefined') {
setTimeout(WMESpeedhelper_init, 660);
log('Waze object unavailable, map still loading');
return;
}
if (editpanel === undefined) {
setTimeout(WMESpeedhelper_init, 660);
log('edit-panel info unavailable, map still loading');
return;
}
// check for changes in the edit-panel
var speedlimitsObserver = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
// Mutation is a NodeList and doesn't support forEach like an array
for (var i = 0; i < mutation.addedNodes.length; i++) {
var addedNode = mutation.addedNodes[i];
// Only fire up if it's a node
if (addedNode.nodeType === Node.ELEMENT_NODE) {
var speedlimitDiv = addedNode.querySelector('div.controls.speed-limit');
if (speedlimitDiv) {
WMESpeedhelper.makeSigns(speedlimitDiv);
}
}
}
});
});
speedlimitsObserver.observe(document.getElementById('edit-panel'), { childList: true, subtree: true });
// Show friendly message to users of unsupported countries (for now)
WMESpeedhelper.showMessage = function() {
// Check if this message isn't allready on screen (bugcheck, can't reproduce myself)
if (!$("#_cnt").length) {
var mD = document.createElement("div");
mD.id = '_cnt';
mD.style.cssText = 'margin:5px 0 10px 0;border:1px solid red;padding:5px;border-radius:5px';
var mI = document.createElement("img");
mI.id = '_img';
mI.style.cssText = 'float:left;margin-right:5px;';
mI.src = mssimg;
var mT = document.createElement("div");
mT.id = '_text';
mT.innerHTML = '<b><a href="https://gf.qytechs.cn/en/scripts/13774-wme-speedhelper" target="_blank">WME Speedhelper 0.2.0</a></b><br>Your country is currently not supported yet. If you want me to add it, follow <a href="https://gf.qytechs.cn/en/scripts/13774-wme-speedhelper" target="_blank">this link</a> and look for the "missing country?" section in the description.';
var cleardiv = document.createElement("div");
cleardiv.id = 'cleardiv';
cleardiv.style.cssText ='clear:both;margin-bottom:5px;';
mD.appendChild(mI);
mD.appendChild(mT);
mD.appendChild(cleardiv);
$("div.controls.speed-limit").prepend(mD);
}
};
// The big one...
WMESpeedhelper.makeSigns = function(reciever) {
//log("COUNTRY CODE: " + Waze.model.countries.top.abbr);
var ABBR = signConfig[Waze.model.countries.top.abbr];
// Country code not found? Show user friendly message with info to get his/her country added
if (typeof ABBR == 'undefined') {
WMESpeedhelper.showMessage();
return;
}
// check if we're not adding to existing signs
if (!$("#signsholder").length) {
var signsholder = document.createElement("div");
signsholder.id = 'signsholder';
//Get the correct list of speedsigns to make
ABBR.spd.forEach(function(speed) {
// The sign background
var addsign = document.createElement("div");
addsign.id = 'signsholder';
// Get width/height of sign background img
var dims = ABBR.dim.split('|');
addsign.style.cssText = 'cursor:pointer;float:left;width:'+dims[0]+'px;height:'+dims[1]+'x;background-image: url(\''+ ABBR.sgn + '\');';
addsign.onclick = function() {
$("input[name=fwdMaxSpeed]").val(speed).change();
$("input[name=revMaxSpeed]").val(speed).change();
};
// The speed value
var speedvalue = document.createElement("div");
speedvalue.id = 'spd_'+ speed;
speedvalue.style.cssText = 'text-align:center;line-height:'+dims[1]+'px;font-size:11px;font-family:\'Varela Round\',sans-serif;color:#000; font-weight:bold;';
speedvalue.innerHTML = speed;
addsign.appendChild(speedvalue);
signsholder.appendChild(addsign);
});
// CSS Clear after the floats
var cleardiv = document.createElement("div");
cleardiv.id = 'cleardiv';
cleardiv.style.cssText ='clear:both;margin-bottom:5px;';
// Add everything to the stage
signsholder.appendChild(cleardiv);
$("div.controls.speed-limit").prepend(signsholder);
log('ready');
}
};
function log(message) {
if (typeof message === 'string') {
console.log('WMESpeedhelper: ' + message);
} else {
console.log('WMESpeedhelper: ', message);
}
}
}
setTimeout(WMESpeedhelper_bootstrap, 3000);