// Tooltips Class
// A superclass to work with simple CSS selectors
var Tooltips = Class.create();
var tooltipsOnPage = new Array();

Tooltips.prototype = {
	initialize: function(selector, options) {
		var tooltips = $$(selector);
		tooltips.each( function(tooltip) {
			//tooltipsOnPage.push(this.el);
			//
			
				new Tooltip(tooltip, options);
			
		});
	}
};
// Tooltip Class
var Tooltip = Class.create();
Tooltip.prototype = {
	initialize: function(el, options) {
		
		this.el = $(el);
		this.contentBox = this.el.title; //this.el.down(".tooltipContent").title;
		if(!this.contentBox) return;
		
		if (this.contentBox != "") {
			tooltipsOnPage.push(this);
			this.initialized = false;
			this.setOptions(options);
			// Event handlers
			this.el.stopObserving();
			this.showEvent = this.show.bindAsEventListener(this);
			this.hideEvent = this.hide.bindAsEventListener(this);
			this.updateEvent = this.update.bindAsEventListener(this);
			Event.observe(this.el, "mouseover", this.showEvent );
			Event.observe(this.el, "mouseout", this.hideEvent );
			Event.observe(this.el, "click", this.hideEvent );
			
			// Removing title from DOM element to avoid showing it
			//this.content=$(this.el.title).innerHTML;
			this.content = this.contentBox.stripScripts().strip();
			this.el.title = "";
	
			// If descendant elements has 'alt' attribute defined, clear it
			//this.el.descendants().each(function(el){
				//if(Element.readAttribute(el, 'alt'))
					//el.alt = "";
			//});
		}
	},
	setOptions: function(options) {
		this.options = {
			backgroundColor: '#c8c8c8', // Default background color
			borderColor: '#000000', // Default border color
			textColor: '', // Default text color (use CSS value)
			textShadowColor: '', // Default text shadow color (use CSS value)
			// maxWidth: 250,	// Default tooltip width
			align: "left", // Default align
			delay: 30, // Default delay before tooltip appears in ms
			mouseFollow: false, // Tooltips follows the mouse moving
			opacity: .95, // Default tooltips opacity
			appearDuration: 0, // Default appear duration in sec
			hideDuration: 0 // Default disappear duration in sec
		};
		Object.extend(this.options, options || {});
	},
	show: function(e) {
		this.xCord = Event.pointerX(e);
		this.yCord = Event.pointerY(e);
		if(!this.initialized)
			this.timeout = window.setTimeout(this.appear.bind(this), this.options.delay);
	},
	hide: function(e) {
		
		if(this.initialized) {
			//alert("hide");
			
			this.tooltip.hide();
			Element.remove(this.tooltip);
			//this.appearingFX.cancel();
//			if(this.options.mouseFollow)
//				Event.stopObserving(this.el, "mousemove", this.updateEvent);
			//new Effect.Fade(this.tooltip, {duration: this.options.hideDuration, afterFinish: function() { Element.remove(this.tooltip) }.bind(this) });
		}
		this._clearTimeout(this.timeout);
		
		this.initialized = false;
	},
	update: function(e){
		this.xCord = Event.pointerX(e);
		this.yCord = Event.pointerY(e);
		this.setup();
	},
	appear: function() {
		// Building tooltip container
		this.tooltip = new Element("div", { className: "tooltip", style: "display: none" });
		
		
		
//		var top = new Element("div", { className: "xtop" }).insert(
//			new Element("div", { className: "xb1", style: "background-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb2", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb3", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb4", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		);
//		
//		var bottom = new Element("div", { className: "xbottom" }).insert(
//			new Element("div", { className: "xb4", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb3", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb2", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + ";" })
//		).insert(
//			new Element("div", { className: "xb1", style:"background-color:" + this.options.borderColor + ";" })
//		);
		
		var content = new Element("div", { className: "tooltipBox", style: "background-color:" + this.options.backgroundColor + "; border-color:" + this.options.borderColor + 
			((this.options.textColor != '') ? "; color:" + this.options.textColor : "") + 
			((this.options.textShadowColor != '') ? "; text-shadow:2px 2px 0" + this.options.textShadowColor + ";" : "") }).update(this.content);
			
		// Building and injecting tooltip into DOM
		this.tooltip.insert(content);
		$(document.body).insert({'top':this.tooltip});
		
		// Coloring arrow element
//		this.tooltip.select('.xarrow b').each(function(el){
//			if(!el.hasClassName('a1'))
//				el.setStyle({backgroundColor: this.options.backgroundColor, borderColor: this.options.borderColor });
//			else
//				el.setStyle({backgroundColor: this.options.borderColor });
//		}.bind(this));
		
		Element.extend(this.tooltip); // IE needs element to be manually extended
		this.options.width = this.tooltip.getWidth() + 1; // Quick fix for Firefox 3
		this.tooltip.style.width = this.options.width + 'px'; // IE7 needs width to be defined
		
		this.setup();
		
//		if(this.options.mouseFollow)
//			Event.observe(this.el, "mousemove", this.updateEvent);
//			
		this.initialized = true;
		this.tooltip.show();
		//this.appearingFX = new Effect.Appear(this.tooltip, {duration: this.options.appearDuration, to: this.options.opacity });
	},
	setup: function(){
		// If content width is more then allowed max width, set width to max
		if(this.options.width > this.options.maxWidth) {
			this.options.width = this.options.maxWidth;
			this.tooltip.style.width = this.options.width + 'px';
		}
		//alert(this.el.style.width);
			
		// Tooltip doesn't fit the current document dimensions
		if(this.xCord + this.options.width >= Element.getWidth(document.body)) {
		//	this.options.align = "right";
			//this.xCord = this.xCord - this.options.width + 20;
			//this.tooltip.down('.xarrow').setStyle({left: this.options.width - 24 + 'px'});
		} else {
			this.options.align = "left";
			//this.tooltip.down('.xarrow').setStyle({left: 12 + 'px'});
		}
		
		this.tooltipHeight = this.tooltip.getHeight();
		
		//alert(Element.getHeight(document.body));
		
		this.tooltip.style.left = this.xCord - 7 + "px";
		
		//alert(this.yCord+", "+this.el.viewportOffset().top);
		if ((this.el.viewportOffset().top + this.tooltipHeight + 20) >= Element.getHeight(document.body)) {
			this.tooltip.style.top = this.yCord - this.tooltipHeight -7 + "px";
		}
		else {
			this.tooltip.style.top = this.yCord + 7 + "px";
		}
		
		
		
	},
	_clearTimeout: function(timer) {
		clearTimeout(timer);
		clearInterval(timer);
		return null;
	}
};