//** Featured Content Slider script- (c) Dynamic Drive DHTML code library (http://www.dynamicdrive.com)
//** Last updated: Feb 28th- 07- Added ability to customize pagination links' text
//** Updated 20090429 - Only display nav if slideCount (alldivs) > 1

////Ajax related settings
var csbustcachevar=0 //bust potential caching of external pages after initial Ajax request? (1=yes, 0=no)
var csloadstatustext="<img src='http://common.onset.freedom.com/images/loading.gif' /> Requesting content..." //HTML to indicate Ajax page is being fetched
var csexternalfiles=[] //External .css or .js files to load to style the external content(s), if any. Separate multiple files with comma ie: ["cat.css", dog.js"]

////NO NEED TO EDIT BELOW////////////////////////
var enablepersist=false
var slidernodes=new Object() //Object array to store references to each content slider's DIV containers (<div class="contentdiv">)
var csloadedobjects="" //Variable to store file names of .js/.css files already loaded (if Ajax is used)

function ContentSlider(sliderid, autorun, customPaginateText, customNextText, cycles){
	var prevText
	var slider=document.getElementById(sliderid)
	if (typeof customPaginateText!="undefined" && customPaginateText!="") //Custom array of pagination links text defined?
		slider.paginateText=customPaginateText
	if (typeof customNextText!="undefined" && customNextText!="") //Custom HTML for "Next" link defined?
		slider.nextText=customNextText
	slidernodes[sliderid]=[] //Array to store references to this content slider's DIV containers (<div class="contentdiv">)
	ContentSlider.loadobjects(csexternalfiles) //Load external .js and .css files, if any
	var alldivs=slider.getElementsByTagName("div")
	for (var i=0; i<alldivs.length; i++){
		if (alldivs[i].className=="contentdiv"){
			slidernodes[sliderid].push(alldivs[i]) //add this DIV reference to array
			if (typeof alldivs[i].getAttribute("rel")=="string") //If get this DIV's content via Ajax (rel attr contains path to external page)
				ContentSlider.ajaxpage(alldivs[i].getAttribute("rel"), alldivs[i])
		}
	}
	ContentSlider.buildpagination(sliderid)
	var loadfirstcontent=true
	if (enablepersist && getCookie(sliderid)!=""){ //if enablepersist is true and cookie contains corresponding value for slider
		var cookieval=getCookie(sliderid).split(":") //process cookie value ([sliderid, int_pagenumber (div content to jump to)]
		if (document.getElementById(cookieval[0])!=null && typeof slidernodes[sliderid][cookieval[1]]!="undefined"){ //check cookie value for validity
			ContentSlider.turnpage(cookieval[0], parseInt(cookieval[1])) //restore content slider's last shown DIV
			loadfirstcontent=false
		}
	}
	if (loadfirstcontent==true) //if enablepersist is false, or cookie value doesn't contain valid value for some reason (ie: user modified the structure of the HTML)
		ContentSlider.turnpage(sliderid, 0) //Display first DIV within slider
	if (typeof autorun=="number" && autorun>0 && alldivs.length>1) //if autorun parameter (int_miliseconds) is defined, fire auto run sequence
		window[sliderid+"timer"]=setTimeout(function(){ContentSlider.autoturnpage(sliderid, autorun, cycles || 0)}, autorun)
	if (alldivs.length<2) {
		document.getElementById('paginate-slider1').innerHTML='&#160;';
	}
}

ContentSlider.buildpagination=function(sliderid){

	var slider=document.getElementById(sliderid)
	var paginatediv=document.getElementById("paginate-"+sliderid) //reference corresponding pagination DIV for slider
	var pcontent=""
	
	if(typeof (imgInfo)!="undefined")
		{
		pcontent+='<a href="#" style="font-weight: bold;" onclick=\"ContentSlider.turnpage(\''+sliderid+'\', parseInt(this.getAttribute(\'rel\'))); return false\">'+(slider.prevText || "<img src=\"http://common.onset.freedom.com/images/arrow_prev.gif\">")+'</a>'
		pcontent+= '<span id="cur_page" style="margin:0px 8px;">' + 1 + ' of '+ imgInfo.length +' </span>'
		//for (var i=0; i<slidernodes[sliderid].length; i++) //For each DIV within slider, generate a pagination link
		//	pcontent+='<a href="#" onclick=\"ContentSlider.turnpage(\''+sliderid+'\', '+i+'); return false\">'+(slider.paginateText? slider.paginateText[i] : i+1)+'</a> '
		pcontent+='<a href="#" style="font-weight: bold;" onclick=\"ContentSlider.turnpage(\''+sliderid+'\', parseInt(this.getAttribute(\'rel\'))); return false\">'+(slider.nextText || "<img src=\"http://common.onset.freedom.com/images/arrow_next.gif\">")+'</a>'
	} else {
		for (var i=0; i<slidernodes[sliderid].length; i++) //For each DIV within slider, generate a pagination link
			pcontent+='<a href="#" onclick=\"ContentSlider.turnpage(\''+sliderid+'\', '+i+'); return false\">'+(slider.paginateText? slider.paginateText[i] : i+1)+'</a> '
		pcontent+='<a href="#" style="font-weight: bold;" onclick=\"ContentSlider.turnpage(\''+sliderid+'\', parseInt(this.getAttribute(\'rel\'))); return false\">'+(slider.nextText || "Next")+'</a>'
		}

	paginatediv.innerHTML=pcontent
	paginatediv.onclick=function(){ //cancel auto run sequence (if defined) when user clicks on pagination DIV
	if (typeof window[sliderid+"timer"]!="undefined")
		clearTimeout(window[sliderid+"timer"])
		}
}

