WME Speedhelper

Makes inputting speed data easier

// ==UserScript==
// @name           WME Speedhelper
// @description    Makes inputting speed data easier
// @namespace      broosgert@gmail.com
// @grant          none
// @grant          GM_info
// @version        1.0.2
// @include 	     /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor.*$/
// @exclude        https://www.waze.com/user/*editor/*
// @exclude        https://www.waze.com/*/user/*editor/*
// @author         Broos Gert '2015
// @license        MIT/BSD/X11
// @icon		       
// @require         https://greasyfork.org/scripts/24851-wazewrap/code/WazeWrap.js
// ==/UserScript==
/* Changelog

*/
/* global W */
/* global I18n */
/* global $ */

const ScriptName = GM_info.script.name;
const ScriptVersion = GM_info.script.version;

let ChangeLog = "WME SpeedHelper has been updated to " + ScriptVersion + "<br />";
//ChangeLog = ChangeLog + "<br /><b>New: </b>";
//ChangeLog = ChangeLog + "<br />" + "- Speedhelper is now using the newly released WME SDK as part of 1 of the first scripts to integrate this.";
ChangeLog = ChangeLog + "<br /><br /><b>Updated: </b>";
ChangeLog = ChangeLog + "<br />" + "- Added Tajikistan";

// Add Google Varela Round font to make sure signs look the same everywhere (less hassle)
const WebFontConfig = {google:{families:['Varela+Round::latin' ]}};
(function() {
  const 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;
  const s = document.getElementsByTagName('script')[0];
  s.parentNode.insertBefore(wf, s);
})();

/* Borden base64 */
const errorimg = '';
const mssimg = '';
//const settingsimg = '';
//const clearimg = '';
//const warningimg = '';
const BGa = ['', '34|34|10|visible']; // Global (red circle)
const BGb = ['', '34|50|10|hidden']; // residential
const BGc = ['','34|31|17|visible']; // US
const BGd = ['', '34|34|10|visible']; // Sweden (red/yellow circle)
const BGe = ['','34|29|10|visible']; // Canada
const BGf = ['','34|37|10|hidden']; // France
const BGg = ['','30|43|0|hidden']; // Finland
const BGh = ['','30|42|0|hidden']; // Sweden
const BGi = ['','34|31|17|visible']; // Puerto Rico
const BGj = ['','34|23|17|hidden']; // Ukraine
const BGk = ['', '34|47|10|hidden']; //LUX

/* // BGh = ['','34|23|17|hidden']; // lost in translation */

