/**
 * DatePicker widget using Prototype and Scriptaculous.
 * (c) 2007 Mathieu Jondet <mathieu@eulerian.com>
 * Eulerian Technologies
 *
 * DatePicker is freely distributable under the same terms as Prototype.
 *
 * Now it is a "SingleDatePicker" - modified by SEC
 *
 */

var oldelement = "";
var oldclassname = "";
var activeElement = "";
var oldelement2 = "";
var oldclassname2 = "";
var activeElement2 = "";

var ActiveDates = [];

Array.prototype.contains = function(searchString){
	for(result=[], x=0; x<this.length; x++){
		if(this[x] == searchString){
			result[result.length]=x;
		}
	}
	return result.length ? result : -1;
};

var DatePicker = Class.create();

DatePicker.prototype = {
 Version	: '0.9.2',
 _relative	: 'date1',
 _field2	: 'date2',
 _hdr1		: 'Anreise',
 _hdr2		: 'Abreise',
 _JSvarName	: 'reise_kalender',
 _disableIDs	: new Array(),
 _div		: null,
 _zindex	: 9999,
 _keepFieldEmpty: false,
 _daysInMonth	: [31,28,31,30,31,30,31,31,30,31,30,31],
 _minDate	: 0,
 _maxDate	: 99999999,
 /* language */
 _language	: 'de',
 _language_month	: $H({
  'fr'	: [ 'Janvier', 'F&#233;vrier', 'Mars', 'Avril', 'Mai', 'Juin', 
   'Juillet', 'Aout', 'Septembre', 'Octobre', 'Novembre', 'D&#233;cembre' ],
  'en'	: [ 'January', 'February', 'March', 'April', 'May',
   'June', 'July', 'August', 'September', 'October', 'November', 'December' ],
  'sp'	: [ 'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 
   'Julio', 'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre' ],
  'it'	: [ 'Gennaio', 'Febbraio', 'Marzo', 'Aprile', 'Maggio', 'Giugno',
   'Luglio', 'Agosto', 'Settembre', 'Ottobre', 'Novembre', 'Dicembre' ],
  'de'	: [ 'Januar', 'Februar', 'M&#228;rz', 'April', 'Mai', 'Juni',
   'Juli', 'August', 'September', 'Oktober', 'November', 'Dezember' ],
  'pt'	: [ 'Janeiro', 'Fevereiro', 'Mar&#231;o', 'Abril', 'Maio', 'Junho',
   'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro' ]
 }),
 _language_day	: $H({
  'fr'	: [ 'Lun', 'Mar', 'Mer', 'Jeu', 'Ven', 'Sam', 'Dim' ],
  'en'	: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ],
  'sp'	: [ 'Lun', 'Mar', 'Mie', 'Jue', 'Vie', 'S&#224;b', 'Dom' ],
  'it'	: [ 'Lun', 'Mar', 'Mer', 'Gio', 'Ven', 'Sab', 'Dom' ],
  'de'	: [ 'Mo', 'Di', 'Mi', 'Do', 'Fr', 'Sa', 'So' ],
  'pt'	: [ 'Seg', 'Ter', 'Qua', 'Qui', 'Sex', 'S&#225;', 'Dom' ]
 }),
 _language_close	: $H({
  'fr'	: 'fermer',
  'en'	: 'close',
  'sp'	: 'cierre',
  'it'	: 'fine',
  'de'	: 'schliessen',
  'pt'	: 'fim'
 }),
 /* date manipulation */
 _todayDate	: new Date(),
 _date_regexp	: /^(\d{1,2})(\/|\.|\-)(\d{1,2})(?:\/|\.|\-)(\d{4})$/,
 _current_date	: null,
 _clickCallback	: Prototype.emptyFunction,
 _date_separator: '.',
 _id_datepicker	: null,
 /* positionning */
 _topOffset	: 0,
 _leftOffset	: 0,
 _isPositionned	: false,
 _relativePosition : true,
 /* return the name of current month in appropriate language */
 getMonthLocale	: function ( month ) {
  return	this._language_month[this._language][month];
 },
 getLocaleClose	: function () {
  /* return	this._language_close[this._language]; */

  return [];
 },
 _initCurrentDate : function (tab) {
  /* check if value in field is proper, set to today */
  if(tab == '1') {
  	this._current_date	= $F(this._field2);
  } else {
  	this._current_date	= $F(this._relative);
  }
  if ( !this._date_regexp.test(this._current_date) ) {
   var now	= new Date();
   var day	= this._leftpad_zero(now.getDate(), 2);
   var mon	= this._leftpad_zero(now.getMonth() + 1, 2);
   /* depending on language not presented the same way */
   if ( this._language == 'en' )
    this._current_date	= mon+'/'+day+'/'+now.getFullYear();
   else 
    this._current_date	= day+'/'+mon+'/'+now.getFullYear();
   /* set the field value ? */
   if ( !this._keepFieldEmpty )
    $(this._relative).setAttribute('value', this._current_date);
  }
  var a_date_regexp	= this._current_date.match(this._date_regexp);
  /* fetch date separator as specified in option or via value */
  this._date_separator	= String(a_date_regexp[2]);
  /* check language */
  if ( this._language == 'en' ) {
   this._current_mon	= Number(a_date_regexp[1]) - 1;
   this._current_day	= Number(a_date_regexp[3]);
  } else {
   this._current_day	= Number(a_date_regexp[1]);
   this._current_mon	= Number(a_date_regexp[3]) - 1;
  }
  this._current_year	= Number(a_date_regexp[4]);
  
  if(tab == '1') {
    this.dev_cur_mon2 = this._current_mon;
    this.dev_cur_year2 = this._current_year;
  } else {
    this.dev_cur_mon1 = this._current_mon;
    this.dev_cur_year1 = this._current_year;
  }
 },
 /* init */
 initialize	: function ( h_p ) {
  /* arguments */
  if ( typeof(h_p["field1"]) != 'undefined' ) this._relative= h_p["field1"];
  if ( typeof(h_p["field2"]) != 'undefined' ) this._field2= h_p["field2"];
  if ( typeof(h_p["hdr1"]) != 'undefined' ) this._hdr1= h_p["hdr1"];
  if ( typeof(h_p["hdr2"]) != 'undefined' ) this._hdr2= h_p["hdr2"];
  if ( typeof(h_p["hideFields"]) != 'undefined' ) this._disableIDs= h_p["hideFields"];
  if ( typeof(h_p["varName"]) != 'undefined' ) this._JSvarName= h_p["varName"];

  if ( typeof(h_p["maxDate"]) != 'undefined' ) this._maxDate= h_p["maxDate"];
  if ( typeof(h_p["minDate"]) != 'undefined' ) this._minDate= h_p["minDate"];

  if ( h_p["language"] )
   this._language = h_p["language"];
  this._zindex	= ( h_p["zindex"] ) ? parseInt(Number(h_p["zindex"])) : 1;
  if ( typeof(h_p["keepFieldEmpty"]) != 'undefined' )
   this._keepFieldEmpty	= h_p["keepFieldEmpty"];
  if ( typeof(h_p["clickCallback"]) == 'function' )
   this._clickCallback	= h_p["clickCallback"];
  if ( typeof(h_p["leftOffset"]) != 'undefined' )
   this._leftOffset	= parseInt(h_p["leftOffset"]);
  if ( typeof(h_p["topOffset"]) != 'undefined' )
   this._topOffset	= parseInt(h_p["topOffset"]);
  if ( typeof(h_p["relativePosition"]) != 'undefined' )
   this._relativePosition = h_p["relativePosition"];
  this._id_datepicker		= 'datepicker-'+this._relative;
  this._id_datepicker_prev	= this._id_datepicker+'-prev';
  this._id_datepicker_next	= this._id_datepicker+'-next';
  this._id_datepicker_hdr	= this._id_datepicker+'-header';
  this._id_datepicker_ftr	= this._id_datepicker+'-footer';

  this._id_datepicker_prev2	= this._id_datepicker+'-prev2';
  this._id_datepicker_next2	= this._id_datepicker+'-next2';
  this._id_datepicker_hdr2	= this._id_datepicker+'-header2';

  this._id_datepicker_closer	= this._id_datepicker+'-closer';

  /* build up calendar skel */
  this._div = Builder.node('div', { 
    id 		: this._id_datepicker,
    className	: 'datepicker',
    style	: 'display: none; z-index: 9;'
   }, [
      Builder.node('div', { className : 'datepicker-header-text' }, [
       Builder.node('span', { id : 'datepicker-hdr-text_left', style : '' }, this._hdr1),
       Builder.node('a', { id : this._id_datepicker_closer, className : 'datepicker-closer' }, 'x')
      ]),
      /* header 1 */
      Builder.node('div', { className : 'datepicker-header' }, [
       Builder.node('span', { 
	id : this._id_datepicker_prev, className : 'datepicker_left' }, ' '),
       Builder.node('span', { id : this._id_datepicker_hdr }),
       Builder.node('span', { 
	id : this._id_datepicker_next, className : 'datepicker_right' }, ' ')
      ]),
      
      /* calendar 2 */
      Builder.node('div', { className : 'datepicker-calendar', style: 'float:right;' }, [
       Builder.node('table', { id : this._id_datepicker+'-table2' }) ]),
      /* calendar 1 */
      Builder.node('div', { className : 'datepicker-calendar' }, [
       Builder.node('table', { id : this._id_datepicker+'-table' }) ]),
      
      /* footer */
      Builder.node('div', { 
       id 	: this._id_datepicker_ftr,
       className: 'datepicker-footer' }, this.getLocaleClose() )
  ]);
  /* finally declare the event listener on input field */
  Event.observe(this._relative, 
    'click', this.click.bindAsEventListener(this), false);
  /* need to append on body when doc is loaded for IE */
  Event.observe(window, 'load', this.load.bindAsEventListener(this), false);
 },
 /**
  * load	: called when document is fully-loaded to append datepicker
  *		  to main object.
  */
 load		: function () {
  /* append to body */
  var body	= document.getElementsByTagName("body").item(0);
  if ( body )
   body.appendChild( this._div );
  /* init the date in field if needed */
  this._initCurrentDate();
  /* declare the observers for UI control */
  Event.observe($(this._id_datepicker_prev), 
    'click', this.prevMonth.bindAsEventListener(this, ''), false);
  Event.observe($(this._id_datepicker_next), 
    'click', this.nextMonth.bindAsEventListener(this, ''), false);
  Event.observe($(this._id_datepicker_closer), 
    'click', this.close.bindAsEventListener(this), false);
 },
 /**
  * click	: called when input element is clicked
  */
 click		: function () {
  if ( !this._isPositionned && this._relativePosition ) {
   /* position the datepicker relatively to element */
   var a_lt = Position.cumulativeOffset($(this._relative));
   $(this._id_datepicker).setStyle({
    'left'	: Number(a_lt[0]+this._leftOffset)+'px',
    'top'	: Number(a_lt[1]+this._topOffset)+'px'
   });
   this._isPositionned	= true;
  }
  if ( !$(this._id_datepicker).visible() ) {
   this._initCurrentDate();
   this._redrawCalendar();
   var actel = this._relative + '-' + this._leftpad_zero(this._current_day, 2) + '-' + this._leftpad_zero((this._current_mon + 1), 2) + '-' + this._current_year;
   oldelement = document.getElementById(actel);
   oldelement.className = oldelement.className + ' active';
  }
  /* eval the clickCallback function */
  eval(this._clickCallback());
  /* Effect toggle to fade-in / fade-out the datepicker */
  new Effect.toggle(this._id_datepicker, 'appear', {duration:0.3});
  load_holidays(lastbundesland, this._relative);

  for(i=0; i<this._disableIDs.length;i++) {
	feld = document.getElementById(this._disableIDs[i]);
    new Effect.toggle(feld, 'appear', {duration:0.3});
  }

  if($(this._id_datepicker).visible() == true) if( window.CallAjaxCalendar ) CallAjaxCalendar();
 },
 /**
  * close	: called when the datepicker is closed
  */
 close		: function () {
  new Effect.Fade(this._id_datepicker, { duration : 0.3 });

  for(i=0; i<this._disableIDs.length;i++) {
	feld = document.getElementById(this._disableIDs[i]);
    new Effect.toggle(feld, 'appear', {duration:0.3});
  }

  if( window.CallAjaxCalendar ) CallAjaxCalendar();
 },
 /**
  * setPosition	: set the position of the datepicker.
  *  param : t=top | l=left
  */
 setPosition	: function ( t, l ) {
  var h_pos	= { 'top' : '0px', 'left' : '0px' };
  if ( typeof(t) != 'undefined' )
   h_pos['top']	= Number(t)+this._topOffset+'px';
  if ( typeof(l) != 'undefined' )
   h_pos['left']= Number(l)+this._leftOffset+'px';
  $(this._id_datepicker).setStyle(h_pos);
  this._isPositionned	= true;
 },
 /**
  * _leftpad_zero : pad the provided string to given number of 0
  */
  /** CHECK toPaddedString: from http://dev.rubyonrails.org/changeset/6363 */
 _leftpad_zero	: function ( str, padToLength ) {
  var result	= '';
  for ( var i = 0; i < (padToLength - String(str).length); i++ )
   result	+= '0';
  return	result + str;
 },
 /**
  * _getMonthDays : given the year and month find the number of days.
  */
 _getMonthDays	: function ( year, month ) {
  if (((0 == (year%4)) && 
   ( (0 != (year%100)) || (0 == (year%400)))) && (month == 1))
   return 29;
  return this._daysInMonth[month];
 },
 /**
  * _buildCalendar	: draw the days array for current date
  */
 _buildCalendar		: function (ZusatzID) {
  var _self	= this;
  var tbody	= document.createElement('tbody');
  /* generate day headers */
  var trDay	= document.createElement('tr');
  this._language_day[this._language].each( function ( item ) {
   var td	= document.createElement('td');
   td.innerHTML	= item;
   td.className	= 'wday';
   trDay.appendChild( td );
  });
  tbody.appendChild( trDay );
  /* generate the content of days */
  
  /* build-up days matrix */
  var a_d	= [
    [ 0, 0, 0, 0, 0, 0, 0 ]
   ,[ 0, 0, 0, 0, 0, 0, 0 ]
   ,[ 0, 0, 0, 0, 0, 0, 0 ]
   ,[ 0, 0, 0, 0, 0, 0, 0 ]
   ,[ 0, 0, 0, 0, 0, 0, 0 ]
   ,[ 0, 0, 0, 0, 0, 0, 0 ]
  ];
  /* set date at beginning of month to display */
  var d		= new Date(this._current_year, this._current_mon, 1, 12);
  /* start the day list on monday */
  var startIndex	= ( !d.getDay() ) ? 6 : d.getDay() - 1;
  var nbDaysInMonth	= this._getMonthDays(
    this._current_year, this._current_mon);
  var daysIndex		= 1;
  for ( var j = startIndex; j < 7; j++ ) {
   a_d[0][j]	= { 
     d : daysIndex
    ,m : this._current_mon
    ,y : this._current_year 
   };
   daysIndex++;
  }
  var a_prevMY	= this._prevMonthYear();
  var nbDaysInMonthPrev	= this._getMonthDays(a_prevMY[1], a_prevMY[0]);
  for ( var j = 0; j < startIndex; j++ ) {
   a_d[0][j]	= { 
     d : Number(nbDaysInMonthPrev - startIndex + j + 1) 
    ,m : Number(a_prevMY[0])
    ,y : a_prevMY[1]
    ,c : 'outbound'
   };
  }
  var switchNextMonth	= false;
  var currentMonth	= this._current_mon;
  var currentYear	= this._current_year;
  for ( var i = 1; i < 6; i++ ) {
   for ( var j = 0; j < 7; j++ ) {
    a_d[i][j]	= { 
      d : daysIndex
     ,m : currentMonth
     ,y : currentYear
     ,c : ( switchNextMonth ) ? 'outbound' : ( 
      ((daysIndex == this._todayDate.getDate()) &&
        (this._current_mon  == this._todayDate.getMonth()) &&
        (this._current_year == this._todayDate.getFullYear())) ? 'today' : null)
    };
    daysIndex++;
    /* if at the end of the month : reset counter */
    if ( daysIndex > nbDaysInMonth ) {
     daysIndex	= 1;
     switchNextMonth = true;
     if ( this._current_mon + 1 > 11 ) {
      currentMonth = 0;
      currentYear += 1;
     } else {
      currentMonth += 1;
     }
    }
   }
  }

  /* generate days for current date */
  for ( var i = 0; i < 6; i++ ) {
   var tr	= document.createElement('tr');
   for ( var j = 0; j < 7; j++ ) {
    var h_ij	= a_d[i][j];
    var td	= document.createElement('td');
    /* id is : datepicker-day-mon-year or depending on language other way */
    /* don't forget to add 1 on month for proper formmatting */
    var tdZusatzID = '';
    if(ZusatzID != "") tdZusatzID = '_' + ZusatzID;
    if ( this._language == 'en' ) 
     var id	= $A([ this._relative, this._leftpad_zero((h_ij["m"] +1), 2),
       this._leftpad_zero(h_ij["d"], 2), h_ij["y"] ]).join('-');
     else 
      var id	= $A([ this._relative + tdZusatzID, this._leftpad_zero(h_ij["d"], 2),
	this._leftpad_zero((h_ij["m"] + 1), 2), h_ij["y"] ]).join('-');
    /* set id and classname for cell if exists */
    td.setAttribute('id', id);

    /* checking date if clickable or not */
	if(h_ij["c"] == "outbound") {
		td.className	= h_ij["c"];
	} else {
	    var checkDatum	= $A([ this._leftpad_zero(h_ij["d"], 2), this._leftpad_zero((h_ij["m"] + 1), 2), h_ij["y"] ]).join('.');
	    var pruefDatum = ActiveDates.contains(checkDatum);
	
		var numberDate = Number(h_ij["y"] + this._leftpad_zero((h_ij["m"] + 1), 2) + this._leftpad_zero(h_ij["d"], 2));
		var numberMinDate = Number(this._minDate);
		var numberMaxDate = Number(this._maxDate);
	
	    // if(pruefDatum.length > 0 || ActiveDates.length == 0) {
		if(numberDate >= numberMinDate && numberDate <= numberMaxDate) {
			if ( h_ij["c"] ) td.className	= h_ij["c"];
		    /* on onclick : rebuild date value from id of current cell */
		    td.onclick	= function () {
		     if(ZusatzID != "") {
		     	var replStr = _self._relative + '_' + ZusatzID;
		     	var replField = _self._field2;
		     	activeElement2 = $(this).readAttribute('id');
		     } else {
		     	var replStr = _self._relative;
		     	var replField = _self._relative;
		     	activeElement = $(this).readAttribute('id');
		     }
		     $(replField).value = String($(this).readAttribute('id')
			).replace(replStr+'-','').replace(/-/g,_self._date_separator); 
		     /* _self.close(); */
     
		     if(ZusatzID != "") {
			     if(oldelement2 != "") {
			       if(oldelement2) oldelement2.className = oldelement2.className.replace(/active/g, "");
			     }
			     oldelement2 = this;
			     this.className = this.className + ' active';
		     } else {
			     if(oldelement != "") {
			       if(oldelement) oldelement.className = oldelement.className.replace(/active/g, "");
			     }
			     oldelement = this;
			     this.className = this.className + ' active';
		     }
		    };
		} else {
			td.className	= "inactive";
			if ( h_ij["c"] ) td.className	= h_ij["c"] + " inactive";
		}
	}
    td.innerHTML= h_ij["d"];
    tr.appendChild( td );
   }
   tbody.appendChild( tr );
  }
  return	tbody;
 },
 /**
  * nextMonth	: redraw the calendar content for next month.
  */
 _nextMonthYear	: function (tab) {
  var c_mon	= this._current_mon;
  var c_year	= this._current_year;
  if(tab == '') {
    var c_mon	= this.dev_cur_mon1;
    var c_year	= this.dev_cur_year1;
  }
  if(tab == '1') {
    var c_mon	= this.dev_cur_mon2;
    var c_year	= this.dev_cur_year2;
  }
  
  if ( c_mon + 1 > 11 ) {
   c_mon	= 0;
   c_year	+= 1;
  } else {
   c_mon	+= 1;
  }
  return	[ c_mon, c_year ];
 },
 nextMonth	: function (evt, tab) {
  var a_next		= this._nextMonthYear(tab);
  this._current_mon	= a_next[0];
  this._current_year 	= a_next[1];
  if(tab == '') {
    this.dev_cur_mon1	= a_next[0];
    this.dev_cur_year1	= a_next[1];
  }
  if(tab == '1') {
    this.dev_cur_mon2	= a_next[0];
    this.dev_cur_year2	= a_next[1];
  }
  this._redrawCalendar(tab);
  load_holidays(lastbundesland, this._relative);
  load_activeElements();
 },
 /**
  * prevMonth	: redraw the calendar content for previous month.
  */
 _prevMonthYear	: function (tab) {
  var c_mon	= this._current_mon;
  var c_year	= this._current_year;
  if(tab == '') {
    var c_mon	= this.dev_cur_mon1;
    var c_year	= this.dev_cur_year1;
  }
  if(tab == '1') {
    var c_mon	= this.dev_cur_mon2;
    var c_year	= this.dev_cur_year2;
  }
  
  if ( c_mon - 1 < 0 ) {
   c_mon	= 11;
   c_year	-= 1;
  } else {
   c_mon	-= 1;
  }
  return	[ c_mon, c_year ];
 },
 prevMonth	: function (evt, tab) {
  var a_prev		= this._prevMonthYear(tab);
  this._current_mon	= a_prev[0];
  this._current_year 	= a_prev[1];
  if(tab == '') {
    this.dev_cur_mon1	= a_prev[0];
    this.dev_cur_year1	= a_prev[1];
  }
  if(tab == '1') {
    this.dev_cur_mon2	= a_prev[0];
    this.dev_cur_year2	= a_prev[1];
  }
  this._redrawCalendar(tab);
  load_holidays(lastbundesland, this._relative);
  load_activeElements();
 },
 _redrawCalendar	: function (Tabelle2) {
  if(Tabelle2 == '1') {
  	this._setLocaleHdr('1');
  	var ZusatzTableId = '2';
  	var BuildTableId = '1';
  } else {
  	this._setLocaleHdr('0');
  	var ZusatzTableId = '';
  	var BuildTableId = '';
  }
  
  var table	= $(this._id_datepicker+'-table' + ZusatzTableId);
  try {
   while ( table.hasChildNodes() )
    table.removeChild(table.childNodes[0]);
  } catch ( e ) {}
  table.appendChild( this._buildCalendar(BuildTableId) );
 },
 _setLocaleHdr	: function (Tabelle2) {
  if(Tabelle2 == '1') {
  	var div_next	= this._id_datepicker_next2;
  	var div_prev	= this._id_datepicker_prev2;
  	var div_hdr	= this._id_datepicker_hdr2;
  } else {
  	var div_next	= this._id_datepicker_next;
  	var div_prev	= this._id_datepicker_prev;
  	var div_hdr	= this._id_datepicker_hdr;
  }
  /* next link */
  var a_next	= this._nextMonthYear();
  $(div_next).setAttribute('title', this.getMonthLocale(a_next[0])+' '+a_next[1]);
  /* prev link */
  var a_prev	= this._prevMonthYear();
  $(div_prev).setAttribute('title', this.getMonthLocale(a_prev[0])+' '+a_prev[1]);
  /* header */
  $(div_hdr).update('&nbsp;'+this.getMonthLocale(this._current_mon)+'&nbsp;'+this._current_year+'&nbsp;');
 }
};

