// ---------------------------------------------------------------------
// general utility -----------------------------------------------------
// ---------------------------------------------------------------------

function destroy (id) {
	var el = document.getElementById(id);
	if (el) {
		var parent = el.parentNode;
		var a = parent.removeChild(el);
		delete a;
	}
}

// ---------------------------------------------------------------------

function getNumber (astring) {
	astring = String(astring);
	var count = (arguments.length > 1) ? arguments[1] - 1 : 0;
	var matches = astring.match(/[0-9]+/g);
	if (!matches || (count > matches.length))
		return 0;
	return Number(matches[count]);
}

// ---------------------------------------------------------------------

function findPos(obj, xory) {
	var result = 0;
	if (obj.offsetParent) {
		while (obj.offsetParent) {
			if (xory == 'x') result += obj.offsetLeft;
			else result += obj.offsetTop;
			obj = obj.offsetParent;
		}
	}
	else if ((xory == 'x') && (obj.x)) result += obj.x;
	else if (obj.y) result += obj.y;
	return result;
}

// ---------------------------------------------------------------------
// menu stuff ----------------------------------------------------------
// ---------------------------------------------------------------------
		
function menuClose(tomenu, alevel) {
	var a;
	for (var i = menuBranches.length - 1; i >= alevel; i--) {
		if ((menuBranches[i] != tomenu) && (menuBranches[i] != '0')) {
			a = document.getElementById(menuBranches[i]);
			a.style.visibilty = 'hidden';
			a.style.top = -2000;
			a.style.left = -2000;
		}
	}
}

// ---------------------------------------------------------------------

function menuGo (frommenu, tomenu, alevel, horizontal, xoff, yoff) {
	if (alevel > 0)
		menuStartTimeOut = setTimeout('menuShow(\'' + frommenu + '\', \'' + tomenu + '\', ' + alevel + ', ' + horizontal + ', ' + xoff + ', ' + yoff + ')', 100);
	else
		menuStartTimeOut = setTimeout('menuShow(\'' + frommenu + '\', \'' + tomenu + '\', ' + alevel + ', ' + horizontal + ', ' + xoff + ', ' + yoff + ')', 200);
}

// ---------------------------------------------------------------------

function menuStop () {
	clearTimeout(menuStartTimeOut);
}

// ---------------------------------------------------------------------

function menuShow (frommenu, tomenu, alevel, horizontal, xoff, yoff) {
	menuClose(tomenu, alevel);
	clearTimeout(menuTimeOut);
	menuTimeOut = setTimeout('menuClose(\'0\', 0)', 60000);
	menuBranches[alevel] = tomenu;
	if (document.getElementById(tomenu)) {
		var a = document.getElementById(frommenu);
		var b = document.getElementById(tomenu);
		var x = findPos(a, 'x');
		var y = findPos(a, 'y');
		var w = Math.max(a.clientWidth, a.offsetWidth);
		var h = Math.max(a.clientHeight, a.offsetHeight);
		var bw = b.offsetWidth;
		var bh = b.offsetHeight;
		var sx = window.innerWidth;
		var sy = window.innerHeight;
		var dx = 0;
		if (horizontal) {
			if (x + 2 + bw > sx)
				dx = -(x + 2 + bw - sx);						
		} else {
			if (x + w + 2 + bw > sx)
				dx = -(w + bw + (2 * xoff));
		}
		var dy = y;
		if (y + bh > sy)
			dy = sy - bh - 1;
		b.style.zIndex = 400;
		if (horizontal) {
			b.style.top = (y + h + 1) + 'px';
			b.style.left = (x + dx) + 'px';
		} else {
			b.style.top = (dy + yoff) + 'px';
			b.style.left = (x + w + xoff + dx) + 'px';
		}
		if (bh > sy) {
			b.style.top = '1px';
			b.style.height = (sy - 2) + 'px';
		}	
		b.style.visibility = 'visible';
	}
}

// ---------------------------------------------------------------------
// date picker stuff ---------------------------------------------------
// ---------------------------------------------------------------------

function dateConform (datestring) { 
	var future = (arguments.length > 1) ? arguments[1] : true; // automically adjust future dates to last century if 2 digit
	monthnames = new Array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
	var now  = new Date();
	// sort out the datestring and get a date to work with
	datestring = datestring.replace(/[\.\/\-]/g, " ");
	var day   = getNumber(datestring, 1);
	var month = getNumber(datestring, 2);
	var year  = getNumber(datestring, 3);
	if (day == 0) {// no datestring
		day   = now.getDate();
		month = now.getMonth() + 1;
		year  = now.getFullYear();
	} else {
		// check month supplied as text
		var monthtext = datestring.match(/[a-zA-z]+/g);
		if (monthtext) {
			if (monthtext.length == 1) { 
				monthtext = monthtext[0];
				for (var i = 0; i < monthnames.length; i++) {
					var reg = new RegExp(monthnames[i], "i")
					if (monthtext.match(reg))
						month = i + 1;
				}
				year  = getNumber(datestring, 2);
			}
		} 
		if (month == 0)
			month = now.getMonth() + 1;
		if ((year < 1) || isNaN(year))
			year = now.getFullYear();
		while (month < 0){
			month += 12;
			year--;
		}
		while (month > 12){
			month -= 12;
			year++;
		}
	}
	if (year < 1)
		year = now.getFullYear();
	year = (year < 1000) ? (2000 + getNumber(year)) : year;
	while ((year > now.getFullYear()) && (!future)) 
		year -= 100;
	return day + '/' + month + '/' + year;
}

