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

var MooTools={version:"1.2.3",build:"4980aa0fb74d2f6eb80bcd9f5b8e1fd6fbb8f607"};var Native=function(k){k=k||{};var a=k.name;var i=k.legacy;var b=k.protect;
var c=k.implement;var h=k.generics;var f=k.initialize;var g=k.afterImplement||function(){};var d=f||i;h=h!==false;d.constructor=Native;d.$family={name:"native"};
if(i&&f){d.prototype=i.prototype;}d.prototype.constructor=d;if(a){var e=a.toLowerCase();d.prototype.$family={name:e};Native.typize(d,e);}var j=function(n,l,o,m){if(!b||m||!n.prototype[l]){n.prototype[l]=o;
}if(h){Native.genericize(n,l,b);}g.call(n,l,o);return n;};d.alias=function(n,l,p){if(typeof n=="string"){var o=this.prototype[n];if((n=o)){return j(this,l,n,p);
}}for(var m in n){this.alias(m,n[m],l);}return this;};d.implement=function(m,l,o){if(typeof m=="string"){return j(this,m,l,o);}for(var n in m){j(this,n,m[n],l);
}return this;};if(c){d.implement(c);}return d;};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.implement=function(d,c){for(var b=0,a=d.length;b<a;b++){d[b].implement(c);}};Native.typize=function(a,b){if(!a.type){a.type=function(c){return($type(c)===b);
};}};(function(){var a={Array:Array,Date:Date,Function:Function,Number:Number,RegExp:RegExp,String:String};for(var h in a){new Native({name:h,initialize:a[h],protect:true});
}var d={"boolean":Boolean,"native":Native,object:Object};for(var c in d){Native.typize(d[c],c);}var f={Array:["concat","indexOf","join","lastIndexOf","pop","push","reverse","shift","slice","sort","splice","toString","unshift","valueOf"],String:["charAt","charCodeAt","concat","indexOf","lastIndexOf","match","replace","search","slice","split","substr","substring","toLowerCase","toUpperCase","valueOf"]};
for(var e in f){for(var b=f[e].length;b--;){Native.genericize(a[e],f[e][b],true);}}})();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({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;},getLength:function(){var b=0;for(var a in this){if(this.hasOwnProperty(a)){b++;
}}return b;}});Hash.alias("forEach","each");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(b){if(b.item){var a=b.length,c=new Array(a);while(a--){c[a]=b[a];}return c;}return Array.prototype.slice.call(b);}function $arguments(a){return function(){return arguments[a];
};}function $chk(a){return !!(a||a===0);}function $clear(a){clearTimeout(a);clearInterval(a);return null;}function $defined(a){return(a!=undefined);}function $each(c,b,d){var a=$type(c);
((a=="arguments"||a=="collection"||a=="array")?Array:Hash).each(c,b,d);}function $empty(){}function $extend(c,a){for(var b in (a||{})){c[b]=a[b];}return c;
}function $H(a){return new Hash(a);}function $lambda(a){return($type(a)=="function")?a:function(){return a;};}function $merge(){var a=Array.slice(arguments);
a.unshift({});return $mixin.apply(null,a);}function $mixin(e){for(var d=1,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")?$mixin(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;};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;}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=new Hash(c);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;}var Browser=$merge({Engine:{name:"unknown",version:0},Platform:{name:(window.orientation!=undefined)?"ipod":(navigator.platform.match(/mac|win|linux/i)||["other"])[0].toLowerCase()},Features:{xpath:!!(document.evaluate),air:!!(window.runtime),query:!!(document.querySelector)},Plugins:{},Engines:{presto:function(){return(!window.opera)?false:((arguments.callee.caller)?960:((document.getElementsByClassName)?950:925));
},trident:function(){return(!window.ActiveXObject)?false:((window.XMLHttpRequest)?5:4);},webkit:function(){return(navigator.taintEnabled)?false:((Browser.Features.xpath)?((Browser.Features.query)?525:420):419);
},gecko:function(){return(document.getBoxObjectFor==undefined)?false:((document.getElementsByClassName)?19:18);}}},Browser||{});Browser.Platform[Browser.Platform.name]=true;
Browser.detect=function(){for(var b in this.Engines){var a=this.Engines[b]();if(a){this.Engine={name:b,version:a};this.Engine[b]=this.Engine[b+a]=true;
break;}}return{name:b,version:a};};Browser.detect();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],10)||0,build:parseInt(a[2],10)||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[(Browser.Engine.webkit&&Browser.Engine.version<420)?"innerText":"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]]"]:{};
}a.document.window=a;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];if(Browser.Engine.trident&&Browser.Engine.version<=4){$try(function(){a.execCommand("BackgroundImageCache",false,true);
});}if(Browser.Engine.trident){a.window.attachEvent("onunload",function(){a.window.detachEvent("onunload",arguments.callee);a.head=a.html=a.window=null;
});}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();};},run:function(a,b){return this.apply(b,$splat(a));},pass:function(a,b){return this.create({bind:b,arguments:a});},bind:function(b,a){return this.create({bind:b,arguments:a});
},bindWithEvent:function(b,a){return this.create({bind:b,arguments:a,event:true});},attempt:function(a,b){return this.create({bind:b,arguments:a,attempt:true})();
},delay:function(b,c,a){return this.create({bind:c,arguments:a,delay:b})();},periodical:function(c,b,a){return this.create({bind:b,arguments:a,periodical:c})();
}});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(a,b){if(this[a]==undefined){this[a]=b;}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;}});function Class(b){if(b instanceof Function){b={initialize:b};}var a=function(){Object.reset(this);if(a._prototyping){return this;
}this._current=$empty;var c=(this.initialize)?this.initialize.apply(this,arguments):this;delete this._current;delete this.caller;return c;}.extend(this);
a.implement(b);a.constructor=Class;a.prototype.constructor=a;return a;}Function.prototype.protect=function(){this._protected=true;return this;};Object.reset=function(a,c){if(c==null){for(var e in a){Object.reset(a,e);
}return a;}delete a[c];switch($type(a[c])){case"object":var d=function(){};d.prototype=a[c];var b=new d;a[c]=Object.reset(b);break;case"array":a[c]=$unlink(a[c]);
break;}return a;};new Native({name:"Class",initialize:Class}).extend({instantiate:function(b){b._prototyping=true;var a=new b;delete b._prototyping;return a;
},wrap:function(a,b,c){if(c._origin){c=c._origin;}return function(){if(c._protected&&this._current==null){throw new Error('The method "'+b+'" cannot be called.');
}var e=this.caller,f=this._current;this.caller=f;this._current=arguments.callee;var d=c.apply(this,arguments);this._current=f;this.caller=e;return d;}.extend({_owner:a,_origin:c,_name:b});
}});Class.implement({implement:function(a,d){if($type(a)=="object"){for(var e in a){this.implement(e,a[e]);}return this;}var f=Class.Mutators[a];if(f){d=f.call(this,d);
if(d==null){return this;}}var c=this.prototype;switch($type(d)){case"function":if(d._hidden){return this;}c[a]=Class.wrap(this,a,d);break;case"object":var b=c[a];
if($type(b)=="object"){$mixin(b,d);}else{c[a]=$unlink(d);}break;case"array":c[a]=$unlink(d);break;default:c[a]=d;}return this;}});Class.Mutators={Extends:function(a){this.parent=a;
this.prototype=Class.instantiate(a);this.implement("parent",function(){var b=this.caller._name,c=this.caller._owner.parent.prototype[b];if(!c){throw new Error('The method "'+b+'" has no parent.');
}return c.apply(this,arguments);}.protect());},Implements:function(a){$splat(a).each(function(b){if(b instanceof Function){b=Class.instantiate(b);}this.implement(b);
},this);}};var Chain=new Class({$chain:[],chain:function(){this.$chain.extend(Array.flatten(arguments));return this;},callChain:function(){return(this.$chain.length)?this.$chain.shift().apply(this,arguments):false;
},clearChain:function(){this.$chain.empty();return this;}});var Events=new Class({$events:{},addEvent:function(c,b,a){c=Events.removeOn(c);if(b!=$empty){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[b]){return this;}if(!a.internal){this.$events[b].erase(a);}return this;},removeEvents:function(c){var d;if($type(c)=="object"){for(d in c){this.removeEvent(d,c[d]);
}return this;}if(c){c=Events.removeOn(c);}for(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;}});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 document.id(a).set(b);},afterImplement:function(a,b){Element.Prototype[a]=b;
if(Array[a]){return;}Elements.implement(a,function(){var c=[],g=true;for(var e=0,d=this.length;e<d;e++){var f=this[e][a].apply(this[e],arguments);c.push(f);
if(g){g=($type(f)=="element");}}return(g)?new Elements(c):c;});}});Element.Prototype={$family:{name:"element"}};Element.Constructors=new Hash;var IFrame=new Native({name:"IFrame",generics:false,initialize:function(){var f=Array.link(arguments,{properties:Object.type,iframe:$defined});
var d=f.properties||{};var c=document.id(f.iframe);var e=d.onload||$empty;delete d.onload;d.id=d.name=$pick(d.id,d.name,c?(c.id||c.name):"IFrame_"+$time());
c=new Element(c||"iframe",d);var b=function(){var g=$try(function(){return c.contentWindow.location.host;});if(!g||g==window.location.host){var h=new Window(c.contentWindow);
new Document(c.contentWindow.document);$extend(h.Element.prototype,Element.Prototype);}e.call(c.contentWindow,c.contentWindow.document);};var a=$try(function(){return c.contentWindow;
});((a&&a.document.body)||window.frames[d.id])?b():c.addListener("load",b);return c;}});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=document.id(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));}});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 document.id(this.createElement(a)).set(b);},newTextNode:function(a){return this.createTextNode(a);
},getDocument:function(){return this;},getWindow:function(){return this.window;},id:(function(){var a={string:function(d,c,b){d=b.getElementById(d);return(d)?a.element(d,c):null;
},element:function(b,e){$uid(b);if(!e&&!b.$family&&!(/^object|embed$/i).test(b.tagName)){var c=Element.Prototype;for(var d in c){b[d]=c[d];}}return b;},object:function(c,d,b){if(c.toElement){return a.element(c.toElement(b),d);
}return null;}};a.textnode=a.whitespace=a.window=a.document=$arguments(0);return function(c,e,d){if(c&&c.$family&&c.uid){return c;}var b=$type(c);return(a[b])?a[b](c,e,d||document):null;
};})()});if(window.$==null){Window.implement({$:function(a,b){return document.id(a,b,this.document);}});}Window.implement({$$: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":f.push(e);break;case"string":f.extend(this.document.getElements(e,true));
}}return new Elements(f);},getDocument:function(){return this.document;},getWindow:function(){return this;}});Native.implement([Element,Document],{getElement:function(a,b){return document.id(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});}});(function(){var h={},f={};var i={input:"checked",option:"selected",textarea:(Browser.Engine.webkit&&Browser.Engine.version<420)?"innerHTML":"value"};
var c=function(l){return(f[l]||(f[l]={}));};var g=function(n,l){if(!n){return;}var m=n.uid;if(Browser.Engine.trident){if(n.clearAttributes){var q=l&&n.cloneNode(false);
n.clearAttributes();if(q){n.mergeAttributes(q);}}else{if(n.removeEvents){n.removeEvents();}}if((/object/i).test(n.tagName)){for(var o in n){if(typeof n[o]=="function"){n[o]=$empty;
}}Element.dispose(n);}}if(!m){return;}h[m]=f[m]=null;};var d=function(){Hash.each(h,g);if(Browser.Engine.trident){$A(document.getElementsByTagName("object")).each(g);
}if(window.CollectGarbage){CollectGarbage();}h=f=null;};var j=function(n,l,s,m,p,r){var o=n[s||l];var q=[];while(o){if(o.nodeType==1&&(!m||Element.match(o,m))){if(!p){return document.id(o,r);
}q.push(o);}o=o[l];}return(p)?new Elements(q,{ddup:false,cash:!r}):null;};var e={html:"innerHTML","class":"className","for":"htmlFor",defaultValue:"defaultValue",text:(Browser.Engine.trident||(Browser.Engine.webkit&&Browser.Engine.version<420))?"innerText":"textContent"};
var b=["compact","nowrap","ismap","declare","noshade","checked","disabled","readonly","multiple","selected","noresize","defer"];var k=["value","type","defaultValue","accessKey","cellPadding","cellSpacing","colSpan","frameBorder","maxLength","readOnly","rowSpan","tabIndex","useMap"];
b=b.associate(b);Hash.extend(e,b);Hash.extend(e,k.associate(k.map(String.toLowerCase)));var a={before:function(m,l){if(l.parentNode){l.parentNode.insertBefore(m,l);
}},after:function(m,l){if(!l.parentNode){return;}var n=l.nextSibling;(n)?l.parentNode.insertBefore(m,n):l.parentNode.appendChild(m);},bottom:function(m,l){l.appendChild(m);
},top:function(m,l){var n=l.firstChild;(n)?l.insertBefore(m,n):l.appendChild(m);}};a.inside=a.bottom;Hash.each(a,function(l,m){m=m.capitalize();Element.implement("inject"+m,function(n){l(this,document.id(n,true));
return this;});Element.implement("grab"+m,function(n){l(document.id(n,true),this);return this;});});Element.implement({set:function(o,m){switch($type(o)){case"object":for(var n in o){this.set(n,o[n]);
}break;case"string":var l=Element.Properties.get(o);(l&&l.set)?l.set.apply(this,Array.slice(arguments,1)):this.setProperty(o,m);}return this;},get:function(m){var l=Element.Properties.get(m);
return(l&&l.get)?l.get.apply(this,Array.slice(arguments,1)):this.getProperty(m);},erase:function(m){var l=Element.Properties.get(m);(l&&l.erase)?l.erase.apply(this):this.removeProperty(m);
return this;},setProperty:function(m,n){var l=e[m];if(n==undefined){return this.removeProperty(m);}if(l&&b[m]){n=!!n;}(l)?this[l]=n:this.setAttribute(m,""+n);
return this;},setProperties:function(l){for(var m in l){this.setProperty(m,l[m]);}return this;},getProperty:function(m){var l=e[m];var n=(l)?this[l]:this.getAttribute(m,2);
return(b[m])?!!n:(l)?n:n||null;},getProperties:function(){var l=$A(arguments);return l.map(this.getProperty,this).associate(l);},removeProperty:function(m){var l=e[m];
(l)?this[l]=(l&&b[m])?false:"":this.removeAttribute(m);return this;},removeProperties:function(){Array.each(arguments,this.removeProperty,this);return this;
},hasClass:function(l){return this.className.contains(l," ");},addClass:function(l){if(!this.hasClass(l)){this.className=(this.className+" "+l).clean();
}return this;},removeClass:function(l){this.className=this.className.replace(new RegExp("(^|\\s)"+l+"(?:\\s|$)"),"$1");return this;},toggleClass:function(l){return this.hasClass(l)?this.removeClass(l):this.addClass(l);
},adopt:function(){Array.flatten(arguments).each(function(l){l=document.id(l,true);if(l){this.appendChild(l);}},this);return this;},appendText:function(m,l){return this.grab(this.getDocument().newTextNode(m),l);
},grab:function(m,l){a[l||"bottom"](document.id(m,true),this);return this;},inject:function(m,l){a[l||"bottom"](this,document.id(m,true));return this;},replaces:function(l){l=document.id(l,true);
l.parentNode.replaceChild(this,l);return this;},wraps:function(m,l){m=document.id(m,true);return this.replaces(m).grab(m,l);},getPrevious:function(l,m){return j(this,"previousSibling",null,l,false,m);
},getAllPrevious:function(l,m){return j(this,"previousSibling",null,l,true,m);},getNext:function(l,m){return j(this,"nextSibling",null,l,false,m);},getAllNext:function(l,m){return j(this,"nextSibling",null,l,true,m);
},getFirst:function(l,m){return j(this,"nextSibling","firstChild",l,false,m);},getLast:function(l,m){return j(this,"previousSibling","lastChild",l,false,m);
},getParent:function(l,m){return j(this,"parentNode",null,l,false,m);},getParents:function(l,m){return j(this,"parentNode",null,l,true,m);},getSiblings:function(l,m){return this.getParent().getChildren(l,m).erase(this);
},getChildren:function(l,m){return j(this,"nextSibling","firstChild",l,true,m);},getWindow:function(){return this.ownerDocument.window;},getDocument:function(){return this.ownerDocument;
},getElementById:function(o,n){var m=this.ownerDocument.getElementById(o);if(!m){return null;}for(var l=m.parentNode;l!=this;l=l.parentNode){if(!l){return null;
}}return document.id(m,n);},getSelected:function(){return new Elements($A(this.options).filter(function(l){return l.selected;}));},getComputedStyle:function(m){if(this.currentStyle){return this.currentStyle[m.camelCase()];
}var l=this.getDocument().defaultView.getComputedStyle(this,null);return(l)?l.getPropertyValue([m.hyphenate()]):null;},toQueryString:function(){var l=[];
this.getElements("input, select, textarea",true).each(function(m){if(!m.name||m.disabled||m.type=="submit"||m.type=="reset"||m.type=="file"){return;}var n=(m.tagName.toLowerCase()=="select")?Element.getSelected(m).map(function(o){return o.value;
}):((m.type=="radio"||m.type=="checkbox")&&!m.checked)?null:m.value;$splat(n).each(function(o){if(typeof o!="undefined"){l.push(m.name+"="+encodeURIComponent(o));
}});});return l.join("&");},clone:function(o,l){o=o!==false;var r=this.cloneNode(o);var n=function(v,u){if(!l){v.removeAttribute("id");}if(Browser.Engine.trident){v.clearAttributes();
v.mergeAttributes(u);v.removeAttribute("uid");if(v.options){var w=v.options,s=u.options;for(var t=w.length;t--;){w[t].selected=s[t].selected;}}}var x=i[u.tagName.toLowerCase()];
if(x&&u[x]){v[x]=u[x];}};if(o){var p=r.getElementsByTagName("*"),q=this.getElementsByTagName("*");for(var m=p.length;m--;){n(p[m],q[m]);}}n(r,this);return document.id(r);
},destroy:function(){Element.empty(this);Element.dispose(this);g(this,true);return null;},empty:function(){$A(this.childNodes).each(function(l){Element.destroy(l);
});return this;},dispose:function(){return(this.parentNode)?this.parentNode.removeChild(this):this;},hasChild:function(l){l=document.id(l,true);if(!l){return false;
}if(Browser.Engine.webkit&&Browser.Engine.version<420){return $A(this.getElementsByTagName(l.tagName)).contains(l);}return(this.contains)?(this!=l&&this.contains(l)):!!(this.compareDocumentPosition(l)&16);
},match:function(l){return(!l||(l==this)||(Element.get(this,"tag")==l));}});Native.implement([Element,Window,Document],{addListener:function(o,n){if(o=="unload"){var l=n,m=this;
n=function(){m.removeListener("unload",n);l();};}else{h[this.uid]=this;}if(this.addEventListener){this.addEventListener(o,n,false);}else{this.attachEvent("on"+o,n);
}return this;},removeListener:function(m,l){if(this.removeEventListener){this.removeEventListener(m,l,false);}else{this.detachEvent("on"+m,l);}return this;
},retrieve:function(m,l){var o=c(this.uid),n=o[m];if(l!=undefined&&n==undefined){n=o[m]=l;}return $pick(n);},store:function(m,l){var n=c(this.uid);n[m]=l;
return this;},eliminate:function(l){var m=c(this.uid);delete m[l];return this;}});window.addListener("unload",d);})();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.html=(function(){var c=document.createElement("div");var a={table:[1,"<table>","</table>"],select:[1,"<select>","</select>"],tbody:[2,"<table><tbody>","</tbody></table>"],tr:[3,"<table><tbody><tr>","</tr></tbody></table>"]};
a.thead=a.tfoot=a.tbody;var b={set:function(){var e=Array.flatten(arguments).join("");var f=Browser.Engine.trident&&a[this.get("tag")];if(f){var g=c;g.innerHTML=f[1]+e+f[2];
for(var d=f[0];d--;){g=g.firstChild;}this.empty().adopt(g.childNodes);}else{this.innerHTML=e;}}};b.erase=b.set;return b;})();if(Browser.Engine.webkit&&Browser.Engine.version<420){Element.Properties.text={get:function(){if(this.innerText){return this.innerText;
}var a=this.ownerDocument.newElement("div",{html:this.innerHTML}).inject(this.ownerDocument.body);var b=a.innerText;a.destroy();return b;}};}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 true;};}f=a.base||f;}var d=function(){return g.call(i);};var b=Element.NativeEvents[f];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(c,b){var a=this.retrieve("events");if(!a||!a[c]){return this;
}var f=a[c].keys.indexOf(b);if(f==-1){return this;}a[c].keys.splice(f,1);var e=a[c].values.splice(f,1)[0];var d=Element.Events.get(c);if(d){if(d.onRemove){d.onRemove.call(this,b);
}c=d.base||c;}return(Element.NativeEvents[c])?this.removeListener(c,e):this;},addEvents:function(a){for(var b in a){this.addEvent(b,a[b]);}return this;
},removeEvents:function(a){var c;if($type(a)=="object"){for(c in a){this.removeEvent(c,a[c]);}return this;}var b=this.retrieve("events");if(!b){return this;
}if(!a){for(c in b){this.removeEvents(c);}this.eliminate("events");}else{if(b[a]){while(b[a].keys[0]){this.removeEvent(a,b[a].keys[0]);}b[a]=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=document.id(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,10)))){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.flatten(arguments).each(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(){if(this.getBoundingClientRect){var m=this.getBoundingClientRect(),k=document.id(this.getDocument().documentElement),i=k.getScroll(),n=(d(this,"position")=="fixed");
return{x:parseInt(m.left,10)+((n)?0:i.x)-k.clientLeft,y:parseInt(m.top,10)+((n)?0:i.y)-k.clientTop};}var j=this,h={x:0,y:0};if(b(this)){return h;}while(j&&!b(j)){h.x+=j.offsetLeft;
h.y+=j.offsetTop;if(Browser.Engine.gecko){if(!f(j)){h.x+=c(j);h.y+=g(j);}var l=j.parentNode;if(l&&d(l,"overflow")!="visible"){h.x+=c(l);h.y+=g(l);}}else{if(j!=this&&Browser.Engine.webkit){h.x+=c(j);
h.y+=g(j);}}j=j.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=document.id(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")};
},setPosition:function(h){return this.setStyles(this.computePosition(h));}});Native.implement([Document,Window],{getSize:function(){if(Browser.Engine.presto||Browser.Engine.webkit){var i=this.getWindow();
return{x:i.innerWidth,y:i.innerHeight};}var h=a(this);return{x:h.clientWidth,y:h.clientHeight};},getScroll:function(){var i=this.getWindow(),h=a(this);
return{x:i.pageXOffset||h.scrollLeft,y:i.pageYOffset||h.scrollTop};},getScrollSize:function(){var i=a(this),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;
}})();Element.alias("setPosition","position");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||(b==this)){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+)(?:([!*^$~|]?=)(["']?)([^\4]*?)\4)?\]|:([\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(h){if(Selectors.Cache.nth[h]){return Selectors.Cache.nth[h];
}var e=h.match(/^([+-]?\d*)?([a-z]+)?([+-]?\d*)?$/);if(!e){return false;}var g=parseInt(e[1],10);var d=(g||g===0)?g:1;var f=e[2]||false;var c=parseInt(e[3],10)||0;
if(d!=0){c--;while(c<1){c+=d;}while(c>=d){c-=d;}}else{d=c;f="index";}switch(f){case"n":e={a:d,b:c,special:"n"};break;case"odd":e={a:2,b:0,special:"n"};
break;case"even":e={a:2,b:1,special:"n"};break;case"first":e={a:0,special:"index"};break;case"last":e={special:"last-child"};break;case"only":e={special:"only-child"};
break;default:e={a:(d-1),special:"index"};}return Selectors.Cache.nth[h]=e;},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[5],c=d[6],j=d[7];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(o,h,t){var b=[];var c=h.trim().replace(Selectors.RegExps.splitter,function(k,j,i){b.push(j);
return":)"+i;}).split(":)");var p,e,A;for(var z=0,v=c.length;z<v;z++){var y=c[z];if(z==0&&Selectors.RegExps.quick.test(y)){p=o.getElementsByTagName(y);
continue;}var a=b[z-1];var q=Selectors.Utils.parseTagAndID(y);var B=q[0],r=q[1];if(z==0){p=Selectors.Utils.getByTagAndID(o,B,r);}else{var d={},g=[];for(var x=0,w=p.length;
x<w;x++){g=Selectors.Getters[a](g,p[x],B,r,d);}p=g;}var f=Selectors.Utils.parseSelector(y);if(f){e=[];for(var u=0,s=p.length;u<s;u++){A=p[u];if(Selectors.Utils.filter(A,f,t)){e.push(A);
}}p=e;}}return p;}};Selectors.Getters={" ":function(h,g,j,a,e){var d=Selectors.Utils.getByTagAndID(g,j,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,j,a,f){var c=Selectors.Utils.getByTagAndID(g,j,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(b=="!=");}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({checked:function(){return this.checked;},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);},selected:function(){return this.selected;},enabled:function(){return(this.disabled===false);
}});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");};if(Browser.Engine.trident){var a=document.createElement("div");(function(){($try(function(){a.doScroll();
return document.id(a).inject(document.body).set("html","temp").dispose();}))?b():arguments.callee.delay(50);})();}else{if(Browser.Engine.webkit&&Browser.Engine.version<525){(function(){(["loaded","complete"].contains(document.readyState))?b():arguments.callee.delay(50);
})();}else{window.addEvent("load",b);document.addEvent("DOMContentLoaded",b);}}})();var JSON=new Hash({$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);
},encode:function(b){switch($type(b)){case"string":return'"'+b.replace(/[\x00-\x1f\\"]/g,JSON.$replaceChars)+'"';case"array":return"["+String(b.map(JSON.encode).clean())+"]";
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;},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=document.id(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=document.id(a,true);a.parentNode.replaceChild(this.toElement(),a);
return this;},inject:function(a){document.id(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"},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";
}},getTransition:function(){return function(a){return -(Math.cos(Math.PI*a)-1)/2;};},step:function(){var a=$time();if(a<this.time+this.options.duration){var b=this.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(){if(!this.timer){return true;}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(this.caller.bind(this,arguments));
return false;}return false;},start:function(b,a){if(!this.check(b,a)){return this;}this.from=b;this.to=a;this.time=0;this.transition=this.getTransition();
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(j,g){if(!j.style){return;}var h=(j.selectorText)?j.selectorText.replace(/^\w+/,function(i){return i.toLowerCase();
}):null;if(!h||!h.test("^"+a+"$")){return;}Element.Styles.each(function(k,i){if(!j.style[i]||Element.ShortStyles[i]){return;}k=String(j.style[i]);b[i]=(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=document.id(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(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=document.id(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(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;}});Fx.implement({getTransition:function(){var a=this.options.transition||Fx.Transitions.Sine.easeInOut;if(typeof a=="string"){var b=a.split(":");
a=Fx.Transitions;a=a[b[0]]||a[b[0].capitalize()];if(b[1]){a=a["ease"+b[1].capitalize()+(b[2]?b[2].capitalize():"")];}}return a;}});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(f){var e;for(var d=0,c=1;1;d+=c,c/=2){if(f>=(7-4*d)/11){e=c*c-Math.pow((11-6*d-11*f)/4,2);
break;}}return e;},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,noCache: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));this.xhr.onreadystatechange=$empty;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();}},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(){if(!this.running){return true;
}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(this.caller.bind(this,arguments));return false;}return false;},send:function(k){if(!this.check(k)){return this;
}this.running=true;var i=$type(k);if(i=="string"||i=="element"){k={data:k};}var d=this.options;k=$extend({data:d.data,url:d.url,method:d.method},k);var g=k.data,b=k.url,a=k.method.toLowerCase();
switch($type(g)){case"element":g=document.id(g).toQueryString();break;case"object":case"hash":g=Hash.toQueryString(g);}if(this.options.format){var j="format="+this.options.format;
g=(g)?j+"&"+g:j;}if(this.options.emulation&&!["get","post"].contains(a)){var h="_method="+a;g=(g)?h+"&"+g:h;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(this.options.noCache){var f="noCache="+new Date().getTime();g=(g)?f+"&"+g:f;
}var e=b.lastIndexOf("/");if(e>-1&&(e=b.indexOf("#"))>-1){b=b.substr(0,e);}if(g&&a=="get"){b=b+(b.contains("?")?"&":"?")+g;g=null;}this.xhr.open(a.toUpperCase(),b,this.options.async);
this.xhr.onreadystatechange=this.onStateChange.bind(this);this.headers.each(function(m,l){try{this.xhr.setRequestHeader(l,m);}catch(n){this.fireEvent("exception",[l,m]);
}},this);this.fireEvent("request");this.xhr.send(g);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}));};});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,append: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];if(!d){return null;}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){document.id(c.update).empty().set("html",b.html);}else{if(c.append){document.id(c.append).adopt(a.getChildren());}}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){b.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-2009 Aaron Newton <http://clientcide.com/>, Valerio Proietti <http://mad4milk.net> & the MooTools team <http://mootools.net/developers>, MIT Style License.

MooTools.More={version:"1.2.3.1"};Fx.Slide=new Class({Extends:Fx,options:{mode:"vertical"},initialize:function(b,a){this.addEvent("complete",function(){this.open=(this.wrapper["offset"+this.layout.capitalize()]!=0);
if(this.open&&Browser.Engine.webkit419){this.element.dispose().inject(this.wrapper);}},true);this.element=this.subject=document.id(b);this.parent(a);var c=this.element.retrieve("wrapper");
this.wrapper=c||new Element("div",{styles:$extend(this.element.getStyles("margin","position"),{overflow:"hidden"})}).wraps(this.element);this.element.store("wrapper",this.wrapper).setStyle("margin",0);
this.now=[];this.open=true;},vertical:function(){this.margin="margin-top";this.layout="height";this.offset=this.element.offsetHeight;},horizontal:function(){this.margin="margin-left";
this.layout="width";this.offset=this.element.offsetWidth;},set:function(a){this.element.setStyle(this.margin,a[0]);this.wrapper.setStyle(this.layout,a[1]);
return this;},compute:function(c,b,a){return[0,1].map(function(d){return Fx.compute(c[d],b[d],a);});},start:function(b,e){if(!this.check(b,e)){return this;
}this[e||this.options.mode]();var d=this.element.getStyle(this.margin).toInt();var c=this.wrapper.getStyle(this.layout).toInt();var a=[[d,c],[0,this.offset]];
var g=[[d,c],[-this.offset,0]];var f;switch(b){case"in":f=a;break;case"out":f=g;break;case"toggle":f=(c==0)?a:g;}return this.parent(f[0],f[1]);},slideIn:function(a){return this.start("in",a);
},slideOut:function(a){return this.start("out",a);},hide:function(a){this[a||this.options.mode]();this.open=false;return this.set([-this.offset,0]);},show:function(a){this[a||this.options.mode]();
this.open=true;return this.set([0,this.offset]);},toggle:function(a){return this.start("toggle",a);}});Element.Properties.slide={set:function(b){var a=this.retrieve("slide");
if(a){a.cancel();}return this.eliminate("slide").store("slide:options",$extend({link:"cancel"},b));},get:function(a){if(a||!this.retrieve("slide")){if(a||!this.retrieve("slide:options")){this.set("slide",a);
}this.store("slide",new Fx.Slide(this,this.retrieve("slide:options")));}return this.retrieve("slide");}};Element.implement({slide:function(d,e){d=d||"toggle";
var b=this.get("slide"),a;switch(d){case"hide":b.hide(e);break;case"show":b.show(e);break;case"toggle":var c=this.retrieve("slide:flag",b.open);b[c?"slideOut":"slideIn"](e);
this.store("slide:flag",!c);a=true;break;default:b.start(d,e);}if(!a){this.eliminate("slide:flag");}return this;}});/*	SWFObject v2.2 <http://code.google.com/p/swfobject/> 
	is released under the MIT License <http://www.opensource.org/licenses/mit-license.php> 
*/
var swfobject=function(){var D="undefined",r="object",S="Shockwave Flash",W="ShockwaveFlash.ShockwaveFlash",q="application/x-shockwave-flash",R="SWFObjectExprInst",x="onreadystatechange",O=window,j=document,t=navigator,T=false,U=[h],o=[],N=[],I=[],l,Q,E,B,J=false,a=false,n,G,m=true,M=function(){var aa=typeof j.getElementById!=D&&typeof j.getElementsByTagName!=D&&typeof j.createElement!=D,ah=t.userAgent.toLowerCase(),Y=t.platform.toLowerCase(),ae=Y?/win/.test(Y):/win/.test(ah),ac=Y?/mac/.test(Y):/mac/.test(ah),af=/webkit/.test(ah)?parseFloat(ah.replace(/^.*webkit\/(\d+(\.\d+)?).*$/,"$1")):false,X=!+"\v1",ag=[0,0,0],ab=null;if(typeof t.plugins!=D&&typeof t.plugins[S]==r){ab=t.plugins[S].description;if(ab&&!(typeof t.mimeTypes!=D&&t.mimeTypes[q]&&!t.mimeTypes[q].enabledPlugin)){T=true;X=false;ab=ab.replace(/^.*\s+(\S+\s+\S+$)/,"$1");ag[0]=parseInt(ab.replace(/^(.*)\..*$/,"$1"),10);ag[1]=parseInt(ab.replace(/^.*\.(.*)\s.*$/,"$1"),10);ag[2]=/[a-zA-Z]/.test(ab)?parseInt(ab.replace(/^.*[a-zA-Z]+(.*)$/,"$1"),10):0}}else{if(typeof O.ActiveXObject!=D){try{var ad=new ActiveXObject(W);if(ad){ab=ad.GetVariable("$version");if(ab){X=true;ab=ab.split(" ")[1].split(",");ag=[parseInt(ab[0],10),parseInt(ab[1],10),parseInt(ab[2],10)]}}}catch(Z){}}}return{w3:aa,pv:ag,wk:af,ie:X,win:ae,mac:ac}}(),k=function(){if(!M.w3){return}if((typeof j.readyState!=D&&j.readyState=="complete")||(typeof j.readyState==D&&(j.getElementsByTagName("body")[0]||j.body))){f()}if(!J){if(typeof j.addEventListener!=D){j.addEventListener("DOMContentLoaded",f,false)}if(M.ie&&M.win){j.attachEvent(x,function(){if(j.readyState=="complete"){j.detachEvent(x,arguments.callee);f()}});if(O==top){(function(){if(J){return}try{j.documentElement.doScroll("left")}catch(X){setTimeout(arguments.callee,0);return}f()})()}}if(M.wk){(function(){if(J){return}if(!/loaded|complete/.test(j.readyState)){setTimeout(arguments.callee,0);return}f()})()}s(f)}}();function f(){if(J){return}try{var Z=j.getElementsByTagName("body")[0].appendChild(C("span"));Z.parentNode.removeChild(Z)}catch(aa){return}J=true;var X=U.length;for(var Y=0;Y<X;Y++){U[Y]()}}function K(X){if(J){X()}else{U[U.length]=X}}function s(Y){if(typeof O.addEventListener!=D){O.addEventListener("load",Y,false)}else{if(typeof j.addEventListener!=D){j.addEventListener("load",Y,false)}else{if(typeof O.attachEvent!=D){i(O,"onload",Y)}else{if(typeof O.onload=="function"){var X=O.onload;O.onload=function(){X();Y()}}else{O.onload=Y}}}}}function h(){if(T){V()}else{H()}}function V(){var X=j.getElementsByTagName("body")[0];var aa=C(r);aa.setAttribute("type",q);var Z=X.appendChild(aa);if(Z){var Y=0;(function(){if(typeof Z.GetVariable!=D){var ab=Z.GetVariable("$version");if(ab){ab=ab.split(" ")[1].split(",");M.pv=[parseInt(ab[0],10),parseInt(ab[1],10),parseInt(ab[2],10)]}}else{if(Y<10){Y++;setTimeout(arguments.callee,10);return}}X.removeChild(aa);Z=null;H()})()}else{H()}}function H(){var ag=o.length;if(ag>0){for(var af=0;af<ag;af++){var Y=o[af].id;var ab=o[af].callbackFn;var aa={success:false,id:Y};if(M.pv[0]>0){var ae=c(Y);if(ae){if(F(o[af].swfVersion)&&!(M.wk&&M.wk<312)){w(Y,true);if(ab){aa.success=true;aa.ref=z(Y);ab(aa)}}else{if(o[af].expressInstall&&A()){var ai={};ai.data=o[af].expressInstall;ai.width=ae.getAttribute("width")||"0";ai.height=ae.getAttribute("height")||"0";if(ae.getAttribute("class")){ai.styleclass=ae.getAttribute("class")}if(ae.getAttribute("align")){ai.align=ae.getAttribute("align")}var ah={};var X=ae.getElementsByTagName("param");var ac=X.length;for(var ad=0;ad<ac;ad++){if(X[ad].getAttribute("name").toLowerCase()!="movie"){ah[X[ad].getAttribute("name")]=X[ad].getAttribute("value")}}P(ai,ah,Y,ab)}else{p(ae);if(ab){ab(aa)}}}}}else{w(Y,true);if(ab){var Z=z(Y);if(Z&&typeof Z.SetVariable!=D){aa.success=true;aa.ref=Z}ab(aa)}}}}}function z(aa){var X=null;var Y=c(aa);if(Y&&Y.nodeName=="OBJECT"){if(typeof Y.SetVariable!=D){X=Y}else{var Z=Y.getElementsByTagName(r)[0];if(Z){X=Z}}}return X}function A(){return !a&&F("6.0.65")&&(M.win||M.mac)&&!(M.wk&&M.wk<312)}function P(aa,ab,X,Z){a=true;E=Z||null;B={success:false,id:X};var ae=c(X);if(ae){if(ae.nodeName=="OBJECT"){l=g(ae);Q=null}else{l=ae;Q=X}aa.id=R;if(typeof aa.width==D||(!/%$/.test(aa.width)&&parseInt(aa.width,10)<310)){aa.width="310"}if(typeof aa.height==D||(!/%$/.test(aa.height)&&parseInt(aa.height,10)<137)){aa.height="137"}j.title=j.title.slice(0,47)+" - Flash Player Installation";var ad=M.ie&&M.win?"ActiveX":"PlugIn",ac="MMredirectURL="+O.location.toString().replace(/&/g,"%26")+"&MMplayerType="+ad+"&MMdoctitle="+j.title;if(typeof ab.flashvars!=D){ab.flashvars+="&"+ac}else{ab.flashvars=ac}if(M.ie&&M.win&&ae.readyState!=4){var Y=C("div");X+="SWFObjectNew";Y.setAttribute("id",X);ae.parentNode.insertBefore(Y,ae);ae.style.display="none";(function(){if(ae.readyState==4){ae.parentNode.removeChild(ae)}else{setTimeout(arguments.callee,10)}})()}u(aa,ab,X)}}function p(Y){if(M.ie&&M.win&&Y.readyState!=4){var X=C("div");Y.parentNode.insertBefore(X,Y);X.parentNode.replaceChild(g(Y),X);Y.style.display="none";(function(){if(Y.readyState==4){Y.parentNode.removeChild(Y)}else{setTimeout(arguments.callee,10)}})()}else{Y.parentNode.replaceChild(g(Y),Y)}}function g(ab){var aa=C("div");if(M.win&&M.ie){aa.innerHTML=ab.innerHTML}else{var Y=ab.getElementsByTagName(r)[0];if(Y){var ad=Y.childNodes;if(ad){var X=ad.length;for(var Z=0;Z<X;Z++){if(!(ad[Z].nodeType==1&&ad[Z].nodeName=="PARAM")&&!(ad[Z].nodeType==8)){aa.appendChild(ad[Z].cloneNode(true))}}}}}return aa}function u(ai,ag,Y){var X,aa=c(Y);if(M.wk&&M.wk<312){return X}if(aa){if(typeof ai.id==D){ai.id=Y}if(M.ie&&M.win){var ah="";for(var ae in ai){if(ai[ae]!=Object.prototype[ae]){if(ae.toLowerCase()=="data"){ag.movie=ai[ae]}else{if(ae.toLowerCase()=="styleclass"){ah+=' class="'+ai[ae]+'"'}else{if(ae.toLowerCase()!="classid"){ah+=" "+ae+'="'+ai[ae]+'"'}}}}}var af="";for(var ad in ag){if(ag[ad]!=Object.prototype[ad]){af+='<param name="'+ad+'" value="'+ag[ad]+'" />'}}aa.outerHTML='<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"'+ah+">"+af+"</object>";N[N.length]=ai.id;X=c(ai.id)}else{var Z=C(r);Z.setAttribute("type",q);for(var ac in ai){if(ai[ac]!=Object.prototype[ac]){if(ac.toLowerCase()=="styleclass"){Z.setAttribute("class",ai[ac])}else{if(ac.toLowerCase()!="classid"){Z.setAttribute(ac,ai[ac])}}}}for(var ab in ag){if(ag[ab]!=Object.prototype[ab]&&ab.toLowerCase()!="movie"){e(Z,ab,ag[ab])}}aa.parentNode.replaceChild(Z,aa);X=Z}}return X}function e(Z,X,Y){var aa=C("param");aa.setAttribute("name",X);aa.setAttribute("value",Y);Z.appendChild(aa)}function y(Y){var X=c(Y);if(X&&X.nodeName=="OBJECT"){if(M.ie&&M.win){X.style.display="none";(function(){if(X.readyState==4){b(Y)}else{setTimeout(arguments.callee,10)}})()}else{X.parentNode.removeChild(X)}}}function b(Z){var Y=c(Z);if(Y){for(var X in Y){if(typeof Y[X]=="function"){Y[X]=null}}Y.parentNode.removeChild(Y)}}function c(Z){var X=null;try{X=j.getElementById(Z)}catch(Y){}return X}function C(X){return j.createElement(X)}function i(Z,X,Y){Z.attachEvent(X,Y);I[I.length]=[Z,X,Y]}function F(Z){var Y=M.pv,X=Z.split(".");X[0]=parseInt(X[0],10);X[1]=parseInt(X[1],10)||0;X[2]=parseInt(X[2],10)||0;return(Y[0]>X[0]||(Y[0]==X[0]&&Y[1]>X[1])||(Y[0]==X[0]&&Y[1]==X[1]&&Y[2]>=X[2]))?true:false}function v(ac,Y,ad,ab){if(M.ie&&M.mac){return}var aa=j.getElementsByTagName("head")[0];if(!aa){return}var X=(ad&&typeof ad=="string")?ad:"screen";if(ab){n=null;G=null}if(!n||G!=X){var Z=C("style");Z.setAttribute("type","text/css");Z.setAttribute("media",X);n=aa.appendChild(Z);if(M.ie&&M.win&&typeof j.styleSheets!=D&&j.styleSheets.length>0){n=j.styleSheets[j.styleSheets.length-1]}G=X}if(M.ie&&M.win){if(n&&typeof n.addRule==r){n.addRule(ac,Y)}}else{if(n&&typeof j.createTextNode!=D){n.appendChild(j.createTextNode(ac+" {"+Y+"}"))}}}function w(Z,X){if(!m){return}var Y=X?"visible":"hidden";if(J&&c(Z)){c(Z).style.visibility=Y}else{v("#"+Z,"visibility:"+Y)}}function L(Y){var Z=/[\\\"<>\.;]/;var X=Z.exec(Y)!=null;return X&&typeof encodeURIComponent!=D?encodeURIComponent(Y):Y}var d=function(){if(M.ie&&M.win){window.attachEvent("onunload",function(){var ac=I.length;for(var ab=0;ab<ac;ab++){I[ab][0].detachEvent(I[ab][1],I[ab][2])}var Z=N.length;for(var aa=0;aa<Z;aa++){y(N[aa])}for(var Y in M){M[Y]=null}M=null;for(var X in swfobject){swfobject[X]=null}swfobject=null})}}();return{registerObject:function(ab,X,aa,Z){if(M.w3&&ab&&X){var Y={};Y.id=ab;Y.swfVersion=X;Y.expressInstall=aa;Y.callbackFn=Z;o[o.length]=Y;w(ab,false)}else{if(Z){Z({success:false,id:ab})}}},getObjectById:function(X){if(M.w3){return z(X)}},embedSWF:function(ab,ah,ae,ag,Y,aa,Z,ad,af,ac){var X={success:false,id:ah};if(M.w3&&!(M.wk&&M.wk<312)&&ab&&ah&&ae&&ag&&Y){w(ah,false);K(function(){ae+="";ag+="";var aj={};if(af&&typeof af===r){for(var al in af){aj[al]=af[al]}}aj.data=ab;aj.width=ae;aj.height=ag;var am={};if(ad&&typeof ad===r){for(var ak in ad){am[ak]=ad[ak]}}if(Z&&typeof Z===r){for(var ai in Z){if(typeof am.flashvars!=D){am.flashvars+="&"+ai+"="+Z[ai]}else{am.flashvars=ai+"="+Z[ai]}}}if(F(Y)){var an=u(aj,am,ah);if(aj.id==ah){w(ah,true)}X.success=true;X.ref=an}else{if(aa&&A()){aj.data=aa;P(aj,am,ah,ac);return}else{w(ah,true)}}if(ac){ac(X)}})}else{if(ac){ac(X)}}},switchOffAutoHideShow:function(){m=false},ua:M,getFlashPlayerVersion:function(){return{major:M.pv[0],minor:M.pv[1],release:M.pv[2]}},hasFlashPlayerVersion:F,createSWF:function(Z,Y,X){if(M.w3){return u(Z,Y,X)}else{return undefined}},showExpressInstall:function(Z,aa,X,Y){if(M.w3&&A()){P(Z,aa,X,Y)}},removeSWF:function(X){if(M.w3){y(X)}},createCSS:function(aa,Z,Y,X){if(M.w3){v(aa,Z,Y,X)}},addDomLoadEvent:K,addLoadEvent:s,getQueryParamValue:function(aa){var Z=j.location.search||j.location.hash;if(Z){if(/\?/.test(Z)){Z=Z.split("?")[1]}if(aa==null){return L(Z)}var Y=Z.split("&");for(var X=0;X<Y.length;X++){if(Y[X].substring(0,Y[X].indexOf("="))==aa){return L(Y[X].substring((Y[X].indexOf("=")+1)))}}}return""},expressInstallCallback:function(){if(a){var X=c(R);if(X&&l){X.parentNode.replaceChild(l,X);if(Q){w(Q,true);if(M.ie&&M.win){l.style.display="block"}}if(E){E(B)}}a=false}}}}();/**
 * 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 = window.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.Morph( 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.dispose();
			this.lightbox.dispose();	
			
			// 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 ( Browser.Engine.name != 'trident' || Browser.Engine.version != 4 ) return;

		$$('select').each( function( elm ) {
			elm.setStyle( 'visibility', 'hidden' );
		});
	},
	
	showSelectBoxes: function( ) {	
		if ( Browser.Engine.name != 'trident' || Browser.Engine.version != 4 ) return;
	
		$$('select').each( function( elm ) {
			elm.setStyle( 'visibility', 'visible' );
		});
	}

});


/**
 * Create a dialog
 */
var MovieLightBox = new Class({
	Extends: Lightbox,
	initialize: function( box_width, box_height, movieid, ytmoviekey, moviewidth, movieheight ) {
	
		// initalize the parent
		this.parent( box_width );
		var myLightbox = this;
		this.movieid = movieid;

		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': '#',
				'html': 'X'				
			}))
			.addEvent( 'click', function(e) {
				new Event(e).stop();
				myLightbox.stopAndHide();				
			})			
			.getParent()
			.getParent()
			.getParent()
			.appendChild( new Element( 'div', {
				'class': 'body_outer'
			}))
			.appendChild( this.body = new Element( 'div', {				
				'class': 'body_inner'
			}))
			.appendChild( new Element( 'div', {
				'id': 'ytapiplayer'
			}));
			
		if ( box_height != '' )			
			this.body.setStyle( 'height', box_height );
			
		var params = { allowScriptAccess: "always" };
		var atts = { id: movieid };
		swfobject.embedSWF("http://www.youtube.com/v/"+ytmoviekey+"&enablejsapi=1&playerapiid=ytplayer&autoplay=1&ap=%2526fmt%3D18", 
						   "ytapiplayer", moviewidth, movieheight, "8", null, null, params, atts );		
	},
	
	
	stopAndHide: function( ) {
		this.hide();
		var ytvideo = $(this.movieid);
		ytvideo.stopVideo();
		ytvideo.clearVideo();
	}

	
});





