//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"};Class.Mutators.Binds=function(a){return a;};Class.Mutators.initialize=function(a){return function(){$splat(this.Binds).each(function(b){var c=this[b];
if(c){this[b]=c.bind(this);}},this);return a.apply(this,arguments);};};Element.implement({tidy:function(){this.set("value",this.get("value").tidy());},getTextInRange:function(b,a){return this.get("value").substring(b,a);
},getSelectedText:function(){if(this.setSelectionRange){return this.getTextInRange(this.getSelectionStart(),this.getSelectionEnd());}return document.selection.createRange().text;
},getSelectedRange:function(){if($defined(this.selectionStart)){return{start:this.selectionStart,end:this.selectionEnd};}var e={start:0,end:0};var a=this.getDocument().selection.createRange();
if(!a||a.parentElement()!=this){return e;}var c=a.duplicate();if(this.type=="text"){e.start=0-c.moveStart("character",-100000);e.end=e.start+a.text.length;
}else{var b=this.get("value");var d=b.length-b.match(/[\n\r]*$/)[0].length;c.moveToElementText(this);c.setEndPoint("StartToEnd",a);e.end=d-c.text.length;
c.setEndPoint("StartToStart",a);e.start=d-c.text.length;}return e;},getSelectionStart:function(){return this.getSelectedRange().start;},getSelectionEnd:function(){return this.getSelectedRange().end;
},setCaretPosition:function(a){if(a=="end"){a=this.get("value").length;}this.selectRange(a,a);return this;},getCaretPosition:function(){return this.getSelectedRange().start;
},selectRange:function(e,a){if(this.setSelectionRange){this.focus();this.setSelectionRange(e,a);}else{var c=this.get("value");var d=c.substr(e,a-e).replace(/\r/g,"").length;
e=c.substr(0,e).replace(/\r/g,"").length;var b=this.createTextRange();b.collapse(true);b.moveEnd("character",e+d);b.moveStart("character",e);b.select();
}return this;},insertAtCursor:function(b,a){var d=this.getSelectedRange();var c=this.get("value");this.set("value",c.substring(0,d.start)+b+c.substring(d.end,c.length));
if($pick(a,true)){this.selectRange(d.start,d.start+b.length);}else{this.setCaretPosition(d.start+b.length);}return this;},insertAroundCursor:function(b,a){b=$extend({before:"",defaultMiddle:"",after:""},b);
var c=this.getSelectedText()||b.defaultMiddle;var g=this.getSelectedRange();var f=this.get("value");if(g.start==g.end){this.set("value",f.substring(0,g.start)+b.before+c+b.after+f.substring(g.end,f.length));
this.selectRange(g.start+b.before.length,g.end+b.before.length+c.length);}else{var d=f.substring(g.start,g.end);this.set("value",f.substring(0,g.start)+b.before+d+b.after+f.substring(g.end,f.length));
var e=g.start+b.before.length;if($pick(a,true)){this.selectRange(e,e+d.length);}else{this.setCaretPosition(e+f.length);}}return this;}});Fx.Elements=new Class({Extends:Fx.CSS,initialize:function(b,a){this.elements=this.subject=$$(b);
this.parent(a);},compute:function(g,h,j){var c={};for(var d in g){var a=g[d],e=h[d],f=c[d]={};for(var b in a){f[b]=this.parent(a[b],e[b],j);}}return c;
},set:function(b){for(var c in b){var a=b[c];for(var d in a){this.render(this.elements[c],d,a[d],this.options.unit);}}return this;},start:function(c){if(!this.check(c)){return this;
}var h={},j={};for(var d in c){var f=c[d],a=h[d]={},g=j[d]={};for(var b in f){var e=this.prepare(this.elements[d],b,f[b]);a[b]=e.from;g[b]=e.to;}}return this.parent(h,j);
}});var Accordion=Fx.Accordion=new Class({Extends:Fx.Elements,options:{display:0,show:false,height:true,width:false,opacity:true,fixedHeight:false,fixedWidth:false,wait:false,alwaysHide:false,trigger:"click",initialDisplayFx:true},initialize:function(){var c=Array.link(arguments,{container:Element.type,options:Object.type,togglers:$defined,elements:$defined});
this.parent(c.elements,c.options);this.togglers=$$(c.togglers);this.container=document.id(c.container);this.previous=-1;if(this.options.alwaysHide){this.options.wait=true;
}if($chk(this.options.show)){this.options.display=false;this.previous=this.options.show;}if(this.options.start){this.options.display=false;this.options.show=false;
}this.effects={};if(this.options.opacity){this.effects.opacity="fullOpacity";}if(this.options.width){this.effects.width=this.options.fixedWidth?"fullWidth":"offsetWidth";
}if(this.options.height){this.effects.height=this.options.fixedHeight?"fullHeight":"scrollHeight";}for(var b=0,a=this.togglers.length;b<a;b++){this.addSection(this.togglers[b],this.elements[b]);
}this.elements.each(function(e,d){if(this.options.show===d){this.fireEvent("active",[this.togglers[d],e]);}else{for(var f in this.effects){e.setStyle(f,0);
}}},this);if($chk(this.options.display)){this.display(this.options.display,this.options.initialDisplayFx);}},addSection:function(d,b){d=document.id(d);
b=document.id(b);var e=this.togglers.contains(d);this.togglers.include(d);this.elements.include(b);var a=this.togglers.indexOf(d);d.addEvent(this.options.trigger,this.display.bind(this,a));
if(this.options.height){b.setStyles({"padding-top":0,"border-top":"none","padding-bottom":0,"border-bottom":"none"});}if(this.options.width){b.setStyles({"padding-left":0,"border-left":"none","padding-right":0,"border-right":"none"});
}b.fullOpacity=1;if(this.options.fixedWidth){b.fullWidth=this.options.fixedWidth;}if(this.options.fixedHeight){b.fullHeight=this.options.fixedHeight;}b.setStyle("overflow","hidden");
if(!e){for(var c in this.effects){b.setStyle(c,0);}}return this;},display:function(a,b){b=$pick(b,true);a=($type(a)=="element")?this.elements.indexOf(a):a;
if((this.timer&&this.options.wait)||(a===this.previous&&!this.options.alwaysHide)){return this;}this.previous=a;var c={};this.elements.each(function(f,e){c[e]={};
var d=(e!=a)||(this.options.alwaysHide&&(f.offsetHeight>0));this.fireEvent(d?"background":"active",[this.togglers[e],f]);for(var g in this.effects){c[e][g]=d?0:f[this.effects[g]];
}},this);return b?this.start(c):this.set(c);}});Fx.Scroll=new Class({Extends:Fx,options:{offset:{x:0,y:0},wheelStops:true},initialize:function(b,a){this.element=this.subject=document.id(b);
this.parent(a);var d=this.cancel.bind(this,false);if($type(this.element)!="element"){this.element=document.id(this.element.getDocument().body);}var c=this.element;
if(this.options.wheelStops){this.addEvent("start",function(){c.addEvent("mousewheel",d);},true);this.addEvent("complete",function(){c.removeEvent("mousewheel",d);
},true);}},set:function(){var a=Array.flatten(arguments);this.element.scrollTo(a[0],a[1]);},compute:function(c,b,a){return[0,1].map(function(d){return Fx.compute(c[d],b[d],a);
});},start:function(c,h){if(!this.check(c,h)){return this;}var e=this.element.getSize(),f=this.element.getScrollSize();var b=this.element.getScroll(),d={x:c,y:h};
for(var g in d){var a=f[g]-e[g];if($chk(d[g])){d[g]=($type(d[g])=="number")?d[g].limit(0,a):a;}else{d[g]=b[g];}d[g]+=this.options.offset[g];}return this.parent([b.x,b.y],[d.x,d.y]);
},toTop:function(){return this.start(false,0);},toLeft:function(){return this.start(0,false);},toRight:function(){return this.start("right",false);},toBottom:function(){return this.start(false,"bottom");
},toElement:function(b){var a=document.id(b).getPosition(this.element);return this.start(a.x,a.y);},scrollIntoView:function(c,e,d){e=e?$splat(e):["x","y"];
var h={};c=document.id(c);var f=c.getPosition(this.element);var i=c.getSize();var g=this.element.getScroll();var a=this.element.getSize();var b={x:f.x+i.x,y:f.y+i.y};
["x","y"].each(function(j){if(e.contains(j)){if(b[j]>g[j]+a[j]){h[j]=b[j]-a[j];}if(f[j]<g[j]){h[j]=f[j];}}if(h[j]==null){h[j]=g[j];}if(d&&d[j]){h[j]=h[j]+d[j];
}},this);if(h.x!=g.x||h.y!=g.y){this.start(h.x,h.y);}return this;}});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;}});var SmoothScroll=Fx.SmoothScroll=new Class({Extends:Fx.Scroll,initialize:function(b,c){c=c||document;
this.doc=c.getDocument();var d=c.getWindow();this.parent(this.doc,b);this.links=this.options.links?$$(this.options.links):$$(this.doc.links);var a=d.location.href.match(/^[^#]*/)[0]+"#";
this.links.each(function(f){if(f.href.indexOf(a)!=0){return;}var e=f.href.substr(a.length);if(e){this.useLink(f,e);}},this);if(!Browser.Engine.webkit419){this.addEvent("complete",function(){d.location.hash=this.anchor;
},true);}},useLink:function(c,a){var b;c.addEvent("click",function(d){if(b!==false&&!b){b=document.id(a)||this.doc.getElement("a[name="+a+"]");}if(b){d.preventDefault();
this.anchor=a;this.toElement(b);c.blur();}}.bind(this));}});var Drag=new Class({Implements:[Events,Options],options:{snap:6,unit:"px",grid:false,style:true,limit:false,handle:false,invert:false,preventDefault:false,modifiers:{x:"left",y:"top"}},initialize:function(){var b=Array.link(arguments,{options:Object.type,element:$defined});
this.element=document.id(b.element);this.document=this.element.getDocument();this.setOptions(b.options||{});var a=$type(this.options.handle);this.handles=((a=="array"||a=="collection")?$$(this.options.handle):document.id(this.options.handle))||this.element;
this.mouse={now:{},pos:{}};this.value={start:{},now:{}};this.selection=(Browser.Engine.trident)?"selectstart":"mousedown";this.bound={start:this.start.bind(this),check:this.check.bind(this),drag:this.drag.bind(this),stop:this.stop.bind(this),cancel:this.cancel.bind(this),eventStop:$lambda(false)};
this.attach();},attach:function(){this.handles.addEvent("mousedown",this.bound.start);return this;},detach:function(){this.handles.removeEvent("mousedown",this.bound.start);
return this;},start:function(c){if(this.options.preventDefault){c.preventDefault();}this.mouse.start=c.page;this.fireEvent("beforeStart",this.element);
var a=this.options.limit;this.limit={x:[],y:[]};for(var d in this.options.modifiers){if(!this.options.modifiers[d]){continue;}if(this.options.style){this.value.now[d]=this.element.getStyle(this.options.modifiers[d]).toInt();
}else{this.value.now[d]=this.element[this.options.modifiers[d]];}if(this.options.invert){this.value.now[d]*=-1;}this.mouse.pos[d]=c.page[d]-this.value.now[d];
if(a&&a[d]){for(var b=2;b--;b){if($chk(a[d][b])){this.limit[d][b]=$lambda(a[d][b])();}}}}if($type(this.options.grid)=="number"){this.options.grid={x:this.options.grid,y:this.options.grid};
}this.document.addEvents({mousemove:this.bound.check,mouseup:this.bound.cancel});this.document.addEvent(this.selection,this.bound.eventStop);},check:function(a){if(this.options.preventDefault){a.preventDefault();
}var b=Math.round(Math.sqrt(Math.pow(a.page.x-this.mouse.start.x,2)+Math.pow(a.page.y-this.mouse.start.y,2)));if(b>this.options.snap){this.cancel();this.document.addEvents({mousemove:this.bound.drag,mouseup:this.bound.stop});
this.fireEvent("start",[this.element,a]).fireEvent("snap",this.element);}},drag:function(a){if(this.options.preventDefault){a.preventDefault();}this.mouse.now=a.page;
for(var b in this.options.modifiers){if(!this.options.modifiers[b]){continue;}this.value.now[b]=this.mouse.now[b]-this.mouse.pos[b];if(this.options.invert){this.value.now[b]*=-1;
}if(this.options.limit&&this.limit[b]){if($chk(this.limit[b][1])&&(this.value.now[b]>this.limit[b][1])){this.value.now[b]=this.limit[b][1];}else{if($chk(this.limit[b][0])&&(this.value.now[b]<this.limit[b][0])){this.value.now[b]=this.limit[b][0];
}}}if(this.options.grid[b]){this.value.now[b]-=((this.value.now[b]-(this.limit[b][0]||0))%this.options.grid[b]);}if(this.options.style){this.element.setStyle(this.options.modifiers[b],this.value.now[b]+this.options.unit);
}else{this.element[this.options.modifiers[b]]=this.value.now[b];}}this.fireEvent("drag",[this.element,a]);},cancel:function(a){this.document.removeEvent("mousemove",this.bound.check);
this.document.removeEvent("mouseup",this.bound.cancel);if(a){this.document.removeEvent(this.selection,this.bound.eventStop);this.fireEvent("cancel",this.element);
}},stop:function(a){this.document.removeEvent(this.selection,this.bound.eventStop);this.document.removeEvent("mousemove",this.bound.drag);this.document.removeEvent("mouseup",this.bound.stop);
if(a){this.fireEvent("complete",[this.element,a]);}}});Element.implement({makeResizable:function(a){var b=new Drag(this,$merge({modifiers:{x:"width",y:"height"}},a));
this.store("resizer",b);return b.addEvent("drag",function(){this.fireEvent("resize",b);}.bind(this));}});Drag.Move=new Class({Extends:Drag,options:{droppables:[],container:false,precalculate:false,includeMargins:true,checkDroppables:true},initialize:function(c,b){this.parent(c,b);
this.droppables=$$(this.options.droppables);this.container=document.id(this.options.container);if(this.container&&$type(this.container)!="element"){this.container=document.id(this.container.getDocument().body);
}var a=this.element.getStyle("position");if(a=="static"){a="absolute";}if([this.element.getStyle("left"),this.element.getStyle("top")].contains("auto")){this.element.position(this.element.getPosition(this.element.offsetParent));
}this.element.setStyle("position",a);this.addEvent("start",this.checkDroppables,true);this.overed=null;},start:function(f){if(this.container){var b=this.container.getCoordinates(this.element.getOffsetParent()),c={},e={};
["top","right","bottom","left"].each(function(g){c[g]=this.container.getStyle("border-"+g).toInt();e[g]=this.element.getStyle("margin-"+g).toInt();},this);
var d=this.element.offsetWidth+e.left+e.right;var a=this.element.offsetHeight+e.top+e.bottom;if(this.options.includeMargins){$each(e,function(h,g){e[g]=0;
});}if(this.container==this.element.getOffsetParent()){this.options.limit={x:[0-e.left,b.right-c.left-c.right-d+e.right],y:[0-e.top,b.bottom-c.top-c.bottom-a+e.bottom]};
}else{this.options.limit={x:[b.left+c.left-e.left,b.right-c.right-d+e.right],y:[b.top+c.top-e.top,b.bottom-c.bottom-a+e.bottom]};}}if(this.options.precalculate){this.positions=this.droppables.map(function(g){return g.getCoordinates();
});}this.parent(f);},checkAgainst:function(c,b){c=(this.positions)?this.positions[b]:c.getCoordinates();var a=this.mouse.now;return(a.x>c.left&&a.x<c.right&&a.y<c.bottom&&a.y>c.top);
},checkDroppables:function(){var a=this.droppables.filter(this.checkAgainst,this).getLast();if(this.overed!=a){if(this.overed){this.fireEvent("leave",[this.element,this.overed]);
}if(a){this.fireEvent("enter",[this.element,a]);}this.overed=a;}},drag:function(a){this.parent(a);if(this.options.checkDroppables&&this.droppables.length){this.checkDroppables();
}},stop:function(a){this.checkDroppables();this.fireEvent("drop",[this.element,this.overed,a]);this.overed=null;return this.parent(a);}});Element.implement({makeDraggable:function(a){var b=new Drag.Move(this,a);
this.store("dragger",b);return b;}});var Slider=new Class({Implements:[Events,Options],Binds:["clickedElement","draggedKnob","scrolledElement"],options:{onTick:function(a){if(this.options.snap){a=this.toPosition(this.step);
}this.knob.setStyle(this.property,a);},snap:false,offset:0,range:false,wheel:false,steps:100,mode:"horizontal"},initialize:function(f,a,e){this.setOptions(e);
this.element=document.id(f);this.knob=document.id(a);this.previousChange=this.previousEnd=this.step=-1;var g,b={},d={x:false,y:false};switch(this.options.mode){case"vertical":this.axis="y";
this.property="top";g="offsetHeight";break;case"horizontal":this.axis="x";this.property="left";g="offsetWidth";}this.half=this.knob[g]/2;this.full=this.element[g]-this.knob[g]+(this.options.offset*2);
this.min=$chk(this.options.range[0])?this.options.range[0]:0;this.max=$chk(this.options.range[1])?this.options.range[1]:this.options.steps;this.range=this.max-this.min;
this.steps=this.options.steps||this.full;this.stepSize=Math.abs(this.range)/this.steps;this.stepWidth=this.stepSize*this.full/Math.abs(this.range);this.knob.setStyle("position","relative").setStyle(this.property,-this.options.offset);
d[this.axis]=this.property;b[this.axis]=[-this.options.offset,this.full-this.options.offset];this.bound={clickedElement:this.clickedElement.bind(this),scrolledElement:this.scrolledElement.bindWithEvent(this),draggedKnob:this.draggedKnob.bind(this)};
var c={snap:0,limit:b,modifiers:d,onDrag:this.bound.draggedKnob,onStart:this.bound.draggedKnob,onBeforeStart:(function(){this.isDragging=true;}).bind(this),onComplete:function(){this.isDragging=false;
this.draggedKnob();this.end();}.bind(this)};if(this.options.snap){c.grid=Math.ceil(this.stepWidth);c.limit[this.axis][1]=this.full;}this.drag=new Drag(this.knob,c);
this.attach();},attach:function(){this.element.addEvent("mousedown",this.bound.clickedElement);if(this.options.wheel){this.element.addEvent("mousewheel",this.bound.scrolledElement);
}this.drag.attach();return this;},detach:function(){this.element.removeEvent("mousedown",this.bound.clickedElement);this.element.removeEvent("mousewheel",this.bound.scrolledElement);
this.drag.detach();return this;},set:function(a){if(!((this.range>0)^(a<this.min))){a=this.min;}if(!((this.range>0)^(a>this.max))){a=this.max;}this.step=Math.round(a);
this.checkStep();this.fireEvent("tick",this.toPosition(this.step));this.end();return this;},clickedElement:function(c){if(this.isDragging||c.target==this.knob){return;
}var b=this.range<0?-1:1;var a=c.page[this.axis]-this.element.getPosition()[this.axis]-this.half;a=a.limit(-this.options.offset,this.full-this.options.offset);
this.step=Math.round(this.min+b*this.toStep(a));this.checkStep();this.fireEvent("tick",a);this.end();},scrolledElement:function(a){var b=(this.options.mode=="horizontal")?(a.wheel<0):(a.wheel>0);
this.set(b?this.step-this.stepSize:this.step+this.stepSize);a.stop();},draggedKnob:function(){var b=this.range<0?-1:1;var a=this.drag.value.now[this.axis];
a=a.limit(-this.options.offset,this.full-this.options.offset);this.step=Math.round(this.min+b*this.toStep(a));this.checkStep();},checkStep:function(){if(this.previousChange!=this.step){this.previousChange=this.step;
this.fireEvent("change",this.step);}},end:function(){if(this.previousEnd!==this.step){this.previousEnd=this.step;this.fireEvent("complete",this.step+"");
}},toStep:function(a){var b=(a+this.options.offset)*this.stepSize/this.full*this.steps;return this.options.steps?Math.round(b-=b%this.stepSize):b;},toPosition:function(a){return(this.full*Math.abs(this.min-a))/(this.steps*this.stepSize)-this.options.offset;
}});var Sortables=new Class({Implements:[Events,Options],options:{snap:4,opacity:1,clone:false,revert:false,handle:false,constrain:false},initialize:function(a,b){this.setOptions(b);
this.elements=[];this.lists=[];this.idle=true;this.addLists($$(document.id(a)||a));if(!this.options.clone){this.options.revert=false;}if(this.options.revert){this.effect=new Fx.Morph(null,$merge({duration:250,link:"cancel"},this.options.revert));
}},attach:function(){this.addLists(this.lists);return this;},detach:function(){this.lists=this.removeLists(this.lists);return this;},addItems:function(){Array.flatten(arguments).each(function(a){this.elements.push(a);
var b=a.retrieve("sortables:start",this.start.bindWithEvent(this,a));(this.options.handle?a.getElement(this.options.handle)||a:a).addEvent("mousedown",b);
},this);return this;},addLists:function(){Array.flatten(arguments).each(function(a){this.lists.push(a);this.addItems(a.getChildren());},this);return this;
},removeItems:function(){return $$(Array.flatten(arguments).map(function(a){this.elements.erase(a);var b=a.retrieve("sortables:start");(this.options.handle?a.getElement(this.options.handle)||a:a).removeEvent("mousedown",b);
return a;},this));},removeLists:function(){return $$(Array.flatten(arguments).map(function(a){this.lists.erase(a);this.removeItems(a.getChildren());return a;
},this));},getClone:function(b,a){if(!this.options.clone){return new Element("div").inject(document.body);}if($type(this.options.clone)=="function"){return this.options.clone.call(this,b,a,this.list);
}return a.clone(true).setStyles({margin:"0px",position:"absolute",visibility:"hidden",width:a.getStyle("width")}).inject(this.list).position(a.getPosition(a.getOffsetParent()));
},getDroppables:function(){var a=this.list.getChildren();if(!this.options.constrain){a=this.lists.concat(a).erase(this.list);}return a.erase(this.clone).erase(this.element);
},insert:function(c,b){var a="inside";if(this.lists.contains(b)){this.list=b;this.drag.droppables=this.getDroppables();}else{a=this.element.getAllPrevious().contains(b)?"before":"after";
}this.element.inject(b,a);this.fireEvent("sort",[this.element,this.clone]);},start:function(b,a){if(!this.idle){return;}this.idle=false;this.element=a;
this.opacity=a.get("opacity");this.list=a.getParent();this.clone=this.getClone(b,a);this.drag=new Drag.Move(this.clone,{snap:this.options.snap,container:this.options.constrain&&this.element.getParent(),droppables:this.getDroppables(),onSnap:function(){b.stop();
this.clone.setStyle("visibility","visible");this.element.set("opacity",this.options.opacity||0);this.fireEvent("start",[this.element,this.clone]);}.bind(this),onEnter:this.insert.bind(this),onCancel:this.reset.bind(this),onComplete:this.end.bind(this)});
this.clone.inject(this.element,"before");this.drag.start(b);},end:function(){this.drag.detach();this.element.set("opacity",this.opacity);if(this.effect){var a=this.element.getStyles("width","height");
var b=this.clone.computePosition(this.element.getPosition(this.clone.offsetParent));this.effect.element=this.clone;this.effect.start({top:b.top,left:b.left,width:a.width,height:a.height,opacity:0.25}).chain(this.reset.bind(this));
}else{this.reset();}},reset:function(){this.idle=true;this.clone.destroy();this.fireEvent("complete",this.element);},serialize:function(){var c=Array.link(arguments,{modifier:Function.type,index:$defined});
var b=this.lists.map(function(d){return d.getChildren().map(c.modifier||function(e){return e.get("id");},this);},this);var a=c.index;if(this.lists.length==1){a=0;
}return $chk(a)&&a>=0&&a<this.lists.length?b[a]:b;}});var Asset={javascript:function(f,d){d=$extend({onload:$empty,document:document,check:$lambda(true)},d);
var b=new Element("script",{src:f,type:"text/javascript"});var e=d.onload.bind(b),a=d.check,g=d.document;delete d.onload;delete d.check;delete d.document;
b.addEvents({load:e,readystatechange:function(){if(["loaded","complete"].contains(this.readyState)){e();}}}).set(d);if(Browser.Engine.webkit419){var c=(function(){if(!$try(a)){return;
}$clear(c);e();}).periodical(50);}return b.inject(g.head);},css:function(b,a){return new Element("link",$merge({rel:"stylesheet",media:"screen",type:"text/css",href:b},a)).inject(document.head);
},image:function(c,b){b=$merge({onload:$empty,onabort:$empty,onerror:$empty},b);var d=new Image();var a=document.id(d)||new Element("img");["load","abort","error"].each(function(e){var f="on"+e;
var g=b[f];delete b[f];d[f]=function(){if(!d){return;}if(!a.parentNode){a.width=d.width;a.height=d.height;}d=d.onload=d.onabort=d.onerror=null;g.delay(1,a,a);
a.fireEvent(e,a,1);};});d.src=a.src=c;if(d&&d.complete){d.onload.delay(1);}return a.set(b);},images:function(d,c){c=$merge({onComplete:$empty,onProgress:$empty,onError:$empty,properties:{}},c);
d=$splat(d);var a=[];var b=0;return new Elements(d.map(function(e){return Asset.image(e,$extend(c.properties,{onload:function(){c.onProgress.call(this,b,d.indexOf(e));
b++;if(b==d.length){c.onComplete();}},onerror:function(){c.onError.call(this,b,d.indexOf(e));b++;if(b==d.length){c.onComplete();}}}));}));}};var Group=new Class({initialize:function(){this.instances=Array.flatten(arguments);
this.events={};this.checker={};},addEvent:function(b,a){this.checker[b]=this.checker[b]||{};this.events[b]=this.events[b]||[];if(this.events[b].contains(a)){return false;
}else{this.events[b].push(a);}this.instances.each(function(c,d){c.addEvent(b,this.check.bind(this,[b,c,d]));},this);return this;},check:function(c,a,b){this.checker[c][b]=true;
var d=this.instances.every(function(f,e){return this.checker[c][e]||false;},this);if(!d){return;}this.checker[c]={};this.events[c].each(function(e){e.call(this,this.instances,a);
},this);}});Hash.Cookie=new Class({Extends:Cookie,options:{autoSave:true},initialize:function(b,a){this.parent(b,a);this.load();},save:function(){var a=JSON.encode(this.hash);
if(!a||a.length>4096){return false;}if(a=="{}"){this.dispose();}else{this.write(a);}return true;},load:function(){this.hash=new Hash(JSON.decode(this.read(),true));
return this;}});Hash.each(Hash.prototype,function(b,a){if(typeof b=="function"){Hash.Cookie.implement(a,function(){var c=b.apply(this.hash,arguments);if(this.options.autoSave){this.save();
}return c;});}});var Scroller=new Class({Implements:[Events,Options],options:{area:20,velocity:1,onChange:function(a,b){this.element.scrollTo(a,b);},fps:50},initialize:function(b,a){this.setOptions(a);
this.element=document.id(b);this.listener=($type(this.element)!="element")?document.id(this.element.getDocument().body):this.element;this.timer=null;this.bound={attach:this.attach.bind(this),detach:this.detach.bind(this),getCoords:this.getCoords.bind(this)};
},start:function(){this.listener.addEvents({mouseenter:this.bound.attach,mouseleave:this.bound.detach});},stop:function(){this.listener.removeEvents({mouseenter:this.bound.attach,mouseleave:this.bound.detach});
this.timer=$clear(this.timer);},attach:function(){this.listener.addEvent("mousemove",this.bound.getCoords);},detach:function(){this.listener.removeEvent("mousemove",this.bound.getCoords);
this.timer=$clear(this.timer);},getCoords:function(a){this.page=(this.listener.get("tag")=="body")?a.client:a.page;if(!this.timer){this.timer=this.scroll.periodical(Math.round(1000/this.options.fps),this);
}},scroll:function(){var b=this.element.getSize(),a=this.element.getScroll(),f=this.element.getOffsets(),c=this.element.getScrollSize(),e={x:0,y:0};for(var d in this.page){if(this.page[d]<(this.options.area+f[d])&&a[d]!=0){e[d]=(this.page[d]-this.options.area-f[d])*this.options.velocity;
}else{if(this.page[d]+this.options.area>(b[d]+f[d])&&a[d]+b[d]!=c[d]){e[d]=(this.page[d]-b[d]+this.options.area-f[d])*this.options.velocity;}}}if(e.y||e.x){this.fireEvent("change",[a.x+e.x,a.y+e.y]);
}}});var Tips=new Class({Implements:[Events,Options],options:{onShow:function(a){a.setStyle("visibility","visible");},onHide:function(a){a.setStyle("visibility","hidden");
},title:"title",text:function(a){return a.get("rel")||a.get("href");},showDelay:100,hideDelay:100,className:null,offset:{x:16,y:16},fixed:false},initialize:function(){var a=Array.link(arguments,{options:Object.type,elements:$defined});
if(a.options&&a.options.offsets){a.options.offset=a.options.offsets;}this.setOptions(a.options);this.container=new Element("div",{"class":"tip"});this.tip=this.getTip();
if(a.elements){this.attach(a.elements);}},getTip:function(){return new Element("div",{"class":this.options.className,styles:{visibility:"hidden",display:"none",position:"absolute",top:0,left:0}}).adopt(new Element("div",{"class":"tip-top"}),this.container,new Element("div",{"class":"tip-bottom"})).inject(document.body);
},attach:function(b){var a=function(d,c){if(d==null){return"";}return $type(d)=="function"?d(c):c.get(d);};$$(b).each(function(d){var e=a(this.options.title,d);
d.erase("title").store("tip:native",e).retrieve("tip:title",e);d.retrieve("tip:text",a(this.options.text,d));var c=["enter","leave"];if(!this.options.fixed){c.push("move");
}c.each(function(f){d.addEvent("mouse"+f,d.retrieve("tip:"+f,this["element"+f.capitalize()].bindWithEvent(this,d)));},this);},this);return this;},detach:function(a){$$(a).each(function(c){["enter","leave","move"].each(function(d){c.removeEvent("mouse"+d,c.retrieve("tip:"+d)||$empty);
});c.eliminate("tip:enter").eliminate("tip:leave").eliminate("tip:move");if($type(this.options.title)=="string"&&this.options.title=="title"){var b=c.retrieve("tip:native");
if(b){c.set("title",b);}}},this);return this;},elementEnter:function(b,a){$A(this.container.childNodes).each(Element.dispose);["title","text"].each(function(d){var c=a.retrieve("tip:"+d);
if(!c){return;}this[d+"Element"]=new Element("div",{"class":"tip-"+d}).inject(this.container);this.fill(this[d+"Element"],c);},this);this.timer=$clear(this.timer);
this.timer=this.show.delay(this.options.showDelay,this,a);this.tip.setStyle("display","block");this.position((!this.options.fixed)?b:{page:a.getPosition()});
},elementLeave:function(b,a){$clear(this.timer);this.tip.setStyle("display","none");this.timer=this.hide.delay(this.options.hideDelay,this,a);},elementMove:function(a){this.position(a);
},position:function(d){var b=window.getSize(),a=window.getScroll(),e={x:this.tip.offsetWidth,y:this.tip.offsetHeight},c={x:"left",y:"top"},f={};for(var g in c){f[c[g]]=d.page[g]+this.options.offset[g];
if((f[c[g]]+e[g]-a[g])>b[g]){f[c[g]]=d.page[g]-this.options.offset[g]-e[g];}}this.tip.setStyles(f);},fill:function(a,b){if(typeof b=="string"){a.set("html",b);
}else{a.adopt(b);}},show:function(a){this.fireEvent("show",[this.tip,a]);},hide:function(a){this.fireEvent("hide",[this.tip,a]);}});
/*
Sortables Improvements
Santiago Cortes

Drag.Move:
onEnter's second parameter (the "entered" object) now has a quadrant attribute indicating entry point (1,2,3,4)
onSwap is now triggered when the current dragged element moves to another quadrant 

Sortables:
Used new Drag.Move enter and swap events to determine insertion point

Script: Chain.Wait.js
	Adds a method to inject pauses between chained events.
	License:	http://www.clientcide.com/wiki/cnet-libraries#license

*/
Drag.Move = new Class({

	Extends: Drag,

	options: {
		droppables: [],
		container: false
	},

	initialize: function(element, options){
		this.parent(element, options);
		this.droppables = $$(this.options.droppables);
		this.container = $(this.options.container);
		if (this.container && $type(this.container) != 'element') this.container = $(this.container.getDocument().body);
		element = this.element;
		
		var current = element.getStyle('position');
		var position = (current != 'static') ? current : 'absolute';
		if (element.getStyle('left') == 'auto' || element.getStyle('top') == 'auto') element.position(element.getPosition(element.offsetParent));
		
		element.setStyle('position', position);
		
		this.addEvent('start', function(){
			this.checkDroppables();
		}, true);
	},

	start: function(event){
		if (this.container){
			var el = this.element, cont = this.container, ccoo = cont.getCoordinates(el.offsetParent), cps = {}, ems = {};

			['top', 'right', 'bottom', 'left'].each(function(pad){
				cps[pad] = cont.getStyle('padding-' + pad).toInt();
				ems[pad] = el.getStyle('margin-' + pad).toInt();
			}, this);

			var width = el.offsetWidth + ems.left + ems.right, height = el.offsetHeight + ems.top + ems.bottom;
			var x = [ccoo.left + cps.left, ccoo.right - cps.right - width];
			var y = [ccoo.top + cps.top, ccoo.bottom - cps.bottom - height];

			this.options.limit = {x: x, y: y};
		}
		this.parent(event);
	},

	checkAgainst: function(el){
		el = el.getCoordinates();
		var now = this.mouse.now;
		return (now.x > el.left && now.x < el.right && now.y < el.bottom && now.y > el.top);
	},

	checkDroppables: function(){
		
		var overed = this.droppables.filter(this.checkAgainst, this).getLast();
		
		if (this.overed != overed){
			
			if (this.overed) {
				this.fireEvent('leave', [this.element, this.overed]);
			}
			
			if (overed) {			
				this.overed = overed;
				
				/* Determine entry quadrant */
				var overed_coords		= this.overed.getCoordinates();
				this.overed.quadrant	= ( this.mouse.now.y < overed_coords.top+overed_coords.height/2 ) ? 0 : 2;
				this.overed.quadrant	+= ( this.mouse.now.x < overed_coords.left+overed_coords.width/2 ) ? 1 : 2;			
				
				this.fireEvent('enter', [this.element, this.overed]);
			
			} else {
				this.overed = null;
			}
		
		} else if ( this.overed ) {		/* Still hovering over the same element. Look for quadrant change */

			/* Determine quadrant changes */
			var overed_coords	= this.overed.getCoordinates();
			var quadrant 		= ( this.mouse.now.y < overed_coords.top+overed_coords.height/2 ) ? 0 : 2;
			quadrant			+= ( this.mouse.now.x < overed_coords.left+overed_coords.width/2 ) ? 1 : 2;
			
			if ( this.overed.quadrant != quadrant ) {
				this.overed.quadrant = quadrant;
				this.fireEvent('swap', [this.element, this.overed]);
			}
		
		}
	},

	drag: function(event){
		this.parent(event);
		if (this.droppables.length) this.checkDroppables();
	},

	stop: function(event){
		this.checkDroppables();
		this.fireEvent('drop', [this.element, this.overed]);
		this.overed = null;
		return this.parent(event);
	}

});




var Sortables = new Class({

	Implements: [Events, Options],

	options: {
		snap: 4,
		opacity: 1,
		clone: false,
		revert: false,
		handle: false,
		constrain: false
	},

	initialize: function(lists, options){
		this.setOptions(options);
		this.elements = [];
		this.lists = [];
		this.idle = true;
		
		this.addLists($$($(lists) || lists));
		if (!this.options.clone) this.options.revert = false;
		if (this.options.revert) this.effect = new Fx.Morph(null, $merge({duration: 250, link: 'cancel'}, this.options.revert));
	},

	attach: function(){
		this.addLists(this.lists);
		return this;
	},

	detach: function(){
		this.lists = this.removeLists(this.lists);
		return this;
	},

	addItems: function(){
		Array.flatten(arguments).each(function(element){
			this.elements.push(element);
			var start = element.retrieve('sortables:start', this.start.bindWithEvent(this, element));
			(this.options.handle ? element.getElement(this.options.handle) || element : element).addEvent('mousedown', start);
		}, this);
		return this;
	},

	addLists: function(){
		Array.flatten(arguments).each(function(list){
			this.lists.push(list);
			this.addItems(list.getChildren());
		}, this);
		return this;
	},

	removeItems: function(){
		var elements = [];
		Array.flatten(arguments).each(function(element){
			elements.push(element);
			this.elements.erase(element);
			var start = element.retrieve('sortables:start');
			(this.options.handle ? element.getElement(this.options.handle) || element : element).removeEvent('mousedown', start);
		}, this);
		return $$(elements);
	},

	removeLists: function(){
		var lists = [];
		Array.flatten(arguments).each(function(list){
			lists.push(list);
			this.lists.erase(list);
			this.removeItems(list.getChildren());
		}, this);
		return $$(lists);
	},

	getClone: function(event, element){
		if (!this.options.clone) return new Element('div').inject(document.body);
		if ($type(this.options.clone) == 'function') return this.options.clone.call(this, event, element, this.list);
		
		/* SCR: Took me a while to figure this out!  Bugfix: Now you can drag from position:FIXED containers to position:STATIC containers */
		offsetParent = element.getOffsetParent()
		pos = element.getPosition(offsetParent)
		if ( offsetParent.getStyle('position') == 'fixed' ) {
			pos.y -= window.getScroll().y
		}
		
		return element.clone(true).setStyles({
			'margin': '0px',
			'position': 'absolute',
			'visibility': 'hidden',
			'width': element.getStyle('width')
		}).inject(this.list).position(pos);
	},

	getDroppables: function(){
		var droppables = this.list.getChildren();
		if (!this.options.constrain) droppables = this.lists.concat(droppables).erase(this.list);
		return droppables.erase(this.clone).erase(this.element);
	},

	insert: function(dragging, element){
		var where = 'inside';
		if (this.lists.contains(element)){
			this.list = element;
			this.drag.droppables = this.getDroppables();
		} else {
			where = element.quadrant <= 2 ? 'before' : 'after';
		}
		this.element.inject(element, where);
		this.fireEvent('sort', [this.element, this.clone]);
	},

	start: function(event, element){
		if (!this.idle) return;
		this.idle = false;
		this.element = element;
		this.opacity = element.get('opacity');
		this.list = element.getParent();
		this.clone = this.getClone(event, element);
		
		this.drag = new Drag.Move(this.clone, {
			snap: this.options.snap,
			container: this.options.constrain && this.element.getParent(),
			droppables: this.getDroppables(),
			onSnap: function(){
				event.stop();
				this.clone.setStyle('visibility', 'visible');
				this.element.set('opacity', this.options.opacity || 0);
				this.fireEvent('start', [this.element, this.clone]);
			}.bind(this),
			onEnter: this.insert.bind(this),
			onSwap: this.insert.bind(this),
			onCancel: this.reset.bind(this),
			onComplete: this.end.bind(this)
		});
		
		this.clone.inject(this.element, 'before');
		this.drag.start(event);
	},

	end: function(){
		this.drag.detach();
		this.element.set('opacity', this.opacity);
		if (this.effect){
			var dim = this.element.getStyles('width', 'height');
			var pos = this.clone.computePosition(this.element.getPosition(this.clone.offsetParent));
			this.effect.element = this.clone;
			this.effect.start({
				top: pos.top,
				left: pos.left,
				width: dim.width,
				height: dim.height,
				opacity: 0.25
			}).chain(this.reset.bind(this));
		} else {
			this.reset();
		}
	},

	reset: function(){
		this.idle = true;
		this.clone.destroy();
		this.fireEvent('complete', this.element);
	},

	serialize: function(){
		var params = Array.link(arguments, {modifier: Function.type, index: $defined});
		var serial = this.lists.map(function(list){
			return list.getChildren().map(params.modifier || function(element){
				return element.get('id');
			}, this);
		}, this);
		
		var index = params.index;
		if (this.lists.length == 1) index = 0;
		return $chk(index) && index >= 0 && index < this.lists.length ? serial[index] : serial;
	}

});

/* 
Use CSS-styled behavior rules
example: 
$$('table.ruler').behave(
	'tr:hover': function(element) { .. add some background .. },
	'tr:click': function(element) { .. highlight .. }
);
*/
Element.implement('behave', function(rules) {
	for ( rule in rules ) {
		var parts = rule.split(':');

		if ( $chk(parts[1]) ) {
			this.getElements(parts[0]).addEvent(parts[1], rules[rule]);
		} else {
			this.getElements(parts[0]).each( function(element) {
				rules[rule].run(null,element);
			});
		}
	}
});


/*
Avoid cloning child <script>
http://mootools.lighthouseapp.com/projects/2706/tickets/225-element-clone-true-clones-and-executes-script-tags-on-ff3 
*/
Element.implement('clone', function(contents, keepid) {
	switch ($type(this)) {
		case 'element':
			var attributes = {};
			for (var j = 0, l = this.attributes.length; j < l; j++){
				var attribute = this.attributes[j], key = attribute.nodeName.toLowerCase();
				if (Browser.Engine.trident && (/input/i).test(this.tagName) && (/width|height/).test(key)) continue;
				var value = (key == 'style' && this.style) ? this.style.cssText : attribute.nodeValue;
				if (!$chk(value) || key == 'uid' || (key == 'id' && !keepid)) continue;
				if (value != 'inherit' && ['string', 'number'].contains($type(value))) attributes[key] = value;
			}
			var element = new Element(this.nodeName.toLowerCase(), attributes);
			if (contents !== false){
				for (var i = 0, k = this.childNodes.length; i < k; i++){
					if (/script/i.test(this.childNodes[i].tagName)) continue;
	
					var child = Element.clone(this.childNodes[i], true, keepid);
					if (child) element.grab(child);
				}
			}
			return element;
		case 'textnode': return document.newTextNode(this.nodeValue);
	}
	return null;
});

/*
visualFocus() and visualBlur()
*/
Element.implement('visualFocus', function(options) {

	options			= options||{};
	options.border	= options.border||0;
	options.color	= options.color||'black';
	options.opacity	= options.opacity||0.8;

	if ( !$chk(this._focus_top) ) {
		initial_settings = {

			_focus_target: this,

			styles: {
				position:	'absolute',
				top:		0,
				left:		0,
				width:		0,
				height:		0,
				background:	options.color,
				opacity:	options.opacity,
				display:	'none',
				zIndex:		999
			},

			events: {
				click: function() {
					target = this._focus_target.visualBlur();
				}
			}
		};

		this._focus_top		= new Element('div', initial_settings).inject(document.body);
		this._focus_right	= new Element('div', initial_settings).inject(document.body);
		this._focus_bottom	= new Element('div', initial_settings).inject(document.body);
		this._focus_left	= new Element('div', initial_settings).inject(document.body);

		this._focus_top._focus_target		= this;
		this._focus_right._focus_target		= this;
		this._focus_bottom._focus_target	= this;
		this._focus_left._focus_target		= this;

		this.addEvent('blur', this.visualBlur);
	}

	winsize		= $(window).getScrollSize();
	coords		= this.getCoordinates();
	
	this._focus_top.setStyles({
		top: 0,
		left: 0,
		width: winsize.x,
		height: coords.top-options.border,
		display: ''
	});

	this._focus_left.setStyles({
		top: coords.top-options.border,
		left: 0,
		width: coords.left-options.border,
		height: coords.height+2*options.border,
		display: ''
	});

	this._focus_right.setStyles({
		top: coords.top-options.border,
		left: coords.left+coords.width+options.border,
		width: winsize.x - (coords.left+coords.width+options.border),
		height: coords.height+2*options.border,
		display: ''
	});

	this._focus_bottom.setStyles({
		top: coords.top+coords.height+options.border,
		left: 0,
		width: winsize.x,
		height: winsize.y-(coords.top+coords.height+options.border),
		display: ''
	});
	
});

Element.implement('visualBlur', function() {
	if ( $chk(this._focus_top) ) {
		this._focus_top.setStyle('display', 'none')
		this._focus_right.setStyle('display', 'none')
		this._focus_bottom.setStyle('display', 'none')
		this._focus_left.setStyle('display', 'none')
		
		this.fireEvent('visualBlur')
	}
});

/*
Script: Chain.Wait.js
	Adds a method to inject pauses between chained events.

License:
	http://www.clientcide.com/wiki/cnet-libraries#license
*/
(function(){
	var wait = {
		wait: function(duration){
			return this.chain(function(){
				this.callChain.delay($pick(duration, 500), this);
			}.bind(this));
		}
	};
	Chain.implement(wait);
	if (window.Fx) {
		Fx.implement(wait);
		['Css', 'Tween', 'Elements'].each(function(cls) {
			if (Fx[cls]) Fx[cls].implement(wait);
		});
	}

	try {
		Element.implement({
			chains: function(effects){
				$splat($pick(effects, ['tween', 'morph', 'reveal'])).each(function(effect){
					this.get(effect).setOptions({
						link:'chain'
					});
				}, this);
				return this;
			},
			pauseFx: function(duration, effect) {
				this.chains(effect).get($pick(effect, 'tween')).wait(duration);
				return this;
			}
		});
	} catch(e){}
})();


 /**
     * String.truncate(max, atChar, trail)
     *
     * ++All parameters are optional.
     * @param max = (integer) maximum length of truncated string. Defaults to 100 chars.
     * @param atChar = (string) truncate at the last index of this string. If not found, just truncates to max length.
     *                 If null, does not search and truncates to max length.
     * @param trail = (string) what you want appended to the end of the returned string
     *
     * @author Michael Fuery, Fuery Solutions, Inc. http://www.fuerysolutions.com/
     *
     * +Requires MooTools Core 1.2.2
     */
String.implement({
   
truncate:function(max, trail, atChar){
    var s = this.trim();
    if(s.length < 1) return '';
    max = $pick(max, 100);
    atChar = $pick(atChar, false); // break at space
    trail = $pick(trail, '...');
    if(s.length > max){
        if(atChar){
            var index = s.lastIndexOf(atChar),
                lastIndex = (index != -1)? index: max;
		s = s.substring(0, lastIndex);
        }else{
                s = s.substring(0, max);
        }
        s += trail;
    }
    return s;
},


highlight: function(substring, prefix, postfix) {
		prefix = prefix||'<em class="phi_font_color">'
		postfix = postfix||'</em>'

		var replacements	= new Array();
		var bigregex		= '';
		var words 			= substring.split(' ');
		words.each( function(word) {
			word_regex	= '('+word.replace(/[aá]/gi,'(a|á)').replace(/[eé]/gi,'(e|é)').replace(/[ií]/gi,'(i|í)').replace(/[oó]/gi,'(o|ó)').replace(/[uú]/gi,'(u|ú)').replace(/[nñ]/gi,'(ñ|n)')+')';
			bigregex 	= bigregex ? bigregex+'|'+word_regex : word_regex;
		});

		bigregex = eval('/('+bigregex+')/gi');
		return this.replace(bigregex,prefix+'$1'+postfix);
	}

})
/*
	PhiPhiBlueprint
	A PhiBlueprint-style HTML generator
	by Santiago Cortes
	santiago.cortes -at- gmail -dot- com
	
	Thanks to PhiBlueprint
	http://www.blueprintcss.org/
*/

var PhiBlueprint = new Class({
	
	Implements: [Options],

	options: {
		classnames: false
	},
	
	initialize: function(element, options, depth) {
		
		if ( !$chk(depth) ) {
			depth = 0
		}
		
		this.element			= $(element)
		this.setOptions(options||{})
		
		this.classname			= ''
		this.marginTop			= 0
		this.marginRight		= 0
		this.marginBottom		= 0
		this.marginLeft			= 0
		
		var children = this.element.getChildren('div[class*=span-]')
		
		if ( children.length ) {
			if ( this.element.get('class').match('span-') ) {
				this.element.addClass('wrapper')
				this.element.blueprint	= this
			}

			lastchild = null
			children.each( function(child) {
				lastchild = new PhiBlueprint(child, this.options, depth+1)
			}.bind(this) )

		} else if ( !$defined(this.element.blueprint) && this.element.get('class').match('span-') && !this.element.hasClass('wrapper') ) {
			
			/* Destroy non-splittable children while stealing their style info (margin and classname) */
			this.element.getChildren().each( function(child) {
				this.marginTop		= child.getStyle('margin-top').replace(/px/g,'')
				this.marginRight	= child.getStyle('margin-right').replace(/px/g,'')
				this.marginBottom	= child.getStyle('margin-bottom').replace(/px/g,'')
				this.marginLeft		= child.getStyle('margin-left').replace(/px/g,'')
				this.classname		= child.get('class').replace('phi_block','').replace(' ','')
				child.destroy()
			}, this)
			
			/* Empty this element */
			this.element.set('html','')

			this.element.addClass('splitable')
			this.element.blueprint	= this

			/* Create the body (controls) */
			this.element.body = new Element('div', {
				'class': 'body',
				styles: {
					margin: '0 15px 0 0'
				}
			}).inject(this.element)
			
			
			new Element('a',{
				href: '#',
				'class': 'splitter horizontal',
				html: '-----',
				events: {
					'click': function(event) {
						this.splitHorizontal()
						return false
					}.bind(this)
				}
			}).inject(this.element.body,'bottom')
			
			new Element('span',{
				'class': 'margininfo marginbottom',
				html: this.marginBottom+'px',
				events: {
					'click': function(event) {
						this.getParent('.splitable').blueprint._prompt(this, this.get('html').replace('px',''), function(value) {
							value = parseInt(value)||0
							this.set('html', value+'px')
							this.getParent('.splitable').blueprint.marginBottom = value
						}.bind(this))
					},
					
					'mousewheel': function(event) {
						value = parseInt(this.getParent('.splitable').blueprint.marginBottom)
						value += parseInt(event.wheel)
						this.set('html', value+'px')
						this.getParent('.splitable').blueprint.marginBottom = value
					}
				}
			}).inject(this.element.body,'top')
			
			new Element('a',{
				href: '#',
				'class': 'splitter vertical',
				html: '|',
				events: {
					'click': function(event) {
						this.splitVertical()
						return false
					}.bind(this)
				}
			}).inject(this.element.body,'top')
			
			new Element('span',{
				'class': 'margininfo margintop',
				html: this.marginTop+'px',
				events: {
					'click': function(event) {
						this.getParent('.splitable').blueprint._prompt(this, this.get('html').replace('px',''), function(value) {
							value = parseInt(value)||0
							this.set('html', value+'px')
							this.getParent('.splitable').blueprint.marginTop = value
						}.bind(this))
					},
					
					'mousewheel': function(event) {
						value = parseInt(this.getParent('.splitable').blueprint.marginTop)
						value += parseInt(event.wheel)
						this.set('html', value+'px')
						this.getParent('.splitable').blueprint.marginTop = value
					}
				}
			}).inject(this.element.body,'top')			
			
			new Element('span',{
				'class': 'margininfo marginright',
				html: this.marginRight+'px',
				events: {
					'click': function(event) {
						this.getParent('.splitable').blueprint._prompt(this, this.get('html').replace('px',''), function(value) {
							value = parseInt(value)||0
							this.set('html', value+'px')
							this.getParent('.splitable').blueprint.marginRight = value
						}.bind(this))
					},
					
					'mousewheel': function(event) {
						value = parseInt(this.getParent('.splitable').blueprint.marginRight)
						value += parseInt(event.wheel)
						this.set('html', value+'px')
						this.getParent('.splitable').blueprint.marginRight = value
					}
				}
			}).inject(this.element.body,'top')
			
			new Element('span',{
				'class': 'margininfo marginleft',
				html: this.marginLeft+'px',
				events: {
					'click': function(event) {
						this.getParent('.splitable').blueprint._prompt(this, this.get('html').replace('px',''), function(value) {
							value = parseInt(value)||0
							this.set('html', value+'px')
							this.getParent('.splitable').blueprint.marginLeft = value
						}.bind(this))
					},
					
					'mousewheel': function(event) {
						value = parseInt(this.getParent('.splitable').blueprint.marginLeft)
						value += parseInt(event.wheel)
						this.set('html', value+'px')
						this.getParent('.splitable').blueprint.marginLeft = value
					}
				}
			}).inject(this.element.body,'top')
			
			new Element('span',{
				'class': 'widthinfo',
				html: Math.round(this.getWidth()*100/24)+'%'
			}).inject(this.element.body,'top')
			
			
			if ( this.options.classnames ) {
			
				new Element('div',{
					'class': 'classinfo',
					html: this.classname||'none',
					events: {
						'click': function(event) {
							this.getParent('.splitable').blueprint._prompt(this, this.get('html'), function(value) {
								this.set('html', value||'none')
								this.getParent('.splitable').blueprint.classname = value
							}.bind(this), this.getParent('.splitable').blueprint.options.classnames)
						}
					}
				}).inject(this.element.body,'top')
			}

			new Element('a',{
				href: '#',
				'class': 'deleter',
				html: 'X',
				events: {
					'click': function(event) {
						this.remove()
						return false
					}.bind(this)
				}
			}).inject(this.element.body,'top')			
			
		}
		
		
		
		/* Create the row adder */
		if ( this.element.hasClass('wrapper') && !$chk(this.adder_top) ) {
			
			this.adder_top = new Element('a',{
				href: '#',
				'class': 'top adder',
				html: '+',
				styles: {
					textAlign: 'center'
				},
				events: {
					'click': function(event) {
						this.prependBlock()
						return false
					}.bind(this)
				}
			}).inject(this.element,'top')
			
			this.adder_bottom = new Element('a',{
				href: '#',
				'class': 'bottom adder',
				html: '+',
				styles: {
					textAlign: 'center'
				},
				events: {
					'click': function(event) {
						this.appendBlock()
						return false
					}.bind(this)
				}
			}).inject(this.element,'bottom')
		}
		
		
		
		/* Create the resizer */
		if ( this.element.get('class').match('span-') && !$chk(this.resizer) ) {
			var coords = this.element.getCoordinates()
			
			this.resizer = new Element('a',{
				href: '#',
				'class': 'resizer',
				html: '&bull',
				styles: {
					display: 'block',
					position: 'absolute',
					height: coords.height-16,
					width: '5px',
					top: coords.top+5,
					left: coords.left+coords.width-10
				}
			}).inject(this.element,'top')
	
			/* Resizer behavior */
			this.resizer.widthIncrease	= 0
			this.resizer.lastIncrease	= 0
			
			grid_size = coords.width/this.getWidth()
			
			new Drag(this.resizer,{
				snap: 0,
				grid: grid_size,
				style: false,
				modifiers: {x:'widthIncrease',y:false},
				onDrag: function(dragged) {
					if ( dragged.widthIncrease > dragged.lastIncrease ) {
						dragged.getParent().blueprint.expand()
					} else if ( dragged.widthIncrease < dragged.lastIncrease ) {
						dragged.getParent().blueprint.contract()
					}
					dragged.lastIncrease = dragged.widthIncrease
				}
			})
			
			/* No last element should have a resizer */
			if ( this.isLast()  ) {
				this.resizer.setStyle('display','none')
			}
		
		}

		if ( depth == 0 ) {
			this._refresh.delay(50)
		}
	},
	
	_prompt: function(element, startvalue, callback, options) {

		var coords 	= element.getCoordinates()
		
		if ( options ) {
			
			var input	= new Element('select', {

				events: {
					blur: function() {
						callback(this.get('value'))
						this.destroy()
					},
					
					change: function(event) {
						callback(this.get('value'))
						this.destroy()
					}
				},

				styles: {
					position: 'absolute',
					top: coords.top,
					left: coords.left
				}
				
			}).inject(element,'before')
			
			new Element('option', {
				value: '',
				html: 'none'
			}).inject(input)
			
			$A(options).each( function(value) {

				new Element('option', {
					value: value,
					html: value,
					selected: value == startvalue
				}).inject(input)
				
			} )
			
			input.focus()
			
		} else {
			var input	= new Element('input', {
				
				type: 'text',
				value: startvalue,
				
				events: {
					blur: function() {
						callback(this.get('value'))
						this.destroy()
					},
					
					keyup: function(event) {
						if ( event.key == 'enter' ) {
							callback(this.get('value'))
							this.destroy()
						}
					}
				},
				
				styles: {
					position: 'absolute',
					top: coords.top,
					left: coords.left,
					width: coords.width,
					height: coords.height
				}
			
			}).inject(element,'before')
			
			input.focus()
			input.select()
		}
		

	},
	
	getNext: function() {
		var next = this.element.getNext()
		while ( next ) {
			if ( $defined(next.blueprint) ) {
				return next.blueprint
			}
			next = next.getNext()
		}
		return next
	},
	
	getPrevious: function() {
		var previous = this.element.getPrevious()
		while ( previous ) {
			if ( $defined(previous.blueprint) ) {
				return previous.blueprint
			}
			previous = previous.getPrevious()
		}
		return previous
	},

	getWidth: function() {
		var matches = this.element.get('class').match('span-([0-9]+)')
		return matches ? parseInt(matches[1]) : 0
	},
	
	setWidth: function(width) {

		if ( this.element.hasClass('wrapper') ) {

			var currentRow		= []
			var rowcount		= 0
			
			var child			= this.element.getFirst()
			
			while ( child ) {
			
				if ( $defined(child.blueprint) ) {
					currentRow.include(child)
					rowcount++
	
					if ( child.blueprint.isLast() ) {
					
						/* ...go over the array.... */
						var addedWidth	= 0
						var newWidth	= Math.floor(width/rowcount)
		
						currentRow.each( function(subelem) {
							subelem.blueprint.setWidth(newWidth)
							addedWidth += newWidth
						} )
						
						/* Fill the remainder */
						if ( addedWidth < width ) {
							child.blueprint.setWidth(newWidth+width-addedWidth)
						}
	
						currentRow	= []
						rowcount	= 0
					}
				}

				child = child.getNext()
			}			
		
		} else {
			var pct = Math.round(width*100/24)
			this.element.getElement('.widthinfo').set('html', pct+'%')
		}
	
		this.element.removeClass(this.element.get('class').match('span-[0-9]+'))
		this.element.addClass('span-'+width)

		this._refresh()
	},

	isLast: function() {
		return this.element.hasClass('last')
	},

	setLast: function() {
		this.element.addClass('last')
	},

	appendBlock: function()
	{
		var width			= this.getWidth()
		var fork = new PhiBlueprint(new Element('div', {
			'class': 'span-'+width+' last'
		}), this.options)
		fork.element.injectAfter(this.element)
		
		this._refresh()
	},
	
	prependBlock: function()
	{
		var width			= this.getWidth()
		var fork = new PhiBlueprint(new Element('div', {
			'class': 'span-'+width+' last'
		}), this.options)
		fork.element.injectBefore(this.element)
		
		this._refresh()
	},
	
	splitHorizontal: function()
	{
		var width			= this.getWidth()
		var parent_width	= $defined(this.element.getParent().blueprint) ? this.element.getParent().blueprint.getWidth() : 24

		var fork = new PhiBlueprint(new Element('div', {
			'class': 'span-'+width+' last'
		}), this.options)
		
		
		/* Create wrapper when necessary */
		if ( parent_width != width ) {
			
			var wrapper = new Element('div', {
				'class': 'span-'+width+( this.isLast() ? ' last' : '' )
			}).injectBefore(this.element)
			wrapper.adopt(this.element)
			wrapper.adopt(fork.element)
			new PhiBlueprint(wrapper, this.options)
		
		} else {
			fork.element.injectAfter(this.element)
		}

		this.setLast()
		
		this._refresh()
	},

	splitVertical: function()
	{
		var width		= this.getWidth()
	
		if ( width <= 4 ) {
			return;
		}
	
		/* Create wrapper if necessary */
		var previous = this.getPrevious()
		if ( this.isLast() && (!previous||previous.isLast()) ) {
			var wrapper = new Element('div', {
				'class': 'wrapper '+this.element.get('class')
			}).injectBefore(this.element)
			wrapper.adopt(this.element)
		}

		this.setWidth(Math.floor(width/2))

		var elem_2_width = width%2 == 0 ? width/2 : Math.floor(width/2)+1
		var fork = new Element('div', {
			'class': 'span-'+elem_2_width
		}).injectBefore(this.element)
		
		if ( $chk(wrapper) ) {
			new PhiBlueprint(wrapper, this.options)
		} else {
			new PhiBlueprint(fork, this.options)
		}
		
		this._refresh()
	},

	contract: function()
	{
		var target	= this
		var parent	= this.element.getParent()
	
		/* Resize entire wrapper (if applies) */
		if ( target.isLast() && parent.hasClass('wrapper') && $defined(parent.blueprint)  ) {
			target = parent.blueprint
		}
	
		if ( target.isLast() || target.getWidth() <= 2 ) {
			return;
		}
	
		var next		= target.getNext()
		if ( next ) {	/* Assert. There is always a next element here! */
			next.setWidth(next.getWidth()+1)
			target.setWidth(target.getWidth()-1)
		}
	},

	expand: function()
	{
		var target	= this
		var parent	= this.element.getParent()
	
		/* Resize entire wrapper (if applies) */
		if ( target.isLast() && parent.hasClass('wrapper') && $defined(parent.blueprint)  ) {
			target = parent.blueprint
		}
	
		if ( target.isLast() ) {
			return;
		}
	
		/* Determine the max allowed width for this element */
		var parent_width	= $defined(target.element.getParent().blueprint) ? target.element.getParent().blueprint.getWidth() : 24

		/* Count all elements in this row */
		var sibling_count		= target.element.getParent().getChildren('.splitable').length-1
		var max_allowed_width	= parent_width - sibling_count*2
	
		if ( target.getWidth() >= max_allowed_width ) {
			return;
		}

		var next = target.getNext()
		while ( next && next.getWidth() <=2 ) {
			next = next.getNext()
		}

		if ( next ) {
			next.setWidth( next.getWidth()-1 )
			target.setWidth( target.getWidth()+1 )
		}
	},

	remove: function()
	{
		var previous	= this.getPrevious()
		var next		= this.getNext()

		/* Avoid removing the last element */
		if ( !previous && !next && !this.element.getParent().hasClass('wrapper') ) {
			return;
		}

		/* If this is NOT the only element in the row, resize a sibling to fill space */
		if ( !this.isLast() || (previous && !previous.isLast()) ) {
			var filler	= this.isLast() ? previous : next
			filler.setWidth(filler.getWidth()+this.getWidth())
		}

		/* Give last class to previous element */
		if ( this.isLast() && previous && !previous.isLast() ) {
			previous.setLast()
		}

		var parent = this.element.getParent()
		
		
		this.resizer.destroy()
		this.resizer = null
		
		this.element.destroy()
		this.element = null
		
		/* If the parent is a wrapper with a single Row, unwrap the child */
		if ( parent.hasClass('wrapper') && parent.getChildren('.last').length == 1 ) {
			
			var haslast = parent.hasClass('last')
			
			while ( parent.getChildren().length > 0 ) {
				var child = parent.getFirst()
				if ( !haslast ) {
					child.removeClass('last')
				}
				child.injectBefore(parent)
			}
			
			parent.blueprint.resizer.destroy()
			parent.blueprint.resizer = null
			
			parent.blueprint.adder_top.destroy()
			parent.blueprint.adder_top = null
			
			parent.blueprint.adder_bottom.destroy()
			parent.blueprint.adder_bottom = null
			
			parent.destroy()
			parent = null
		}
		
		this._refresh()
	},

	_refresh: function() {
		$$('.resizer').each( function(elem) {
			
			parent = elem.getParent()
			coords = parent.getCoordinates()
			
			if ( parent.hasClass('last') ) {
				elem.setStyle('display','none')
			} else {
				elem.setStyles({
					display: 'block',
					top: coords.top+5,
					height: coords.height-16,
					left: coords.left+coords.width-10
				})
			}
		} )
		
		$$('.adder').each( function(elem) {
			
			parent		= elem.getParent().blueprint
			last_child	= parent.element.getLast('.splitable').blueprint
			if ( !$chk(last_child) ) {
				return elem.destroy()
			}			
			
			if ( elem.hasClass('bottom') ) {
				next_element	= parent.getNext()
								
				if ( last_child.getWidth() != parent.getWidth() && (!next_element || next_element.element.hasClass('wrapper')) ) {
					elem.setStyle('display','block')
				} else {
					elem.setStyle('display','none')
				}
			} else {
				previous_element	= parent.getPrevious()
				
				if ( last_child.getWidth() != parent.getWidth() && (!previous_element || previous_element.getWidth() != parent.getWidth()) ) {
					elem.setStyle('display','block')
				} else {
					elem.setStyle('display','none')
				}
			}

		} )
	},

	getHTML: function(container_id) {
		this.block_id = 0
		
		var	output		= ''
		var children	= this.element.getChildren('div')
		children.each( function(child) {
			output	+= this._toString(child,'', container_id)+"\n"
		}.bind(this) )
		
		return output
	},

	_toString: function(element, padding, container_id) {

		var matches = element.get('class').match('span-([0-9]+)')
		if ( element.hasClass('last') ) {
			var classname = matches ? 'span-'+matches[1]+' last' : 'last'
		} else {
			var classname = matches ? 'span-'+matches[1] : ''
		}

		var children	= element.getChildren('div[class*=span-]')

		if ( !children.length ) {
			var output = padding+'<div class="'+classname+'"><div style="margin: '+element.blueprint.marginTop+'px '+element.blueprint.marginRight+'px '+element.blueprint.marginBottom+'px '+element.blueprint.marginLeft+'px" class="phi_block '+element.blueprint.classname+'" id="phi_block_'+container_id+'_'+this.block_id+'"></div></div>'
			this.block_id++
		} else {
			var output = padding+'<div class="'+classname+'">'+"\n"
			children.each( function(child, index, array) {	
				output += this._toString(child, padding+"\t", container_id)
				if ( index < array.length-1 ) {
					output += "\n"
				}
			}, this)
			output += "\n"+padding+'</div>'
		}

		return output	
	}	

})
/*
	PhiBubble
	by Santiago Cortes and Esteban Diaz
	
	Given document coordinates (x,y) and a bubble position [top,right,bottom,left], draws a bubble with
	an arrow pointing exactly into (x,y)
	
	santiago.cortes -at- gmail -dot- com
*/
var PhiBubble = new Class({

	Implements: [Options],

	options: {
	
		x:			100,
		y:			100,
		position:	'top',
		html:		'',
		classname:	'',

		opacity:		1,
		color:			'#fff',
		zIndex:			9999,
		borderWidth:	2,
		borderColor:	'#333',
		
		width:		250,
		height:		100,
		
		pointerWidth:	20,
		pointerHeight:	20,
		
		limit:		false
	},
	
	initialize: function(options)
	{
		this.setOptions(options||{});
		
		/* Establish bounds */
		if ( !this.options.limit ) {

			/* Cache window size  */
			var win			= $(window);
			var winsize		= win.getScrollSize();
			
			this.options.limit = {
				x: 0,
				y: 0,
				width: winsize.x,
				height: winsize.y
			}
		}
		
		/* Create the global wrapper (which will provide opacity) */
		this.wrapper = new Element('div', {
			styles: {
				/*position:	'fixed',*/
				top:		0,
				left:		0,
				opacity:	0,
				zIndex:		this.options.zIndex
			}
		}).inject($(document.body));
		
		/* Create the pointer */
		this.pointer	= new Element('div', {
			styles: {
				position:		'absolute',
				width:			0,
				height:			0
			}
		}).inject(this.wrapper);
		
		this.pointer_filler	= new Element('div', {
			styles: {
				position:		'absolute',
				width:			0,
				height:			0,
				zIndex:			2
			}
		}).inject(this.pointer);
		
		
		/* Create the bubble */
		this.bubble	= new Element('div', {
			'class': this.options.classname,
			styles: {
				
				border:				this.options.borderWidth ? this.options.borderWidth+'px solid '+this.options.borderColor : 0,
				
				position:			'absolute',
				backgroundColor:	this.options.color,
				width:				this.options.width,
				height:				this.options.height
			}
		}).inject(this.wrapper);
		
		this.setHTML(this.options.html);	
	},
	
	setHTML: function(html)
	{
		if ( $type(html) == 'element' ) {
			this.bubble.set('html','');
			html.inject(this.bubble);
		} else {
			this.bubble.set('html',html);
		}
	},
	
	_validatePosition: function(x,y,position)
	{
		switch ( position ) {
			case 'top':
				if ( y-this.options.pointerHeight-this.options.height <= this.options.limit.y ) {
					return 'bottom';
				}
			break;
			
			case 'right':
				if ( x+this.options.pointerWidth+this.options.width >= this.options.limit.x+this.options.limit.width ) {
					return 'left';
				}
			break;
			
			case 'bottom':
				if ( y+this.options.pointerHeight+this.options.height > this.options.limit.y+this.options.limit.height ) {
					return 'top';
				}
			break;
			
			case 'left':
				if ( x-this.options.pointerWidth-this.options.width < this.options.limit.x ) {
					return 'right';
				}
			break;
		}
		
		return position;
	},
	
	show: function(x,y,position)
	{
		x					= x||this.options.x;
		y					= y||this.options.y;
		position			= position||this.options.position;
		
		position			= this._validatePosition(x,y,position);
		
		if ( position == 'right' ) {
			
			this.pointer.setStyles({
				top:			y-((this.options.pointerHeight+this.options.borderWidth)/2),
				left:			x,
				borderTop:		((this.options.pointerHeight+this.options.borderWidth)/2)+'px solid transparent',
				borderBottom:	((this.options.pointerHeight+this.options.borderWidth)/2)+'px solid transparent',				
				borderRight:	this.options.pointerWidth+this.options.borderWidth/2+'px solid '+(this.options.borderWidth ? this.options.borderColor : this.options.color),
				borderLeft:		0
			});
			
			this.pointer_filler.setStyles({
				top:			this.options.pointerHeight*-0.5,
				right:			-this.options.pointerWidth-this.options.borderWidth*1.5,
				borderTop:		(this.options.pointerHeight/2)+'px solid transparent',
				borderBottom:	(this.options.pointerHeight/2)+'px solid transparent',
				borderRight:	this.options.pointerWidth+'px solid '+this.options.color,
				borderLeft:		0,
				opacity:		this.options.borderWidth ? 1 : 0
			});

			this.bubble.setStyles({
				left:			x+this.options.pointerWidth+Math.floor(this.options.borderWidth/2),
				top:			Math.min(Math.max(y-this.options.height/2-this.options.borderWidth, this.options.limit.y), this.options.limit.y+this.options.limit.height-this.options.height)
			});

		} else if ( position == 'left' ) {
			
			this.pointer.setStyles({
				top:			y-((this.options.pointerHeight+this.options.borderWidth)/2),
				left:			x-this.options.pointerWidth-this.options.borderWidth/2,
				borderTop:		((this.options.pointerHeight+this.options.borderWidth)/2)+'px solid transparent',
				borderBottom:	((this.options.pointerHeight+this.options.borderWidth)/2)+'px solid transparent',				
				borderRight:	0,
				borderLeft:		this.options.pointerWidth+this.options.borderWidth/2+'px solid '+(this.options.borderWidth ? this.options.borderColor : this.options.color)				
			});
			
			this.pointer_filler.setStyles({
				top:			this.options.pointerHeight*-0.5,
				left:			-this.options.pointerWidth-this.options.borderWidth*1.5,
				borderTop:		(this.options.pointerHeight/2)+'px solid transparent',
				borderBottom:	(this.options.pointerHeight/2)+'px solid transparent',
				borderRight:	0,
				borderLeft:		this.options.pointerWidth+'px solid '+this.options.color,
				opacity:		this.options.borderWidth ? 1 : 0
			});
			
			this.bubble.setStyles({
				left:			x-this.options.pointerWidth-this.options.width-this.options.borderWidth*2.5,
				top:			Math.min(Math.max(y-this.options.height/2-this.options.borderWidth, this.options.limit.y), this.options.limit.y+this.options.limit.height-this.options.height)
			});

		} else if ( position == 'top' ) {
			
			this.pointer.setStyles({
				top:			y-this.options.pointerHeight-this.options.borderWidth*0.5,
				left:			x-(this.options.pointerWidth+this.options.borderWidth)/2,
				borderLeft:		((this.options.pointerWidth+this.options.borderWidth)/2)+'px solid transparent',
				borderRight:	((this.options.pointerWidth+this.options.borderWidth)/2)+'px solid transparent',				
				borderTop:		this.options.pointerHeight+this.options.borderWidth/2+'px solid '+(this.options.borderWidth ? this.options.borderColor : this.options.color),
				borderBottom:	0
			});
			
			this.pointer_filler.setStyles({
				top:			-this.options.pointerHeight-this.options.borderWidth*1.5,
				left:			this.options.pointerWidth*-0.5,
				borderLeft:		(this.options.pointerWidth/2)+'px solid transparent',
				borderRight:	(this.options.pointerWidth/2)+'px solid transparent',				
				borderTop:		this.options.pointerHeight+'px solid '+this.options.color,
				borderBottom:	0,
				opacity:		this.options.borderWidth ? 1 : 0
			});
			
			this.bubble.setStyles({
				top:			y-this.options.pointerHeight-this.options.height-this.options.borderWidth*2.5,
				left:			Math.min(Math.max(x-this.options.width/2-this.options.borderWidth, this.options.limit.x),this.options.limit.x+this.options.limit.width-this.options.width)
			});

		} else if ( position == 'bottom' ) {
			
			this.pointer.setStyles({
				top:			y,
				left:			x-(this.options.pointerWidth+this.options.borderWidth)/2,
				borderLeft:		((this.options.pointerWidth+this.options.borderWidth)/2)+'px solid transparent',
				borderRight:	((this.options.pointerWidth+this.options.borderWidth)/2)+'px solid transparent',
				borderBottom:	this.options.pointerHeight+this.options.borderWidth/2+'px solid '+(this.options.borderWidth ? this.options.borderColor : this.options.color),
				borderTop:		0
			});
			
			this.pointer_filler.setStyles({
				top:			Math.floor(this.options.borderWidth*1.5),
				left:			this.options.pointerWidth*-0.5,
				borderLeft:		(this.options.pointerWidth/2)+'px solid transparent',
				borderRight:	(this.options.pointerWidth/2)+'px solid transparent',				
				borderBottom:	this.options.pointerHeight+'px solid '+this.options.color,
				borderTop:		0,
				opacity:		this.options.borderWidth ? 1 : 0
			});			
			
			this.bubble.setStyles({
				top:			y+this.options.pointerHeight+Math.floor(this.options.borderWidth*0.5),
				left:			Math.min(Math.max(x-this.options.width/2-this.options.borderWidth, this.options.limit.x),this.options.limit.x+this.options.limit.width-this.options.width)
			});

		}

		/* Display */
		this.wrapper.setStyle('opacity', this.options.opacity);
		return this;
	},
	
	hide: function()
	{
		this.wrapper.setStyle('opacity', 0);
		return this;
	},
	
	destroy: function()
	{
		this.wrapper.destroy();
		this.bubble.destroy();
		this.pointer.destroy();
		this.pointer_filler.destroy();
	}

});
/*
	PhiCalendar
	Event organizer for Phi i/event module
	by Santiago Cortes
	santiago.cortes -at- gmail -dot- com
*/
var PhiCalendar = new Class({
	
	initialize: function(master_id)
	{
		this.overlap_distance	= 20;
		this.count				= 0;
		this.master				= $(master_id);
		this.master.calendar	= this;
		this.slots				= new Hash();
		this.elements			= new Hash();
	},
	
	addElement: function(color, day, start_date, end_date, title, description, target_link)
	{
		/* Initialize */
		this.count++;
		if ( !this.slots.has(day) ) {
			this.slots.set(day, new Hash());
		}
		
		/* Create the element */
		var start_element	= $(this.master.id+'_'+day+'_'+start_date);
		var start_coords	= start_element.getCoordinates();

		var end_element		= end_date == '0000' ? $(this.master.id+'_'+day+'_bottom') : $(this.master.id+'_'+day+'_'+end_date);
		var end_coords		= end_element.getCoordinates();
		
		var start_string	= start_date.substring(0,2)+':'+start_date.substring(2);
		var end_string		= end_date.substring(0,2)+':'+end_date.substring(2);
		
		var element			= new Element('div', {
			'id': 'calendar_event_'+this.count,
			'class': 'calendar_event_wrapper',
			'html': '<div class="calendar_event"><div class="range">'+start_string+' - '+end_string+'</div><div class="title"><a href="'+target_link+'">'+title+'</a></div></div>',
			'styles': {
				position:			'absolute',
				top:				start_coords.top,
				left:				start_coords.left-1,
				height:				end_coords.top-start_coords.top,
				width:				start_coords.width,
				backgroundColor:	'#'+color,
				color: 				'#fff'
			},
			'events': {
				
				'click': function() {
					if ( target_link ) {
						window.location = target_link;
					}
				},
				
				'mouseenter': function(event) {
					this.addClass('hover');
					this._old_zIndex	= this.getStyle('z-index');
					this.setStyle('z-index', 10);
				},
				
				'mouseleave': function() {
					this.removeClass('hover');
					this.setStyle('z-index', this._old_zIndex);
				}
			}
		}).inject(this.master, 'after');
		
		element.tooltip	= new PhiTooltip(element, {
			classname: 'event_tooltip',
			html: '<div><h1>'+title+'</h1><p>'+description+'</p></div>',
			follow: true
		});		
		
		element.crashes		= new Array();

		element._phi_calendar_day			= day;
		element._phi_calendar_start_date	= start_date;
		element._phi_calendar_end_date		= end_date;
		element._phi_calendar_title			= title;
		element._phi_calendar_description	= description;
		element._phi_calendar_target_link	= target_link;
		
		this.elements.set(element.id, element);
		
		
		/* Fill the slots */
		if ( end_date == '0000' ) {
			end_date = '2330';
		}
		
		var slots	= this.slots.get(day);
		var slot	= start_date;
		var timeout	= 24;
		while ( slot != end_date && timeout > 0) {
			timeout--;
			
			if ( slots.has(slot) ) {
				slots.get(slot).each( function(crashed_id) {
					
					if ( this.elements.has(crashed_id) ) {
						element.crashes.include(crashed_id);
					}
				}.bind(this) );
			} else {
				slots.set(slot, new Array());
			}
			slots.get(slot).include(element.id);
		
			slot = this._increment(slot);
		}
		
		if ( element.crashes.length ) {

			/* Determine the recursive depth */
			var crash_chain		= new Array();
			this._getCrashChain(element.id, crash_chain);
			
			var factor			= 1/crash_chain.length;
			var new_width		= (start_coords.width+this.overlap_distance*(crash_chain.length-1))*factor;
			var current_left	= start_coords.left;
			var zindex			= 1;
			
			element.setStyle('width', new_width);
			
			crash_chain.each( function(element_id) {
				$(element_id).setStyle('width',		new_width-1);
				$(element_id).setStyle('left',		current_left-1);
				$(element_id).setStyle('z-index',	zindex++);
				current_left	+= new_width-this.overlap_distance;
			}.bind(this) );
		}
		
		return element;
	},
	
	redraw: function(deleted)
	{
		this.elements.erase(deleted);
		
		this.elements.each(function (element) {
			
			var element_coords = element.getCoordinates();
			this.elements.erase(element.id);
			element.destroy();
			
			var clone = this.addElement(
					element._phi_calendar_day,
					element._phi_calendar_start_date,
					element._phi_calendar_end_date,
					element._phi_calendar_title,
					element._phi_calendar_description,
					element._phi_calendar_target_link
			);
			
			var clone_coords = clone.getCoordinates();

			//clone.tween('left', element_coords.left, clone_coords.left);
			clone.tween('width', element_coords.width, clone_coords.width);
			
		}.bind(this));		

	},
	
	_increment: function(date)
	{
		hour	= date.substring(0,2);
		minute	= date.substring(2);
		
		if ( minute == '00' ) {
			return hour+'30';
		} else {
			nexthour = hour.substring(0,1) == '0' ? parseInt(hour.substring(1))+1 : parseInt(hour)+1;
			hour = nexthour <= 9 ? '0'+nexthour : nexthour+'';
			return hour+'00';
		}
	},
	
	_getCrashChain: function(element_id, retval)
	{
		if ( !this.elements.has(element_id) || !$(element_id) ) {
			return;
		}
		
		$(element_id).crashes.each( function(element_id) {
			this._getCrashChain(element_id, retval);
		}.bind(this) );
		
		retval.include(element_id);		
	},
	
	appendElement: function(color, day, title, description, target_link)
	{
		var element = $(this.master.id+'_'+day);
		
		if ( !$chk(element.list) ) {
			element.list = new Element('ul').inject(element);
		}
		
		var added_event = new Element('li', {
			html: target_link ? '<a href="'+target_link+'" style="color: #'+color+'">'+title+'</a>' : title
		}).inject(element.list);
		
		added_event.tooltip	= new PhiTooltip(added_event, {
			classname: 'event_tooltip',
			html: '<div><h1>'+title+'</h1><p>'+description+'</p></div>',
			follow: true
		});			
		
	}
});
/*
	PhiDatePicker
	Datepicker widget based on mootools
					effects and layout based on Windows Vista by microsoft corp.  microsoft -dot - com
					and VlaCal widget made by dev.base86 crew rcz -at- base86.com
	by Esteban Diaz
	esteban.diaz -at- phidias -dot- com -dot- co
	madsad -at- gmail -dot- com
 */

var PhiDatePicker = new Class({

	Implements:[Options, Events],

	options :{
		currentYear: new Date().getFullYear(),
		currentMonth: new Date().getMonth(),
		currentDay: new Date().getDate(),
		markedDays: [],
		retrieveonlyonmarked: false,
		markedDaysRecursive: false,
		holyDays: [],
		width: 160,
		height: 180,
		/*start_year: 1921,*/
		startDay: 0,
		twoDigits : true,
		twoDigitsYear : false,
		arrowColor: 'black',
		className: 'phi-datepicker',
		tooltipWidth: 300,
		dateFormat: 'm/d/y',
		separator: '/',
		shortDayNames : new Array('Su','Mo','Tu','We','Th','Fr','Sa'),
		shortMonthNames : new Array(	'Jan',	'Feb',	'Mar',	'Apr',	'May',	'Jun',	'Jul',	'Aug',	'Sep',	'Oct',	'Nov',	'Dec'),
		monthNames : new Array(	'January',	'February',	'March',	'April',	'May',	'June',	'July',	'August',	'September',	'October',	'November',	'December'),
		effect: 'fade',
		loadDaysURL: null,
		markSundays: false,
		markSaturdays: false
	},

	initialize: function(element, options) {


		this.startyear = this.options.currentYear
		this.startmonth = this.options.currentMonth

		this.reference = $(element)
		this.firstrun = true;
		this.ontransdu = false
		this.loading = false
		this.tooltip = new Element('div')
		this.tooltip.set('tween')
		this.tooltip.addClass('dptooltip')
		
		this.browsedisable = false
		this.calctype = 'day'
		this.frame = new Element('div');
		this.mcontainer = new Element('div', {
			'class': 'framecontainer'
		});
		this.fcontainer	= new Element('div', {
			'class': 'frametwo'
		});
		this.scontainer	= new Element('div', {
			'class': 'frameone'

		});

		/*this.loading = new Element('div', {
			'class': 'loadscreen'

		});*/

		this.table = new Element('table');
		this.tablehead = new Element('thead');
		this.tablebody = new Element('tbody');




		this.controls = new Element('div')
		this.left = new Element('div', {
			'class': 'dpleft'
		})
		this.right = new Element('div', {
			'class': 'dpright'
		})

		this.label = new Element('span', {
			'class': 'dplabel'
		})

		this.load = new Element('span', {
			'class': 'dploading'
		})

		this.load.setStyle('opacity', 0)


		this.label.set('html', this.options.shortMonthNames[this.options.currentMonth] + ' ' +String(this.options.currentYear))

		this.pointerr	= new Element('div', {
			'class': 'pointer right'
		}).inject(this.right);

		this.pointerr_filler	= new Element('div', {
			'class': 'filler'
		}).inject(this.pointerr);


		this.pointerl	= new Element('div', {
			'class': 'pointer left'
		}).inject(this.left);

		this.pointerl_filler	= new Element('div', {
			'class': 'filler'
		}).inject(this.pointerl);

		this.setOptions(options);
		//console.log(options)

		this.frame.addClass(this.options.className)

		this.dateobject = new Date()
		this.dateobject.setMonth(this.options.currentMonth)
		this.dateobject.setDate(this.options.currentDay)
		this.dateobject.setFullYear(this.options.currentYear)


		this.fxe = new Fx.Elements([this.scontainer, this.fcontainer])

		//console.log(this.dateobject);
		this.frame.setStyles({
			width : this.options.width,
			height : this.options.height,
			border: '1px solid #ccc',
			overflow: 'hidden'
		})


		this.mcontainer.setStyles({
			width : this.options.width*2,
			height : this.options.height,
			left: this.options.width*-1,
			position: 'relative'
		})

		this.fcontainer.setStyles({
			width : this.options.width,
			height : this.options.height,
			'float': 'left'
		})

		this.scontainer.setStyles({
			width : this.options.width,
			height : this.options.height,
			'float': 'left'
		})

		this.controls.addClass("controls")


		this.fcontainer.set('tween')
		this.scontainer.set('tween')

		this.fcontainer.inject(this.mcontainer)
		this.scontainer.inject(this.mcontainer)



		this.right.inject(this.controls)
		this.left.inject(this.controls)
		this.label.inject(this.controls)
		this.load.inject(this.controls)

		this.controls.inject(this.frame)


		this.mcontainer.set('tween')
		this.mcontainer.inject(this.frame)


		if(this.reference.hasClass('standalone')){
			this.frame.inject(this.reference, 'after');
			this.reference.setStyle('display', 'none');
		}else{
			this.reference.set('day', this.dateobject.getDate())
			this.reference.set('month', this.dateobject.getMonth()+1)
			this.reference.set('year', this.dateobject.getFullYear())
			this.frame.setStyle('position', 'absolute')

			var dim = this.reference.getCoordinates()
			switch(this.options.effect){
				default :
					this.frame.setStyles({
						'left': dim.left + dim.width,
						'top': dim.top,
						'opacity': 0
					})
					this.frame.inject(this.reference, 'after');
					this.reference.addEvent('click', function(){
						this.frame.fade('toggle')

					}.bind(this))

					break
				case 'grow':
					this.frame.setStyles({
						'left': dim.left,
						'top': dim.top + dim.height,
						'opacity': 0,
						'width': 0,
						'height': 0
					})
					this.frame.inject(this.reference, 'after');
					this.reference.addEvent('click', function(){
						this.frame.morph({
							'opacity': 1,
							'width': this.options.width,
							'height': this.options.height
						})

					}.bind(this))
					break
			}
			document.addEvent('mousedown', function(event){
				var whereclick = this._mousePosition(event)
				if(!(whereclick.x >= this.frame.getPosition().x && whereclick.x <= (this.frame.getPosition().x+this.frame.getSize().x) && whereclick.y >= this.frame.getPosition().y && whereclick.y <= (this.frame.getPosition().y+this.frame.getSize().y))){

					switch(this.options.effect){
						case 'grow':
							this.frame.morph({
								'opacity': 0,
								'width': 0,
								'height': 0
							})
							break

						default:
							this.frame.fade('out')
							break
					}

				//}
				}
			//console.log(whereclick)
			}.bind(this))
		}
		//this.language('phi-datepicker/'+this.options.language+'.js')

		this.pointerr.addEvent('click', this.fordward.bind(this))
		this.pointerl.addEvent('click', this.backward.bind(this))
		this.label.addEvent('click', this.browse.bind(this))


		//console.log(this.options.markedDays)
		this.calculateDays(this.scontainer)/*** ok.. lets seee***/
	},

	calculateDays: function(container){
		/*	reset table */
		//console.log(this.reference)
		if(this.options.loadMarkedDaysURL){
		   console.log(this.options.loadMarkedDaysURL);

		}
		if(!Browser.Engine.trident){
			this.tablehead.set('html', '');
			this.tablebody.set('html', '');
			this.table.set('html', '');
		}
		this.table.removeClass('tableyear')
		this.table.removeClass('tablemonth')
		this.label.set('html', this.options.monthNames[this.options.currentMonth] + ' ' + String(this.dateobject.getFullYear()))

		this.dateobject.setDate(1)
		var currenttime = this.dateobject.getTime();
		/*get first day of the month day*/
		var daynumber = this.dateobject.getDay();

		//insert day names
		var trdays = new Element('tr')
		trdays.addClass('dnames')
		for(var fd = this.options.startDay ; fd < 7; fd++){
			var tdday = new Element('td')
			tdday.set('html', this.options.shortDayNames[fd])
			tdday.inject(trdays);
		}
		if(this.options.startDay > 0 ){
			for(fd = this.options.startDay - 1 ; fd >= 0; fd--){
				tdday = new Element('td')
				tdday.set('html', this.options.shortDayNames[fd])
				tdday.inject(trdays);
			}
		}
		
		trdays.inject(this.tablehead)
		this.tablehead.inject(this.table)


		for(var w = 1; w < 7; w++){

			var tr = new Element('tr')
			tr.addClass('week')
			tr.set('id', 'week_'+String(w))

			for(var d = 1; d < 8; d++ ){
				//fill "out-of month days"
				if(this.dateobject.getDate() == 1 && this.dateobject.getMonth() == this.options.currentMonth){
					if(daynumber == 0 && this.options.startDay > 0){
						daynumber = 7
					}

					for(daynumber; this.options.startDay < daynumber ; daynumber--){
						this.dateobject.setTime((this.dateobject.getTime() - (86400000)))
						var td = new Element('td')
						td.addClass('day')
						td.addClass('offmonthday')
						if(this.dateobject.getDay() == this.options.startDay){
							td.addClass('firstcday')
						}
						td.set('date', '{day : '+String(this.dateobject.getDate())+', month : '+String(this.dateobject.getMonth()+1)+', year : '+String(this.dateobject.getFullYear())+'}')
						td.set('html', this.dateobject.getDate())
						td.inject(tr, 'top');
						d++
					}
					//reset to the first day of the current month
					this.dateobject.setTime(currenttime);
				}

				var tdm = new Element('td')
				tdm.addClass('day')
				if(this.dateobject.getMonth() == this.options.currentMonth){
					tdm.addClass('monthday')
					//var tmp = String(this.dateobject.getDate())+"/"+String(this.dateobject.getMonth()+1)+"/"+String(this.dateobject.getFullYear())
					if((this.firstrun || (this.startmonth == this.dateobject.getMonth() && this.startyear == this.dateobject.getFullYear()) || $defined(this.options.loadDaysURL)) && this.checkMarked(this.dateobject.getDate(), String(this.dateobject.getFullYear()), String(this.dateobject.getMonth()+1))){
						tdm.addClass('marked')
					}
				}else{
					tdm.addClass('offmonthday')
				}
				if(this.dateobject.getDay() == this.options.startDay){
					tdm.addClass('firstcday')
				}
				tdm.set('date', '{day : '+String(this.dateobject.getDate())+', month : '+String(this.dateobject.getMonth()+1)+', year : '+String(this.dateobject.getFullYear())+'}')
				tdm.set('html', this.dateobject.getDate())
				this.dateobject.setTime(this.dateobject.getTime() + 86400000)
				tdm.inject(tr);
			}
			tr.inject(this.tablebody)
			this.tablebody.inject(this.table)
			this.table.inject(container)
		}
		/*leave original data */
		this.dateobject.setMonth(this.options.currentMonth)
		this.dateobject.setFullYear(this.options.currentYear)
		this.dateobject.setDate(this.options.currentDay)
		this.applyEvents();
		if(!this.options.markedDaysRecursive){
			this.firstrun = false
		}
	},

	calculateMonths: function(container){
		//alert('lick')
		/*repaste code*/
		//this.fcontainer.setStyle('left', this.scontainer.getStyle('left'))
		this.label.set('html', String(this.dateobject.getFullYear()))
		if(!Browser.Engine.trident){
			this.tablehead.set('html', '');
			this.tablebody.set('html', '');
			this.table.set('html', '');
		}
		this.table.addClass('tablemonth')
		this.table.removeClass('tableyear')
		var monthcount = 0
		for(var w = 1; w < 4; w++){
			var monthtr = new Element('tr')
			for(var d = 0; d < 4; d++ ){
				var mtd = new Element('td')
				mtd.addClass('monthname')
				var sp = new Element('span', {
					'class' : 'month',
					'month' : '{month : '+String(monthcount) +', year : '+String(this.options.currentYear)+'}'
				})
				sp.set('html', this.options.shortMonthNames[monthcount])
				
				sp.inject(mtd)
				mtd.inject(monthtr)
				monthcount++
			}
			monthtr.inject(this.tablebody)
		}
		this.tablebody.inject(this.table)
		this.table.inject(container)
		this.applyEvents();
	},

	calculateYears: function(container){
		//console.log(this.options.currentYear)
		this.label.set('html', String(this.options.currentYear - 5) +' - '+ String(this.options.currentYear + 6) )
		if(!Browser.Engine.trident){
			this.tablehead.set('html', '');
			this.tablebody.set('html', '');
			this.table.set('html', '')
		}
		this.table.addClass('tableyear')
		this.table.removeClass('tablemonth')
		var wbyear = this.dateobject.getFullYear()- 5
		for(var w = 1; w < 4; w++){
			var monthtr = new Element('tr')
			for(var d = 0; d < 4; d++ ){
				var mtd = new Element('td')
				mtd.addClass('yearname')
				var sp = new Element('span', {
					'class' : 'year',
					'year' : '{year : '+String(wbyear)+'}'
				})
				sp.set('html', wbyear)
				sp.inject(mtd)
				mtd.inject(monthtr)
				wbyear++
			}
			monthtr.inject(this.tablebody)
		}
		this.tablebody.inject(this.table)
		this.table.inject(container)
		this.applyEvents();
	//this.label.removeEvents()
	},

	resetToAbsolute: function() {
		this.fcontainer.setStyle('position', 'absolute')
		this.fcontainer.setStyle('opacity', 0)
		this.scontainer.setStyle('position', 'absolute')
		this.scontainer.setStyle('opacity', 1)
		this.mcontainer.setStyle('left', 0)
	},

	resetToRelative: function(){
		this.fcontainer.setStyle('position', 'relative')
		this.fcontainer.setStyle('opacity', 1)
		this.scontainer.setStyle('position', 'relative')
		this.scontainer.setStyle('opacity', 1)

		this.scontainer.set('html', this.fcontainer.get('html'))

		this.mcontainer.setStyle('left', this.options.width*-1)
		this.fcontainer.set('html', '')
		this.applyEvents()
	//console.log('finished reseting')
	},
	
	fordward : function(){
		if(this.ontransdu){
			return
		}
		this.ontransdu = true
		//console.log(this.dateobject.getMonth())
		//console.log(this.dateobject.getMonth())
		switch(this.calctype) {
			case 'day':
				if($defined(this.options.loadDaysURL)){
					if(!this.loading){
						this.load.fade('in');
						this.label.fade('out');
						var cosDate = new Date()
						cosDate.setFullYear(this.dateobject.getFullYear())
						cosDate.setMonth(this.dateobject.getMonth()+1)
						
						//cosDate.setMonth(cosDate.getMonth() + 1)
						new Request.JSON({
							'url': this.options.loadDaysURL+"&month="+String(cosDate.getMonth()+1) + "&year=" +String(cosDate.getFullYear()),
							onComplete: function(events){
								this.options.markedDays = events
								this.loading = true
								this.ontransdu = false
								this.fordward()
							}.bind(this)
						}).send()
						//console.log('aca termine')
						return
					}else{						
						this.load.fade('out');
						this.label.fade('in');
						this.loading = false						
					}
				}
				this.fcontainer.set('html', this.scontainer.get('html'))
				this.mcontainer.setStyle('left', 0)
				this.scontainer.set('html', '')
				this.dateobject.setMonth(this.dateobject.getMonth() + 1)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateDays(this.scontainer);
				break;
			
			case 'month':
				this.fcontainer.set('html', this.scontainer.get('html'))
				this.mcontainer.setStyle('left', 0)
				this.scontainer.set('html', '')
				this.dateobject.setFullYear(this.dateobject.getFullYear() + 1)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateMonths(this.scontainer);
				break;

			case 'year':
				this.fcontainer.set('html', this.scontainer.get('html'))
				this.mcontainer.setStyle('left', 0)
				this.scontainer.set('html', '')
				this.dateobject.setFullYear(this.dateobject.getFullYear() + 12)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateYears(this.scontainer);
				break;
		}


		this.mcontainer.get('tween').addEvent('onComplete', function(){
			this.fcontainer.set('html','')
			this.ontransdu = false
		}.bind(this))
		this.mcontainer.tween('left', parseInt(this.mcontainer.getStyle('left').replace('px', ''))-this.options.width)

	},


	backward: function(){
		if(this.ontransdu){
			return
		}
		this.ontransdu = true

		var ghost = this.scontainer.get('html')
		this.scontainer.set('html', ghost)

		switch(this.calctype) {

			case 'day':
			
				if($defined(this.options.loadDaysURL)){
					if(!this.loading){
						this.load.fade('in');
						this.label.fade('out');
						//console.log('me fui '+this.options.loadDaysURL)
						var cosDate = new Date()
						cosDate.setFullYear(this.dateobject.getFullYear())
						cosDate.setMonth(this.dateobject.getMonth() - 1)
						//console.log(cosDate.getMonth());
						//cosDate.setFullYear(this.dateobject.getFullYear())
						new Request.JSON({
							'url': this.options.loadDaysURL+ "&month="+String(cosDate.getMonth() + 1) + "&year=" +String(cosDate.getFullYear()),
							onComplete: function(events){
								this.options.markedDays = events
								this.loading = true
								this.ontransdu = false
								this.backward()
							}.bind(this)
						}).send()
						//console.log('aca termine')
						return
					}else{
						this.load.fade('out');
						this.label.fade('in');
						this.loading = false
					}
				}
				this.dateobject.setMonth(this.dateobject.getMonth() - 1)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateDays(this.fcontainer);
				break;

			case 'month':
				this.dateobject.setFullYear(this.dateobject.getFullYear() - 1)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateMonths(this.fcontainer);
				break;

			case 'year':
				this.dateobject.setFullYear(this.dateobject.getFullYear() - 12)
				this.options.currentMonth = this.dateobject.getMonth()
				this.options.currentYear = this.dateobject.getFullYear()
				this.calculateYears(this.fcontainer);
				break;
		}

		
		this.mcontainer.get('tween').addEvent('onComplete', function(){
			this.scontainer.set('html', '')

			switch(this.calctype) {

				case 'day':
					this.calculateDays(this.scontainer);
					break;

				case 'month':
					this.calculateMonths(this.scontainer);
					break;

				case 'year':
					this.calculateYears(this.scontainer);
					break;
			}
			//this.calculate(this.scontainer);

			this.mcontainer.setStyle('left', this.options.width*-1)
			//this.label.set('html', this.options.shortMonthNames[this.options.currentMonth] + ' ' + String(this.dateobject.getFullYear()))
			this.ontransdu = false
		}.bind(this))
	
		this.mcontainer.tween('left', parseInt(this.mcontainer.getStyle('left').replace('px', ''))+this.options.width)
	},

	browse: function(element){
		if((this.ontransdu || this.browsedisable) && !element.target.get('year')){
			return
		}
		this.ontransdu = true

		var code = this.scontainer.get('html')
		this.scontainer.set('html', code)
		if(!Browser.Engine.trident){
			this.table.set('html', '');
			this.tablehead.set('html', '');
			this.tablebody.set('html', '');
		}
		this.resetToAbsolute()

		switch(this.calctype){
			case 'day':
				this.calctype = 'month'
				this.calculateMonths(this.fcontainer)
				break;

			case 'month':
				if(element.target.get('month')){
					var obj = JSON.decode(element.target.get('month'))
					this.dateobject.setFullYear(obj.year)
					this.dateobject.setMonth(obj.month)
					this.options.currentMonth = this.dateobject.getMonth()
					this.options.currentYear = this.dateobject.getFullYear()
					if($defined(this.options.loadDaysURL)){
						if(!this.loading){
							//console.log('entro a hacer el request')
							this.load.fade('in');
							this.label.fade('out');
							new Request.JSON({
								'url': this.options.loadDaysURL,
								'data': "month="+String(this.dateobject.getMonth()) + "&year=" +String(this.dateobject.getFullYear()),
								onComplete: function(events){
									this.options.markedDays = events
									this.loading = true
									this.ontransdu = false
									this.browse(element)
								}.bind(this)
							}).send()
							return
						}else{
							//console.log('NO entro a hacer el request')
							this.load.fade('out');
							this.label.fade('in');
							this.loading = false						
						}
					}
					this.calculateDays(this.fcontainer)
					this.calctype = 'day'
				}else{
					this.calctype = 'year'
					this.browsedisable = true
					this.calculateYears(this.fcontainer)
				}
				
				break;

			case 'year':
				if(element.target.get('year')){
					var obj2 = JSON.decode(element.target.get('year'))
					this.dateobject.setFullYear(obj2.year)
					this.options.currentMonth = this.dateobject.getMonth()
					this.options.currentYear = this.dateobject.getFullYear()
					this.calculateMonths(this.fcontainer)
					this.calctype = 'month'
					this.browsedisable = false
				}
				break;
		}

		this.fxe.removeEvents()
		this.fxe.addEvent('onComplete', function(){
			this.resetToRelative()
			this.ontransdu = false
		}.bind(this))

		this.fxe.start({
			'0':{
				'opacity': 0
			},
			'1':{
				'opacity': 1
			}
		})

	},

	showtooltip: function(event){
		this.tooltip.get('tween').removeEvents()
		//var mousee = this.mousePosition(event);
		//console.log(event.target)
		var mousee = event.target.getCoordinates();
		this.tooltip.setStyles({
			'position': 'absolute',
			'left': mousee.left + mousee.width,
			'top': mousee.top + mousee.height,//.getScroll().y,
			'width': this.options.tooltipWidth,
			'background-color': 'white',
			'opacity': 0,
			'border': '2px dotted grey',
			'padding': 10,
			'z-index': 20

		})
		//console.log(event.target)
		var obj = JSON.decode(event.target.get('date'))
		if(this.checkMarked(obj.day,obj.year,obj.month)){
			this.tooltip.set('html', this.checkMarked(obj.day,obj.year,obj.month))
		}
		this.tooltip.inject(document.body)
		this.tooltip.tween('opacity', 1)
	},

	hidetooltip: function(){
		this.tooltip.get('tween').addEvent('onComplete', function(element){
			element.dispose()
		})
		this.tooltip.tween('opacity', 0)
	},

	applyEvents: function(){
		this.frame.getElements('.day').each(function(element){
		    if(this.options.retrieveonlyonmarked && element.hasClass('marked')){
			element.addEvent('click', this.retrieve.bind(this))
		    }else if(!this.options.retrieveonlyonmarked){
			element.addEvent('click', this.retrieve.bind(this))
		    }
		}.bind(this))
		//this.frame.getElements('.day').addEvent('click', this.retrieve.bind(this))
		this.frame.getElements('.marked').addEvent('mouseenter', this.showtooltip.bindWithEvent(this))
		this.frame.getElements('.marked').addEvent('mouseleave', this.hidetooltip.bindWithEvent(this))
		this.frame.getElements('.month').addEvent('click', this.browse.bind(this))
		this.frame.getElements('.year').addEvent('click', this.browse.bind(this))
	},
	
	retrieve: function(element){
		var obj = JSON.decode(element.target.get('date'))
		var result = ''

		if(this.options.twoDigits){
			if(parseInt(obj.day) < 10){
				obj.day = '0'+obj.day
			}
			if(parseInt(obj.month) < 10){
				obj.month = '0'+obj.month
			}
		}
		if(this.options.twoDigitsYear){
			var year = obj.year
			obj.year = year.toString().substring(2)
		}

		switch(this.options.dateFormat){
			case 'd/m/y':
				result = obj.day+this.options.separator+obj.month+this.options.separator+obj.year
				break
			case 'm/d/y':
				result = obj.month+this.options.separator+obj.day+this.options.separator+obj.year
				break
			case 'y/m/d':
				result = obj.year+this.options.separator+obj.month+this.options.separator+obj.day
				break
			case 'y/d/m':
				result = obj.year+this.options.separator+obj.day+this.options.separator+obj.month
				break
		}
		
		if(!this.reference.hasClass('standalone')){
			this.frame.fade('out')
			this.reference.set('day', obj.day)
			this.reference.set('month', obj.month)
			this.reference.set('year', obj.year)
			this.reference.set('value', result)
		}
		this.fireEvent('retrieve', obj)
	},

	_mousePosition: function(event){
		return({
			'x' : event.client.x,
			'y': event.client.y
		})
	},

	checkMarked: function(day, year, month){
		if($defined(this.options.markedDays[String(day)+"/"+String(month)+"/"+String(year)])){
			return this.options.markedDays[String(day)+"/"+String(month)+"/"+String(year)]
		//return true
		}
		if($defined(this.options.markedDays[String(day)+"/"+String(year)])){
			return this.options.markedDays[String(day)+"/"+String(year)]
		//return true
		}
		if($defined(this.options.markedDays[String(day)])){
			return this.options.markedDays[String(day)]
		//return true
		}
		return false
	}

})
/*
	PhiImageManager
	Image Manager widget based on mootools
	by Esteban Diaz
	esteban.diaz -at- phidias -dot- com -dot- co
	madsad -at- gmail -dot- com
 */


var PhiImageManager= new Class({

    initialize: function(element, callback) {
	//alert('asdasd');
	this.element	= $(element)
	this.frames = []
	this.frameid =''
	this.sorturl = this.element.get('sort')
	var tmpframes = this.element.getChildren('div.frame')
	this.list	= new Element('ol', {
	    'class':'image_manager'
	}).inject(this.element,'top')
	this.number_count = 0
	this.editables_count = 0
	tmpframes.each( function(frame) {
	    this.number_count++
	    this.editables = []
	    this.frameid = frame.get('id')
	    var image_container = frame.getElement('div.image_container')
	    
	    
	    var image_editables = frame.getElements('div.editable');
	    //console.log(image_editables)
	    
	    image_editables.each(function(editable){
		this.editables_count++
		var edittype = editable.get('typeof')
		//console.log(editable.get('typeof'))
		var input = null
		var trunc = editable.get('html').truncate(20)
		//console.log(trunc)

		var originaltext = new Element ('div', {'class' : 'otext', 'html' : trunc, 'id' : 'otext_'+this.frameid+String(this.editables_count)})

		if(edittype == 'text'){
		    input = new Element('input', {'type': 'text', 'class' : 'editable_widget', 'value':editable.get('html'), 'id' : 'input_'+this.frameid+String(this.editables_count), 'style' : 'display:none'})
		    originaltext.addClass('ot')
		}else if(edittype == 'textarea'){
		    input = new Element('textarea', {'class' : 'editable_widget', 'html' : editable.get('html'), 'id' : 'input_'+this.frameid+String(this.editables_count), 'style' : 'display:none'})
		    originaltext.addClass('ota')
		}

		var textile = new Element('div', {'class': 'editable', 'id': 'editable_'+this.frameid})
		
		
		originaltext.inject(textile)
		input.inject(textile)

		this.editables.include(textile)
	    }.bind(this))
	    
	    var img = image_container.getChildren('img')[0];

	    var list_elem = new Element('li', {	'class':'im_frame', 'id' : 'im_frame_'+this.frameid})
	    var container = new Element('div', {'class':'frame_container', 'id' : 'frame_container_'+this.frameid})
	    var content = new Element('div', {'class':'frame_content', 'id' : 'frame_content'+this.frameid})
	    var frame_image = new Element('div', {'class':'frame_image', 'id' : 'frame_image_'+this.frameid})
	   // var frame_title = new Element('div', {'class':'frame_title'})


	    img.inject(frame_image);

	    new Element('div', {'class':'frame_number', 'html' : this.number_count}).inject(container)
	    frame_image.inject(content)
	    //console.log(this.editables)
	    this.editables.each(function(element){
		element.inject(content)
	    }.bind(this))

	    content.inject(container)
	    new Element('div', {'class':'frame_options', 'id' : 'frame_options_'+this.frameid}).inject(container)

	    container.inject(list_elem)

	    this.frames.include(list_elem.inject(this.list))
	    frame.destroy()

	}.bind(this) )
	//element.setStyle('display', 'none')
	this.applyEvents()

    },

    applyEvents: function(){


	Phi.pagesort = new Sortables($(this.list), {
	    opacity: 0.3,
	    clone: true,
	    constrain: true,
	    handle: '.frame_number'
	})

	Phi.pagesort.addEvent('complete', function(){

	    $$('.frame_number').each(function(element, counter){
		element.set('html', String(counter+1))
	    })

	    var params	= Phi.pagesort.serialize(null, function(element) {
		return element.id.replace('im_frame_','');
	    }).flatten().join('|');
	   //console.log(params)

	    if (Phi.pagesort.resorted) {
		new Request({
		    'url': this.sorturl,
		    'data': 'order='+params
		}).send();
	    }
	}.bind(this));

	Phi.pagesort.addEvent('sort', function(item){
	    Phi.pagesort.resorted = true;
	});

	//console.log(this.frames)
	this.frames.each(function(element){
	    var action = element.getElement('div.frame_content')
	    action.addEvent('mouseenter', function(obj){
		this.set('tween', {'duration': 'short'});
		/*this.tween('opacity', 1)*/
		var options = this.getParent().getElement('div.frame_options');
		options.set('tween', {'duration': 200});
		options.set('height', '100%');
		options.tween('left', 135);
	    })
	})
	
	this.frames.each(function(element){
	    var action = element.getElement('div.frame_content')
	    action.addEvent('mouseleave', function(element){
		var options = this.getParent().getElement('div.frame_options');
		/*this.tween('opacity', 0.8)*/
		var coordinates = options.getCoordinates()

		//console.log(element.client.x)
		options.addEvent('mouseleave', function(){
		    this.set('tween', {'duration': 200})
		    this.set('height', '100%')
		    this.tween('left', 25)
		})

		if(!(element.page.x >= coordinates.left && element.page.x <= coordinates.right && element.page.y >= coordinates.top && element.page.y <= coordinates.bottom)){
		   /* console.log(coordinates)
		    console.log(element.page)*/
		    options.set('tween', {'duration': 200})
		    options.set('height', '100%')
		    options.tween('left', 25)

		}
	    })
	})


	$$('.otext').addEvent('click', function() {
		this.set('styles', {'display':'none'});

		var kid = $(this.id.replace('otext_','input_'));
		kid.set('styles', {'display':'block'});
		kid.focus();
		kid.select();
	});

	$$('.editable_widget').addEvent('blur', function() {
		this.set('styles', {'display':'none'});

		var father = $(this.id.replace('input_','otext_'));

		var value =  this.value||Language.get('untitled').capitalize()

		father.set('html',value.truncate(20));
		father.set('styles', {'display':'block'});


		/*new Request({
			'url':	Phi.linkbase+'i/image/edit&_id={/literal}{$_id}{literal}',
			'data':	this.name+'='+this.value,
			onComplete: function() {
				father.highlight();
			}
		}).send();	*/
	});


    }


})
var PhiScroller = new Class({

	element: false,
	viewport: false,
	
	initialize: function(element) {

		this.element = $(element)
		this.element.setStyle('overflow', 'hidden')

		this.slider = new Element('div').inject(document.body)
		
		this.width		= this.element.getSize().x
		this.current	= 0
		this.n_slides	= 0
		
		max_height	= 0
		total_width	= 0
		children	= this.element.getChildren()
		children.each( function(child) {
			
			child.setStyles({
				float: 'left',
				width: this.width
			})
			child.inject(this.slider)

			size		= child.getSize()
			max_height	= Math.max(max_height, size.y)
			total_width	+= this.width
			this.n_slides++
			
		}.bind(this) )

		this.slider.inject(this.element)
		this.element.setStyle('height', max_height)
		this.slider.setStyle('width', total_width)

		this.scroll = new Fx.Scroll(this.element)
	},

	scrollTo: function(index) {
		this.current = index
		this.scroll.start(index*this.width, 0)
	},
	
	next: function() {
		this.scrollTo(Math.min(this.current+1, this.n_slides-1))
	},
	
	previous: function() {
		this.scrollTo(Math.max(this.current-1, 0))
	}
	
})
var PhiStyler = new Class({

	Implements: [Options],
	
	options: {
		setters:			[],				/* an array of form elements.  Element name must correspond with CSS property */
		getters:			new Hash({}),	/* a Hash. Key is a CSS selector, value is a coloquial name */
		properties:			new Hash({}),	/* Modified properties. Key is a CSS selector, value is a JS object with the modified CSS properties */
		onTargetChange: 	$empty,
		inspect:			true			/* Allow selector selection by clicking on existing DOM elements */
	},

	target_selector:	false,
	
	initialize: function(options)
	{
		this.setOptions(options||{});

		/* Property setter */
		this.options.setters.each( function(element) { 

			element._PhiStyler_object = this;

			switch ( element.get('tag') ) {
				case 'select':
					element.addEvent('change', this._setProperty);
				break;

				case 'input':
					if ( element.hasClass('color') ) {
						element.addEvent('change', this._setProperty);
					} else {
						element.addEvent('keyup', this._setProperty);
					}
				break;
			}
		}.bind(this));

		/* Is mootools "unHashing" Hashes passed as options? It appears so. Fix it. */
		this.options.getters	= $H(this.options.getters);
		this.options.properties	= $H(this.options.properties);
		
		/* Add "inspect element"-like behavior to getters */
		if ( this.options.inspect ) {
			this.options.getters.each( function(name,selector) {
	
				$$(selector).each( function(dom_element) {
					dom_element.addEvents(this._inspect_events);
					dom_element._PhiStyler_selector = selector;
					dom_element._PhiStyler_object = this;
				}.bind(this) );
	
			}.bind(this) );
		}
		
		/* Target the first selector */
		this.setTarget( this.options.getters.getKeys()[0] );
	},

	setTarget: function(target_selector)
	{
		this.target_selector = target_selector		
		
		/* Load current properties */		
		current_properties = this.options.properties.get(target_selector)

		this.options.setters.each( function(property) {
			property_name = property.get('name')
			property.set('value', $chk(current_properties) && $chk(current_properties[property_name]) ? current_properties[property_name] : '' );
		}.bind(this) );
		
		$$(this.target_selector).highlight()
		this.options.onTargetChange.run(target_selector)
	},
	
	/* Set all properties from current setter(this) to specified selector */
	_setProperty: function()
	{
		$$(this._PhiStyler_object.target_selector).setStyle(this.get('name'),this.get('value'));

		properties = this._PhiStyler_object.options.properties.get(this._PhiStyler_object.target_selector)
		if ( !$chk(properties) ) {
			properties = {}
		}

		properties[this.get('name')] = this.get('value')
		this._PhiStyler_object.options.properties.set(this._PhiStyler_object.target_selector, properties)
	},

	_inspect_events:
	{
		mouseover: function() {
			this.setStyle('border', '1px solid red');
			return false;
		},
	
		mouseout: function() {
			this.setStyle('border', '');
		},
	
		click: function() {
			this.setStyle('border', '');
			this._PhiStyler_object.setTarget(this._PhiStyler_selector);			
			return false;
		}
	},

	unload: function()
	{
		/* Remove "inspect element"-like behavior to getters */
		if ( this.options.inspect ) {
			this.options.getters.each( function(name,selector) {
	
				$$(selector).each( function(dom_element) {
					dom_element.removeEvent('mouseover',	this._inspect_events.mouseover);
					dom_element.removeEvent('mouseout',		this._inspect_events.mouseout);
					dom_element.removeEvent('click',		this._inspect_events.click);
				}.bind(this) );
	
			}.bind(this) );
		}
	},

	getCSS: function()
	{
		output = ''
		
		this.options.properties.each( function(properties, selector) {
			output += selector+' {\n'
			for ( property in properties ) {
				if ( properties[property] )
					output += '\t'+property.replace(/[A-Z]/g,"-$&").toLowerCase()+': '+properties[property]+';\n'
			}
			output += '}\n\n'
		}.bind(this) )

		return output
	}

});
var PhiTabs = new Class({
	
	initialize: function(element, callback) {
		
		this.element	= $(element)
		this.tabs		= this.element.getChildren('.tab')
		this.tablist	= new Element('ul', {'class':'phi_tabs'}).inject(this.element,'top')
		this.callback	= $chk(callback) ? callback : $empty
		
		first = true
		this.tabs.each( function(tab) {
			
			/* Create the LI from the first H2 */
			h2 = tab.getFirst('h2')
			
			tab.list_item = new Element('li', {'class':(first?'active_tab':'')}).inject(this.tablist)
			
			link = new Element('a', {
				href: '#',
				html: h2.get('html'),
				events: {
					click: function() {
						this.tabpane.open(this.tab)
						//this.getParent('li').addClass('active_tab')
						this.blur()
						return false
					}
				}
			}).inject(tab.list_item)
			
			link.tab		= tab
			link.tabpane	= this
			
			h2.destroy()
			
			/* Hide all but the first tab */
			if ( !first )
				tab.setStyle('display','none')
			first = false
			
		}.bind(this) )
	
	},
	
	open: function(tab)
	{
		tab = $(tab)
		this.tabs.setStyle('display', 'none')
		tab.setStyle('display', 'block')
		this.tablist.getChildren('li').removeClass('active_tab')
		tab.list_item.addClass('active_tab')
		this.callback.run(tab)
	}
	
})
/*
	PhiTooltip
	by Santiago Cortes and Esteban Diaz
	santiago.cortes -at- gmail -dot- com
*/
var PhiTooltip = new Class({
	
	Extends: PhiBubble,
	
	options: {
		follow:		false,
		rollover:	true,
		margin:		10
	},
	
	initialize: function(element, options)
	{
		this.parent(options);
		
		this.element = $(element);
		
		if ( this.options.rollover ) {
			this.element.addEvent('mouseenter', this._show.bind(this));
			this.element.addEvent('mouseleave', this.hide.bind(this));
		}
		
		if ( this.options.follow ) {
			this.element.addEvent('mousemove',	this._show.bind(this));
		}
	},
	
	_getPoints: function(position, event)
	{
		var x			= 0;
		var y			= 0;		
		var coords		= this.element.getCoordinates();
		
		switch ( position ) {
			case 'top':
				x = this.options.follow ? event.page.x : coords.left+coords.width/2;
				y = this.options.follow ? event.page.y-this.options.margin : coords.top-this.options.margin;
			break;
			
			case 'right':
				x = this.options.follow ? event.page.x+this.options.margin : coords.left+coords.width+this.options.margin;
				y = this.options.follow ? event.page.y : coords.top+coords.height/2;
			break;
		
			case 'bottom':
				x = this.options.follow ? event.page.x : coords.left+coords.width/2;
				y = this.options.follow ? event.page.y+this.options.margin : coords.top+coords.height+this.options.margin;
			break;
			
			case 'left':
				x = this.options.follow ? event.page.x-this.options.margin : coords.left-this.options.margin;
				y = this.options.follow ? event.page.y : coords.top+coords.height/2;
			break;
		}
		
		return {x:x,y:y};
	},
	
	_show: function(event)
	{
		var position	= this.options.position;
		
		if ( position == 'top' ) {
			var points = this._getPoints(position, event);
			if ( this._validatePosition(points.x,points.y,position) == position ) {
				return this.show(points.x,points.y,position);
			} else {
				var points	= this._getPoints('bottom', event);
				position = 'bottom';
				return this.show(points.x,points.y,position);
			}
		}
		
		if ( position == 'bottom' ) {
			var points = this._getPoints(position, event);
			if ( this._validatePosition(points.x,points.y,position) == position ) {
				return this.show(points.x,points.y,position);
			} else {
				var points	= this._getPoints('top', event);
				position = 'top';
				return this.show(points.x,points.y,position);
			}
		}
		
		if ( position == 'left' ) {
			var points = this._getPoints(position, event);
			if ( this._validatePosition(points.x,points.y,position) == position ) {
				return this.show(points.x,points.y,position);
			} else {
				var points	= this._getPoints('right', event);
				position = 'right';
				return this.show(points.x,points.y,position);
			}
		}
		
		if ( position == 'right' ) {
			var points = this._getPoints(position, event);
			if ( this._validatePosition(points.x,points.y,position) == position ) {
				return this.show(points.x,points.y,position);
			} else {
				var points	= this._getPoints('left', event);
				position = 'left';
				return this.show(points.x,points.y,position);
			}
		}
	}

});
/*
	Phi content editor
	by Santiago Cortes <santiago.cortes -at- gmail -dot- com>
	fixed for mootools by Esteban Diaz <madsad -at- gmail -dot- com>

	This script provides methods for reloading instance content via AJAX, and to handle lightboxed actions.
	
	Phidias Software Ltda.
	All Rights Reserved
	Bogota - Colombia
 */
Phi = {}
Phi.rules = {

	/* Accordions */
	'div.accordion': function()
	{
		new Accordion(this.getElements('.toggler'), this.getElements('.content'))
	},
		
	/* Color picker */
	'input.color': function()
	{
		new Asset.javascript(Phi.interface_url+'default/js/jscolor/jscolor.js', {
			onload: function() {
				new jscolor.color(this, {
					hash:true,
					caps:false
				});
			}.bind(this)
		})
	},
	
	'input.slider:keyup': function(event)
	{			
		if ( !$chk(this.slider) || !$defined(event) ) {
			return;
		}

		numvalue	= parseFloat(this.value.replace(/[^0-9.-]/g),'')||0;
		step		= parseFloat(this.get('slider_step'))||1;

		if ( event.key == 'up' ) {
			numvalue += step
		} else if (event.key == 'down' ) {
			numvalue -= step
		}

		
		this.set('value', numvalue+this.get('slider_append'))
		
		if ( numvalue >= this.slider.options.range[0] && numvalue <= this.slider.options.range[1]) {
			this.slider.set(numvalue)
		}
		this.setCaretPosition('end')
		this.setCaretPosition(this.getCaretPosition()-2)
	},
	
	'input.slider:focus': function()
	{
		this.select()
		
		coords = this.getCoordinates()		
		
		if ( $chk(this.slider) ) {
			this.slider_frame.setStyles({
				display: 'block',
				left: coords.left,
				top: coords.top+coords.height				
			})
			return;
		}
		
		this.slider_frame	= new Element('div', {
			'class': 'slider_frame',
			styles: {
				position: 'absolute',
				left: coords.left,
				top: coords.top+coords.height,
				zIndex: 10000
			}
		}).inject(document.body)
		
		this.slider_bar		= new Element('div', {
			'class': 'slider_ridge'
		}).inject(this.slider_frame)
		
		this.slider_knob	= new Element('div', {
			'class': 'slider_knob'
		}).inject(this.slider_bar)
		
		this.slider = new Slider(this.slider_bar, this.slider_knob, {
		    range: [0, 100],
		    wheel: true,
		    offset: 0,
		    onChange: function(pos) {
				this.set('value', pos+this.get('slider_append'))
				this.fireEvent('keyup')
		    }.bind(this)
		})
		
		if ( numvalue = parseFloat(this.value.replace(/[^0-9.-]/g),'') ) {
			this.slider.set(numvalue)
		}
	},

	'input.slider:blur': function()
	{
		this.slider_frame.setStyle('display','none')
	},
	

	/* General sortables */
	'ol.sortable':function()
	{
		var handleob = this.get('handle');
		Phi.pagesort = new Sortables($(this), {
			opacity: 0.3,
			clone: true,
			constrain: true,
			handle: handleob
		})
		Phi.pagesort.addEvent('complete',	function(item){
			var url = this.getParent().get('action');
			var params	= Phi.pagesort.serialize(null, function(element) {
				return element.id;
			}).flatten().join('|');
			if (Phi.pagesort.resorted) {
				new Request({
					'url': url,
					'data': 'order='+params
				}).send();
			}
		}.bind(this));
		Phi.pagesort.addEvent('sort', function(item){
			Phi.pagesort.resorted = true;
		});
	},

	/*input fields related on edition*/
	'.editrelate:keyup':function()
	{
		var related = $$(this.get('relation'));
		if ( $defined(related)) {
			var value = '';
			value = this.get('value');
			related.set('value', value);
			related.set('html', value);
		}
	},

	'.updateonchange:change':function()
	{
		var data = this.getParent('form').toQueryString();
		if(this.hasClass('nosave')){
			data = data+'&nosave=true';
		}
		data = data+'&update='+this.get('update');

		new Request.HTML({
			'url': this.getParent('form').get('action'),
			'data': data,
			'evalScripts': false,
			onComplete: function(tree,elements,response,javascript){
				/*console.log(response);
				console.log(elements);
				console.log(javascript);*/
				var mydiv = new Element('div')
				//mydiv.set('html', response.trim());
				elements.each(function(element){
					element.inject(mydiv);
				})
			//	console.log(mydiv);
				/*check of iframes*/
				/*if($defined(mydiv.getElement('iframe'))){
					//console.log('FOUND IT');
				}*/
				$(this.get('update')).set('html', mydiv.get('html'));
				eval(javascript);
			}.bind(this)
		}).send();
		return false;
	},

	/* Master checkboxes */
	'input[type=checkbox].master:click': function()
	{
		$$('input[type=checkbox].copy_'+this.id).set('checked', this.checked);
	},
	
	/* General deleters */
	'a.deleter:click': function()
	{
		var parent = null;
		if ( parent = $(this.get('parent')) ) {
			
			var message = this.get('message')||Language.get('delete this element');
			if ( !confirm(message) ) {
				return false;
			}

			new Request({
				'url': this.href,
				'onComplete': function() {
					new Fx.Tween(parent, {
						onComplete: function() {
							parent.destroy();
							
							if ( this.get('ondelete') ) {
								eval(this.get('ondelete'));
							}

						}.bind(this)
					}).start('opacity',0);
				}.bind(this)
			}).send();
			return false;
		}
	},
	
	/* date input fields */
	'input.date': function()
	{		
		if ( !this.id ) {
			this.id = this.get('name');
		}
		
		var date_after = $(this.get('always_before'));
		
		if ( date_after ) {
			this.date_after			= date_after;	
			date_after.date_before	= this;
		}

		new Asset.css(Phi.interface_url+'default/css/phi_datepicker.css')
		new PhiDatePicker(this, {
			currentYear : this.get('year'),
			currentDay : this.get('day'),
			currentMonth : parseInt(this.get('month'))-1,
			dateFormat: 'd/m/y',
			height: 210,
			onRetrieve: function(){
				if ( this.date_after || this.date_before ) {

					var target			= this.date_after||this.date_before;

					var current_array	= this.get('value').split('/');
					var current_epoch	= parseInt(current_array[0]) + parseInt(current_array[1])*32 + parseInt(current_array[2])*365;

					var target_array	= target.get('value').split('/');
					var target_epoch	= parseInt(target_array[0]) + parseInt(target_array[1])*32 + parseInt(target_array[2])*365;

					if ( (this.date_after && current_epoch > target_epoch) || (this.date_before && current_epoch < target_epoch) ) {
						target.set('value', this.get('value'));
					}
				}
			}.bind(this)
		});
	},

	'div.image_manager': function()
	{
	    new PhiImageManager(this);
	}


}

Phi.runRules = function()
{
	$(document.body).behave(Phi.rules)
}
window.addEvent('load', Phi.runRules)
/*
	PhiFinder
	Port of S.O.Phi.A finder tools
 */

var Finder = new Class({

    initialize: function(url, dom, delay)  {
	this.url = url
	this.extra_data = ''

	this.dom = dom
	this.dom.finder = this

	this.query = ''

	this.delay = delay||230

	this.timer = null
    },

    search: function(query) {

	if ( query == this.query ) {
	    return;
	}

	this.query = query
	if ( $chk(this.timer) ) {
	    $clear(this.timer)
	}

	if ( !this.query.length ) {
	    return this.dom.process('',[])
	}

	this.timer = this.pull.delay(this.delay,this)
    },

    pull: function() {
	new Request({
	    url: this.url,
	    data: 'q='+this.query+this.extra_data,
	    onComplete: function(response) {
		var results = JSON.decode(response)
		if ( $chk(results) ) {
		    this.dom.process(this.query, results)
		} else {
		    this.dom.error(this.query, response)
		}
		this.extra_data = ''
	    }.bind(this)
	}).send()
    },

    setDom: function(dom) {
	this.dom = dom
    }

})



var Finder_DOM_Sections = new Class({

    initialize: function(search_field, results_container, value_container,  type) {

	this.page = 1
	this.search_field = $(search_field)
	this.results = $(results_container)
	this.idcont = $(value_container)
	this.results.set('tween')
	this.results.pointer = false
	this.type = type
	this.message = this.search_field.getParent().getNext('.message')

	/* Set special search field functions */
	this.search_field.removeEvents('keydown')
	this.search_field.addEvents({

	    'focus': function(event) {
		this.results.tween('height', 23)
	    }.bind(this),

	    'blur': function(event) {
		this.results.tween('height', 0)
	    }.bind(this),

	    'keydown': function(event) {

		switch ( event.key ) {
		    case 'enter':
			if ( $chk(this.results.pointer) ) {
			    this.search_field.set('value', this.results.pointer.getElement('.name').get('result'))
			    this.idcont.set('value', this.results.pointer.getElement('.name').get('id'))
			    this.search_field.blur()

			}
			event.stop()
			break;

		    case 'down':
			if ( $chk(this.results.pointer) ) {
			    var next = this.results.pointer.getNext()
			    if ( $chk(next) ) {
				this.results.pointer.removeClass('active')
				this.results.pointer.addClass('inactive')
				this.results.pointer = next
				this.results.pointer.addClass('active')
				this.results.pointer.removeClass('inactive')
			    }
			}
			break;

		    case 'up':
			if ( $chk(this.results.pointer) ) {
			    var prev = this.results.pointer.getPrevious()
			    if ( $chk(prev) ) {
				this.results.pointer.removeClass('active')
				this.results.pointer.addClass('inactive')
				this.results.pointer = prev
				this.results.pointer.addClass('active')
				this.results.pointer.removeClass('inactive')
			    }
			}
			break;
		}

	    }.bind(this)

	})
    },

    process: function(query, results) {

	this.results.pointer = false
	this.results.set('html','')
	this.message.set('html' , '')
	if ( !query ) {
	    return;
	}

	if ( !results.length ) {
	    return this.results.set('html','<span class="result active">'+Language.get('No results')+'</span>').highlight()
	}

		

	results.each(function(result) {

	    var res = new Element('div', {
		'class': 'result inactive'
	    }).inject(this.results)

	    new Element('span', {
		'class': 'name',
		'result': result.name,
		'id': result.id,
		'html': result.name.highlight(query)
	    }).inject(res)

	    new Element('span', {
		'class': 'relation',
		'html': '<span class="number">'+result.relation +'</span>  '+this.type
	    }).inject(res)

	    if ( !$chk(this.results.pointer) ) {
		this.results.pointer = res
		this.results.pointer.removeClass('inactive')
		this.results.pointer.addClass('active')

	    }
			
	    res.addEvent('mouseover', function() {
		this.addClass('mover')
	    })

	    res.addEvent('mouseout', function() {
		this.removeClass('mover')
	    })

	    res.addEvent('click', function() {
		if ( $chk(this.results.pointer) ) {
		    this.search_field.set('value', this.results.pointer.getElement('.name').get('result'))
		    this.idcont.set('value', this.results.pointer.getElement('.name').get('id'))
		    this.search_field.blur()
		    this.results.pointer.removeClass('mover')

		}
	    }.bind(this))


	    res.store('dom', this)

	}.bind(this))

	if(results.length > 1) {
	    this.message.set('html', Language.get('more than one result found press &uarr; and &darr; to navigate'))
	}

    },

    error: function(query, response) {
	this.results.set('html', '<h1>Error</h1>'+response).highlight('#990000')
    }

})
