WME Place tools

Add some buttons on different places. That makes some actions more easy to be done

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name                WME Place tools
// @namespace           @test_Myriades
// @description         Add some buttons on different places. That makes some actions more easy to be done
// @include             https://www.waze.com/editor/*
// @include             https://www.waze.com/*/editor/*
// @icon                
// @version             0.9
// @copyright   		2014, Myriades
// ==/UserScript==

/* Global vars */
var WMEPT = {};
WMEPT = {'loaded': false, 'script_name': 'Places Tools', 'version': GM_info.script.version, 'script_URL': 'https://www.waze.com/forum/viewtopic.php?f=68&t=98212'};
WMEPT.options = {};
WMEPT.options = {'HL_on_off': true, 'Debug_Level': 3};
WMEPT.venue_defs = {};
//	-3 : never warn - -2 : undefined in wiki(warn the author only) - -1 : on représente pas - 0 : lieu - 1 : zone - 2 : au choix (dépends de la taille (X ou Y) > 50m )
//	Refer to : https://wiki.waze.com/wiki/Places#When_to_use_Area_or_Point
//	Car services
WMEPT.venue_defs['GAS_STATION'] = {'code': '0.0', 'type': 1};
WMEPT.venue_defs['PARKING_LOT'] = {'code': '0.1', 'type': -3};
WMEPT.venue_defs['GARAGE_AUTOMOTIVE_SHOP'] = {'code': '0.2', 'type': 0};
WMEPT.venue_defs['CAR_WASH'] = {'code': '0.3', 'type': 0};
WMEPT.venue_defs['CHARGING_STATION'] = {'code': '0.4', 'type': 0};
//	Transportation
WMEPT.venue_defs['AIRPORT'] = {'code': '1.0', 'type': 1};
WMEPT.venue_defs['BUS_STATION'] = {'code': '1.1', 'type': 0};
WMEPT.venue_defs['FERRY_PIER'] = {'code': '1.2', 'type': 0};
WMEPT.venue_defs['SEAPORT_MARINA_HARBOR'] = {'code': '1.3', 'type': 2};
WMEPT.venue_defs['SUBWAY_STATION'] = {'code': '1.4', 'type': 0};
WMEPT.venue_defs['TRAIN_STATION'] = {'code': '1.5', 'type': 0};
WMEPT.venue_defs['BRIDGE'] = {'code': '1.6', 'type': 1};
WMEPT.venue_defs['TUNNEL'] = {'code': '1.7', 'type': 1};
WMEPT.venue_defs['TAXI_STATION'] = {'code': '1.8', 'type': 0};
WMEPT.venue_defs['JUNCTION_INTERCHANGE'] = {'code': '1.9', 'type': 1};
//	PROFESSIONAL_AND_PUBLIC
WMEPT.venue_defs['COLLEGE_UNIVERSITY'] = {'code': '2.0', 'type': 1};
WMEPT.venue_defs['SCHOOL'] = {'code': '2.1', 'type': 1};
WMEPT.venue_defs['CONVENTIONS_EVENT_CENTER'] = {'code': '2.2', 'type': 2};
WMEPT.venue_defs['GOVERNMENT'] = {'code': '2.3', 'type': 0};
WMEPT.venue_defs['LIBRARY'] = {'code': '2.4', 'type': 0};
WMEPT.venue_defs['CITY_HALL'] = {'code': '2.5', 'type': 0};
WMEPT.venue_defs['ORGANIZATION_OR_ASSOCIATION'] = {'code': '2.6', 'type': 0};
WMEPT.venue_defs['PRISON_CORRECTIONAL_FACILITY'] = {'code': '2.7', 'type': 1};
WMEPT.venue_defs['COURTHOUSE'] = {'code': '2.8', 'type': 0};
WMEPT.venue_defs['CEMETERY'] = {'code': '2.9', 'type': 1};
WMEPT.venue_defs['FIRE_DEPARTMENT'] = {'code': '2.10', 'type': 0};
WMEPT.venue_defs['POLICE_STATION'] = {'code': '2.11', 'type': 0};
WMEPT.venue_defs['MILITARY'] = {'code': '2.12', 'type': 1};
WMEPT.venue_defs['HOSPITAL_MEDICAL_CARE'] = {'code': '2.13', 'type': 2};
WMEPT.venue_defs['OFFICES'] = {'code': '2.14', 'type': 2};
WMEPT.venue_defs['POST_OFFICE'] = {'code': '2.15', 'type': 0};
WMEPT.venue_defs['RELIGIOUS_CENTER'] = {'code': '2.16', 'type': 0};
WMEPT.venue_defs['KINDERGARDEN'] = {'code': '2.17', 'type': 0};
WMEPT.venue_defs['FACTORY_INDUSTRIAL'] = {'code': '2.18', 'type': 2};
WMEPT.venue_defs['EMBASSY_CONSULATE'] = {'code': '2.19', 'type': 1};
WMEPT.venue_defs['INFORMATION_POINT'] = {'code': '2.20', 'type': 0};
//	SHOPPING_AND_SERVICES
WMEPT.venue_defs['ARTS_AND_CRAFTS'] = {'code': '3.0', 'type': 0};
WMEPT.venue_defs['BANK_FINANCIAL'] = {'code': '3.1', 'type': 0};
WMEPT.venue_defs['SPORTING_GOODS'] = {'code': '3.2', 'type': 0};
WMEPT.venue_defs['BOOKSTORE'] = {'code': '3.3', 'type': 0};
WMEPT.venue_defs['PHOTOGRAPHY'] = {'code': '3.4', 'type': 0};
WMEPT.venue_defs['CAR_DEALERSHIP'] = {'code': '3.5', 'type': 2};
WMEPT.venue_defs['FASHION_AND_CLOTHING'] = {'code': '3.6', 'type': 0};
WMEPT.venue_defs['CONVENIENCE_STORE'] = {'code': '3.7', 'type': 0};
WMEPT.venue_defs['PERSONAL_CARE'] = {'code': '3.8', 'type': 0};
WMEPT.venue_defs['DEPARTMENT_STORE'] = {'code': '3.9', 'type': 0};
WMEPT.venue_defs['PHARMACY'] = {'code': '3.10', 'type': 0};
WMEPT.venue_defs['ELECTRONICS'] = {'code': '3.11', 'type': 0};
WMEPT.venue_defs['FLOWERS'] = {'code': '3.12', 'type': 0};
WMEPT.venue_defs['FURNITURE_HOME_STORE'] = {'code': '3.13', 'type': 0};
WMEPT.venue_defs['GIFTS'] = {'code': '3.14', 'type': 0};
WMEPT.venue_defs['GYM_FITNESS'] = {'code': '3.15', 'type': 0};
WMEPT.venue_defs['SWIMMING_POOL'] = {'code': '3.16', 'type': 0};
WMEPT.venue_defs['HARDWARE_STORE'] = {'code': '3.17', 'type': 0};
WMEPT.venue_defs['MARKET'] = {'code': '3.18', 'type': 0};
WMEPT.venue_defs['SUPERMARKET_GROCERY'] = {'code': '3.19', 'type': 2};
WMEPT.venue_defs['JEWELRY'] = {'code': '3.20', 'type': 0};
WMEPT.venue_defs['LAUNDRY_DRY_CLEAN'] = {'code': '3.21', 'type': 0};
WMEPT.venue_defs['SHOPPING_CENTER'] = {'code': '3.22', 'type': 1};
WMEPT.venue_defs['MUSIC_STORE'] = {'code': '3.23', 'type': 0};
WMEPT.venue_defs['PET_STORE_VETERINARIAN_SERVICES'] = {'code': '3.24', 'type': 0};
WMEPT.venue_defs['TOY_STORE'] = {'code': '3.25', 'type': 0};
WMEPT.venue_defs['TRAVEL_AGENCY'] = {'code': '3.26', 'type': 0};
WMEPT.venue_defs['ATM'] = {'code': '3.27', 'type': 0};
WMEPT.venue_defs['CURRENCY_EXCHANGE'] = {'code': '3.28', 'type': 0};
WMEPT.venue_defs['CAR_RENTAL'] = {'code': '3.29', 'type': 0};
//	FOOD_AND_DRINK
WMEPT.venue_defs['RESTAURANT'] = {'code': '4.0', 'type': 0};
WMEPT.venue_defs['BAKERY'] = {'code': '4.1', 'type': 0};
WMEPT.venue_defs['DESSERT'] = {'code': '4.2', 'type': 0};
WMEPT.venue_defs['CAFE'] = {'code': '4.3', 'type': 0};
WMEPT.venue_defs['FAST_FOOD'] = {'code': '4.4', 'type': 0};
WMEPT.venue_defs['FOOD_COURT'] = {'code': '4.5', 'type': 0};
WMEPT.venue_defs['BAR'] = {'code': '4.6', 'type': 0};
WMEPT.venue_defs['ICE_CREAM'] = {'code': '4.7', 'type': 0};
//	CULTURE_AND_ENTERTAINEMENT
WMEPT.venue_defs['ART_GALLERY'] = {'code': '5.0', 'type': 0};
WMEPT.venue_defs['CASINO'] = {'code': '5.1', 'type': 2};
WMEPT.venue_defs['CLUB'] = {'code': '5.2', 'type': 2};
WMEPT.venue_defs['TOURIST_ATTRACTION_HISTORIC_SITE'] = {'code': '5.3', 'type': 0};
WMEPT.venue_defs['MOVIE_THEATER'] = {'code': '5.4', 'type': 0};
WMEPT.venue_defs['MUSEUM'] = {'code': '5.5', 'type': 0};
WMEPT.venue_defs['MUSIC_VENUE'] = {'code': '5.6', 'type': 0};
WMEPT.venue_defs['PERFORMING_ARTS_VENUE'] = {'code': '5.7', 'type': 0};
WMEPT.venue_defs['GAME_CLUB'] = {'code': '5.8', 'type': 0};
WMEPT.venue_defs['STADIUM_ARENA'] = {'code': '5.9', 'type': 1};
WMEPT.venue_defs['THEME_PARK'] = {'code': '5.10', 'type': 1};
WMEPT.venue_defs['ZOO_AQUARIUM'] = {'code': '5.11', 'type': 2};
WMEPT.venue_defs['RACING_TRACK'] = {'code': '5.12', 'type': 1};
WMEPT.venue_defs['THEATER'] = {'code': '5.13', 'type': 0};
//	OTHER
WMEPT.venue_defs['RESIDENCE_HOME'] = {'code': '6.0', 'type': 0};
WMEPT.venue_defs['CONSTRUCTION_SITE'] = {'code': '6.1', 'type': -1};
//	LODGING
WMEPT.venue_defs['HOTEL'] = {'code': '7.0', 'type': 0};
WMEPT.venue_defs['HOSTEL'] = {'code': '7.1', 'type': 0};
WMEPT.venue_defs['CAMPING_TRAILER_PARK'] = {'code': '7.2', 'type': 2};
WMEPT.venue_defs['COTTAGE_CABIN'] = {'code': '7.3', 'type': 0};
WMEPT.venue_defs['BED_AND_BREAKFAST'] = {'code': '7.4', 'type': 0};
//	OUTDOORS
WMEPT.venue_defs['PARK'] = {'code': '8.0', 'type': 1};
WMEPT.venue_defs['PLAYGROUND'] = {'code': '8.1', 'type': 0};
WMEPT.venue_defs['BEACH'] = {'code': '8.2', 'type': 1};
WMEPT.venue_defs['SPORTS_COURT'] = {'code': '8.3', 'type': 0};
WMEPT.venue_defs['GOLF_COURSE'] = {'code': '8.4', 'type': 1};
WMEPT.venue_defs['PLAZA'] = {'code': '8.5', 'type': 0};
WMEPT.venue_defs['PROMENADE'] = {'code': '8.6', 'type': 0};
WMEPT.venue_defs['POOL'] = {'code': '8.7', 'type': -2}; // undefinded in wiki
WMEPT.venue_defs['SCENIC_LOOKOUT_VIEWPOINT'] = {'code': '8.8', 'type': 0};
WMEPT.venue_defs['SKI_AREA'] = {'code': '8.9', 'type': 1};
//	NATURAL_FEATURES
WMEPT.venue_defs['ISLAND'] = {'code': '9.0', 'type': 1};
WMEPT.venue_defs['SEA_LAKE_POOL'] = {'code': '9.1', 'type': 1};
WMEPT.venue_defs['RIVER_STREAM'] = {'code': '9.2', 'type': 1};
WMEPT.venue_defs['FOREST_GROVE'] = {'code': '9.3', 'type': 1};
WMEPT.venue_defs['FARM'] = {'code': '9.4', 'type': -1};
//	Translations
WMEPT.translations = {}
WMEPT.translations.fr = {};
WMEPT.translations.fr[0] = 'Masquer';
WMEPT.translations.fr[1] = 'Visible sur le smartphone';
WMEPT.translations.fr[2] = 'Informations supplémentaires';
WMEPT.translations.fr[3] = 'Oui';
WMEPT.translations.fr[4] = 'Non';
WMEPT.translations.fr[5] = 'Afficher tout';
WMEPT.translations.fr[6] = 'Filtre';
WMEPT.translations.fr[7] = 'Options / Outils';
WMEPT.translations.fr[8] = 'Aucun';
WMEPT.translations.fr[9] = 'Par défaut';
WMEPT.translations.fr[10] = 'Tous';
WMEPT.translations.fr[11] = 'Colorisation globale';
WMEPT.translations.fr[12] = 'Coloriser les POI invisibles sur le client';
WMEPT.translations.fr[13] = 'Utiliser la colorisation du LiveMap';
WMEPT.translations.fr[14] = 'Catégories';
WMEPT.translations.fr[15] = 'Masquer cette catégorie';
WMEPT.translations.fr[16] = 'Ne <span style="font-weight: bold;">JAMAIS</span> représenter';
WMEPT.translations.fr[17] = 'Cette zone <span style="font-weight: bold;">DOIT</span> être un point';
WMEPT.translations.fr[18] = 'Ce point<span style="font-weight: bold;">DOIT</span> être une zone';
WMEPT.translations.fr[19] = 'Cette zone <span style="font-weight: bold;">DEVRAIT</span> être un point.<br>Elle est trop petite pour être affichée sur le client.';
WMEPT.translations.fr[20] = 'Cette zone <span style="font-weight: bold;">EST</span> trop petite pour être affichée sur le client.</p><p>Vous pouvez toutefois tenter de l\'agrandir en y ajoutant le parking attenant (+5m min).';
WMEPT.translations.fr[21] = 'Utilisation d\'une catégorie principale';
WMEPT.translations.fr[22] = {text:"Parking sans nom", wiki:"https://wiki.waze.com/wiki/Lieux/Parkings#Nommage", link:"Nommer en [P]"};
WMEPT.translations.fr[23] = 'On-Off';
WMEPT.translations.fr[24] = 'Hauteur de la boite (N/S)';
WMEPT.translations.fr[25] = 'Largeur de la boite (E/O)';
WMEPT.translations.fr[26] = 'Aire réelle';
WMEPT.translations.en = {};
WMEPT.translations.en[0] = 'Hide';
WMEPT.translations.en[1] = 'Venue is visible on client';
WMEPT.translations.en[2] = 'Extra informations';
WMEPT.translations.en[3] = 'Yes';
WMEPT.translations.en[4] = 'No';
WMEPT.translations.en[5] = 'Show all';
WMEPT.translations.en[6] = 'Filter';
WMEPT.translations.en[7] = 'Options / Tools';
WMEPT.translations.en[8] = 'None';
WMEPT.translations.en[9] = 'Reset to default';
WMEPT.translations.en[10] = 'All';
WMEPT.translations.en[11] = 'General highlight';
WMEPT.translations.en[12] = 'Highlight too small landmarks';
WMEPT.translations.en[13] = 'Use livemap coloration style';
WMEPT.translations.en[14] = 'Categories';
WMEPT.translations.en[15] = 'Hide this place type';
WMEPT.translations.en[16] = '<span style="font-weight: bold;">NEVER</span> draw';
WMEPT.translations.en[17] = 'This area <span style="font-weight: bold;">MUST</span> be a point';
WMEPT.translations.en[18] = 'This point<span style="font-weight: bold;">MUST</span> be an area';
WMEPT.translations.en[19] = 'This area <span style="font-weight: bold;">SHOULD</span> be a point.<br>The area is too small to be visible on the phone';
WMEPT.translations.en[20] = 'This area <span style="font-weight: bold;">IS</span> too small to be visible on the phone.</p><p>Try to increase it (+5m max).';
WMEPT.translations.en[21] = 'Do NOT uses a main categorie';
WMEPT.translations.en[22] = {text:"Unnamed parking", wiki:"https://wiki.waze.com/wiki/Places/Parking_lot#Naming", link:"Fix to [P]"};
WMEPT.translations.en[23] = 'On-Off';
WMEPT.translations.en[24] = 'Box height (N/S)';
WMEPT.translations.en[25] = 'Box width (E/O)';
WMEPT.translations.en[26] = 'Real area';
WMEPT.translations.cs = {};
WMEPT.translations.cs[0] = 'Skrýt';
WMEPT.translations.cs[1] = 'Místo je zobrazeno v klientu';
WMEPT.translations.cs[2] = 'Další informace';
WMEPT.translations.cs[3] = 'Ano';
WMEPT.translations.cs[4] = 'Ne';
WMEPT.translations.cs[5] = 'Zobrazit vše';
WMEPT.translations.cs[6] = 'Filtr';
WMEPT.translations.cs[7] = 'Nastavení';
WMEPT.translations.cs[8] = 'Nic';
WMEPT.translations.cs[9] = 'Obnovit výchozí';
WMEPT.translations.cs[10] = 'Vše';
WMEPT.translations.cs[11] = 'Obecné zvýraznění';
WMEPT.translations.cs[12] = 'Zvýraznit příliš malá místa';
WMEPT.translations.cs[13] = 'Použít barevný styl livemap';
WMEPT.translations.cs[14] = 'Kategorie';
WMEPT.translations.cs[15] = 'Skrýt tento typ míst';
WMEPT.translations.cs[16] = '<span style="font-weight: bold;">NIKDY</span> nekreslit';
WMEPT.translations.cs[17] = 'Toto místo <span style="font-weight: bold;">MUSÍ</span> být bod';
WMEPT.translations.cs[18] = 'Toto místo<span style="font-weight: bold;">MUSÍ</span> být plocha';
WMEPT.translations.cs[19] = 'Toto místo <span style="font-weight: bold;">BY MĚLO</span> být bod.<br>Plocha prvku je příliš malá pro zobrazení v klientu';
WMEPT.translations.cs[20] = 'Tato plocha <span style="font-weight: bold;">JE</span> příliš malá pro zobrazení v klientu.</p><p>Zkuste ji zvětšit (maximálně o 5 metrů).';
WMEPT.translations.cs[21] = 'NEPOUŽÍVEJTE obecné kategorie';
WMEPT.translations.cs[22] = {text:"Nepojmenované parkoviště", wiki:"https://wiki.waze.com/wiki/M%C3%ADsta#Parkovi.C5.A1t.C4.9B", link:"Pojmenovat [P]"};
WMEPT.translations.cs[23] = 'Zapnout/Vypnout';
WMEPT.translations.cs[24] = 'Výška prvku';
WMEPT.translations.cs[25] = 'Šířka prvku';
WMEPT.translations.cs[26] = 'Plocha prvku';
var HL_options = [];
var isReset = false;
var requested_div = "";
var pin_error = '';
var pin_missused = '';


