/**
 * SWFObject v1.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 formarly 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.createElement||!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(this.getAttribute("version"),_7);
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(_23,_24){
var _25=new deconcept.PlayerVersion([0,0,0]);
if(navigator.plugins&&navigator.mimeTypes.length){
var x=navigator.plugins["Shockwave Flash"];
if(x&&x.description){_25=new deconcept.PlayerVersion(x.description.replace(/([a-z]|[A-Z]|\s)+/,"").replace(/(\s+r|\s+b[0-9]+)/,".").split("."));}
}else{try{
var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash");
for(var i=3;axo!=null;i++){
axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash."+i);
_25=new deconcept.PlayerVersion([i,0,0]);}}
catch(e){}
if(_23&&_25.major>_23.major){return _25;}
if(!_23||((_23.minor!=0||_23.rev!=0)&&_25.major==_23.major)||_25.major!=6||_24){
try{_25=new deconcept.PlayerVersion(axo.GetVariable("$version").split(" ")[1].split(","));}
catch(e){}}}
return _25;};
deconcept.PlayerVersion=function(_29){
this.major=parseInt(_29[0])!=null?parseInt(_29[0]):0;
this.minor=parseInt(_29[1])||0;
this.rev=parseInt(_29[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(_2b){
var q=document.location.search||document.location.hash;
if(q){
var _2d=q.indexOf(_2b+"=");
var _2e=(q.indexOf("&",_2d)>-1)?q.indexOf("&",_2d):q.length;
if(q.length>1&&_2d>-1){
return q.substring(q.indexOf("=",_2d)+1,_2e);
}}return "";}};
if(Array.prototype.push==null){
Array.prototype.push=function(_2f){
this[this.length]=_2f;
return this.length;};}
var getQueryParamValue=deconcept.util.getRequestParameter;
var FlashObject=deconcept.SWFObject; // for backwards compatibility
var SWFObject=deconcept.SWFObject;

//MooTools, <http://mootools.net>, My Object Oriented (JavaScript) Tools. Copyright (c) 2006-2008 Valerio Proietti, <http://mad4milk.net>, MIT Style License.

var MooTools={version:"1.2.0",build:""};var Native=function(J){J=J||{};var F=J.afterImplement||function(){};var G=J.generics;G=(G!==false);var H=J.legacy;
var E=J.initialize;var B=J.protect;var A=J.name;var C=E||H;C.constructor=Native;C.$family={name:"native"};if(H&&E){C.prototype=H.prototype;}C.prototype.constructor=C;
if(A){var D=A.toLowerCase();C.prototype.$family={name:D};Native.typize(C,D);}var I=function(M,K,N,L){if(!B||L||!M.prototype[K]){M.prototype[K]=N;}if(G){Native.genericize(M,K,B);
}F.call(M,K,N);return M;};C.implement=function(L,K,N){if(typeof L=="string"){return I(this,L,K,N);}for(var M in L){I(this,M,L[M],K);}return this;};C.alias=function(M,K,N){if(typeof M=="string"){M=this.prototype[M];
if(M){I(this,K,M,N);}}else{for(var L in M){this.alias(L,M[L],K);}}return this;};return C;};Native.implement=function(D,C){for(var B=0,A=D.length;B<A;B++){D[B].implement(C);
}};Native.genericize=function(B,C,A){if((!A||!B[C])&&typeof B.prototype[C]=="function"){B[C]=function(){var D=Array.prototype.slice.call(arguments);return B.prototype[C].apply(D.shift(),D);
};}};Native.typize=function(A,B){if(!A.type){A.type=function(C){return($type(C)===B);};}};Native.alias=function(E,B,A,F){for(var D=0,C=E.length;D<C;D++){E[D].alias(B,A,F);
}};(function(B){for(var A in B){Native.typize(B[A],A);}})({"boolean":Boolean,"native":Native,object:Object});(function(B){for(var A in B){new Native({name:A,initialize:B[A],protect:true});
}})({String:String,Function:Function,Number:Number,Array:Array,RegExp:RegExp,Date:Date});(function(B,A){for(var C=A.length;C--;C){Native.genericize(B,A[C],true);
}return arguments.callee;})(Array,["pop","push","reverse","shift","sort","splice","unshift","concat","join","slice","toString","valueOf","indexOf","lastIndexOf"])(String,["charAt","charCodeAt","concat","indexOf","lastIndexOf","match","replace","search","slice","split","substr","substring","toLowerCase","toUpperCase","valueOf"]);
function $chk(A){return !!(A||A===0);}function $clear(A){clearTimeout(A);clearInterval(A);return null;}function $defined(A){return(A!=undefined);}function $empty(){}function $arguments(A){return function(){return arguments[A];
};}function $lambda(A){return(typeof A=="function")?A:function(){return A;};}function $extend(C,A){for(var B in (A||{})){C[B]=A[B];}return C;}function $unlink(C){var B;
switch($type(C)){case"object":B={};for(var E in C){B[E]=$unlink(C[E]);}break;case"hash":B=$unlink(C.getClean());break;case"array":B=[];for(var D=0,A=C.length;
D<A;D++){B[D]=$unlink(C[D]);}break;default:return C;}return B;}function $merge(){var E={};for(var D=0,A=arguments.length;D<A;D++){var B=arguments[D];if($type(B)!="object"){continue;
}for(var C in B){var G=B[C],F=E[C];E[C]=(F&&$type(G)=="object"&&$type(F)=="object")?$merge(F,G):$unlink(G);}}return E;}function $pick(){for(var B=0,A=arguments.length;
B<A;B++){if(arguments[B]!=undefined){return arguments[B];}}return null;}function $random(B,A){return Math.floor(Math.random()*(A-B+1)+B);}function $splat(B){var A=$type(B);
return(A)?((A!="array"&&A!="arguments")?[B]:B):[];}var $time=Date.now||function(){return new Date().getTime();};function $try(){for(var B=0,A=arguments.length;
B<A;B++){try{return arguments[B]();}catch(C){}}return null;}function $type(A){if(A==undefined){return false;}if(A.$family){return(A.$family.name=="number"&&!isFinite(A))?false:A.$family.name;
}if(A.nodeName){switch(A.nodeType){case 1:return"element";case 3:return(/\S/).test(A.nodeValue)?"textnode":"whitespace";}}else{if(typeof A.length=="number"){if(A.callee){return"arguments";
}else{if(A.item){return"collection";}}}}return typeof A;}var Hash=new Native({name:"Hash",initialize:function(A){if($type(A)=="hash"){A=$unlink(A.getClean());
}for(var B in A){this[B]=A[B];}return this;}});Hash.implement({getLength:function(){var B=0;for(var A in this){if(this.hasOwnProperty(A)){B++;}}return B;
},forEach:function(B,C){for(var A in this){if(this.hasOwnProperty(A)){B.call(C,this[A],A,this);}}},getClean:function(){var B={};for(var A in this){if(this.hasOwnProperty(A)){B[A]=this[A];
}}return B;}});Hash.alias("forEach","each");function $H(A){return new Hash(A);}Array.implement({forEach:function(C,D){for(var B=0,A=this.length;B<A;B++){C.call(D,this[B],B,this);
}}});Array.alias("forEach","each");function $A(C){if(C.item){var D=[];for(var B=0,A=C.length;B<A;B++){D[B]=C[B];}return D;}return Array.prototype.slice.call(C);
}function $each(C,B,D){var A=$type(C);((A=="arguments"||A=="collection"||A=="array")?Array:Hash).each(C,B,D);}var Browser=new Hash({Engine:{name:"unknown",version:""},Platform:{name:(navigator.platform.match(/mac|win|linux/i)||["other"])[0].toLowerCase()},Features:{xpath:!!(document.evaluate),air:!!(window.runtime)},Plugins:{}});
if(window.opera){Browser.Engine={name:"presto",version:(document.getElementsByClassName)?950:925};}else{if(window.ActiveXObject){Browser.Engine={name:"trident",version:(window.XMLHttpRequest)?5:4};
}else{if(!navigator.taintEnabled){Browser.Engine={name:"webkit",version:(Browser.Features.xpath)?420:419};}else{if(document.getBoxObjectFor!=null){Browser.Engine={name:"gecko",version:(document.getElementsByClassName)?19:18};
}}}}Browser.Engine[Browser.Engine.name]=Browser.Engine[Browser.Engine.name+Browser.Engine.version]=true;if(window.orientation!=undefined){Browser.Platform.name="ipod";
}Browser.Platform[Browser.Platform.name]=true;Browser.Request=function(){return $try(function(){return new XMLHttpRequest();},function(){return new ActiveXObject("MSXML2.XMLHTTP");
});};Browser.Features.xhr=!!(Browser.Request());Browser.Plugins.Flash=(function(){var A=($try(function(){return navigator.plugins["Shockwave Flash"].description;
},function(){return new ActiveXObject("ShockwaveFlash.ShockwaveFlash").GetVariable("$version");})||"0 r0").match(/\d+/g);return{version:parseInt(A[0]||0+"."+A[1]||0),build:parseInt(A[2]||0)};
})();function $exec(B){if(!B){return B;}if(window.execScript){window.execScript(B);}else{var A=document.createElement("script");A.setAttribute("type","text/javascript");
A.text=B;document.head.appendChild(A);document.head.removeChild(A);}return B;}Native.UID=1;var $uid=(Browser.Engine.trident)?function(A){return(A.uid||(A.uid=[Native.UID++]))[0];
}:function(A){return A.uid||(A.uid=Native.UID++);};var Window=new Native({name:"Window",legacy:(Browser.Engine.trident)?null:window.Window,initialize:function(A){$uid(A);
if(!A.Element){A.Element=$empty;if(Browser.Engine.webkit){A.document.createElement("iframe");}A.Element.prototype=(Browser.Engine.webkit)?window["[[DOMElement.prototype]]"]:{};
}return $extend(A,Window.Prototype);},afterImplement:function(B,A){window[B]=Window.Prototype[B]=A;}});Window.Prototype={$family:{name:"window"}};new Window(window);
var Document=new Native({name:"Document",legacy:(Browser.Engine.trident)?null:window.Document,initialize:function(A){$uid(A);A.head=A.getElementsByTagName("head")[0];
A.html=A.getElementsByTagName("html")[0];A.window=A.defaultView||A.parentWindow;if(Browser.Engine.trident4){$try(function(){A.execCommand("BackgroundImageCache",false,true);
});}return $extend(A,Document.Prototype);},afterImplement:function(B,A){document[B]=Document.Prototype[B]=A;}});Document.Prototype={$family:{name:"document"}};
new Document(document);Array.implement({every:function(C,D){for(var B=0,A=this.length;B<A;B++){if(!C.call(D,this[B],B,this)){return false;}}return true;
},filter:function(D,E){var C=[];for(var B=0,A=this.length;B<A;B++){if(D.call(E,this[B],B,this)){C.push(this[B]);}}return C;},clean:function(){return this.filter($defined);
},indexOf:function(C,D){var A=this.length;for(var B=(D<0)?Math.max(0,A+D):D||0;B<A;B++){if(this[B]===C){return B;}}return -1;},map:function(D,E){var C=[];
for(var B=0,A=this.length;B<A;B++){C[B]=D.call(E,this[B],B,this);}return C;},some:function(C,D){for(var B=0,A=this.length;B<A;B++){if(C.call(D,this[B],B,this)){return true;
}}return false;},associate:function(C){var D={},B=Math.min(this.length,C.length);for(var A=0;A<B;A++){D[C[A]]=this[A];}return D;},link:function(C){var A={};
for(var E=0,B=this.length;E<B;E++){for(var D in C){if(C[D](this[E])){A[D]=this[E];delete C[D];break;}}}return A;},contains:function(A,B){return this.indexOf(A,B)!=-1;
},extend:function(C){for(var B=0,A=C.length;B<A;B++){this.push(C[B]);}return this;},getLast:function(){return(this.length)?this[this.length-1]:null;},getRandom:function(){return(this.length)?this[$random(0,this.length-1)]:null;
},include:function(A){if(!this.contains(A)){this.push(A);}return this;},combine:function(C){for(var B=0,A=C.length;B<A;B++){this.include(C[B]);}return this;
},erase:function(B){for(var A=this.length;A--;A){if(this[A]===B){this.splice(A,1);}}return this;},empty:function(){this.length=0;return this;},flatten:function(){var D=[];
for(var B=0,A=this.length;B<A;B++){var C=$type(this[B]);if(!C){continue;}D=D.concat((C=="array"||C=="collection"||C=="arguments")?Array.flatten(this[B]):this[B]);
}return D;},hexToRgb:function(B){if(this.length!=3){return null;}var A=this.map(function(C){if(C.length==1){C+=C;}return C.toInt(16);});return(B)?A:"rgb("+A+")";
},rgbToHex:function(D){if(this.length<3){return null;}if(this.length==4&&this[3]==0&&!D){return"transparent";}var B=[];for(var A=0;A<3;A++){var C=(this[A]-0).toString(16);
B.push((C.length==1)?"0"+C:C);}return(D)?B:"#"+B.join("");}});Function.implement({extend:function(A){for(var B in A){this[B]=A[B];}return this;},create:function(B){var A=this;
B=B||{};return function(D){var C=B.arguments;C=(C!=undefined)?$splat(C):Array.slice(arguments,(B.event)?1:0);if(B.event){C=[D||window.event].extend(C);
}var E=function(){return A.apply(B.bind||null,C);};if(B.delay){return setTimeout(E,B.delay);}if(B.periodical){return setInterval(E,B.periodical);}if(B.attempt){return $try(E);
}return E();};},pass:function(A,B){return this.create({arguments:A,bind:B});},attempt:function(A,B){return this.create({arguments:A,bind:B,attempt:true})();
},bind:function(B,A){return this.create({bind:B,arguments:A});},bindWithEvent:function(B,A){return this.create({bind:B,event:true,arguments:A});},delay:function(B,C,A){return this.create({delay:B,bind:C,arguments:A})();
},periodical:function(A,C,B){return this.create({periodical:A,bind:C,arguments:B})();},run:function(A,B){return this.apply(B,$splat(A));}});Number.implement({limit:function(B,A){return Math.min(A,Math.max(B,this));
},round:function(A){A=Math.pow(10,A||0);return Math.round(this*A)/A;},times:function(B,C){for(var A=0;A<this;A++){B.call(C,A,this);}},toFloat:function(){return parseFloat(this);
},toInt:function(A){return parseInt(this,A||10);}});Number.alias("times","each");(function(B){var A={};B.each(function(C){if(!Number[C]){A[C]=function(){return Math[C].apply(null,[this].concat($A(arguments)));
};}});Number.implement(A);})(["abs","acos","asin","atan","atan2","ceil","cos","exp","floor","log","max","min","pow","sin","sqrt","tan"]);String.implement({test:function(A,B){return((typeof A=="string")?new RegExp(A,B):A).test(this);
},contains:function(A,B){return(B)?(B+this+B).indexOf(B+A+B)>-1:this.indexOf(A)>-1;},trim:function(){return this.replace(/^\s+|\s+$/g,"");},clean:function(){return this.replace(/\s+/g," ").trim();
},camelCase:function(){return this.replace(/-\D/g,function(A){return A.charAt(1).toUpperCase();});},hyphenate:function(){return this.replace(/[A-Z]/g,function(A){return("-"+A.charAt(0).toLowerCase());
});},capitalize:function(){return this.replace(/\b[a-z]/g,function(A){return A.toUpperCase();});},escapeRegExp:function(){return this.replace(/([-.*+?^${}()|[\]\/\\])/g,"\\$1");
},toInt:function(A){return parseInt(this,A||10);},toFloat:function(){return parseFloat(this);},hexToRgb:function(B){var A=this.match(/^#?(\w{1,2})(\w{1,2})(\w{1,2})$/);
return(A)?A.slice(1).hexToRgb(B):null;},rgbToHex:function(B){var A=this.match(/\d{1,3}/g);return(A)?A.rgbToHex(B):null;},stripScripts:function(B){var A="";
var C=this.replace(/<script[^>]*>([\s\S]*?)<\/script>/gi,function(){A+=arguments[1]+"\n";return"";});if(B===true){$exec(A);}else{if($type(B)=="function"){B(A,C);
}}return C;},substitute:function(A,B){return this.replace(B||(/\\?\{([^}]+)\}/g),function(D,C){if(D.charAt(0)=="\\"){return D.slice(1);}return(A[C]!=undefined)?A[C]:"";
});}});Hash.implement({has:Object.prototype.hasOwnProperty,keyOf:function(B){for(var A in this){if(this.hasOwnProperty(A)&&this[A]===B){return A;}}return null;
},hasValue:function(A){return(Hash.keyOf(this,A)!==null);},extend:function(A){Hash.each(A,function(C,B){Hash.set(this,B,C);},this);return this;},combine:function(A){Hash.each(A,function(C,B){Hash.include(this,B,C);
},this);return this;},erase:function(A){if(this.hasOwnProperty(A)){delete this[A];}return this;},get:function(A){return(this.hasOwnProperty(A))?this[A]:null;
},set:function(A,B){if(!this[A]||this.hasOwnProperty(A)){this[A]=B;}return this;},empty:function(){Hash.each(this,function(B,A){delete this[A];},this);
return this;},include:function(B,C){var A=this[B];if(A==undefined){this[B]=C;}return this;},map:function(B,C){var A=new Hash;Hash.each(this,function(E,D){A.set(D,B.call(C,E,D,this));
},this);return A;},filter:function(B,C){var A=new Hash;Hash.each(this,function(E,D){if(B.call(C,E,D,this)){A.set(D,E);}},this);return A;},every:function(B,C){for(var A in this){if(this.hasOwnProperty(A)&&!B.call(C,this[A],A)){return false;
}}return true;},some:function(B,C){for(var A in this){if(this.hasOwnProperty(A)&&B.call(C,this[A],A)){return true;}}return false;},getKeys:function(){var A=[];
Hash.each(this,function(C,B){A.push(B);});return A;},getValues:function(){var A=[];Hash.each(this,function(B){A.push(B);});return A;},toQueryString:function(A){var B=[];
Hash.each(this,function(F,E){if(A){E=A+"["+E+"]";}var D;switch($type(F)){case"object":D=Hash.toQueryString(F,E);break;case"array":var C={};F.each(function(H,G){C[G]=H;
});D=Hash.toQueryString(C,E);break;default:D=E+"="+encodeURIComponent(F);}if(F!=undefined){B.push(D);}});return B.join("&");}});Hash.alias({keyOf:"indexOf",hasValue:"contains"});
var Event=new Native({name:"Event",initialize:function(A,F){F=F||window;var K=F.document;A=A||F.event;if(A.$extended){return A;}this.$extended=true;var J=A.type;
var G=A.target||A.srcElement;while(G&&G.nodeType==3){G=G.parentNode;}if(J.test(/key/)){var B=A.which||A.keyCode;var M=Event.Keys.keyOf(B);if(J=="keydown"){var D=B-111;
if(D>0&&D<13){M="f"+D;}}M=M||String.fromCharCode(B).toLowerCase();}else{if(J.match(/(click|mouse|menu)/i)){K=(!K.compatMode||K.compatMode=="CSS1Compat")?K.html:K.body;
var I={x:A.pageX||A.clientX+K.scrollLeft,y:A.pageY||A.clientY+K.scrollTop};var C={x:(A.pageX)?A.pageX-F.pageXOffset:A.clientX,y:(A.pageY)?A.pageY-F.pageYOffset:A.clientY};
if(J.match(/DOMMouseScroll|mousewheel/)){var H=(A.wheelDelta)?A.wheelDelta/120:-(A.detail||0)/3;}var E=(A.which==3)||(A.button==2);var L=null;if(J.match(/over|out/)){switch(J){case"mouseover":L=A.relatedTarget||A.fromElement;
break;case"mouseout":L=A.relatedTarget||A.toElement;}if(!(function(){while(L&&L.nodeType==3){L=L.parentNode;}return true;}).create({attempt:Browser.Engine.gecko})()){L=false;
}}}}return $extend(this,{event:A,type:J,page:I,client:C,rightClick:E,wheel:H,relatedTarget:L,target:G,code:B,key:M,shift:A.shiftKey,control:A.ctrlKey,alt:A.altKey,meta:A.metaKey});
}});Event.Keys=new Hash({enter:13,up:38,down:40,left:37,right:39,esc:27,space:32,backspace:8,tab:9,"delete":46});Event.implement({stop:function(){return this.stopPropagation().preventDefault();
},stopPropagation:function(){if(this.event.stopPropagation){this.event.stopPropagation();}else{this.event.cancelBubble=true;}return this;},preventDefault:function(){if(this.event.preventDefault){this.event.preventDefault();
}else{this.event.returnValue=false;}return this;}});var Class=new Native({name:"Class",initialize:function(B){B=B||{};var A=function(E){for(var D in this){this[D]=$unlink(this[D]);
}for(var F in Class.Mutators){if(!this[F]){continue;}Class.Mutators[F](this,this[F]);delete this[F];}this.constructor=A;if(E===$empty){return this;}var C=(this.initialize)?this.initialize.apply(this,arguments):this;
if(this.options&&this.options.initialize){this.options.initialize.call(this);}return C;};$extend(A,this);A.constructor=Class;A.prototype=B;return A;}});
Class.implement({implement:function(){Class.Mutators.Implements(this.prototype,Array.slice(arguments));return this;}});Class.Mutators={Implements:function(A,B){$splat(B).each(function(C){$extend(A,($type(C)=="class")?new C($empty):C);
});},Extends:function(self,klass){var instance=new klass($empty);delete instance.parent;delete instance.parentOf;for(var key in instance){var current=self[key],previous=instance[key];
if(current==undefined){self[key]=previous;continue;}var ctype=$type(current),ptype=$type(previous);if(ctype!=ptype){continue;}switch(ctype){case"function":if(!arguments.callee.caller){self[key]=eval("("+String(current).replace(/\bthis\.parent\(\s*(\))?/g,function(full,close){return"arguments.callee._parent_.call(this"+(close||", ");
})+")");}self[key]._parent_=previous;break;case"object":self[key]=$merge(previous,current);}}self.parent=function(){return arguments.callee.caller._parent_.apply(this,arguments);
};self.parentOf=function(descendant){return descendant._parent_.apply(this,Array.slice(arguments,1));};}};var Chain=new Class({chain:function(){this.$chain=(this.$chain||[]).extend(arguments);
return this;},callChain:function(){return(this.$chain&&this.$chain.length)?this.$chain.shift().apply(this,arguments):false;},clearChain:function(){if(this.$chain){this.$chain.empty();
}return this;}});var Events=new Class({addEvent:function(C,B,A){C=Events.removeOn(C);if(B!=$empty){this.$events=this.$events||{};this.$events[C]=this.$events[C]||[];
this.$events[C].include(B);if(A){B.internal=true;}}return this;},addEvents:function(A){for(var B in A){this.addEvent(B,A[B]);}return this;},fireEvent:function(C,B,A){C=Events.removeOn(C);
if(!this.$events||!this.$events[C]){return this;}this.$events[C].each(function(D){D.create({bind:this,delay:A,"arguments":B})();},this);return this;},removeEvent:function(B,A){B=Events.removeOn(B);
if(!this.$events||!this.$events[B]){return this;}if(!A.internal){this.$events[B].erase(A);}return this;},removeEvents:function(C){for(var D in this.$events){if(C&&C!=D){continue;
}var B=this.$events[D];for(var A=B.length;A--;A){this.removeEvent(D,B[A]);}}return this;}});Events.removeOn=function(A){return A.replace(/^on([A-Z])/,function(B,C){return C.toLowerCase();
});};var Options=new Class({setOptions:function(){this.options=$merge.run([this.options].extend(arguments));if(!this.addEvent){return this;}for(var A in this.options){if($type(this.options[A])!="function"||!(/^on[A-Z]/).test(A)){continue;
}this.addEvent(A,this.options[A]);delete this.options[A];}return this;}});Document.implement({newElement:function(A,B){if(Browser.Engine.trident&&B){["name","type","checked"].each(function(C){if(!B[C]){return ;
}A+=" "+C+'="'+B[C]+'"';if(C!="checked"){delete B[C];}});A="<"+A+">";}return $.element(this.createElement(A)).set(B);},newTextNode:function(A){return this.createTextNode(A);
},getDocument:function(){return this;},getWindow:function(){return this.defaultView||this.parentWindow;},purge:function(){var C=this.getElementsByTagName("*");
for(var B=0,A=C.length;B<A;B++){Browser.freeMem(C[B]);}}});var Element=new Native({name:"Element",legacy:window.Element,initialize:function(A,B){var C=Element.Constructors.get(A);
if(C){return C(B);}if(typeof A=="string"){return document.newElement(A,B);}return $(A).set(B);},afterImplement:function(A,B){if(!Array[A]){Elements.implement(A,Elements.multi(A));
}Element.Prototype[A]=B;}});Element.Prototype={$family:{name:"element"}};Element.Constructors=new Hash;var IFrame=new Native({name:"IFrame",generics:false,initialize:function(){var E=Array.link(arguments,{properties:Object.type,iframe:$defined});
var C=E.properties||{};var B=$(E.iframe)||false;var D=C.onload||$empty;delete C.onload;C.id=C.name=$pick(C.id,C.name,B.id,B.name,"IFrame_"+$time());B=new Element(B||"iframe",C);
var A=function(){var F=$try(function(){return B.contentWindow.location.host;});if(F&&F==window.location.host){var H=new Window(B.contentWindow);var G=new Document(B.contentWindow.document);
$extend(H.Element.prototype,Element.Prototype);}D.call(B.contentWindow,B.contentWindow.document);};(!window.frames[C.id])?B.addListener("load",A):A();return B;
}});var Elements=new Native({initialize:function(F,B){B=$extend({ddup:true,cash:true},B);F=F||[];if(B.ddup||B.cash){var G={},E=[];for(var C=0,A=F.length;
C<A;C++){var D=$.element(F[C],!B.cash);if(B.ddup){if(G[D.uid]){continue;}G[D.uid]=true;}E.push(D);}F=E;}return(B.cash)?$extend(F,this):F;}});Elements.implement({filter:function(A,B){if(!A){return this;
}return new Elements(Array.filter(this,(typeof A=="string")?function(C){return C.match(A);}:A,B));}});Elements.multi=function(A){return function(){var B=[];
var F=true;for(var D=0,C=this.length;D<C;D++){var E=this[D][A].apply(this[D],arguments);B.push(E);if(F){F=($type(E)=="element");}}return(F)?new Elements(B):B;
};};Window.implement({$:function(B,C){if(B&&B.$family&&B.uid){return B;}var A=$type(B);return($[A])?$[A](B,C,this.document):null;},$$:function(A){if(arguments.length==1&&typeof A=="string"){return this.document.getElements(A);
}var F=[];var C=Array.flatten(arguments);for(var D=0,B=C.length;D<B;D++){var E=C[D];switch($type(E)){case"element":E=[E];break;case"string":E=this.document.getElements(E,true);
break;default:E=false;}if(E){F.extend(E);}}return new Elements(F);},getDocument:function(){return this.document;},getWindow:function(){return this;}});
$.string=function(C,B,A){C=A.getElementById(C);return(C)?$.element(C,B):null;};$.element=function(A,D){$uid(A);if(!D&&!A.$family&&!(/^object|embed$/i).test(A.tagName)){var B=Element.Prototype;
for(var C in B){A[C]=B[C];}}return A;};$.object=function(B,C,A){if(B.toElement){return $.element(B.toElement(A),C);}return null;};$.textnode=$.whitespace=$.window=$.document=$arguments(0);
Native.implement([Element,Document],{getElement:function(A,B){return $(this.getElements(A,true)[0]||null,B);},getElements:function(A,D){A=A.split(",");
var C=[];var B=(A.length>1);A.each(function(E){var F=this.getElementsByTagName(E.trim());(B)?C.extend(F):C=F;},this);return new Elements(C,{ddup:B,cash:!D});
}});Element.Storage={get:function(A){return(this[A]||(this[A]={}));}};Element.Inserters=new Hash({before:function(B,A){if(A.parentNode){A.parentNode.insertBefore(B,A);
}},after:function(B,A){if(!A.parentNode){return ;}var C=A.nextSibling;(C)?A.parentNode.insertBefore(B,C):A.parentNode.appendChild(B);},bottom:function(B,A){A.appendChild(B);
},top:function(B,A){var C=A.firstChild;(C)?A.insertBefore(B,C):A.appendChild(B);}});Element.Inserters.inside=Element.Inserters.bottom;Element.Inserters.each(function(C,B){var A=B.capitalize();
Element.implement("inject"+A,function(D){C(this,$(D,true));return this;});Element.implement("grab"+A,function(D){C($(D,true),this);return this;});});Element.implement({getDocument:function(){return this.ownerDocument;
},getWindow:function(){return this.ownerDocument.getWindow();},getElementById:function(D,C){var B=this.ownerDocument.getElementById(D);if(!B){return null;
}for(var A=B.parentNode;A!=this;A=A.parentNode){if(!A){return null;}}return $.element(B,C);},set:function(D,B){switch($type(D)){case"object":for(var C in D){this.set(C,D[C]);
}break;case"string":var A=Element.Properties.get(D);(A&&A.set)?A.set.apply(this,Array.slice(arguments,1)):this.setProperty(D,B);}return this;},get:function(B){var A=Element.Properties.get(B);
return(A&&A.get)?A.get.apply(this,Array.slice(arguments,1)):this.getProperty(B);},erase:function(B){var A=Element.Properties.get(B);(A&&A.erase)?A.erase.apply(this,Array.slice(arguments,1)):this.removeProperty(B);
return this;},match:function(A){return(!A||Element.get(this,"tag")==A);},inject:function(B,A){Element.Inserters.get(A||"bottom")(this,$(B,true));return this;
},wraps:function(B,A){B=$(B,true);return this.replaces(B).grab(B,A);},grab:function(B,A){Element.Inserters.get(A||"bottom")($(B,true),this);return this;
},appendText:function(B,A){return this.grab(this.getDocument().newTextNode(B),A);},adopt:function(){Array.flatten(arguments).each(function(A){A=$(A,true);
if(A){this.appendChild(A);}},this);return this;},dispose:function(){return(this.parentNode)?this.parentNode.removeChild(this):this;},clone:function(D,C){switch($type(this)){case"element":var H={};
for(var G=0,E=this.attributes.length;G<E;G++){var B=this.attributes[G],L=B.nodeName.toLowerCase();if(Browser.Engine.trident&&(/input/i).test(this.tagName)&&(/width|height/).test(L)){continue;
}var K=(L=="style"&&this.style)?this.style.cssText:B.nodeValue;if(!$chk(K)||L=="uid"||(L=="id"&&!C)){continue;}if(K!="inherit"&&["string","number"].contains($type(K))){H[L]=K;
}}var J=new Element(this.nodeName.toLowerCase(),H);if(D!==false){for(var I=0,F=this.childNodes.length;I<F;I++){var A=Element.clone(this.childNodes[I],true,C);
if(A){J.grab(A);}}}return J;case"textnode":return document.newTextNode(this.nodeValue);}return null;},replaces:function(A){A=$(A,true);A.parentNode.replaceChild(this,A);
return this;},hasClass:function(A){return this.className.contains(A," ");},addClass:function(A){if(!this.hasClass(A)){this.className=(this.className+" "+A).clean();
}return this;},removeClass:function(A){this.className=this.className.replace(new RegExp("(^|\\s)"+A+"(?:\\s|$)"),"$1").clean();return this;},toggleClass:function(A){return this.hasClass(A)?this.removeClass(A):this.addClass(A);
},getComputedStyle:function(B){if(this.currentStyle){return this.currentStyle[B.camelCase()];}var A=this.getWindow().getComputedStyle(this,null);return(A)?A.getPropertyValue([B.hyphenate()]):null;
},empty:function(){$A(this.childNodes).each(function(A){Browser.freeMem(A);Element.empty(A);Element.dispose(A);},this);return this;},destroy:function(){Browser.freeMem(this.empty().dispose());
return null;},getSelected:function(){var opties=this.getElements("option");return new Elements(opties.filter(function(A){return A.selected;}));},toQueryString:function(){var A=[];
this.getElements("input, select, textarea").each(function(B){if(!B.name||B.disabled){return ;}var C=(B.tagName.toLowerCase()=="select")?Element.getSelected(B).map(function(D){return D.value;
}):((B.type=="radio"||B.type=="checkbox")&&!B.checked)?null:B.value;$splat(C).each(function(D){if(D){A.push(B.name+"="+encodeURIComponent(D));}});});return A.join("&");
},getProperty:function(C){var B=Element.Attributes,A=B.Props[C];var D=(A)?this[A]:this.getAttribute(C,2);return(B.Bools[C])?!!D:(A)?D:D||null;},getProperties:function(){var A=$A(arguments);
return A.map(function(B){return this.getProperty(B);},this).associate(A);},setProperty:function(D,E){var C=Element.Attributes,B=C.Props[D],A=$defined(E);
if(B&&C.Bools[D]){E=(E||!A)?true:false;}else{if(!A){return this.removeProperty(D);}}(B)?this[B]=E:this.setAttribute(D,E);return this;},setProperties:function(A){for(var B in A){this.setProperty(B,A[B]);
}return this;},removeProperty:function(D){var C=Element.Attributes,B=C.Props[D],A=(B&&C.Bools[D]);(B)?this[B]=(A)?false:"":this.removeAttribute(D);return this;
},removeProperties:function(){Array.each(arguments,this.removeProperty,this);return this;}});(function(){var A=function(D,B,I,C,F,H){var E=D[I||B];var G=[];
while(E){if(E.nodeType==1&&(!C||Element.match(E,C))){G.push(E);if(!F){break;}}E=E[B];}return(F)?new Elements(G,{ddup:false,cash:!H}):$(G[0],H);};Element.implement({getPrevious:function(B,C){return A(this,"previousSibling",null,B,false,C);
},getAllPrevious:function(B,C){return A(this,"previousSibling",null,B,true,C);},getNext:function(B,C){return A(this,"nextSibling",null,B,false,C);},getAllNext:function(B,C){return A(this,"nextSibling",null,B,true,C);
},getFirst:function(B,C){return A(this,"nextSibling","firstChild",B,false,C);},getLast:function(B,C){return A(this,"previousSibling","lastChild",B,false,C);
},getParent:function(B,C){return A(this,"parentNode",null,B,false,C);},getParents:function(B,C){return A(this,"parentNode",null,B,true,C);},getChildren:function(B,C){return A(this,"nextSibling","firstChild",B,true,C);
},hasChild:function(B){B=$(B,true);return(!!B&&$A(this.getElementsByTagName(B.tagName)).contains(B));}});})();Element.Properties=new Hash;Element.Properties.style={set:function(A){this.style.cssText=A;
},get:function(){return this.style.cssText;},erase:function(){this.style.cssText="";}};Element.Properties.tag={get:function(){return this.tagName.toLowerCase();
}};Element.Properties.href={get:function(){return(!this.href)?null:this.href.replace(new RegExp("^"+document.location.protocol+"//"+document.location.host),"");
}};Element.Properties.html={set:function(){return this.innerHTML=Array.flatten(arguments).join("");}};Native.implement([Element,Window,Document],{addListener:function(B,A){if(this.addEventListener){this.addEventListener(B,A,false);
}else{this.attachEvent("on"+B,A);}return this;},removeListener:function(B,A){if(this.removeEventListener){this.removeEventListener(B,A,false);}else{this.detachEvent("on"+B,A);
}return this;},retrieve:function(B,A){var D=Element.Storage.get(this.uid);var C=D[B];if($defined(A)&&!$defined(C)){C=D[B]=A;}return $pick(C);},store:function(B,A){var C=Element.Storage.get(this.uid);
C[B]=A;return this;},eliminate:function(A){var B=Element.Storage.get(this.uid);delete B[A];return this;}});Element.Attributes=new Hash({Props:{html:"innerHTML","class":"className","for":"htmlFor",text:(Browser.Engine.trident)?"innerText":"textContent"},Bools:["compact","nowrap","ismap","declare","noshade","checked","disabled","readonly","multiple","selected","noresize","defer"],Camels:["value","accessKey","cellPadding","cellSpacing","colSpan","frameBorder","maxLength","readOnly","rowSpan","tabIndex","useMap"]});
Browser.freeMem=function(A){if(!A){return ;}if(Browser.Engine.trident&&(/object/i).test(A.tagName)){for(var B in A){if(typeof A[B]=="function"){A[B]=$empty;
}}Element.dispose(A);}if(A.uid&&A.removeEvents){A.removeEvents();}};(function(B){var C=B.Bools,A=B.Camels;B.Bools=C=C.associate(C);Hash.extend(Hash.combine(B.Props,C),A.associate(A.map(function(D){return D.toLowerCase();
})));B.erase("Camels");})(Element.Attributes);window.addListener("unload",function(){window.removeListener("unload",arguments.callee);document.purge();
if(Browser.Engine.trident){CollectGarbage();}});Element.Properties.events={set:function(A){this.addEvents(A);}};Native.implement([Element,Window,Document],{addEvent:function(E,G){var H=this.retrieve("events",{});
H[E]=H[E]||{keys:[],values:[]};if(H[E].keys.contains(G)){return this;}H[E].keys.push(G);var F=E,A=Element.Events.get(E),C=G,I=this;if(A){if(A.onAdd){A.onAdd.call(this,G);
}if(A.condition){C=function(J){if(A.condition.call(this,J)){return G.call(this,J);}return false;};}F=A.base||F;}var D=function(){return G.call(I);};var B=Element.NativeEvents[F]||0;
if(B){if(B==2){D=function(J){J=new Event(J,I.getWindow());if(C.call(I,J)===false){J.stop();}};}this.addListener(F,D);}H[E].values.push(D);return this;},removeEvent:function(D,C){var B=this.retrieve("events");
if(!B||!B[D]){return this;}var G=B[D].keys.indexOf(C);if(G==-1){return this;}var A=B[D].keys.splice(G,1)[0];var F=B[D].values.splice(G,1)[0];var E=Element.Events.get(D);
if(E){if(E.onRemove){E.onRemove.call(this,C);}D=E.base||D;}return(Element.NativeEvents[D])?this.removeListener(D,F):this;},addEvents:function(A){for(var B in A){this.addEvent(B,A[B]);
}return this;},removeEvents:function(B){var A=this.retrieve("events");if(!A){return this;}if(!B){for(var C in A){this.removeEvents(C);}A=null;}else{if(A[B]){while(A[B].keys[0]){this.removeEvent(B,A[B].keys[0]);
}A[B]=null;}}return this;},fireEvent:function(D,B,A){var C=this.retrieve("events");if(!C||!C[D]){return this;}C[D].keys.each(function(E){E.create({bind:this,delay:A,"arguments":B})();
},this);return this;},cloneEvents:function(D,A){D=$(D);var C=D.retrieve("events");if(!C){return this;}if(!A){for(var B in C){this.cloneEvents(D,B);}}else{if(C[A]){C[A].keys.each(function(E){this.addEvent(A,E);
},this);}}return this;}});Element.NativeEvents={click:2,dblclick:2,mouseup:2,mousedown:2,contextmenu:2,mousewheel:2,DOMMouseScroll:2,mouseover:2,mouseout:2,mousemove:2,selectstart:2,selectend:2,keydown:2,keypress:2,keyup:2,focus:2,blur:2,change:2,reset:2,select:2,submit:2,load:1,unload:1,beforeunload:2,resize:1,move:1,DOMContentLoaded:1,readystatechange:1,error:1,abort:1,scroll:1};
(function(){var A=function(B){var C=B.relatedTarget;if(C==undefined){return true;}if(C===false){return false;}return($type(this)!="document"&&C!=this&&C.prefix!="xul"&&!this.hasChild(C));
};Element.Events=new Hash({mouseenter:{base:"mouseover",condition:A},mouseleave:{base:"mouseout",condition:A},mousewheel:{base:(Browser.Engine.gecko)?"DOMMouseScroll":"mousewheel"}});
})();Element.Properties.styles={set:function(A){this.setStyles(A);}};Element.Properties.opacity={set:function(A,B){if(!B){if(A==0){if(this.style.visibility!="hidden"){this.style.visibility="hidden";
}}else{if(this.style.visibility!="visible"){this.style.visibility="visible";}}}if(!this.currentStyle||!this.currentStyle.hasLayout){this.style.zoom=1;}if(Browser.Engine.trident){this.style.filter=(A==1)?"":"alpha(opacity="+A*100+")";
}this.style.opacity=A;this.store("opacity",A);},get:function(){return this.retrieve("opacity",1);}};Element.implement({setOpacity:function(A){return this.set("opacity",A,true);
},getOpacity:function(){return this.get("opacity");},setStyle:function(B,A){switch(B){case"opacity":return this.set("opacity",parseFloat(A));case"float":B=(Browser.Engine.trident)?"styleFloat":"cssFloat";
}B=B.camelCase();if($type(A)!="string"){var C=(Element.Styles.get(B)||"@").split(" ");A=$splat(A).map(function(E,D){if(!C[D]){return"";}return($type(E)=="number")?C[D].replace("@",Math.round(E)):E;
}).join(" ");}else{if(A==String(Number(A))){A=Math.round(A);}}this.style[B]=A;return this;},getStyle:function(G){switch(G){case"opacity":return this.get("opacity");
case"float":G=(Browser.Engine.trident)?"styleFloat":"cssFloat";}G=G.camelCase();var A=this.style[G];if(!$chk(A)){A=[];for(var F in Element.ShortStyles){if(G!=F){continue;
}for(var E in Element.ShortStyles[F]){A.push(this.getStyle(E));}return A.join(" ");}A=this.getComputedStyle(G);}if(A){A=String(A);var C=A.match(/rgba?\([\d\s,]+\)/);
if(C){A=A.replace(C[0],C[0].rgbToHex());}}if(Browser.Engine.presto||(Browser.Engine.trident&&!$chk(parseInt(A)))){if(G.test(/^(height|width)$/)){var B=(G=="width")?["left","right"]:["top","bottom"],D=0;
B.each(function(H){D+=this.getStyle("border-"+H+"-width").toInt()+this.getStyle("padding-"+H).toInt();},this);return this["offset"+G.capitalize()]-D+"px";
}if(Browser.Engine.presto&&String(A).test("px")){return A;}if(G.test(/(border(.+)Width|margin|padding)/)){return"0px";}}return A;},setStyles:function(B){for(var A in B){this.setStyle(A,B[A]);
}return this;},getStyles:function(){var A={};Array.each(arguments,function(B){A[B]=this.getStyle(B);},this);return A;}});Element.Styles=new Hash({left:"@px",top:"@px",bottom:"@px",right:"@px",width:"@px",height:"@px",maxWidth:"@px",maxHeight:"@px",minWidth:"@px",minHeight:"@px",backgroundColor:"rgb(@, @, @)",backgroundPosition:"@px @px",color:"rgb(@, @, @)",fontSize:"@px",letterSpacing:"@px",lineHeight:"@px",clip:"rect(@px @px @px @px)",margin:"@px @px @px @px",padding:"@px @px @px @px",border:"@px @ rgb(@, @, @) @px @ rgb(@, @, @) @px @ rgb(@, @, @)",borderWidth:"@px @px @px @px",borderStyle:"@ @ @ @",borderColor:"rgb(@, @, @) rgb(@, @, @) rgb(@, @, @) rgb(@, @, @)",zIndex:"@",zoom:"@",fontWeight:"@",textIndent:"@px",opacity:"@"});
Element.ShortStyles={margin:{},padding:{},border:{},borderWidth:{},borderStyle:{},borderColor:{}};["Top","Right","Bottom","Left"].each(function(G){var F=Element.ShortStyles;
var B=Element.Styles;["margin","padding"].each(function(H){var I=H+G;F[H][I]=B[I]="@px";});var E="border"+G;F.border[E]=B[E]="@px @ rgb(@, @, @)";var D=E+"Width",A=E+"Style",C=E+"Color";
F[E]={};F.borderWidth[D]=F[E][D]=B[D]="@px";F.borderStyle[A]=F[E][A]=B[A]="@";F.borderColor[C]=F[E][C]=B[C]="rgb(@, @, @)";});(function(){Element.implement({scrollTo:function(H,I){if(B(this)){this.getWindow().scrollTo(H,I);
}else{this.scrollLeft=H;this.scrollTop=I;}return this;},getSize:function(){if(B(this)){return this.getWindow().getSize();}return{x:this.offsetWidth,y:this.offsetHeight};
},getScrollSize:function(){if(B(this)){return this.getWindow().getScrollSize();}return{x:this.scrollWidth,y:this.scrollHeight};},getScroll:function(){if(B(this)){return this.getWindow().getScroll();
}return{x:this.scrollLeft,y:this.scrollTop};},getScrolls:function(){var I=this,H={x:0,y:0};while(I&&!B(I)){H.x+=I.scrollLeft;H.y+=I.scrollTop;I=I.parentNode;
}return H;},getOffsetParent:function(){var H=this;if(B(H)){return null;}if(!Browser.Engine.trident){return H.offsetParent;}while((H=H.parentNode)&&!B(H)){if(D(H,"position")!="static"){return H;
}}return null;},getOffsets:function(){var I=this,H={x:0,y:0};if(B(this)){return H;}while(I&&!B(I)){H.x+=I.offsetLeft;H.y+=I.offsetTop;if(Browser.Engine.gecko){if(!F(I)){H.x+=C(I);
H.y+=G(I);}var J=I.parentNode;if(J&&D(J,"overflow")!="visible"){H.x+=C(J);H.y+=G(J);}}else{if(I!=this&&(Browser.Engine.trident||Browser.Engine.webkit)){H.x+=C(I);
H.y+=G(I);}}I=I.offsetParent;if(Browser.Engine.trident){while(I&&!I.currentStyle.hasLayout){I=I.offsetParent;}}}if(Browser.Engine.gecko&&!F(this)){H.x-=C(this);
H.y-=G(this);}return H;},getPosition:function(K){if(B(this)){return{x:0,y:0};}var L=this.getOffsets(),I=this.getScrolls();var H={x:L.x-I.x,y:L.y-I.y};var J=(K&&(K=$(K)))?K.getPosition():{x:0,y:0};
return{x:H.x-J.x,y:H.y-J.y};},getCoordinates:function(J){if(B(this)){return this.getWindow().getCoordinates();}var H=this.getPosition(J),I=this.getSize();
var K={left:H.x,top:H.y,width:I.x,height:I.y};K.right=K.left+K.width;K.bottom=K.top+K.height;return K;},computePosition:function(H){return{left:H.x-E(this,"margin-left"),top:H.y-E(this,"margin-top")};
},position:function(H){return this.setStyles(this.computePosition(H));}});Native.implement([Document,Window],{getSize:function(){var I=this.getWindow();
if(Browser.Engine.presto||Browser.Engine.webkit){return{x:I.innerWidth,y:I.innerHeight};}var H=A(this);return{x:H.clientWidth,y:H.clientHeight};},getScroll:function(){var I=this.getWindow();
var H=A(this);return{x:I.pageXOffset||H.scrollLeft,y:I.pageYOffset||H.scrollTop};},getScrollSize:function(){var I=A(this);var H=this.getSize();return{x:Math.max(I.scrollWidth,H.x),y:Math.max(I.scrollHeight,H.y)};
},getPosition:function(){return{x:0,y:0};},getCoordinates:function(){var H=this.getSize();return{top:0,left:0,bottom:H.y,right:H.x,height:H.y,width:H.x};
}});var D=Element.getComputedStyle;function E(H,I){return D(H,I).toInt()||0;}function F(H){return D(H,"-moz-box-sizing")=="border-box";}function G(H){return E(H,"border-top-width");
}function C(H){return E(H,"border-left-width");}function B(H){return(/^(?:body|html)$/i).test(H.tagName);}function A(H){var I=H.getDocument();return(!I.compatMode||I.compatMode=="CSS1Compat")?I.html:I.body;
}})();Native.implement([Window,Document,Element],{getHeight:function(){return this.getSize().y;},getWidth:function(){return this.getSize().x;},getScrollTop:function(){return this.getScroll().y;
},getScrollLeft:function(){return this.getScroll().x;},getScrollHeight:function(){return this.getScrollSize().y;},getScrollWidth:function(){return this.getScrollSize().x;
},getTop:function(){return this.getPosition().y;},getLeft:function(){return this.getPosition().x;}});Native.implement([Document,Element],{getElements:function(H,G){H=H.split(",");
var C,E={};for(var D=0,B=H.length;D<B;D++){var A=H[D],F=Selectors.Utils.search(this,A,E);if(D!=0&&F.item){F=$A(F);}C=(D==0)?F:(C.item)?$A(C).concat(F):C.concat(F);
}return new Elements(C,{ddup:(H.length>1),cash:!G});}});Element.implement({match:function(B){if(!B){return true;}var D=Selectors.Utils.parseTagAndID(B);
var A=D[0],E=D[1];if(!Selectors.Filters.byID(this,E)||!Selectors.Filters.byTag(this,A)){return false;}var C=Selectors.Utils.parseSelector(B);return(C)?Selectors.Utils.filter(this,C,{}):true;
}});var Selectors={Cache:{nth:{},parsed:{}}};Selectors.RegExps={id:(/#([\w-]+)/),tag:(/^(\w+|\*)/),quick:(/^(\w+|\*)$/),splitter:(/\s*([+>~\s])\s*([a-zA-Z#.*:\[])/g),combined:(/\.([\w-]+)|\[(\w+)(?:([!*^$~|]?=)["']?(.*?)["']?)?\]|:([\w-]+)(?:\(["']?(.*?)?["']?\)|$)/g)};
Selectors.Utils={chk:function(B,C){if(!C){return true;}var A=$uid(B);if(!C[A]){return C[A]=true;}return false;},parseNthArgument:function(F){if(Selectors.Cache.nth[F]){return Selectors.Cache.nth[F];
}var C=F.match(/^([+-]?\d*)?([a-z]+)?([+-]?\d*)?$/);if(!C){return false;}var E=parseInt(C[1]);var B=(E||E===0)?E:1;var D=C[2]||false;var A=parseInt(C[3])||0;
if(B!=0){A--;while(A<1){A+=B;}while(A>=B){A-=B;}}else{B=A;D="index";}switch(D){case"n":C={a:B,b:A,special:"n"};break;case"odd":C={a:2,b:0,special:"n"};
break;case"even":C={a:2,b:1,special:"n"};break;case"first":C={a:0,special:"index"};break;case"last":C={special:"last-child"};break;case"only":C={special:"only-child"};
break;default:C={a:(B-1),special:"index"};}return Selectors.Cache.nth[F]=C;},parseSelector:function(E){if(Selectors.Cache.parsed[E]){return Selectors.Cache.parsed[E];
}var D,H={classes:[],pseudos:[],attributes:[]};while((D=Selectors.RegExps.combined.exec(E))){var I=D[1],G=D[2],F=D[3],B=D[4],C=D[5],J=D[6];if(I){H.classes.push(I);
}else{if(C){var A=Selectors.Pseudo.get(C);if(A){H.pseudos.push({parser:A,argument:J});}else{H.attributes.push({name:C,operator:"=",value:J});}}else{if(G){H.attributes.push({name:G,operator:F,value:B});
}}}}if(!H.classes.length){delete H.classes;}if(!H.attributes.length){delete H.attributes;}if(!H.pseudos.length){delete H.pseudos;}if(!H.classes&&!H.attributes&&!H.pseudos){H=null;
}return Selectors.Cache.parsed[E]=H;},parseTagAndID:function(B){var A=B.match(Selectors.RegExps.tag);var C=B.match(Selectors.RegExps.id);return[(A)?A[1]:"*",(C)?C[1]:false];
},filter:function(F,C,E){var D;if(C.classes){for(D=C.classes.length;D--;D){var G=C.classes[D];if(!Selectors.Filters.byClass(F,G)){return false;}}}if(C.attributes){for(D=C.attributes.length;
D--;D){var B=C.attributes[D];if(!Selectors.Filters.byAttribute(F,B.name,B.operator,B.value)){return false;}}}if(C.pseudos){for(D=C.pseudos.length;D--;D){var A=C.pseudos[D];
if(!Selectors.Filters.byPseudo(F,A.parser,A.argument,E)){return false;}}}return true;},getByTagAndID:function(B,A,D){if(D){var C=(B.getElementById)?B.getElementById(D,true):Element.getElementById(B,D,true);
return(C&&Selectors.Filters.byTag(C,A))?[C]:[];}else{return B.getElementsByTagName(A);}},search:function(J,I,O){var B=[];var C=I.trim().replace(Selectors.RegExps.splitter,function(Z,Y,X){B.push(Y);
return":)"+X;}).split(":)");var K,F,E,V;for(var U=0,Q=C.length;U<Q;U++){var T=C[U];if(U==0&&Selectors.RegExps.quick.test(T)){K=J.getElementsByTagName(T);
continue;}var A=B[U-1];var L=Selectors.Utils.parseTagAndID(T);var W=L[0],M=L[1];if(U==0){K=Selectors.Utils.getByTagAndID(J,W,M);}else{var D={},H=[];for(var S=0,R=K.length;
S<R;S++){H=Selectors.Getters[A](H,K[S],W,M,D);}K=H;}var G=Selectors.Utils.parseSelector(T);if(G){E=[];for(var P=0,N=K.length;P<N;P++){V=K[P];if(Selectors.Utils.filter(V,G,O)){E.push(V);
}}K=E;}}return K;}};Selectors.Getters={" ":function(H,G,I,A,E){var D=Selectors.Utils.getByTagAndID(G,I,A);for(var C=0,B=D.length;C<B;C++){var F=D[C];if(Selectors.Utils.chk(F,E)){H.push(F);
}}return H;},">":function(H,G,I,A,F){var C=Selectors.Utils.getByTagAndID(G,I,A);for(var E=0,D=C.length;E<D;E++){var B=C[E];if(B.parentNode==G&&Selectors.Utils.chk(B,F)){H.push(B);
}}return H;},"+":function(C,B,A,E,D){while((B=B.nextSibling)){if(B.nodeType==1){if(Selectors.Utils.chk(B,D)&&Selectors.Filters.byTag(B,A)&&Selectors.Filters.byID(B,E)){C.push(B);
}break;}}return C;},"~":function(C,B,A,E,D){while((B=B.nextSibling)){if(B.nodeType==1){if(!Selectors.Utils.chk(B,D)){break;}if(Selectors.Filters.byTag(B,A)&&Selectors.Filters.byID(B,E)){C.push(B);
}}}return C;}};Selectors.Filters={byTag:function(B,A){return(A=="*"||(B.tagName&&B.tagName.toLowerCase()==A));},byID:function(A,B){return(!B||(A.id&&A.id==B));
},byClass:function(B,A){return(B.className&&B.className.contains(A," "));},byPseudo:function(A,D,C,B){return D.call(A,C,B);},byAttribute:function(C,D,B,E){var A=Element.prototype.getProperty.call(C,D);
if(!A){return false;}if(!B||E==undefined){return true;}switch(B){case"=":return(A==E);case"*=":return(A.contains(E));case"^=":return(A.substr(0,E.length)==E);
case"$=":return(A.substr(A.length-E.length)==E);case"!=":return(A!=E);case"~=":return A.contains(E," ");case"|=":return A.contains(E,"-");}return false;
}};Selectors.Pseudo=new Hash({empty:function(){return !(this.innerText||this.textContent||"").length;},not:function(A){return !Element.match(this,A);},contains:function(A){return(this.innerText||this.textContent||"").contains(A);
},"first-child":function(){return Selectors.Pseudo.index.call(this,0);},"last-child":function(){var A=this;while((A=A.nextSibling)){if(A.nodeType==1){return false;
}}return true;},"only-child":function(){var B=this;while((B=B.previousSibling)){if(B.nodeType==1){return false;}}var A=this;while((A=A.nextSibling)){if(A.nodeType==1){return false;
}}return true;},"nth-child":function(G,E){G=(G==undefined)?"n":G;var C=Selectors.Utils.parseNthArgument(G);if(C.special!="n"){return Selectors.Pseudo[C.special].call(this,C.a,E);
}var F=0;E.positions=E.positions||{};var D=$uid(this);if(!E.positions[D]){var B=this;while((B=B.previousSibling)){if(B.nodeType!=1){continue;}F++;var A=E.positions[$uid(B)];
if(A!=undefined){F=A+F;break;}}E.positions[D]=F;}return(E.positions[D]%C.a==C.b);},index:function(A){var B=this,C=0;while((B=B.previousSibling)){if(B.nodeType==1&&++C>A){return false;
}}return(C==A);},even:function(B,A){return Selectors.Pseudo["nth-child"].call(this,"2n+1",A);},odd:function(B,A){return Selectors.Pseudo["nth-child"].call(this,"2n",A);
}});Element.Events.domready={onAdd:function(A){if(Browser.loaded){A.call(this);}}};(function(){var B=function(){if(Browser.loaded){return ;}Browser.loaded=true;
window.fireEvent("domready");document.fireEvent("domready");};switch(Browser.Engine.name){case"webkit":(function(){(["loaded","complete"].contains(document.readyState))?B():arguments.callee.delay(50);
})();break;case"trident":var A=document.createElement("div");(function(){($try(function(){A.doScroll("left");return $(A).inject(document.body).set("html","temp").dispose();
}))?B():arguments.callee.delay(50);})();break;default:window.addEvent("load",B);document.addEvent("DOMContentLoaded",B);}})();var JSON=new Hash({encode:function(B){switch($type(B)){case"string":return'"'+B.replace(/[\x00-\x1f\\"]/g,JSON.$replaceChars)+'"';
case"array":return"["+String(B.map(JSON.encode).filter($defined))+"]";case"object":case"hash":var A=[];Hash.each(B,function(E,D){var C=JSON.encode(E);if(C){A.push(JSON.encode(D)+":"+C);
}});return"{"+A+"}";case"number":case"boolean":return String(B);case false:return"null";}return null;},$specialChars:{"\b":"\\b","\t":"\\t","\n":"\\n","\f":"\\f","\r":"\\r",'"':'\\"',"\\":"\\\\"},$replaceChars:function(A){return JSON.$specialChars[A]||"\\u00"+Math.floor(A.charCodeAt()/16).toString(16)+(A.charCodeAt()%16).toString(16);
},decode:function(string,secure){if($type(string)!="string"||!string.length){return null;}if(secure&&!(/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(string.replace(/\\./g,"@").replace(/"[^"\\\n\r]*"/g,""))){return null;
}return eval("("+string+")");}});Native.implement([Hash,Array,String,Number],{toJSON:function(){return JSON.encode(this);}});var Cookie=new Class({Implements:Options,options:{path:false,domain:false,duration:false,secure:false,document:document},initialize:function(B,A){this.key=B;
this.setOptions(A);},write:function(B){B=encodeURIComponent(B);if(this.options.domain){B+="; domain="+this.options.domain;}if(this.options.path){B+="; path="+this.options.path;
}if(this.options.duration){var A=new Date();A.setTime(A.getTime()+this.options.duration*24*60*60*1000);B+="; expires="+A.toGMTString();}if(this.options.secure){B+="; secure";
}this.options.document.cookie=this.key+"="+B;return this;},read:function(){var A=this.options.document.cookie.match("(?:^|;)\\s*"+this.key.escapeRegExp()+"=([^;]*)");
return(A)?decodeURIComponent(A[1]):null;},dispose:function(){new Cookie(this.key,$merge(this.options,{duration:-1})).write("");return this;}});Cookie.write=function(B,C,A){return new Cookie(B,A).write(C);
};Cookie.read=function(A){return new Cookie(A).read();};Cookie.dispose=function(B,A){return new Cookie(B,A).dispose();};var Swiff=new Class({Implements:[Options],options:{id:null,height:1,width:1,container:null,properties:{},params:{quality:"high",allowScriptAccess:"always",wMode:"transparent",swLiveConnect:true},callBacks:{},vars:{}},toElement:function(){return this.object;
},initialize:function(L,M){this.instance="Swiff_"+$time();this.setOptions(M);M=this.options;var B=this.id=M.id||this.instance;var A=$(M.container);Swiff.CallBacks[this.instance]={};
var E=M.params,G=M.vars,F=M.callBacks;var H=$extend({height:M.height,width:M.width},M.properties);var K=this;for(var D in F){Swiff.CallBacks[this.instance][D]=(function(N){return function(){return N.apply(K.object,arguments);
};})(F[D]);G[D]="Swiff.CallBacks."+this.instance+"."+D;}E.flashVars=Hash.toQueryString(G);if(Browser.Engine.trident){H.classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000";
E.movie=L;}else{H.type="application/x-shockwave-flash";H.data=L;}var J='<object id="'+B+'"';for(var I in H){J+=" "+I+'="'+H[I]+'"';}J+=">";for(var C in E){if(E[C]){J+='<param name="'+C+'" value="'+E[C]+'" />';
}}J+="</object>";this.object=((A)?A.empty():new Element("div")).set("html",J).firstChild;},replaces:function(A){A=$(A,true);A.parentNode.replaceChild(this.toElement(),A);
return this;},inject:function(A){$(A,true).appendChild(this.toElement());return this;},remote:function(){return Swiff.remote.apply(Swiff,[this.toElement()].extend(arguments));
}});Swiff.CallBacks={};Swiff.remote=function(obj,fn){var rs=obj.CallFunction('<invoke name="'+fn+'" returntype="javascript">'+__flash__argumentsToXML(arguments,2)+"</invoke>");
return eval(rs);};var Fx=new Class({Implements:[Chain,Events,Options],options:{fps:50,unit:false,duration:500,link:"ignore",transition:function(A){return -(Math.cos(Math.PI*A)-1)/2;
}},initialize:function(A){this.subject=this.subject||this;this.setOptions(A);this.options.duration=Fx.Durations[this.options.duration]||this.options.duration.toInt();
var B=this.options.wait;if(B===false){this.options.link="cancel";}},step:function(){var A=$time();if(A<this.time+this.options.duration){var B=this.options.transition((A-this.time)/this.options.duration);
this.set(this.compute(this.from,this.to,B));}else{this.set(this.compute(this.from,this.to,1));this.complete();}},set:function(A){return A;},compute:function(C,B,A){return Fx.compute(C,B,A);
},check:function(A){if(!this.timer){return true;}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(A.bind(this,Array.slice(arguments,1)));
return false;}return false;},start:function(B,A){if(!this.check(arguments.callee,B,A)){return this;}this.from=B;this.to=A;this.time=0;this.startTimer();
this.onStart();return this;},complete:function(){if(this.stopTimer()){this.onComplete();}return this;},cancel:function(){if(this.stopTimer()){this.onCancel();
}return this;},onStart:function(){this.fireEvent("start",this.subject);},onComplete:function(){this.fireEvent("complete",this.subject);if(!this.callChain()){this.fireEvent("chainComplete",this.subject);
}},onCancel:function(){this.fireEvent("cancel",this.subject).clearChain();},pause:function(){this.stopTimer();return this;},resume:function(){this.startTimer();
return this;},stopTimer:function(){if(!this.timer){return false;}this.time=$time()-this.time;this.timer=$clear(this.timer);return true;},startTimer:function(){if(this.timer){return false;
}this.time=$time()-this.time;this.timer=this.step.periodical(Math.round(1000/this.options.fps),this);return true;}});Fx.compute=function(C,B,A){return(B-C)*A+C;
};Fx.Durations={"short":250,normal:500,"long":1000};Fx.CSS=new Class({Extends:Fx,prepare:function(D,E,B){B=$splat(B);var C=B[1];if(!$chk(C)){B[1]=B[0];
B[0]=D.getStyle(E);}var A=B.map(this.parse);return{from:A[0],to:A[1]};},parse:function(A){A=$lambda(A)();A=(typeof A=="string")?A.split(" "):$splat(A);
return A.map(function(C){C=String(C);var B=false;Fx.CSS.Parsers.each(function(F,E){if(B){return ;}var D=F.parse(C);if($chk(D)){B={value:D,parser:F};}});
B=B||{value:C,parser:Fx.CSS.Parsers.String};return B;});},compute:function(D,C,B){var A=[];(Math.min(D.length,C.length)).times(function(E){A.push({value:D[E].parser.compute(D[E].value,C[E].value,B),parser:D[E].parser});
});A.$family={name:"fx:css:value"};return A;},serve:function(C,B){if($type(C)!="fx:css:value"){C=this.parse(C);}var A=[];C.each(function(D){A=A.concat(D.parser.serve(D.value,B));
});return A;},render:function(A,D,C,B){A.setStyle(D,this.serve(C,B));},search:function(A){if(Fx.CSS.Cache[A]){return Fx.CSS.Cache[A];}var B={};Array.each(document.styleSheets,function(E,D){var C=E.href;
if(C&&C.contains("://")&&!C.contains(document.domain)){return ;}var F=E.rules||E.cssRules;Array.each(F,function(I,G){if(!I.style){return ;}var H=(I.selectorText)?I.selectorText.replace(/^\w+/,function(J){return J.toLowerCase();
}):null;if(!H||!H.test("^"+A+"$")){return ;}Element.Styles.each(function(K,J){if(!I.style[J]||Element.ShortStyles[J]){return ;}K=String(I.style[J]);B[J]=(K.test(/^rgb/))?K.rgbToHex():K;
});});});return Fx.CSS.Cache[A]=B;}});Fx.CSS.Cache={};Fx.CSS.Parsers=new Hash({Color:{parse:function(A){if(A.match(/^#[0-9a-f]{3,6}$/i)){return A.hexToRgb(true);
}return((A=A.match(/(\d+),\s*(\d+),\s*(\d+)/)))?[A[1],A[2],A[3]]:false;},compute:function(C,B,A){return C.map(function(E,D){return Math.round(Fx.compute(C[D],B[D],A));
});},serve:function(A){return A.map(Number);}},Number:{parse:parseFloat,compute:Fx.compute,serve:function(B,A){return(A)?B+A:B;}},String:{parse:$lambda(false),compute:$arguments(1),serve:$arguments(0)}});
Fx.Tween=new Class({Extends:Fx.CSS,initialize:function(B,A){this.element=this.subject=$(B);this.parent(A);},set:function(B,A){if(arguments.length==1){A=B;
B=this.property||this.options.property;}this.render(this.element,B,A,this.options.unit);return this;},start:function(C,E,D){if(!this.check(arguments.callee,C,E,D)){return this;
}var B=Array.flatten(arguments);this.property=this.options.property||B.shift();var A=this.prepare(this.element,this.property,B);return this.parent(A.from,A.to);
}});Element.Properties.tween={set:function(A){var B=this.retrieve("tween");if(B){B.cancel();}return this.eliminate("tween").store("tween:options",$extend({link:"cancel"},A));
},get:function(A){if(A||!this.retrieve("tween")){if(A||!this.retrieve("tween:options")){this.set("tween",A);}this.store("tween",new Fx.Tween(this,this.retrieve("tween:options")));
}return this.retrieve("tween");}};Element.implement({tween:function(A,C,B){this.get("tween").start(arguments);return this;},fade:function(C){var E=this.get("tween"),D="opacity",A;
C=$pick(C,"toggle");switch(C){case"in":E.start(D,1);break;case"out":E.start(D,0);break;case"show":E.set(D,1);break;case"hide":E.set(D,0);break;case"toggle":var B=this.retrieve("fade:flag",this.get("opacity")==1);
E.start(D,(B)?0:1);this.store("fade:flag",!B);A=true;break;default:E.start(D,arguments);}if(!A){this.eliminate("fade:flag");}return this;},highlight:function(C,A){if(!A){A=this.retrieve("highlight:original",this.getStyle("background-color"));
A=(A=="transparent")?"#fff":A;}var B=this.get("tween");B.start("background-color",C||"#ffff88",A).chain(function(){this.setStyle("background-color",this.retrieve("highlight:original"));
B.callChain();}.bind(this));return this;}});Fx.Morph=new Class({Extends:Fx.CSS,initialize:function(B,A){this.element=this.subject=$(B);this.parent(A);},set:function(A){if(typeof A=="string"){A=this.search(A);
}for(var B in A){this.render(this.element,B,A[B],this.options.unit);}return this;},compute:function(E,D,C){var A={};for(var B in E){A[B]=this.parent(E[B],D[B],C);
}return A;},start:function(B){if(!this.check(arguments.callee,B)){return this;}if(typeof B=="string"){B=this.search(B);}var E={},D={};for(var C in B){var A=this.prepare(this.element,C,B[C]);
E[C]=A.from;D[C]=A.to;}return this.parent(E,D);}});Element.Properties.morph={set:function(A){var B=this.retrieve("morph");if(B){B.cancel();}return this.eliminate("morph").store("morph:options",$extend({link:"cancel"},A));
},get:function(A){if(A||!this.retrieve("morph")){if(A||!this.retrieve("morph:options")){this.set("morph",A);}this.store("morph",new Fx.Morph(this,this.retrieve("morph:options")));
}return this.retrieve("morph");}};Element.implement({morph:function(A){this.get("morph").start(A);return this;}});(function(){var A=Fx.prototype.initialize;
Fx.prototype.initialize=function(B){A.call(this,B);var C=this.options.transition;if(typeof C=="string"&&(C=C.split(":"))){var D=Fx.Transitions;D=D[C[0]]||D[C[0].capitalize()];
if(C[1]){D=D["ease"+C[1].capitalize()+(C[2]?C[2].capitalize():"")];}this.options.transition=D;}};})();Fx.Transition=function(B,A){A=$splat(A);return $extend(B,{easeIn:function(C){return B(C,A);
},easeOut:function(C){return 1-B(1-C,A);},easeInOut:function(C){return(C<=0.5)?B(2*C,A)/2:(2-B(2*(1-C),A))/2;}});};Fx.Transitions=new Hash({linear:$arguments(0)});
Fx.Transitions.extend=function(A){for(var B in A){Fx.Transitions[B]=new Fx.Transition(A[B]);}};Fx.Transitions.extend({Pow:function(B,A){return Math.pow(B,A[0]||6);
},Expo:function(A){return Math.pow(2,8*(A-1));},Circ:function(A){return 1-Math.sin(Math.acos(A));},Sine:function(A){return 1-Math.sin((1-A)*Math.PI/2);
},Back:function(B,A){A=A[0]||1.618;return Math.pow(B,2)*((A+1)*B-A);},Bounce:function(D){var C;for(var B=0,A=1;1;B+=A,A/=2){if(D>=(7-4*B)/11){C=-Math.pow((11-6*B-11*D)/4,2)+A*A;
break;}}return C;},Elastic:function(B,A){return Math.pow(2,10*--B)*Math.cos(20*B*Math.PI*(A[0]||1)/3);}});["Quad","Cubic","Quart","Quint"].each(function(B,A){Fx.Transitions[B]=new Fx.Transition(function(C){return Math.pow(C,[A+2]);
});});var Request=new Class({Implements:[Chain,Events,Options],options:{url:"",data:"",headers:{"X-Requested-With":"XMLHttpRequest",Accept:"text/javascript, text/html, application/xml, text/xml, */*"},async:true,format:false,method:"post",link:"ignore",isSuccess:null,emulation:true,urlEncoded:true,encoding:"utf-8",evalScripts:false,evalResponse:false},initialize:function(A){this.xhr=new Browser.Request();
this.setOptions(A);this.options.isSuccess=this.options.isSuccess||this.isSuccess;this.headers=new Hash(this.options.headers);},onStateChange:function(){if(this.xhr.readyState!=4||!this.running){return ;
}this.running=false;this.status=0;$try(function(){this.status=this.xhr.status;}.bind(this));if(this.options.isSuccess.call(this,this.status)){this.response={text:this.xhr.responseText,xml:this.xhr.responseXML};
this.success(this.response.text,this.response.xml);}else{this.response={text:null,xml:null};this.failure();}this.xhr.onreadystatechange=$empty;},isSuccess:function(){return((this.status>=200)&&(this.status<300));
},processScripts:function(A){if(this.options.evalResponse||(/(ecma|java)script/).test(this.getHeader("Content-type"))){return $exec(A);}return A.stripScripts(this.options.evalScripts);
},success:function(B,A){this.onSuccess(this.processScripts(B),A);},onSuccess:function(){this.fireEvent("complete",arguments).fireEvent("success",arguments).callChain();
},failure:function(){this.onFailure();},onFailure:function(){this.fireEvent("complete").fireEvent("failure",this.xhr);},setHeader:function(A,B){this.headers.set(A,B);
return this;},getHeader:function(A){return $try(function(){return this.xhr.getResponseHeader(A);}.bind(this));},check:function(A){if(!this.running){return true;
}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(A.bind(this,Array.slice(arguments,1)));return false;}return false;
},send:function(I){if(!this.check(arguments.callee,I)){return this;}this.running=true;var G=$type(I);if(G=="string"||G=="element"){I={data:I};}var D=this.options;
I=$extend({data:D.data,url:D.url,method:D.method},I);var E=I.data,B=I.url,A=I.method;switch($type(E)){case"element":E=$(E).toQueryString();break;case"object":case"hash":E=Hash.toQueryString(E);
}if(this.options.format){var H="format="+this.options.format;E=(E)?H+"&"+E:H;}if(this.options.emulation&&["put","delete"].contains(A)){var F="_method="+A;
E=(E)?F+"&"+E:F;A="post";}if(this.options.urlEncoded&&A=="post"){var C=(this.options.encoding)?"; charset="+this.options.encoding:"";this.headers.set("Content-type","application/x-www-form-urlencoded"+C);
}if(E&&A=="get"){B=B+(B.contains("?")?"&":"?")+E;E=null;}this.xhr.open(A.toUpperCase(),B,this.options.async);this.xhr.onreadystatechange=this.onStateChange.bind(this);
this.headers.each(function(K,J){if(!$try(function(){this.xhr.setRequestHeader(J,K);return true;}.bind(this))){this.fireEvent("exception",[J,K]);}},this);
this.fireEvent("request");this.xhr.send(E);if(!this.options.async){this.onStateChange();}return this;},cancel:function(){if(!this.running){return this;
}this.running=false;this.xhr.abort();this.xhr.onreadystatechange=$empty;this.xhr=new Browser.Request();this.fireEvent("cancel");return this;}});(function(){var A={};
["get","post","put","delete","GET","POST","PUT","DELETE"].each(function(B){A[B]=function(){var C=Array.link(arguments,{url:String.type,data:$defined});
return this.send($extend(C,{method:B.toLowerCase()}));};});Request.implement(A);})();Element.Properties.send={set:function(A){var B=this.retrieve("send");
if(B){B.cancel();}return this.eliminate("send").store("send:options",$extend({data:this,link:"cancel",method:this.get("method")||"post",url:this.get("action")},A));
},get:function(A){if(A||!this.retrieve("send")){if(A||!this.retrieve("send:options")){this.set("send",A);}this.store("send",new Request(this.retrieve("send:options")));
}return this.retrieve("send");}};Element.implement({send:function(A){var B=this.get("send");B.send({data:this,url:A||B.options.url});return this;}});Request.HTML=new Class({Extends:Request,options:{update:false,evalScripts:true,filter:false},processHTML:function(C){var B=C.match(/<body[^>]*>([\s\S]*?)<\/body>/i);
C=(B)?B[1]:C;var A=new Element("div");return $try(function(){var D="<root>"+C+"</root>",G;if(Browser.Engine.trident){G=new ActiveXObject("Microsoft.XMLDOM");
G.async=false;G.loadXML(D);}else{G=new DOMParser().parseFromString(D,"text/xml");}D=G.getElementsByTagName("root")[0];for(var F=0,E=D.childNodes.length;
F<E;F++){var H=Element.clone(D.childNodes[F],true,true);if(H){A.grab(H);}}return A;})||A.set("html",C);},success:function(D){var C=this.options,B=this.response;
B.html=D.stripScripts(function(E){B.javascript=E;});var A=this.processHTML(B.html);B.tree=A.childNodes;B.elements=A.getElements("*");if(C.filter){B.tree=B.elements.filter(C.filter);
}if(C.update){$(C.update).empty().adopt(B.tree);}if(C.evalScripts){$exec(B.javascript);}this.onSuccess(B.tree,B.elements,B.html,B.javascript);}});Element.Properties.load={set:function(A){var B=this.retrieve("load");
if(B){send.cancel();}return this.eliminate("load").store("load:options",$extend({data:this,link:"cancel",update:this,method:"get"},A));},get:function(A){if(A||!this.retrieve("load")){if(A||!this.retrieve("load:options")){this.set("load",A);
}this.store("load",new Request.HTML(this.retrieve("load:options")));}return this.retrieve("load");}};Element.implement({load:function(){this.get("load").send(Array.link(arguments,{data:Object.type,url:String.type}));
return this;}});Request.JSON=new Class({Extends:Request,options:{secure:true},initialize:function(A){this.parent(A);this.headers.extend({Accept:"application/json","X-Request":"JSON"});
},success:function(A){this.response.json=JSON.decode(A,this.options.secure);this.onSuccess(this.response.json,A);}});
//MooTools More, <http://mootools.net/more>. Copyright (c) 2006-2008 Valerio Proietti, <http://mad4milk.net>, MIT Style License.