// The code below contains functions that run active content. The functions
// assemble an OBJECT/EMBED tag string, and then perform a document.write of 
// this string in the calling html document.
//   AC_RunFlContent() - build tags to display Flash content.
//   AC_RunFlContentX() - build XHTML formatted tags to display Flash content.
//   AC_RunSWContent() - build tags to display Shockwave content.
//   AC_RunSWContentX()  - build XHTML formatted tags to display Shockwave content.
//
// To call one of these functions, pass all the attributes and values that you would 
// otherwise specify for the object, param, and embed tags in the following form:
//   AC_RunFlContent(
//     "attrName1", "attrValue1"
//     "attrName2", "attrValue2"
//     ...
//     "attrNamen", "attrValuen"
//   )
//
// When passing in the src or movie attributes, do not include the file extension.
// Note, these functions use default values for several standard tag attributes, 
// including classid, codebase, pluginsPage, and mimeType, depending on the function
// you call. So, you should not pass in values for these attributes. If you require
// an alternate values for these attributes, you'll need to modify the default values 
// used in the 'Run' function implementations below. However, you may pass in an
// alternate version for the codebase value, as in AC_RunFlContent("codebase","6,0,0,0",...).
// Note that you should only pass in the version string rather than the full
// codebase URL.
//
// You must include AC_RunActiveContent.js for these functions to work.