// ---------------------------------------------------------------------

function calendarSet (datestring, fieldid) {
	var field = document.getElementById(fieldid);
	if (field)
		field.value = dateConform(datestring);
	destroy('calendarpopup');
}

// ---------------------------------------------------------------------

function calendarDraw (day, month, year, fieldid) {
	monthnames = new Array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
	var html = '\n\t<table class="cal" cellspacing="0">';
	// year
	html += '\
		<tr>\
			<td colspan="2" class="cal year"><a class="cal year" href="javascript:void(0)" onMouseDown="calendarDraw(' + day + ', ' + month + ', ' + (year - 1) + ', \'' + fieldid + '\');">&laquo;</a></td>\
			<td colspan="3" class="cal year">' + year + '</td>\
			<td colspan="2" class="cal year"><a class="cal year" href="javascript:void(0)" onMouseDown="calendarDraw(' + day + ', ' + month + ', ' + (year + 1) + ', \'' + fieldid + '\');">&raquo;</a></td>\
		</tr>';
	// month
	html += '\
		<tr>\
			<td colspan="2" class="cal month"><a class="cal month" href="javascript:void(0)" onMouseDown="calendarDraw(' + day + ', ' + ((month == 1) ? 12 : (month - 1)) + ', ' + ((month == 1) ? (year - 1) : year) + ', \'' + fieldid + '\');">&laquo;</a></td>\
			<td colspan="3" class="cal month">' + monthnames[month - 1] + '</td>\
			<td colspan="2" class="cal month"><a class="cal month" href="javascript:void(0)" onMouseDown="calendarDraw(' + day + ', ' + ((month == 12) ? 1 : (month + 1)) + ', ' + ((month == 12) ? (year + 1) : year) + ', \'' + fieldid + '\');">&raquo;</a></td>\
		</tr>';
	// day names
	var daynames = new Array('S', 'M', 'T', 'W', 'T', 'F', 'S');
	html += '\n\t\t<tr>';
	for (var i = 0; i < daynames.length; i++)
		html += '<td class="cal dayname">' + daynames[i] + '</td>';
	html += '</tr>';
	// days
	// previous month days
	var first = new Date(year, month - 1, 1);
	html += '<tr>';
	var weekstart = first.getDay();
	for(var i = weekstart; i > 0; i--)
		html += '<td class="cal day">&nbsp;</td>';
	// current month days
	var thismonth = new Date(year, month - 1, 1);
	var nextmonth = new Date(year, month, 1);
	var monthdays = Math.round((nextmonth.getTime() - thismonth.getTime()) / 86400000);
	var today = new Date();
	for(var i = 1; i <= monthdays; i++) {
		var todayclass = ((i == today.getDate()) && (month == (today.getMonth() + 1)) && (year == today.getFullYear())) ? ' today' : '';
		html += '<td class="cal day' + todayclass + '"><a href="javascript:void(0)" class="cal' + todayclass + '" onclick="calendarSet(\'' + i + '/' + month + '/' + year + '\', \'' + fieldid + '\')">' + i + '</a></td>';
		if ((i + weekstart - 1) % 7 == 6)
			html += '</tr><tr>';
	}
	// next month days
	var last = new Date(year, month - 1, monthdays);
	var weekfinish = last.getDay();
	for(var i = 6; i > weekfinish; i--)
		html += '<td class="cal day">&nbsp;</td>';
	html += '</tr>';
	// finish
	html += '</table>';
	document.getElementById('calendarpopup').innerHTML = html;
}

//----------------------------------------------------------------------

function calendarPopUp (fieldid, whereid, aclass) {
	if (document.getElementById('calendarpopup'))
		destroy('calendarpopup');
	else
		setTimeout('calendarMakePopUp(\'' + fieldid + '\', \'' + aclass + '\', \'' + whereid + '\')', 100);
}

// ---------------------------------------------------------------------

function calendarMakePopUp (fieldid, whereid, aclass) { 
	aclass = (aclass) ? aclass : '';
	var where = document.getElementById(whereid);
	var field = document.getElementById(fieldid);
	if (field && where) {
		calendarfieldid = fieldid;
		var caldiv = document.createElement('div');
		caldiv.id = 'calendarpopup';
		caldiv.className = aclass;
		document.body.appendChild(caldiv);
		caldiv.style.position = 'absolute';
		caldiv.style.left = findPos(where, 'x');
		caldiv.style.top  = findPos(where, 'y') + Math.max(where.clientHeight, where.offsetHeight);
		var today = new Date();
		calendarDraw(today.getDate(), today.getMonth() + 1, today.getFullYear(), fieldid);
	} 
}

// ---------------------------------------------------------------------
// globals -------------------------------------------------------------
// ---------------------------------------------------------------------

var menuBranches = new Array();
menuBranches[0] = '0';
menuStartTimeOut = 0;
menuTimeOut = 0;

document.onclick = function() { 
	menuClose('0', 0); 
	if (document.getElementById('calendarpopup'))
		destroy('calendarpopup');
};
	