var Drag=new Class({Implements:[Events,Options],options:{snap:6,unit:"px",grid:false,style:true,limit:false,handle:false,invert:false,preventDefault:false,modifiers:{x:"left",y:"top"}},initialize:function(){var B=Array.link(arguments,{options:Object.type,element:$defined});
this.element=$(B.element);this.document=this.element.getDocument();this.setOptions(B.options||{});var A=$type(this.options.handle);this.handles=(A=="array"||A=="collection")?$$(this.options.handle):$(this.options.handle)||this.element;
this.mouse={now:{},pos:{}};this.value={start:{},now:{}};this.selection=(Browser.Engine.trident)?"selectstart":"mousedown";this.bound={start:this.start.bind(this),check:this.check.bind(this),drag:this.drag.bind(this),stop:this.stop.bind(this),cancel:this.cancel.bind(this),eventStop:$lambda(false)};
this.attach();},attach:function(){this.handles.addEvent("mousedown",this.bound.start);return this;},detach:function(){this.handles.removeEvent("mousedown",this.bound.start);
return this;},start:function(C){if(this.options.preventDefault){C.preventDefault();}this.fireEvent("beforeStart",this.element);this.mouse.start=C.page;
var A=this.options.limit;this.limit={x:[],y:[]};for(var D in this.options.modifiers){if(!this.options.modifiers[D]){continue;}if(this.options.style){this.value.now[D]=this.element.getStyle(this.options.modifiers[D]).toInt();
}else{this.value.now[D]=this.element[this.options.modifiers[D]];}if(this.options.invert){this.value.now[D]*=-1;}this.mouse.pos[D]=C.page[D]-this.value.now[D];
if(A&&A[D]){for(var B=2;B--;B){if($chk(A[D][B])){this.limit[D][B]=$lambda(A[D][B])();}}}}if($type(this.options.grid)=="number"){this.options.grid={x:this.options.grid,y:this.options.grid};
}this.document.addEvents({mousemove:this.bound.check,mouseup:this.bound.cancel});this.document.addEvent(this.selection,this.bound.eventStop);},check:function(A){if(this.options.preventDefault){A.preventDefault();
}var B=Math.round(Math.sqrt(Math.pow(A.page.x-this.mouse.start.x,2)+Math.pow(A.page.y-this.mouse.start.y,2)));if(B>this.options.snap){this.cancel();this.document.addEvents({mousemove:this.bound.drag,mouseup:this.bound.stop});
this.fireEvent("start",this.element).fireEvent("snap",this.element);}},drag:function(A){if(this.options.preventDefault){A.preventDefault();}this.mouse.now=A.page;
for(var B in this.options.modifiers){if(!this.options.modifiers[B]){continue;}this.value.now[B]=this.mouse.now[B]-this.mouse.pos[B];if(this.options.invert){this.value.now[B]*=-1;
}if(this.options.limit&&this.limit[B]){if($chk(this.limit[B][1])&&(this.value.now[B]>this.limit[B][1])){this.value.now[B]=this.limit[B][1];}else{if($chk(this.limit[B][0])&&(this.value.now[B]<this.limit[B][0])){this.value.now[B]=this.limit[B][0];
}}}if(this.options.grid[B]){this.value.now[B]-=(this.value.now[B]%this.options.grid[B]);}if(this.options.style){this.element.setStyle(this.options.modifiers[B],this.value.now[B]+this.options.unit);
}else{this.element[this.options.modifiers[B]]=this.value.now[B];}}this.fireEvent("drag",this.element);},cancel:function(A){this.document.removeEvent("mousemove",this.bound.check);
this.document.removeEvent("mouseup",this.bound.cancel);if(A){this.document.removeEvent(this.selection,this.bound.eventStop);this.fireEvent("cancel",this.element);
}},stop:function(A){this.document.removeEvent(this.selection,this.bound.eventStop);this.document.removeEvent("mousemove",this.bound.drag);this.document.removeEvent("mouseup",this.bound.stop);
if(A){this.fireEvent("complete",this.element);}}});Element.implement({makeResizable:function(A){return new Drag(this,$merge({modifiers:{x:"width",y:"height"}},A));
}});Drag.Move=new Class({Extends:Drag,options:{droppables:[],container:false},initialize:function(C,B){this.parent(C,B);this.droppables=$$(this.options.droppables);
this.container=$(this.options.container);if(this.container&&$type(this.container)!="element"){this.container=$(this.container.getDocument().body);}C=this.element;
var D=C.getStyle("position");var A=(D!="static")?D:"absolute";if(C.getStyle("left")=="auto"||C.getStyle("top")=="auto"){C.position(C.getPosition(C.offsetParent));
}C.setStyle("position",A);this.addEvent("start",function(){this.checkDroppables();},true);},start:function(B){if(this.container){var D=this.element,J=this.container,E=J.getCoordinates(D.offsetParent),F={},A={};
["top","right","bottom","left"].each(function(K){F[K]=J.getStyle("padding-"+K).toInt();A[K]=D.getStyle("margin-"+K).toInt();},this);var C=D.offsetWidth+A.left+A.right,I=D.offsetHeight+A.top+A.bottom;
var H=[E.left+F.left,E.right-F.right-C];var G=[E.top+F.top,E.bottom-F.bottom-I];this.options.limit={x:H,y:G};}this.parent(B);},checkAgainst:function(B){B=B.getCoordinates();
var A=this.mouse.now;return(A.x>B.left&&A.x<B.right&&A.y<B.bottom&&A.y>B.top);},checkDroppables:function(){var A=this.droppables.filter(this.checkAgainst,this).getLast();
if(this.overed!=A){if(this.overed){this.fireEvent("leave",[this.element,this.overed]);}if(A){this.overed=A;this.fireEvent("enter",[this.element,A]);}else{this.overed=null;
}}},drag:function(A){this.parent(A);if(this.droppables.length){this.checkDroppables();}},stop:function(A){this.checkDroppables();this.fireEvent("drop",[this.element,this.overed]);
this.overed=null;return this.parent(A);}});Element.implement({makeDraggable:function(A){return new Drag.Move(this,A);}});$A = function(iterable, start, length){
	if (Browser.Engine.trident && $type(iterable) == 'collection'){
		start = start || 0;
		if (start < 0) start = iterable.length + start;
		length = length || (iterable.length - start);
		var array = [];
		for (var i = 0; i < length; i++) array[i] = iterable[start++];
		return array;
	}
	start = (start || 0) + ((start < 0) ? iterable.length : 0);
	var end = ((!$chk(length)) ? iterable.length : length) + start;
	return Array.prototype.slice.call(iterable, start, end);
};

