/**
 * NOTICE OF LICENSE
 * DG, Copyright (c) 2010 dreier-schmiede UG | www.dreier-schmiede.de
 *
 * @category    design
 * @copyright   DG, Copyright (c) 2010 dreier-schmiede UG | www.dreier-schmiede.de
 * @requires	prototype.js, 12geschenke.js
 * 
 */

// Create namespace
if (at == undefined) var at = {};
if (at.bartelme == undefined) at.bartelme = {};

// Newsticker Class
at.bartelme.newsticker = Class.create();
at.bartelme.newsticker.prototype = {
	initialize: function()
	{
		// Get elements
		this.interval = 7000;	// Zeit Anzeigedauer
		this.container = $("col-right02");
		this.messages  = $A(this.container.getElementsByTagName("li"));
		this.number_of_messages = this.messages.length;
		if (this.number_of_messages == 0)
		{
			this.showError();
			return false;
		}
		this.current_message = 0;
		this.previous_message = null;
		this.hideMessages();
		this.showMessage();
		// Install timer
		this.timer = setInterval(this.showMessage.bind(this), this.interval);
  	},
	showMessage: function()
	{
		Effect.Appear(this.messages[this.current_message], {duration:3}); // Zeit-Auftauchen
		setTimeout(this.fadeMessage.bind(this), this.interval-3000); // Zeit zwischen Auftauchen und Abgang
		if (this.current_message < this.number_of_messages-1)
		{
			this.previous_message = this.current_message;
			this.current_message = this.current_message + 1;
		} else {
			this.current_message = 0;
			this.previous_message = this.number_of_messages - 1;
		}
	},
	fadeMessage: function()
	{
		Effect.Fade(this.messages[this.previous_message], {duration:3}); // Zeit-Abgang
	},
	hideMessages: function()
	{
		this.messages.each(function(message)
		{
			Element.hide(message);
		})
	},
	toggle: function()
	{
		Effect.BlindUp(this.container, 1000);
	},
	showError: function()
	{
		if (this.container.getElementsByTagName("ul").length == 0)
		{
			this.list = document.createElement("ul");
			this.container.appendChild(this.list);
		} else {
			this.list = this.container.getElementsByTagName("ul")[0];
		}
		this.errorMessage = document.createElement("li");
		this.errorMessage.className = "error";
		this.errorMessage.innerHTML = "Could not retrieve data";
		this.list.appendChild(this.errorMessage);
	}
}

Event.observe(window, "load", function(){
	// Get the highest <li>-element
	var MaxHeight = 0;
	// First get highest
	$$('#col-right02 li').each(function(item){
		if(item.getHeight()>MaxHeight) MaxHeight=item.getHeight();
	});
	// Get current height of div and then add MaxHight in <div>-element
	$('col-right02').select('ul').first().setStyle({height: MaxHeight+'px'});
	// Start newsticker
	new at.bartelme.newsticker()}, false);