function AC_RunFlContent()
{
  // First, look for a "movie" and "src" params, and if either exists, add a ".swf" to the end
  // if it doesn't already have one (this function will only run swf files)
  AC_AddExtension(arguments, "movie", ".swf");
  AC_AddExtension(arguments, "src", ".swf");

  // Build the codebase value. If user passed in a version for the codebase, add the version
  // to the base codebase url. Otherwise, use the default version.
  var codebase = AC_GetCodebase
                 (  "http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version="
                  , "7,0,0,0", arguments 
                 );
	
  AC_GenerateObj
  (  "AC_RunFlContent()", false, "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
   , codebase
   , "http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash"
   , "application/x-shockwave-flash", arguments
  );
}

function Apolair_RunFlContentX()
{
  // First, look for a "movie" and "src" params, and if either exists, add a ".swf" to the end
  // if it doesn't already have one (this function will only run swf files)
  Apolair_AddExtension(arguments, "movie", ".swf");
  Apolair_AddExtension(arguments, "src", ".swf");

  // Build the codebase value. If user passed in a version for the codebase, add the version
  // to the base codebase url. Otherwise, use the default version.
  var codebase = Apolair_GetCodebase
                 (  "http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version="
                  , "7,0,0,0", arguments 
                 );
	
  Apolair_GenerateObj
  (  "Apolair_RunFlContentX()", true, "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
   , codebase
   , "http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash"
   , "application/x-shockwave-flash", arguments
  );	
}

