File: //home/investoo.co.uk/public_html/js/Interface.js
/*
	Static Class: Interface
	----------------------------------------
	Interface is the primary port of call for most scripts.
*/
var Interface = new(function(){
	this._listeners = new Array();
	this.depth = 1;
	this.interval = null;
	
	this._iePngFixPath = 'js/iePngFix.htc';
	
	this.addListener = function(obj){
		this._listeners[this._listeners.length] = obj;
	}
	
	this.onLoad = function(){
		Interface.init();
	}
	
	this.init = function(){
		// to do this is temporary till moved into its own object
		this.fixPng();
		for(var i=0; i < this._listeners.length; i++){
			if(this._listeners[i].init) this._listeners[i].init();
		}
	}
	
	this.fixPng = function(){
		// we only need this for IE so only worry about addRule
		// Make sure we only work on IE 5.5 or 6
		
		if(/MSIE (5\.5|6\.)/.test(navigator.userAgent)){
			var css = document.styleSheets[document.styleSheets.length-1];
			if(css && css.addRule){
				var b = 'behavior: url("' + this._iePngFixPath + '")';
				css.addRule('div', b);
				css.addRule('img', b);
				css.addRule('span', b);
				css.addRule('td', b);
			}
		}
	}
	
	this.resize = function(){
		// resize the interface cover
		for(var i=0; i < this._listeners.length; i++){
			if(this._listeners[i].onResize) this._listeners[i].onResize();
		}
	}
	
	this.onResize = function(){
		clearTimeout(this.interval);
		this.interval = setTimeout(function(){Interface.resize();}, 500);
	}
		
	this.preload = function(){
		var args = this.preload.arguments;
		
		document.imageArray = new Array(args.length);
		for(var i=0; i<args.length; i++){
			document.imageArray[i] = new Image;
			document.imageArray[i].src = args[i];
		}
	}
	
	this.getObjectsByType = function(htmlType, type){
		var objects = document.getElementsByTagName(htmlType);
		var returnObjects = new Array();
		
		if(objects.length > 0){
			for(var i=0; i < objects.length; i++){
				if(objects[i].getAttribute('evance-uiobject')){
					returnObjects[returnObjects.length] = objects[i];
				} 
			}
		}
		return returnObjects;
	}
	
	this.getNextZIndex = function(){
		++this.depth;
		return this.depth;
	}
	
	this.disableSelect = function(target){
		if(typeof target == 'string'){
			target = document.getElementById(target);
		}
		target.onselectstart = function() {
			return false;
		};
		target.unselectable = "on";
		target.style.MozUserSelect = "none";
	}
	
	this.getElementDimensions = function(Elem){
		if(typeof Elem == 'string'){
			if(document.getElementById) {
				var elem = document.getElementById(Elem);
			} else if (document.all){
				var elem = document.all[Elem];
			}
		} else if (typeof Elem == 'object') {
			var elem = Elem;
		} else {
			return false;
		}
		if ((navigator.userAgent.indexOf("Opera 5")!=-1) 
			||(navigator.userAgent.indexOf("Opera/5")!=-1)) { 
			h = elem.style.pixelHeight;
			w = elem.style.pixelWidth;
		} else {
			w = elem.offsetWidth;
			h = elem.offsetHeight;
		}
		elem = null;
		return {_width:w, _height:h};
	}
	
	this.getElementPosition = function (obj){
		if(typeof obj == 'string') obj = document.getElementById(obj);
		var left = 0;
		var top  = 0;
		var e = obj;
		while (e.offsetParent){
			left += e.offsetLeft;
			top  += e.offsetTop;
			e     = e.offsetParent;
		}
		left += e.offsetLeft;
		top  += e.offsetTop;
		return {_x:left, _y:top};
	}
});
/*
	Mouse Information
	----------------------------------------
*/
var Mouse = new ( function () {
	this._listeners = new Array();
	this._x = 0;
	this._y = 0;
	this.isDragging = false;
	
	this.move = function(event){
		Mouse.onMouseMove(event);
	}
	
	this.onMouseMove = function(event){
		event = Event.fix(event);
		this.getCoords(event);
		for(var i=0; i < this._listeners.length; i++){
			if(this._listeners[i].onMouseMove) this._listeners[i].onMouseMove(event);
		}
	}
	
	this.up = function(event){
		Mouse.onMouseUp(event);
	}
	
	this.onMouseUp = function (event){
		event = Event.fix(event);
		this.getCoords(event);
		for(var i=0; i < this._listeners.length; i++){
			if(this._listeners[i].onMouseUp) this._listeners[i].onMouseUp(event);
		}
	}
	
	this.down = function (event){
		Mouse.onMouseDown(event);
	}
	
	this.onMouseDown = function (event){
		event = Event.fix(event);
		this.getCoords(event);
		for(var i=0; i < this._listeners.length; i++){
			if(this._listeners[i].onMouseDown) this._listeners[i].onMouseDown(event);
		}
	}
	
	this.addListener = function(obj){
		this._listeners[this._listeners.length] = obj;
	}
	
	this.getCoords = function(event){
		if(event.pageX || event.pageY){
			this._x = event.pageX;
			this._y = event.pageY;
		} else {
			this._x = event.clientX + document.body.scrollLeft - document.body.clientLeft,
			this._y = event.clientY + document.body.scrollTop  - document.body.clientTop
		}
	}
	
});
/*
	Event Information
	----------------------------------------
*/
Event = {
	fix : function(event){
		if (!event) event = window.event;
		if (event.target) {
			if (event.target.nodeType == 3) event.target = event.target.parentNode;
		} else if (event.srcElement) {
			event.target = event.srcElement;
		}
	
		return event;
	}
}
/*
	Setup Browser Event Monitoring
*/
document.onmousemove = Mouse.move;
document.onmouseup = Mouse.up;
document.onmousedown = Mouse.down;
window.onresize = Interface.onResize;
window.onload = Interface.onLoad;