var agt=navigator.userAgent.toLowerCase();
var is_major=parseInt(navigator.appVersion);
var is_minor=parseFloat(navigator.appVersion);
var is_nav =((agt.indexOf('mozilla')!=-1) && (agt.indexOf('spoofer')==-1)&& (agt.indexOf('compatible')==-1) && (agt.indexOf('opera')==-1)&& (agt.indexOf('webtv')==-1) && (agt.indexOf('hotjava')==-1));
var is_nav2=(is_nav && (is_major==2));
var is_nav3=(is_nav && (is_major==3));
var is_nav4=(is_nav && (is_major==4));
var is_nav4up=(is_nav && (is_major >= 4));
var is_navonly=(is_nav && ((agt.indexOf(";nav") != -1) ||(agt.indexOf("; nav") != -1)) );
var is_nav6=(is_nav && (is_major==5));
var is_nav6up=(is_nav && (is_major >= 5));
var is_gecko=(agt.indexOf('gecko') != -1);
var is_ie=((agt.indexOf("msie") != -1) && (agt.indexOf("opera")==-1));
var is_ie3=(is_ie && (is_major < 4));
var is_ie4=(is_ie && (is_major==4) && (agt.indexOf("msie 4")!=-1) );
var is_ie4up =(is_ie && (is_major >= 4));
var is_ie5=(is_ie && (is_major==4) && (agt.indexOf("msie 5.0")!=-1) );
var is_ie5_5=(is_ie && (is_major==4) && (agt.indexOf("msie 5.5") !=-1));
var is_ie5up=(is_ie && !is_ie3 && !is_ie4);
var is_ie5_5up =(is_ie && !is_ie3 && !is_ie4 && !is_ie5);
var is_ie6=(is_ie && (is_major==4) && (agt.indexOf("msie 6.")!=-1) );
var is_ie6up =(is_ie && !is_ie3 && !is_ie4 && !is_ie5 && !is_ie5_5);
var is_opera=(agt.indexOf("opera") != -1);
var is_opera2=(agt.indexOf("opera 2") != -1 || agt.indexOf("opera/2") != -1);
var is_opera3=(agt.indexOf("opera 3") != -1 || agt.indexOf("opera/3") != -1);
var is_opera4=(agt.indexOf("opera 4") != -1 || agt.indexOf("opera/4") != -1);
var is_opera5=(agt.indexOf("opera 5") != -1 || agt.indexOf("opera/5") != -1);
var is_opera5up=(is_opera && !is_opera2 && !is_opera3 && !is_opera4);




// Global variables
dynCalendar_layers          = new Array();
dynCalendar_mouseoverStatus = false;
dynCalendar_mouseX          = 0;
dynCalendar_mouseY          = 0;

if (dil=='tr'){
	aylar=new Array('Ocak','Şubat','Mart','Nisan','Mayıs','Haziran','Temmuz','Ağustos','Eylül','Ekim','Kasım','Aralık');
	gunler=new Array('Paz','Pts','Sal','Çrş','Prş','Cum','Cts');
}

if (dil=='en'){
	aylar=new Array('January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December');
	gunler=new Array('Sun','Mon','Tue','Wed','Thu','Fri','Sat');
}

