//Basic Ajax Routine- Author: Dynamic Drive (http://www.dynamicdrive.com)
//Last updated: Dec 4th, 07'

//leegmaken van inputveld bij klikken
function clearText(theField){
	if(theField.value == theField.defaultValue){
		theField.value = "";
	}
}
//vullen van inputveld bij naast klikken
function setText(theField){
	if(theField.value == ""){
		theField.value = theField.defaultValue;
	}
}

function GetE( elementId ){
	return document.getElementById( elementId )  ;
}

function createAjaxObj(){
var httprequest=false
	if (window.XMLHttpRequest){ // if Mozilla, Safari etc
		httprequest=new XMLHttpRequest()
		if (httprequest.overrideMimeType)
			httprequest.overrideMimeType('text/xml')
	}
	else if (window.ActiveXObject){ // if IE
		try {
			httprequest=new ActiveXObject("Msxml2.XMLHTTP");
		} 
		catch (e){
		try{
			httprequest=new ActiveXObject("Microsoft.XMLHTTP");
		}
		catch (e){}
		}
	}
	return httprequest
}

var ajaxpack=new Object()
ajaxpack.basedomain="http://"+window.location.hostname
ajaxpack.ajaxobj=createAjaxObj()
ajaxpack.filetype="txt"
ajaxpack.addrandomnumber=0 //Set to 1 or 0. See documentation.

ajaxpack.getAjaxRequest=function(url, parameters, callbackfunc, filetype){
	ajaxpack.ajaxobj=createAjaxObj() //recreate ajax object to defeat cache problem in IE
	if (ajaxpack.addrandomnumber==1) //Further defeat caching problem in IE?
		var parameters=parameters+"&ajaxcachebust="+new Date().getTime()
	if (this.ajaxobj){
		this.filetype=filetype
		this.ajaxobj.onreadystatechange=callbackfunc
		this.ajaxobj.open('GET', url+"?"+parameters, true)
		this.ajaxobj.send(null)
	}
}

ajaxpack.postAjaxRequest=function(url, parameters, callbackfunc, filetype){
	ajaxpack.ajaxobj=createAjaxObj() //recreate ajax object to defeat cache problem in IE
	if (this.ajaxobj){
		this.filetype=filetype
		this.ajaxobj.onreadystatechange = callbackfunc;
		this.ajaxobj.open('POST', url, true);
		this.ajaxobj.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
		this.ajaxobj.setRequestHeader("Content-length", parameters.length);
		this.ajaxobj.setRequestHeader("Connection", "close");
		this.ajaxobj.send(parameters);
	}
}
function processGet(){
	var myajax=ajaxpack.ajaxobj
	var myfiletype=ajaxpack.filetype
	if (myajax.readyState == 4){ //if request of file completed
		if (myajax.status==200 || window.location.href.indexOf("http")==-1){ //if request was successful or running script locally
			var temp_text = ""; // Tijdelijke text variabele (hier staat de string met de content in
			if (myfiletype=="xml") { // het XML object
				xmlItems=myajax.responseXML.getElementsByTagName("item");
				temp_text += '<ul>';
				for (var i=0; i<xmlItems.length; i++){
					temp_text += '<li>';
					temp_text += '<a href="'+xmlItems[i].getElementsByTagName("link")[0].firstChild.nodeValue+'">';
					temp_text += xmlItems[i].getElementsByTagName("title")[0].firstChild.nodeValue;
					temp_text += '</a>';
					temp_text += '<br /><em>Datum: '+filterDate(xmlItems[i].getElementsByTagName("pubDate")[0].firstChild.nodeValue)+'</em>';
					temp_text += '</li>';
				}
				temp_text += '</ul>';
			} else {
				temp_text = "Er kunnen geen nieuws items getoond worden";
			}
			GetE('rss_data').innerHTML = temp_text; // De HTML in de DIV zetten
			showItem(xmlItems[0],'rss_data2');
			showItem(xmlItems[1],'rss_data3');
		}
	}
}

function showItem(xObj,eObj){
	var outputString = '<div class="rss_items">';
	imgNode = xObj.getElementsByTagName("enclosure")[0].firstChild;
	if (imgNode != null){
		outputString += '<a href="'+xObj.getElementsByTagName('link')[0].firstChild.nodeValue+'">';
		outputString += '<img class="left" src="'+xObj.getElementsByTagName('enclosure')[0].firstChild.nodeValue+'" />';
		outputString += '</a>';
	}
	outputString += '<div class="left">';
	outputString += '<a href="'+xObj.getElementsByTagName('link')[0].firstChild.nodeValue+'">';
	outputString += '<h1>'+xObj.getElementsByTagName("title")[0].firstChild.nodeValue+'</h1>';
	outputString += '</a>';
	outputString += xObj.getElementsByTagName("description")[0].firstChild.nodeValue;
	outputString += '<br />';
	/*outputString += '<em>'+filterDate(xObj.getElementsByTagName("pubDate")[0].firstChild.nodeValue)+'</em>';
	outputString += ' | ';*/
	outputString += '<a href="'+xObj.getElementsByTagName('link')[0].firstChild.nodeValue+'" title="'+xObj.getElementsByTagName('title')[0].firstChild.nodeValue+'">';
	outputString += 'Lees verder';
	outputString += '</a>';	
	outputString += '</div>';
	outputString += '<div class="clear"></div>';
	outputString += '</div>';

	GetE(eObj).innerHTML = outputString; // De HTML in de DIV zetten	
}

