
/*
clickabletablerow.js
*/
if(!Control) var Control = {};

Control.ClickableTableRow = Class.create();



Control.ClickableTableRow.prototype = {



  initialize: function(element, link, linkClassName, removeLinks) {

    this.element = $(element);

    this.link = link;       

    this.linkClassName = linkClassName;            

    this.removeLinks = false;       

    if (removeLinks)

    {

	    this.removeLinks = true;   

	  }

	  if (this.element)

    {   

    	this.setup();

   	}

  },

  

  dispose: function() {

  	if (this.element)

    {    

    	Event.stopObserving(this.element, "mousedown", this.eventClick);

    }

  },



  setup: function() {

    Element.addClassName(this.element, 'clickable');

    

    this.eventClick = this.click.bindAsEventListener(this);         

    Event.observe(this.element, "mousedown", this.eventClick);



    this.eventMouseOver = this.hoverIn.bindAsEventListener(this);         

    this.eventMouseOut = this.hoverOut.bindAsEventListener(this);

    Event.observe(this.element, "mouseover", this.eventMouseOver);

    Event.observe(this.element, "mouseout", this.eventMouseOut); 

    

    if (this.removeLinks)

    {    

	    var links = this.element.getElementsByTagName('a');

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

    	{

				links[i].href = 'JavaScript:nop();'; 			

	    }                      

	  }

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }  

    Event.stop(event);

    var link = Element.findParentTag(Event.element(event), 'a');

    if (!link)

    {

      document.location.href = this.link;    

      return false;

    }

    return true;   

  },

    

  hoverIn: function(event) {

    var buttons = this.element.getElementsByClassName(this.linkClassName);

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

    {

			var img = buttons[i]; 			

	 		var extension = img.src.substr(img.src.length - 4, 4);

	 		var state = img.src.substr(img.src.length - 5, 1);

	 		var name = img.src.substr(0, img.src.length - 5); 		

	 		if (state == '1')

	 		{

	 			img.src = name + '2' + extension;

	 		}

    }    		

    Event.stop(event);	

  },

    

  hoverOut: function(event) {

    var buttons = document.getElementsByClassName(this.linkClassName, this.element);

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

    {

			var img = buttons[i]; 			

	 		var extension = img.src.substr(img.src.length - 4, 4);

	 		var state = img.src.substr(img.src.length - 5, 1);

	 		var name = img.src.substr(0, img.src.length - 5); 		

	 		if (state == '2')

	 		{

	 			img.src = name + '1' + extension;

	 		}	

    }    		

    Event.stop(event);	  

  }  

}
/*
flashobject.js
*/
/**
 * SWFObject v1.4.4: Flash Player detection and embed - http://blog.deconcept.com/swfobject/
 *
 * SWFObject is (c) 2006 Geoff Stearns and is released under the MIT License:
 * http://www.opensource.org/licenses/mit-license.php
 *
 * **SWFObject is the SWF embed script formerly known as FlashObject. The name was changed for
 *   legal reasons.
 */