/**
* The calendar constructor
*
* @access public
* @param string objName      Name of the object that you create
* @param string callbackFunc Name of the callback function
* @param string OPTIONAL     Optional layer name
* @param string OPTIONAL     Optional images path
*/
function dynCalendar(objName, callbackFunc, field){
	// Properties

	// Todays date
	this.today          = new Date();
	this.date           = this.today.getDate();
	this.month          = this.today.getMonth();
	this.year           = this.today.getFullYear();

	this.objName        = objName;
	this.callbackFunc   = callbackFunc;
	this.field          = field;
	this.imagesPath     = 'images/';
	this.layerID        = 'dynCalendar_layer_' + dynCalendar_layers.length;

	this.posX           = 0;
	this.posY           = 0;

	this.offsetX        = 5;
	this.offsetY        = 5;

	this.useMonthCombo  = true;
	this.useYearCombo   = true;
	this.yearComboRange = 5;

	this.currentMonth   = this.month;
	this.currentYear    = this.year;

	// Public Methods
	this.show              = dynCalendar_show;
	this.writeHTML         = dynCalendar_writeHTML;

	// Accessor methods
	this.setPosition       = dynCalendar_setPosition;
	this.setOffset         = dynCalendar_setOffset;
	this.setOffsetX        = dynCalendar_setOffsetX;
	this.setOffsetY        = dynCalendar_setOffsetY;
	this.setImagesPath     = dynCalendar_setImagesPath;
	this.setMonthCombo     = dynCalendar_setMonthCombo;
	this.setYearCombo      = dynCalendar_setYearCombo;
	this.setCurrentMonth   = dynCalendar_setCurrentMonth;
	this.setCurrentYear    = dynCalendar_setCurrentYear;
	this.setYearComboRange = dynCalendar_setYearComboRange;

	// Private methods

	// Layer manipulation
	this._getLayer         = dynCalendar_getLayer;
	this._hideLayer        = dynCalendar_hideLayer;
	this._showLayer        = dynCalendar_showLayer;
	this._setLayerPosition = dynCalendar_setLayerPosition;
	this._setHTML          = dynCalendar_setHTML;

	// Miscellaneous
	this._getDaysInMonth   = dynCalendar_getDaysInMonth;
	this._mouseover        = dynCalendar_mouseover;

  // Constructor type code
	dynCalendar_layers[dynCalendar_layers.length] = this;
	this.writeHTML();
}