/* bootstrap, will call HL_init() */
function HL_bootstrap(){
	HL_addLog(1, 'info', 'init');
	// if (typeof(unsafeWindow) === "undefined"){
		// unsafeWindow = ( function () {
			// var dummyElem = document.createElement('p');
			// dummyElem.setAttribute('onclick', 'return window;');
			// return dummyElem.onclick();
		// }) ();
	// }
	// /* begin running the code! */
	setTimeout(HL_init, 1000);
}

/* helper function */
function getElementsByClassName(classname, node) {
  if(!node) node = document.getElementsByTagName("body")[0];
  var a = [];
  var re = new RegExp('\\b' + classname + '\\b');
  var els = node.getElementsByTagName("*");
  for (var i=0,j=els.length; i<j; i++)
    if (re.test(els[i].className)) a.push(els[i]);
  return a;
}

function getId(node) {
  return document.getElementById(node);
}

function DOMDataFilter(obj){
	return JSON.parse(JSON.stringify(obj));
}

function getSelectedValue(node){
	var t = getId(node);
	return t.options[t.selectedIndex].value;
}

function PT_int_trans(Index_need2beTrans){
	if(typeof(WMEPT.translations[HL_cur_lng]) != 'undefined'){
		switch(typeof(WMEPT.translations[HL_cur_lng][Index_need2beTrans])){
			case 'string':
				return WMEPT.translations[HL_cur_lng][Index_need2beTrans];
			case 'object':
				if(arguments.length > 1){
					return WMEPT.translations[HL_cur_lng][Index_need2beTrans][arguments[1]];
				}
		}
	}
	switch(typeof(WMEPT.translations.en[Index_need2beTrans])){
		case 'string':
			return WMEPT.translations.en[Index_need2beTrans] + ' (u)';
		case 'object':
			if(arguments.length > 1){
				return WMEPT.translations.en[Index_need2beTrans][arguments[1]] + ' (u)';
			}
		default:
			return 'Error nothing is defined, alert author plz';
	}
}