const signConfig = {
  NL:         {'sgn': BGa, 'ann':'kph', 'spd':[ [15,BGb], 30, 50, 60, 70, 80, 100, 120, 130 ]}, //------------------------ 1.The Netherlands
  BE:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20,BGb], 30, 50, 70, 90, 100, 120 ]}, //--------------------------------- 2.Belgium
  LU:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20,BGk], 30, 50, 70, 90, 110, 130 ]}, //--------------------------------- 3.Luxemburg
  FR:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20, BGf], 30, 50, 70, 80, 90, 110, 130 ]}, //---------------------------- 4.France
  AU:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 100, 110, 120, 130 ]}, //------------------------- 5.Austria
  UK:         {'sgn': BGa, 'ann':'mph', 'spd':[ 20, 30, 40, 50, 60, 70]}, //---------------------------------------------- 6.United Kingdom
  HU:         {'sgn': BGa, 'ann':'kph', 'spd':[ 5, 10, 15, 20, 25, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, //--- 7.Hungary
  MX:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 45, 50, 60, 70, 80, 90, 100, 110]}, //-------------------- 8.Mexico
  SZ:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20,BGb], 30, 40, 50, 60, 70, 80, 100, 120]}, //-------------------------- 9.Switzerland
  GM:         {'sgn': BGa, 'ann':'kph', 'spd':[ [7,BGb], 30, 40, 50, 60, 70, 80, 100, 120, 130]}, //-----------------------10.Germany
  LG:         {'sgn': BGa, 'ann':'kph', 'spd':[ 5, 10, [20,BGb], 30, 40, 50, 60, 70, 80, 90, 100]}, //-------------------- 11.Latvia
  LH:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, [20,BGb], 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130 ]}, //--------12.Lithuania
  RS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130 ]}, //----------------- 13.Russia
  EZ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 70, 80, 90 ]}, //----------------------------------------- 14.Czech Republic
  SP:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 120 ]}, //--------------------------- 15.Spain
  PO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 120]}, //-------------------------------- 16.Portugal
  DA:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 110]}, //------------------------------------- 17.Danmark
  CO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 120]}, //------------------------ 18.Colombia
  LO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110, 130]}, //--------------------------- 19.Slovakia
  BR:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110]}, //---------------------------- 20.Brazil
  UY:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 45, 60, 75, 80, 90, 110]}, //----------------------------------------- 21.Uruguay
  US:         {'sgn': BGc, 'ann':'mph', 'spd':[ 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80]}, //------- 22.United States
  ES:         {'sgn': BGa, 'ann':'kph', 'spd':[ 25, 40, 50, 60, 70, 80, 90]}, //------------------------------------------ 23.El Salvador
  BL:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 50, 70, 80, 100]}, //--------------------------------------------- 24.Bolivia
  LS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 80, 100, 120]}, //---------------------------------------- 25.Liechtenstein
  EI:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 80, 100, 120]}, //---------------------------------------- 26.Ireland
  PL:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140]}, //------------- 27.Poland
  AS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 25, 30, 40, 50, 60, 70, 80, 90, 100, 110, 130]}, //------------------- 28.Australia
  NZ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 50, 60, 70, 80, 100]}, //--------------------------------------------- 29.New Zealand
  SW:         {'sgn': BGd, 'ann':'kph', 'spd':[ [7,BGh], 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120]}, //-------------- 30.Sweden
  CA:         {'sgn': BGe, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110]}, //-------------------------------- 31.Canada
  SR:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, //-------------------32.Serbia
  RO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 5, 10, 15, 20, 30, 40, 50, 60, 70, 80, 90, 100, 130]}, //----------------- 33.Romania
  IT:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110, 130]}, //--------------------------- 34.Italy
  GQ:         {'sgn': BGc, 'ann':'mph', 'spd':[ 5, 10, 15, 20, 25, 30, 35, 40, 45]}, //----------------------------------- 35.Guam
  SI:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 30, 40, 50, 60, 70, 90, 100, 110, 130]}, //----------------------------36.Slovenia
  BO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120]}, //----------------------- 37.Belarus
  BC:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 60, 70, 80, 100, 120]}, //-------------------------------------------- 38.Botswana
  SF:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 40, 60, 70, 80, 100, 120]}, //------------------------------------ 39.South Africa
  MY:         {'sgn': BGa, 'ann':'kph', 'spd':[ [30,BGb], 35, 40, 50, 60, 70, 80, 90, 110]}, //--------------------------- 40.Malaysia
  BU:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 120, 140]}, //---------------------------- 41.Bulgaria
  JE:         {'sgn': BGa, 'ann':'mph', 'spd':[ 15, 20, 30, 40]}, //------------------------------------------------------ 42.Jersey
  IC:         {'sgn': BGd, 'ann':'mph', 'spd':[ 30, 35, 45, 50, 60, 70, 80, 90]}, //-------------------------------------- 43.Iceland
  AR:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, //-------------- 44.Argentina
  RE:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 70, 90, 110]}, //------------------------------------------------- 45.Réunion
  TU:         {'sgn': BGa, 'ann':'kph', 'spd':[ 50, 90, 110, 120]}, //---------------------------------------------------- 46.Turkey
  CJ:         {'sgn': BGa, 'ann':'mph', 'spd':[ 25, 30, 50]}, //---------------------------------------------------------- 47.Cayman Island
  MU:         {'sgn': BGa, 'ann':'kph', 'spd':[ 25, 40, 60, 80, 90, 100, 120]}, //---------------------------------------- 48.Oman
  VE:         {'sgn': BGa, 'ann':'kph', 'spd':[ 15, 30, 40, 50, 60, 70, 90, 120]}, //------------------------------------- 49.Venezuela
  RP:         {'sgn': BGa, 'ann':'kph', 'spd':[ 100, 80, 60, 50, 40, 30, 20, 15]}, //------------------------------------- 50.Philippines
  KZ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20,40, 60, 100, 110, 140]}, //-------------------------------------------- 51.Kazakhstan
  FI:         {'sgn': BGd, 'ann':'kph', 'spd':[ [20,BGg], 30, 40, 50, 60, 70, 80, 90, 100, 120 ]}, //--------------------- 52.Finland
  IL:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60 ,70, 80, 90 ,100, 110, 120, 130]}, //---------------------- 53.Israel
  TC:         {'sgn': BGa, 'ann':'kph', 'spd':[ 25, 40, 60, 70, 80, 90, 100, 120, 140]}, //------------------------------- 54.United Arab Emirates
  TW:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140]}, //----------------- 55.Taiwan
  CE:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140, 150]}, //------------ 56.Sri Lanka
  NO:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110]}, //-------------------------------- 57.Norway
  WE:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110]}, //-------------------------------- 58.West Bank
  CH:         {'sgn': BGa, 'ann':'kph', 'spd':[ 120, 100, 80, 70, 60, 50, 40, 20]}, //------------------------------------ 59.China
  ID:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 120]}, //------------------------ 60.Indonesia
  GK:         {'sgn': BGa, 'ann':'mph', 'spd':[ 15, 20, 25, 35]}, //------------------------------------------------------ 61.Guernsey
  EC:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100]}, //--------------------------------- 62.Ecuador
  CS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100]}, //------------------------------------- 63.Costa Rica
  RQ:         {'sgn': BGi, 'ann':'mph', 'spd':[ 5,10,15,20,25,30,35,40,45,50,55,60,65]}, //------------------------------- 64.Puerto Rico
  AG:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 100, 120]}, //------------------------------------ 65.Algeria
  BX:         {'sgn': BGa, 'ann':'mph', 'spd':[ 30, 35, 40, 50, 60, 70, 80, 90, 110]}, //--------------------------------- 66.Brunei
  PM:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 60, 80]}, //---------------------------------------------- 67.Panama
  UZ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 30, 50, 70, 100]}, //------------------------------------------------- 68.Uzbekistan
  MD:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90]}, // ----------------------------------------- 69.Moldova
  IN:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, // ------------- 70.India
  HR:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, // ------------- 71.Croatia
  LE:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 80, 90, 100, 110]}, // ------------------------------- 72.Lebanon
  HK:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 70, 80, 100, 110]}, // ------------------------------------------- 73.Hong Kong
  EN:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20,BGg], 30, 40, 50, 60, 70, 80, 90, 100, 110]}, // --------------------- 74.Estonia
  SN:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 50, 60, 70, 80, 90]}, // --------------------------------------------- 75.Singapore
  CM:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 60, 80, 100]}, // ---------------------------------------------------- 76.Cameroon
  CI:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 80, 100, 120]}, // --------------------------------------- 77.Chile
  QA:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 80, 100, 120]}, // ----------------------------------- 78.Quatar
  MW:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 60, 80, 100, 120]}, // ------------------------------------------- 79.Montenegro
  AA:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 60, 80]}, // --------------------------------------------------------- 80.Aruba (ABC)
  NS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 60, 90]}, // --------------------------------------------------------- 81.Suriname
  CW:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 80]}, // --------------------------------------------------------- 82.Curacao
  BQ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 80]}, // --------------------------------------------------------- 83.Bonaire / Saba Island
  MF:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 80]}, // --------------------------------------------------------- 84.Sint Eustatius
  MN:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 70, 80, 90]}, // ----------------------------------------- 85.Monaco
  UP:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 5, 10, [20, BGh], 30, 40, 50, 90, 110, [130, BGj] ]}, // ----------------- 86.Ukraine
  BK: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, // ----------------- 87.Bosnia-Herzegovina
  GR:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130]}, // ----------------- 88.Greece
  PP:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 50, 90, 130]}, // -------------------------------------------------------- 89.Papua New Guinea
  MP:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 60, 80, 110]}, // ---------------------------------------------------- 90.Mauritius
  //IR:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 70, 80, 90, 100, 110, 120]}, // ---------------------------------- 91.Iran
  DR:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 45, 60, 100, 120]}, // ----------------------------------- 92.Dominican Republic
  BG:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 25, 40, 50, 60, 80]}, // ------------------------------------------------- 93.Bangladesh
  PE:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 35, 40, 55, 60, 80, 100, 120 ]}, // -------------------------------------- 94.Peru
  ZA:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 50, 60, 80, 100, 120 ]}, // ------------------------------------------ 95.Zambia
  //AO:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 60, 90, 120 ]}, // ------------------------------------------------------- 96.Angola
  MZ:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 90, 100, 120 ]}, // ---------------------------------- 97.Mozambique
  CY:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 65, 80, 100 ]}, // ----------------------------------------------- 98.Cyprus
  AJ: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 50, 60, 70, 90, 110 ]}, // ----------------------------------------------- 99.Azerbaijan
  AM: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 60, 70, 90 ]}, // ---------------------------------------------------- 100.Armenia
  AO: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 120 ]}, // -------------------------- 101.Angola
  GT: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 15, 20, 25, 30, 40, 60, 70, 80, 90 ]}, // ---------------------------- 102.Guatemala
  IR: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 65, 70, 75, 80, 85, 90, 95, 100, 110, 120 ]}, // --------- 103.Iran
  JM: 		    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 65, 80, 100, 110 ]}, // -------------------------------------- 104.Jamaica
  VQ:         {'sgn': BGc, 'ann':'mph', 'spd':[ 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55 ,60, 65, 70, 75, 80 ]}, //------ 105.Virgin Islands (US)
  CQ:         {'sgn': BGc, 'ann':'mph', 'spd':[ 5,10, 15, 20, 25, 30, 35, 40, 45]}, //------------------------------------ 106. Northern Mariana Islands (US)
  PK:         {'sgn': BGa, 'ann':'kph', 'spd':[ 40, 50, 60, 80, 100, 120 ]}, //------------------------------------------- 107. Pakistan
  BA:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 70, 80, 90, 100, 120 ]}, //------------------------------- 108.Bahrain
  SA:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140 ]}, //------------ 109.Saudi Arabia
  KU:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 45, 50, 60, 80, 100, 120 ]}, //------------------------------- 110.Kuwait
  KG:         {'sgn': BGa, 'ann':'kph', 'spd':[ 5, 20, 40, 50, 60, 90 ]}, //---------------------------------------------- 111.Kyrgyzstan
  WA:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 40, 60, 80, 100, 120 ]}, //--------------------------------------------112.Namibia
  LT:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 40, 60, 70, 80, 90, 100, 120 ]}, //------------------------------------113.Lesotho
  WZ:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 40, 60, 70, 80, 90, 100, 120 ]}, //------------------------------------114.eSwatini
  ZI:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 40, 60, 70, 80, 90, 100, 120 ]}, //------------------------------------115.Zimbabwe
  AN:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 70, 90 ]}, //----------------------------------------------116.Andorra
  MG:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 120 ]}, //----------------------------117.Mongolia - Waze uses MG
  HO:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 25, 40, 50, 60, 80 ]}, //----------------------------------------- 118. Honduras
  MK:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 40, 50, 60, 80, 100, 120, 130 ]}, //---------------------------------- 119. Macedonia
  YM:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 120, 140 ]}, //------------------ 120. Yemen
  MO:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 100, 120 ]}, //------------------------------- 121. Morocco - Waze uses MO
  SU:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 40, 70, 120 ]}, //-----------------------------------------------------122.Sudan
  VM:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 50, 60, 70, 80, 90, 100, 120 ]}, //----------------------------------------123.Vietnam - Waze uses VM
  NP:         {'sgn': BGa, 'ann':'kph', 'spd':[ [20,BGk], 30, 40, 50, 60, 70, 80 ]}, //------------------------------------124. Nepal
  FJ:			    {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80 ]}, //------------------------------------------125. Fiji
  GI:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50 ]}, //------------------------------------------------------126. Gibraltar
  SS:         {'sgn': BGa, 'ann':'kph', 'spd':[ 50, 90, 110, 130 ]}, //----------------------------------------------------127. South Sudan
  TH:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 30, 40, 50, 60, 70, 80, 90, 100, 120 ]}, //----------------------------128. Thailand
  GH:         {'sgn': BGa, 'ann':'kph', 'spd':[ 30, 50, 90, 100 ]}, //-----------------------------------------------------129. Ghana
  MV:         {'sgn': BGa, 'ann':'kph', 'spd':[ 10, 15, 25, 30, 35 ]}, //--------------------------------------------------130. Maldives
  TJ:         {'sgn': BGa, 'ann':'kph', 'spd':[ 20, 60, 90, 110 ]}, //-----------------------------------------------------131. Tajikistan
};