(function(){
	var natives = [Array, Function, String, RegExp, Number];
	for (var i = 0, l = natives.length; i < l; i++) natives[i].extend = natives[i].implement;
})();

window.extend = document.extend = function(properties){
	for (var property in properties) this[property] = properties[property];
};

window[Browser.Engine.name] = window[Browser.Engine.name + Browser.Engine.version] = true;

window.ie = window.trident;
window.ie6 = window.trident4;
window.ie7 = window.trident5;

Class.empty = $empty;

//legacy .extend support

Class.prototype.extend = function(properties){
	properties.Extends = this;
	return new Class(properties);
};

Array.implement({

	copy: function(start, length){
		return $A(this, start, length);
	}

});

Array.alias({erase: 'remove', combine: 'merge'});

Function.extend({

	bindAsEventListener: function(bind, args){
		return this.create({'bind': bind, 'event': true, 'arguments': args});
	}

});

Function.empty = $empty;

Hash.alias({getKeys: 'keys', getValues: 'values', has: 'hasKey', combine: 'merge'});
var Abstract = Hash;

Element.extend = Element.implement;

Elements.extend = Elements.implement;

Element.implement({

	getFormElements: function(){
		return this.getElements('input, textarea, select');
	},

	replaceWith: function(el){
		el = $(el);
		this.parentNode.replaceChild(el, this);
		return el;
	},
	
	removeElements: function(){
		return this.dispose();
	}

});