function HL_getTranslations(){
	HL_def_translations = HL_translations[HL_def_lng];
	HL_available_translations = HL_translations[HL_cur_lng];
	if(HL_available_translations.venues){
		HL_categories_translations = HL_available_translations.venues.categories;
	}
	else{
		HL_categories_translations = HL_def_translations.venues.categories;
	}
	HL_SortTranslatedPOI(HL_categories_translations);
}

function HL_SortTranslatedPOI(theObj){
	HL_translatedPOI = [];
	for(var i in theObj){
		HL_translatedPOI.push({'key':i, 'value':theObj[i]});
    }
	HL_translatedPOI.sort(function(a,b){return a.value.localeCompare(b.value);});
}

function clacAngle(){
/*
	fA = Sqr(((Xc - Xb) ^ 2) + ((Yc - Yb) ^ 2)) 'distance entre b et c
	fB = Sqr(((Xc - Xa) ^ 2) + ((Yc - Ya) ^ 2)) 'distance entre a et c
	fC = Sqr(((Xb - Xa) ^ 2) + ((Yb - Ya) ^ 2)) 'distance entre a et b
	fAngle = ((fA ^ 2) + (fC ^ 2) - (fB ^ 2)) / (2 * fA * fC) '(a2 + c2 - b2) / (2*a*c)
	Acos(fAngle) 'inverse du cosinus
	Degrees(fAngle) 'fonction degree
*/
}