if(typeof deconcept=="undefined"){var deconcept=new Object();}
if(typeof deconcept.util=="undefined"){deconcept.util=new Object();}
if(typeof deconcept.SWFObjectUtil=="undefined"){deconcept.SWFObjectUtil=new Object();}
deconcept.SWFObject=function(_1,id,w,h,_5,c,_7,_8,_9,_a,_b){if(!document.getElementById){return;}
this.DETECT_KEY=_b?_b:"detectflash";
this.skipDetect=deconcept.util.getRequestParameter(this.DETECT_KEY);
this.params=new Object();
this.variables=new Object();
this.attributes=new Array();
if(_1){this.setAttribute("swf",_1);}
if(id){this.setAttribute("id",id);}
if(w){this.setAttribute("width",w);}
if(h){this.setAttribute("height",h);}
if(_5){this.setAttribute("version",new deconcept.PlayerVersion(_5.toString().split(".")));}
this.installedVer=deconcept.SWFObjectUtil.getPlayerVersion();
if(c){this.addParam("bgcolor",c);}
var q=_8?_8:"high";
this.addParam("quality",q);
this.setAttribute("useExpressInstall",_7);
this.setAttribute("doExpressInstall",false);
var _d=(_9)?_9:window.location;
this.setAttribute("xiRedirectUrl",_d);
this.setAttribute("redirectUrl","");
if(_a){this.setAttribute("redirectUrl",_a);}};
deconcept.SWFObject.prototype={setAttribute:function(_e,_f){
this.attributes[_e]=_f;
},getAttribute:function(_10){
return this.attributes[_10];
},addParam:function(_11,_12){
this.params[_11]=_12;
},getParams:function(){
return this.params;
},addVariable:function(_13,_14){
this.variables[_13]=_14;
},getVariable:function(_15){
return this.variables[_15];
},getVariables:function(){
return this.variables;
},getVariablePairs:function(){
var _16=new Array();
var key;
var _18=this.getVariables();
for(key in _18){_16.push(key+"="+_18[key]);}
return _16;},getSWFHTML:function(){var _19="";
if(navigator.plugins&&navigator.mimeTypes&&navigator.mimeTypes.length){
if(this.getAttribute("doExpressInstall")){
this.addVariable("MMplayerType","PlugIn");}
_19="<embed type=\"application/x-shockwave-flash\" src=\""+this.getAttribute("swf")+"\" width=\""+this.getAttribute("width")+"\" height=\""+this.getAttribute("height")+"\"";
_19+=" id=\""+this.getAttribute("id")+"\" name=\""+this.getAttribute("id")+"\" ";
var _1a=this.getParams();
for(var key in _1a){_19+=[key]+"=\""+_1a[key]+"\" ";}
var _1c=this.getVariablePairs().join("&");
if(_1c.length>0){_19+="flashvars=\""+_1c+"\"";}_19+="/>";
}else{if(this.getAttribute("doExpressInstall")){this.addVariable("MMplayerType","ActiveX");}
_19="<object id=\""+this.getAttribute("id")+"\" classid=\"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000\" width=\""+this.getAttribute("width")+"\" height=\""+this.getAttribute("height")+"\">";
_19+="<param name=\"movie\" value=\""+this.getAttribute("swf")+"\" />";
var _1d=this.getParams();
for(var key in _1d){_19+="<param name=\""+key+"\" value=\""+_1d[key]+"\" />";}
var _1f=this.getVariablePairs().join("&");
if(_1f.length>0){_19+="<param name=\"flashvars\" value=\""+_1f+"\" />";}_19+="</object>";}
return _19;
},write:function(_20){
if(this.getAttribute("useExpressInstall")){
var _21=new deconcept.PlayerVersion([6,0,65]);
if(this.installedVer.versionIsValid(_21)&&!this.installedVer.versionIsValid(this.getAttribute("version"))){
this.setAttribute("doExpressInstall",true);
this.addVariable("MMredirectURL",escape(this.getAttribute("xiRedirectUrl")));
document.title=document.title.slice(0,47)+" - Flash Player Installation";
this.addVariable("MMdoctitle",document.title);}}
if(this.skipDetect||this.getAttribute("doExpressInstall")||this.installedVer.versionIsValid(this.getAttribute("version"))){
var n=(typeof _20=="string")?document.getElementById(_20):_20;
n.innerHTML=this.getSWFHTML();return true;
}else{if(this.getAttribute("redirectUrl")!=""){document.location.replace(this.getAttribute("redirectUrl"));}}
return false;}};
deconcept.SWFObjectUtil.getPlayerVersion=function(){
var _23=new deconcept.PlayerVersion([0,0,0]);
if(navigator.plugins&&navigator.mimeTypes.length){
var x=navigator.plugins["Shockwave Flash"];
if(x&&x.description){_23=new deconcept.PlayerVersion(x.description.replace(/([a-zA-Z]|\s)+/,"").replace(/(\s+r|\s+b[0-9]+)/,".").split("."));}
}else{try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");}
catch(e){try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
_23=new deconcept.PlayerVersion([6,0,21]);axo.AllowScriptAccess="always";}
catch(e){if(_23.major==6){return _23;}}try{axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash");}
catch(e){}}if(axo!=null){_23=new deconcept.PlayerVersion(axo.GetVariable("$version").split(" ")[1].split(","));}}
return _23;};
deconcept.PlayerVersion=function(_27){
this.major=_27[0]!=null?parseInt(_27[0]):0;
this.minor=_27[1]!=null?parseInt(_27[1]):0;
this.rev=_27[2]!=null?parseInt(_27[2]):0;
};
deconcept.PlayerVersion.prototype.versionIsValid=function(fv){
if(this.major<fv.major){return false;}
if(this.major>fv.major){return true;}
if(this.minor<fv.minor){return false;}
if(this.minor>fv.minor){return true;}
if(this.rev<fv.rev){
return false;
}return true;};
deconcept.util={getRequestParameter:function(_29){
var q=document.location.search||document.location.hash;
if(q){var _2b=q.substring(1).split("&");
for(var i=0;i<_2b.length;i++){
if(_2b[i].substring(0,_2b[i].indexOf("="))==_29){
return _2b[i].substring((_2b[i].indexOf("=")+1));}}}
return "";}};
deconcept.SWFObjectUtil.cleanupSWFs=function(){if(window.opera||!document.all){return;}
var _2d=document.getElementsByTagName("OBJECT");
for(var i=0;i<_2d.length;i++){_2d[i].style.display="none";for(var x in _2d[i]){
if(typeof _2d[i][x]=="function"){_2d[i][x]=function(){};}}}};
deconcept.SWFObjectUtil.prepUnload=function(){__flash_unloadHandler=function(){};
__flash_savedUnloadHandler=function(){};
if(typeof window.onunload=="function"){
var _30=window.onunload;
window.onunload=function(){
deconcept.SWFObjectUtil.cleanupSWFs();_30();};
}else{window.onunload=deconcept.SWFObjectUtil.cleanupSWFs;}};
if(typeof window.onbeforeunload=="function"){
var oldBeforeUnload=window.onbeforeunload;
window.onbeforeunload=function(){
deconcept.SWFObjectUtil.prepUnload();
oldBeforeUnload();};
}else{window.onbeforeunload=deconcept.SWFObjectUtil.prepUnload;}
if(Array.prototype.push==null){
Array.prototype.push=function(_31){
this[this.length]=_31;
return this.length;};}
var getQueryParamValue=deconcept.util.getRequestParameter;
var FlashObject=deconcept.SWFObject;
var SWFObject=deconcept.SWFObject;
/*
imagezoom.js
*/
if(!Control) var Control = {};

 