Element.alias({'dispose': 'remove', 'getLast': 'getLastChild'});

Element.implement({

	getText: function(){
		return this.get('text');
	},

	setText: function(text){
		return this.set('text', text);
	},

	setHTML: function(){
		return this.set('html', arguments);
	},
	
	getHTML: function(){
		return this.get('html');
	},

	getTag: function(){
		return this.get('tag');
	}

});

Event.keys = Event.Keys;

Element.implement({
	
	setOpacity: function(op){
		return this.set('opacity', op);
	}
	
});

Object.toQueryString = Hash.toQueryString;

var XHR = new Class({

	Extends: Request,

	options: {
		update: false
	},

	initialize: function(url, options){
		this.parent(options);
		this.url = url;
	},

	request: function(data){
		return this.send(this.url, data || this.options.data);
	},

	send: function(url, data){
		if (!this.check(arguments.callee, url, data)) return this;
		return this.parent({url: url, data: data});
	},

	success: function(text, xml){
		text = this.processScripts(text);
		if (this.options.update) $(this.options.update).empty().set('html', text);
		this.onSuccess(text, xml);
	},
	
	failure: function(){
		this.fireEvent('failure', this.xhr);
	}

});

var Ajax = XHR;

JSON.Remote = new Class({

	options: {
		key: 'json'
	},

	Extends: Request.JSON,

	initialize: function(url, options){
		this.parent(options);
		this.onComplete = $empty;
		this.url = url;
	},

	send: function(data){
		if (!this.check(arguments.callee, data)) return this;
		return this.parent({url: this.url, data: {json: Json.encode(data)}});
	},
	
	failure: function(){
		this.fireEvent('failure', this.xhr);
	}

});

