/*
 * Open a pop-up window, to the specifications
 *
 * Note:
 *   - marginHidth and marginHeight are required for Opera to display properly.
*/




function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}

function MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}















function popupImage(imageName,imageWidth,imageHeight,alt)
{
	document.location = 'image_view.php?src=' + imageName + '&alt=' + alt;
/*
 // build the window and set focus
 newWindow = window.open("","newWindow","width="+imageWidth+",height="+(imageHeight+100)+",innerWidth="+imageWidth+",innerHeight="+imageHeight);
 newWindow.document.open();
  newWindow.document.write('<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">');
 newWindow.document.write('<html><title>'+alt+'<\/title>');
 newWindow.document.write('<style type="text/css">body {margin: 0px;} img {display: block;} p {margin: 0px; padding: 0px; text-align: center; font-size: smaller; font-family: arial, sans-serif;} <\/style>');
 newWindow.document.write('<body marginwidth="0" marginheight="0" onBlur="self.close()">'); 
 newWindow.document.write('<p><img src="'+imageName+'" width="'+imageWidth+'" height="'+imageHeight+'" alt="'+alt+'"><\/p>'); 
 newWindow.document.write('<p><a href="#" onClick="self.close();">[close window]<\/a><\/p>');
 newWindow.document.write('<\/body><\/html>');
 newWindow.document.close();
 newWindow.focus();
 */
 // do this so that the calling event does nothing BUT this function
 return false;

}

// implement ltrim, rtrim and trim
String.prototype.trim  = function () { return this.ltrim().rtrim() }
String.prototype.ltrim = function () { return this.replace(/^\s+/g, "") }
String.prototype.rtrim = function () { return this.replace(/\s+$/g, "") }


//
function validateSearchForm() {
  if (document.forms['searchForm'].T1.value.trim() == '') {
    alert('You must enter a word to search on!');
    return false;
  } else {
    return true;
  }
}

// pop up a window centered on the page
function doPopup(page, width, height) {
	var url = 'http://www.tshirtmagic.com/' + page;
	var winleft = (screen.width - width) / 2;
	var winUp = (screen.height - height) / 2;
	var winProp = 'location=no,scrollbars=yes,width='+width+',height='+height+',left='+winleft+',top='+winUp+',resizable'		
	window.open(url, "preview", winProp);
}	

// Home Page
function addbookmark()
{
bookmarkurl="http://www.tshirtmagic.com/"
bookmarktitle="T-Shirt Magic Custom T-Shirts"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}

// Stock Step 3 Design Page
function addbookmark2()
{
bookmarkurl="http://www.tshirtmagic.com/^design@BookmarkURL^"
bookmarktitle="http://www.tshirtmagic.com/^design@BookmarkTitle^"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}

// help page
function addbookmarkhelp()
{
bookmarkurl="http://www.tshirtmagic.com/help.htm"
bookmarktitle="T-Shirt Magic Help Desk"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}

// sitemap
function addbookmarksitemap()
{
bookmarkurl="http://www.tshirtmagic.com/sitemap.htm"
bookmarktitle="T-Shirt Magic Site Map"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}


// logout
function addbookmarkpoker()
{
bookmarkurl="http://www.tshirtmagic.com/stockc.php?action=step2&c1=282"
bookmarktitle="T-Shirt Magic Poker T-Shirts"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}

function bookmarksite()
{
bookmarkurl="http://www.tshirtmagic.com/"
bookmarktitle="T-Shirt Magic Custom T-Shirts"
if (document.all)
window.external.AddFavorite(bookmarkurl,bookmarktitle)
}










// add rotating stock random images

function stock()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock1[adNo])

  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock2[adNo])
  
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock3[adNo])
  
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock4[adNo])
  
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock5[adNo])
  
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(stock6[adNo])
}



  



// add statis message when clicked

function wordage (txt) { 
window.status=txt; 
setTimeout("clear()",5000) 
} 
function clear () { 
window.status= ""; 
} 



//<![CDATA[





function Setup()
    {
    om = new OverlayMessage( document.getElementById( 'container' ) );
    On();
    }


function On()
    {
    om.Set( '<marquee scrolldelay=50 width=90%>Please wait... your image is uploading.</marquee>' );
    setTimeout( "Off()", 1000 );
    }


/* function Off()
    {
    om.Clear();
    setTimeout( "On()", 1000 );
    }


//]]>
*/



OverlayMessage = function ( container )
    {
    // Terminology:
    // +-----------------+
    // |wrapper          |
    // |+---------------+|
    // ||container      ||
    // ||   +-------+   ||
    // ||   |overlay|   ||
    // ||   +-------+   ||
    // ||               ||
    // |+---------------+|
    // +-----------------+

    // Get the parent.
    var parent = container.parentNode;

    // Make the wrapper div.
    var wrapper = document.createElement( 'div' );
    wrapper.style.cssText = container.style.cssText;
    parent.insertBefore( wrapper, container );

    // Move the container into the wrapper.
    parent.removeChild( container );
    wrapper.appendChild( container );
    container.style.cssText = 'position: relative; width: 100%; height: 100%;';

    // Add the overlay div.
    this.overlay = document.createElement( 'div' );
    wrapper.appendChild( this.overlay );
    this.visibleStyle = 'position: relative; top: -50%; background-color: ' + OverlayMessage.backgroundColor + '; width: 55%;  text-style: "Trebuchet MS"; text-align: center; margin-left: auto; margin-right: auto; padding: 0em; border: 0.01in ridge ' + OverlayMessage.borderColor + '; z-index: 100; opacity: .25; filter: alpha(opacity=100);';
    this.invisibleStyle = 'display: none;';
    this.overlay.style.cssText = this.invisibleStyle;
    };