function ImageZoomNOP(){}



Control.ImageZoom = Class.create();

Control.ImageZoom.prototype = {



  initialize: function(element, url, width, height) {

    this.element = $(element);

    this.url = url;

    this.width = width + 18;

    this.height = height + 18;

    this.setup();

  },

  

  dispose: function() {

		Event.stopObserving(this.element, "mousedown", this.eventClick);

  },



  setup: function() {

    this.eventClick = this.click.bindAsEventListener(this);         

    var links = this.element.getElementsByTagName('a');

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

    {

      links[i].target = '';

      links[i].href = 'JavaScript: ImageZoomNOP();';

    }       

		Event.observe(this.element, "mousedown", this.eventClick);    

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }

    Event.stop(event);

    window.open(this.url, '', 'width='+this.width+',height='+this.height+',resizable=yes');

    return true;

  }

}
/*
selector.js
*/
if(!Control) var Control = {};

Control.Selector = Class.create();



Control.Selector.prototype = {



  initialize: function(element) {

    this.element = $(element);     

    if (this.element)

    {

    	this.setup();

   	}

  },

  

  dispose: function() {

  	if (this.element)

    {    

    	Event.stopObserving(this.element, "change", this.eventClick);

    }

  },



  setup: function() {

    this.eventChange = this.change.bindAsEventListener(this);         

    Event.observe(this.element, "change", this.eventChange);

  },

    

  change: function(event) {

    document.location.href = this.element.value;    

  }

}
/*
print.js
*/
function setPrintImage(number)

{

  //debug('Set Image ' + number);

  var link = $('print-this-page');

  var url = '?print&image=' + (parseInt(number) + 1);

  link.href = url;

}
/*
link.js
*/
if(!Control) var Control = {};

Control.Link = Class.create();



Control.Link.prototype = {



  initialize: function(element, link, className) {

    this.element = $(element);

    this.link = link;

    if (this.element)

    {

    	this.setup();

   	}

  },

  

  dispose: function() {

  	if (this.element)

    {    

    	Event.stopObserving(this.element, "mousedown", this.eventClick);

    }

  },



  setup: function() {

    this.eventClick = this.click.bindAsEventListener(this);         

    Event.observe(this.element, "mousedown", this.eventClick);

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }  

    Event.stop(event);  

    document.location.href = this.link;    

  }

}
/*
productanimation.js
*/
if(!Control) var Control = {};

Control.ProductAnimation = Class.create();