Fx.implement({

	custom: function(from, to){
		return this.start(from, to);
	},

	clearTimer: function(){
		return this.cancel();
	},
	
	stop: function(){
		return this.cancel();
	}

});

Fx.Base = Fx;

Fx.Style = function(element, property, options){
	return new Fx.Tween(element, $extend({property: property}, options));
};

Element.implement({
	
	effect: function(property, options){
		return new Fx.Tween(this, $extend({property: property}, options));
	}

});

Fx.Styles = Fx.Morph;

Element.implement({
	
	effects: function(options){
		return new Fx.Morph(this, options);
	}

});

Native.implement([Element, Document], {

	getElementsByClassName: function(className){
		return this.getElements('.' + className);
	},

	getElementsBySelector: function(selector){
		return this.getElements(selector);
	}

});

Elements.implement({

	filterByTag: function(tag){
		return this.filter(tag);
	},

	filterByClass: function(className){
		return this.filter('.' + className);
	},

	filterById: function(id){
		return this.filter('#' + id);
	},

	filterByAttribute: function(name, operator, value){
		return this.filter('[' + name + (operator || '') + (value || '') + ']');
	}

});

var $E = function(selector, filter){
	return ($(filter) || document).getElement(selector);
};

var $ES = function(selector, filter){
	return ($(filter) || document).getElements(selector);
};

var Json = JSON;

JSON.toString = JSON.encode;
JSON.evaluate = JSON.decode;

Cookie.set = function(key, value, options){
	return new Cookie(key, options).write(value);
};

Cookie.get = function(key){
	return new Cookie(key).read();
};

Cookie.remove = function(key, options){
	return new Cookie(key, options).dispose();
};

/**
 * Some of Frank's personal additions
 */
String.implement({
	
	isBlank: function(){
		var val = this;
		if(val==null){return true;}
		for(var i=0;i<val.length;i++) {
		if ((val.charAt(i)!=' ')&&(val.charAt(i)!="\t")&&(val.charAt(i)!="\n")&&(val.charAt(i)!="\r")){return false;}}
		return true;
	},
	
	isInteger: function(){
		var val = this;
		if (this.isBlank()){return false;}
		for(var i=0;i<val.length;i++){
			if(!(val.charAt(i).isDigit())){return false;}
		}
		return true;
	},
	
	isArray: function(){
		var obj = this;
		return(typeof(obj.length)=="undefined")?false:true;
	},
	
	isDigit: function(){
		var num = this;
		if (num.length>1){return false;}
		var string="1234567890";
		if (string.indexOf(num)!=-1){return true;}
		return false;
	},
	
	htmlEntityDecode: function() {
	    var ret, tarea = document.createElement('textarea');
	    tarea.innerHTML = this;
	    ret = tarea.value;
	    return ret;
	}
});





/**
 * Lightbox framework
 *
 * @author Frank Dekker
 * @copyright 2007-2008 Frank Dekker
 */

/**
 * My Lightbox 
 *
 * A bare frame to show an overlay + the box
 */
var light_box_lock = false;
var Lightbox = new Class({
	
	initialize: function( box_width ) {
		
		if ( light_box_lock )
			return;
		
		var page_size = document.getElement('body').getScrollSize();
		
		/*
			The structure of the lightbox will look like this and
		
			<div class="overlay"></div>
			<div class="lightbox"></div>
			</body>
			</html>
		*/	
		document.getElement( 'body' )
		   .appendChild( this.overlay = new Element( 'div', {
		        'id': 'overlay',
		        'styles': {	'height': page_size.y, 'width': page_size.x, 'opacity': 0.0 }
		   }))
		   .getParent()
		   .appendChild( this.lightbox = new Element( 'div', {
				'id': 'lightbox',
				'styles': {
					'width': box_width 
				}
			}));
			
		this.showing = true;			
	},
	
	show: function( ) {
	
		// check if we're already showing the lightbox
		if ( light_box_lock )
			return;
		
		// lock the lightbox in place
		light_box_lock = true;
	
		// create a new style fx for the lightbox
		this.fx = new Fx.Styles( this.overlay, {duration: 200, wait: false} );

		this.centerBox();		
		this.hideSelectBoxes();
		this.showing = true;
	
		this.fx.start( { 
			'opacity': 0.7 
		}).chain( function() {
			this.setStyle( 'visibility', 'visible' );
		}.bind( this.lightbox ) );
	},
	
	
	hide: function( ) {
		
		// hide the lightbox;
		this.lightbox.setStyle( 'visibility', 'hidden' );
		this.showing = false;
				
		// fade the overlay
		this.fx.start({
			'opacity': 0
		}).chain( function() {		
			// remove the components
			this.overlay.remove();
			this.lightbox.remove();	
			
			// show select boxes
			this.showSelectBoxes();				
		}.bind( this ));
		
		// unlock the lightbox
		light_box_lock = false;
	},
	
	
	isShowing: function ( ) {
		return this.showing;
	},
	
	
	centerBox: function( )
	{
		// get sizes		
		var window_size = window.getSize();
		var scroll_size = window.getScroll();
		var box_size = this.lightbox.getSize();	
				
		// determine the coordinates to center the lightbox in the current view	
		var box_x = scroll_size.x + ( window_size.x - box_size.x ) / 2;
		var box_y = scroll_size.y + ( window_size.y - box_size.y ) / 2;
		
		this.lightbox.setStyles({
			"margin-left": box_x,
			"margin-top": box_y
		});
	},
	
	hideSelectBoxes: function( ) {
		
		if ( !window.ie6 ) return;
		
		$$('select').each( function( elm ) {
			elm.setStyle( 'visibility', 'hidden' );
		});
	},
	
	showSelectBoxes: function( ) {
	
		if ( !window.ie6 ) return;
	
		$$('select').each( function( elm ) {
			elm.setStyle( 'visibility', 'visible' );
		});
	}

});


/**
 * Create a dialog
 */
var Dialog = Lightbox.extend({

	initialize: function( box_width, box_height ) {
	
		// initalize the parent
		this.parent( box_width );
		var myLightbox = this;
		
		/*
			-- create the dialog
		
			<div class="content_frame content_dark">
				<div class="header_outer">
				<div class="header_inner">
					
				</div></div>		
				<div class="body_outer">
				<div class="body_inner">
								
				</div></div>		
			</div>
		*/
		
		this.lightbox		
			.appendChild( new Element( 'div', {
				'class': 'content_frame content_light'				
			}))
			.appendChild( new Element( 'div', {
				'class': 'header_outer'
			}))
			.appendChild( this.header = new Element( 'div', {
				'class': 'header_inner'				
			}))
			.appendChild( new Element( 'a', {
				'class': 'closebutton',
				'href': '#'				
			}))
			.addEvent( 'click', function(e) {
				new Event(e).stop();
				myLightbox.hide();				
			})			
			.getParent()
			.getParent()
			.getParent()
			.appendChild( new Element( 'div', {
				'class': 'body_outer'
			}))
			.appendChild( this.body = new Element( 'div', {
				'class': 'body_inner'
			}));
			
		if ( box_height != '' )			
			this.body.setStyle( 'height', box_height );
	}

});



var MessageDialog = Dialog.extend({
	
	initialize: function( width, height, title, message, icon ) {		
		this.parent( width, '' );	
		
		if ( icon == "" || icon == null )
			icon = "uitroepteken";		
	
		var textElm = null;
	
		// create the inner elements
		this.body
			.appendChild( new Element( 'div', {
				'class': 'message_dialog'
			}))
			.appendChild( new Element( 'div', {
				'class': 'message_icon message_icon_'+icon
			}))
			.getParent()
			.appendChild( new Element( 'div', {
				'class': 'message_body'
			}))
			.appendChild( (textElm = new Element( 'p' )) )
			.getParent()
			.getParent()
			.appendChild( new Element( 'div', {
				'class': 'message_button'
			}))
			.appendChild( new Element( 'input', {
				'type': 'button',
				'class': 'thisbutton',
				'value': 'Ok'
			}))
			.addEvent( 'click', function(e) {
				new Event(e).stop();
				this.hide();
			}.bindWithEvent(this));
					
		textElm.setHTML( message );			
	}
});


var AjaxDialog = Dialog.extend({
	
	initialize: function( width ) {
	
		this.parent( width, '' );
	},

	requestShow: function( datatype, properties ) {
	
		if ( properties != null && properties != '' )
		{
			var hash = new Hash( properties );
			var queryString = '&'+hash.toQueryString();
		}
		else
			var queryString = '';
	
		var url = baseurl+'ajax/?query=html&data='+datatype+queryString;
	
		this.body.setHTML( '<div id="ajax_dialog_spinner"><div class="dialog_spinner"</div>' );
		this.show();

		// setup the request and send it
		new Json.Remote(url, {
			onComplete: function(jsonObj) {
				this.body.setHTML(jsonObj.properties.html);

				if ( jsonObj.properties.exec != null )
					eval( jsonObj.properties.exec );
			}.bind(this)
		}).send();
		
				
		return this;
	}
});


var MyMusicPlayer = Dialog.extend({

	initialize: function( width, title, url ) {
				
		this.parent( width, '' );
		
		this.body
			.appendChild( new Element( 'div', {
				'id': "myMusicPlayer"
			}))
			.appendChild( new Element( 'div', {
				'class': 'title',
				'html': title
			}))
			.getParent()
			.appendChild( new Element( 'div', {
				'id': 'embeddedPlayer',
				'class': 'player'
			}));
			
		/**
		 *  Updates for the audio player can be found at
		 *  
		 *  http://wpaudioplayer.com/
		 */				
		var obj = new Swiff(baseurl+'web/flash/player.swf', {
		    id: 'myBeautifulPlayer',
		    width: 290,
		    height: 30,
		    container: 'embeddedPlayer',
			vars: {
				'soundFile': url, 
				'autostart': "yes",			
				'titles': title
			}
		});					
	}
});