let wmeSDK;
const options = loadOptions();

// Now validate the options are ok
validateOptions(options);

function log(message) {
  if (typeof message === 'string') {
    console.log('WMESpeedhelper: ' + message);
  } else {
    console.log('WMESpeedhelper: ', message);
  }
}

// the sdk init function will be available after the WME is initialized
function WMESpeedhelper_bootstrap() {
  if (!document.getElementById('edit-panel') || !wmeSDK.DataModel.Countries.getTopCountry() || !WazeWrap.Ready) {
    setTimeout(WMESpeedhelper_bootstrap, 250);
    return;
  }

  if (wmeSDK.State.isReady) {
    WMESpeedhelper_init();
  } else {
    wmeSDK.Events.once({ eventName: "wme-ready" }).then(WMESpeedhelper_init);
  }
}

function WMESpeedhelper_init() {
  log("Start");

  // check for changes in the edit-panel
  const speedLimitsObserver = new MutationObserver((mutations) => {
    mutations.forEach(function(mutation) {
      // Mutation is a NodeList and doesn't support forEach like an array
      for (let i = 0; i < mutation.addedNodes.length; i++) {
        const addedNode = mutation.addedNodes[i];

        // Only fire up if it's a node
        if (addedNode.nodeType === Node.ELEMENT_NODE) {

          if (addedNode.querySelector('div.speed-limit-fwd') || addedNode.querySelector('div.speed-limit-rev')) {
            makeSigns();
          }
        }
      }
    });
  });

  speedLimitsObserver.observe(document.getElementById('edit-panel'), { childList: true, subtree: true });

  // Catch permalinks
  makeSigns();

  constructSettings();
  displayChangelog();

  log("Done");

}