function HL_addLog(HL_Level, HL_type, HL_text){
	if(HL_Level <= WMEPT.options.Debug_Level){
		var HLaL_text = 'WME_PT_' + WMEPT.version + ' : ' + HL_text;
		switch(HL_type){
			case 'info':
				console.info(HLaL_text);
				break;
			case 'error':
				console.error(HLaL_text);
				break;
			default:
				console.log(HLaL_text);
				break;
		}
		if(typeof(arguments[3]) !== 'undefined'){
			console.debug(HLaL_text);
			console.debug(arguments[3]);
		}
	}
}

function getVenues(){
	//	les catégories
	PT_Cat = [];
	PT_Cat = DOMDataFilter(HL_config_venues.categories);
	HL_addLog(2, 'info', 'PT_Cat', PT_Cat);
	//	Les définitions de lieux et points
	var l = 0;
	var warn_author = false;
	for(var i=0; i<PT_Cat.length; i++){
		var SCat = DOMDataFilter(HL_config_venues.subcategories[PT_Cat[i]]);
		HL_addLog(2, 'info', 'SCat', SCat);
		var SCatLen = SCat.length;
		for(var j=0; j<SCatLen; j++){
			var found = false;
			var code = i+'.'+j;
			//	now search for the defined obj
			var index = 0;
			for(var k in WMEPT.venue_defs){
				//	Same subcategory
				if(k.localeCompare(SCat[j]) == 0){
					//	Different code
					if(WMEPT.venue_defs[k].code != code){
						WMEPT.venue_defs[k].code = code;
						WMEPT.venue_defs[k].comment = 'Code has changed';
						warn_author = true;
						if(HL_user.id == 39613931)HL_addLog(1, 'info', 'Some category code changed : ' + k + ' :: ' + code);
					}
					WMEPT.venue_defs[k].name = SCat[j];
					WMEPT.venue_defs[k].parent = PT_Cat[i];
					found = true;
					index++;
					break;
				}
			}
			//	or add a new obj
			if(!found){
				index++;
				WMEPT.venue_defs[SCat[j]] = {'code': code, 'type': '-2', 'name': SCat[j], 'parent': PT_Cat[i], 'comment': 'not defined in wiki'};
				if(HL_user.id == 39613931){
					warn_author = true;
					HL_addLog(1, "info", 'New subcategory; Check :' + PT_Cat[i] + ' :: ' + SCat[j] + ' ::: ' + code);
				}
			}
		}
	}
	if(warn_author && HL_user.id == 39613931)alert('There are some changes in subcategories. Check logs');
	HL_addLog(1, 'info', 'venue loaded', WMEPT);
}

function checkVenue(venue){
	//	-3 : never warn - -2 : undefined in wiki(warn the author only) - -1 : on représente pas - 0 : lieu - 1 : zone - 2 : au choix (dépends de la taille (X ou Y) > 50m ) - 3 : pas de catégorie en source - 4 : Parking sans nom
	var categorie = venue.attributes.categories[0];
	//	Cas des parkings		A FAIRE!!!
	if(categorie == "PARKING_LOT"){
		if(venue.attributes.name == ""){
			return 4;
		}
	}
	//	En général
	for(var i in WMEPT.venue_defs){
		var venue_def = WMEPT.venue_defs[i];
		//	Catégorie en type == erreur
		if(venue_def.parent == categorie){
			return 3;
		}
		//	correspond à une sous catégorie
		if(venue_def.name == categorie){
			return venue_def.type;	//	-3, -2, -1, 0, 1, 2
		}
	}
	return -3;
}

function FixParkingLot(isFree){
	switch(isFree){
		case true:
			HL_waze_model.actionManager.add(new HL_Waze.Action.UpdateObject(HL_selectionManager.selectedItems[0], {name: '[P]'}));
			break;
		case false:
			HL_waze_model.actionManager.add(new HL_Waze.Action.UpdateObject(HL_selectionManager.selectedItems[0], {name: '[P]€'}));
			break;
	}
}

function HL_POI_html_init(){
	//	Primary checks
	if(getId('HL_POI_extra_infos') != null)return;
	selVenue = HL_selectionManager.selectedItems[0];
	if(typeof(selVenue) === 'undefined')return;
	if(selVenue.type != 'venue')return;
	HL_POI_html();
}

