/* Initialising the JavaScript */
function init() {
	hoverMenu();
}

/* Functies die worden gebruikt bij het uitgebreid zoeken */
function andereStap(volgende) {
	$('volgende_stap').value = volgende;
	document.uitgebreidzoeken.submit();
}

function wisStappenplan() {
	var a = confirm('Weet je zeker dat je alle stappen wilt wissen?');
	if(a) {
		$('volgende_stap').value = 'wissen';
		document.uitgebreidzoeken.submit();
	}
}

/* Het aanvinken van parent and child cats */
var id = '';
var originalClasses = new Array();
function setParent(parent,child) {
	var idParent = 'cats_' + parent;
	var idChild = 'cats_' + child;
	if($(idParent).checked == false && $(idChild).checked == true) $(idParent).checked = true;
}

function setChilds(parent,childs) {
	if($('cats_' + parent).checked == false) {
		var children = childs.split(',');
		for(i=0;i<children.length;i++) {
			var idChild = 'cats_' + children[i];
			$(idChild).checked = false;
		}
		
		// Toggle window with childs
		new Effect.SlideUp($('childs_' + parent), 'slide');
		$('list_' + parent).className = $('list_' + parent).className.replace(/s*blue/,'');
	}
	else {
		// Toggle window with childs
		new Effect.SlideDown($('childs_' + parent), 'slide');
		$('list_' + parent).className = $('list_' + parent).className + ' blue';
	}
}

/* Bij het zoeken op de eigenschappen van de opleiding hoort het volgende */
function showEigenschap(eigenschap) {
	if($(eigenschap + '_kiezer').checked == true) {
		// De keuze is geselecteerd, laat de mogelijkheid/-heden zien	
		new Effect.SlideDown($(eigenschap + '_scroller'), 'slide');
		$(eigenschap + '_kiezerItem').className = $(eigenschap + '_kiezerItem').className + ' blue';
	}
	else {
		// De keuze is niet geselecteerd, haal de mogelijkheid/-heden weg
		new Effect.SlideUp($(eigenschap + '_scroller'), 'slide');
		$(eigenschap + '_kiezerItem').className = $(eigenschap + '_kiezerItem').className.replace(/s*blue/,'');
	}
}

/* Het ophalen van de resultaten van het uitgebreid zoeken */
function uitgebreidZoeken() {	
	var url = linkprefix + 'XML/uitgebreidzoeken.php';
	
	var myAjax = new Ajax.Request(
	url, 
	{
		method: 'get', 
		onComplete: showUitgebreidZoeken
	});
}

function showUitgebreidZoeken(originalRequest) {
	var response = originalRequest.responseText;
	
	// Vul de nieuwe data in de div met de begeleidende tekst
	$('resultaten').innerHTML = response;
	
	// Dan de ene div weghalen en de andere div tevoorschijn toveren
	new Effect.SlideUp($('beschrijving'),'slide');
	new Effect.SlideDown($('resultaten'), {queue: 'end'});
}

function uitgebreidZoekenResultaten(pagina) {
	if(pagina == undefined) pagina = 1;
	
	var url = linkprefix + 'XML/uitgebreidzoeken.php';
	var pars = 'pagina=' + pagina;

	setLoading('active');

	var myAjax = new Ajax.Request(
	url, 
	{
		method: 'get', 
		parameters: pars, 
		onComplete: showUitgebreidZoekenResultaten
	});
}

function showUitgebreidZoekenResultaten(originalRequest) {
	var response = originalRequest.responseText;
	
	// Vul de nieuwe data in de div met de begeleidende tekst
	$('resultaten').innerHTML = response;
	setLoading('inactive');
}

function setLoading(state) {
	if(state == undefined) state = 'active';

	if(state == 'active') {
		$('loading').style.display = '';
	}
	else if (state == 'inactive') {
		$('loading').style.display = 'none';
	}
}

