WME Place tools

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

目前為 2014-07-12 提交的版本,檢視 最新版本

// ==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.8
// @grant               none
// @copyright   		2014, Myriades
// ==/UserScript==

/* Global vars */
window.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', 'Debug_Level': 3, 'options': {}, 'venue_defs': {}};
window.WMEPT.options = {'HL_on_off': true};
//	-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
window.WMEPT.venue_defs['GAS_STATION'] = {'code': '0.0', 'type': 1};
window.WMEPT.venue_defs['PARKING_LOT'] = {'code': '0.1', 'type': -3};
window.WMEPT.venue_defs['GARAGE_AUTOMOTIVE_SHOP'] = {'code': '0.2', 'type': 0};
window.WMEPT.venue_defs['CAR_WASH'] = {'code': '0.3', 'type': 0};
window.WMEPT.venue_defs['CHARGING_STATION'] = {'code': '0.4', 'type': 0};
//	Transportation
window.WMEPT.venue_defs['AIRPORT'] = {'code': '1.0', 'type': 1};
window.WMEPT.venue_defs['BUS_STATION'] = {'code': '1.1', 'type': 0};
window.WMEPT.venue_defs['FERRY_PIER'] = {'code': '1.2', 'type': 0};
window.WMEPT.venue_defs['SEAPORT_MARINA_HARBOR'] = {'code': '1.3', 'type': 2};
window.WMEPT.venue_defs['SUBWAY_STATION'] = {'code': '1.4', 'type': 0};
window.WMEPT.venue_defs['TRAIN_STATION'] = {'code': '1.5', 'type': 0};
window.WMEPT.venue_defs['BRIDGE'] = {'code': '1.6', 'type': 1};
window.WMEPT.venue_defs['TUNNEL'] = {'code': '1.7', 'type': 1};
window.WMEPT.venue_defs['TAXI_STATION'] = {'code': '1.8', 'type': 0};
window.WMEPT.venue_defs['JUNCTION_INTERCHANGE'] = {'code': '1.9', 'type': 1};
//	PROFESSIONAL_AND_PUBLIC
window.WMEPT.venue_defs['COLLEGE_UNIVERSITY'] = {'code': '2.0', 'type': 1};
window.WMEPT.venue_defs['SCHOOL'] = {'code': '2.1', 'type': 1};
window.WMEPT.venue_defs['CONVENTIONS_EVENT_CENTER'] = {'code': '2.2', 'type': 2};
window.WMEPT.venue_defs['GOVERNMENT'] = {'code': '2.3', 'type': 0};
window.WMEPT.venue_defs['LIBRARY'] = {'code': '2.4', 'type': 0};
window.WMEPT.venue_defs['CITY_HALL'] = {'code': '2.5', 'type': 0};
window.WMEPT.venue_defs['ORGANIZATION_OR_ASSOCIATION'] = {'code': '2.6', 'type': 0};
window.WMEPT.venue_defs['PRISON_CORRECTIONAL_FACILITY'] = {'code': '2.7', 'type': 1};
window.WMEPT.venue_defs['COURTHOUSE'] = {'code': '2.8', 'type': 0};
window.WMEPT.venue_defs['CEMETERY'] = {'code': '2.9', 'type': 1};
window.WMEPT.venue_defs['FIRE_DEPARTMENT'] = {'code': '2.10', 'type': 0};
window.WMEPT.venue_defs['POLICE_STATION'] = {'code': '2.11', 'type': 0};
window.WMEPT.venue_defs['MILITARY'] = {'code': '2.12', 'type': 1};
window.WMEPT.venue_defs['HOSPITAL_MEDICAL_CARE'] = {'code': '2.13', 'type': 2};
window.WMEPT.venue_defs['OFFICES'] = {'code': '2.14', 'type': 2};
window.WMEPT.venue_defs['POST_OFFICE'] = {'code': '2.15', 'type': 0};
window.WMEPT.venue_defs['RELIGIOUS_CENTER'] = {'code': '2.16', 'type': 0};
window.WMEPT.venue_defs['KINDERGARDEN'] = {'code': '2.17', 'type': 0};
window.WMEPT.venue_defs['FACTORY_INDUSTRIAL'] = {'code': '2.18', 'type': 2};
window.WMEPT.venue_defs['EMBASSY_CONSULATE'] = {'code': '2.19', 'type': 1};
window.WMEPT.venue_defs['INFORMATION_POINT'] = {'code': '2.20', 'type': 0};
//	SHOPPING_AND_SERVICES
window.WMEPT.venue_defs['ARTS_AND_CRAFTS'] = {'code': '3.0', 'type': 0};
window.WMEPT.venue_defs['BANK_FINANCIAL'] = {'code': '3.1', 'type': 0};
window.WMEPT.venue_defs['SPORTING_GOODS'] = {'code': '3.2', 'type': 0};
window.WMEPT.venue_defs['BOOKSTORE'] = {'code': '3.3', 'type': 0};
window.WMEPT.venue_defs['PHOTOGRAPHY'] = {'code': '3.4', 'type': 0};
window.WMEPT.venue_defs['CAR_DEALERSHIP'] = {'code': '3.5', 'type': 2};
window.WMEPT.venue_defs['FASHION_AND_CLOTHING'] = {'code': '3.6', 'type': 0};
window.WMEPT.venue_defs['CONVENIENCE_STORE'] = {'code': '3.7', 'type': 0};
window.WMEPT.venue_defs['PERSONAL_CARE'] = {'code': '3.8', 'type': 0};
window.WMEPT.venue_defs['DEPARTMENT_STORE'] = {'code': '3.9', 'type': 0};
window.WMEPT.venue_defs['PHARMACY'] = {'code': '3.10', 'type': 0};
window.WMEPT.venue_defs['ELECTRONICS'] = {'code': '3.11', 'type': 0};
window.WMEPT.venue_defs['FLOWERS'] = {'code': '3.12', 'type': 0};
window.WMEPT.venue_defs['FURNITURE_HOME_STORE'] = {'code': '3.13', 'type': 0};
window.WMEPT.venue_defs['GIFTS'] = {'code': '3.14', 'type': 0};
window.WMEPT.venue_defs['GYM_FITNESS'] = {'code': '3.15', 'type': 0};
window.WMEPT.venue_defs['SWIMMING_POOL'] = {'code': '3.16', 'type': 0};
window.WMEPT.venue_defs['HARDWARE_STORE'] = {'code': '3.17', 'type': 0};
window.WMEPT.venue_defs['MARKET'] = {'code': '3.18', 'type': 0};
window.WMEPT.venue_defs['SUPERMARKET_GROCERY'] = {'code': '3.19', 'type': 2};
window.WMEPT.venue_defs['JEWELRY'] = {'code': '3.20', 'type': 0};
window.WMEPT.venue_defs['LAUNDRY_DRY_CLEAN'] = {'code': '3.21', 'type': 0};
window.WMEPT.venue_defs['SHOPPING_CENTER'] = {'code': '3.22', 'type': 1};
window.WMEPT.venue_defs['MUSIC_STORE'] = {'code': '3.23', 'type': 0};
window.WMEPT.venue_defs['PET_STORE_VETERINARIAN_SERVICES'] = {'code': '3.24', 'type': 0};
window.WMEPT.venue_defs['TOY_STORE'] = {'code': '3.25', 'type': 0};
window.WMEPT.venue_defs['TRAVEL_AGENCY'] = {'code': '3.26', 'type': 0};
window.WMEPT.venue_defs['ATM'] = {'code': '3.27', 'type': 0};
window.WMEPT.venue_defs['CURRENCY_EXCHANGE'] = {'code': '3.28', 'type': 0};
window.WMEPT.venue_defs['CAR_RENTAL'] = {'code': '3.29', 'type': 0};
//	FOOD_AND_DRINK
window.WMEPT.venue_defs['RESTAURANT'] = {'code': '4.0', 'type': 0};
window.WMEPT.venue_defs['BAKERY'] = {'code': '4.1', 'type': 0};
window.WMEPT.venue_defs['DESSERT'] = {'code': '4.2', 'type': 0};
window.WMEPT.venue_defs['CAFE'] = {'code': '4.3', 'type': 0};
window.WMEPT.venue_defs['FAST_FOOD'] = {'code': '4.4', 'type': 0};
window.WMEPT.venue_defs['FOOD_COURT'] = {'code': '4.5', 'type': 0};
window.WMEPT.venue_defs['BAR'] = {'code': '4.6', 'type': 0};
window.WMEPT.venue_defs['ICE_CREAM'] = {'code': '4.7', 'type': 0};
//	CULTURE_AND_ENTERTAINEMENT
window.WMEPT.venue_defs['ART_GALLERY'] = {'code': '5.0', 'type': 0};
window.WMEPT.venue_defs['CASINO'] = {'code': '5.1', 'type': 2};
window.WMEPT.venue_defs['CLUB'] = {'code': '5.2', 'type': 2};
window.WMEPT.venue_defs['TOURIST_ATTRACTION_HISTORIC_SITE'] = {'code': '5.3', 'type': 0};
window.WMEPT.venue_defs['MOVIE_THEATER'] = {'code': '5.4', 'type': 0};
window.WMEPT.venue_defs['MUSEUM'] = {'code': '5.5', 'type': 0};
window.WMEPT.venue_defs['MUSIC_VENUE'] = {'code': '5.6', 'type': 0};
window.WMEPT.venue_defs['PERFORMING_ARTS_VENUE'] = {'code': '5.7', 'type': 0};
window.WMEPT.venue_defs['GAME_CLUB'] = {'code': '5.8', 'type': 0};
window.WMEPT.venue_defs['STADIUM_ARENA'] = {'code': '5.9', 'type': 1};
window.WMEPT.venue_defs['THEME_PARK'] = {'code': '5.10', 'type': 1};
window.WMEPT.venue_defs['ZOO_AQUARIUM'] = {'code': '5.11', 'type': 2};
window.WMEPT.venue_defs['RACING_TRACK'] = {'code': '5.12', 'type': 1};
window.WMEPT.venue_defs['THEATER'] = {'code': '5.13', 'type': 0};
//	OTHER
window.WMEPT.venue_defs['RESIDENCE_HOME'] = {'code': '6.0', 'type': -1};
window.WMEPT.venue_defs['CONSTRUCTION_SITE'] = {'code': '6.1', 'type': -1};
//	LODGING
window.WMEPT.venue_defs['HOTEL'] = {'code': '7.0', 'type': 0};
window.WMEPT.venue_defs['HOSTEL'] = {'code': '7.1', 'type': 0};
window.WMEPT.venue_defs['CAMPING_TRAILER_PARK'] = {'code': '7.2', 'type': 2};
window.WMEPT.venue_defs['COTTAGE_CABIN'] = {'code': '7.3', 'type': 0};
window.WMEPT.venue_defs['BED_AND_BREAKFAST'] = {'code': '7.4', 'type': 0};
//	OUTDOORS
window.WMEPT.venue_defs['PARK'] = {'code': '8.0', 'type': 1};
window.WMEPT.venue_defs['PLAYGROUND'] = {'code': '8.1', 'type': 0};
window.WMEPT.venue_defs['BEACH'] = {'code': '8.2', 'type': 1};
window.WMEPT.venue_defs['SPORTS_COURT'] = {'code': '8.3', 'type': 0};
window.WMEPT.venue_defs['GOLF_COURSE'] = {'code': '8.4', 'type': 1};
window.WMEPT.venue_defs['PLAZA'] = {'code': '8.5', 'type': 0};
window.WMEPT.venue_defs['PROMENADE'] = {'code': '8.6', 'type': 0};
window.WMEPT.venue_defs['POOL'] = {'code': '8.7', 'type': -2}; // undefinded in wiki
window.WMEPT.venue_defs['SCENIC_LOOKOUT_VIEWPOINT'] = {'code': '8.8', 'type': 0};
window.WMEPT.venue_defs['SKI_AREA'] = {'code': '8.9', 'type': 1};
//	NATURAL_FEATURES
window.WMEPT.venue_defs['ISLAND'] = {'code': '9.0', 'type': 1};
window.WMEPT.venue_defs['SEA_LAKE_POOL'] = {'code': '9.1', 'type': 1};
window.WMEPT.venue_defs['RIVER_STREAM'] = {'code': '9.2', 'type': 1};
window.WMEPT.venue_defs['FOREST_GROVE'] = {'code': '9.3', 'type': 1};
window.WMEPT.venue_defs['FARM'] = {'code': '9.4', 'type': -1};
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 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 = new Array();
	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.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){
						window.WMEPT.venue_defs[k].code = code;
						window.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);
					}
					window.WMEPT.venue_defs[k].name = SCat[j];
					window.WMEPT.venue_defs[k].parent = PT_Cat[i];
					found = true;
					index++;
					break;
				}
			}
			//	or add a new obj
			if(!found){
				index++;
				window.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');
	WMEPT = unsafeWindow.WMEPT;
	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;">no</span>';
	if(lm_width >= 50 || lm_height >= 50)lm_is_visible = '<span style="color: green;">yes</span>';
	//	HTML rendering
	WME_HL_POI_addon.innerHTML = '<hr><b>Extra informations</b><br>';
	WME_HL_POI_addon.innerHTML += '- Venue is visible on client : ' + lm_is_visible + '<br>';
	if(isArea(selVenue)){
		var lm_aera = LandGeometry.getArea();
		WME_HL_POI_addon.innerHTML += '- Box width : ' + (Math.round(lm_width * 100) / 100) + 'm<br>';
		WME_HL_POI_addon.innerHTML += '- Box height : ' + (Math.round(lm_height * 100) / 100) + 'm<br>';
		WME_HL_POI_addon.innerHTML += '- Place area : ' + (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="Hide this place type" /><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;">Ne <span style="font-weight: bold;">JAMAIS</span> représenter</p>';
			break;
		case 0:
			if(isArea(selVenue)){
				showElem = true;
				WME_POI_EC_HTML.innerHTML += '<p style="color: red;">Cette zone <span style="font-weight: bold;">DOIT</span> être un point</p>';
			}
			break;
		case 1:
			if(!isArea(selVenue)){
				showElem = true;
				WME_POI_EC_HTML.innerHTML += '<p style="color: red;">Ce point<span style="font-weight: bold;">DOIT</span> être une zone</p>';
			}
			break;
		case 2:
			if(isArea(selVenue)){
				showElem = true;
				switch(is2small(selVenue)){
					case 1:
						WME_POI_EC_HTML.innerHTML += '<p style="color: violet;">Cette zone <span style="font-weight: bold;">DEVRAIT</span> être un point. Elle est trop petite pour être affichée sur le client.</p>';
						break;
					case 2:
						WME_POI_EC_HTML.innerHTML += '<p style="color: orange;">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).</p>';
						break;
				}
			}
			break;
		case 3:
			showElem = true;
			WME_POI_EC_HTML.innerHTML += '<p style="color: red;">Utilisation d\'une catégorie principale</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="https://wiki.waze.com/wiki/Lieux/Parkings#Nommage" target="_blank" style="color: red;">Parking sans nom</a></p><p style="text-align: center; width: 100%;"><input id="HL_Btn_fix_P" type="button" value="Fix to [P]" /><span style="width: 15px;">&nbsp;</span><input id="HL_Btn_fix_PE" type="button" value="Fix to [P]' + HL_translations[lang].number.currency.format.unit + '" /></p>';
			break;
		default:
			showElem = true;
			WME_POI_EC_HTML.innerHTML += '<p>test</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">On-Off</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">Hide</a></li>';
	myTabs.innerHTML += '<li class=""><a href="#hidel-tools" data-toggle="tab">Options / Tools</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="None" /><span style="padding-left: 3px;"></span>'
						+ '<input type="button" id="btn_hl_reset" value="Reset to default" /><span style="padding-left: 3px;"></span>'
						+ '<input type="button" id="btn_hl_all" value="All" /><br/>'
						+ '<label for="text_hl_filter" style="padding-right: 5px;">Filtre</label><input type="button" id="btn_hl_FR" value="X" /><br />'
						// + '<select id="PT_Cat_Filter">'
						// + '<option value="-1">Show all</option>';
	// section.innerHTML += '<option value=""></option>'
	// section.innerHTML += '</select>'
						+ '<input type="text" class="form-control" id="text_hl_filter" /></div>'
						+ '<div id="HL_common"></div>';
	addon_tab_content.appendChild(section);
	//	Populate HL_common
	var Hl_common = getId('HL_common');
	for(var i in HL_translatedPOI){
		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>Options / Tools</b><br>';
	section.innerHTML += '<input type="checkbox" id="lh_glh">&nbsp;General highlight<br>';
	section.innerHTML += '<input type="checkbox" id="st_sl">&nbsp;Highlight too small landmarks<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">Use livemap coloration style<br>';
	addon_tab_content.appendChild(section);
}

function HL_HTML_filter(){
	var filtre = getId('text_hl_filter').value.toLowerCase();
	for(var i in HL_translatedPOI){
		var HL_string = HL_translatedPOI[i].value.toLowerCase();
		if(HL_string.contains(filtre)){
			getId('_HL_' + HL_translatedPOI[i].key).style.display = 'block';
		}
		else{
			getId('_HL_' + HL_translatedPOI[i].key).style.display = 'none';
		}
	}
}

function ShowHideAll(theCheck){
	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 = theCheck;
	}
}

//	On masque/affiche les places et +
function HideL(){
	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.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
	HL_translations = unsafeWindow.I18n.translations;
	if(typeof(HL_translations) == 'undefined'){
		HL_addLog(1, 'error', 'translations NOK');
		setTimeout(HL_init, 500);
		return;
	}
	HL_cur_lng = unsafeWindow.I18n.locale;
	if(typeof(HL_cur_lng) == 'undefined'){
		setTimeout(HL_init, 500);
		return;
	}
	HL_def_lng = 'en';
	HL_addLog(1, 'info', 'Traductions OK');
	//	Then do the job
	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=''; HL_HTML_filter();};
	getId('btn_hl_reset').onclick = function(){isReset = true; HideDefaultOptions();};
	getId('text_hl_filter').onkeyup = HL_HTML_filter;
	//	Waze events
	HL_selectionManager.events.register("selectionchanged", null, HL_POI_html_init);
	// HL_waze_model.venues.events.register("objectschanged", 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);
	getVenues();
	window.WMEPT.loaded = true;
	WMEPT = unsafeWindow.WMEPT;
	HL_addLog(1, 'info', 'WMEPT loaded');
}

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

/*	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).
	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 : removing useless geometrical nodes
-2 : determine if roads running threw parking lots are set as parking lot roads
*/