function HL_POI_html(){
	//	Primary checks
	var LandGeometry = selVenue.geometry;
	if(typeof(LandGeometry) === 'undefined')return;
	var LandBounds = LandGeometry.bounds;
	if(typeof(LandBounds) === 'undefined')return;
	//	Landmark infos
	var WME_POI_infos = getId('landmark-edit-general');
	WME_HL_POI_addon = document.createElement('div');
	WME_HL_POI_addon.id = 'HL_POI_extra_infos';
	//	Area Vars
	var lm_width = Math.abs(LandBounds.left - LandBounds.right);
	var lm_height = Math.abs(LandBounds.bottom - LandBounds.top);
	var lm_is_visible = '<span style="color: red; font-weight: bold;">' + PT_int_trans(4) + '</span>';
	if(lm_width >= 50 || lm_height >= 50)lm_is_visible = '<span style="color: green;">' + PT_int_trans(3) + '</span>';
	//	HTML rendering
	WME_HL_POI_addon.innerHTML = '<hr><b>' + PT_int_trans(2) + '</b><br>';
	WME_HL_POI_addon.innerHTML += '- ' + PT_int_trans(1) + ' : ' + lm_is_visible + '<br>';
	if(isArea(selVenue)){
		var lm_aera = LandGeometry.getArea();
		WME_HL_POI_addon.innerHTML += '- ' + PT_int_trans(25) + ' : ' + (Math.round(lm_width * 100) / 100) + 'm<br>';
		WME_HL_POI_addon.innerHTML += '- ' + PT_int_trans(24) + ' : ' + (Math.round(lm_height * 100) / 100) + 'm<br>';
		WME_HL_POI_addon.innerHTML += '- ' + PT_int_trans(26) + ' : ' + (Math.round(lm_aera * 1) / 1) + ' m²<br>';
	}
	if(WMEPT.options['HL_on_off']){
		WME_HL_POI_addon.innerHTML += '<input type="button" id="_HL_btn_hide_all" value="' + PT_int_trans(15) + '" /><br>';
		// WME_HL_POI_addon.innerHTML += '<input type="button" id="_HL_btn_fix_geo" value="Fix place geometry" /><br>';
	}
	WME_POI_infos.appendChild(WME_HL_POI_addon);
	//	Event
	if(WMEPT.options['HL_on_off']){
		getId('_HL_btn_hide_all').onclick = HL_btn_Hider;
	}
	//	Place tools validator infos
	//	The new elem
	var showElem = false;
	var WME_POI_EC_HTML = document.createElement('div');
	WME_POI_EC_HTML.innerHTML = '<a href="' + WMEPT.script_URL + '" target="_blank">WME Places Tools</a> : validator<br/>';
	var testedVenue = checkVenue(selVenue);
	switch(testedVenue){
		case -3:
			break;
		case -2:
			break;
		case -1:
			showElem = true;
			WME_POI_EC_HTML.innerHTML += '<p style="color: red;">' + PT_int_trans(16) + '</p>';
			break;
		case 0:
			if(isArea(selVenue)){
				showElem = true;
				WME_POI_EC_HTML.innerHTML += '<p style="color: red;">' + PT_int_trans(17) + '</p>';
			}
			break;
		case 1:
			if(!isArea(selVenue)){
				showElem = true;
				WME_POI_EC_HTML.innerHTML += '<p style="color: red;">' + PT_int_trans(18) + '</p>';
			}
			break;
		case 2:
			if(isArea(selVenue)){
				showElem = true;
				switch(is2small(selVenue)){
					case 1:
						WME_POI_EC_HTML.innerHTML += '<p style="color: violet;">' + PT_int_trans(19) + '</p>';
						break;
					case 2:
						WME_POI_EC_HTML.innerHTML += '<p style="color: orange;">' + PT_int_trans(20) + '</p>';
						break;
				}
			}
			break;
		case 3:
			showElem = true;
			WME_POI_EC_HTML.innerHTML += '<p style="color: red;">' + PT_int_trans(21) + '</p>';
			break;
		case 4:
			showElem = true;
			var lang = '';
			if(typeof(HL_translations[HL_cur_lng].number) != 'object')lang = 'en';
			else if(typeof(HL_translations[HL_cur_lng].number.currency) != 'object')lang = 'en';
			else if(typeof(HL_translations[HL_cur_lng].number.currency.format) != 'object')lang = 'en';
			else lang = HL_cur_lng;
			WME_POI_EC_HTML.innerHTML += '<p><a href="' + PT_int_trans(22, 'wiki') + '" target="_blank" style="color: red;">' + PT_int_trans(22, 'text') + '</a></p><p style="text-align: center; width: 100%;"><input id="HL_Btn_fix_P" type="button" value="' + PT_int_trans(22, 'link') + '" /><span style="width: 15px;">&nbsp;</span><input id="HL_Btn_fix_PE" type="button" value="' + PT_int_trans(22, 'link') + HL_translations[lang].number.currency.format.unit + '" /></p>';
			break;
		default:
			showElem = true;
			WME_POI_EC_HTML.innerHTML += '<p>erreur</p>';
			break;
	}
	WME_POI_EC_HTML.innerHTML += '<hr />';
	//	the replacement
	if(showElem){
		var WME_edit_panel = getId('landmark-edit-general');
		var parentDiv = WME_edit_panel.parentNode;
		var theNewElem = parentDiv.insertBefore(WME_POI_EC_HTML, WME_edit_panel);
		if(testedVenue == 4){
			getId('HL_Btn_fix_P').onclick = function (){FixParkingLot(true);};
			getId('HL_Btn_fix_PE').onclick = function (){FixParkingLot(false);};
		}
	}
	HL_addLog(1, 'info', 'Renderred landmark extra infos');
}

function HL_btn_Hider(){
	getId('HL_' + selVenue.attributes.categories[0]).checked = true;
	HL_selectionManager.unselectAll();
}