window.SDK_INITIALIZED.then(() => {
  // initialize the sdk with your script id and script name
  wmeSDK = getWmeSdk({scriptId: "wme-speed-helper", scriptName: "Speed Helper"});
  WMESpeedhelper_bootstrap();
});

// Show friendly message to users of unsupported countries (for now)
function showUnsupportedCountry() {

  // Check if the user hasn't already asked to hide this message
  if (localStorage.msgHide !== 1) {
    if (!$("#_wmesh_msg1").length) {

      const mainDiv = $('<div id="_wmesh_msg1" style="margin:5px 0 10px 0; border:1px solid red; padding:5px; border-radius:5px; position:relative"></div>');
      const iconDiv = $('<div style="cursor:pointer; width:16px; height:16px; position:absolute; right:3px; top:3px; background-image:url(' + errorimg + ');"></div>');
      iconDiv.on('click', () => {
        localStorage.msgHide = 1;
        $('#_wmesh_msg1').hide('slow');
      });

      mainDiv.append(iconDiv);

      const img = $('<img style="float:left; margin-right:5px;" alt="" src="' + mssimg + '" />');
      const content = $('<div></div>')
        .append('<b><a href="https://greasyfork.org/en/scripts/13774-wme-speedhelper" target="_blank">WME Speedhelper ' + ScriptVersion + '</a></b>')
        .append('<br />')
        .append('Country missing? Follow <a href="https://greasyfork.org/en/scripts/13774-wme-speedhelper" target="_blank">this</a> link Your country code: <b>' + getCurrentCountry().abbr + '</b>');

      const clearDiv = $('<div id="cleardiv" style="clear:both; margin-bottom:5px;"></div>');

      mainDiv.append(img);
      mainDiv.append(content);
      mainDiv.append(clearDiv);

      addToSpeedLimitSection(mainDiv);
    }
  }
}