ContentSlider.turnpage=function(sliderid, thepage){
	
	var paginatelinks=document.getElementById("paginate-"+sliderid).getElementsByTagName("a") //gather pagination links
	var nFrames;
	if(typeof (imgInfo)!="undefined")
		{
		for (var i=0; i<imgInfo.length; i++){ //For each DIV within slider
			//paginatelinks[i].className="" //empty corresponding pagination link's class name
			slidernodes[sliderid][i].style.display="none" //hide DIV
			}
		nFrames=imgInfo.length;
		document.getElementById("cur_page").innerHTML = '' + (thepage + 1) + ' of '+ nFrames +''
	} else {
		for (var i=0; i<slidernodes[sliderid].length; i++){ //For each DIV within slider
			paginatelinks[i].className="" //empty corresponding pagination link's class name
			slidernodes[sliderid][i].style.display="none" //hide DIV
			}
		nFrames=slidernodes[sliderid].length;
		}
	//paginatelinks[thepage].className="selected" //for selected DIV, set corresponding pagination link's class name
	try{
	slidernodes[sliderid][thepage].style.display="block" //show selected DIV

	}catch(err){}
	// Set "Prev" link
	paginatelinks[0].setAttribute("rel", theprevpage=(thepage>0)? thepage-1 : (nFrames-1))
	//Set "Next" pagination link's (last link within pagination DIV) "rel" attribute to the next DIV number to show
	paginatelinks[paginatelinks.length-1].setAttribute("rel", thenextpage=(thepage<(nFrames-1))? thepage+1 : 0)
	if (enablepersist)
		setCookie(sliderid, sliderid+":"+thepage)
	
}

ContentSlider.autoturnpage=function(sliderid, autorunperiod, cycles){
	var paginatelinks=document.getElementById("paginate-"+sliderid).getElementsByTagName("a") //Get pagination links
	var nextpagenumber=parseInt(paginatelinks[paginatelinks.length-1].getAttribute("rel")) //Get page number of next DIV to show
	ContentSlider.turnpage(sliderid, nextpagenumber) //Show that DIV
	if (cycles>0){
	var slider=document.getElementById(sliderid)
	if (nextpagenumber==0)
	slider.cyclecount=(typeof slider.cyclecount!="undefined")? slider.cyclecount+1 : 1
	if (slider.cyclecount && slider.cyclecount==cycles)
	return
	}
	window[sliderid+"timer"]=setTimeout(function(){ContentSlider.autoturnpage(sliderid, autorunperiod, cycles)}, autorunperiod)
}

function getCookie(Name){ 
	var re=new RegExp(Name+"=[^;]+", "i"); //construct RE to search for target name/value pair
	if (document.cookie.match(re)) //if cookie found
		return document.cookie.match(re)[0].split("=")[1] //return its value
	return ""
}

function setCookie(name, value){
	document.cookie = name+"="+value
}

////////////////Ajax Related functions //////////////////////////////////

ContentSlider.ajaxpage=function(url, thediv){
	var page_request = false
	var bustcacheparameter=""
	if (window.XMLHttpRequest) // if Mozilla, Safari etc
		page_request = new XMLHttpRequest()
	else if (window.ActiveXObject){ // if IE
		try {
		page_request = new ActiveXObject("Msxml2.XMLHTTP")
		} 
		catch (e){
		try{
		page_request = new ActiveXObject("Microsoft.XMLHTTP")
		}
		catch (e){}
		}
	}
	else
		return false
	thediv.innerHTML=csloadstatustext
	page_request.onreadystatechange=function(){
		ContentSlider.loadpage(page_request, thediv)
	}
	if (csbustcachevar) //if bust caching of external page
		bustcacheparameter=(url.indexOf("?")!=-1)? "&"+new Date().getTime() : "?"+new Date().getTime()
	page_request.open('GET', url+bustcacheparameter, true)
	page_request.send(null)
}