function HL_html(){
	//	Les traductions
	HL_getTranslations();
	//	L'onglet
	newtab = document.createElement('li');
	newtab.id = 'HL_tab_selector';
	newtab.innerHTML = '<a href="#sidepanel-hidel" data-toggle="tab">' + WMEPT.script_name + '</a>';
	HL_navTabs.appendChild(newtab);
	//	Le contenant 1
	var addon = document.createElement('div');
	addon.id = "sidepanel-hidel";
	addon.className = "tab-pane";
	//	L'entête du contenu
	addon.innerHTML = '<b><a href="' + WMEPT.script_URL + '" target="_blank"><u>' + WMEPT.script_name + '</u></a></b> v ' + WMEPT.version;
	addon.innerHTML += '<span style="padding-left: 20px;"><input type="checkbox" id="HL_on_off" /><label style="padding-left: 5px;" for="HL_on_off">' + PT_int_trans(23) + '</label></span>';
	HL_tabContent.appendChild(addon);
	//	Les onglets du plugin
	myTabs = document.createElement('ul');
	myTabs.id = 'HL_tab_subselector';
	myTabs.className = "nav nav-tabs";
	myTabs.innerHTML = '<li class="active"><a href="#hidel-hidding" data-toggle="tab">' + PT_int_trans(0) + '</a></li>';
	myTabs.innerHTML += '<li class=""><a href="#hidel-tools" data-toggle="tab">' + PT_int_trans(7) + '</a></li>';
	// myTabs.innerHTML += '<li class=""><a href="#hidel-infos" data-toggle="tab">Infos</a></li>';
	addon.appendChild(myTabs);
	//	Le contenant 2
	var addon_tab_content = document.createElement('div');
	addon_tab_content.className = "tab-content";
	addon.appendChild(addon_tab_content);
	//	Le contenu 1
	var section = document.createElement('p');
	section.className = "tab-pane active";
	section.style.padding = "8px 16px";
	section.style.textIndent = "-16px";
	section.id = "hidel-hidding";
	//	Commons
	section.innerHTML = '<div style="text-align: center;">'
						+ '<input type="button" id="btn_hl_none" value="' + PT_int_trans(8) + '" /><span style="padding-left: 3px;"></span>'
						+ '<input type="button" id="btn_hl_reset" value="' + PT_int_trans(9) + '" /><span style="padding-left: 3px;"></span>'
						+ '<input type="button" id="btn_hl_all" value="' + PT_int_trans(10) + '" /></div>'
						+ '<div style="text-align: center;">'
						+ '<label for="text_hl_filter" style="padding-right: 5px;">' + PT_int_trans(6) + '</label><input type="button" id="btn_hl_FR" value="X" /><br />'
						+ '<input type="text" class="form-control" id="text_hl_filter" /></div>'
						+ '<div style="text-align: center;">'
						+ '<label for="PT_Cat_Filter" style="margin-right: 15px;" >' + PT_int_trans(14) + '</label><select id="PT_Cat_Filter">'
						+ '<option value="-1">' + PT_int_trans(5) + '</option>';
	section.innerHTML += '</select></div>'
						+ '<div id="HL_common"></div>';
	addon_tab_content.appendChild(section);
	//	populate dropdown list
	PT_sorted_Cat = DOMDataFilter(PT_Cat);
	PT_sorted_Cat.sort();
	/*		V1		*/
	var PT_select = getId('PT_Cat_Filter');
	for(var i=0; i < PT_sorted_Cat.length; i++){
		for(var j=0; j < PT_Cat.length; j++){
			if(PT_sorted_Cat[i] == PT_Cat[j]){
				var dummy = document.createElement('option');
				dummy.value = j;
				//	I18n.translations.fr.venues.categories
				if(typeof(HL_translations[HL_cur_lng]) != 'undefined'){
					if(typeof(HL_translations[HL_cur_lng].venues) != 'undefined'){
						if(typeof(HL_translations[HL_cur_lng].venues.categories) != 'undefined'){
							dummy.text = HL_translations[HL_cur_lng].venues.categories[PT_sorted_Cat[i]];
						}
					}
				}
				else{
					dummy.text = HL_translations.en.venues.categories[PT_sorted_Cat[i]];
				}
				PT_select.add(dummy);
			}
		}
	}
	//	Populate HL_common
	var Hl_common = getId('HL_common');
	for(var i=0; i<HL_translatedPOI.length; i++){
		Hl_common.innerHTML += '<div id="_HL_' + HL_translatedPOI[i].key + '" style="display: block;"><input type="checkbox" id="HL_' + HL_translatedPOI[i].key + '" >&nbsp;' + HL_translatedPOI[i].value;
		// <label style="padding-left: 20px;" for="' + HL_translatedPOI[i].key + '">' + HL_translatedPOI[i].value + '</label></<div>';
	}
	//	Le contenu 2
	var section = document.createElement('p');
	section.className = "tab-pane";
	section.style.padding = "8px 16px";
	section.style.textIndent = "-16px";
	section.id = "hidel-tools";
	section.innerHTML = '<b>' + PT_int_trans(7) + '</b><br>';
	section.innerHTML += '<input type="checkbox" id="lh_glh">&nbsp;' + PT_int_trans(11) + '<br>';
	section.innerHTML += '<input type="checkbox" id="st_sl">&nbsp;' + PT_int_trans(12) + '<br>';
	// section.innerHTML += '<input type="checkbox" id="h2l2">&nbsp;Highlight too high level landmark (not yet)<br>';
	// section.innerHTML += '<input type="button" id="d2_sl" value="Delete too small landmarks">&nbsp;(lvl 3)(not yet)<br>';
	section.innerHTML += '<input type="checkbox" id="pt_lmcs">&nbsp;' + PT_int_trans(13) + '<br>';
	addon_tab_content.appendChild(section);
	//	Events
	getId('PT_Cat_Filter').onchange = HL_HTML_filter;
	getId('btn_hl_reset').onclick = function(){	getId('PT_Cat_Filter').options[0].selected = true; isReset = true; HideDefaultOptions(); HL_HTML_filter();};
}

function HL_HTML_filter(){
	var filtre = getId('text_hl_filter').value.toLowerCase();
	for(var i=0; i<HL_translatedPOI.length; i++){
		// HL_addLog(3, 'info', 'HL_translatedPOI[i]', HL_translatedPOI[i]);
		var HL_string = HL_translatedPOI[i].value.toLowerCase();
		if(HL_string.indexOf(filtre) >= 0 && isInCat(HL_translatedPOI[i])){
			getId('_HL_' + HL_translatedPOI[i].key).style.display = 'block';
		}
		else{
			getId('_HL_' + HL_translatedPOI[i].key).style.display = 'none';
		}
	}
}

function isInCat(theSearch){
	var selCat = getId('PT_Cat_Filter');
	var selValue = selCat.value;
	if(selValue == -1)return true;
	for(var i in WMEPT.venue_defs){
		if(i == theSearch.key && selValue == WMEPT.venue_defs[i].code.split('.')[0])return true;
	}
	return false;
}

function ShowHideAll(theCheck){
	var HL_script = getId('hidel-hidding');
	var HL_script_inputs = HL_script.getElementsByTagName('input');
	var selValue = getId('PT_Cat_Filter').value;
	for(var i=0; i < HL_script_inputs.length; i++){
		if(selValue == -1){	//	tous
			HL_script_inputs[i].checked = theCheck;
			continue;
		}
		//	spécifique à la catégorie
		for(var j in WMEPT.venue_defs){
			var CatCode = WMEPT.venue_defs[j].code.split('.')[0];
			var CatName = 'HL_' + WMEPT.venue_defs[j].name;
			if(selValue == CatCode && HL_script_inputs[i].id == CatName){
				HL_script_inputs[i].checked = theCheck;
				break;
			}
		}
	}
}