function getPageName(path){
	thisPage = path.substring(path.lastIndexOf('/') + 1);
	thisPage = thisPage.replace(window.location.search,"");
	return thisPage;
}

function Len(str){
	return String(str).length;
}

function processGetImage(){
	var myajax=ajaxpack.ajaxobj
	var myfiletype=ajaxpack.filetype
	var thisPath = getPageName(window.location.href);
	if (myajax.readyState == 4){ //if request of file completed
		if (myajax.status==200 || window.location.href.indexOf("http")==-1){ //if request was successful or running script locally
			var temp_text = ""; // Tijdelijke text variabele (hier staat de string met de content in
			if (myfiletype=="xml") { // het XML object
				items=myajax.responseXML.getElementsByTagName("item");
				for (var i=0; i<items.length; i++){
					 titleClass = '';
					temp_text += '<div class="rss_items">';
					imgNode = items[i].getElementsByTagName("enclosure")[0].firstChild;
					if (imgNode != null){
						temp_text += '<a href="'+items[i].getElementsByTagName('link')[0].firstChild.nodeValue+'">';
						temp_text += '<img class="left" src="'+items[i].getElementsByTagName('enclosure')[0].firstChild.nodeValue+'" />';
						temp_text += '</a>';
					}
					/*if(thisPath==getPageName(items[i].getElementsByTagName('link')[0].firstChild.nodeValue)){
						titleClass = ' class="active"';
					}*/
					temp_text += '<div class="left">';
					temp_text += '<a href="'+items[i].getElementsByTagName('link')[0].firstChild.nodeValue+'">';
					/*temp_text += '<strong '+titleClass+'>';*/
					temp_text += '<h1>'+items[i].getElementsByTagName("title")[0].firstChild.nodeValue+'</h1>';
					temp_text += '</a>';
					temp_text += items[i].getElementsByTagName("description")[0].firstChild.nodeValue;
					temp_text += '<br />';
					temp_text += '<a href="'+items[i].getElementsByTagName('link')[0].firstChild.nodeValue+'">';
					temp_text += 'Lees verder';
					temp_text += '</a>';
					temp_text += '</div>';
					temp_text += '<div class="clear"></div>';
					temp_text += '</div>';
				}
			} else {
				temp_text = "Er kunnen geen nieuws items getoond worden";
			}
			GetE('rss_data').innerHTML = temp_text; // De HTML in de DIV zetten
		}
	}
}

/*function filterDate(ufdate) {
	if(ufdate.length == 8) {
		var toFilterDate = new String(ufdate);
		fYear = toFilterDate.substr(0,4);
		fMonth = toFilterDate.substr(4,2);
		fDay = toFilterDate.substr(6,2);
		filteredDate = fDay + '-' + fMonth + '-' + fYear;
		return filteredDate;
	} else {
		var todayDate = new Date();
		filteredDate = todayDate.getDate() + '-' + (todayDate.getMonth()+1) + '-' + todayDate.getFullYear();
		return filteredDate;
	}	
}*/

function filterDate(ufdate){
	var toFilterDate = new String(ufdate);
	space1 = toFilterDate.indexOf(" ")
	space2 = toFilterDate.indexOf(" ",space1+1)
	day = toFilterDate.substring(0,space1)
	month = toFilterDate.substring(space1+1,space2)	
	year = toFilterDate.substring(space2+1)
	
	if(month == "januari"){month = "01"}
	if(month == "februari"){month = "02"}
	if(month == "maart"){month = "03"}
	if(month == "april"){month = "04"}
	if(month == "mei"){month = "05"}
	if(month == "juni"){month = "06"}
	if(month == "juli"){month = "07"}
	if(month == "augustus"){month = "08"}
	if(month == "september"){month = "09"}
	if(month == "oktober"){month = "10"}
	if(month == "november"){month = "11"}
	if(month == "december"){month = "12"}
	
	filteredDate = day + '-' + month + '-' + year;
	return filteredDate;
}

//ACCESSIBLE VARIABLES (for use within your callback functions):
//1) ajaxpack.ajaxobj //points to the current ajax object
//2) ajaxpack.filetype //The expected file type of the external file ("txt" or "xml")
//3) ajaxpack.basedomain //The root domain executing this ajax script, taking into account the possible "www" prefix.
//4) ajaxpack.addrandomnumber //Set to 0 or 1. When set to 1, a random number will be added to the end of the query string of GET requests to bust file caching of the external file in IE. See docs for more info.