var ImageDialog = Dialog.extend({

	initialize: function( imgpath, width, height ) {
	
		this.parent( width+3, height );
		
		this.body
			.appendChild( new Element( 'img', {
				'src': imgpath,
				'width': width,
				'height': height
			}));
	}
});

var MyTMPlayer = Dialog.extend({

	initialize: function( width, title, rttype, previewid ) {
				
		this.parent( width, '' );
		
		this.body
			.appendChild( new Element( 'div', {
				'id': "myMusicPlayer"
			}))
			.appendChild( new Element( 'div', {
				'class': 'title',
				'html': title
			}))
			.getParent()
			.appendChild( new Element( 'div', {
				'id': 'embeddedPlayer',
				'class': 'player'
			}))			
			.appendChild( new Element( 'iframe', {
				'src': "http://www.ringtonio.nl/msp/preview.php?rttype="+rttype+"&id="+previewid,
				'width': 80,
				'height': 60,
				'marginwidth': 0,
				'marginheight': 0,
				'hspace': 0,
				'vspace': 0,
				'frameborder': 0,
				'scrolling': 'no'				
			}));
	}
});

var MyCardBox = Dialog.extend({
	
	initialize: function( settings, storeFunction ) {		
		this.parent( 800, '' );
		
		this.ajaxQuery = baseurl+'ajax/?query=ecard&get=';
		
		this.elm1 = new Element( "div", { "class": "elm1" } );
		this.elm2 = new Element( "div", { "class": "elm2" } );
		this.elm3 = new Element( "div", { "class": "elm3" } );
		this.elm4 = new Element( "div", { "class": "elm4" } );
		this.elm5 = new Element( "div", { "class": "elm5" } );
		
		this.ecard = 
			this.body
			.appendChild( new Element( 'div', {
				"id": "ecard_module"
			}));
			
		this.ecard
			.appendChild( this.elm1 )
			.getParent()			
			.appendChild( this.elm2 )
			.getParent()
			.appendChild( this.elm3 )
			.getParent()
			.appendChild( this.elm4 )
			.getParent()
			.appendChild( this.elm5 );	
		
		// Text area
		this.elm1
			.appendChild( new Element( 'div', {
				"class": "text_beschrijving"
			}))
			.appendChild( new Element( 'h2', {
				"text": "Tekst op de voorkant"
			}))
			.getParent()
			.appendChild( (this.text_textarea = new Element( 'textarea', {
				"text": "Tik hier een tekstje voor op de voorkant",
				"default": "Tik hier een tekstje voor op de voorkant",
				"events": {
					"focus": function( e ) {					
						if (this.text_textarea.get('value') == this.text_textarea.get('text')) 
						{
							this.text_movementhelp.setStyle( "visibility", "visible" );
							$clear(this.textarea_timer);
							this.textarea_fx.stop();
							this.text_textarea.set('value', '');
							this.text_textarea.setStyles({
								"fontSize": 12,
								"fontWeight": "normal",
								"color": "#000000"
							});							
						}
						
					}.bindWithEvent( this ),
					"keyup": function( e ) {
						this.updateTextarea( );
					}.bindWithEvent( this )
				}
			})))
			.getParent()
			.appendChild( new Element( 'div', {
				"class": "text_letop",
				"text": "Let op: Het invullen van een persoonlijke boodschap voor op de achterkant volgt later!"
			}));
		
		// add text fx to the text area
		this.textarea_fx = new Fx.Styles( this.text_textarea, {duration: 500, wait: false } );
		this.textarea_loop = function( ) {
			this.textarea_fx.start( {
				"color": this.text_textarea.getStyle( "backgroundColor" )
			})
			.chain( function( ) {
				this.start({ 
					"color": "#000000"
				});
			});		
		}.bind(this);
		this.textarea_timer = this.textarea_loop.periodical( 2500 );				
		
		// Bold, Italic and Underline
		this.elm1
			.appendChild( new Element( 'div', {
				"class": "text_decorations"				
			}))
			.appendChild( new Element( 'h4', {
				"text": "Tekst decoratie"
			}))
			.getParent()
			.appendChild( new Element( 'a', {
				"class": "text_bold",
				"href": "javascript:;",
				"text": "Vet",
				"events": {
					"click": function( e ) {
						e.stop();
						this.toggleTextDecoration("bold");
					}.bindWithEvent( this )
				}
			}))
			.getParent()
			.appendChild( new Element( 'a', { 
				"class": "text_underline",
				"href": "javascript:;",
				"text": "Onderstreept",
				"events": {
					"click": function( e ) {
						e.stop();
						this.toggleTextDecoration("underline");
					}.bindWithEvent( this )
				}
			}))
			.getParent()
			.appendChild( new Element( 'a', {
				"class": "text_italic",
				"href": "javascript:;",
				"text": "Cursief",
				"events": {
					"click": function( e ) {
						e.stop();
						this.toggleTextDecoration("italic");
					}.bindWithEvent( this )
				}
			}))
			.getParent()
			.appendChild( new Element( 'div', { "class": "clr" } ));
			
		// Font Size
		this.elm1
			.appendChild( new Element( 'div', {
				"class": "text_fontsize"	
			}))
			.appendChild( new Element( 'h4', {
				"text": "Tekst grootte"
			}))
			.getParent()
			.appendChild( new Element( 'a', {
				"class": "text_fontup",
				"href": "javascript:;",
				"text": "Groter",
				"events": {
					"click": function( e ) {
						e.stop();
						this.changeTextSize(4);
					}.bindWithEvent( this )
				}
			}))
			.getParent()
			.appendChild( new Element( 'a', {
				"class": "text_fontdown",
				"href": "javascript:;",
				"text": "Kleiner",
				"events": {
					"click": function( e ) {
						e.stop();
						this.changeTextSize(-4);
					}.bindWithEvent( this )
				}
			}))
			.getParent()
			.appendChild( new Element( 'div', { "class": "clr" } ));
			
		// Color
		this.elm1
			.appendChild( (this.text_colors = new Element( 'div', {
				"class": "text_colors"
			})))
			.appendChild( new Element( 'h4', {
				"text": "Tekst kleur"
			}));
		
		var colors = new Array( 
			"#000000", "#FFFFFF",
			"#FFCCCC", "#CCFFCC", "#CCCCFF", 
			"#FFCC00", "#FF00CC",
			"#CCFF00", "#00FFCC",
			"#00CCFF", "#CC00FF",
			"#00CCCC", "#CC00CC", "#CCCC00",
			"#00CC00", "#CC0000", "#0000CC",
			"#FF0000", "#00FF00", "#0000FF",
			"#FFFF00", "#00FFFF", "#FF00FF"
			);
		for ( var i = 0; i < colors.length; i++ )
		{
			this.text_colors
				.appendChild( new Element( 'a', {
					"class": "text_color",
					"href": "javascript:;",
					"styles": {
						"backgroundColor": colors[i]						
					},
					"events": {
						"click": function( e ) {
							e.stop();
							this.setTextColor( e.target.getStyle( "backgroundColor" ));
						}.bindWithEvent( this )
					}
				}));
		}	
		this.text_colors
			.appendChild( new Element( 'div', { "class": "clr" } ) );
			
		// fonts
		var fonts = new Array( "Arial", "Verdana", "Sans-serif", "Courier", "Helvetica", "Comic Sans MS", "Times" );
		this.elm1
			.appendChild( (this.text_fonts = new Element( 'div', {
				"class": "text_fonts"
			})))
			.appendChild( new Element( 'h4', {
				"text": "Lettertype"	
			}))
			.getParent();	
		for( var i = 0; i < fonts.length; i++ )
		{
			this.text_fonts
				.appendChild( new Element( 'a', {
					"class": "text_font",
					"text": fonts[i],
					"href": "javascript:;",
					"styles": {
						"fontFamily": fonts[i]
					},
					"events": {
						"click": function( e ) {
							e.stop();
							this.setTextFont( e.target.getStyle( 'fontFamily' ) );
						}.bindWithEvent( this )
					}										
				}));
		}		
		
		/*
		 *  File Upload
		 */
		this.elm2
			.appendChild( new Element( 'div', {
				"class": "image_uploader",
				"html" : '<form enctype="multipart/form-data" method="post" ' +
				         'action="'+baseurl+'process.php" target="myIFrame" name="uploader">' +
						 '<h2>Upload hier jouw eigen foto:</h2><br />' +
						 '<div class="fileinput">' +
						 '<input type="hidden" name="formname" value="Ecardupload">' +
						 '<input type="file" name="customimage" class="file"><br />' +
						 '<small>Beste kwaliteit: 400x300 pixels</small>' +
						 '</div>' +   
						 '</form>'
			}))
			.getParent()
			.appendChild( new Element( 'iframe', {
				"src": "about:blank",
				"id": "myIFrame",
				"name": "myIFrame",
				"styles": {		
					"display": "none"
					/**
					"width": 300,
					"height": 200
					*/
															
				},
				"events": {
					"load": function( e ) {
						// get the correct iframe document 
						var i = document.getElementById('myIFrame');
				        if (i.contentDocument) { var d = i.contentDocument; }
						else if (i.contentWindow) { var d = i.contentWindow.document; } 
						else { var d = window.frames['myIFrame'].document; }
						// check if the document was reloaded
				        if (d.location.href == "about:blank") return;						
						
				        var jsonObj = JSON.decode( d.body.innerHTML );
						
						if ( jsonObj.properties.error != null )
							alert( jsonObj.properties.error );
						else						
							this.setCustomImage( jsonObj.properties.image );
						
					}.bindWithEvent( this )
				}				
			}));
		
		// attach events to the uploadform
		var uploadform = $("ecard_module").getElement("form[name=uploader]");
		uploadform.getElement( ".file" )
			.addEvent( "change", function( e ) {				
				new Event( e ).stop();			
				uploadform.submit();
								
			}.bindWithEvent(this));		
		
		/*
		 *  Image categories
		 */	
		this.elm2			
			.appendChild( new Element( 'div', {
				"class": "ecard_categories_full"
			}))			
			.appendChild( new Element( "h2", {
				"text": "...of kies een kaart:"
			}))			
			.getParent()
			.appendChild( (this.image_categories = new Element( 'div', {
				"class": "ecard_categories clearfix"
			})))
			.appendChild( new Element( "h4", {
				"text": "Categorie:"
			}));	
			
		// the ecard	
		this.elm3
			.appendChild( (this.image_holder = new Element( 'div', {
				"class": "image_holder"
			})))
			.appendChild( (this.text_holder = new Element( 'div', {
				"class": "text_holder",
				"styles": {
					"fontSize": 20,
					"lineHeight": 20
				}
			})))
			.getParent()
			.getParent()
			.appendChild( (this.text_movementhelp = new Element( 'div', {
				"class": "text_movementhelp",
				"text": "Ga met je muis over jouw tekstje en sleep deze naar de gewenste positie."
			})));	
		
		this.elm3
			.appendChild( new Element( 'div', { "class": "clr" } ) );
		
		// Image selector
		this.elm4		
			.appendChild( new Element( 'div', {
				"class": "scroll_container"
			}))
			.appendChild( new Element( 'div', {
				"id": "image_scroller_right",
				"class": "scrollcontrol",
				"text" : "<"
			}))
			.getParent()
			.appendChild( (this.image_scroller = new Element( 'div', {
				"class": "image_scroller"
			})))			
			.appendChild( (this.image_selector = new Element( 'div', {
				"class": "image_selector"
			})))
			.getParent()
			.getParent()
			.appendChild( new Element( 'div', {
				"id": "image_scroller_left",
				"class": "scrollcontrol",
				"text": ">"
			}))
			.getParent()
			.appendChild( new Element( 'div', { "class": "clr" }));
		
		// buttons
		this.elm5 
			.appendChild( (this.back_button = new Element( 'input', {
				"type": "button",
				"value": "Terug",
				"class": "button_terug thisbutton",
				"events": {
					"click": function( e ) {
						e.stop();
						this.setPage( 1 );
					}.bindWithEvent( this )
				}
			})))
			.getParent()
			.appendChild( (this.next_button = new Element( 'input', {
				"type": "button",
				"value": "Verder",
				"class": "button_verder thisbutton",
				"events": {
					"click": function( e ) {
						e.stop();
						if ( this.ecardImage == null )
						{
							alert( "Je hebt geen ecard geselecteerd. Upload jouw eigen\nkaart of kies er een uit de categorieen.");
							return;
						} 						
						this.setPage( 2 );
					}.bindWithEvent( this )
				}
			})))
			.getParent()
			.appendChild( new Element( 'div', { "class": "clr" } ));	
		
		// init variables
		this.ecardImage = null;
		this.textColor = "black";
		this.textSize = 20;
		this.textBold = false;
		this.textItalic = false;
		this.textUnderline = false;
		this.textFont = "Arial";			
		this.thumbs = 0;	
		
		// remember store function
		this.storeFunction = storeFunction;
		
		// initialize controls	
		this.setEcardsSelector( this.image_selector, "Verjaardag" );
		this.setCategories( this.image_categories );
		this.setScrollers( );
		
		// set the text element moveable
		new Drag.Move( this.text_holder, { "container": this.image_holder });
		
		// load the settings if any
		if ( settings != null && settings != "" )
			this.loadSettings( settings );			
	},
	
	updateTextarea: function( ) {
		var text = this.text_textarea.get('value');  // get the text
		text = text.replace( / /g, "&nbsp;" );       // replace 'space' with nbsp
		text = text.replace( /\n/g, "<br />" );      // replace \n with br 		
		this.text_holder.set( 'html', text );        // set the text
	},	
	
	setTextFont: function( font ) {
		this.textFont = font;
		this.text_holder.setStyle( 'fontFamily', font );
	},
	
	changeTextSize: function( change ) {
		
		if (this.textSize + change < 10 || this.textSize + change > 40)
			return;	
		
		this.textSize += change;	
		this.text_holder.setStyles( 
			{ 'fontSize': this.textSize,
			  'lineHeight': this.textSize } 		
		);				
	},
	
	setTextColor: function ( color ) {
		this.textColor = color;
		this.text_holder.setStyle( "color", color );
	},
	
	toggleTextDecoration: function ( type ) {
		
		switch( type )
		{
			case "bold":
				this.text_holder.setStyle( "fontWeight", ( this.textBold ? "normal" : "bold" ) );
				this.textBold = !this.textBold;
				break;	
			
			case "italic":
				this.text_holder.setStyle( "fontStyle", ( this.textItalic ? "normal" : "italic" ) );
				this.textItalic = !this.textItalic;
				break;
			
			case "underline":
				this.text_holder.setStyle( "textDecoration", ( this.textUnderline ? "none" : "underline" ) );
				this.textUnderline = !this.textUnderline;
				break;
			
			default:
				break;
		}			
	},	
	
	setScrollers: function( ) {
		
		var lock = false;
		
		$$("#ecard_module .scrollcontrol").each( function( elm ) {
			elm.addEvents( {
				"mouseover": function( e ) {
					new Event( e ).stop( );
					elm.addClass( "sfhover" );
				},	
				"mouseout": function( e ) {
					new Event( e ).stop( );
					elm.removeClass( "sfhover" );
				},						
				"mousedown": function( e ) {
					new Event( e ).stop( );
					elm.addClass( "sfclicked" );
				},
				"mouseup": function( e ) {
					new Event( e ).stop( );
					elm.removeClass( "sfclicked" );
				},	
				"click": function( e ) {
					new Event( e ).stop( );
					if ( lock ) return;
					lock = true;
					var moveImages = 7;
					var size = this.image_scroller.getSize();
					var totalLength = this.thumbs*90;
					var left = this.image_selector.getStyle( "left" ).toInt();
					var movement = ( elm.get('id') == 'image_scroller_left' ) ? -90*moveImages : 90*moveImages;
					var leftX = left+movement;
					if ( leftX > 0 ) leftX = 0;
					if ( totalLength + left < size.x && movement < 0 ) leftX = left;
					if ( leftX == left ) { lock = false; return }																			
					var fx = new Fx.Styles( this.image_selector, {duration: 1000, wait: true} );
					fx.start( {
						"left": leftX
					})
					.chain( function( ) {
						lock = false;	
					});																						
				}.bindWithEvent(this)							
			});			
		}.bind(this));		
	},
	
	setCategories: function( category_container ) {
		
		url = this.ajaxQuery+'categories';
		new Json.Remote(url, {
			onComplete: function(jsonObj) {	
				var list = category_container
					.appendChild( new Element( 'ul' ) );
								
				jsonObj.elements.each( function( elm ) {
					list.appendChild( new Element( 'li' ))
						.appendChild( new Element( 'a', {
							"href": "javascript:;",
							"html": elm.name,
							"events": {
								"click": function( event ) {
									this.setEcardsSelector( this.image_selector, elm.name );									
								}.bindWithEvent(this)
							}
						}));					
				}.bind(this));				
			}.bind(this)
		}).send();
	},
	
	setCustomImage: function( image ) {
		this.image_holder
			.setStyle( "background", 'url('+baseurl+'data/ecards/'+image+')' )
			.setStyle( "width", 400 );
		this.ecardImage = image;
	},
	
	setSelectedImage: function( idx ) {
		this.image_holder
			.setStyle( "background", 'url('+baseurl+'data/img/ecards/'+idx+'-1.jpg)' )
			.setStyle( "width", 400 );
		this.ecardImage = idx;
	},

	setEcardsSelector: function( selector_container, category ) {
	
		// remove all the current images
		selector_container.empty();
		selector_container.setStyle( "left", 0 );
	
		url = this.ajaxQuery+'ecards&category='+category;
		new Json.Remote(url, {
			onComplete: function(jsonObj) {
				
				this.thumbs = 0;
				jsonObj.elements.each( function( elm ) {					
					selector_container
						.appendChild( new Element( 'a', {
							"href": "javascript:;",
							"events": {
								"click": function( e ) {
									new Event( e ).stop( );
									this.setSelectedImage( elm.idx );
								}.bindWithEvent(this)
							}
						}))
						.appendChild( new Element( 'img', {
							"width": 80,
							"height": 60,
							"src": baseurl+'web/img/imagescaler.php?type=ecard&item='+elm.idx+'&width=80&height=60'							
						}));
					this.thumbs += 1;										
				}.bind(this)); 					
				selector_container
					.appendChild( new Element( 'div', { "class": "clr" } ));	
			}.bind(this)
		}).send();		
	},
	
	setPage: function( page )
	{
		if ( page == 1 )
		{
			this.elm1.setStyle( 'display', 'none' );
			this.elm2.setStyle( 'display', 'block' );
			this.elm4.setStyle( 'display', 'block' );
			this.back_button.setStyle( 'visibility', 'hidden' );
			this.next_button.set( 'value', 'Verder' );			
		}	
		else // page == 2
		{
			if ( this.next_button.get('value') == "Bewaren" ) 
			{	
				this.hide();
				this.storeFunction( this.saveSettings(), this.ecardImage );			
			}
			else
			{
				this.elm1.setStyle('display', 'block');
				this.elm2.setStyle('display', 'none');
				this.elm4.setStyle('display', 'none');
				this.back_button.setStyle('visibility', 'visible');
				this.next_button.set('value', 'Bewaren');
			}
		}	
	},
	
	saveSettings: function( ) {
		
		var settings = { 
			"card": this.ecardImage,
			"text": (this.text_textarea.get('default')==this.text_textarea.get('value')?"":this.text_textarea.get('value')),
			"color": this.textColor,
			"size": this.textSize,
			"bold": (this.textBold?"true":"false"),
			"italic": (this.textItalic?"true":"false"),
			"underline": (this.textUnderline?"true":"false"),
			"top": this.text_holder.getStyle( "top" ).toInt(),
			"left": this.text_holder.getStyle( "left" ).toInt(),
			"font": this.textFont 
		};	
		
		return JSON.encode( settings );
	},
	
	loadSettings: function( str ) {
		var settings = JSON.decode( str );
		
		// card
		if ( settings.card.isInteger() )
			this.setSelectedImage( settings.card );
		else
			this.setCustomImage( settings.card );
		
		// text
		if (settings.text != null && settings.text != "") 
		{
			this.text_textarea.set('value', settings.text);
			this.updateTextarea();
			this.text_movementhelp.setStyle( "visibility", "visible" );
			$clear(this.textarea_timer);
			this.textarea_fx.stop();
			this.text_textarea.setStyles({
				"fontSize": 12,
				"fontWeight": "normal",
				"color": "#000000"
			});							
		}
		
		// color		
		this.setTextColor( settings.color );
		
		// bold
		if ( settings.bold == "true" )
			this.toggleTextDecoration( "bold" );
		
		// italic
		if ( settings.italic == "true" )
			this.toggleTextDecoration( "italic" );
		
		// cursief
		if ( settings.underline == "true" )
			this.toggleTextDecoration( "underline" );	
		
		// position
		this.text_holder.setStyle( "top", settings.top );
		this.text_holder.setStyle( "left", settings.left );
		
		// size
		this.textSize = settings.size - 1;
		this.changeTextSize( 1 );
		
		// font
		this.setTextFont( settings.font );
	}

});