//	On masque/affiche les places et +
function HideL(){
	getId('HL_on_off').checked?HL_landmarkLayer.setVisibility(true):HL_landmarkLayer.setVisibility(false);
	if(HL_waze_venues.active === true){
		for(var venue in HL_waze_venues.objects){
			var landmark = HL_waze_venues.get(venue);
			if(landmark.state == 'Insert')continue;
			var poly = getId(landmark.geometry.id);
			if(poly !== null){
				if(getId('HL_on_off').checked){
					WMEPT.options['HL_on_off'] = true;
					//	Check if visibility is allowed
					var theId = 'HL_' + landmark.attributes.categories[0];
					if(getId(theId).checked){
						poly.setAttribute("visibility", "hidden");
						continue;
					}
					else{
						poly.setAttribute("visibility", "visible");
					}
					//	General highlight
					if(getId('lh_glh').checked){
						var fillColor = "#999";
						var stroke = "#ccc";
						var fillOpacity = 0.5;
						//	Highlight 2 small valid landmark
						var isOk = true;
						if(getId('st_sl').checked){
							switch(is2small(landmark)){
								case 1:
									stroke = "#FF0000";
									fillColor = "#FF4D4D";
									isOk = false;
									break;
								case 2:
									stroke = "#FF0000";
									fillColor = "#FF9900";
									isOk = false;
									break;
							}
						}
						//	-3 : never warn - -2 : undefined in wiki(warn the author only) - -1 : on représente pas - 0 : lieu - 1 : zone - 2 : au choix (ou dépendent de la taille (X ou Y) > 50m ) - 3 : pas de catégorie en source
						var POI_type = checkVenue(landmark);
						switch(POI_type){
							case -3:	//	never warn
							case -2:	//	warn author, problem in defs
							case -1:	//	never represent
								break;
							case 0:	//	point
								if(isArea(landmark)){
									stroke = "#7821AD";
									fillColor = "#AD41F0";
									isOk = false;
								}
								break;
							case 1:	//	area
								if(!isArea(landmark)){
									var poi = getId(landmark.geometry.id);
									poi.setAttribute('href', pin_error);
									isOk = false;
								}
								break;
							case 2: // both but size dependent
								if(isArea(landmark)){
									switch(is2small(landmark)){
										case 1:
											stroke = "#7821AD";
											fillColor = "#AD41F0";
											isOk = false;
											break;
										case 2:
											stroke = "#FF0000";
											fillColor = "#FF9900";
											isOk = false;
											break;
									}
								}
								break;
							case 3:	//	error, do NOT use a main category as a subcategory
								isOk = false;
								if(isArea(landmark)){
									stroke = "#3737C4";
									fillColor = "#A1A1F6";
								}
								else{
									var poi = getId(landmark.geometry.id);
									poi.setAttribute('href', pin_missused);
								}
								break;
							case 4:	//	unnamed parking lot
								stroke = "#00A";
								fillColor = "#FF4D4D";
								break;
						}
						//	Default coloring (livemap style)
						if(isOk && getId('pt_lmcs').checked){
							switch(landmark.attributes.categories[0]){
								case 'PARKING_LOT':
									stroke = "#00A";
									// fillColor = "#E7E7E7";
									break;
								case 'RIVER_STREAM':
								case 'SEA_LAKE_POOL':
									stroke = "#4C6198";
									fillColor = "#03B9DA";
									break;
								case 'HOSPITAL_MEDICAL_CARE':
								case 'PET_STORE_VETERINARIAN_SERVICES':
									stroke = "#ED10E6";
									fillColor = "#E39AE1";
									break;
								case 'CEMETERY':
									stoke = "#B6BFB1";
									fillcolor = "#D6DED2";
									break;
							}
						}
						poly.setAttribute("stroke", stroke);
						poly.setAttribute("fill", fillColor);
						poly.setAttribute("fill-opacity",fillOpacity);
						continue;
					}
					else{
						poly.setAttribute("visibility", "visible");
						poly.setAttribute("fill", "#d191d6");
						poly.setAttribute("stroke", "#d191d6");
						poly.setAttribute("fill-opacity", 0.3);
					}
				}
				else{
					WMEPT.options['HL_on_off'] = false;
					poly.setAttribute("visibility", "visible");
					poly.setAttribute("fill", "#d191d6");
					poly.setAttribute("stroke", "#d191d6");
					poly.setAttribute("fill-opacity", 0.3);
				}
			}
		}
	}
}

function is2small(landmark){
	if(HL_waze_Map.zoom < 5)return 0;
	if(!getId('st_sl').checked)return 0;
	var LandBounds = landmark.geometry.bounds;
	var v_Dist = Math.abs(LandBounds.bottom - LandBounds.top);
	var h_Dist = Math.abs(LandBounds.left - LandBounds.right);
	if(v_Dist < 45 && h_Dist < 45)return 1;
	if(v_Dist < 50 && h_Dist < 50)return 2;
	return 0;
}

function isArea(venue){
	var LandBounds = venue.geometry.bounds;
	return ((LandBounds.left == LandBounds.right) && (LandBounds.bottom == LandBounds.top))? false : true;
}

//	On vérifie les options pour la sauvegarde
function HL_CheckOptions(){
	getInputs('hidel-hidding');
	getInputs('hidel-tools');
	//	On-Off
	addRemove(getId('HL_on_off'));
}

function getInputs(divId){
	var HL_script = getId(divId);
	var HL_script_inputs = HL_script.getElementsByTagName('input');
	for(var i=0; i < HL_script_inputs.length; i++){
		addRemove(HL_script_inputs[i]);
	}
}

function addRemove(DOMinput){
	//	Ajout
	if(DOMinput.checked === true){
		if(HL_options.indexOf(DOMinput.id) == -1){
			HL_options.push(DOMinput.id);
		}
	}
	//	Retrait
	else{
		if(HL_options.indexOf(DOMinput.id) > -1){
			HL_options.splice(HL_options.indexOf(DOMinput.id),1);
		}
	}
}

//	restore saved settings
function HL_restoreOptions(){
	if(localStorage.WMEPTScript) {
		HL_options = JSON.parse(localStorage.WMEPTScript);
		for(var i=0; i < HL_options.length; i++){
			getId(HL_options[i]).checked = true;
		}
	}
	//	Default options
	else{
		getId('HL_on_off').checked = true;
		getId('lh_glh').checked = true;
		getId('st_sl').checked = true;
		getId('pt_lmcs').checked = true;
		HideDefaultOptions();
	}
}

function HideDefaultOptions(){
	if(isReset === true){
		var HL_script = getId('hidel-hidding');
		var HL_script_inputs = HL_script.getElementsByTagName('input');
		for(var i=0; i < HL_script_inputs.length; i++){
			HL_script_inputs[i].checked = false;
		}
	}
	getId('HL_PARK').checked = true;
	getId('HL_FOREST_GROVE').checked = true;
	getId('HL_SEA_LAKE_POOL').checked = true;
	getId('HL_RIVER_STREAM').checked = true;
	isReset = false;
	HL_CheckOptions();
}

//	overload the WME exit function
function HL_saveOptions(){
	if(localStorage){
		HL_CheckOptions();
		var HL_options_JSON = JSON.stringify(HL_options);
		localStorage.WMEPTScript = HL_options_JSON;
		HL_addLog(1, 'info', 'options saved');
	}
}