function Apolair_RunSWContent()
{
  // First, look for a "src" param, and if it exists, add a ".dcr" to the end
  // if it doesn't already have one (this function will only run dcr files)
  Apolair_AddExtension(arguments, "src", ".dcr");

  // Build the codebase value. If user passed in a version for the codebase, add the version
  // to the base codebase url. Otherwise, use the default version.
  var codebase = Apolair_GetCodebase
                 (  "http://fpdownload.macromedia.com/pub/shockwave/cabs/director/sw.cab#version="
                  , "8,5,0,0", arguments 
                 );
	
  Apolair_GenerateObj
  (  "Apolair_RunSWContent()", false, "clsid:166B1BCA-3F9C-11CF-8075-444553540000"
   , codebase
   , "http://www.macromedia.com/shockwave/download/", null, arguments
  );
}
	
function Apolair_RunSWContentX()
{
  // First, look for a "src" param, and if it exists, add a ".dcr" to the end
  // if it doesn't already have one (this function will only run dcr files)
  Apolair_AddExtension(arguments, "src", ".dcr");

  // Build the codebase value. If user passed in a version for the codebase, add the version
  // to the base codebase url. Otherwise, use the default version.
  var codebase = Apolair_GetCodebase
                 (  "http://fpdownload.macromedia.com/pub/shockwave/cabs/director/sw.cab#version="
                  , "8,5,0,0", arguments 
                 );
	
  Apolair_GenerateObj
  (  "Apolair_RunSWContentX()", true, "clsid:166B1BCA-3F9C-11CF-8075-444553540000"
   , codebase
   , "http://www.macromedia.com/shockwave/download/", null, arguments
  );
}
	


// Implements Apolair_GenerateObj() function. This is a generic function used to generate
// object/embed/param tags. It is used by higher level api functions.

/************** LOCALIZABLE GLOBAL VARIABLES ****************/

var MSG_EvenArgs = 'The %s function requires an even number of arguments.'
                 + '\nArguments should be in the form "atttributeName","attributeValue",...';
var MSG_SrcRequired = "The %s function requires that a movie src be passed in as one of the arguments.";

/******************** END LOCALIZABLE **********************/

// Finds a parameter with the name paramName, and checks to see if it has the 
// passed extension. If it doesn't have it, this function adds the extension.
function Apolair_AddExtension(args, paramName, extension)
{
  var currArg, paramVal, queryStr, endStr;
  for (var i=0; i < args.length; i=i+2){
    currArg = args[i].toLowerCase();    
    if (currArg == paramName.toLowerCase() && args.length > i+1) {
      paramVal = args[i+1];
      queryStr = "";

      // Pull off the query string if it exists.
      var indQueryStr = args[i+1].indexOf('?');
      if (indQueryStr != -1){
        paramVal = args[i+1].substring(0, indQueryStr);
        queryStr = args[i+1].substr(indQueryStr);
      }

      endStr = "";
      if (paramVal.length > extension.length)
        endStr = paramVal.substr(paramVal.length - extension.length);
      if (endStr.toLowerCase() != extension.toLowerCase()) {
        // Extension doesn't exist, add it
        args[i+1] = paramVal + extension + queryStr;
      }
    }
  }
}

// Builds the codebase value to use. If the 'codebase' parameter is found in the args,
// uses its value as the version for the baseURL. If 'codebase' is not found in the args,
// uses the defaultVersion.
function Apolair_GetCodebase(baseURL, defaultVersion, args)
{
  var codebase = baseURL + defaultVersion;
  for (var i=0; i < args.length; i=i+2) {
    currArg = args[i].toLowerCase();    
    if (currArg == "codebase" && args.length > i+1) {
      if (args[i+1].indexOf("http://") == 0) {
        // User passed in a full codebase, so use it.
        codebase = args[i+1];
      }
      else {
        codebase = baseURL + args[i+1];
      }
    }
  }
	
  return codebase;	
}

// Substitutes values for %s in a string.
// Usage: Apolair_sprintf("The %s function requires %s arguments.","foo()","4");
function Apolair_sprintf(str){
  for (var i=1; i < arguments.length; i++){
    str = str.replace(/%s/,arguments[i]);
  }
  return str;
}
		
// Checks that args, the argument list to check, has an even number of 
// arguments. Alerts the user if an odd number of arguments is found.
function Apolair_checkArgs(args,callingFn){
  var retVal = true;
  // If number of arguments isn't even, show a warning and return false.
  if (parseFloat(args.length/2) != parseInt(args.length/2)){
    alert(sprintf(MSG_EvenArgs,callingFn));
    retVal = false;
  }
  return retVal;
}
	
function Apolair_GenerateObj(callingFn, useXHTML, classid, codebase, pluginsPage, mimeType, args){

  if (!Apolair_checkArgs(args,callingFn)){
    return;
  }

  // Initialize variables
  var tagStr = '';
  var currArg = '';
  var closer = (useXHTML) ? '/>' : '>';
  var srcFound = false;
  var embedStr = '<embed';
  var paramStr = '';
  var embedNameAttr = '';
  var objStr = '<object classid="' + classid + '" codebase="' + codebase + '"';

  // Spin through all the argument pairs, assigning attributes and values to the object,
  // param, and embed tags as appropriate.
  for (var i=0; i < args.length; i=i+2){
    currArg = args[i].toLowerCase();    

    if (currArg == "src"){
      if (callingFn.indexOf("RunSW") != -1){
        paramStr += '<param name="' + args[i] + '" value="' + args[i+1] + '"' + closer + '\n';
        embedStr += ' ' + args[i] + '="' + args[i+1] + '"';
        srcFound = true;
      }
      else if (!srcFound){
        paramStr += '<param name="movie" value="' + args[i+1] + '"' + closer + '\n'; 
        embedStr += ' ' + args[i] + '="' + args[i+1] + '"';
        srcFound = true;
      }
    }
    else if (currArg == "movie"){
      if (!srcFound){
        paramStr += '<param name="' + args[i] + '" value="' + args[i+1] + '"' + closer + '\n'; 
        embedStr += ' src="' + args[i+1] + '"';
        srcFound = true;
      }
    }
    else if (   currArg == "width" 
              || currArg == "height" 
              || currArg == "align" 
              || currArg == "vspace" 
              || currArg == "hspace" 
              || currArg == "class" 
              || currArg == "title" 
              || currArg == "accesskey" 
              || currArg == "tabindex"){
      objStr += ' ' + args[i] + '="' + args[i+1] + '"';
      embedStr += ' ' + args[i] + '="' + args[i+1] + '"';
    }
    else if (currArg == "id"){
      objStr += ' ' + args[i] + '="' + args[i+1] + '"';
      // Only add the name attribute to the embed tag if a name attribute 
      // isn't already there. This is what Dreamweaver does if the user
      // enters a name for a movie in the PI: it adds id to the object
      // tag, and name to the embed tag.
      if (embedNameAttr == "")
        embedNameAttr = ' name="' + args[i+1] + '"';
    }
    else if (currArg == "name"){
      objStr += ' ' + args[i] + '="' + args[i+1] + '"';
      // Replace the current embed tag name attribute with the one passed in.
      embedNameAttr = ' ' + args[i] + '="' + args[i+1] + '"';
    }    
    else if (currArg == "codebase"){
      // The codebase parameter has already been handled, so ignore it. 
    }    
    // This is an attribute we don't know about. Assume that we should add it to the 
    // param and embed strings.
    else{
      paramStr += '<param name="' + args[i] + '" value="' + args[i+1] + '"' + closer + '\n'; 
      embedStr += ' ' + args[i] + '="' + args[i+1] + '"';
    }
  }

  // Tell the user that a movie/src is required, if one was not passed in.
  if (!srcFound){
    alert(Apolair_sprintf(MSG_SrcRequired,callingFn));
    return;
  }

  if (embedNameAttr)
    embedStr += embedNameAttr;	
  if (pluginsPage)
    embedStr += ' pluginspage="' + pluginsPage + '"';
  if (mimeType)
    embedStr += ' type="' + mimeType + '"';
    
  // Close off the object and embed strings
  objStr += '>\n';
  embedStr += '></embed>\n'; 

  // Assemble the three tag strings into a single string.
  tagStr = objStr + paramStr + embedStr + "</object>\n"; 

  document.write(tagStr);
}