/**
 * Class to handle data live from the server with the
 * ability to set and remove properties retrieving new data.
 */
var DataTableController = new Class({

	initialize: function( container ) {
		
		// get the complete container
		this.container = $(container);
		
		// get page numbers
		this.pagenumbers = this.container.getElements('.content_paginas');
		
		// get the title
		this.title = this.container.getElement( '.top_title .second' );
		
		// setup page controls
		this.pagenumbers.each( function( elm ) {
		
			elm.getElement('.eerste').addEvent( 'click', function(e) {
				new Event(e).stop();
				this.showPage( 0 );				
			}.bindWithEvent( this ));
			
			elm.getElement('.vorige').addEvent( 'click', function(e) {
				new Event(e).stop();
				this.showPage( -1 );				
			}.bindWithEvent( this ));
			
			elm.getElement('.volgende').addEvent( 'click', function(e) {
				new Event(e).stop();
				this.showPage( +1 );				
			}.bindWithEvent( this ));
			
			elm.getElement('.laatste').addEvent( 'click', function(e) {
				new Event(e).stop();
				this.showPage( 10 );				
			}.bindWithEvent( this ));
											
		}.bind( this ));
		
		/*
		$('controller_pagelength').addEvent( 'change', function(e) {
			$$('#controller_pagelength option').each( function( option ) {
				if ( option.selected ) 
				{
					this.handler.setParameter( 'page', 1 );
					this.handler.requestData( 'pagelength', option.text );
				} 
			}.bind( this ));
		}.bindWithEvent( this ) );	*/	
		
		// get elements
		this.root_element = this.container.getElement( '.content_elements' );
		this.elements = this.container.getElements( '.content_element' );
		
		// set mouse events
		this.addMouseEvents();	
	},
	
	showPage: function( pagenumber ) {
	
		var currentpage = this.handler.getParameter( 'page' );
		if ( currentpage == null || currentpage == "" )
			currentpage = 1;
		else
			currentpage = parseInt( currentpage );
	
		if ( pagenumber == 0 )
			page = 1;
		else if ( pagenumber == 10 )
			page = this.paginas;
		else
			page = currentpage + pagenumber;
	
		this.handler.requestData( 'page', page  );
	},
	
	addMouseEvents: function( )
	{
		this.elements.each( function( elm ) {
			elm.addEvents({
				'mouseover': function(event) { elm.addClass( 'content_element_selected' ) },
				'mouseout': function(event) { elm.removeClass( 'content_element_selected' ) }
			});			
		});		
	},
	
	setRequestHandler: function( handler ) {
		this.handler = handler;
	},
	
	setPageNumbers: function( start, end, total ) {
		
		var pagelength = end - start + 1;
		start = parseInt( start );
		end = parseInt( end );
		total = parseInt( total );
		
		this.pagenumbers.each( function( elm ) {
		
			// set the page numbers
			elm.getElement('.start').setHTML( start );
			elm.getElement('.eind').setHTML( end );
			elm.getElement('.totaal').setHTML( total );
						
			// show or hide the page numbers based upon the position			
			elm.getElement('.eerste').setStyle( 'display', ( (start - 2 * pagelength < 1) ? 'none' : 'inline') );
			elm.getElement('.vorige').setStyle( 'display', ( (start <= 1) ? 'none' : 'inline') );						
			elm.getElement('.laatste').setStyle( 'display', ( (end >= total - pagelength) ? 'none' : 'inline') );						
			elm.getElement('.volgende').setStyle( 'display', ( (end >= total) ? 'none' : 'inline') );
		});		
	},
	
	applyProperties: function( properties ) {
		
		// set the page numbers
		this.setPageNumbers( properties.start, properties.eind, properties.totaal );
		
		// set the total number of pages					
		this.paginas = properties.paginas;
		this.items = properties.totaal;
		
		// set the title
		if ( this.title != null )
			this.title.setHTML( properties.titel );
	},
	
	addElement: function( elm ) {
		this.root_element
			.appendChild( new Element( 'div', {
				"html": elm.data,
				"class": "content_element",
				"events": {
					"click": function(e) {
						new Event(e).stop();
						if ( elm.link != '' )
							window.location=elm.link;
					}
				}
			}));
	},
	
	update: function( ) {
		// setup elements again
		this.elements = this.container.getElements( '.content_element' );
		
		// add mouse events
		this.addMouseEvents();
		
		// show message if there are no items
		if ( this.items == 0 )
			this.setEmpty( );
	},
	
	setEmpty: function( ) {
		var size = this.root_element.getSize();
		this.reset();
		this.root_element
		.appendChild( new Element( 'div', {
			'class': 'content_loading',
			'html': 'Er zijn nog geen items in dit overzicht.',
			'styles': { 'height': size.y - 100 }
		}));
	},
	
	setloading: function( ) {
	
		this.load_timeout = function( ) {
			var size = this.root_element.getSize();
		
			this.reset();
			this.root_element
			.appendChild( new Element( 'div', {
				'class': 'content_loading',
				'html': l_contentloading,
				'styles': { 'height': size.y - 100 }
			}));	
		}.delay( 200, this );			
	},
	
	clearloading: function( ) {
	
		if ( this.load_timeout != null )
		{
			$clear( this.load_timeout );
			this.load_timeout = null;
		}
	},
	
	reset: function() {	
		this.root_element.empty();
	}	
}); 

/**
 * Class to handle a request, retrieve the new data, and add it to the 
 * table
 */