ContentSlider.loadpage=function(page_request, thediv){
	if (page_request.readyState == 4 && (page_request.status==200 || window.location.href.indexOf("http")==-1))
		thediv.innerHTML=page_request.responseText
}

ContentSlider.loadobjects=function(externalfiles){ //function to load external .js and .css files. Parameter accepts a list of external files to load (array)
	for (var i=0; i<externalfiles.length; i++){
		var file=externalfiles[i]
		var fileref=""
		if (csloadedobjects.indexOf(file)==-1){ //Check to see if this object has not already been added to page before proceeding
			if (file.indexOf(".js")!=-1){ //If object is a js file
				fileref=document.createElement('script')
				fileref.setAttribute("type","text/javascript");
				fileref.setAttribute("src", file);
			}
			else if (file.indexOf(".css")!=-1){ //If object is a css file
				fileref=document.createElement("link")
				fileref.setAttribute("rel", "stylesheet");
				fileref.setAttribute("type", "text/css");
				fileref.setAttribute("href", file);
			}
		}
		if (fileref!=""){
			document.getElementsByTagName("head").item(0).appendChild(fileref)
			csloadedobjects+=file+" " //Remember this object as being already added to page
		}
	}
}


// Freedom-specific modifications
var imgCount,htmlOut,imgsSlider,imgMaxWidth,imgMaxHeight,imgMaxTotalHeight;
imgCount=0;
function imageSlide(file,cutline,credit,picturealt,width,height,storyid,storydb, picturetitle)
{
  this.file=file;
  this.cutline=cutline;
  this.credit=credit;
  this.picturealt=picturealt;
  this.picturetitle=picturetitle;
  this.width=width;
  this.height=height;
	if (storyid != "")
		this.storyid=storyid;
	if (storydb != "")
		this.storydb=storydb;
}

function writeImageSlider () {
	htmlOut = ''
	htmlOut += '<div id="slider1" class="contentslide1" style="width:230px;">\n';
	for (i=0;i<imgCount;i++) {
		var myWidth = (imageSlide[i].width < 230)?'width="'+imageSlide[i].width+'"':'width=230';
		htmlOut += '<div class="contentdiv">\n';
		htmlOut += '<div class="image_mask" >'	
		htmlOut += '<div class="image_box"><div>'
		
		//if (imageSlide[i].width < 230)
			htmlOut += '<div align="center">';
			
		if (parseInt(imageSlide[i].storyid) > 0) {
			htmlOut += '  <a href="/sections/article/gallery/?pic='+(i+1)+'&amp;id='+imageSlide[i].storyid+'&amp;db='+imageSlide[i].storydb+'">';
		} else {
			htmlOut += '  <a href="'+imageSlide[i].file+'" target="_blank">';			
		}
		htmlOut += '<img src="'+imageSlide[i].file+'" '+myWidth+' style="max-width:230px;" alt="'+imageSlide[i].picturealt+'" title="'+imageSlide[i].picturetitle+'" border="0" />';
		htmlOut += '</a>';
		//if (imageSlide[i].width < 230)
			htmlOut += '</div>';
	
		htmlOut += '</div></div>' // end image_box and div
		
		htmlOut += '<div class="image_info_box"><div class="enlarge opaque">'
		htmlOut += '<a href="/sections/article/gallery/?pic='+(i+1)+'&amp;id='+imageSlide[i].storyid+'&amp;db='+imageSlide[i].storydb+'">enlarge</a>';
		htmlOut += '</div></div>' // end image_info_box, enlarge
		htmlOut += '</div>' // end image_mask
		
		if ('"'+imageSlide[i].credit+'"' != "") {
			htmlOut += '  <div class="credit">\n';
			htmlOut +=   ' '+imageSlide[i].credit+'&#160;\n';
			htmlOut += '  </div>\n';
		}			 
		if (imageSlide[i].cutline!='') {
			htmlOut += '  <div class="contentdivtxt" style="width:230px;overflow:auto;">\n';
			htmlOut +=     imageSlide[i].cutline+'&#160;';
			htmlOut += '  </div>\n';
		}
		/*
		if (parseInt(imageSlide[i].storyid) > 0) {
			htmlOut += '<br /><a href="/sections/article/gallery/?pic='+(i+1)+'&amp;id='+imageSlide[i].storyid+'&amp;db='+imageSlide[i].storydb+'" style="color:#036;font-size:9pt;font-weight:normal;">Click to Enlarge</a>\n';
		}
		*/
		htmlOut += '</div>\n';
	}
	htmlOut += '<div class="thumbnailpagination" id="paginate-slider1"></div>';
	htmlOut += '</div>';
	
	return htmlOut;
}