//ACCESSIBLE FUNCTIONS:
//1) ajaxpack.getAjaxRequest(url, parameters, callbackfunc, filetype)
//2) ajaxpack.postAjaxRequest(url, parameters, callbackfunc, filetype)

///////////END OF ROUTINE HERE////////////////////////


//////EXAMPLE USAGE ////////////////////////////////////////////
/* Comment begins here

//Define call back function to process returned data
function processGetPost(){
var myajax=ajaxpack.ajaxobj
var myfiletype=ajaxpack.filetype
if (myajax.readyState == 4){ //if request of file completed
if (myajax.status==200 || window.location.href.indexOf("http")==-1){ if request was successful or running script locally
if (myfiletype=="txt")
alert(myajax.responseText)
else
alert(myajax.responseXML)
}
}
}

/////1) GET Example- alert contents of any file (regular text or xml file):

ajaxpack.getAjaxRequest("example.php", "", processGetPost, "txt")
ajaxpack.getAjaxRequest("example.php", "name=George&age=27", processGetPost, "txt")
ajaxpack.getAjaxRequest("examplexml.php", "name=George&age=27", processGetPost, "xml")
ajaxpack.getAjaxRequest(ajaxpack.basedomain+"/mydir/mylist.txt", "", processGetPost, "txt")

/////2) Post Example- Post some data to a PHP script for processing, then alert posted data:

//Define function to construct the desired parameters and their values to post via Ajax
function getPostParameters(){
var namevalue=document.getElementById("namediv").innerHTML //get name value from a DIV
var agevalue=document.getElementById("myform").agefield.value //get age value from a form field
var poststr = "name=" + encodeURI(namevalue) + "&age=" + encodeURI(agevalue)
return poststr
}

var poststr=getPostParameters()

ajaxpack.postAjaxRequest("example.php", poststr, processGetPost, "txt")
ajaxpack.postAjaxRequest("examplexml.php", poststr, processGetPost, "xml")

Comment Ends here */

/***********************************************
* Ajax Includes script- © Dynamic Drive DHTML code library (www.dynamicdrive.com)
* This notice MUST stay intact for legal use
* Visit Dynamic Drive at http://www.dynamicdrive.com/ for full source code
***********************************************/

//To include a page, invoke ajaxinclude("afile.htm") in the BODY of page
//Included file MUST be from the same domain as the page displaying it.

var rootdomain="http://"+window.location.hostname

function ajaxinclude(url) {
var page_request = false
if (window.XMLHttpRequest) // if Mozilla, Safari etc
page_request = new XMLHttpRequest()
else if (window.ActiveXObject){ // if IE
try {
page_request = new ActiveXObject("Msxml2.XMLHTTP")
} 
catch (e){
try{
page_request = new ActiveXObject("Microsoft.XMLHTTP")
}
catch (e){}
}
}
else
return false
page_request.open('GET', url, false) //get page synchronously 
page_request.send(null)
writecontent(page_request)
}

function writecontent(page_request){
if (window.location.href.indexOf("http")==-1 || page_request.status==200)
document.write(page_request.responseText)
}


/* Deze functie is een standaard functie om e-mail te controleren 
	 Het heeft niets met XML en AJAX te maken
*/

function isEmail(form) {
  var field = form.vanmail;
  var str = field.value;
  if (window.RegExp) {
    var reg1str = "(@.*@)|(\\.\\.)|(@\\.)|(\\.@)|(^\\.)";
    var reg2str = "^.+\\@(\\[?)[a-zA-Z0-9\\-\\.]+\\.([a-zA-Z]{2,3}|[0-9]{1,3})(\\]?)$";
    var reg1 = new RegExp(reg1str);
    var reg2 = new RegExp(reg2str);
    if (!reg1.test(str) && reg2.test(str)) {
      return true;
    }
    field.focus();
    field.select();
    return false;
  } else {
    if(str.indexOf("@") >= 0)
      return true;
    field.focus();
    field.select();
    return false;
  }
}

function setTekst(obj, tekst) {
	var naam = obj.value;
	if (naam == tekst) {
		obj.value = '';
	} else if (naam == '') {
		obj.value = tekst;
	}
}

function showButton(obj){
	obj.style.width=84+'px';
	document.getElementById('seachButton').style.display='inline';
}

function searchWord(){
	var word = document.getElementById('word').value;
		document.location.href='http://www.i-concept.nl/search/searchmain.cfm?SearchString='+word;
}

//huidige pagina checken in url
var url = document.location.href;
var qm = url.indexOf("?");
var em = url.indexOf("=");
var param = url.substring(qm+1,em);
if(param == "loginfailed"){
	alert("U heeft geen juiste inloggegevens ingevuld.");
}