Control.ProductAnimation.prototype = {



  initialize: function() {

    this.image = $('product-scroll-me-img');  

    this.setup();

  },

  

  dispose: function() {

    Event.stopObserving(this.image, "mouseover", this.eventMouseDown);

    Event.stopObserving(this.image, "mouseout", this.eventMouseDown);    

  },



  setup: function() {               

    this.eventMouseOver = this.hoverIn.bindAsEventListener(this);         

    this.eventMouseOut = this.hoverOut.bindAsEventListener(this);             

    Event.observe(this.image, "mouseover", this.eventMouseOver);

    Event.observe(this.image, "mouseout", this.eventMouseOut);      

  },

  

  hoverIn: function(event) {

    var img = Event.element(event);     

    var extension = img.src.substr(img.src.length - 4, 4);

    var state = img.src.substr(img.src.length - 5, 1);

    var name = img.src.substr(0, img.src.length - 5);     

    if (state != '2')

    {

      img.src = name + '2' + extension;

    }

    Event.stop(event);  

  },

    

  hoverOut: function(event) {

    var img = Event.element(event);     

    var extension = img.src.substr(img.src.length - 4, 4);

    var state = img.src.substr(img.src.length - 5, 1);

    var name = img.src.substr(0, img.src.length - 5);     

    if (state != '1')

    {

      img.src = name + '1' + extension;

    }

    Event.stop(event);  

  }

}
/*
extensions.js
*/
Object.extend(Element, {

  findParentTag: function(element, tagName) {

    while (element.parentNode && (!element.tagName ||

        (element.tagName.toUpperCase() != tagName.toUpperCase())))

    {

      element = element.parentNode;

    }

    if ((!element.tagName ||

         (element.tagName.toUpperCase() != tagName.toUpperCase())))

    {

      element = false;

    }    

    return element;

  },

  

  findSiblingTag: function(element, tagName) {

    var nextElement = element.nextSibling;

    while( nextElement && (!nextElement.tagName || 

          (nextElement.tagName.toUpperCase() != tagName.toUpperCase()) ) )

    {

      nextElement = nextElement.nextSibling;

    }

    return nextElement;

  }  

  

 });

 

 

function nop()

{

}
/*
downloadlist.js
*/
if(!Control) var Control = {};

 

function DownloadListNOP(){}



Control.DownloadList = Class.create();

Control.DownloadList.prototype = {



  initialize: function(element, url) {

    this.element = $(element);

    this.url = url;

    this.width = 720;

    this.height = 500;

    this.setup();

  },

  

  dispose: function() {

		Event.stopObserving(this.element, "mousedown", this.eventClick);

  },



  setup: function() {

    this.eventClick = this.click.bindAsEventListener(this);         

    this.element.target = '';

    this.element.href = 'JavaScript: DownloadListNOP();';

		Event.observe(this.element, "mousedown", this.eventClick);    

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }

    Event.stop(event);

    window.open(this.url, '', 'width='+this.width+',height='+this.height+',resizable=yes');  

    return true;

  }

}
/*
tracking.js
*/
function sendTrackingPixel(url)

{

	var pixel = document.createElement('img');

	pixel.src = url;

	document.body.appendChild(pixel);

}
/*
teaser.js
*/
if(!Control) var Control = {};

Control.Teaser = Class.create();



Control.Teaser.prototype = {



  initialize: function(element, link, linkClassName) {

    this.element = $(element);

    this.link = link;   

    this.linkClassName = linkClassName;            

    if (this.element)

    {

      var classNames = Element.classNames(this.element);

  	  this.className = classNames.toArray()[0];

	    this.classNameHover = this.className + '-hover';     

    	this.setup();

   	}

  },

  

  dispose: function() {

  	if (this.element)

    {    

    	Event.stopObserving(this.element, "mousedown", this.eventClick);

    }

  },



  setup: function() {

	  Element.addClassName(this.element, 'clickable');

	  

    this.eventClick = this.click.bindAsEventListener(this);         

    Event.observe(this.element, "mousedown", this.eventClick);



    this.eventMouseOver = this.hoverIn.bindAsEventListener(this);         

    this.eventMouseOut = this.hoverOut.bindAsEventListener(this);

    Event.observe(this.element, "mouseover", this.eventMouseOver);

    Event.observe(this.element, "mouseout", this.eventMouseOut);                  

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }  

    Event.stop(event);  

    document.location.href = this.link;    

  },

    

  hoverIn: function(event) {

    Element.addClassName(this.element, this.classNameHover);
    var buttons = this.element.getElementsByClassName(this.linkClassName);
    for(var i=0; i<buttons.length; i++)

    {

			var img = buttons[i]; 			

	 		var extension = img.src.substr(img.src.length - 4, 4);

	 		var state = img.src.substr(img.src.length - 5, 1);

	 		var name = img.src.substr(0, img.src.length - 5); 		
	 		if (state == '1')

	 		{

	 			img.src = name + '2' + extension;

	 		}

    }    		

    Event.stop(event);	

  },

    

  hoverOut: function(event) {

    Element.removeClassName(this.element, this.classNameHover);  

    var buttons = document.getElementsByClassName(this.linkClassName, this.element);

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

    {

			var img = buttons[i]; 			

	 		var extension = img.src.substr(img.src.length - 4, 4);

	 		var state = img.src.substr(img.src.length - 5, 1);

	 		var name = img.src.substr(0, img.src.length - 5); 		

	 		if (state == '2')

	 		{

	 			img.src = name + '1' + extension;

	 		}	

    }    		

    Event.stop(event);	  

  }  

}
/*
hover.js
*/
if(!Control) var Control = {};