/**
* Shows the calendar, or updates the layer if
* already visible.
*
* @access public
* @param integer month Optional month number (0-11)
* @param integer year  Optional year (YYYY format)
*/
function dynCalendar_show(){
	// Variable declarations to prevent globalisation
	var month, year, monthnames, numdays, thisMonth, firstOfMonth;
	var ret, row, i, cssClass, linkHTML, previousMonth, previousYear;
	var nextMonth, nextYear, prevImgHTML, prevLinkHTML, nextImgHTML, nextLinkHTML;
	var monthComboOptions, monthCombo, yearComboOptions, yearCombo, html;
	
	this.currentMonth = month = arguments[0] != null ? arguments[0] : this.currentMonth;
	this.currentYear  = year  = arguments[1] != null ? arguments[1] : this.currentYear;

	monthnames = aylar;
	numdays    = this._getDaysInMonth(month, year);

	thisMonth    = new Date(year, month, 1);
	firstOfMonth = thisMonth.getDay();

	// First few blanks up to first day
	ret = new Array(new Array());
	for (i=0; i<firstOfMonth; i++) ret[0][ret[0].length] = '<td>&nbsp;</td>';

	// Main body of calendar
	row = 0;
	i   = 1;
	while(i <= numdays){
		if (ret[row].length == 7) ret[++row] = new Array();

    // Generate this cells' HTML
		cssClass = (i == this.date && month == this.month && year == this.year) ? ' id="bugun"' : '';
		gun=i+''; if (gun.length==1) gun='0'+gun;
		ay=(Number(month) + 1)+''; if (ay.length==1) ay='0'+ay;
		linkHTML = '<a href="javascript: ' + this.callbackFunc + '(\'' + this.field + '\',\'' + gun + '\', \'' + ay + '\', ' + year + '); ' + this.objName + '._hideLayer()">' + (i++) + '</a>';
		ret[row][ret[row].length] = '<td align="center"' + cssClass + '>' + linkHTML + '</td>';
	}

	// Format the HTML
	for (i=0; i<ret.length; i++) ret[i] = ret[i].join('\n') + '\n';

	previousYear  = thisMonth.getFullYear();
	previousMonth = thisMonth.getMonth() - 1;
	if (previousMonth < 0){
		previousMonth = 11;
		previousYear--;
	}
	
	nextYear  = thisMonth.getFullYear();
	nextMonth = thisMonth.getMonth() + 1;
	if (nextMonth > 11){
		nextMonth = 0;
		nextYear++;
	}

	prevImgHTML  = '<img src="' + this.imagesPath + '/prev.gif" alt="<<" border="0" />';
	prevLinkHTML = '<a href="javascript: ' + this.objName + '.show(' + previousMonth + ', ' + previousYear + ')">' + prevImgHTML + '</a>';
	nextImgHTML  = '<img src="' + this.imagesPath + '/next.gif" alt="<<" border="0" />';
	nextLinkHTML = '<a href="javascript: ' + this.objName + '.show(' + nextMonth + ', ' + nextYear + ')">' + nextImgHTML + '</a>';

	// Build month combo
	if (this.useMonthCombo){
		monthComboOptions = '';
		for (i=0; i<12; i++) {
			selected = (i == thisMonth.getMonth() ? 'selected="selected"' : '');
			monthComboOptions += '<option value="' + i + '" ' + selected + '>' + monthnames[i] + '</option>';
		}
		monthCombo = '<select name="months" onchange="' + this.objName + '.show(this.options[this.selectedIndex].value, ' + this.objName + '.currentYear)">' + monthComboOptions + '</select>';
	}else{
		monthCombo = monthnames[thisMonth.getMonth()];
	}
	
	// Build year combo
	if (this.useYearCombo){
		yearComboOptions = '';
		for (i = thisMonth.getFullYear() - this.yearComboRange; i <= (thisMonth.getFullYear() + this.yearComboRange); i++) {
			selected = (i == thisMonth.getFullYear() ? 'selected="selected"' : '');
			yearComboOptions += '<option value="' + i + '" ' + selected + '>' + i + '</option>';
		}
		yearCombo = '<select style="border: 1px groove" name="years" onchange="' + this.objName + '.show(' + this.objName + '.currentMonth, this.options[this.selectedIndex].value)">' + yearComboOptions + '</select>';
	}else{
		yearCombo = thisMonth.getFullYear();
	}

	html = '<table width=160 border=0 bgcolor="#eeeeee" cellspacing=1 cellpadding=0 id="takvim2">';
	html += '<col width=20><col width=20><col width=20><col width=20><col width=20><col width=20><col width=20>';
	html += '<tr><th>' + prevLinkHTML + '</th><th colspan=5 nowrap>' + monthCombo + yearCombo + '</th><th>' + nextLinkHTML + '</th></tr>';
	html += '<tr>';
	html += '<td>'+gunler[0]+'</td>';
	html += '<td>'+gunler[1]+'</td>';
	html += '<td>'+gunler[2]+'</td>';
	html += '<td>'+gunler[3]+'</td>';
	html += '<td>'+gunler[4]+'</td>';
	html += '<td>'+gunler[5]+'</td>';
	html += '<td>'+gunler[6]+'</td></tr>';
	html += '<tr>' + ret.join('</tr>\n<tr>') + '</tr>';
	html += '</table>';

	this._setHTML(html);
	if (!arguments[0] && !arguments[1]){
		this._showLayer();
		this._setLayerPosition();
	}
}

/**
* Writes HTML to document for layer
*
* @access public
*/
function dynCalendar_writeHTML(){
	if (is_ie5up || is_nav6up || is_gecko) {
		document.write('<a href="javascript: ' + this.objName + '.show()"><img src="' + this.imagesPath + 'takvim.gif" border="0" width="16" height="16" /></a>');
		document.write('<div class="divTakvim2" id="' + this.layerID + '" onmouseover="' + this.objName + '._mouseover(true)" onmouseout="' + this.objName + '._mouseover(false)"></div>');
	}
}

function dynCalendar_setPosition(X,Y){
	this.posX=X;
	this.posY=Y;
}

/**
* Sets the offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Xoffset Number of pixels for vertical
*                        offset from mouse position
* @param integer Yoffset Number of pixels for horizontal
*                        offset from mouse position
*/
function dynCalendar_setOffset(Xoffset, Yoffset){
	this.setOffsetX(Xoffset);
	this.setOffsetY(Yoffset);
}

/**
* Sets the X offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Xoffset Number of pixels for horizontal
*                        offset from mouse position
*/
function dynCalendar_setOffsetX(Xoffset){
	this.offsetX = Xoffset;
}

/**
* Sets the Y offset to the mouse position
* that the calendar appears at.
*
* @access public
* @param integer Yoffset Number of pixels for vertical
*                        offset from mouse position
*/
function dynCalendar_setOffsetY(Yoffset){
	this.offsetY = Yoffset;
}