/**
 *
 *  Javascript sprintf
 *  http://www.webtoolkit.info/
 *
 *
 */
sprintfWrapper = {
 
	init : function () {
 
		if (typeof arguments == "undefined") { return null; }
		if (arguments.length < 1) { return null; }
		if (typeof arguments[0] != "string") { return null; }
		if (typeof RegExp == "undefined") { return null; }
 
		var string = arguments[0];
		var exp = new RegExp(/(%([%]|(\-)?(\+|\x20)?(0)?(\d+)?(\.(\d)?)?([bcdfosxX])))/g);
		var matches = new Array();
		var strings = new Array();
		var convCount = 0;
		var stringPosStart = 0;
		var stringPosEnd = 0;
		var matchPosEnd = 0;
		var newString = '';
		var match = null;
 
		while (match = exp.exec(string)) {
			if (match[9]) { convCount += 1; }
 
			stringPosStart = matchPosEnd;
			stringPosEnd = exp.lastIndex - match[0].length;
			strings[strings.length] = string.substring(stringPosStart, stringPosEnd);
 
			matchPosEnd = exp.lastIndex;
			matches[matches.length] = {
				match: match[0],
				left: match[3] ? true : false,
				sign: match[4] || '',
				pad: match[5] || ' ',
				min: match[6] || 0,
				precision: match[8],
				code: match[9] || '%',
				negative: parseInt(arguments[convCount]) < 0 ? true : false,
				argument: String(arguments[convCount])
			};
		}
		strings[strings.length] = string.substring(matchPosEnd);
 
		if (matches.length == 0) { return string; }
		if ((arguments.length - 1) < convCount) { return null; }
 
		var code = null;
		var match = null;
		var i = null;
 
		for (i=0; i < matches.length; i++) {
 
			if (matches[i].code == '%') { substitution = '%' }
			else if (matches[i].code == 'b') {
				matches[i].argument = String(Math.abs(parseInt(matches[i].argument)).toString(2));
				substitution = sprintfWrapper.convert(matches[i], true);
			}
			else if (matches[i].code == 'c') {
				matches[i].argument = String(String.fromCharCode(parseInt(Math.abs(parseInt(matches[i].argument)))));
				substitution = sprintfWrapper.convert(matches[i], true);
			}
			else if (matches[i].code == 'd') {
				matches[i].argument = String(Math.abs(parseInt(matches[i].argument)));
				substitution = sprintfWrapper.convert(matches[i]);
			}
			else if (matches[i].code == 'f') {
				matches[i].argument = String(Math.abs(parseFloat(matches[i].argument)).toFixed(matches[i].precision ? matches[i].precision : 6));
				substitution = sprintfWrapper.convert(matches[i]);
			}
			else if (matches[i].code == 'o') {
				matches[i].argument = String(Math.abs(parseInt(matches[i].argument)).toString(8));
				substitution = sprintfWrapper.convert(matches[i]);
			}
			else if (matches[i].code == 's') {
				matches[i].argument = matches[i].argument.substring(0, matches[i].precision ? matches[i].precision : matches[i].argument.length)
				substitution = sprintfWrapper.convert(matches[i], true);
			}
			else if (matches[i].code == 'x') {
				matches[i].argument = String(Math.abs(parseInt(matches[i].argument)).toString(16));
				substitution = sprintfWrapper.convert(matches[i]);
			}
			else if (matches[i].code == 'X') {
				matches[i].argument = String(Math.abs(parseInt(matches[i].argument)).toString(16));
				substitution = sprintfWrapper.convert(matches[i]).toUpperCase();
			}
			else {
				substitution = matches[i].match;
			}
 
			newString += strings[i];
			newString += substitution;
 
		}
		newString += strings[i];
 
		return newString;
 
	},
 
	convert : function(match, nosign){
		if (nosign) {
			match.sign = '';
		} else {
			match.sign = match.negative ? '-' : match.sign;
		}
		var l = match.min - match.argument.length + 1 - match.sign.length;
		var pad = new Array(l < 0 ? 0 : l).join(match.pad);
		if (!match.left) {
			if (match.pad == "0" || nosign) {
				return match.sign + pad + match.argument;
			} else {
				return pad + match.sign + match.argument;
			}
		} else {
			if (match.pad == "0" || nosign) {
				return match.sign + match.argument + pad.replace(/0/g, ' ');
			} else {
				return match.sign + match.argument + pad;
			}
		}
	}
}
sprintf = sprintfWrapper.init;

/**
 * Easy log function to printout message to the firebug console
 * 
 * @param str
 */
function log( str )
{
	if ( $type( str ) == "object" )
	{
		var message = "";		
		str.each( function( value, key ) {
			message += "<b>" + key + ":</b> " + value + "<br />";
		});		
		str = message;
	}
	
	
	if ( window.loadFirebugConsole )
	{
		window.loadFirebugConsole();
		if ( console && console.log ) console.log( str );
	}
	
	//if ( $type( dejato ) != false )
	//{
	//	dejato.log( str );
	//}	
}

/**
 * Quick Ajax JSON request function. 
 * 
 * @param options
 * 		options.command: the remote php command to execute
 * 		options.argument: string, array or hash with the remote command arguments
 * 		options.method: [optional] the method to use the request with, defaults to 'post'
 * 		options.path: [optional] the path to send the request to, defaults to baseurl/ajax
 * 		options.onSuccess: [optional] the function that will be called once the query completes 		
 * @return bool
 */
function ajax( options )
{
	var dataObj = { 'rs': options.command };
	
	switch( $type( options.argument ) )
	{
		case "array":
		case "string": 
			dataObj.een = options.argument;
			break;
		
		case "hash":
			dataObj = options.argument;
			dataObj.rs = options.command;
			break;
			
		case "object":			
			dataObj = new Hash( options.argument );
			dataObj.rs = options.command;
			break;
			
		default: 
			log( "ajax object type: " + $type( options.argument ) );
			break;		
	}
	
	var jsonRequest = new Request.JSON( 
		{
			url: options.path ? options.path : baseurl+"ajax", 
			onSuccess: options.onSuccess ? options.onSuccess : function(){},  
			async: options.async == "nee" ? false : true
	    }
	);
	
	if ( !options.method || options.method == "post" )
		jsonRequest.post( dataObj );
	else
		jsonRequest.get( dataObj );
    return true;
}


/**
 * Clicks registration 
 */
function register_click( arg ) 
{
	return ajax({
		command: 'doRegisterClick',
		argument: arg,
		onSuccess: function( jsonObject ) {
			if ( !jsonObject || jsonObject.result != "1111" ) alert( "RegisterClick resulteerde in een fout" ); 
		}
	});	
}

/**
 * Google Map v2 Initializer
 * 
 * @param lat the latitude of the current position
 * @param lon the longitude of the current position
 * @param container the name of the container to add the google map
 */
var ApolairGoogleMap = new Class({
	
	initialize: function( lat, lon, container, options ) {
		if ( GBrowserIsCompatible() ) 
		{
			if ( !options ) options = {};
			if ( !options.initialZoom ) options.initialZoom = 8;
			
			var point = new GLatLng( lat, lon );
			this.map = new GMap2( $(container) );
			this.bounds = new GLatLngBounds();
			this.map.setCenter( point, options.initialZoom );
			this.markers = 0;
			this.delay = 100;
			this.maximumzoom = 10;
			this.zoomleveladjust = 0;
			
			this.progressBar = new ProgressbarControl( this.map, {width:150});
			
			// add unload event if not available
			if ( !$type( new Element( document.body ).get( "onunload" ) ) )
				window.addEvent( "unload", function( event ) { GUnload(); });
		}
	},

	/**
	 * Function to add the Hybrid/Map/Satelite control 
	 */
	addMapTypeControl: function( )
	{
		this.map.addControl( new GMapTypeControl() );
	},
	
	/**
	 * Function to add an OverviewMap 
	 */
	addOverviewMapControl: function( )
	{
		this.map.addControl( new GOverviewMapControl() );
	},
	
	/**
	 * Function to add the navigation arrows + zoom level
	 */
	addMapNavControl: function( )
	{
		this.map.addControl( new GSmallMapControl() );
	},
	
	/**
	 * Adjust auto zoom level, positive value will zoom in more
	 */
	setZoomLevelAdjust: function( adjust )
	{
		this.zoomleveladjust = adjust;
	},

	/**
	 * Set the type of the map
	 */
	setMapType: function( type )
	{
		this.map.setMapType( type );
	},
	
	/**
	 * Set the minimum resolution till which can zoom out
	 */
	setMinimumResolution: function( resolution )
	{
		G_PHYSICAL_MAP.getMinimumResolution = function () { return resolution };
        G_NORMAL_MAP.getMinimumResolution = function () { return resolution };
        G_SATELLITE_MAP.getMinimumResolution = function () { return resolution };
        G_HYBRID_MAP.getMinimumResolution = function () { return resolution };
	},
	
	/**
	 * Set the maximum resolution for which can zoom in
	 */
	setMaximumResolution: function( resolution )
	{
        G_PHYSICAL_MAP.getMaximumResolution = function () { return resolution };
        G_NORMAL_MAP.getMaximumResolution = function () { return resolution };
        G_SATELLITE_MAP.getMaximumResolution = function () { return resolution };
        G_HYBRID_MAP.getMaximumResolution = function () { return resolution }; 
	},
	
	/**
	 * Set the maximum value to zoom in with setCenter
	 */
	setMaximumZoom: function( zoomlevel )
	{
		this.maximumzoom = zoomlevel;
	},

	/**
	 * Enable the scrollwheel of the mouse to set zoomlevel
	 */
	enableScrollWheelZoom: function ()
	{
		this.map.enableScrollWheelZoom();
	},

	/**
	 * Visualise the progress in the items loaded
	 */
	enableProgressbar: function ( numberOfItems )
	{
		this.progressBar.start( numberOfItems );
	},

	disableProgressbar: function ( )
	{		    
		var myF = function() {
			this.progressBar.remove();
		}.bind( this ).delay( this.delay * ( this.markers + 1 ) );
	},
	
	/**
	 * Function to add a html marker to the Google Map
	 * 
	 * @param float lat the latitutde
	 * @param flaot lon the longitude
	 * @param string html the html that should be in the marker
	 * @param string icon the name of the icon or null if default 
	 */
	addMarkerToMap: function( lat, lon, html, icon ) {
		
		if ( icon == "bluedot" )
			icon = this.createBlueDot();
		else if ( icon == "blue" )
			icon = this.createBlueIcon();		
		
		var point = new GLatLng( lat, lon );
		var marker = this.createMarker( point, html, icon );
		
		// extends bounds
		this.bounds.extend( point );
		this.markers += 1;
		
		// add marker to overview
		var myF = function() {
			this.map.addOverlay(marker);
			this.progressBar.updateLoader(1);
		}.bind( this ).delay( this.delay * this.markers );
	},
	
	/**
	 * Set the map to the correct center position with the appropriate zoom level
	 */
	setCenter: function( zoomLevel )
	{		    
		var myF = function() {
			if ( zoomLevel == null )
			{
				var myZoomLevel = Math.min( this.maximumzoom, this.map.getBoundsZoomLevel( this.bounds ) );			
				this.map.setCenter( this.bounds.getCenter( ), myZoomLevel + this.zoomleveladjust );
			}
			else
			{
				this.map.setCenter( this.bounds.getCenter( ), zoomLevel );
			}
		}.bind( this ).delay( this.delay * ( this.markers + 1 ) );
	},
	
	createMarker: function( point, html, icon ) {
		var marker = new GMarker(point, icon);
		if ( html != null )
		{
			GEvent.addListener(marker, "click", function() {
				marker.openInfoWindowHtml(html);
			});
		}
		return marker;
	},	
	
	createBlueIcon: function( ) {
		return this.createIcon( "http://www.apolair.nl/repository/images/gmarker_blue.png" );
	},
	
	createIcon: function( iconImage ) {
		var icon = new GIcon();
		icon.image = iconImage;
		/* icon.shadow = "http://www.google.com/mapfiles/shadow50.png"; */
		icon.iconSize = new GSize(20, 34);
		icon.shadowSize = new GSize(37, 34);
		icon.iconAnchor = new GPoint(9, 34);
		icon.infoWindowAnchor = new GPoint(9, 2);
		icon.infoShadowAnchor = new GPoint(18, 25);
		icon.transparent = "http://www.google.com/intl/en_ALL/mapfiles/markerTransparent.png";		
	}
});

/**
 * Apolair Google maps Progress Bar
 * 
 * @see options for options.
 */
var ApolairGmapsProgressBar = new Class({

	Implements: [Options],
	
    options: {
		height:     '1.3em',
		width:      '150px',
		top:        '30px',
		right:      '5px',
		colorBar:   '#68c',
		background: '#FFF',
		fontFamily: 'Arial, sans-serif',
		fontSize:   '12px',
		shadow:     '1px 1px #888'
    },
    
    initialize: function( options ) {
    	
    	this.setOptions(options);
                    
        this.current = 0;
        this.total = 0;        
          
        // create the progress bar div
        this.div = new Element( 'div', {
        	id: 'pg_div',
        	styles: {
        		cssText:'box-shadow: ' + this.options.shadow + '; ' +
        	    		'-webkit-box-shadow: ' + this.options.shadow + '; ' +
        	      		'-moz-box-shadow: ' + this.options.shadow + '; ',
        	    display: 'none',
        	    width: this.options.width,
        	    height: this.options.height,
        	    marginRight: '6px',
        	    border: '1px solid #bbb',
        	    background: this.options.background,
        	    fontSize: this.options.fontSize,
        	    textAlign: 'left'
        	} 
        });
          
        // create the text label
        this.text = new Element( 'div', {
        	id: 'pg_text',
        	styles: {
        		position: 'absolute',
        		width: '100%',
        		border: '5px',
        		textAlign: 'center',
        		verticalAlign: 'bottom'          	
        	}
        }).inject( this.div );
          
        // create the progress bar
        this.bar = new Element( 'div', {
        	id: 'pg_bar',
        	styles: {
        		height: this.options.height,
        	    backgroundColor: this.options.colorBar                  
        	}
        }).inject( this.div );          
    },
        
    start: function( total_ ) {
    	
    	if ( parseInt( total_ ) === total_ && total_ > 0 )
    	{
    		this.total = total_;
    		this.current = 0;
    		this.bar.setStyle( "width", "0%" );
    		this.text.set( "html", "Loading..." );
    		this.div.setStyle( "display", "block" );
    	}
		return this.total;
    },
    
    updateBar: function( increase )
    {
    	if ( parseInt( increase ) === increase && this.total )
    	{
    		this.current += parseInt( increase );
    		if ( this.current > this.total )
    			this.current = this.total;
    		else if ( this.current < 0 )
    			this.current = 0;
    		
    		this.bar.setStyle( "width", Math.round( (this.current/this.total) * 100 ) + '%' );
    		this.text.set( "html", this.current + ' / ' + this.total );	
    	}
    	else if ( !this.total )
    	{
    		return this.total;
    	}
    	return this.current;
    },
    
    hide: function( ) {
    	this.div.setStyle( "display", "none" );
    },
    
    getDiv: function( ) {
    	return this.div;
    },
    
    getTotal: function( ) {
    	return this.total;
    },
    
    setTotal: function( total ) {
    	this.total = total;
    }
});


