// Chained Selects

// Copyright Xin Yang 2004
// Web Site: www.yxScripts.com
// EMail: m_yangxin@hotmail.com
// Last Updated: 2004-08-23

// This script is free as long as the copyright notice remains intact.

var _disable_empty_list=false;
var _hide_empty_list=false;

// ------
if (typeof(disable_empty_list)=="undefined") { disable_empty_list=_disable_empty_list; }
if (typeof(hide_empty_list)=="undefined") { hide_empty_list=_hide_empty_list; }

var cs_goodContent=true, cs_M="M", cs_L="L", cs_curTop=null, cs_curSub=null;

function cs_findOBJ(obj,n) {
  for (var i=0; i<obj.length; i++) {
    if (obj[i].name==n) { return obj[i]; }
  }
  return null;
}
function cs_findContent(n) { return cs_findOBJ(cs_content,n); }

function cs_findM(m,n) {
  if (m.name==n) { return m; }

  var sm=null;
  for (var i=0; i<m.items.length; i++) {
    if (m.items[i].type==cs_M) {
      sm=cs_findM(m.items[i],n);
      if (sm!=null) { break; }
    }
  }
  return sm;
}
function cs_findMenu(n) { return (cs_curSub!=null && cs_curSub.name==n)?cs_curSub:cs_findM(cs_curTop,n); }

function cs_contentOBJ(n,obj){ this.name=n; this.menu=obj; this.lists=new Array(); this.cookie=""; }; cs_content=new Array();
function cs_topmenuOBJ(tm) { this.name=tm; this.items=new Array(); this.df=0; this.addM=cs_addM; this.addL=cs_addL; }
function cs_submenuOBJ(dis,link,sub) {
  this.name=sub;
  this.type=cs_M; this.dis=dis; this.link=link; this.df=0;

  var x=cs_findMenu(sub);
  this.items=x==null?new Array():x.items;

  this.addM=cs_addM; this.addL=cs_addL;
}
function cs_linkOBJ(dis,link) { this.type=cs_L; this.dis=dis; this.link=link; }

function cs_addM(dis,link,sub) { this.items[this.items.length]=new cs_submenuOBJ(dis,link,sub); }
function cs_addL(dis,link) { this.items[this.items.length]=new cs_linkOBJ(dis,link); }

function cs_showMsg(msg) { window.status=msg; }
function cs_badContent(n) { cs_goodContent=false; cs_showMsg("["+n+"] Not Found."); }

function cs_optionOBJ(text,value) { this.text=text; this.value=value; }
function cs_emptyList(list) { for (var i=list.options.length-1; i>=0; i--) { list.options[i]=null; } }
function cs_refreshList(list,opt,df) {
  cs_emptyList(list);

  for (var i=0; i<opt.length; i++) {
    list.options[i]=new Option(opt[i].text, opt[i].value);
  }

  if (opt.length>0) {
    list.selectedIndex=df;
  }
}
function cs_getOptions(menu) {
  var opt=new Array();
  for (var i=0; i<menu.items.length; i++) {
    opt[i]=new cs_optionOBJ(menu.items[i].dis, menu.items[i].link);
  }
  return opt;
}
function cs_updateListGroup(content,idx,sidx,mode) {
  var i=0, curItem=null, menu=content.menu;

  while (i<idx) {
    menu=menu.items[content.lists[i++].selectedIndex];
  }

  if (menu.items[sidx].type==cs_M && idx<content.lists.length-1) {
    var df=cs_getIdx(mode,content.cookie,idx+1,menu.items[sidx].df);

    cs_refreshList(content.lists[idx+1], cs_getOptions(menu.items[sidx]), df);
    if (content.cookie) {
      cs_setCookie(content.cookie+"_"+(idx+1),df);
    }

    if (idx+1<content.lists.length) {
      if (disable_empty_list) {
        content.lists[idx+1].disabled=false;
      }
      if (hide_empty_list) {
        content.lists[idx+1].style.display="";
      }

      cs_updateListGroup(content,idx+1,df,mode);
    }
  }
  else {
    for (var s=idx+1; s<content.lists.length; s++) {
      cs_emptyList(content.lists[s]);

      if (disable_empty_list) {
        content.lists[s].disabled=true;
      }
      if (hide_empty_list) {
        content.lists[s].style.display="none";
      }

      if (content.cookie) {
        cs_setCookie(content.cookie+"_"+s,"");
      }
    }
  }
}
function cs_initListGroup(content,mode) {
  var df=cs_getIdx(mode,content.cookie,0,content.menu.df);

  cs_refreshList(content.lists[0], cs_getOptions(content.menu), df);
  if (content.cookie) {
    cs_setCookie(content.cookie+"_"+0,df);
  }

  cs_updateListGroup(content,0,df,mode);
}