OverlayMessage.font = 'Trebuchet MS';
OverlayMessage.borderColor = '#0001EC';


OverlayMessage.backgroundColor = '#99CCFF';
OverlayMessage.borderColor = '#0001EC';


OverlayMessage.prototype.Set = function ( message )
    {
    this.overlay.innerHTML = message;
    this.overlay.style.cssText = this.visibleStyle;
    };


OverlayMessage.prototype.Clear = function ()
    {
    this.overlay.style.cssText = this.invisibleStyle;
    };


OverlayMessage.SetBackgroundColor = function ( color )
    {
    OverlayMessage.backgroundColor = color;
    };


OverlayMessage.SetBorderColor = function ( color )
    {
    OverlayMessage.borderColor = color;
    };
	
	
	
	// XXXXXXXXXXXXXXXXXXXXXXXXXXX
	
	
	
	function Setup2()
    {
    om = new OverlayMessage( document.getElementById( 'container' ) );
    On();
    }


function On()
    {
    om.Set( '<marquee scrolldelay=50 width=90%>Please wait while your image is uploading...</marquee>' );
    setTimeout( "Off()", 1000 );
    }


/* function Off()
    {
    om.Clear();
    setTimeout( "On()", 1000 );
    }


//]]>
*/



OverlayMessage = function ( container2 )
    {
    // Terminology:
    // +-----------------+
    // |wrapper          |
    // |+---------------+|
    // ||container      ||
    // ||   +-------+   ||
    // ||   |overlay|   ||
    // ||   +-------+   ||
    // ||               ||
    // |+---------------+|
    // +-----------------+

    // Get the parent.
    var parent = container2.parentNode;

    // Make the wrapper div.
    var wrapper = document.createElement( 'div' );
    wrapper.style.cssText = container2.style.cssText;
    parent.insertBefore( wrapper, container2 );

    // Move the container into the wrapper.
    parent.removeChild( container2 );
    wrapper.appendChild( container2 );
    container2.style.cssText = 'position: relative; width: 100%; height: 100%;';

    // Add the overlay div.
    this.overlay = document.createElement( 'div' );
    wrapper.appendChild( this.overlay );
    this.visibleStyle = 'position: relative; top: -50%; background-color: ' + OverlayMessage.backgroundColor + '; width: 55%;  text-style: "Trebuchet MS"; text-align: center; margin-left: auto; margin-right: auto; padding: 0em; border: 0.01in ridge ' + OverlayMessage.borderColor + '; z-index: 100; opacity: .25; filter: alpha(opacity=100);';
    this.invisibleStyle = 'display: none;';
    this.overlay.style.cssText = this.invisibleStyle;
    };
	
	OverlayMessage.font = 'Trebuchet MS';
OverlayMessage.borderColor = '#0001EC';


OverlayMessage.backgroundColor = '#99CCFF';
OverlayMessage.borderColor = '#0001EC';


OverlayMessage.prototype.Set = function ( message )
    {
    this.overlay.innerHTML = message;
    this.overlay.style.cssText = this.visibleStyle;
    };


OverlayMessage.prototype.Clear = function ()
    {
    this.overlay.style.cssText = this.invisibleStyle;
    };


OverlayMessage.SetBackgroundColor = function ( color )
    {
    OverlayMessage.backgroundColor = color;
    };


OverlayMessage.SetBorderColor = function ( color )
    {
    OverlayMessage.borderColor = color;
    };
	
	
	
	
    var addthis_config = {
		"data_track_clickback":true,
		ui_cobrand: "T-SHIRT MAGIC",
		ui_header_color: "#000000",
		ui_header_background: "#99CCFF",
		ui_use_css: true
		}; 

 	sfHover = function() {
		var sfEls = document.getElementById("nav").getElementsByTagName("LI");
		for (var i=0; i<sfEls.length; i++) {
			sfEls[i].onmouseover=function() {
				this.className+=" sfhover";
			}
			sfEls[i].onmouseout=function() {
				this.className=this.className.replace(new RegExp(" sfhover\\b"), "");
			}
		}
	}
	if (window.attachEvent) window.attachEvent("onload", sfHover);

//xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx//





//** Animated Collapsible DIV v2.0- (c) Dynamic Drive DHTML code library: http://www.dynamicdrive.com.
//** May 24th, 08'- Script rewritten and updated to 2.0.
//** June 4th, 08'- Version 2.01: Bug fix to work with jquery 1.2.6 (which changed the way attr() behaves).
//** March 5th, 09'- Version 2.2, which adds the following:
			//1) ontoggle($, divobj, state) event that fires each time a DIV is expanded/collapsed, including when the page 1st loads
			//2) Ability to expand a DIV via a URL parameter string, ie: index.htm?expanddiv=jason or index.htm?expanddiv=jason,kelly

//** March 9th, 09'- Version 2.2.1: Optimized ontoggle event handler slightly.
//** July 3rd, 09'- Version 2.4, which adds the following:
			//1) You can now insert rel="expand[divid] | collapse[divid] | toggle[divid]" inside arbitrary links to act as DIV togglers
			//2) For image toggler links, you can insert the attributes "data-openimage" and "data-closedimage" to update its image based on the DIV state