/**
 * Google Map v3 Initializer
 * 
 * @param lat the latitude of the current position
 * @param lon the longitude of the current position
 * @param container the name of the container to add the google map
 * @param options 
 * 		options.initialZoom , (8)
 * 		options.mapType,
 * 		options.navigationControl,
 * 		options.navigationControlStyle,
 * 		options.mapTypeControl,
 * 		options.mapTypeControlStyle,
 *      options.scaleControl,
 *      
 */
var ApolairGoogleMap3 = new Class({
	
	initialize: function( lat, lon, container, options ) {
		
		if ( !options ) options = {};
		if ( !options.initialZoom ) options.initialZoom = 8;
		if ( !options.mapType ) options.mapType = google.maps.MapTypeId.ROADMAP;
		if ( !options.navigationControlStyle ) options.navigationControlStyle = google.maps.NavigationControlStyle.ZOOM_PAN;
		if ( !options.mapTypeControlStyle ) options.mapTypeControlStyle = google.maps.MapTypeControlStyle.DROPDOWN_MENU;		
		if ( !options.scrollwheel ) options.scrollwheel = false;
		
		var point = new google.maps.LatLng( lat, lon );
		this.map = new google.maps.Map( $(container), {
			center: point,
			mapTypeId: options.mapType, 
			zoom: options.initialZoom,
			navigationControl: options.navigationControl,
			navigationControlOptions: { style: options.navigationControlStyle },
			mapTypeControl: options.mapTypeControl,
			mapTypeControlOptions: { style: options.mapTypeControlStyle },
			scaleControl: options.scaleControl,
			scrollwheel: options.scrollwheel
		});		
		this.bounds = new google.maps.LatLngBounds();			
		this.markers = 0;
		this.delay = 100;
		this.maximumzoom = 10;
		this.zoomleveladjust = 0;
	},

	/**
	 * Function to add the Hybrid/Map/Satelite control 
	 */
	addMapTypeControl: function( )
	{
		alert( "addMapTypeControl: deprecated see apolair-1.0.js" );
	},
	
	/**
	 * Function to add an OverviewMap 
	 */
	addOverviewMapControl: function( )
	{
		alert( "addOverviewMapControl: deprecated see apolair-1.0.js" );
	},
	
	/**
	 * Function to add the navigation arrows + zoom level
	 */
	addMapNavControl: function( )
	{
		alert( "addMapNavControl: deprecated see apolair-1.0.js" );
	},
	
	/**
	 * Adjust auto zoom level, positive value will zoom in more
	 */
	setZoomLevelAdjust: function( adjust )
	{
		this.zoomleveladjust = adjust;
	},

	/**
	 * Set the type of the map
	 */
	setMapType: function( type )
	{
		this.map.setMapTypeId( type );
	},
	
	/**
	 * Set the minimum resolution till which can zoom out
	 */
	setMinimumResolution: function( resolution )
	{
		 google.maps.event.addListener( this.map, 'zoom_changed', function() {	 
			 if ( this.map.getZoom() < resolution ) 
			      this.map.setZoom( resolution );    
		 }.bind( this ));
	},
	
	/**
	 * Set the maximum resolution for which can zoom in
	 */
	setMaximumResolution: function( resolution )
	{
		google.maps.event.addListener( this.map, 'zoom_changed', function() {	 
			 if ( this.map.getZoom() > resolution ) 
			      this.map.setZoom( resolution );    
		 }.bind( this ));
	},
	
	/**
	 * Set the maximum value to zoom in with setCenter
	 */
	setMaximumZoom: function( zoomlevel )
	{
		this.maximumzoom = zoomlevel;
	},

	/**
	 * Enable the scrollwheel of the mouse to set zoomlevel
	 */
	enableScrollWheelZoom: function ()
	{
		this.map.enableScrollWheelZoom();
	},

	/**
	 * Visualise the progress in the items loaded
	 */
	enableProgressbar: function ( numberOfItems )
	{
		this.progressbar = new ApolairGmapsProgressBar();
        this.map.controls[google.maps.ControlPosition.RIGHT].push( this.progressbar.getDiv() );
        this.progressbar.start( numberOfItems );
	},

	disableProgressbar: function ( )
	{		    
		var myF = function() {
			if ( this.progressbar )	this.progressbar.hide();
		}.bind( this ).delay( this.delay * ( this.markers + 1 ) );
	},
	
	/**
	 * Function to add a html marker to the Google Map
	 * 
	 * @param float lat the latitutde
	 * @param flaot lon the longitude
	 * @param string html the html that should be in the marker
	 * @param string icon the name of the icon or null if default 
	 */
	addMarkerToMap: function( lat, lon, html, icon ) {
		
		var point = new google.maps.LatLng( lat, lon );
				
		// extends bounds
		this.bounds.extend( point );
		this.markers += 1;
		
		// add marker to overview		
		var myF = function() {
			var marker = this.createMarker( point, html, icon );
			if ( this.progressbar )	this.progressbar.updateBar(1);
		}.bind( this ).delay( this.delay * this.markers );
	},
	
	/**
	 * Function to add a html marker to the Google Map
	 * 
	 * @param float lat the latitutde
	 * @param flaot lon the longitude
	 * @param string html the html that should be in the marker
	 * @param string icon the name of the icon or null if default 
	 */
	addLinkMarkerToMap: function( lat, lon, link, title, icon ) {
		
		var point = new google.maps.LatLng( lat, lon );		
		
		// extends bounds
		this.bounds.extend( point );
		this.markers += 1;
		
		// create marker
		var myF = function() {
			
			if ( this.progressbar )	this.progressbar.updateBar(1);
		
			var marker = new google.maps.Marker({
				position: point,
				map: this.map,
				title: title,
				icon: icon				
			});
			
			// add redirect on click link
			google.maps.event.addListener( marker, 'click', function() {
				window.location = link;
			}.bind( this ));
		
		}.bind( this ).delay( this.delay * this.markers );
	},
	
	/**
	 * Set the map to the correct center position with the appropriate zoom level
	 */
	setCenter: function( zoomLevel )
	{		    
		var myF = function() {			
			this.map.fitBounds( this.bounds );			
		}.bind( this ).delay( this.delay * ( this.markers + 3 ) );
	},
	
	createMarker: function( point, html, imgIcon ) {
		var marker = new google.maps.Marker({
			position: point,
			map: this.map,			
			icon: imgIcon				
		});
		
		if ( html != null )
		{
			var elm = new Element( "div", {				
				"html": html
			});						
			
			google.maps.event.addListener( marker, 'click', function() {
				
				if ( this.infowindow )
					this.infowindow.close();
				
				this.infowindow = new google.maps.InfoWindow({
					content: elm
				});								
				this.infowindow.open( this.map, marker );
			}.bind( this ));
		}
		return marker;
	},	
	
	createBlueIcon: function( ) {
		//return this.createIcon( "http://www.apolair.nl/repository/images/gmarker_blue.png" );
	},
	
	createIcon: function( iconImage ) {
		/*
		var icon = new GIcon();
		icon.image = iconImage;
		icon.shadow = "http://www.google.com/mapfiles/shadow50.png";
		icon.iconSize = new GSize(20, 34);
		icon.shadowSize = new GSize(37, 34);
		icon.iconAnchor = new GPoint(9, 34);
		icon.infoWindowAnchor = new GPoint(9, 2);
		icon.infoShadowAnchor = new GPoint(18, 25);
		icon.transparent = "http://www.google.com/intl/en_ALL/mapfiles/markerTransparent.png";
		*/		
	}
});


/**
 * Web-Effects small screen fix
 * 
 * - disables the position:fixed attribute in the menu bar
 * - enables position:fixed when the window is scrolled to keep the menu visible
 */
var WebFxSmallWindow = new Class({
	
	initialize: function( minHeight, minScroll, toAbsolute, toFixed ) {
		this.minHeight = minHeight;
		this.minScroll = minScroll;
		this.toAbsolute = toAbsolute;
		this.toFixed = toFixed;	
	},

	startFix: function() {
		
		var portview = window.getSize();
		
		// portview is big enough, return
		if ( portview.y >= this.minHeight )
			return;
		
		// disable fixed position
		this.toAbsolute.setStyle( "position", "absolute" );
		
		// determine the position of the fixed map
		//this.pinsize = this.toFixed.getPosition( window );		
		this.toFixed.setStyle( "position", "fixed" );
		this.toFixed.setStyle( "top", this.minScroll );
		
		
		// periodically check the scroll position
		var scrollDetector = function( ) {
			this.setFixedOnScroll( );			
		}.periodical( 250, this );
		
		this.currentScroll = 0;
		this.setFixedOnScroll( );
	},
	
	setFixedOnScroll: function ( )
	{
		var vscroll = document.getElement('body').getScroll();			
		
		if ( this.currentScroll == vscroll.y )
			return;
		
		if ( vscroll.y < this.minScroll )		
			this.toFixed.setStyle( "top", this.minScroll - vscroll.y );
		else
			this.toFixed.setStyle( "top", 0 );		
		
		this.currentScroll = vscroll.y;
	}	
});




/**
 * Set this element relative to the given element. Requires this element to be 
 * positioned absolutely to the document. 
 * 
 * @param element the element to set it relative to
 * @param align the alignment (2 characters, first vertical align, second horizontal align)
 *   - Vertical alignment values: T, t, c, b, B
 *   - Horizontal alignment values: L, l, m, r, R
 * @param offset hash defaults to {x: 0, y: 0} 
 */
Element.implement({
	
	setRelativeTo: function( element, align, offset ) {
		
		var cRelTo = element.getCoordinates( );
		var cContainer = this.getCoordinates( );
		
		var y = 0;
		var x = 0;
		
		// do vertical position
		switch( align.charAt(0) )
		{
			case "T": y = cRelTo.top - (cContainer.height); break;		
			case "t": y = cRelTo.top - (cContainer.height - cRelTo.height);	break;
			default:
			case "c": y = cRelTo.top - (cContainer.height - cRelTo.height)/2; break;
			case "b": y = cRelTo.top; break;			
			case "B": y = cRelTo.top + cRelTo.height; break;
		}
		
		// do horizontal position
		switch( align.charAt(1) )
		{
			case "L": x = cRelTo.left - cContainer.width; break;				
			case "l": x = cRelTo.left - cContainer.width + cRelTo.width; break;			
			default:
			case "m": x = cRelTo.left - (cContainer.width - cRelTo.width)/2; break;				
			case "r": x = cRelTo.left; break;				
			case "R": x = cRelTo.left + cRelTo.width; break;
		}	
		
		// adjust tooltip position with given offset (if exists)
		if ( offset != null )
		{
			x += offset.x;
			y += offset.y;
		}
		
		// set the position
		this.setStyles({
			"position": "absolute",
			"top": y,
			"left": x
		});
	}
});

/**
 * Implements Fx.Scroll to scroll an element to the center of the current
 * viewport
 */
Element.implement({
	
	scrollToCenter: function( w ) {
		if ( !w ) w = window;	
		// determine size of the viewport
		var viewport = w.getSize();
		// determine the position and height of the current element
		var coordinates = this.getCoordinates( w );
		// calculate the viewport position
		if ( viewport.y >= coordinates.height )		
			var position = coordinates.top - ( viewport.y - coordinates.height ) / 2;
		else
			var position = coordinates.top;

		// scroll it
		var myFx = new Fx.Scroll( w, { 
			offset: { 'x': 0, 'y': position }
		}).toTop();	
	}
});

/**
 * Implements a default text value inside a input.text elements
 * 
 * The default value is an attribute of the element <input type="text" default="Gebruikersnaam">
 */
Element.implement({
	
	enableDefaultDescription: function( defaultClass ) {
		
		var defaultValue = this.get( "default" );
	
		// add focus event
		this.addEvent( "focus", function( ) {			
			if ( this.value == defaultValue )
			{
				this.value = "";
				this.removeClass( defaultClass );
			}			
		}.bindWithEvent( this ));
	
		// add blur event
		this.addEvent( "blur", function( ) {
			if ( this.value == "" || this.value == defaultValue )
			{
				this.value = defaultValue;
				this.addClass( defaultClass );
			}
		}.bindWithEvent( this ));
		
		// add erase event
		this.addEvent( "erase", function( ) {
			
			this.value = defaultValue;
			this.addClass( defaultClass );
			
		}.bindWithEvent( this ));
		
		// fill the default value
		if ( this.value == "" || this.value == defaultValue )
		{
			this.value = defaultValue;
			this.addClass( defaultClass );
		}
		return this;
	},
	
	setDefaultDescription: function( ) {		
		this.fireEvent( "erase" );
	}
});

/**
 * Add Fx.Blink functionality to an element 
 */
Element.implement({
	
	blink: function( options ) {
	
		if ( !options ) options = {};
		if ( !options.key ) options.key = "backgroundColor";
		if ( !options.duration ) options.duration = 300;
		if ( !options.fromValue ) options.fromValue = this.getStyle( options.key );
		if ( !options.toValue ) options.toValue = '#000000';
	
		// create the fx object
		//el.get('tween', {property: 'opacity', duration: 'long'}).start(0);
		if ( this.myFx )
			this.myFx.cancel();
			
		this.myFx = this.get('tween', {property: options.key, duration: options.duration, link: 'chain'} );
		
		// animate it
		this.myFx.cancel()
			.start( options.toValue )
			.start( options.fromValue )
			.start( options.toValue )
			.start( options.fromValue );		
	}
});

/**
 * Implements the UTF8 encode and decode functions for strings 
 */
String.implement({
	
	utf8encode: function( )
	{
		var s = this;
		for(var c, i = -1, l = (s = s.split("")).length, o = String.fromCharCode; ++i < l;
			s[i] = (c = s[i].charCodeAt(0)) >= 127 ? o(0xc0 | (c >>> 6)) + o(0x80 | (c & 0x3f)) : s[i]
		);
		return s.join("");
	},
		
	utf8decode: function( )
	{
		var s = this;
		for(var a, b, i = -1, l = (s = s.split("")).length, o = String.fromCharCode, c = "charCodeAt"; ++i < l;
			((a = s[i][c](0)) & 0x80) &&
			(s[i] = (a & 0xfc) == 0xc0 && ((b = s[i + 1][c](0)) & 0xc0) == 0x80 ?
					o(((a & 0x03) << 6) + (b & 0x3f)) : o(128), s[++i] = "")
		    );
		return s.join("");
	}
});

/**
 * AjaxHtmlTooltip. Javascript class to show an tooltip with html content
 * obtained through an ajax request
 * 
 * Example:
 * 
 * var aht = new AjaxHtmlToolTip( 'ajax', 'getHtmlTooltip' );
 * aht.showAt( element, 'TL', 2 );
 * 
 * Expected output from the ajax request
 * 
 * json_encode( 
 *     array( "result" => array( "html" => "html output", 
 *                               "script" => "javascript output (optional)" 
 *     ) ) );
 */