function cs_updateList() {
  var content=this.content;
  for (var i=0; i<content.lists.length; i++) {
    if (content.lists[i]==this) {
      if (content.cookie) {
        cs_setCookie(content.cookie+"_"+i,this.selectedIndex);
      }

      if (i<content.lists.length-1) {
        cs_updateListGroup(content,i,this.selectedIndex,"");
      }
    }
  }
  reEvaluate();
}

function cs_getIdx(mode,name,idx,df) {
  if (mode) {
    var cs_idx=cs_getCookie(name+"_"+idx);
    if (cs_idx!="") {
      df=parseInt(cs_idx);
    }
  }
  return df;
  
}

function _setCookie(name, value) {
  document.cookie=name+"="+value;
}
function cs_setCookie(name, value) {
  //-- setTimeout("_setCookie('"+name+"','"+value+"')",0);
}

function cs_getCookie(name) {
  var cookieRE=new RegExp(name+"=([^;]+)");
  if (document.cookie.search(cookieRE)!=-1) {
    return "";	//-- 	RegExp.$1;
  }
  else {
    return "";
  }
}

// ----
function addListGroup(n,tm) {
  if (cs_goodContent) {
    cs_curTop=new cs_topmenuOBJ(tm); cs_curSub=null;

    var c=cs_findContent(n);
    if (c==null) {
      cs_content[cs_content.length]=new cs_contentOBJ(n,cs_curTop);
    }
    else {
      delete(c.menu); c.menu=cs_curTop;
    }
  }
}

function addList(n,dis,link,sub,df) {
  if (cs_goodContent) {
    cs_curSub=cs_findMenu(n);

    if (cs_curSub!=null) {
      cs_curSub.addM(dis,link||"",sub);
      if (typeof(df)!="undefined") { cs_curSub.df=cs_curSub.items.length-1; }
    }
    else {
      cs_badContent(n);
    }
  }
}

function addOption(n,dis,link,df) {
  if (cs_goodContent) {
    cs_curSub=cs_findMenu(n);

    if (cs_curSub!=null) {
      cs_curSub.addL(dis,link||"");
      if (typeof(df)!="undefined") { cs_curSub.df=cs_curSub.items.length-1; }
    }
    else {
      cs_badContent(n);
    }
  }
}


function initListGroup(n) {
  var _content=cs_findContent(n), count=0;
  if (_content!=null) {
    content=new cs_contentOBJ("cs_"+n,_content.menu);
    cs_content[cs_content.length]=content;

    for (var i=1; i<initListGroup.arguments.length; i++) {
      if (typeof(arguments[i])=="object" && arguments[i].tagName && arguments[i].tagName=="SELECT") {
        content.lists[count]=arguments[i];

        arguments[i].onchange=cs_updateList;
        arguments[i].content=content; arguments[i].idx=count++;
      }
      else if (typeof(arguments[i])=="string" && /^[a-zA-Z_]\w*$/.test(arguments[i])) {
        content.cookie=arguments[i];
      }
    }

    if (content.lists.length>0) {
      cs_initListGroup(content,content.cookie);
    }
  }
}

function resetListGroup(n) {
  var content=cs_findContent("cs_"+n);
  if (content!=null && content.lists.length>0) {
    cs_initListGroup(content,"");
  }
}