/**
* Sets the images path
*
* @access public
* @param string path Path to use for images
*/
function dynCalendar_setImagesPath(path){
	this.imagesPath = path;
}

/**
* Turns on/off the month dropdown
*
* @access public
* @param boolean useMonthCombo Whether to use month dropdown or not
*/
function dynCalendar_setMonthCombo(useMonthCombo){
	this.useMonthCombo = useMonthCombo;
}

/**
* Turns on/off the year dropdown
*
* @access public
* @param boolean useYearCombo Whether to use year dropdown or not
*/
function dynCalendar_setYearCombo(useYearCombo){
	this.useYearCombo = useYearCombo;
}

/**
* Sets the current month being displayed
*
* @access public
* @param boolean month The month to set the current month to
*/
function dynCalendar_setCurrentMonth(month){
	this.currentMonth = month;
}

/**
* Sets the current month being displayed
*
* @access public
* @param boolean year The year to set the current year to
*/
function dynCalendar_setCurrentYear(year){
	this.currentYear = year;
}

/**
* Sets the range of the year combo. Displays this number of
* years either side of the year being displayed.
*
* @access public
* @param integer range The range to set
*/
function dynCalendar_setYearComboRange(range){
	this.yearComboRange = range;
}

/**
* Returns the layer object
*
* @access private
*/
function dynCalendar_getLayer(){
	var layerID = this.layerID;

	if (document.getElementById(layerID)) {
		return document.getElementById(layerID);
	} else if (document.all(layerID)) {
		return document.all(layerID);
	}
}

/**
* Hides the calendar layer
*
* @access private
*/
function dynCalendar_hideLayer(){
	this._getLayer().style.visibility = 'hidden';
}

/**
* Shows the calendar layer
*
* @access private
*/
function dynCalendar_showLayer(){
	this._getLayer().style.visibility = 'visible';
}

/**
* Sets the layers position
*
* @access private
*/
function dynCalendar_setLayerPosition(){
	px=(this.posX) ? this.posX : dynCalendar_mouseX + this.offsetX;
	py=(this.posY) ? this.posY : dynCalendar_mouseY + this.offsetY;
	this._getLayer().style.left = px + 'px';
	this._getLayer().style.top  = py + 'px';
}

/**
* Sets the innerHTML attribute of the layer
*
* @access private
*/
function dynCalendar_setHTML(html){
	this._getLayer().innerHTML = html;
}

/**
* Returns number of days in the supplied month
*
* @access private
* @param integer month The month to get number of days in
* @param integer year  The year of the month in question
*/
function dynCalendar_getDaysInMonth(month, year){
	monthdays = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
	if (month != 1) return monthdays[month];
	return ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0 ? 29 : 28);
}

/**
* onMouse(Over|Out) event handler
*
* @access private
* @param boolean status Whether the mouse is over the
*                       calendar or not
*/
function dynCalendar_mouseover(status){
	dynCalendar_mouseoverStatus = status;
	return true;
}

/**
* onMouseMove event handler
*/
dynCalendar_oldOnmousemove = document.onmousemove ? document.onmousemove : new Function;

document.onmousemove = function (){
	if (is_ie5up || is_nav6up || is_gecko) {
		if (arguments[0]) {
			dynCalendar_mouseX = arguments[0].pageX;
			dynCalendar_mouseY = arguments[0].pageY;
		}else{
			dynCalendar_mouseX = event.clientX + document.body.scrollLeft;
			dynCalendar_mouseY = event.clientY + document.body.scrollTop;
			arguments[0] = null;
		}

		dynCalendar_oldOnmousemove();
	}
}

/**
* Callbacks for document.onclick
*/
dynCalendar_oldOnclick = document.onclick ? document.onclick : new Function;

document.onclick = function (){
	if (is_ie5up || is_nav6up || is_gecko) {
		if (!dynCalendar_mouseoverStatus){
			for (i=0; i<dynCalendar_layers.length; ++i){
				dynCalendar_layers[i]._hideLayer();
			}
		}

		dynCalendar_oldOnclick(arguments[0] ? arguments[0] : null);
	}
}