function showImperial(wmeMode) {
  if (!$("#_wmesh_msg1").length) {

    const mainDiv = $('<div id="_wmesh_msg1" style="display: flex; margin:5px 0 10px 0; border:1px solid red; padding:5px; border-radius:5px; position:relative; font-size:90%; background:#FFE7E7"></div>')
    const img = $('<img style="float:left; margin-right:5px; width:25px; height:25px" alt="" src="' + BGa[0] + '" />');

    const content = $('<div></div>')
      .append('<b>WME is currently set to <u>' + wmeMode + '</u>. Please change this to if you want to add speedlimits in this country ('+ getCurrentCountry().abbr +')</b>');

    mainDiv.append(img);
    mainDiv.append(content);

    addToSpeedLimitSection(mainDiv);
  }
}

function makeSigns() {
  const activeConfig = findCountryConfig();

  // Country code not found? Show user-friendly message with info to get his/her country added
  if (typeof activeConfig == 'undefined') {
    showUnsupportedCountry();
    return;
  }

  const mphOrKph = activeConfig.ann;
  const wmeMode = wmeSDK.Settings.getUserSettings().isImperial ? 'mph' : 'kph';

  // Hide signs if the user's settings are not correct.
  if (wmeMode !== mphOrKph){
    showImperial(wmeMode);
    return;
  }

  /*************
   * EDIT PANEL *
   *************/
  // check if we're not adding to existing signs
  if (!$("#_wmesh_signsholder").length) {
    const signsHolder = $('<div id="_wmesh_signsholder"></div>')

    renderSigns(activeConfig, signsHolder, (speed) => clickSegmentSpeed(speed));

    addToSpeedLimitSection(signsHolder);
  }
}