/* Ferien für Bundesländer mit anderer Class versehen, wenn man das Bundesland auswählt */

var lastbundesland = 0;
function load_holidays(bundesland, DIVID) {
	
	if(lastbundesland > 0) {
		if(Ferien[lastbundesland]) {
			var AlteFerien = Ferien[lastbundesland];
			for (var i = 0; i < AlteFerien.length; ++i) {
				var element = DIVID + '-' + AlteFerien[i];
				var element2 = DIVID + '_1-' + AlteFerien[i];
				if(document.getElementById(element)) document.getElementById(element).className = document.getElementById(element).className.replace('highlight');
				if(document.getElementById(element2)) document.getElementById(element2).className = document.getElementById(element2).className.replace('highlight');
			}
		}
	}

	if(bundesland > 0) {
		if(Ferien[bundesland]) {
			var NeueFerien = Ferien[bundesland];
			for (var i = 0; i < NeueFerien.length; ++i) {
				var element = DIVID + '-' + NeueFerien[i];
				var element2 = DIVID + '_1-' + NeueFerien[i];
				if(document.getElementById(element)) document.getElementById(element).className =  document.getElementById(element).className + " highlight";
				if(document.getElementById(element2)) document.getElementById(element2).className = document.getElementById(element2).className + " highlight";
			}
		}
	}
	
	lastbundesland = bundesland;
	load_activeElements();
}

/* Die 2 aktiven Tage markieren */

function load_activeElements() {
	if(activeElement != "") {
		if(document.getElementById(activeElement)) {
			oldelement = document.getElementById(activeElement);
			document.getElementById(activeElement).className = document.getElementById(activeElement).className + ' active';
		}
	}
	if(activeElement2 != "") {
		if(document.getElementById(activeElement2)) {
			oldelement2 = document.getElementById(activeElement2);
			document.getElementById(activeElement2).className = document.getElementById(activeElement2).className + ' active';
		}
	}
}