var AjaxHtmlTooltip = new Class({
	
	/**
	 * Initalize the AHT class
	 * 
	 * @param url absolute url to call for the ajax request
	 * @param phpHandler the function to process the ajax request
	 */
	initialize: function( url, phpHandler ) {
		this.url = url;
		this.phpHandler = phpHandler;
		this.alignment = null;
		this.offset = null;
		this.closeOnBlur = false;
		this.hash = new Hash();
		
		this.hash["rs"] = phpHandler;
	},
	
	/**
	 * Set whether the tooltip will be hidden when there is clicked outside the tooltip area
	 */
	setCloseOnBlur: function( )
	{
		this.closeOnBlur = true;
	},
	
	addParameter: function( key, value )
	{
		this.hash[key] = value;
	},

	setAlign: function( alignment ) {
		this.alignment = alignment;
	},
	
	setOffset: function( offset ) {
		this.offset = offset;
	},
	
	/**
	 * Show the tooltip with the give values of setAlign and setOffset
	 */
	show: function( relTo, parameter )
	{
		// initialize container object
		this.init();
		// set container relative to the element
		this.container.setRelativeTo( new Element( relTo ), this.alignment, this.offset );
		// show the container
		this.container.setStyle( "visibility", "visible" );
		// get the html from ajax
		this.getHtml( parameter );
		
		this.relTo = relTo;
	},
	
	/**
	 * Show the tooltip at the given element, with the given position
	 * 
	 * @param relTo the element the tooltip should be positioned relativeTo
	 * @param align the aligment of the tooltip, see setRelativeTo in apolair-1.0.js in the repository
	 * @param parameter the ajax parameter (optional)
	 */	
	showAt: function( relTo, align, parameter ) {
		// initialize container object
		this.init();
		
		relTo = new Element( relTo );
		
		// set container relative to the element
		this.container.setRelativeTo( relTo, align );
		// show the container
		this.container.setStyle( "visibility", "visible" );
		// get the html from ajax
		this.getHtml( parameter );
		
		this.alignment = align;
		this.relTo = relTo;
		
		this.registerClick();		
	},	
	
	/**
	 * Hide the tooltip
	 */
	hide: function() {
		this.container.setStyle( "visibility", "hidden" );
	},
	
	/**
	 * Toggle visiblity
	 */
	toggle: function() {
		if ( this.container.getStyle( "visibility" ) == "visible" )			
			this.container.setStyle( "visibility", "hidden" );
		else
		{
			this.container.setStyle( "visibility", "visible" );
			this.registerClick();
		}
	},
	
	/**
	 * @access private
	 */
	init: function( ) {
		if ( this.container == null )
		{
			this.container = new Element( 'div', { 'class': 'ajaxTooltip' }).inject( document.body, 'bottom' );
			this.content = this.container.appendChild( new Element( 'div', {'class': 'ajaxTooltipInner'} ) );
		}
		else
			this.content.empty();
		
		// add loader
		new Element( 'div', {'class': 'loader'}).inject( this.content );
	},
	
	/**
	 * @access private
	 */
	getHtml: function( parameter ) {
		var jsonRequest = new Request.JSON({url: baseurl+"ajax", 
			onSuccess: function(jsonObject){
				// set the html
				if ( jsonObject && jsonObject.result && jsonObject.result.html )
				{
					this.content.empty();
					this.content.set( "html", jsonObject.result.html );
					this.container.setRelativeTo( this.relTo, this.alignment, this.offset );
				}
				else
					this.content.set( "html", "Html Ajax error" );
				
				// run the script (optional)
				//if ( jsonObject && jsonObject.result && jsonObject.result.script && jsonObject.result.script != "" )
				//	eval( jsonObject.result.script );
				
				// check for script elements
				this.content.getElements( 'script' ).each( function( script ) {
					eval( script.get( "html" ) );
				});
				
		}.bind(this)});		
		this.hash['een'] = parameter;		
		jsonRequest.get( this.hash );
	},
	
	/**
	 * @access private
	 */
	registerClick: function( )
	{
		if ( this.closeOnBlur )
		{
			var f = function( e ) {
				e = new Event( e );
				if ( !this.container.hasChild( e.target ) )
				{				
					document.removeEvent( "click", f );
					this.hide();
				}
			}.bindWithEvent( this );			
			
			document.addEvent( "click", f );
		}
	}
});


/**
 * Stylish Checkbox for Apolair usage
 * 
 * Classes to style:
 * 
 * default: ApolairStyledCheckbox
 * mouseover: ApolairStyledCheckbox-mouseover
 * mousedown: ApolairStyledCheckbox-mousedown
 * checked: ApolairStyledCheckbox-checked
 */
var ApolairStyledCheckbox = new Class({
		
	initialize: function( checkboxes ) {
		this.checkboxes = checkboxes;
		this.toggle = false;
		this.currentcustom = null;
		this.currentcheck = null;
	},

	enableToggle: function( )
	{
		this.toggle = true;
		return this;
	},
	
	init: function( ) {
	
		// IE 6 or lower, just ignore the style
		if ( Browser.Engine.trident && Browser.Engine.version < 5 )
			return this;
		
		this.checkboxes.each( function( checkbox ) {
			// hide current checkbox
			checkbox.setStyle( "display", "none" );

			// create a custom checkbox span
			var custombox = new Element( 'span', {
				"class": "ApolairStyledCheckbox"
			});
			// insert before the checkbox
			custombox.inject( checkbox, 'before' );
			
			if ( checkbox.checked )
			{
				custombox.addClass( "ApolairStyledCheckbox-checked" );
				this.currentcustom = custombox;
				this.currentcheck = checkbox;
			}
			
			// add click events
			custombox.addEvents( {
				"mousedown": function( event ) { custombox.addClass( "ApolairStyledCheckbox-mousedown" ); },				
				"mouseup":   function( event ) { custombox.removeClass( "ApolairStyledCheckbox-mousedown" ); },
				"mouseover": function( event ) { custombox.addClass( "ApolairStyledCheckbox-mouseover" ); },
				"mouseout":  function( event ) { custombox.removeClass( "ApolairStyledCheckbox-mouseover" ); },
				"click": function( event ) {
					if ( this.toggle && this.currentcustom && this.currentcheck && this.currentcustom != custombox )
					{
						this.currentcustom.removeClass( "ApolairStyledCheckbox-checked" );
						this.currentcheck.set( "checked", false );						
					}
					
					if ( checkbox.checked ) 
						custombox.removeClass( "ApolairStyledCheckbox-checked" );											
					else
					{
						custombox.addClass( "ApolairStyledCheckbox-checked" );
						this.currentcustom = custombox;
						this.currentcheck = checkbox;
					}
					
					checkbox.set( "checked", !checkbox.checked );
					checkbox.fireEvent( "change" );
					
				}.bind( this )			
			});
		}.bind(this));	
		
		return this;
	}
	
});

/**
 * Stylish Combobox for Apolair usage
 * 
 * Classes to style:
 * 
 * default: ApolairStyledCombobox
 * <select>: ApolairStyledCombobox-select
 * mouseover: ApolairStyledCombobox-mouseover
 */
var ApolairStyledCombobox = new Class({
	
	Implements: Options,
	options: {
		defaultTextValue: "",									// the default text value to present when the selection is empty
		defaultTextClass: "ApolairStyledCombobox-default"		// the default class when the default text value is used 
	},	
	
	initialize: function( comboboxes, options ) {
		this.setOptions( options );
		this.comboboxes = comboboxes;
	},
	
	init: function( ) {
		
		// IE 6 or lower, just ignore the style   (version 4)
		if ( Browser.Engine.trident && Browser.Engine.version < 5 )
			return;
		
		this.comboboxes.each( function( combobox ) {
			
			// make the current combobox transparent
			combobox.setStyle( "opacity", 0.01 );
			combobox.setStyle( "position", "relative" );
			combobox.setStyle( "zIndex", 5 );
			combobox.addClass( "ApolairStyledCombobox-select" );
			
			// create a custom checkbox span
			var custombox = new Element( 'span', {				
				"class": "ApolairStyledCombobox",
				"styles": {	"position": "absolute" }
			});
			
			// update text value
			this.updateTextValue( custombox, this.getTextValue( combobox ) );
			
			// insert before the checkbox
			custombox.inject( combobox, 'before' );
			
			// add change event
			combobox.addEvents({				
				"change":    function( event ) { this.updateTextValue( custombox, this.getTextValue( combobox ) ); }.bind( this ),
				"mouseover": function( event ) { custombox.addClass( "ApolairStyledCombobox-mouseover" ); },
				"mouseout":  function( event ) { custombox.removeClass( "ApolairStyledCombobox-mouseover" ); },
				"focus":     function( event ) { custombox.addClass( "ApolairStyledCombobox-focus" ); },
				"blur":      function( event ) { custombox.removeClass( "ApolairStyledCombobox-focus" ); },
				"keyup":     function( event ) { this.updateTextValue( custombox, this.getTextValue( combobox ) ); }.bind( this )
			});
			
		}.bind(this));		
	},	
	
	updateTextValue: function( custombox, value ) {
		
		if ( this.options.defaultTextValue != "" && value == "" )
		{
			custombox.set( "html", this.options.defaultTextValue );
			custombox.addClass( this.options.defaultTextClass );
		}
		else
		{
			custombox.set( "html", value );
			custombox.removeClass( this.options.defaultTextClass );
		}
	},
	
	getTextValue: function( combobox )
	{
		var option = combobox.options[combobox.selectedIndex];		
		return option ? option.text : "";	
	}
});


/**
 * Apolair Number Range textfield
 */
