/*  Prototype JavaScript framework
 *  (c) 2005 Sam Stephenson <sam@conio.net>
 *  Prototype is freely distributable under the terms of an MIT-style license.
 *  For details, see the Prototype web site: http://prototype.conio.net/
/*--------------------------------------------------------------------------*/

//note: modified & stripped down version of prototype, to be used with moo.fx by mad4milk (http://moofx.mad4milk.net).

var Class = {
	create: function() {
		return function() {
			this.initialize.apply(this, arguments);
		}
	}
}

Object.extend = function(destination, source) {
	for (property in source) destination[property] = source[property];
	return destination;
}

Function.prototype.bind = function(object) {
	var __method = this;
	return function() {
		return __method.apply(object, arguments);
	}
}

Function.prototype.bindAsEventListener = function(object) {
var __method = this;
	return function(event) {
		__method.call(object, event || window.event);
	}
}

function $$$() {
	if (arguments.length == 1) return get$$$(arguments[0]);
	var elements = [];
	$c(arguments).each(function(el){
		elements.push(get$$$(el));
	});
	return elements;

	function get$$$(el){
		if (typeof el == 'string') el = document.getElementById(el);
		return el;
	}
}

if (!window.Element) var Element = new Object();

Object.extend(Element, {
	remove: function(element) {
		element = $$$(element);
		element.parentNode.removeChild(element);
	},

	hasClassName: function(element, className) {
		element = $$$(element);
		if (!element) return;
		var hasClass = false;
		element.className.split(' ').each(function(cn){
			if (cn == className) hasClass = true;
		});
		return hasClass;
	},

	addClassName: function(element, className) {
		element = $$$(element);
		Element.removeClassName(element, className);
		element.className += ' ' + className;
	},
  
	removeClassName: function(element, className) {
		element = $$$(element);
		if (!element) return;
		var newClassName = '';
		element.className.split(' ').each(function(cn, i){
			if (cn != className){
				if (i > 0) newClassName += ' ';
				newClassName += cn;
			}
		});
		element.className = newClassName;
	},

	cleanWhitespace: function(element) {
		element = $$$(element);
		$c(element.childNodes).each(function(node){
			if (node.nodeType == 3 && !/\S/.test(node.nodeValue)) Element.remove(node);
		});
	},

	find: function(element, what) {
		element = $$$(element)[what];
		while (element.nodeType != 1) element = element[what];
		return element;
	}
});

var Position = {
	cumulativeOffset: function(element) {
		var valueT = 0, valueL = 0;
		do {
			valueT += element.offsetTop  || 0;
			valueL += element.offsetLeft || 0;
			element = element.offsetParent;
		} while (element);
		return [valueL, valueT];
	}
};

document.getElementsByClassName = function(className) {
	var children = document.getElementsByTagName('*') || document.all;
	var elements = [];
	$c(children).each(function(child){
		if (Element.hasClassName(child, className)) elements.push(child);
	});  
	return elements;
}

//useful array functions
Array.prototype.iterate = function(func){
	for(var i=0;i<this.length;i++) func(this[i], i);
}
if (!Array.prototype.each) Array.prototype.each = Array.prototype.iterate;

function $c(array){
	var nArray = [];
	for (var i=0;i<array.length;i++) nArray.push(array[i]);
	return nArray;
}


/*
moo.fx, simple effects library built with prototype.js (http://prototype.conio.net).
by Valerio Proietti (http://mad4milk.net) MIT-style LICENSE.
for more info (http://moofx.mad4milk.net).
Sunday, March 05, 2006
v 1.2.3
*/

var fx = new Object();
//base
fx.Base = function(){};
fx.Base.prototype = {
	setOptions: function(options) {
	this.options = {
		duration: 500,
		onComplete: '',
		transition: fx.sinoidal
	}
	Object.extend(this.options, options || {});
	},

	step: function() {
		var time  = (new Date).getTime();
		if (time >= this.options.duration+this.startTime) {
			this.now = this.to;
			clearInterval (this.timer);
			this.timer = null;
			if (this.options.onComplete) setTimeout(this.options.onComplete.bind(this), 10);
		}
		else {
			var Tpos = (time - this.startTime) / (this.options.duration);
			this.now = this.options.transition(Tpos) * (this.to-this.from) + this.from;
		}
		this.increase();
	},

	custom: function(from, to) {
		if (this.timer != null) return;
		this.from = from;
		this.to = to;
		this.startTime = (new Date).getTime();
		this.timer = setInterval (this.step.bind(this), 13);
	},

	hide: function() {
		this.now = 0;
		this.increase();
	},

	clearTimer: function() {
		clearInterval(this.timer);
		this.timer = null;
	}
}

//transitions
fx.sinoidal = function(pos){
	return ((-Math.cos(pos*Math.PI)/2) + 0.5);
	//this transition is from script.aculo.us
}



//ACRO MEDIA ADDITION of left:XXpx; sliding effect. Built around video object declared below.

fx.Slide = Class.create();
fx.Slide.prototype = Object.extend(new fx.Base(), {
	initialize: function(el, options) {
		this.el = $$$(el);
		this.setOptions(options);
		this.now = 0;
	},
	increase: function() {		
		this.el.style.marginLeft = this.now + "px";	
		
	},
	slide: function(howMuch){
		this.clearTimer();
		this.custom(this.now, howMuch * this.options.distance * -1);
	}
});

var video = {
	vids : null, currentNum : 0, slider : null,
	init : function(){
		this.vids = $$$('popSlide').getElementsByTagName('div').length;
		//this.vids = $$$('popSlide').getElementsById('displayunit').length;
		this.vids = eval(this.vids / 6);
		
 		this.slider = new fx.Slide($$$('popSlide'), {distance: 531, duration: 600});	 
	},toggle : function(direction){	   
		if(!this.slider) this.init();
    var new_num = this.currentNum + direction;

    if (this.vids <= 3){
        document.getElementById('video_left').style.display = 'none';
        document.getElementById('video_right').style.display = 'none';
    } else {
    		if(new_num <= 0) {    
            new_num = 0;
            //document.getElementById('video_left').style.display = 'none';
            document.getElementById('video_left').innerHTML = '&nbsp;';
        } else {
            //document.getElementById('video_left').style.display = '';  
            document.getElementById('video_left').innerHTML = '<li><a href="#" onclick="video.toggle(-1); return false;" class="pg_prev" title="previous page"></a></li><li class="txtlink"><a href="#" onclick="video.toggle(-1); return false;">Previous</a></li>';                  
        }

        if(eval(eval(eval(new_num + 1) * 3) - this.vids) >= 0.8) {            
            document.getElementById('video_right').style.display = 'none';          
        }  else {            
            document.getElementById('video_right').style.display = '';                  
        }  
    }
    this.currentNum = new_num;
		this.slider.slide(this.currentNum);
	}
}
fx.sinoidal = function(pos){return ((-Math.cos(pos*Math.PI)/2) + 0.5);}