function HL_init(){
	//	Waze object needed
	if(typeof(unsafeWindow.Waze) == 'undefined'){
		HL_addLog(1, 'error', 'unsafeWindow.W NOK', unsafeWindow.Waze);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_Waze = unsafeWindow.Waze;
	if(typeof(HL_Waze.Config) == 'undefined'){
		HL_addLog(1, 'error', 'Config NOK', HL_Waze.Config);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_waze_config = HL_Waze.Config;
	if(typeof(HL_waze_config.ready) == 'undefined'){
		HL_addLog(1, 'error', 'Config NOK', HL_waze_config.ready);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_config_ready = HL_waze_config.ready;
	var HL_status = HL_config_ready.state();
	if(HL_status != 'resolved'){
		HL_addLog(1, 'error', 'Config status', HL_status);
		window.setTimeout(HL_init, 500);
		return;
	}
	if(typeof(HL_Waze.location) == 'undefined'){
		HL_addLog(1, 'error', 'HL_env NOK', HL_Waze.location);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_env = HL_Waze.location;
	if(typeof(HL_Waze.map) == 'undefined'){
		HL_addLog(1, 'error', 'map NOK', HL_Waze.map);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_waze_Map = HL_Waze.map;
	if(typeof(HL_waze_Map.landmarkLayer) == 'undefined'){
		HL_addLog(1, 'error', 'landmarkLayer NOK', HL_waze_Map.landmarkLayer);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_landmarkLayer = HL_waze_Map.landmarkLayer;
	if(typeof(HL_Waze.model) == 'undefined'){
		HL_addLog(1, 'error', 'model NOK', HL_Waze.model);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_waze_model = HL_Waze.model;
	HL_selectionManager = HL_Waze.selectionManager;
	if(typeof(HL_selectionManager) == 'undefined'){
		HL_addLog(1, 'error', 'selectionManager NOK', HL_selectionManager);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_loginManager = HL_Waze.loginManager;
	if(typeof(HL_loginManager) == 'undefined'){
		HL_addLog(1, 'error', 'loginManager NOK', HL_loginManager);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_user = HL_loginManager.user;
	if(typeof(HL_user) == 'undefined'){
		HL_addLog(1, 'error', 'user NOK', HL_user);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_waze_venues = HL_waze_model.venues;
	if(typeof(HL_waze_venues) == 'undefined'){
		HL_addLog(1, 'error', 'venues NOK');
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_config_venues = HL_Waze.Config.venues;
	if(typeof(HL_config_venues) == 'undefined'){
		HL_addLog(1, 'error', 'HL_config_venues NOK', HL_config_venues);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_addLog(1, 'info', 'Waze OK');
	//	Waze GUI needed
	HL_userTabs = getId('user-info');
	if(typeof(HL_userTabs) == 'undefined'){
		HL_addLog('error', 'userTabs NOK', HL_userTabs);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_editPanel = getId('edit-panel');
	if(typeof(HL_editPanel) == 'undefined'){
		HL_addLog(1, 'error', 'editPanel NOK', HL_editPanel);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_navTabs = HL_userTabs.getElementsByTagName('ul')[0];
	if(typeof(HL_navTabs) == 'undefined'){
		HL_addLog(1, 'error', 'navTabs NOK', HL_navTabs);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_tabContent = HL_userTabs.getElementsByTagName('div')[0];
	if(typeof(HL_tabContent) == 'undefined'){
		HL_addLog(1, 'error', 'tabContent NOK', HL_tabContent);
		window.setTimeout(HL_init, 500);
		return;
	}
	HL_addLog(1, 'info', 'GUI OK');
	//	Traductions
	if(typeof(unsafeWindow.I18n) == 'undefined'){
		HL_addLog(1, 'error', 'translations system NOK');
		setTimeout(HL_init, 500);
		return;
	}
	HL_I18n = unsafeWindow.I18n;
	if(typeof(HL_I18n.translations) == 'undefined'){
		HL_addLog(1, 'error', 'translations NOK');
		setTimeout(HL_init, 500);
		return;
	}
	HL_translations = HL_I18n.translations;
	if(typeof(HL_I18n.locale) == 'undefined'){
		setTimeout(HL_init, 500);
		return;
	}
	HL_cur_lng = HL_I18n.locale;
	HL_def_lng = 'en';
	HL_addLog(1, 'info', 'Traductions OK');
	//	Then do the job
	getVenues();
	HL_html();
	//	restore saved settings
	HL_restoreOptions();
	//	Btn / radio Events
	getId('lh_glh').onchange = HideL;
	getId('st_sl').onchange = HideL;
	getId('HL_on_off').onchange = HideL;
	getId('btn_hl_none').onclick = function (){ShowHideAll(false);};
	getId('btn_hl_all').onclick = function (){ShowHideAll(true);};
	getId('btn_hl_FR').onclick = function (){getId('text_hl_filter').value=''; getId('PT_Cat_Filter').options[0].selected = true;
HL_HTML_filter();};
	getId('text_hl_filter').onkeyup = HL_HTML_filter;
	//	Waze events
	HL_selectionManager.events.register("selectionchanged", null, HL_POI_html_init);
	HL_selectionManager.events.register("selectionchanged", null, HideL);
	HL_waze_Map.events.register("mergeend", null, HideL);
	HL_waze_Map.events.register("zoomeend", null, HideL);
	//	Periodics updates
	window.setInterval(HideL, 250);
	//	beforeunload WME overload
	window.addEventListener("beforeunload", HL_saveOptions, false);
	WMEPT.loaded = true;
	HL_addLog(1, 'info', 'WMEPT loaded');
}

/* engage! =================================================================== */
HL_bootstrap();
/* end ======================================================================= */

/*	Version 0.9
	Add : category filtering in places tools tab : 0.9b1
	Add : translations FR, EN, CS (thx Zirland) : 0.9b4
	Add : simple venue layer activation, toggle the on-off checkbox (user request) : 0.9b2
	Fix : bug with chrome (thx zirland who found it) : 0.9b4
	Fix : bug in hide venue filtering on chrome (thx DummyD2) : 0.9b1
	Improvement : Extend none and all buttons functionalities (only cat filter ability) : 0.9b2
	Improvement : reset buttons (filter and defaults) now performs cat reset : 0.9b2
	Update : Other/RESIDENCE_HOME -> point (do not represent before) (28/07/2014) : 0.9b2
*/

/*	Version 0.8
	Add : blue pin; point misused main category instead of category
	Add : new area colouring : blue border, red background : unnamed parking lot
	Add : what to do on a problematic pin or area (validator style).
	Add : 2 default buttons to fix unnamed parking lot
	Fix : bug in venues acquisition (thx DummyD2)
	Fix : bug in chrome venues (thx DummyD2)
*/

/*	Version 0.7
	Add : livemap colouration style on/off (on by default)
	Fix : script crash on untranslated venues (thx tkr85)
*/

/*	Version 0.6
	Fix : 2 bugs in tab options
	Fix : bug in colouration rules(thx PHIL-IP63)
*/

/*	Version 0.5
	Add : area general highlight inspired from livemap
	Improvement : better system detection on WME changes
*/

/*	Version 0.4
	Add : detect changes in venue definitions (new one added by waze)
	Add : venue type selection depending on venue size
	Fix : bug in definitions
	Update : Hôpital / Centre médical :: from area to both
*/

/*	Version 0.3.1
-	fix : bug selection (once again :/)
*/

/*	Version 0.3
-	add : red pin for incorrect pin usage
-	fix : bug selection, thx to DummyD2
*/

/*	Version 0.2.1
- update : changed the misused main category. from red to blue
*/

/*	Version 0.2
- Add : colouring venue (areas) according to the wiki recommendations.
- Fix : some bug and non senses
*/

/*	Version 0.1
- First release
*/

/*	TODO
-1 : détecter zone dans une zone
-2 : determine if roads running threw parking lots are set as parking lot roads
-3 : removing useless geometrical nodes
-4 : merge 2 POI (landmark)
*/