/* De werking van de filter bij de steden, opleidingen, etc */
function filterDeSteden() {	
	setLoading('active');
	
	if($('filter_stad').value != '') $('filter_stad_waarde').value = $('filter_stad').value;
	if($('filter_kroegen').value != '---') $('filter_kroegen_waarde').value = $('filter_kroegen').value;
	if($('filter_bioscopen').value != '---') $('filter_bioscopen_waarde').value = $('filter_bioscopen').value;
	if($('filter_musea').value != '---') $('filter_musea_waarde').value = $('filter_musea').value;
	if($('filter_studenten').value != '---') $('filter_studenten_waarde').value = $('filter_studenten').value;
	
	document.stedenfilter.submit()
}

function filterDeOpleidingen() {	
	setLoading('active');
	
	if($('filter_opleiding').value != '') $('filter_opleiding_waarde').value = $('filter_opleiding').value;
	if($('filter_duur').value != '---') $('filter_duur_waarde').value = $('filter_duur').value;
	if($('filter_niveau').value != '---') $('filter_niveau_waarde').value = $('filter_niveau').value;
	
	document.opleidingenfilter.submit()
}

function filterDeInstellingen() {	
	setLoading('active');
	
	if($('filter_instelling').value != '') $('filter_instelling_waarde').value = $('filter_instelling').value;
	if($('filter_stad').value != '---') $('filter_stad_waarde').value = $('filter_stad').value;
	//if($('filter_aantal').value != '---') $('filter_aantal_waarde').value = $('filter_aantal').value;
	
	document.instellingenfilter.submit()
}

/* Opzoeken van opleidingen met brochure */
var warning = false;
var restformulier = false;
function getOpleidingenBrochure() {
	setLoading('active');
	
	if(warning) {
		new Effect.SlideUp($('warning'),'slide');
		warning = false;
	}
	
	if(restformulier) {
		new Effect.SlideUp($('restformulier'),'slide');
		restformulier = false;
	}
	
	var instelling = $('ins_id').value;
	
	if(instelling == 0) {
		// Fout
		$('warning').innerHTML = "<div id=\"warning_content\"><p>U moet een instelling kiezen om een brochure aan te vragen.</p></div>";
		new Effect.SlideDown($('warning'), {queue: 'end'});
		warning = true;
		setLoading('inactive');
	}
	else {
		// Haal de opleidingen op met AJAX.
		var url = linkprefix + 'XML/opleidingen.php';
		var pars = 'instelling=' + instelling;
	
		var myAjax = new Ajax.Request(
		url, 
		{
			method: 'get', 
			parameters: pars, 
			onComplete: showOpleidingenBrochure
		});
	}
}

function showOpleidingenBrochure(originalRequest) {
	var response = originalRequest.responseText;
	
	// Vul de nieuwe data in de div met de begeleidende tekst
	$('restformulier').innerHTML = response;
	new Effect.SlideDown($('restformulier'), {queue: 'end'});
	restformulier = true;
	setLoading('inactive');
}

function getOpleidingenBrochureNaFout() {
	setLoading('active');
	
	if(restformulier) {
		new Effect.SlideUp($('restformulier'),'slide');
		restformulier = false;
	}
	
	var instelling = $('ins_id').value;
	
	if(instelling == 0) {
		// Fout
		$('warning').innerHTML = "<div id=\"warning_content\"><p>U moet een instelling kiezen om een brochure aan te vragen.</p></div>";
		setLoading('inactive');
	}
	else {
		// Haal de opleidingen op met AJAX.
		var url = linkprefix + 'XML/opleidingen.php';
	
		var myAjax = new Ajax.Request(
		url, 
		{
			method: 'get', 
			parameters: pars, 
			onComplete: showOpleidingenBrochure
		});
	}
}

function formatPostcode(id) {
	$(id).value = $(id).value.toUpperCase();
	$(id).value = $(id).value.replace(/ /gi,"");
}