Control.Hover = Class.create();



Control.Hover.prototype = {



  initialize: function(className) {

    this.className = className;

    this.setup();    

  },

  

  dispose: function() {

    var buttons = document.getElementsByClassName(this.className);

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

    {

			Event.stopObserving(buttons[i], "mouseover", this.eventMouseOver);

			Event.stopObserving(buttons[i], "mouseout", this.eventMouseOut);			

    } 

  },



  setup: function() {

    this.eventMouseOver = this.hoverIn.bindAsEventListener(this);         

    this.eventMouseOut = this.hoverOut.bindAsEventListener(this);             

    var buttons = document.getElementsByClassName(this.className);

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

    {

			Event.observe(buttons[i], "mouseover", this.eventMouseOver);

			Event.observe(buttons[i], "mouseout", this.eventMouseOut);			

    }    

  },



  hoverIn: function(event) {

 		if ((!Event) || (!Event.element)) return;

 		var img = Event.element(event); 		

 		var extension = img.src.substr(img.src.length - 4, 4);

 		var state = img.src.substr(img.src.length - 5, 1);

 		var name = img.src.substr(0, img.src.length - 5); 		

 		if (state == '1')

 		{

 			img.src = name + '2' + extension;

 		}

    Event.stop(event);	

  },

    

  hoverOut: function(event) {

 		if ((!Event) || (!Event.element)) return;

 		var img = Event.element(event); 		

 		var extension = img.src.substr(img.src.length - 4, 4);

 		var state = img.src.substr(img.src.length - 5, 1);

 		var name = img.src.substr(0, img.src.length - 5); 		

 		//debug('hoverOut Name ' + name + ', Extension ' + extension + ', State ' + state);

 		if (state == '2')

 		{

 			img.src = name + '1' + extension;

 		}

    Event.stop(event);	

  }

}
/*
popup.js
*/
if(!Control) var Control = {};

 

function PopupNOP(){}



Control.Popup = Class.create();

Control.Popup.prototype = {



  initialize: function(element, url, width, height) {

    this.element = $(element);

    this.url = url;

    this.width = width + 18;

    this.height = height + 18;

    this.setup();

  },

  

  dispose: function() {

		Event.stopObserving(this.element, "mousedown", this.eventClick);

  },



  setup: function() {

    this.eventClick = this.click.bindAsEventListener(this);         

    this.element.target = '';

    this.element.href = 'JavaScript: PopupNOP();';

		Event.observe(this.element, "mousedown", this.eventClick);    

  },

    

  click: function(event) {

	  if (!Event.isLeftClick(event))

	  {

	  	return;

	  }

    Event.stop(event);

    window.open(this.url, '', 'width='+this.width+',height='+this.height+',left=0,top=0,resizable=yes,menubar=yes,location=yes,scrollbars=yes,toolbar=yes,status=yes');

    return true;

  }

}
/*
teaserstories.js
*/
/* teaserstories.js */

var teaserElements;

var actualTeaserId = 0;

var zIndex = 0;

var loadedImages = new Array();

var slideshowTimeout = 5000;



function showNextContainer()

{

    if(loadedImages[getNextTeaserId()].complete) 

    {

        changeTeaserContent();

    } 

    else 

    {

        loadedImages[getNextTeaserId()].onload = function() { 

            changeTeaserContent();

        }

    }

}



function changeTeaserContent()

{

    var oldElementId = teaserElements[actualTeaserId][0];

    actualTeaserId = getNextTeaserId();

    zIndex ++;

    var newElementId = teaserElements[actualTeaserId][0];

    $(newElementId).setOpacity(0);

    $(newElementId).setStyle({

        zIndex: zIndex,

        display: 'block'

    });  

    new Effect.Opacity(newElementId, {duration:2, from:0, to:1});

    window.setTimeout(showNextContainer, slideshowTimeout); 

}



function getNextTeaserId()

{

    return (actualTeaserId + 1 < teaserElements.length) ? actualTeaserId + 1 : 0;

}