var animatedcollapse={
divholders: {}, //structure: {div.id, div.attrs, div.$divref, div.$togglerimage}
divgroups: {}, //structure: {groupname.count, groupname.lastactivedivid}
lastactiveingroup: {}, //structure: {lastactivediv.id}
preloadimages: [],

show:function(divids){ //public method
	if (typeof divids=="object"){
		for (var i=0; i<divids.length; i++)
			this.showhide(divids[i], "show")
	}
	else
		this.showhide(divids, "show")
},

hide:function(divids){ //public method
	if (typeof divids=="object"){
		for (var i=0; i<divids.length; i++)
			this.showhide(divids[i], "hide")
	}
	else
		this.showhide(divids, "hide")
},

toggle:function(divid){ //public method
	if (typeof divid=="object")
		divid=divid[0]
	this.showhide(divid, "toggle")
},

addDiv:function(divid, attrstring){ //public function
	this.divholders[divid]=({id: divid, $divref: null, attrs: attrstring})
	this.divholders[divid].getAttr=function(name){ //assign getAttr() function to each divholder object
		var attr=new RegExp(name+"=([^,]+)", "i") //get name/value config pair (ie: width=400px,)
		return (attr.test(this.attrs) && parseInt(RegExp.$1)!=0)? RegExp.$1 : null //return value portion (string), or 0 (false) if none found
	}
	this.currentid=divid //keep track of current div object being manipulated (in the event of chaining)
	return this
},

showhide:function(divid, action){
	var $divref=this.divholders[divid].$divref //reference collapsible DIV
	if (this.divholders[divid] && $divref.length==1){ //if DIV exists
		var targetgroup=this.divgroups[$divref.attr('groupname')] //find out which group DIV belongs to (if any)
		if ($divref.attr('groupname') && targetgroup.count>1 && (action=="show" || action=="toggle" && $divref.css('display')=='none')){ //If current DIV belongs to a group
			if (targetgroup.lastactivedivid && targetgroup.lastactivedivid!=divid) //if last active DIV is set
				this.slideengine(targetgroup.lastactivedivid, 'hide') //hide last active DIV within group first
				this.slideengine(divid, 'show')
			targetgroup.lastactivedivid=divid //remember last active DIV
		}
		else{
			this.slideengine(divid, action)
		}
	}
},

slideengine:function(divid, action){
	var $divref=this.divholders[divid].$divref
	var $togglerimage=this.divholders[divid].$togglerimage
	if (this.divholders[divid] && $divref.length==1){ //if this DIV exists
		var animateSetting={height: action}
		if ($divref.attr('fade'))
			animateSetting.opacity=action
		$divref.animate(animateSetting, $divref.attr('speed')? parseInt($divref.attr('speed')) : 500, function(){
			if ($togglerimage){
				$togglerimage.attr('src', ($divref.css('display')=="none")? $togglerimage.data('srcs').closed : $togglerimage.data('srcs').open)
			}
			if (animatedcollapse.ontoggle){
				try{
					animatedcollapse.ontoggle(jQuery, $divref.get(0), $divref.css('display'))
				}
				catch(e){
					alert("An error exists inside your \"ontoggle\" function:\n\n"+e+"\n\nAborting execution of function.")
				}
			}
		})
		return false
	}
},

generatemap:function(){
	var map={}
	for (var i=0; i<arguments.length; i++){
		if (arguments[i][1]!=null){ //do not generate name/value pair if value is null
			map[arguments[i][0]]=arguments[i][1]
		}
	}
	return map
},

init:function(){
	var ac=this
	jQuery(document).ready(function($){
		animatedcollapse.ontoggle=animatedcollapse.ontoggle || null
		var urlparamopenids=animatedcollapse.urlparamselect() //Get div ids that should be expanded based on the url (['div1','div2',etc])
		var persistopenids=ac.getCookie('acopendivids') //Get list of div ids that should be expanded due to persistence ('div1,div2,etc')
		var groupswithpersist=ac.getCookie('acgroupswithpersist') //Get list of group names that have 1 or more divs with "persist" attribute defined
		if (persistopenids!=null) //if cookie isn't null (is null if first time page loads, and cookie hasnt been set yet)
			persistopenids=(persistopenids=='nada')? [] : persistopenids.split(',') //if no divs are persisted, set to empty array, else, array of div ids
		groupswithpersist=(groupswithpersist==null || groupswithpersist=='nada')? [] : groupswithpersist.split(',') //Get list of groups with divs that are persisted
		jQuery.each(ac.divholders, function(){ //loop through each collapsible DIV object
			this.$divref=$('#'+this.id)
			if ((this.getAttr('persist') || jQuery.inArray(this.getAttr('group'), groupswithpersist)!=-1) && persistopenids!=null){ //if this div carries a user "persist" setting, or belong to a group with at least one div that does
				var cssdisplay=(jQuery.inArray(this.id, persistopenids)!=-1)? 'block' : 'none'
			}
			else{
				var cssdisplay=this.getAttr('hide')? 'none' : null
			}
			if (urlparamopenids[0]=="all" || jQuery.inArray(this.id, urlparamopenids)!=-1){ //if url parameter string contains the single array element "all", or this div's ID
				cssdisplay='block' //set div to "block", overriding any other setting
			}
			else if (urlparamopenids[0]=="none"){
				cssdisplay='none' //set div to "none", overriding any other setting
			}
			this.$divref.css(ac.generatemap(['height', this.getAttr('height')], ['display', cssdisplay]))
			this.$divref.attr(ac.generatemap(['groupname', this.getAttr('group')], ['fade', this.getAttr('fade')], ['speed', this.getAttr('speed')]))
			if (this.getAttr('group')){ //if this DIV has the "group" attr defined
				var targetgroup=ac.divgroups[this.getAttr('group')] || (ac.divgroups[this.getAttr('group')]={}) //Get settings for this group, or if it no settings exist yet, create blank object to store them in
				targetgroup.count=(targetgroup.count||0)+1 //count # of DIVs within this group
				if (jQuery.inArray(this.id, urlparamopenids)!=-1){ //if url parameter string contains this div's ID
					targetgroup.lastactivedivid=this.id //remember this DIV as the last "active" DIV (this DIV will be expanded). Overrides other settings
					targetgroup.overridepersist=1 //Indicate to override persisted div that would have been expanded
				}
				if (!targetgroup.lastactivedivid && this.$divref.css('display')!='none' || cssdisplay=="block" && typeof targetgroup.overridepersist=="undefined") //if this DIV was open by default or should be open due to persistence								
					targetgroup.lastactivedivid=this.id //remember this DIV as the last "active" DIV (this DIV will be expanded)
				this.$divref.css({display:'none'}) //hide any DIV that's part of said group for now
			}
		}) //end divholders.each
		jQuery.each(ac.divgroups, function(){ //loop through each group
			if (this.lastactivedivid && urlparamopenids[0]!="none") //show last "active" DIV within each group (one that should be expanded), unless url param="none"
				ac.divholders[this.lastactivedivid].$divref.show()
		})
		if (animatedcollapse.ontoggle){
			jQuery.each(ac.divholders, function(){ //loop through each collapsible DIV object and fire ontoggle event
				animatedcollapse.ontoggle(jQuery, this.$divref.get(0), this.$divref.css('display'))
			})
		}
 		//Parse page for links containing rel attribute
		var $allcontrols=$('a[rel]').filter('[rel^="collapse["], [rel^="expand["], [rel^="toggle["]') //get all elements on page with rel="collapse[]", "expand[]" and "toggle[]"
		$allcontrols.each(function(){ //loop though each control link
			this._divids=this.getAttribute('rel').replace(/(^\w+)|(\s+)/g, "").replace(/[\[\]']/g, "") //cache value 'div1,div2,etc' within identifier[div1,div2,etc]
			if (this.getElementsByTagName('img').length==1 && ac.divholders[this._divids]){ //if control is an image link that toggles a single DIV (must be one to one to update status image)
				animatedcollapse.preloadimage(this.getAttribute('data-openimage'), this.getAttribute('data-closedimage')) //preload control images (if defined)
				$togglerimage=$(this).find('img').eq(0).data('srcs', {open:this.getAttribute('data-openimage'), closed:this.getAttribute('data-closedimage')}) //remember open and closed images' paths
				ac.divholders[this._divids].$togglerimage=$(this).find('img').eq(0) //save reference to toggler image (to be updated inside slideengine()
				ac.divholders[this._divids].$togglerimage.attr('src', (ac.divholders[this._divids].$divref.css('display')=="none")? $togglerimage.data('srcs').closed : $togglerimage.data('srcs').open)
			}
			$(this).click(function(){ //assign click behavior to each control link
				var relattr=this.getAttribute('rel')
				var divids=(this._divids=="")? [] : this._divids.split(',') //convert 'div1,div2,etc' to array 
				if (divids.length>0){
					animatedcollapse[/expand/i.test(relattr)? 'show' : /collapse/i.test(relattr)? 'hide' : 'toggle'](divids) //call corresponding public function
					return false
				}
			}) //end control.click
		})// end control.each

		$(window).bind('unload', function(){
			ac.uninit()
		})
	}) //end doc.ready()
},

uninit:function(){
	var opendivids='', groupswithpersist=''
	jQuery.each(this.divholders, function(){
		if (this.$divref.css('display')!='none'){
			opendivids+=this.id+',' //store ids of DIVs that are expanded when page unloads: 'div1,div2,etc'
		}
		if (this.getAttr('group') && this.getAttr('persist'))
			groupswithpersist+=this.getAttr('group')+',' //store groups with which at least one DIV has persistance enabled: 'group1,group2,etc'
	})
	opendivids=(opendivids=='')? 'nada' : opendivids.replace(/,$/, '')
	groupswithpersist=(groupswithpersist=='')? 'nada' : groupswithpersist.replace(/,$/, '')
	this.setCookie('acopendivids', opendivids)
	this.setCookie('acgroupswithpersist', groupswithpersist)
},

getCookie:function(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 null
},

setCookie:function(name, value, days){
	if (typeof days!="undefined"){ //if set persistent cookie
		var expireDate = new Date()
		expireDate.setDate(expireDate.getDate()+days)
		document.cookie = name+"="+value+"; path=/; expires="+expireDate.toGMTString()
	}
	else //else if this is a session only cookie
		document.cookie = name+"="+value+"; path=/"
},

urlparamselect:function(){
	window.location.search.match(/expanddiv=([\w\-_,]+)/i) //search for expanddiv=divid or divid1,divid2,etc
	return (RegExp.$1!="")? RegExp.$1.split(",") : []
},

preloadimage:function(){
	var preloadimages=this.preloadimages
	for (var i=0; i<arguments.length; i++){
		if (arguments[i] && arguments[i].length>0){
			preloadimages[preloadimages.length]=new Image()
			preloadimages[preloadimages.length-1].src=arguments[i]
		}
	}
}

}










//** Animated Collapsible DIV v2.0- (c) Dynamic Drive DHTML code library: http://www.dynamicdrive.com.
//** May 24th, 08'- Script rewritten and updated to 2.0.
//** June 4th, 08'- Version 2.01: Bug fix to work with jquery 1.2.6 (which changed the way attr() behaves).
//** March 5th, 09'- Version 2.2, which adds the following:
			//1) ontoggle($, divobj, state) event that fires each time a DIV is expanded/collapsed, including when the page 1st loads
			//2) Ability to expand a DIV via a URL parameter string, ie: index.htm?expanddiv=jason or index.htm?expanddiv=jason,kelly

//** March 9th, 09'- Version 2.2.1: Optimized ontoggle event handler slightly.
//** July 3rd, 09'- Version 2.4, which adds the following:
			//1) You can now insert rel="expand[divid] | collapse[divid] | toggle[divid]" inside arbitrary links to act as DIV togglers
			//2) For image toggler links, you can insert the attributes "data-openimage" and "data-closedimage" to update its image based on the DIV state

var animatedcollapse={
divholders: {}, //structure: {div.id, div.attrs, div.$divref, div.$togglerimage}
divgroups: {}, //structure: {groupname.count, groupname.lastactivedivid}
lastactiveingroup: {}, //structure: {lastactivediv.id}
preloadimages: [],

show:function(divids){ //public method
	if (typeof divids=="object"){
		for (var i=0; i<divids.length; i++)
			this.showhide(divids[i], "show")
	}
	else
		this.showhide(divids, "show")
},

hide:function(divids){ //public method
	if (typeof divids=="object"){
		for (var i=0; i<divids.length; i++)
			this.showhide(divids[i], "hide")
	}
	else
		this.showhide(divids, "hide")
},

toggle:function(divid){ //public method
	if (typeof divid=="object")
		divid=divid[0]
	this.showhide(divid, "toggle")
},

addDiv:function(divid, attrstring){ //public function
	this.divholders[divid]=({id: divid, $divref: null, attrs: attrstring})
	this.divholders[divid].getAttr=function(name){ //assign getAttr() function to each divholder object
		var attr=new RegExp(name+"=([^,]+)", "i") //get name/value config pair (ie: width=400px,)
		return (attr.test(this.attrs) && parseInt(RegExp.$1)!=0)? RegExp.$1 : null //return value portion (string), or 0 (false) if none found
	}
	this.currentid=divid //keep track of current div object being manipulated (in the event of chaining)
	return this
},

showhide:function(divid, action){
	var $divref=this.divholders[divid].$divref //reference collapsible DIV
	if (this.divholders[divid] && $divref.length==1){ //if DIV exists
		var targetgroup=this.divgroups[$divref.attr('groupname')] //find out which group DIV belongs to (if any)
		if ($divref.attr('groupname') && targetgroup.count>1 && (action=="show" || action=="toggle" && $divref.css('display')=='none')){ //If current DIV belongs to a group
			if (targetgroup.lastactivedivid && targetgroup.lastactivedivid!=divid) //if last active DIV is set
				this.slideengine(targetgroup.lastactivedivid, 'hide') //hide last active DIV within group first
				this.slideengine(divid, 'show')
			targetgroup.lastactivedivid=divid //remember last active DIV
		}
		else{
			this.slideengine(divid, action)
		}
	}
},

slideengine:function(divid, action){
	var $divref=this.divholders[divid].$divref
	var $togglerimage=this.divholders[divid].$togglerimage
	if (this.divholders[divid] && $divref.length==1){ //if this DIV exists
		var animateSetting={height: action}
		if ($divref.attr('fade'))
			animateSetting.opacity=action
		$divref.animate(animateSetting, $divref.attr('speed')? parseInt($divref.attr('speed')) : 500, function(){
			if ($togglerimage){
				$togglerimage.attr('src', ($divref.css('display')=="none")? $togglerimage.data('srcs').closed : $togglerimage.data('srcs').open)
			}
			if (animatedcollapse.ontoggle){
				try{
					animatedcollapse.ontoggle(jQuery, $divref.get(0), $divref.css('display'))
				}
				catch(e){
					alert("An error exists inside your \"ontoggle\" function:\n\n"+e+"\n\nAborting execution of function.")
				}
			}
		})
		return false
	}
},

generatemap:function(){
	var map={}
	for (var i=0; i<arguments.length; i++){
		if (arguments[i][1]!=null){ //do not generate name/value pair if value is null
			map[arguments[i][0]]=arguments[i][1]
		}
	}
	return map
},

init:function(){
	var ac=this
	jQuery(document).ready(function($){
		animatedcollapse.ontoggle=animatedcollapse.ontoggle || null
		var urlparamopenids=animatedcollapse.urlparamselect() //Get div ids that should be expanded based on the url (['div1','div2',etc])
		var persistopenids=ac.getCookie('acopendivids') //Get list of div ids that should be expanded due to persistence ('div1,div2,etc')
		var groupswithpersist=ac.getCookie('acgroupswithpersist') //Get list of group names that have 1 or more divs with "persist" attribute defined
		if (persistopenids!=null) //if cookie isn't null (is null if first time page loads, and cookie hasnt been set yet)
			persistopenids=(persistopenids=='nada')? [] : persistopenids.split(',') //if no divs are persisted, set to empty array, else, array of div ids
		groupswithpersist=(groupswithpersist==null || groupswithpersist=='nada')? [] : groupswithpersist.split(',') //Get list of groups with divs that are persisted
		jQuery.each(ac.divholders, function(){ //loop through each collapsible DIV object
			this.$divref=$('#'+this.id)
			if ((this.getAttr('persist') || jQuery.inArray(this.getAttr('group'), groupswithpersist)!=-1) && persistopenids!=null){ //if this div carries a user "persist" setting, or belong to a group with at least one div that does
				var cssdisplay=(jQuery.inArray(this.id, persistopenids)!=-1)? 'block' : 'none'
			}
			else{
				var cssdisplay=this.getAttr('hide')? 'none' : null
			}
			if (urlparamopenids[0]=="all" || jQuery.inArray(this.id, urlparamopenids)!=-1){ //if url parameter string contains the single array element "all", or this div's ID
				cssdisplay='block' //set div to "block", overriding any other setting
			}
			else if (urlparamopenids[0]=="none"){
				cssdisplay='none' //set div to "none", overriding any other setting
			}
			this.$divref.css(ac.generatemap(['height', this.getAttr('height')], ['display', cssdisplay]))
			this.$divref.attr(ac.generatemap(['groupname', this.getAttr('group')], ['fade', this.getAttr('fade')], ['speed', this.getAttr('speed')]))
			if (this.getAttr('group')){ //if this DIV has the "group" attr defined
				var targetgroup=ac.divgroups[this.getAttr('group')] || (ac.divgroups[this.getAttr('group')]={}) //Get settings for this group, or if it no settings exist yet, create blank object to store them in
				targetgroup.count=(targetgroup.count||0)+1 //count # of DIVs within this group
				if (jQuery.inArray(this.id, urlparamopenids)!=-1){ //if url parameter string contains this div's ID
					targetgroup.lastactivedivid=this.id //remember this DIV as the last "active" DIV (this DIV will be expanded). Overrides other settings
					targetgroup.overridepersist=1 //Indicate to override persisted div that would have been expanded
				}
				if (!targetgroup.lastactivedivid && this.$divref.css('display')!='none' || cssdisplay=="block" && typeof targetgroup.overridepersist=="undefined") //if this DIV was open by default or should be open due to persistence								
					targetgroup.lastactivedivid=this.id //remember this DIV as the last "active" DIV (this DIV will be expanded)
				this.$divref.css({display:'none'}) //hide any DIV that's part of said group for now
			}
		}) //end divholders.each
		jQuery.each(ac.divgroups, function(){ //loop through each group
			if (this.lastactivedivid && urlparamopenids[0]!="none") //show last "active" DIV within each group (one that should be expanded), unless url param="none"
				ac.divholders[this.lastactivedivid].$divref.show()
		})
		if (animatedcollapse.ontoggle){
			jQuery.each(ac.divholders, function(){ //loop through each collapsible DIV object and fire ontoggle event
				animatedcollapse.ontoggle(jQuery, this.$divref.get(0), this.$divref.css('display'))
			})
		}
 		//Parse page for links containing rel attribute
		var $allcontrols=$('a[rel]').filter('[rel^="collapse["], [rel^="expand["], [rel^="toggle["]') //get all elements on page with rel="collapse[]", "expand[]" and "toggle[]"
		$allcontrols.each(function(){ //loop though each control link
			this._divids=this.getAttribute('rel').replace(/(^\w+)|(\s+)/g, "").replace(/[\[\]']/g, "") //cache value 'div1,div2,etc' within identifier[div1,div2,etc]
			if (this.getElementsByTagName('img').length==1 && ac.divholders[this._divids]){ //if control is an image link that toggles a single DIV (must be one to one to update status image)
				animatedcollapse.preloadimage(this.getAttribute('title'), this.getAttribute('rev')) //preload control images (if defined)
				$togglerimage=$(this).find('img').eq(0).data('srcs', {open:this.getAttribute('title'), closed:this.getAttribute('rev')}) //remember open and closed images' paths
				ac.divholders[this._divids].$togglerimage=$(this).find('img').eq(0) //save reference to toggler image (to be updated inside slideengine()
				ac.divholders[this._divids].$togglerimage.attr('src', (ac.divholders[this._divids].$divref.css('display')=="none")? $togglerimage.data('srcs').closed : $togglerimage.data('srcs').open)
			}
			$(this).click(function(){ //assign click behavior to each control link
				var relattr=this.getAttribute('rel')
				var divids=(this._divids=="")? [] : this._divids.split(',') //convert 'div1,div2,etc' to array 
				if (divids.length>0){
					animatedcollapse[/expand/i.test(relattr)? 'show' : /collapse/i.test(relattr)? 'hide' : 'toggle'](divids) //call corresponding public function
					return false
				}
			}) //end control.click
		})// end control.each

		$(window).bind('unload', function(){
			ac.uninit()
		})
	}) //end doc.ready()
},

uninit:function(){
	var opendivids='', groupswithpersist=''
	jQuery.each(this.divholders, function(){
		if (this.$divref.css('display')!='none'){
			opendivids+=this.id+',' //store ids of DIVs that are expanded when page unloads: 'div1,div2,etc'
		}
		if (this.getAttr('group') && this.getAttr('persist'))
			groupswithpersist+=this.getAttr('group')+',' //store groups with which at least one DIV has persistance enabled: 'group1,group2,etc'
	})
	opendivids=(opendivids=='')? 'nada' : opendivids.replace(/,$/, '')
	groupswithpersist=(groupswithpersist=='')? 'nada' : groupswithpersist.replace(/,$/, '')
	this.setCookie('acopendivids', opendivids)
	this.setCookie('acgroupswithpersist', groupswithpersist)
},

getCookie:function(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 null
},

setCookie:function(name, value, days){
	if (typeof days!="undefined"){ //if set persistent cookie
		var expireDate = new Date()
		expireDate.setDate(expireDate.getDate()+days)
		document.cookie = name+"="+value+"; path=/; expires="+expireDate.toGMTString()
	}
	else //else if this is a session only cookie
		document.cookie = name+"="+value+"; path=/"
},

urlparamselect:function(){
	window.location.search.match(/expanddiv=([\w\-_,]+)/i) //search for expanddiv=divid or divid1,divid2,etc
	return (RegExp.$1!="")? RegExp.$1.split(",") : []
},

preloadimage:function(){
	var preloadimages=this.preloadimages
	for (var i=0; i<arguments.length; i++){
		if (arguments[i] && arguments[i].length>0){
			preloadimages[preloadimages.length]=new Image()
			preloadimages[preloadimages.length-1].src=arguments[i]
		}
	}
}

}












/*function layerSetup(id,visibility){
if(document.getElementById){
this.obj = document.getElementById(id).style;
this.obj.visibility = visibility;
return this.obj;}
else if(document.all){
this.obj = document.all[id].style;
this.obj.visibility = visibility;
return this.obj;}
else if(document.layers){
this.obj = document.layers[id];
this.obj.visibility = visibility;
return this.obj;}
}
function visVisible(param){
new layerSetup(param,'visible');
}

function visHidden(param){
new layerSetup(param,'hidden');
}



// -------------------------------------------------------------------

// Image Thumbnail Viewer Script- By Dynamic Drive, available at: http://www.dynamicdrive.com

// Last updated: July 7th, 2008- Fixed enlarged image not showing in IE sometimes

// -------------------------------------------------------------------



var thumbnailviewer={

enableTitle: true, //Should "title" attribute of link be used as description?

enableAnimation: true, //Enable fading animation?

definefooter: '<div class="footerbar"><a href=http://www.tshirtmagic.com/stock.php?action=step2&c1=3352>Newest Designs</a></div><div class="footerbar2"><a>CLOSE X</a></div>', //Define HTML for footer interface

//ORG --- definefooter: '<div class="footerbar">CLOSE X</div>', //Define HTML for footer interface

defineLoading: '<img src="http://www.tshirtmagic.com/newsite2/images/loadingAnimation.gif" /><br> Loading Image...', //Define HTML for "loading" div



/////////////No need to edit beyond here/////////////////////////



scrollbarwidth: 16,

opacitystring: 'filter:progid:DXImageTransform.Microsoft.alpha(opacity=10); -moz-opacity: 0.1; opacity: 0.1',

targetlinks:[], //Array to hold links with rel="thumbnail"



createthumbBox:function(){

//write out HTML for Image Thumbnail Viewer plus loading div

document.write('<div id="thumbBox" onClick="thumbnailviewer.closeit()"><div id="thumbImage"></div>'+this.definefooter+'</div>')


document.write('<div id="thumbLoading">'+this.defineLoading+'</div>')

this.thumbBox=document.getElementById("thumbBox")

this.thumbImage=document.getElementById("thumbImage") //Reference div that holds the shown image

this.thumbLoading=document.getElementById("thumbLoading") //Reference "loading" div that will be shown while image is fetched

this.standardbody=(document.compatMode=="CSS1Compat")? document.documentElement : document.body //create reference to common "body" across doctypes

},





centerDiv:function(divobj){ //Centers a div element on the page

var ie=document.all && !window.opera

var dom=document.getElementById

var scroll_top=(ie)? this.standardbody.scrollTop : window.pageYOffset

var scroll_left=(ie)? this.standardbody.scrollLeft : window.pageXOffset

var docwidth=(ie)? this.standardbody.clientWidth : window.innerWidth-this.scrollbarwidth

var docheight=(ie)? this.standardbody.clientHeight: window.innerHeight

var docheightcomplete=(this.standardbody.offsetHeight>this.standardbody.scrollHeight)? this.standardbody.offsetHeight : this.standardbody.scrollHeight //Full scroll height of document

var objwidth=divobj.offsetWidth //width of div element

var objheight=divobj.offsetHeight //height of div element

var topposition=(docheight>objheight)? scroll_top+docheight/2-objheight/2+"px" : scroll_top+10+"px" //Vertical position of div element: Either centered, or if element height larger than viewpoint height, 10px from top of viewpoint

divobj.style.left=docwidth/2-objwidth/2+"px" //Center div element horizontally

divobj.style.top=Math.floor(parseInt(topposition))+"px"

divobj.style.visibility="visible"

},



showthumbBox:function(){ //Show ThumbBox div

thumbnailviewer.thumbLoading.style.visibility="hidden" //Hide "loading" div

this.centerDiv(this.thumbBox)

if (this.enableAnimation){ //If fading animation enabled

this.currentopacity=0.1 //Starting opacity value

this.opacitytimer=setInterval("thumbnailviewer.opacityanimation()", 20)

}

},





loadimage:function(link){ //Load image function that gets attached to each link on the page with rel="thumbnail"

if (this.thumbBox.style.visibility=="visible") //if thumbox is visible on the page already

this.closeit() //Hide it first (not doing so causes triggers some positioning bug in Firefox

var imageHTML='<img src="'+link.getAttribute("href")+'" style="'+this.opacitystring+'" />' //Construct HTML for shown image

if (this.enableTitle && link.getAttribute("title")) //Use title attr of the link as description?

imageHTML+='<br />'+link.getAttribute("title")

this.centerDiv(this.thumbLoading) //Center and display "loading" div while we set up the image to be shown

this.thumbImage.innerHTML=imageHTML //Populate thumbImage div with shown image's HTML (while still hidden)

this.featureImage=this.thumbImage.getElementsByTagName("img")[0] //Reference shown image itself

if (this.featureImage.complete)

thumbnailviewer.showthumbBox()

else{

this.featureImage.onload=function(){ //When target image has completely loaded

thumbnailviewer.showthumbBox() //Display "thumbbox" div to the world!

}

}

if (document.all && !window.createPopup) //Target IE5.0 browsers only. Address IE image cache not firing onload bug: panoramio.com/blog/onload-event/

this.featureImage.src=link.getAttribute("href")

this.featureImage.onerror=function(){ //If an error has occurred while loading the image to show

thumbnailviewer.thumbLoading.style.visibility="hidden" //Hide "loading" div, game over

}

},



setimgopacity:function(value){ //Sets the opacity of "thumbimage" div per the passed in value setting (0 to 1 and in between)

var targetobject=this.featureImage

if (targetobject.filters && targetobject.filters[0]){ //IE syntax

if (typeof targetobject.filters[0].opacity=="number") //IE6

targetobject.filters[0].opacity=value*100

else //IE 5.5

targetobject.style.filter="alpha(opacity="+value*100+")"

}

else if (typeof targetobject.style.MozOpacity!="undefined") //Old Mozilla syntax

targetobject.style.MozOpacity=value

else if (typeof targetobject.style.opacity!="undefined") //Standard opacity syntax

targetobject.style.opacity=value

else //Non of the above, stop opacity animation

this.stopanimation()

},



opacityanimation:function(){ //Gradually increase opacity function

this.setimgopacity(this.currentopacity)

this.currentopacity+=0.1

if (this.currentopacity>1)

this.stopanimation()

},



stopanimation:function(){

if (typeof this.opacitytimer!="undefined")

clearInterval(this.opacitytimer)

},





closeit:function(){ //Close "thumbbox" div function

this.stopanimation()

this.thumbBox.style.visibility="hidden"

this.thumbImage.innerHTML=""

this.thumbBox.style.left="-2000px"

this.thumbBox.style.top="-2000px"

},



cleanup:function(){ //Clean up routine on page unload

this.thumbLoading=null

if (this.featureImage) this.featureImage.onload=null

this.featureImage=null

this.thumbImage=null

for (var i=0; i<this.targetlinks.length; i++)

this.targetlinks[i].onclick=null

this.thumbBox=null

},



dotask:function(target, functionref, tasktype){ //assign a function to execute to an event handler (ie: onunload)

var tasktype=(window.addEventListener)? tasktype : "on"+tasktype

if (target.addEventListener)

target.addEventListener(tasktype, functionref, false)

else if (target.attachEvent)

target.attachEvent(tasktype, functionref)

},



init:function(){ //Initialize thumbnail viewer script by scanning page and attaching appropriate function to links with rel="thumbnail"

if (!this.enableAnimation)

this.opacitystring=""

var pagelinks=document.getElementsByTagName("a")

for (var i=0; i<pagelinks.length; i++){ //BEGIN FOR LOOP

if (pagelinks[i].getAttribute("rel") && pagelinks[i].getAttribute("rel")=="thumbnail3"){ //Begin if statement

pagelinks[i].onclick=function(){

thumbnailviewer.stopanimation() //Stop any currently running fade animation on "thumbbox" div before proceeding

thumbnailviewer.loadimage(this) //Load image

return false

}

this.targetlinks[this.targetlinks.length]=pagelinks[i] //store reference to target link

} //end if statement

} //END FOR LOOP

//Reposition "thumbbox" div when page is resized

this.dotask(window, function(){if (thumbnailviewer.thumbBox.style.visibility=="visible") thumbnailviewer.centerDiv(thumbnailviewer.thumbBox)}, "resize")





} //END init() function



}



thumbnailviewer.createthumbBox() //Output HTML for the image thumbnail viewer

thumbnailviewer.dotask(window, function(){thumbnailviewer.init()}, "load") //Initialize script on page load

thumbnailviewer.dotask(window, function(){thumbnailviewer.cleanup()}, "unload")*/

















/*XXXXXXX STEP 1 STOCK CATAGORY XXXXXXX*/


function newest()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(newest1[adNo])
}

function animals()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(animals1[adNo])
}
  
function art()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(art1[adNo])
}
  
function asian()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(asian1[adNo])
}
  
