
/*
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 = 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 == '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;    
  }
}
/*
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;
}


/*
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 = 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 == '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;
  }
}
