	dynCalendar_layers          = new Array();
	dynCalendar_short_layers    = new Array();
	dynCalendar_mouseoverStatus = false;
	dynCalendar_mouseX          = 0;
	dynCalendar_mouseY          = 0;

	function dynCalendar(objName,langu, callbackFunc,inputid)
	{
		this.today          = new Date();
		this.hour						= 0;
		this.date           = this.today.getDate();
		this.month          = this.today.getMonth();
		this.year           = this.today.getFullYear();
		
		this.objName        = objName;
		this.langu					= langu;
		this.callbackFunc   = callbackFunc;
		this.inputid				= inputid;
		this.imagesPath     = arguments[4] ? arguments[4] : '../images/';
		this.layerID        = arguments[5] ? arguments[5] : 'dynCalendar_layer_' + dynCalendar_layers.length;

		if (arguments[6] != ''){
			this.date = arguments[6];
		}
		if (arguments[7] != ''){
			this.month = arguments[7]-1;
		}
		if (arguments[8] != ''){
			this.year = arguments[8];
		}

		this.offsetX        = 5;
		this.offsetY        = 5;

		this.useMonthCombo  = true;
		this.useYearCombo   = true;
		this.yearComboRange = 5;

		this.currentMonth   = this.month;
		this.currentYear    = this.year;
		this.currentHour		= this.hour;
		
		/**
        * Public Methods
        */
		this.show              = dynCalendar_show;
		this.writeHTML         = dynCalendar_writeHTML;

		// Accessor methods
		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();
	}


	function dynCalendar_short(objName,langu)
	{
		// Todays date
		this.today          = new Date();
		this.month          = this.today.getMonth();
		this.year           = this.today.getFullYear();
		
		this.objName        = objName;
		this.langu					= langu;
		this.imagesPath     = arguments[4] ? arguments[4] : '../images/';
		this.layerID        = arguments[5] ? arguments[5] : 'dynCalendar_short_layer_' + dynCalendar_short_layers.length;

		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_short;
		this.writeHTML         = dynCalendar_writeHTML_short;

		// Accessor methods
		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._setHTML          = dynCalendar_setHTML;

		// Miscellaneous
		this._getDaysInMonth   = dynCalendar_getDaysInMonth;

		/**
        * Constructor type code
        */
		dynCalendar_short_layers[dynCalendar_short_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 hour, 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;
		this.currentHour  = hour  = arguments[2] != null ? arguments[2] : this.currentHour;
		
		if (this.langu=='en')
		monthnames = new Array('January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December');
		else
		monthnames = new Array('Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Aout', 'Septembre', 'Octobre', 'Novembre', 'Decembre');
			
		numdays    = this._getDaysInMonth(month, year);

		thisMonth    = new Date(year, month, 1);
		
		if (this.langu=='en')
		firstOfMonth = thisMonth.getDay();
		else
		firstOfMonth = thisMonth.getUTCDay();
		
		// 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) ? 'dynCalendar_today' : 'dynCalendar_day';
			linkHTML = "<a href=javascript:" + this.callbackFunc + "('"+ this.inputid +"'," + hour + "," + i + "," + (Number(month) + 1) + "," + year + ");" + this.objName + "._hideLayer()>" + (i++) + "</a>";
			ret[row][ret[row].length] = '<td align="center" class="' + 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 + ', ' + hour + ')">' + prevImgHTML + '</a>';
		nextImgHTML  = '<img src="' + this.imagesPath + '/next.gif" alt=">>" border="0" />';
		nextLinkHTML = '<a href="javascript: ' + this.objName + '.show(' + nextMonth + ', ' + nextYear + ', ' + hour + ')">' + 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, '+hour+')">' + 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,'+hour+')">' + yearComboOptions + '</select>';
		} else {
			yearCombo = thisMonth.getFullYear();
		}

		td_debut = '<td align="center" class="' + cssClass + '">';
		td_fin = '</td>';
		
		dynCalendar_hour = new Array(new Array());
		dynCalendar_hour_html = new Array(new Array());
		
		max_nb_hour_by_line = 12;
		nb_hour = 0;
		row = 0;
		row = 0;
		for (h=0; h<24; h=h+1) {
			nb_hour++;
			
			if (dynCalendar_hour_html[row].length == max_nb_hour_by_line)
			{
				++row;
				dynCalendar_hour_html[row] = new Array();
				dynCalendar_hour[row] = new Array();
			}
			
				if (this.currentHour == h){
					sel = " CHECKED ";
				}
				else
				{
					sel = "";
				}
				
				dynCalendar_hour_html[row][dynCalendar_hour_html[row].length] = '<td align="center" class="dynCalendar_hourname">'+h+'</td>';
	
				oncheck = ' onclick="javascript: ' + this.objName + '.show(' + month + ', ' + year + ', ' + h + ')" ';
				dynCalendar_hour[row][dynCalendar_hour[row].length] = td_debut+ '<input type="radio" '+sel+' name="r_hour" '+oncheck+'>' +td_fin;
				
					}
		
		html = '<table border="0" cellpadding="0" cellspacing="0"><tr><td>'
		
		html += '<table border="0" cellpadding="0" cellspacing="0" width="100%">';
		html += '<tr><td colspan="7" class="dynCalendar_header"><img src="../images/blank.gif" width="250" height="1" border="0"></td></tr>';
		html += '<tr><td colspan="7" class="dynCalendar_header">' + prevLinkHTML + '&nbsp;&nbsp;' + monthCombo + ' ' + yearCombo + '&nbsp;&nbsp;' + nextLinkHTML + '</td></tr>';
		html += '<tr>';
			if (this.langu=='en'){
			html += '<td class="dynCalendar_dayname">Sun</td>';
			html += '<td class="dynCalendar_dayname">Mon</td>';
			html += '<td class="dynCalendar_dayname">Tue</td>';
			html += '<td class="dynCalendar_dayname">Wed</td>';
			html += '<td class="dynCalendar_dayname">Thu</td>';
			html += '<td class="dynCalendar_dayname">Fri</td>';
			html += '<td class="dynCalendar_dayname">Sat</td></tr>';
			
			titre_heure = "Hour :";
		}
		else
			{
			html += '<td class="dynCalendar_dayname">Lun</td>';
			html += '<td class="dynCalendar_dayname">Mar</td>';
			html += '<td class="dynCalendar_dayname">Mer</td>';
			html += '<td class="dynCalendar_dayname">Jeu</td>';
			html += '<td class="dynCalendar_dayname">Ven</td>';
			html += '<td class="dynCalendar_dayname">Sam</td>';
			html += '<td class="dynCalendar_dayname">Dim</td></tr>';
			
			titre_heure = "Heure :";
		}
		html += '<tr>' + ret.join('</tr>\n<tr>') + '</tr>';
		html += '</table>';
		
		/*
		html += '</td></tr><tr><td colspan="7" align="center">'+titre_heure+'</td></tr><tr><td>';
		
		html += '<table border="0" cellpadding="0" cellspacing="0" width="100%">';
		html += '<tr>' + dynCalendar_hour_html[0].join('') + '</tr>';
		html += '<tr>' + dynCalendar_hour[0].join('') + '</tr>';
		html += '<tr>' + dynCalendar_hour_html[1].join('') + '</tr>';
		html += '<tr>' + dynCalendar_hour[1].join('') + '</tr>';
		html += '</table>';
		*/
		html += '</td></tr></table>';
		
		
		this._setHTML(html);
		if (!arguments[0] && !arguments[1]) {
			this._showLayer();
			this._setLayerPosition();
		}
	}

	function dynCalendar_show_short()
	{
		// 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;
		
		if (this.langu=='en')
		monthnames = new Array('January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December');
		else
		monthnames = new Array('Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Aout', 'Septembre', 'Octobre', 'Novembre', 'Decembre');
			
		numdays    = this._getDaysInMonth(month, year);

		thisMonth    = new Date(year, month, 1);

		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 border="0" cellpadding="0" cellspacing="0">';
		html += '<tr><td class="dynCalendar_header">' + prevLinkHTML + '&nbsp;&nbsp;' + monthCombo + ' ' + yearCombo + '&nbsp;&nbsp;' + nextLinkHTML + '</td></tr>';
		html += '<tr><td align="center"><input type="submit" value="Valider"></td></tr>';
		html += '</table>';
		
		this._setHTML(html);
	}