function findCountryConfig() {
  return signConfig[getCurrentCountry().abbr];
}

function addToSpeedLimitSection(content) {
  content.append('<div style="clear:both; margin-bottom:5px;"></div>')

  let $speedLimitDiv = $('div.speed-limit-fwd');
  if ($speedLimitDiv.length === 0) {
    $speedLimitDiv = $("div.speed-limit-rev");
  }
  $speedLimitDiv.prepend(content);
}

function clickSegmentSpeed(allowedSpeed) {
  const selection = wmeSDK.Editing.getSelection();

  if (!selection || selection.objectType !== 'segment') {
    return;
  }

  log('Changing speed to ' + allowedSpeed);

  if (wmeSDK.Settings.getUserSettings().isImperial) {
    allowedSpeed = allowedSpeed * 1.609344;
  }

  selection.ids.forEach(id => {
    try {
      wmeSDK.DataModel.Segments.updateSegment({
        segmentId: id,
        fwdSpeedLimit: allowedSpeed,
        revSpeedLimit: allowedSpeed
      })
    }
    catch (err) {
      // function updateSegment is throwing an 'InvalidStateError' if no update is needed; this should be ignored to update the remaining segments
      if (err.name !== 'InvalidStateError') {
        console.log(`WMESpeedhelper: error updating segment: ${err.name}: ${err.message}`);
      }
    }
  });
}