/* Werking van de datumpicker */
function submitDatum() {
	setLoading('active');
	document.datumPicker.submit();
}

/* Openen van cat in FAQ */
function openFaqCat(id) {
	setLoading('active');
	var cat = $(id).value;
	
	if(cat != 0) {
		window.location = linkprefix + 'faq/' + cat + '/';
	} else setLoading('inactive');
}

/* Openen van een lang overzicht in een tabel */
function LaatTabelZien() {
	setLoading('active');
	new Effect.SlideUp($('kortoverzicht'),'slide');
	new Effect.SlideDown($('langoverzicht'), {queue: 'end'});
	setLoading('inactive');
}

/* Het laten werken van het menu in IE6 */
function hoverMenu() {
	// Hoeft alleen in IE 6
	if(BrowserDetect.browser == "Explorer" && BrowserDetect.version == "6") {
		var html = $('hoofdmenu').innerHTML;
		html = html.replace(/<li/gi, "<li onmouseover=\"this.className += 'hover'\" onmouseout=\"this.className = this.className.replace(/\s*hover/, '')\"");
		$('hoofdmenu').innerHTML = html;
	}
}

/* Browser detectie */
var BrowserDetect = {
	init: function () {
		this.browser = this.searchString(this.dataBrowser) || "An unknown browser";
		this.version = this.searchVersion(navigator.userAgent)
			|| this.searchVersion(navigator.appVersion)
			|| "an unknown version";
		this.OS = this.searchString(this.dataOS) || "an unknown OS";
	},
	searchString: function (data) {
		for (var i=0;i<data.length;i++)	{
			var dataString = data[i].string;
			var dataProp = data[i].prop;
			this.versionSearchString = data[i].versionSearch || data[i].identity;
			if (dataString) {
				if (dataString.indexOf(data[i].subString) != -1)
					return data[i].identity;
			}
			else if (dataProp)
				return data[i].identity;
		}
	},
	searchVersion: function (dataString) {
		var index = dataString.indexOf(this.versionSearchString);
		if (index == -1) return;
		return parseFloat(dataString.substring(index+this.versionSearchString.length+1));
	},
	dataBrowser: [
		{ 	string: navigator.userAgent,
			subString: "OmniWeb",
			versionSearch: "OmniWeb/",
			identity: "OmniWeb"
		},
		{
			string: navigator.vendor,
			subString: "Apple",
			identity: "Safari"
		},
		{
			prop: window.opera,
			identity: "Opera"
		},
		{
			string: navigator.vendor,
			subString: "iCab",
			identity: "iCab"
		},
		{
			string: navigator.vendor,
			subString: "KDE",
			identity: "Konqueror"
		},
		{
			string: navigator.userAgent,
			subString: "Firefox",
			identity: "Firefox"
		},
		{
			string: navigator.vendor,
			subString: "Camino",
			identity: "Camino"
		},
		{		// for newer Netscapes (6+)
			string: navigator.userAgent,
			subString: "Netscape",
			identity: "Netscape"
		},
		{
			string: navigator.userAgent,
			subString: "MSIE",
			identity: "Explorer",
			versionSearch: "MSIE"
		},
		{
			string: navigator.userAgent,
			subString: "Gecko",
			identity: "Mozilla",
			versionSearch: "rv"
		},
		{ 		// for older Netscapes (4-)
			string: navigator.userAgent,
			subString: "Mozilla",
			identity: "Netscape",
			versionSearch: "Mozilla"
		}
	],
	dataOS : [
		{
			string: navigator.platform,
			subString: "Win",
			identity: "Windows"
		},
		{
			string: navigator.platform,
			subString: "Mac",
			identity: "Mac"
		},
		{
			string: navigator.platform,
			subString: "Linux",
			identity: "Linux"
		}
	]

};
BrowserDetect.init();

window.onload = init;