//-- Stock Graph Function
var graphRed = "../images/products_js/graph-red.gif"
var graphYellow = "../images/products_js/graph-yellow.gif"
var graphGreen = "../images/products_js/graph-green.gif"
//graphRed = "#ff0000"
//graphYellow = "#ffcc00"
//graphGreen = "#66cc00"
function graphitP(g,gwidth){
var graphNow = ""
var graphmessage = ""
outputP='<table width="100%" border="0" cellspacing="0" cellpadding="0">'
for (i=0;i<g.length;i++){

calwidthP=gwidth*(parseInt(g[i][1])/100)
//calwidthP=2*parseInt(g[i][1])

if	(calwidthP >= 100)
	{
	calwidthP = 100;
	}
	
	
if	(calwidthP <= 100 && calwidthP > 10)
	{
	graphNow = graphGreen;
	graphmessage = "In Stock";
//	if (calwidthP > 10 && calwidthP < 15)
//		{
//		calwidthP = 15;
//		}
	}
	
else if	(calwidthP <= 10 && calwidthP > 5)
	{
	graphNow = graphYellow;
	graphmessage = "Low Stock. May Delay Order";
//	if (calwidthP < 8)
//		{
//		calwidthP = 8;
//		}
	}
else 
	{
	graphNow = graphRed;
	graphmessage = "Out of Stock. 10 Day Back Order";
	calwidthP = 5;
	}
	

outputP+='<tr><td width="10%" class="stock-label">'+g[i][0]+'&nbsp;</td><td width="90%" class="stock-desc"><img src="'+graphNow+'" width="'+calwidthP+'%" height="10" border="0" alt="'+graphmessage+'"></td></tr>'
}
outputP+='</table>'
return outputP
}

//-- Dynamically generate price, stock levels
function reEvaluate() {
var prod_price = new Array()
prod_price[131]="$6.00"
prod_price[133]="$6.00"
prod_price[134]="$6.00"
prod_price[135]="$6.00"
prod_price[138]="$6.00"
prod_price[139]="$6.00"
prod_price[1121]="$6.00"
prod_price[1123]="$6.00"
prod_price[1124]="$6.00"
prod_price[1125]="$6.00"
prod_price[1128]="$6.00"
prod_price[1129]="$6.00"




var idtype = document.frm.idType.value;
var idcolor = document.frm.idColor.value;
var idsize = document.frm.idSize.value;
chooseInner('price', prod_price[idtype +idcolor +idsize]);
document.frm.prod_price.value = prod_price[idtype +idcolor +idsize]
//-- alert ("prod_price[" + idtype + "-" + idcolor + "-" + idsize + "]")
document.frm.dprice.value = idtype + "-" + idcolor + "-" + idsize




//-- Stock Availability
var prod_type_name = new Array();
prod_type_name[1] = "T-Shirt";



var prod_color_name = new Array();
prod_color_name[3] = "Black";
prod_color_name[12] = "Royal Blue";




var hasInnerText = (document.getElementsByTagName("body")[0].innerHTML != undefined) ? true : false;
var elem = document.getElementById('prod_stock');
var elem2 = document.getElementById ('stocklevels');

if(!hasInnerText){
    elem.textContent = prod_color_name[idcolor] + " " + prod_type_name[idtype];
} else{
    elem.innerHTML = prod_color_name[idcolor] + " " + prod_type_name[idtype];
}







//-- Stock Details


//DEFINE GRAPH VALUES [Item name, Percentage value]
var g13=new Array();
g13[0]=["S","10"];
g13[1]=["M","25"];
g13[2]=["L","26"];
g13[3]=["XL","26"];
g13[4]=["2XL","9"];
g13[5]=["3XL","3"];

var g112=new Array();
g112[0]=["S","4"];
g112[1]=["M","12"];
g112[2]=["L","12"];
g112[3]=["XL","12"];
g112[4]=["2XL","4"];
g112[5]=["3XL","1"];





var g = 'g' + idtype + idcolor
var gwidth = 100
//var tblGrph='<table border="0" cellspacing="0" cellpadding="0">'
//for (i=0;i<g.length;i++){
//calwidthP=gwidth*(parseInt(g[i][1])/100)
//tblGrph+='<tr><td>'+g[i][0]+'&nbsp;</td><td><img src="'+graphNow+'" width="'+calwidthP+'" height="10"> '+g[i][1]+'</td></tr>'
//}
//tblGrph+='</table>'


//alert(g)
switch(g){
case 'g13' : chooseInner('prod_stock', graphitP(g13,gwidth))
break
case 'g112' : chooseInner('prod_stock', graphitP(g112,gwidth))
break
}






// END Function
}



function chooseInner(frm, val){
var hasInnerText = (document.getElementsByTagName("body")[0].innerHTML != undefined) ? true : false;
var elem20 = document.getElementById (frm);
	if(!hasInnerText){
	    elem20.textContent = val;
	} else{
	    elem20.innerHTML = val;
	}
}





function showproductimage(imgval){
	
	chooseInner('lrgimage', '<img src="' + imgval + '" border="0" alt="">');
}