function renderSigns(activeConfig, holder, click) {

  // Get the correct list of speed signs to make
  activeConfig.spd.forEach((speed) => {
    let bgImage = activeConfig.sgn[0];
    let allowedSpeed = speed;
    let dims = activeConfig.sgn[1].split('|');

    // Check per speed value if we need a special image
    try {
      if (Array.isArray(speed)) {
        allowedSpeed = speed[0];
        bgImage = speed[1][0];
        dims = speed[1][1].split('|');
      }
    } catch (e) {
    }

    // The sign background
    const sign = document.createElement("div");
    sign.id = 'sign'+allowedSpeed;

    // Get width/height of sign background img
    const scale = options.iconScale / 100;
    sign.style.cssText = 'cursor:pointer;float:left;width:'+(dims[1]*scale)+'px;height:'+(dims[0]*scale)+'px;background-image: url(\''+ bgImage + '\');background-size:contain;';

    // Credits for some of these parts go to t0cableguy & Rickzabel
    sign.onclick = () => click(allowedSpeed);

    // The speed value
    const speedValue = document.createElement("div");
    speedValue.id = 'spd_'+ allowedSpeed;
    speedValue.style.cssText = 'text-align:center;margin-top:'+(dims[2] - (dims[2]*2*(1 - scale)))+'px;font-size:' + (10 * scale) + 'px;font-family:\'Varela Round\',sans-serif;color:#000; font-weight:bold;visibility:'+dims[3];
    speedValue.innerHTML = allowedSpeed;
    sign.append(speedValue);
    holder.append(sign);
  });
}

function displayChangelog() {
  if (!WazeWrap.Interface) {
    setTimeout(displayChangelog, 1000);
    return;
  }

  // Alert the user in URComment version updates
  if (options.lastAnnouncedVersion === ScriptVersion) {
    log('Version: ' + ScriptVersion);
  } else {
    WazeWrap.Interface.ShowScriptUpdate(ScriptName, ScriptVersion, ChangeLog + "<br /><br />", "https://github.com/wazers/wme-speedhelper");

    const updateName = "#wmespeedhelper" + ScriptVersion.replaceAll(".", "");
    $(updateName + " .WWSUFooter a").text("Github")

    options.lastAnnouncedVersion = ScriptVersion;
    saveOptions(options);
  }
}

function getCurrentCountry() {
  return wmeSDK.DataModel.Countries.getTopCountry();
}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
////
//// Option Logic
////
////////////////////////////////////////////////////////////////////////////////////////////////////////////
function constructSettings() {

  // -- Set up the tab for the script
  wmeSDK.Sidebar.registerScriptTab().then(({ tabLabel, tabPane }) => {
    tabLabel.innerText = 'SpeedHelper';
    tabLabel.title = 'Speed Helper Settings';

    tabPane.innerHTML = '<div id="speedhelper-settings"></div>';

    const scriptContentPane = $('#speedhelper-settings');

    scriptContentPane.append(`<h2 style="margin-top: 0;">SpeedHelper</h2>`);
    scriptContentPane.append(`<span>Current Version: <b>${ScriptVersion}</b></span>`);

    addTextNumberSettings(scriptContentPane, '', 'Icon Scale in %', 'iconScale');
  });

}

function getDefaultOptions() {
  return {
    lastAnnouncedVersion: '',
    iconScale: 100
  }
}

function loadOptions() {
  let text = localStorage.getItem("SpeedHelper-Options");
  let options;

  if (text) {
    options = JSON.parse(text);
  } else {
    options = getDefaultOptions();
  }

  return options;
}

function validateOptions(options) {
  const defaultOptions = getDefaultOptions();

  // Add missing options
  for (let key in defaultOptions) {
    if (!(key in options)) {
      options[key] = defaultOptions[key]
    }
  }
}

function saveOptions(options) {
  const optionsJson = JSON.stringify(options);
  localStorage.setItem("SpeedHelper-Options", optionsJson);
}

function changeText(event) {
  options[event.target.id] = event.target.value;
  saveOptions(options);
}

function addTextNumberSettings(container, title, label, name, step = 1) {
  const currentValue = options[name];

  const textInput = $('<wz-text-input type="number" min="0" max="999" step="' + step + '" id="' + name + '" value="' + currentValue + '"></wz-text-input>');
  const optionHtml = $('<div style="margin-top: 10px;"><span Title="' + title + '">' + label + '</span></div>').append(textInput);

  container.append(optionHtml);

  textInput.on('change', changeText);
}