var ApolairNumberRange = new Class({
	
	Implements: Options,
	options: {
		allowed: [ '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'left', 'right', 'down', 'up', 'backspace', 'delete']
	},
	
	initialize: function( elements, options ) 
	{
		this.setOptions( options );
		this.elements = elements;
		
		this.elements.each( function( element ) {			
			// add key listener
			this.validate( element );
			element.focused = false;
			
			element.addEvent( "keydown", function ( e ) {				
				e = new Event( e );				
				if ( !this.options.allowed.contains( e.key ) )
				{
					e.stop();
					return;
				}
				
				if ( e.key == 'up' )
					this.increment( element );
				else if ( e.key == 'down' )
					this.decrement( element );
				else
					this.setModified( element );				
				
			}.bindWithEvent( this ));
	
			element.addEvent( "keyup", function( e ) {
				if ( element.value != "" ) this.validate( element );				
			}.bindWithEvent( this ));
			
			element.addEvent( "blur", function( e ) {
				this.validate( element );
			}.bindWithEvent( this ));
			
			element.addEvent( "validate", function( e ) {				
				this.validate( element );				
			}.bindWithEvent( this ));
			
			element.addEvent( "mousewheel", function( e ) {
				
				e = new Event( e );
				if ( e.wheel > 0 ) this.increment( element );
				if ( e.wheel < 0 ) this.decrement( element );							
				e.stop();
				
			}.bindWithEvent( this ));
			
		}.bind( this ));
	},
	
	validate: function( element ) {
		
		var value = element.value.toInt();
		
		if ( !value )
			value = 0;
		
		var max = element.get( "max" ).toInt();
		var min = element.get( "min" ).toInt();
		var modified = false;
		
		if ( value > max )
		{
			element.blink( { key: 'borderColor', fromValue: '#CCCCCC', toValue: '#FF0000' } );
			value = max;
			modified = true;
		}
		
		if ( value < min )
		{
			element.blink( { key: 'borderColor', fromValue: '#CCCCCC', toValue: '#FF0000' } );
			value = min;
			modified = true;
		}
		
		element.value = value;
		if( modified )
			this.setModified( element );
	},
	
	increment: function( element ) {
		
		var max = element.get( "max" ).toInt();
		var value = element.value.toInt() + 1;
		
		if ( value > max )
		{
			element.blink( { key: 'borderColor', fromValue: '#CCCCCC', toValue: '#FF0000' } );
			value = max;
		}
		
		element.value = value; 
		this.setModified( element );
	},
	
	decrement: function( element ) {
		
		var min = element.get( "min" ).toInt();		
		var value = element.value.toInt() - 1;
		
		if ( value < min )
		{
			element.blink( { key: 'borderColor', fromValue: '#CCCCCC', toValue: '#FF0000' } );
			value = min;
		}
		
		element.value = value;	
		this.setModified( element );
	},
	
	setModified: function( element ) {
		element.set( "modified", "yes" );
		
		$clear( element.timer );
		element.timer = function( ) {
			if ( element.get( "modified" ) == "yes" )
			{
				element.set( "modified", "" );
				element.fireEvent( "change" );
			}
		}.bind( this ).delay( 300 );		
	}
});


/**
 * Stylish input element.
 * 
 * Add on focus class to add style to focused elements
 * 
 * Classes:
 * 
 * focus - ApolairStyledInput-focus
 */
var ApolairStyledInput = new Class({
	
	initialize: function( inputs ) {
		this.inputs = inputs;
	},
	
	init: function( ) {
		this.inputs.each( function( element ) {
			
			element.addEvents({
				"focus": function( event ) { element.addClass( "ApolairStyledInput-focus" ) },
				"blur":  function( event ) { element.removeClass( "ApolairStyledInput-focus" ) }			
			});
			
		}.bind( this ));
	}
});


/**
 * Simple Javascript Form Hooks
 * 
 * Adds a simple "submit-on-enter" event to all elements
 */
var ApolairSimpleForm = new Class({
	
	initialize: function( form ) {
		this.form = form;
		this.elements = this.form.getElements( "input, textarea, select" );
	},
	
	init: function( ) {
	
		// add keydown event to all elements and submit form on return
		// add focus event and resets error on focus
		this.elements.each( function( element ) {
			if ( element.tagName == "INPUT" || element.tagName == "SELECT" ) {
				element.addEvent( "keydown", function( event ) {
					event = new Event( event );					
					if ( event.key == "enter" )
					{						
						this.submit();
						event.stop();
					}
				}.bindWithEvent( this ));
			}
			
			element.addEvent( "focus", function( event ) {
				element.removeClass( "formerror" );
			});
			
		}.bind( this ));
		
		return this;
	},
	
	setError: function( field ) {
		this.elements.each( function( element ) {
			if ( element.get( "name" ) == field ) 
				element.addClass( "formerror" );
		});
	},
	
	resetErrors: function( ) {
		this.elements.each( function( element ) {			
			element.removeClass( "formerror" );
		});
	},
	
	submit: function( ) {
		this.form.submit();
	}	
});


/**
 * Ajax form submit and verify
 * 
 * Extends ApolairSimpleForm
 * 
 * Can handle json:
 * 
 * [feedback][status]
 * [feedback][message]
 * [reset] = "yes"
 */
var ApolairAjaxForm = new Class({	
	Extends: ApolairSimpleForm,
	Implements: Options,
	options: {
		feedback: false,
		feedbackBefore: null,
		feedbackAfter: null
	},
	
	initialize: function( form, ajaxCallUrl, ajaxCallFunction, options ) {
		if ( options ) this.setOptions( options );		
		this.parent( form );
		this.ajaxCallUrl = ajaxCallUrl;
		this.ajaxCallFunction = ajaxCallFunction;
		
		// add hook to the form submit event
		this.form.addEvent( "submit", function( e ) {
			if ( e ) new Event( e ).stop();					
			this.submit( );			
		}.bindWithEvent( this ));
		
		// create ajax request object with JSON
		this.request = new Request.JSON({
			link: 'ignore',
			url: this.ajaxCallUrl,
			onSuccess: this.onFormSuccess.bind( this )
		});
		
		// create feedback class
		if ( this.options.feedback ) {
			this.feedback = new Element( 'div', {
				"class": "feedback",
				"styles": { "display": "none" }
			})
			this.feedbackinner = new Element( 'div', {
				"class": "feedback-inner"
			}).inject( this.feedback, 'top' );
			
			// set location based on element
			if ( options.feedbackBefore )
				this.feedback.inject( options.feedbackBefore, 'before' );
			else if ( options.feedbackAfter )
				this.feedback.inject( options.feedbackAfter, 'after' );
			else
				this.feedback.inject( this.form, 'top' );
		}
		
		// add hook to the submit button(s) (IE7)
		this.form.getElements( "input[type=submit]" ).each( function( button ) {
			button.addEvent( "click", function( e ) {
				new Event( e ).stop();
				this.form.fireEvent( "submit" );
			}.bindWithEvent( this ));			
		}.bind( this ));		
	},	
	
	/**
	 * Function that is called once the form is succesfully send through ajax
	 */
	setOnSuccess: function( f ) {
		this.onSuccessF = f;
	},
	
	/**
	 * Funtion that is called just before the form is send through ajax (trigger disable send button for example)
	 */
	setOnSubmit: function( f ) {
		this.onSubmitF = f;
	},
	
	/** private functions **/
	
	getFormData: function( ){
		
		var result = new Hash();
		
		this.form.getElements( "input, textarea, select" ).each( function( element ) {			
			result[element.get("name")] = this.getElementValue( element );			
		}.bind( this ));
		
		return result.toQueryString();
	},
	
	getElementValue: function( element ) {		
		var value = ( element.type != "radio" && element.type != "checkbox" ) || element.checked ? element.get( "value" ) : "";
		
		if ( value == element.get( "default" ) )
			return "";
		
		return value;
	},
	
	onFormSuccess: function( jsonObject ) {
		// if feedback is enabled, show feedback if available
		if ( this.options.feedback && jsonObject && jsonObject.feedback )
		{
			if ( jsonObject.feedback.status )
				this.feedback.set( "class", "feedback feedback-" + jsonObject.feedback.status );
			this.feedbackinner.set( "html", jsonObject.feedback.message );
			this.feedback.setStyle( "display", "block" );
		}
		
		if ( this.onSuccessF ) this.onSuccessF( this, jsonObject );		
		
		// clear form on success if set
		if ( jsonObject && jsonObject.reset == "yes" )
			this.form.reset();
	},
	
	onFormSubmit: function( data ) {
		if ( this.options.feedback )
		{
			this.feedback.setStyle( "display", "none" );
		}
		
		if ( this.onSubmitF ) this.onSubmitF( this, data );
	},
	
	submit: function( ) {
		this.onFormSubmit( );
		var data = this.getFormData( );						
		this.request.post({'rs': this.ajaxCallFunction, 'een': this.form.get("id"), 'twee': data});
	},
	
	cancel: function( ) {
		this.request.cancel();		
	}
	
});




/**
 * Development Javascript Toolkit
 * 
 * Utility bar at the bottom of the screen to view php variables.
 */
var DeJaTo = new Class({
	
	initialize: function( )
	{
		if ( !Browser.Engine.gecko ) // firefox only, ow ye
			return;
	
		this.container = new Element( "div", {			
			styles: {
				backgroundColor: "#fcfcfc",
				borderTop: "1px solid #7f7f7f",
				padding: "5px",
				position: "fixed",
				width: "100%",
				bottom: 0,	
				left: 0,
				zIndex: 5000
			}
		}).inject( document.getElement( "body" ) );
		
		// pad the bottom of the body to show the full page
		document.getElement( "body" ).setStyle( "paddingBottom", 38 );
		
		this.console = new Element( "div", {
			html: "",
			styles: {
				backgroundColor: "#efefff",
				color: "#000000",
				border: "1px solid #7f7f7f",
				padding: "10px",
				position: "absolute",
				right: "10px",
				bottom: "0px",
				width: "500px",
				zIndex: 1001,
				visibility: "hidden"
			}
		}).inject( this.container );
		
		this.slideout = new Element( "div", {
			html: "test",
			styles: {
				backgroundColor: "#efefef",
				padding: "5px",
				border: "1px solid #7f7f7f",
				position: "absolute",
				bottom: "36px",
				width: "1000px",
				height: "500px",
				overflow: "auto",
				left: "-1px",
				visibility: "hidden"
			}
		}).inject( this.container );
		
		e = new Element( "a", {
			html: "$_SESSION",
			href: "javascript:;",
			styles: {
				display: "block",
				border: "1px solid #ccc",
				float: "left",
				color: "black",
				fontSize: "11px",
				padding: "5px",
				marginRight: "5px",
				backgroundColor: "#efefef"
			},
			events: {
				"click": function( event ) {
					this.showSession( );
				}.bindWithEvent( this )
			}		
		}).inject( this.container );
		
		e = new Element( "a", {
			html: "$_SERVER",
			href: "javascript:;",
			styles: {
				display: "block",
				border: "1px solid #ccc",
				float: "left",
				color: "black",
				fontSize: "11px",
				padding: "5px",
				marginRight: "5px",
				backgroundColor: "#efefef"
			},
			events: {
				"click": function( event ) {
					this.showServer( );
				}.bindWithEvent( this )
			}		
		}).inject( this.container );
		
		e = new Element( "a", {
			html: "PHPINFO",
			href: "javascript:;",
			styles: {
				display: "block",
				border: "1px solid #ccc",
				float: "left",
				color: "black",
				fontSize: "11px",
				padding: "5px",
				marginRight: "5px",
				backgroundColor: "#efefef"
			},
			events: {
				"click": function( event ) {
					this.showInfo( );
				}.bindWithEvent( this )
			}		
		}).inject( this.container );
		
		var checkCookie = Cookie.read( "dejato-redirect" );
		
		e = new Element( "input", {
			name: "redirect",
			type: "checkbox",
			"class": "checkbox",
			checked: ( checkCookie == "ja" ? "checked" : null ),
			events: {
				"click": function( event ) {
					Cookie.write( "dejato-redirect", ( event.target.checked ? "ja" : "nee" ), {duration: 356} );
				}.bindWithEvent( this )
			}		
		}).inject( this.container );
		
		e = new Element( "label", {
			html: "Delay redirect"
		}).inject( this.container );
		
		clr = new Element( "div", {
			styles: {
				clear: "both"
			}
		}).inject( this.container );
		
		this.request = new Request({
			url: baseurl+'ajax',
			onSuccess: function( responseText, responseXML ) {
				this.slideout.set( "html", responseText );				
				this.slideout.setStyle( "visibility", "visible" );
				this.registerBodyClick();
			}.bind( this )
		});		
	},
	
	log: function( message ) {
		
		$clear( this.logtimer );
		
		this.console.set( "html", message + "<br />" + this.console.get( "html" ) );
		this.console.setStyle( "visibility", "visible" );
		
		this.logtimer = function( ) {
			this.console.setStyle( "visibility", "hidden" );
			this.console.set( "html", "" );
		}.bind( this ).delay( 5000 );
		
	},
	
	registerBodyClick: function( )
	{
		var bodyF = function( event ) {
			document.removeEvent( "click", bodyF );
			this.slideout.setStyle( "visibility", "hidden" );			
		}.bindWithEvent( this );
		document.addEvent( "click", bodyF );
	},	
	
	showSession: function( )
	{		
		this.request.post( {"rs": "dejatoSession"} );
	},
	
	showServer: function( )
	{
		this.request.post( {"rs": "dejatoServer"} );
	},

	showInfo: function( )
	{		
		this.request.post( {"rs": "dejatoInfo"} );
	}

});


/**
 * Class to manage labels and tabs
 */
var ApolairTab = new Class({
	
	initialize: function( label, tab ) 
	{
		this.label = label;
		this.tab = tab;
		this.active = false;
		
		if ( this.label == null || this.tab == null )
			return;
		
		this.label.addEvent( "click", function( event ) {
			this.label.fireEvent( "activate", this );
			this.active = true;
		}.bindWithEvent( this ) );		
	},

	getLabelSize: function( ) 
	{
		return this.label.getSize();
	},
	
	activate: function( )
	{
		this.active = true;
		this.label.fireEvent( "activate", this );
	},
	
	deactivate: function( )
	{
		this.active = false;
		this.label.fireEvent( "deactivate", this );		
	},

	addEvent: function( trigger, func )
	{
		this.label.addEvent( trigger, func );
	}
});

var ApolairTabbedPane = new Class({
	
	initialize: function( )
	{
		this.tabs = new Array();
		this.activetab = null;
	},
	
	addTab: function( tab )
	{
		if ( tab.label == null || tab.tab == null )
			return;
		
		this.tabs.extend([tab]);
		
		tab.addEvent( "activate", function( event ) {			
			this.deactivateActiveTab();
			this.activetab = tab;		
			tab.label.addClass( "apolairtabbedpane-active" );
			tab.tab.addClass( "apolairtabbedpane-active" );
		}.bindWithEvent( this ));
		
		tab.addEvent( "deactivate", function( event ) {						
			tab.label.removeClass( "apolairtabbedpane-active" );
			tab.tab.removeClass( "apolairtabbedpane-active" );
		}.bindWithEvent( this ));
	},
	
	addTabs: function( tabs )
	{
		tabs.each( function( tab ) {
			this.addTab( tab );
		}.bind( this ) );
	},
	
	deactivateActiveTab: function( )
	{
		if ( this.activetab )
			this.activetab.deactivate();
	}
})




/**
 * Lightbox framework
 *
 * @author Constantin Stürmer
 * @copyright Constantin Stürmer, Apolair Internet Solutions
 */


/**
 * Create a dialog
 */
var GoogleMapLightBox = new Class({
	Extends: Lightbox,
	initialize: function( box_width, box_height, id, name, address, moviewidth, movieheight ) {
	
		// initalize the parent
		this.parent( box_width );
		var myLightbox = this;
		this.movieid = id;
		this.moviename = name;

		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': '#',
				'html': 'X'				
			}))
			.addEvent( 'click', function(e) {
				new Event(e).stop();
				myLightbox.stopAndHide();				
			})			
			.getParent()
			.appendChild( new Element( 'div', {
			    'html': '<h1>'+name+'</h1>'
			}))
			.getParent()
			.getParent()
			.getParent()
			.appendChild( new Element( 'div', {
				'class': 'body_outer'
			}))
			.appendChild( this.body = new Element( 'div', {				
				'class': 'body_inner'
			}))
			.appendChild( new Element( 'div', {
				'id': id,
				'styles': {width:moviewidth,height:movieheight}
			}));
			
		if ( box_height != '' )			
			this.body.setStyle( 'height', box_height );
		
		if ( address != '' )
			this.googleMapLoad( id, name, address);

	},
	
	setAddressAndCoordinates: function( address, longitude, latitude )
	{
		if ( GBrowserIsCompatible() ) 
		{
	    	this.map = new GMap2( $( this.movieid ) );
	    	var point = new GLatLng( latitude, longitude );
	    	this.showMap( this.moviename, address, point );
		}
		return this;
	},
		
	stopAndHide: function( ) {
		this.hide();
		
	},

	googleMapLoad: function( id, name, address ) {
		if ( GBrowserIsCompatible() ) 
		{
	    	this.map = new GMap2( $( id ) );
			this.geocoder = new GClientGeocoder();
			this.showAddress( name, address );						
		}
	},

	createMarker: function( point, content ) {  
		var marker = new GMarker( point );  
		GEvent.addListener(marker, "click", function() {
			marker.openInfoWindowHtml( content );  
		});
		return marker;
	},
	
	showAddress: function( name, address ) {
		if ( !this.geocoder )
			return; 
		
    	this.geocoder.getLatLng(
			address,
	        function( point ) {
	           	if ( !point ) {
	        		alert(address + " not found");
	           	} else {
	              	this.showMap( name, address, point );	              
				}
			}.bind( this )
        );
	},
	
	showMap: function( name, address, point )
	{
		this.map.setCenter( point, 13, G_HYBRID_MAP );

		// Add control for zoom
  		this.map.addControl(new GSmallMapControl());
  		
	 	// Add control for type
		this.map.addControl(new GMapTypeControl());

		var link = '<br /><font size="1"><a href="http://maps.google.com?f=d&q='+address+'" target="_new">Plan hier uw route</a></font>';
		var content = '<font size="2">'+name+'</font><br /><font size="1">'+address+'</font>';
		content = '<div style="background:white;">'+content+link+'</div>';
		this.map.addOverlay( this.createMarker( point, content ) );
	}
	
});

	
		

	    




// ***** Configuratie *****
var prefix_clickouts = "/clickout/";
var prefix_mailto    = "/mailto/";
var ignore_urls      =  ""; 

function checkLinkToOwnDomains(txt)
{
	for (var i = 0; i <= ignore_urls.length; i++)
		if (txt.indexOf(ignore_urls[i]) > -1) return false;

	return true;
}

function initClickthrough( custom_ignore_urls )
{
	ignore_urls = document.domain + " " + custom_ignore_urls;
	ignore_urls = ignore_urls.replace(/^\s+/,'').replace(/\s+$/,''); 
	ignore_urls = ignore_urls.split(" ");
	
	// Get all A from the document
	$$("a").each( function( elm ) {

		var path = elm.href + "";
	    
	  	// Javascript (skip it)
	  	if ( path.indexOf( "javascript:" ) > -1 )
	  		return;
	  
	  	// Downloads
	  	if (path.match(/\.(doc|eps|jpg|png|svg|xls|ppt|pdf|xls|zip|txt|vsd|vxd|js|css|rar|exe|wma|mov|avi|wmv|mp3)/) != null)
	  	{
	    	if ((path.indexOf("http://" + location.host) > -1) || (checkLinkToOwnDomains(path) == false))
	    	{
				elm.addEvent( "click", function( e ) { pageTracker._trackPageview(this.href) }.bindWithEvent( elm ));
			}
		}
	  
	  	// Mailto's
	  	if (path.indexOf("mailto:") > -1)
	  	{
			elm.addEvent( "click", function( e ) { pageTracker._trackPageview(prefix_mailto + (this.href).substr(7)) }.bindWithEvent( elm ) );
		}
		
		// Uitgaande links
		if ((checkLinkToOwnDomains(path)) && (path.indexOf("mailto:") == -1))
		{ 			
			elm.addEvent( "click", function( e ) { pageTracker._trackPageview(prefix_clickouts + (this.href).substr(7)) }.bindWithEvent( elm ) );			 
		}
	});	
}