var RequestHandler = new Class({
	
	initialize: function( controller, datatype ) {
	
		// store the controller
		this.controller = controller;	
		this.controller.setRequestHandler( this );
		
		// store the data type
		this.datatype = datatype;
		
		// properties to add in the url
		this.properties = new Hash();
		
		// the handler lock
		this.lock = false;
	},
	
	/**
	 * Set the property of the request
	 */
	setParameter: function( key, value ) {
		if ( this.lock ) return;
		
		if ( key == null || key == "" ) return;	
		else if ( value == null || value == "" ) this.properties.erase( key );
		else this.properties.set( key, value );
		
		
		$$('.control_entry .'+key+' ul li').each( function( elm ) {			
			elm.removeClass( "selected" );
		});


		$$('.control_entry .list ul li.list_'+key+'_'+value ).each( function( elm ) {
			elm.addClass( "selected" );
		})		
	},
	
	/**
	 * Set multiple parameters
	 */
	setParameters: function( properties ) {
		if ( this.lock ) return;
	
		var hash = new Hash( properties );
		hash.each( function( value, key ) {
			this.properties.setParameter( key, value );
		}.bind( this ));
	},
	
	/**
	 * Reset all the properties
	 */
	resetParameters: function( keep ) {
		if ( this.lock ) return;
		
		if ( keep != null )
		{
			var store = new Hash();
			var value = this.properties.get( keep );
			if ( value != null )
				store.set( keep, value );
			this.properties = store;
		}
		else	
			this.properties.empty();
	},
	
	/**
	 * Get the properties in a string
	 */
	getParameters: function() {
		var result = this.properties.toQueryString();
		
		if ( result != "" )
			result = "&" + result;
			
		return result;
	},
	 
	/**
	 * Get the property with the given parameter
	 */
	getParameter: function( key ) {
		return this.properties.get( key );
	},	 
	 
	/**
	 * Request new data from the server
	 *
	 * Example:
	 *    page - first, prev, next, last
	 *    genre - name
	 *    sort - type
	 *
	 * @param type the type of the request
	 * @param action the action of the request 
	 */ 
	requestData: function( key, value ) {
		if ( this.lock ) return;
	
		// set the new parameters
		this.setParameter( key, value );
		
		var handler = this;
		
		// create a query string from the current parameters
		var queryString = this.getParameters();
		var url = baseurl+'ajax/?query=content&data='+this.datatype+queryString;
		
		// setup loading
		this.controller.setloading();
		
		// lock the 
		this.lock = true;
		
		// setup the request and send it
		var request = new Json.Remote(url, {
			onComplete: function(jsonObj) {
				handler.controller.clearloading();
				handler.handleProperties(jsonObj.properties);
				handler.handleData(jsonObj.elements);
				handler.lock = false;
			}
		}).send();
		this.updateLocation();		
	},
	
	/**
	 * Process the properties of the request
	 */
	handleProperties: function( properties ) {

		this.controller.applyProperties( properties );
	},
	
	/**
	 * Process the received data
	 *
	 * @param elements an element list for all the elements received
	 */
	handleData: function( elements ) {
		
		// reset all the current elements
		this.controller.reset();	
			
		// add the element data to the controller			
		elements.each( function( elm ) {			 
			this.controller.addElement( elm );		
		}, this);
		
		// update all the mouse events etc
		this.controller.update();
	},
	
	/**
	 * Update the location
	 */
	updateLocation: function() {
	
		window.location.replace( "#" + this.hashToLocation( this.properties ) );
	},
	
	/**
	 * Apply the current location to this object
	 */
	applyDefaults: function( defaults ) {
		
		var string = window.location.href;
		var parts = string.split( /#/ );
		var hash = null;
		
		// first check if we have location parameters
		if ( parts.length >= 2 && parts[1].length > 0 )
		{
			hash = this.locationToHash( parts[1] );					
		}	
		// otherwise apply default settings
		else
		{
			hash = new Hash( defaults ); 			
		}	
		
		// load all the values into the object
		hash.each( function( value, key ) {
			this.setParameter( key, value );
		}.bind( this ));
		
		// request the data
		this.requestData();	
	},
	
	/**
	 * Convert a hash to a location string
	 */
	hashToLocation: function( hash ) {
		
		var string = "";
	
		hash.each( function( value, key ) {
		
			if ( string != "" )
				string += ",";
			string += key + ":" + value;		
		});
		
		return string;
	},
	
	/**
	 * Convert a location string to a hash
	 */
	locationToHash: function( string ) {
		
		var hash = new Hash();
		var parts = string.split( /,/ );
		
		parts.each( function( item ) {
			
			var pair = item.split( /:/ );
			hash.set( pair[0], pair[1] );
		});	
		
		return hash;
	}
});




















/**
 * Things to do when the dom is ready
 */
window.addEvent( 'domready', function() {
    fixManuelLength();
    fixMenuLength();
});


/*
 * Menu Tabs
 */
function initTopMenu( )
{
	starttab = null;

	/**
	 * Add mouseover event to all the main menu tabs
	 */
	$$('#main_navigation ul li.tab').each( function( tab ) {
		var timer = 0;
		
		// when mouse moves in, delay the show of the next menu tab
		tab.addEvent( 'mouseenter', function( event ) {		
			timer = function( ) {				
				var ltr = false;
			  			    	    			  
				// remove all the previous classes and set the correct ones				  			    	    			    				
    			$$('#main_navigation ul li.tab').each( function( xtab ) {		    				
    				if ( tab == xtab ) {		    				
    					xtab.removeClass('tab_right').removeClass('tab_left').addClass('tab_selected');
    					ltr = true;
    				} else if ( ltr == false ) {		    					
    					xtab.removeClass('tab_selected').removeClass('tab_right').addClass('tab_left');
    				} else { 
    					xtab.removeClass('tab_selected').removeClass('tab_left').addClass('tab_right');
    				}		    						    					    				
    			});   				
			
			}.delay(200);					
		});
		
		// when mouse moves out, cancel the timer.
		tab.addEvent( 'mouseleave', function( event ) {
			clearTimeout( timer );
		});
		
		// remember which tab we started with
		if ( tab.hasClass( "tab_selected" ) )
			starttab = tab;
	});
	
	// reset the menu to it's default tab after 10 seconds
	var navigation_timer = 0;
   	$('main_navigation').addEvent( 'mouseleave', function( event ) {
   		navigation_timer = function( ) {
			starttab.fireEvent( 'mouseenter' );
		}.delay( 10000 );			    		
   	});
   	// cancel this timer when the mouse moves back into the menu
   	$('main_navigation').addEvent( 'mouseenter', function( event ) {
   		clearTimeout( navigation_timer );		    		
   	});
} 

/**
 * Search functionality
 */
function initSearch( zoekform, defaulttext ) {
	
	var slider = $('menu_zoeken').getElement( ".slider");
	
	var fx = new Fx.Styles( slider, {duration: 500, wait: false} );
	
	
	var form = $(zoekform);
	
	var veld = form.getElement( ".text" );
	veld.setAttribute( 'default', defaulttext );
	
	veld.addEvents( {
		'focus': function( event ) {
			if ( veld.getAttribute( "default" ) == veld.get('value') )
				veld.set('value','');
			veld.removeClass( "stylized" );		
		},
		'blur': function( event ) {
			if ( veld.get('value') == "" )
				veld.set('value', veld.getAttribute( "default" ) );
			if ( veld.get('value') == veld.getAttribute( "default" ) )
				veld.addClass( "stylized" );
		},
		'keyup': function( event ) {			
			if (    veld.get('value') != veld.getAttribute( "default" )
				 && veld.get('value') != ""
				 && event.code == "13" ) // enter
			{
				event.stop();
				fx.start({'height': 80});
				form.submit();					
			}			
		}
	});
	
	var link = form.getElement( ".zoeklink" );
	link.addEvent( "click", function( event ) {
		event.stop();
		fx.start({'height': 50});
		form.submit();	
	});
	
	veld.fireEvent( 'blur' );
}

/**
 * Initialize form
 */
function initForm( formname )
{			
	/**
	 * Create Form feedback
	 */
	feedback = new Element( 'div' );
	feedback.setStyle( 'display', 'none' );
	feedback.setAttribute( 'id', formname+'-feedback' );
	feedback.addClass( 'form_feedback' );	
	feedback.appendChild( new Element( 'div', {
				'class': 'outer'
			}))
			.appendChild( new Element( 'div', {
				'class': 'inner'
			}));		
	$(formname).insertBefore( feedback, $(formname).firstChild );

	/**
	 * - Add focus listener to all fields to clear feedback
	 * - Add enable/disable submit button (if disabled show progress)
	 */
	$(formname).getFormElements().each( function(el) 
	{
		el.addEvent( 'focus', function( event ) {
			feedback.setStyle( 'display', 'none' );
			el.removeClass( "erroneous" );
		});			
	});

	/**
	 * Submit button
	 */
	var button = $(formname).getElement('input.form_submit');
	var spinner = button.getParent().appendChild( new Element( 'div', { 'id' : formname+'-spinner' } ) );
	button.injectInside( spinner );		
		
	$(formname).addEvent('submit', function(e) {
		
		/**
		 *  get the form
		 */
		var form = $(formname);
	
		/**
		 * Prevent the submit event
		 */
		if ( e != null ) new Event(e).stop();
	 
	 	/**
	 	 * Disable the submit button
	 	 */
	 	this.getElement('input.form_submit').disabled = true;
	 
	 	/**
	 	 * Clear any enabled error messages
	 	 */
		feedback.setStyle( 'display', 'none' );
	 
		/**
		 * show the spinner
		 */		
		spinner.addClass('form_spinner');
	 
		/**
		 * send takes care of encoding and returns the Ajax instance.
		 * onComplete removes the spinner from the log.
		 */
		this.set('send', {
                method: 'post',
                data: $(formname), 
                evalResponse: false,                                     
                onSuccess: function( responseText, responseXML ) {
					$(formname).getElement('input[type=submit]').disabled = false;
					spinner.removeClass( 'form_spinner' );
					jsonObj = JSON.decode( responseText, true );					

					if ( jsonObj.properties.script != "" )
						eval( jsonObj.properties.script );
					
					if ( jsonObj.properties.location != "" && jsonObj.properties.location != null )
						window.location.href = jsonObj.properties.location;
				}			
        });
        this.send(this.action);  
	});
}

/**
 * Handle form errors
 */
function processFormError( form, label, error, message )
{	
	// if ecard reset it
	var previewecard = $(form).getElement('input[name=previewecard]');
	if ( previewecard != null )
		previewecard.set('value','no');

	var labelfound = false;
	feedback = $(form+'-feedback');
	f_inner = feedback.getElement( '.inner' );
	f_outer = feedback.getElement( '.outer' );
	
	f_inner.setHTML(message)
	f_outer.setStyles({
		'top': 0,
		'left': 0,
		'width': 'auto'
	});			
	feedback.setStyle( 'visibility', 'hidden' );
	feedback.setStyle( 'display', 'block' );		
	
	// function to position the bubble next to an element
	var setPosition = function( el )
	{
		// check if the element is displayed, otherwise location fails
		var displayed = true;
		if ( el.getStyle( 'display') == "none" )
		{
			el.setStyle( 'display', "block" );
			displayed = false;
		}
		
		// get the correct coordinates				
		var fcoords = feedback.getCoordinates();
		var ocoords = f_outer.getCoordinates();
		var ecoords = el.getCoordinates();
				
		// position the error bubble
		f_outer.setStyle( 'left', ecoords.left - fcoords.left + ecoords.width - 22 );
		
		// resize the window if it is too small
		var ocoords = f_outer.getCoordinates();
		if ( ocoords.width < 300 )
			f_outer.setStyle( 'width', 300 );
		
		// recalculate some coordinates
		var ocoords = f_outer.getCoordinates();				
		f_outer.setStyle( 'top', ecoords.top - fcoords.top - ocoords.height + 3 );
				
		feedback.setStyle( 'visibility', 'visible' );
		
		el.addClass('erroneous');
		
		// hide the element again if it wasn't displayed
		if ( !displayed ) 
			el.setStyle( 'display', "none" );
	}		
		
	// get the correct form element		
	$(form).getFormElements().each( function(el) 
	{
		if ( el.getProperty('name') == label )
		{
			if ( labelfound == true )
				return;
			
			if ( el.getAttribute('type') == 'radio' )
				return;	
				
			setPosition( el );
			labelfound = true;
		}
	});
	
	// check if we have an element with the given identifier
	if ( labelfound == false )
	{
		var el = $(label);
		if ( el != null )
		{			
			setPosition( el );
			labelfound = true;
		}
	}
	
	// cant find the element, position it at the top of the form
	if ( labelfound == false )
	{
		// set element relative to it's parent							   		
		fsize = f_outer.getSize( );
		f_outer.setStyles({
			'top': -1*fsize.y+5,
			'left': 5	
		});
		feedback.setStyle( 'visibility', 'visible' );
	}
}

/**
 * Handle form succes 
 */
function processFormSuccess( form, message, reset )
{
	// clear form
	if ( reset )
		$(form).reset();
	
	// show message
	var m = new MessageDialog( 500, 200, '', message );
	m.show();		
}

/**
 * Update the boncode after activation
 */
function updateBoncodeTabel( )
{
	var url = baseurl+'ajax/?query=html&data=mijnboncodes';
		
	// setup the request and send it
	var request = new Json.Remote(url, {
		onComplete: function(jsonObj) {
			$('mijnboncodes_actieveboncodes').setHTML( jsonObj.properties.html );
		}
	}).send();		
}

/**
 * Add shop item to the shopping list
 */
function addShopItem( contentparty, category, itemid )
{
	currentDialog = new AjaxDialog( 550 ).requestShow("addshopitem",{"contentparty":contentparty,"category":category,"itemid":itemid});
	return true;		
}

/**
 * Setup development tabs
 */
function initDevelopment( )
{
	// setup the folding
	$('development').getElement( '.folder a' ).addEvent( 'click', function( event )	{
		// catch event and stop it
		event = new Event( event );
		event.stop();
		
		// check if the tabs are already visible
		folder = $('development').getElement( '.foldcontent' );
		visible = folder.getStyle( 'display' ) == 'block';
		
		// show or hide the tabs
		folder.setStyle( 'display', ( visible ? 'none' : 'block' ) );
				
		// toggle the arrows
		$('development').getElement( '.folder a' ).innerHTML = ( visible ? '&raquo;' : '&laquo;' );	
	});

	// setup the tabs
	$$('#development .element').each( function( elm ) {
		
		title = elm.getElement( 'a' );
				
		title.addEvent( 'click', function( event ) {
			
			// get the event and stop it
			event = new Event( event );
			event.stop();
		
			// get the current content element
			content = elm.getElement( '.content' );
			visible = content.getStyle( 'display' ) == 'block';
			
			// hide all visible elements
			$$('#development .element .content').each( function( m ) {
				m.setStyle( 'display', 'none' );
			});		
			
			// toggle the display on the current element
			if ( visible )			
				content.setStyle( 'display', 'none' );
			else
				content.setStyle( 'display', 'block' );						
		});		
	});	
}


/**
 * Setup the mouseover for the content items 
 */
function initContentElements( parentId )
{
	// get all content elements from the element with the given id
	$(parentId).getElements( '.content_element' ).each( function( elm ) {
	
		elm.addEvents({
			'mouseover': function() {			
				elm.addClass( 'content_element_selected' );		
			},	
			'mouseout': function() {
				elm.removeClass( 'content_element_selected' );
			}
		});
	});
}


/**
 * Fix the height of manuel 
 */
function fixManuelLength( )
{
	help = $('help_frame');
	
	if ( help == null )
		return;
	
	help = help.getElement( '.body_inner' );
	
	if ( help == null )
		return;
	
	hsize = help.getCoordinates();	
	
	p = $('help_bar');
	if ( p != null )
	{
		psize = p.getCoordinates();	
		help.setStyle("height", psize.height + psize.top - hsize.top - 8);
	}
}

/**
 * Fix the length of the left menu
 */
function fixMenuLength() 
{
	menu = $('menu_content_frame');
	
	if ( menu == null )
		return;
	
	menu = menu.getElement( '.body_inner' );
	
	if ( menu == null )
		return;
		
	column = menu.getParent().getParent().getParent().getParent();
	
	menu_c = menu.getCoordinates( column );
	column_s = column.getSize();
	
	
	menu.setStyle( "height", column_s.y - menu_c.top - 8 );
	
	//alert( menu_c.top + " " + menu_c.height + " " + column_s.y ); 
}

/**
 * Initialize zoek artiest
 */
var currentDialog = null
function initZoekArtiest( key )
{
	$('zoekartiesten').addEvent('submit', function(e) {
		
		if ( currentDialog != null && currentDialog.isShowing( ) )
			return;
		
		var form = $('zoekartiesten');			
		new Event(e).stop();
		
		var artist = form.getElement('input[type=text]').get('value');
		
		if ( artist == null || artist == "" )
			return;
		
		currentDialog = new AjaxDialog( 500 ).requestShow("zoek"+key+"artiest",{"search":artist});
	});
}

/**
 * Show a default message
 */
function showMessage( message, icon )
{
	new MessageDialog( 500, 300, '', message, icon ).show();	
}

function initTest( )
{
	var box = new MessageDialog( 500, 300, '', 'blaat' );
	box.show();
}

/**
 * MOLLIE BETAAL METHODE
 */
function mollie_start( servicenumber, paycode )
{
	var url = baseurl+'ajax/?query=mollie&servicenumber='+servicenumber+'&paycode='+paycode;
		
	// setup the request and send it
	var request = new Json.Remote(url, {
		onComplete: function(jsonObj) {
			mollie_handle_poll(jsonObj.properties);
		}
	}).send();	
}

function mollie_handle_poll( properties )
{
	mollie_set_progress( properties.percentage );
	var interval = 15000;
	
	if ( properties.percentage > 0 )
		interval = 10000;	

	if ( properties.paid == 'false' )
		setTimeout( "mollie_start('"+properties.servicenumber+"','"+properties.paycode+"')", interval );
	//else
	//	document.getElementById('mollie_submit_button').style.display = 'block';
}

function mollie_set_progress( percentage )
{
	var indicator = document.getElementById( 'indicator' );
	indicator.innerHTML = percentage + '%';
	
	if ( percentage >= 100 )
		indicator.style.width = 'auto';
	else
		indicator.style.width = percentage + '%';
}

/*
 * Phone class for mobile phone selection
 */
var phones = Array();
var Phone = new Class({
	
	initialize: function( brand, phonetype, phoneid ) {
		
		this.brand = brand;
		this.phonetype = phonetype;
		this.phoneid = phoneid;
	},
	
	getBrand: function( ) {
		return this.brand;
	},
	
	getType: function( ) {
		return this.phonetype;
	},
	
	getId: function( ) {
		return this.phoneid;
	}

}); 

function addPhone( brand, phonetype, phoneid )
{
    if ( phonetype.length == "" )
        return;

    phones[phones.length] = new Phone( brand, phonetype, phoneid );
}

function selectPhoneBrand( dropdown )
{
    var brand = dropdown.value;
    var elm = document.getElementById('phonetypeid');

    // remove all elements
    elm.options.length = 0;

    // fill it with the elements of the brand
    count = 0;
    for ( i = 0; i < phones.length; i++ )
    {
        if ( phones[i].getBrand( ) == brand )
        {
            elm.options[count++] = new Option(phones[i].getType(),phones[i].getId());
        }
    }
}


/**
 * Shopping basket
 */
var ShoppingBasket = new Class({

	initialize: function( ) {
	
		this.shopitems = $('winkelwagen_layout').getElement('.shopitems');
		
		this.shoptotal = $('winkelwagen_layout').getElement('.shoptotal .price');
		
	},
	
	/**
	 * Remove an item from the shopping basket
	 */
	removeItem: function( id, src ) {
		
		src = new Element( src ); 		
		this.execute( 'remove', id, function( jsonObj ) {		
			var shopNode = src.getParent().getParent();
			shopNode.setStyle( 'overflow', 'hidden' );
			
			var fx = new Fx.Styles( shopNode, {duration: 500, wait: false} );
			fx.start({
				'height': 0,
				'padding': 0
			}).chain( function( ) {
				shopNode.getParent().removeChild( shopNode );
				this.updateTotalPrice( jsonObj.properties.pricetotal );
				this.updateWinkelwagenCount( jsonObj.properties.shopcount );
			}.bind( this ));			
						
		}.bind( this ));
	},

	/**
	 * Increase or lower quantity
	 */
	changeQuantity: function( change, id, src ) {
	
		src = new Element( src );
		var node = src.getParent().getElement( 'span.quantity_value' );
		var value = parseInt( node.get('html') )+change;
		
		if ( value < 1 )
			return;
		
		if ( change < 0 )
			change = 'changedown';
		else
			change = 'changeup'; 
		 
		this.execute( change, id, function( jsonObj ) {
			node.set('html',value);
			this.updateTotalPrice( jsonObj.properties.pricetotal ); 
		}.bind( this ) );
	},
	
	/**
	 * Update Total Price
	 */
	updateTotalPrice: function( price ) {
		this.shoptotal.set( 'html', price );
	},
	
	/**
	 * Update the item count in the shoppingbasket
	 */
	updateWinkelwagenCount: function( count ) {		
		if ( count == 0 ) // winkelwagen is leeg
			$('header_links').getElement( '.winkelwagencount' ).empty( );
		else
			$('header_links').getElement( '.winkelwagencount .count' ).set( 'html', count );
	},


	/**
	 * Execute an ajax action
	 */
	execute: function( action, id, runOnSuccess ) {
		var url = baseurl+'ajax/?query=action&method=basket&action='+action+'&item='+id;
		var request = new Json.Remote(url, {onComplete: runOnSuccess}).send();		
	}
});

/**
 * SMS voeg nummer toe
 */
var SmsClass = new Class({
	
	initialize: function( formname ) {
	
		this.formname = formname;
		this.form = $(formname);
		this.numberField = this.form.getElement( 'input[name=nieuwnummer]' );
		this.numberList = this.form.getElement( 'ul.checklist' );	
		this.berichten = this.form.getElement( 'table td.berichten' );
		this.bundel = this.form.getElement( 'table td.bundel' );
		this.verzendkosten = this.form.getElement( 'table td.verzendkosten' );
		this.initNumberListeners();	
		this.updateOverview();	
	},
	
	initNumberListeners: function( ) {
	
		// setup change listener for all the numbers 
		this.numberList.getElements( 'li input' ).each( function( elm ) {
			
			elm.addEvent( 'change', this.updateOverview.bindWithEvent( this ) );
		
		}.bind( this ));
	},
	
	updateOverview: function( ) {
		// get the amount of selected numbers
		var selected = 0;
		this.numberList.getElements( 'li input' ).each( function( elm ) {
			if ( elm.get('checked') )
				selected++;			
		});
		
		// get the amount of sms in the bundle
		var inbundel = parseInt( this.bundel.get('html') );
		
		// calculate the price of the sms' which are going to be send			
		var bedrag = 0.00;
		if ( inbundel < selected )
			bedrag = 0.12 * ( selected - inbundel )
		
		// update the overview
		this.berichten.set( 'html', selected );
		this.verzendkosten.set('html', '&euro; '+bedrag);
	},
	
	addNumber: function( ) {
	
		var newNumber = this.numberField.get('value');
		
		// check for correct length
		if ( newNumber.length != 10 )
		{
			new MessageDialog( 500, '', '', 'Je ingevulde telefoonnummer is niet correct. Een juist telefoonnummer bestaat uit 10 cijfers.' ).show();
			return;		
		}	
		
		// check if the number isn't already in the list
		var nummer = $('sms_ontvangers_'+newNumber);
		if ( nummer != null )
		{
			new MessageDialog( 500, '', '', 'Het gekozen nummer zit al in je lijst.' ).show();
			return;
		}
				
		this.numberList.appendChild( new Element( 'li' ) )		
			.appendChild( new Element( 'label', {
				'for': 'sms_ontvangers_'+newNumber				
			}))
			.appendChild( new Element( 'input', {
				'id': 'sms_ontvangers_'+newNumber,
				'name': 'sms_ontvangers_'+newNumber,
				'class': 'checkbox',
				'type': 'checkbox',
				'value': 'on',
				'checked': 'checked'			
			}))
			.addEvent( 'change', this.updateOverview.bindWithEvent( this ) )
			.getParent()
			.appendChild( new Element( 'span', {
				'html': '&nbsp;'+newNumber
			}));
			
		this.updateOverview();
		this.numberField.set('value', '');
	}
});


/**
 * Verkooppunten
 */
var verkooppuntLock = false;
function showVerkooppuntAdres( src, plaatsnaam, provincie ) 
{
	if ( verkooppuntLock )
		return;
		
	verkooppuntLock = true;

	// create a new element as Internet explorer does assign functions automatically
	src = new Element( src );
	dst = $('verkooppunten_adressen');
	spin = $('verkooppunten_spinner');
	
	dst.setStyle( 'display', 'none' );
	spin.setStyle( 'display', 'block' );
	

	// remove all selects
	$$('#verkooppunten_layout .plaatsen .plaats a').each( function( elm ) {
		elm.removeClass( 'selected' );
	});		
	
	src.addClass( 'selected' );

	// create the url
	var url = baseurl+'ajax/?query=html&data=verkooppunt&plaats='+plaatsnaam+'&provincie='+provincie;

	// setup the request and send it
	var request = new Json.Remote(url, {
		autoCancel: true,
		onComplete: function(jsonObj) 
		{
			spin.setStyle('display', 'none' );
			dst.setStyle('visibility', 'hidden');
			dst.setStyle('display', 'block');
			dst.set('html',jsonObj.properties.html);
			dst.setStyle('top','0px');
						
			var cSrc = src.getCoordinates( );
			var cDst = dst.getCoordinates( );
			var cPrnt = src.getParent().getParent().getCoordinates( );
			
			var movement = cSrc.top - cDst.top;
			var height = cPrnt.height;
			var dheight = cDst.height;
			
			if ( height < dheight + movement )
				movement -= dheight + movement - height;
				
			if ( movement < 0 )
				movement = 0;
		
			dst.setStyle('top', movement );			
			dst.setStyle('visibility', 'visible');
			verkooppuntLock = false;
		}
	}).send();
}

/**
 * Home - wat geef je
 */
function homeWatGeefIk( )
{
	$$('#watgeefik .types .type').each( function( elm ) {
	
		elm.addEvents( {
			"mouseover": function(event){
			
				// remove all highlights
				$$('#watgeefik .icons .icon').each(function(icon){
					icon.removeClass("highlighted");
				});
				
				var iconId = elm.get('id').replace(/type-/, "icon-");
				var icon = $(iconId);
				
				if (icon != null) 
					icon.addClass("highlighted");
				
				elm.addClass( "selected" );
			},
			"mouseout": function(event){
				elm.removeClass( "selected" ); 
			}					
		});
	});	
}

/**
 * Home - roulerende actie banner
 */
function homeActieBanner( )
{
	var tabparents = $$('#home_acties .tabs, #home_acties .slides');
	var tabs = $$('#home_acties .tabs .tab');
	var slides = $$('#home_acties .slides .slide');
	var nSlide = slides.length;
	var iSlide = nSlide-1;
	
	// if there only 1 or less slides, dont do anything
	if ( nSlide <= 1 )
		return;
	
	// disable the timer when we mouse over the tabs or slides
	tabparents.each( function( p ) {
		
		p.addEvents( {
			"mouseover": function( event ) {
				$clear( timer );
			},
			"mouseout": function( event ) {
				timer = slider.periodical( 6000 );		
			} 	
		});
	});
	
	// show a slide when we mouseover a tab
	var tabindex = 0;
	tabs.each( function( tab ) {
		
		var tindex = tabindex++;
				
		tab.addEvents( {			
			"mouseover": function( event ) {
				iSlide = tindex;
				 
				for( var i = 0; i < nSlide; i++ )
					if ( i <= tindex )
						slides[i].set('opacity', 1);
					else
						slides[i].set('opacity', 0);
			
				tabs.each( function( tab ) { tab.removeClass( "selected" );	});	
				tabs[tindex].addClass( "selected" );
			}				
		});			
	});
	
	var slider = function( ) {
		
		if ( iSlide <= 0 ) 
		{			
			iSlide = nSlide-1;
		
			// get the last invisible slide
			var slide = slides[iSlide];

			// switch tab
			tabs.each( function( tab ) { tab.removeClass( "selected" );	});					
			tabs[iSlide].addClass( "selected" );
			
			// fade the last slide back in.
			var fx = new Fx.Tween(slide, {duration: 2000});
			fx.start('opacity', 1)
			  .chain( function( ) {
				for ( var i = 0; i < iSlide; i++ )
					slides[iSlide].set('opacity', 1);
			  });					
		}
		else 
		{
			// get the current visible slide
			var slide = slides[iSlide];
			
			// fade the current slide		
			var fx = new Fx.Tween(slide, {duration: 2000});
			fx.start('opacity', 0);			
			
			iSlide--;
			
			// switch tab
			tabs.each( function( tab ) { tab.removeClass( "selected" );	});					
			tabs[iSlide].addClass( "selected" );
			console.log("slide2: "+iSlide);		
		}			
	};
	
	var timer = slider.periodical( 6000 );
}

/**
 * Ecard - set card
 */
function ecardSetSelectedCard( result, image )
{
	$('kadobon_stap3').getElement('.verzendgegevens input[name=email_cardidx]').set('value',result);	
	var imageDiv = $('kadobon_stap3').getElement('.verzendgegevens .selected_ecard_image');
	
	if ( image.isInteger() ) 
	{
		imageDiv
			.setStyle("background", 'url(' + baseurl + 'web/img/imagescaler.php?type=ecard&item=' + image + '&width=120&height=90)')
			.setStyle("width", 120);
	}
	else
	{
		imageDiv
			.setStyle("background", 'url(' + baseurl + 'web/img/imagescaler.php?type=customecard&item=' + escape(image) + '&width=120&height=90)')
			.setStyle("width", 120);	
	}		
}

/**
 * Kadobon korting
 */
function addKadobonKorting( percentage, totaalbedrag )
{
	$('kadobon_stap4').getElement( '.kosten .korting .bedrag' ).set('html', percentage );
	$('kadobon_stap4').getElement( '.kosten .totaalbedrag .value' ).set('html', totaalbedrag );
}

/**
 * Feedback message
 */

function showFeedback( message )
{
	var slider = null;
	
	$('header')
		.appendChild( slider = new Element( 'div', {
			'class': "phpfeedback",
			'html': message	
		}));
		
	var size = slider.getSize();
	
	if ( size.x > 400 )
	{
		slider.setStyle( 'width', 400 );
		size = slider.getSize();
	}
	
	var height = size.y;
	slider.setStyle( 'top', "-"+height+"px" );	
	slider.setStyle( 'visibility', 'visible' ); 
	   		
	var fx = new Fx.Tween( slider );
	fx.start( 'top', 0 )
      .chain( function( ) { 
	  		fx.start.delay( 4000, this, [ 'top', "-"+height+"px" ] );
		})
	  .chain( function( ) {
			fx.set( 'visibility', 'hidden' );
	  });	 
}


/**
 * JS Calendar
 */
function initCalendar( )
{
	myCal = new Calendar(
		{ 	dateselector: 'd-m-Y'	
		}, 
		{ 	classes: ['calendar'], 
			direction: .5, 
			draggable: false,
			offset: 1,
			months: [ 
				"Januari", 
				"Februari", 
				"Maart", 
				"April", 
				"Mei", 
				"Juni", 
				"Juli", 
				"Augustus", 
				"September", 
				"Oktober", 
				"November", 
				"December" ],
			days: [
				"Z",
				"M",
				"D",
				"W",
				"D",
				"V",
				"Z" ] 
		});
}
 