/**
* 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 + 'dynCalendar.gif" border="0" width="32" height="18"></a><div class="dynCalendar" id="' + this.layerID + '" onmouseover="' + this.objName + '._mouseover(true)" onmouseout="' + this.objName + '._mouseover(false)"></div>');
		}
	}
	function dynCalendar_writeHTML_short()
	{
		if (is_ie5up || is_nav6up || is_gecko) {
			document.write('<form action="planning.asp"><div align="center" class="dynCalendar_short" id="' + this.layerID + '"></div></form>');
		}
	}
	
    function cb(inputid, hour, date, month, year)
    {
        if (String(month).length == 1) {
            month = '0' + month;
        }
        if (String(date).length == 1) {
            date = '0' + date;
        }
        if (String(hour).length == 1) {
            hour = '0' + hour;
        }
        //document.getElementById(inputid).value = date+ '/' +month+ '/' +year+' '+hour+':00:00';
		document.getElementById(inputid).value = date+ '/' +month+ '/' +year;

    }
/**
* 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()
	{
		//this._getLayer().style.top  = (dynCalendar_mouseY + this.offsetY) + 'px';
		//this._getLayer().style.left = (dynCalendar_mouseX + this.offsetX) + 'px';
		
		this._getLayer().style.top  = (y + this.offsetY) + 'px';
		this._getLayer().style.left = (x + this.offsetX) + '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];
		} else {
			return ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0 ? 29 : 28);
		}
	}

// onMouse(Over|Out) event handler

	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);
		}
	}