function attitude()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(attitude1[adNo])
}
  
function autos()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(autos1[adNo])
}

function best()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(best1[adNo])
}
  
function birthday()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(birthday1[adNo])
}
  
function celebrations()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(celebrations1[adNo])
}
  
function chocolate()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(chocolate1[adNo])
}
  
function computer()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(computer1[adNo])
}
  
function customlettering()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(customlettering1[adNo])
}
  
function darkshirtdesigns()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(darkshirtdesigns1[adNo])
}
  
function family()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(family1[adNo])
}
  
function forherforhim()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(forherforhim1[adNo])
}
  
function hobbies()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(hobbies1[adNo])
}
  
function humor()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(humor1[adNo])
}

function inspirational()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(inspirational1[adNo])
}

function infants()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(infants1[adNo])
}

function mystical()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(mystical1[adNo])
}

function nationality()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(nationality1[adNo])
}

function nature()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(nature1[adNo])
}

function occupational()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(occupational1[adNo])
}

function personalized()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(personalized1[adNo])
}
  
function poker()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(poker1[adNo])
}
  
function retro()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(retro1[adNo])
}
  
function romance()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(romance1[adNo])
}
  
function scifi()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(scifi1[adNo])
}
  
function seniors()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(seniors1[adNo])
}
  
function sports()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(sports1[adNo])
}

function sales()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(sales1[adNo])
}

function suggest()

{
  adNo = Math.round(Math.random() * maxAdNo)
  document.write(suggest1[adNo])
}