var imgCount,htmlOut,imgsSlider,imgMaxWidth,imgMaxHeight;
imgCount=0;

if( typeof(imgInfo) != 'undefined' )
{
	for(x = 0; x < imgInfo.length; x++)
	{
		if (imgInfo[x][0] != "" && imgInfo[x][0] != "medium/" && imgInfo[x][0] != "http://images.onset.freedom.com/"+imgInfo[x][7]+"/") 
		{
			if (imgInfo[x][6] != "")
				imgStoryId = imgInfo[x][6];
			if (imgInfo[x][7] != "")
				imgStoryDb = imgInfo[x][7];
			
			imageSlide[x] = new imageSlide(imagePrefix + imgInfo[x][0],imgInfo[x][1],imgInfo[x][2],imgInfo[x][3],imgInfo[x][4],imgInfo[x][5],imgStoryId,imgStoryDb, imgInfo[x][8]);
			imgMaxWidth = imgInfo[x][4];
			imgMaxHeight = imgInfo[x][5];
			
			imgCount++;
			imgMaxTotalHeight = parseInt(imgMaxHeight)
			imgMaxTotalHeight += 100 ;
		}
	}
	
	/*
	//if (imgInfo[0][0] != "") 
	if (imgInfo[0][0] != "" && imgInfo[0][0] != "medium/" && imgInfo[0][0] != "http://images.onset.freedom.com/"+imgInfo[0][7]+"/") 
	{
	  if (imgInfo[0][6] != "")
	  	imgStoryId = imgInfo[0][6];
	  if (imgInfo[0][7] != "")
	  	imgStoryDb = imgInfo[0][7];

	  imageSlide[0] = new imageSlide(imagePrefix + imgInfo[0][0],imgInfo[0][1],imgInfo[0][2],imgInfo[0][3],imgInfo[0][4],imgInfo[0][5],imgStoryId,imgStoryDb);
	  imgMaxWidth = imgInfo[0][4];
	  imgMaxHeight = imgInfo[0][5];
	  
	  imgCount++;
		imgMaxTotalHeight = parseInt(imgMaxHeight)
		//if (imageSlide[0].cutline != '') {
			imgMaxTotalHeight += 100 ;
		//}
	}
	//if (imgInfo[1][0] != "")
	if (imgInfo[1][0] != "" && imgInfo[1][0] != "medium/" && imgInfo[1][0] != "http://images.onset.freedom.com/"+imgInfo[0][7]+"/")
	{
	  imageSlide[1] = new imageSlide(imagePrefix + imgInfo[1][0],imgInfo[1][1],imgInfo[1][2],imgInfo[1][3],imgInfo[1][4],imgInfo[1][5],imgStoryId,imgStoryDb);
	  if (imgMaxWidth < parseInt(imgInfo[1][4]))
	    imgMaxWidth=parseInt(imgInfo[1][4]);
	  if (imgMaxHeight < parseInt(imgInfo[1][5]))
	    imgMaxHeight=parseInt(imgInfo[1][5]);

			imgMaxTotalHeight = parseInt(imgMaxHeight)
			//if (imageSlide[1].cutline != '') {
				imgMaxTotalHeight += 100 ;
			//}
	  imgCount++;
	}
	//if (imgInfo[2][0] != "")
	if (imgInfo[2][0] != "" && imgInfo[2][0] != "medium/" && imgInfo[2][0] != "http://images.onset.freedom.com/"+imgInfo[0][7]+"/")
	{
	  imageSlide[2] = new imageSlide(imagePrefix + imgInfo[2][0],imgInfo[2][1],imgInfo[2][2],imgInfo[2][3],imgInfo[2][4],imgInfo[2][5],imgStoryId,imgStoryDb);
	  if (imgMaxWidth < parseInt(imgInfo[2][4]))
	    imgMaxWidth=parseInt(imgInfo[2][4]);
	  if (imgMaxHeight < parseInt(imgInfo[2][5]))
	    imgMaxHeight=parseInt(imgInfo[2][5]);
			imgMaxTotalHeight = parseInt(imgMaxHeight)
			//if (imageSlide[2].cutline != '') {
				imgMaxTotalHeight += 100 ;
			//}
	  imgCount++;
	}
	*/
}

if (imgCount > 1) {
  document.getElementById(articleDivID).innerHTML = writeImageSlider();
  ContentSlider("slider1", 0, "", "", 1);

}
