/*
DezinerFolio.com Simple Accordians.

Author  : G.S.Navin Raj Kumar
Website : http://dezinerfolio.com

Extended by S&L Medienproduktion GmbH (03/19/2008)
Added   : - image exchange on click event:
            you can add two images called "x-thumb" and "x-poster",
            where "x" is the div identifier (equal to "x-header" and "x-content").
            "x-thumb" will be display when div is closed, else "x-poster"
          - default opened div:
            parameter "e" in Accordian()-call names the div that will be opened on load,
            can be omitted
          - multiple parent divs:
            variable "d" can have more than one div in a comma-separated list
          - an open div will be closed now when clicked
Website : http://slmedien.de
Tributes: G.S.Navin Raj Kumar for a great script
*/

/*
* The Variable names have been compressed to achive a higher level of compression.
*/

// Prototype Method to get the element based on ID
function $(d){
	return document.getElementById(d);
}

// set or get the current display style of the div
function dsp(d,v){
	if(v==undefined){
		return d.style.display;
	}else{
		d.style.display=v;
	}
}

// set or get the height of a div.
function sh(d,v){
	// if you are getting the height then display must be block to return the absolute height
	if(v==undefined){
		if(dsp(d)!='none'&& dsp(d)!=''){
			return d.offsetHeight;
		}
		viz = d.style.visibility;
		d.style.visibility = 'hidden';
		o = dsp(d);
		dsp(d,'block');
		r = parseInt(d.offsetHeight);
		dsp(d,o);
		d.style.visibility = viz;
		return r;
	}else{
		d.style.height=v;
	}
}
/*
* Variable 'S' defines the speed of the accordian
* Variable 'T' defines the refresh rate of the accordian
*/
s=7;
t=10;

// Collapse Timer is triggered as a setInterval to reduce the height of the div exponentially.
function ct(d){
	d = $(d);
	if(sh(d)>0){
		v = Math.round(sh(d)/d.s);
		v = (v<1) ? 1 :v ;
		v = (sh(d)-v);
		sh(d,v+'px');
		d.style.opacity = (v/d.maxh);
		d.style.filter= 'alpha(opacity='+(v*100/d.maxh)+');';
	}else{
		sh(d,0);
		dsp(d,'none');
		clearInterval(d.t);
	}
}

// Expand Timer is triggered as a setInterval to increase the height of the div exponentially.
function et(d){
	d = $(d);
	if(sh(d)<d.maxh){
		v = Math.round((d.maxh-sh(d))/d.s);
		v = (v<1) ? 1 :v ;
		v = (sh(d)+v);
		sh(d,v+'px');
		d.style.opacity = (v/d.maxh);
		d.style.filter= 'alpha(opacity='+(v*100/d.maxh)+');';
	}else{
		sh(d,d.maxh);
		clearInterval(d.t);
	}
}

// Collapse Initializer
function cl(d){
	if(dsp(d)=='block'){
		clearInterval(d.t);
		d.t=setInterval('ct("'+d.id+'")',t);
	}
}

// Expand Initializer
function ex(d){
	if(dsp(d)=='none'){
		dsp(d,'block');
		d.style.height='0px';
		clearInterval(d.t);
		d.t=setInterval('et("'+d.id+'")',t);
	}
}

// Removes Classname from the given div.
function cc(n,v){
	s=n.className.split(/\s+/);
	for(p=0;p<s.length;p++){
		if(s[p]==v+n.tc){
			s.splice(p,1);
			n.className=s.join(' ');
			break;
		}
	}
}
// Accordian Initializer
function Accordian(d,s,tc,e){
  da = d.split(',');
  l=[];
  for (i=0; i<da.length; i++) {
  	// get all the elements that have id as content
  	la=$(da[i]).getElementsByTagName('div');
    for (j=0; j<la.length; j++) {
      l.push(la[j]);
    }
  }
	c=[]; // content-divs id list
	for(i=0;i<l.length;i++){
		h=l[i].id;
		if(h.substr(h.indexOf('-')+1,h.length)=='content'){c.push(h);}
	}
	sel=null;
	//then search through headers
	for(i=0;i<l.length;i++){
		h=l[i].id;
		if(h.substr(h.indexOf('-')+1,h.length)=='header'){
			d=$(h.substr(0,h.indexOf('-'))+'-content');
			d.style.display='none';
			d.style.overflow='hidden';
			d.maxh =sh(d);
			d.s=(s==undefined)? 7 : s;
			h=$(h);
			h.tc=tc;
			h.c=c;
			// set the onclick function for each header.
			h.onclick = function(){
				for(i=0;i<this.c.length;i++){
					cn=this.c[i];
					n=cn.substr(0,cn.indexOf('-'));
					if((n+'-header')==this.id){
            cn = $(n+'-header').className;
            if (cn!=undefined && cn.indexOf(tc) != -1) {
              Collapse(n);
            } else {
  						Expand(n);
            }
					}else{
           Collapse(n);
					}
				}
			}
			if(h.className.match(/selected+/)!=undefined){ sel=h;}
		}
	}
	if(sel!=undefined){sel.onclick();}

// Initializes the first expanded div:
  if (e!=undefined) Expand(e);
}

function Expand(n) {
  ex($(n+'-content'));
  n2=$(n+'-header');
  cc(n2,'__');
  n2.className=n2.className+' '+n2.tc;
  setTimeout("SwitchToPoster('"+n+"')", 800);
}

function Collapse(n) {
  if ($(n+'-thumb')!=undefined) $(n+'-thumb').style.display='block';
  if ($(n+'-poster')!=undefined) $(n+'-poster').style.display='none';
  cl($(n+'-content'));
  cc($(n+'-header'),'');
}

function SwitchToPoster(n) {
  if ($(n+'-thumb')!=undefined) $(n+'-thumb').style.display='none';
  if ($(n+'-poster')!=undefined) $(n+'-poster').style.display='block';  
}