
if(typeof(AC)=="undefined"){AC={};}









AC.ProductBrowser2={
productSlider:null,
sliderVal:0,
animationId:false,
viewportWidth:946,
contentWidth:946,
categories:[
{id:'pb2-cat1',offset:0},
{id:'pb2-cat2',offset:0.32}
],
isIPhone:AC.Detector.isiPhone(),
iPhoneCategories:[
{id:'pb2-cat1',offset:0},
{id:'pb2-cat2',offset:0.32}
],
arrowScrollAmount:0.24,
iPhoneScrollAmount:0.22,
iPhoneContainerWidth:834,
isSliding:false,
lastX:0.32,
isMouseDown:false,
dif:0,
overlap:0,
offsetImageWidth:127,
sliderOffset:291,
offsetContentWidth:-946,
clicked:false,
startIndex:0,

isIpScroll:false,
hasIpDragged:false,
init:function(setupArgs){
if(typeof(setupArgs.categories)!='undefined')this.categories=setupArgs.categories;
if(typeof(setupArgs.imageOverlap)!='undefined')this.overlap=setupArgs.imageOverlap;
if(typeof(setupArgs.sliderCentering)!='undefined')this.sliderOffset=setupArgs.sliderCentering;
if(typeof(setupArgs.initialCategory)!='undefined')this.startIndex=setupArgs.initialCategory;
if(typeof(setupArgs.arrowScrollAmount)!='undefined')this.arrowScrollAmount=setupArgs.arrowScrollAmount;
if(typeof(setupArgs.iPhoneCategories)!='undefined'){this.iPhoneCategories=setupArgs.iPhoneCategories;}
if(typeof(setupArgs.iPhoneScrollAmount)!='undefined')this.iPhoneScrollAmount=setupArgs.iPhoneScrollAmount;
if(typeof(setupArgs.iPhoneContainerWidth)!='undefined')this.iPhoneContainerWidth=setupArgs.iPhoneContainerWidth;

$('pb2-productslidertrack').style.visibility="visible";
$('pb2-productbrowsercontainer').style.overflow="hidden";

this.viewportWidth=$('pb2-productbrowsercontainer').getWidth();
this.offsetImageWidth=$$('#pb2-productslider .pb2-productimage')[0].getWidth()-this.overlap;
this.contentWidth=this.offsetImageWidth*$$('#pb2-productslider .pb2-productimage').length;
this.offsetContentWidth=-1*(this.contentWidth-this.viewportWidth);

this.productSlider=new Control.Slider('pb2-productsliderhandle','pb2-productslidertrack',{
axis:'horizontal'
});

if(AC.ProductBrowser2.isIPhone){
this.categories=this.iPhoneCategories;
this.arrowScrollAmount=this.iPhoneScrollAmount;
$('pb2-productslidertrack').style.visibility="none";
$('pb2-leftarrow').style.visibility="none";
$('pb2-rightarrow').style.visibility="none";
$('pb2-productbrowsercontainer').style.width=this.iPhoneContainerWidth+"px";

var leftArrow=document.createElement('div');
leftArrow.id="pb2-iphone-leftarrow";

var rightArrow=document.createElement('div');
rightArrow.id="pb2-iphone-rightarrow";

$('productbrowser').appendChild(leftArrow);
$('productbrowser').appendChild(rightArrow);

Event.observe($(leftArrow),'click',function(){
AC.ProductBrowser2.left();
});

Event.observe($(rightArrow),'click',function(){
AC.ProductBrowser2.right();
});
}

AC.ProductBrowser2.animateSlide(this.categories[this.startIndex].offset);


this.productSlider.options.onChange=function(value){
$('pb2-productsliderhandleimage').style.left=$('pb2-productsliderhandle').style.left;

if(AC.ProductBrowser2.isThrow&&!AC.ProductBrowser2.isSliding){
AC.ProductBrowser2.isSliding=true;
AC.ProductBrowser2.isThrow=false;

var mod=value+AC.ProductBrowser2.throwMod;
if(mod<0)mod=0;
if(mod>1)mod=1;
AC.ProductBrowser2.animateSlide(mod);
}
else if(!AC.ProductBrowser2.isSliding&&value){
AC.ProductBrowser2.isSliding=true;
AC.ProductBrowser2.animateSlide(value);
}
};

this.productSlider.options.onSlide=function(value){
$('pb2-productsliderhandleimage').style.left=$('pb2-productsliderhandle').style.left;
if(value&&!AC.ProductBrowser2.isSliding){
AC.ProductBrowser2.isSliding=true;
AC.ProductBrowser2.isThrow=false;
if(AC.ProductBrowser2.isMouseDown){
AC.ProductBrowser2.dif=value-AC.ProductBrowser2.lastX;
AC.ProductBrowser2.lastX=value;


if(AC.ProductBrowser2.dif>0.05){
AC.ProductBrowser2.isThrow=true;
AC.ProductBrowser2.throwMod=0.2;
}
else if(AC.ProductBrowser2.dif<-0.04){
AC.ProductBrowser2.isThrow=true;
AC.ProductBrowser2.throwMod=-0.2;
}
}

var w=AC.ProductBrowser2.offsetContentWidth;
$('pb2-productslider').style.left=w*value+"px";

this.sliderVal=value;
AC.ProductBrowser2.lastX=value;
AC.ProductBrowser2.colorCats();
AC.ProductBrowser2.isSliding=false;
}

Element.setStyle($('pb2-productbrowsercontainer'),{overflow:"hidden"});
};

Event.observe('pb2-productslidertrack','mousedown',function(e){
var o=e.offsetX||e.layerX;
if(Event.element(e).id=='pb2-productslidertrack'&&o<100)AC.ProductBrowser2.animateSlide(0);
});
Event.observe('pb2-leftarrow','mousedown',function(){
AC.ProductBrowser2.left();
});
Event.observe('pb2-rightarrow','mousedown',function(){
AC.ProductBrowser2.right();
});

Event.observe('pb2-productsliderhandle','mousedown',function(){
AC.ProductBrowser2.isMouseDown=true;
$('pb2-productsliderhandle').style.zIndex="5";
});

Event.observe('pb2-productsliderhandle','mouseup',function(){
AC.ProductBrowser2.isMouseDown=false;
});

AC.ProductBrowser2.categories.each(function(c){
Event.observe($(c.id),'mouseup',function(e){
AC.ProductBrowser2.animateSlide(c.offset);
});
});
},

animateSlide:function(toX){

if(toX>1)toX=1;
if(toX<0)toX=0;
AC.ProductBrowser2.sliderVal=toX;
window.clearInterval(AC.ProductBrowser2.animationId);
var w=AC.ProductBrowser2.offsetContentWidth;
var stopPoint=w*toX;

var sliderStopPoint=(Math.round(AC.ProductBrowser2.viewportWidth-AC.ProductBrowser2.sliderOffset)*toX);

AC.ProductBrowser2.isSliding=true;
AC.ProductBrowser2.animationId=window.setInterval(function(){
var sliderPos=parseInt($('pb2-productslider').getStyle('left'))||0;
var handlePos=parseInt($('pb2-productsliderhandle').getStyle('left'))||0;
var x=AC.ProductBrowser2.calculateDecel(sliderPos,stopPoint);
var sx=AC.ProductBrowser2.calculateDecel(handlePos,sliderStopPoint);
$('pb2-productslider').style.left=x+"px";
$('pb2-productsliderhandle').style.left=sx+"px";
$('pb2-productsliderhandleimage').style.left=sx+"px";
AC.ProductBrowser2.colorCats();

if(x==stopPoint){
window.clearInterval(AC.ProductBrowser2.animationId);
AC.ProductBrowser2.isSliding=false;
}
},30);

},

colorCats:function(){
var sliderX=parseInt($('pb2-productsliderhandle').getStyle('left'))+(($('pb2-productsliderhandle').getWidth()-20)/2);
AC.ProductBrowser2.categories.each(function(c){
var left=parseInt($(c.id).getStyle('left'))
var clr=Math.ceil((Math.min(sliderX,left)/Math.max(sliderX,left))*10);
$(c.id).className='pb2-catclass'+clr;
});
},

left:function(){
AC.ProductBrowser2.animateSlide(AC.ProductBrowser2.sliderVal-AC.ProductBrowser2.arrowScrollAmount);
},

right:function(){
AC.ProductBrowser2.animateSlide(AC.ProductBrowser2.sliderVal+AC.ProductBrowser2.arrowScrollAmount);
},

calculateDecel:function(from,to){
var n=from-Math.floor((from-to)*.4);
if(Math.abs(from-to)<4)return to;
else return n;
}
};

