var MooTools={version:"1.2.0",build:""};var Native=function(e){e=e||{};var i=e.afterImplement||function(){};var h=e.generics;h=(h!==false);var g=e.legacy;var j=e.initialize;var c=e.protect;var d=e.name;var b=j||g;b.constructor=Native;b.$family={name:"native"};if(g&&j){b.prototype=g.prototype}b.prototype.constructor=b;if(d){var a=d.toLowerCase();b.prototype.$family={name:a};Native.typize(b,a)}var f=function(n,l,m,k){if(!c||k||!n.prototype[l]){n.prototype[l]=m}if(h){Native.genericize(n,l,c)}i.call(n,l,m);return n};b.implement=function(k,l,m){if(typeof k=="string"){return f(this,k,l,m)}for(var n in k){f(this,n,k[n],l)}return this};b.alias=function(n,l,m){if(typeof n=="string"){n=this.prototype[n];if(n){f(this,l,n,m)}}else{for(var k in n){this.alias(k,n[k],l)}}return this};return b};Native.implement=function(b,c){for(var d=0,a=b.length;d<a;d++){b[d].implement(c)}};Native.genericize=function(c,b,a){if((!a||!c[b])&&typeof c.prototype[b]=="function"){c[b]=function(){var d=Array.prototype.slice.call(arguments);return c.prototype[b].apply(d.shift(),d)}}};Native.typize=function(a,b){if(!a.type){a.type=function(c){return($type(c)===b)}}};Native.alias=function(c,f,a,b){for(var d=0,e=c.length;d<e;d++){c[d].alias(f,a,b)}};(function(b){for(var a in b){Native.typize(b[a],a)}})({"boolean":Boolean,"native":Native,object:Object});(function(b){for(var a in b){new Native({name:a,initialize:b[a],protect:true})}})({String:String,Function:Function,Number:Number,Array:Array,RegExp:RegExp,Date:Date});(function(c,a){for(var b=a.length;b--;b){Native.genericize(c,a[b],true)}return arguments.callee})(Array,["pop","push","reverse","shift","sort","splice","unshift","concat","join","slice","toString","valueOf","indexOf","lastIndexOf"])(String,["charAt","charCodeAt","concat","indexOf","lastIndexOf","match","replace","search","slice","split","substr","substring","toLowerCase","toUpperCase","valueOf"]);function $chk(a){return !!(a||a===0)}function $clear(a){clearTimeout(a);clearInterval(a);return null}function $defined(a){return(a!=undefined)}function $empty(){}function $arguments(a){return function(){return arguments[a]}}function $lambda(a){return(typeof a=="function")?a:function(){return a}}function $extend(b,a){for(var c in (a||{})){b[c]=a[c]}return b}function $unlink(d){var e;switch($type(d)){case"object":e={};for(var b in d){e[b]=$unlink(d[b])}break;case"hash":e=$unlink(d.getClean());break;case"array":e=[];for(var c=0,a=d.length;c<a;c++){e[c]=$unlink(d[c])}break;default:return d}return e}function $merge(){var d={};for(var e=0,a=arguments.length;e<a;e++){var g=arguments[e];if($type(g)!="object"){continue}for(var f in g){var b=g[f],c=d[f];d[f]=(c&&$type(b)=="object"&&$type(c)=="object")?$merge(c,b):$unlink(b)}}return d}function $pick(){for(var b=0,a=arguments.length;b<a;b++){if(arguments[b]!=undefined){return arguments[b]}}return null}function $random(b,a){return Math.floor(Math.random()*(a-b+1)+b)}function $splat(b){var a=$type(b);return(a)?((a!="array"&&a!="arguments")?[b]:b):[]}var $time=Date.now||function(){return new Date().getTime()};function $try(){for(var c=0,a=arguments.length;c<a;c++){try{return arguments[c]()}catch(b){}}return null}function $type(a){if(a==undefined){return false}if(a.$family){return(a.$family.name=="number"&&!isFinite(a))?false:a.$family.name}if(a.nodeName){switch(a.nodeType){case 1:return"element";case 3:return(/\S/).test(a.nodeValue)?"textnode":"whitespace"}}else{if(typeof a.length=="number"){if(a.callee){return"arguments"}else{if(a.item){return"collection"}}}}return typeof a}var Hash=new Native({name:"Hash",initialize:function(a){if($type(a)=="hash"){a=$unlink(a.getClean())}for(var b in a){this[b]=a[b]}return this}});Hash.implement({getLength:function(){var b=0;for(var a in this){if(this.hasOwnProperty(a)){b++}}return b},forEach:function(c,b){for(var a in this){if(this.hasOwnProperty(a)){c.call(b,this[a],a,this)}}},getClean:function(){var b={};for(var a in this){if(this.hasOwnProperty(a)){b[a]=this[a]}}return b}});Hash.alias("forEach","each");function $H(a){return new Hash(a)}Array.implement({forEach:function(c,b){for(var d=0,a=this.length;d<a;d++){c.call(b,this[d],d,this)}}});Array.alias("forEach","each");function $A(c){if(c.item){var b=[];for(var d=0,a=c.length;d<a;d++){b[d]=c[d]}return b}return Array.prototype.slice.call(c)}function $each(c,d,b){var a=$type(c);((a=="arguments"||a=="collection"||a=="array")?Array:Hash).each(c,d,b)}var Browser=new Hash({Engine:{name:"unknown",version:""},Platform:{name:(navigator.platform.match(/mac|win|linux/i)||["other"])[0].toLowerCase()},Features:{xpath:!!(document.evaluate),air:!!(window.runtime)},Plugins:{}});if(window.opera){Browser.Engine={name:"presto",version:(document.getElementsByClassName)?950:925}}else{if(window.ActiveXObject){Browser.Engine={name:"trident",version:(window.XMLHttpRequest)?5:4}}else{if(!navigator.taintEnabled){Browser.Engine={name:"webkit",version:(Browser.Features.xpath)?420:419}}else{if(document.getBoxObjectFor!=null){Browser.Engine={name:"gecko",version:(document.getElementsByClassName)?19:18}}}}}Browser.Engine[Browser.Engine.name]=Browser.Engine[Browser.Engine.name+Browser.Engine.version]=true;if(window.orientation!=undefined){Browser.Platform.name="ipod"}Browser.Platform[Browser.Platform.name]=true;Browser.Request=function(){return $try(function(){return new XMLHttpRequest()},function(){return new ActiveXObject("MSXML2.XMLHTTP")})};Browser.Features.xhr=!!(Browser.Request());Browser.Plugins.Flash=(function(){var a=($try(function(){return navigator.plugins["Shockwave Flash"].description},function(){return new ActiveXObject("ShockwaveFlash.ShockwaveFlash").GetVariable("$version")})||"0 r0").match(/\d+/g);return{version:parseInt(a[0]||0+"."+a[1]||0),build:parseInt(a[2]||0)}})();function $exec(b){if(!b){return b}if(window.execScript){window.execScript(b)}else{var a=document.createElement("script");a.setAttribute("type","text/javascript");a.text=b;document.head.appendChild(a);document.head.removeChild(a)}return b}Native.UID=1;var $uid=(Browser.Engine.trident)?function(a){return(a.uid||(a.uid=[Native.UID++]))[0]}:function(a){return a.uid||(a.uid=Native.UID++)};var Window=new Native({name:"Window",legacy:(Browser.Engine.trident)?null:window.Window,initialize:function(a){$uid(a);if(!a.Element){a.Element=$empty;if(Browser.Engine.webkit){a.document.createElement("iframe")}a.Element.prototype=(Browser.Engine.webkit)?window["[[DOMElement.prototype]]"]:{}}return $extend(a,Window.Prototype)},afterImplement:function(b,a){window[b]=Window.Prototype[b]=a}});Window.Prototype={$family:{name:"window"}};new Window(window);var Document=new Native({name:"Document",legacy:(Browser.Engine.trident)?null:window.Document,initialize:function(a){$uid(a);a.head=a.getElementsByTagName("head")[0];a.html=a.getElementsByTagName("html")[0];a.window=a.defaultView||a.parentWindow;if(Browser.Engine.trident4){$try(function(){a.execCommand("BackgroundImageCache",false,true)})}return $extend(a,Document.Prototype)},afterImplement:function(b,a){document[b]=Document.Prototype[b]=a}});Document.Prototype={$family:{name:"document"}};new Document(document);Array.implement({every:function(c,b){for(var d=0,a=this.length;d<a;d++){if(!c.call(b,this[d],d,this)){return false}}return true},filter:function(c,b){var d=[];for(var e=0,a=this.length;e<a;e++){if(c.call(b,this[e],e,this)){d.push(this[e])}}return d},clean:function(){return this.filter($defined)},indexOf:function(c,b){var a=this.length;for(var d=(b<0)?Math.max(0,a+b):b||0;d<a;d++){if(this[d]===c){return d}}return -1},map:function(c,b){var d=[];for(var e=0,a=this.length;e<a;e++){d[e]=c.call(b,this[e],e,this)}return d},some:function(c,b){for(var d=0,a=this.length;d<a;d++){if(c.call(b,this[d],d,this)){return true}}return false},associate:function(c){var b={},d=Math.min(this.length,c.length);for(var a=0;a<d;a++){b[c[a]]=this[a]}return b},link:function(d){var a={};for(var b=0,e=this.length;b<e;b++){for(var c in d){if(d[c](this[b])){a[c]=this[b];delete d[c];break}}}return a},contains:function(a,b){return this.indexOf(a,b)!=-1},extend:function(b){for(var c=0,a=b.length;c<a;c++){this.push(b[c])}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(b){for(var c=0,a=b.length;c<a;c++){this.include(b[c])}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 b=[];for(var d=0,a=this.length;d<a;d++){var c=$type(this[d]);if(!c){continue}b=b.concat((c=="array"||c=="collection"||c=="arguments")?Array.flatten(this[d]):this[d])}return b},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(b){if(this.length<3){return null}if(this.length==4&&this[3]==0&&!b){return"transparent"}var d=[];for(var a=0;a<3;a++){var c=(this[a]-0).toString(16);d.push((c.length==1)?"0"+c:c)}return(b)?d:"#"+d.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 e=b.arguments;e=(e!=undefined)?$splat(e):Array.slice(arguments,(b.event)?1:0);if(b.event){e=[d||window.event].extend(e)}var c=function(){return a.apply(b.bind||null,e)};if(b.delay){return setTimeout(c,b.delay)}if(b.periodical){return setInterval(c,b.periodical)}if(b.attempt){return $try(c)}return c()}},pass:function(a,b){return this.create({arguments:a,bind:b})},attempt:function(a,b){return this.create({arguments:a,bind:b,attempt:true})()},bind:function(b,a){return this.create({bind:b,arguments:a})},bindWithEvent:function(b,a){return this.create({bind:b,event:true,arguments:a})},delay:function(c,b,a){return this.create({delay:c,bind:b,arguments:a})()},periodical:function(a,b,c){return this.create({periodical:a,bind:b,arguments:c})()},run:function(a,b){return this.apply(b,$splat(a))}});Number.implement({limit:function(b,a){return Math.min(a,Math.max(b,this))},round:function(a){a=Math.pow(10,a||0);return Math.round(this*a)/a},times:function(c,b){for(var a=0;a<this;a++){c.call(b,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(c){var a="";var b=this.replace(/<script[^>]*>([\s\S]*?)<\/script>/gi,function(){a+=arguments[1]+"\n";return""});if(c===true){$exec(a)}else{if($type(c)=="function"){c(a,b)}}return b},substitute:function(a,b){return this.replace(b||(/\\?\{([^}]+)\}/g),function(c,d){if(c.charAt(0)=="\\"){return c.slice(1)}return(a[d]!=undefined)?a[d]:""})}});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(b,c){Hash.set(this,c,b)},this);return this},combine:function(a){Hash.each(a,function(b,c){Hash.include(this,c,b)},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(c,b){var a=this[c];if(a==undefined){this[c]=b}return this},map:function(c,b){var a=new Hash;Hash.each(this,function(d,e){a.set(e,c.call(b,d,e,this))},this);return a},filter:function(c,b){var a=new Hash;Hash.each(this,function(d,e){if(c.call(b,d,e,this)){a.set(e,d)}},this);return a},every:function(c,b){for(var a in this){if(this.hasOwnProperty(a)&&!c.call(b,this[a],a)){return false}}return true},some:function(c,b){for(var a in this){if(this.hasOwnProperty(a)&&c.call(b,this[a],a)){return true}}return false},getKeys:function(){var a=[];Hash.each(this,function(b,c){a.push(c)});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(c,d){if(a){d=a+"["+d+"]"}var e;switch($type(c)){case"object":e=Hash.toQueryString(c,d);break;case"array":var f={};c.each(function(g,h){f[h]=g});e=Hash.toQueryString(f,d);break;default:e=d+"="+encodeURIComponent(c)}if(c!=undefined){b.push(e)}});return b.join("&")}});Hash.alias({keyOf:"indexOf",hasValue:"contains"});var Event=new Native({name:"Event",initialize:function(d,l){l=l||window;var g=l.document;d=d||l.event;if(d.$extended){return d}this.$extended=true;var h=d.type;var k=d.target||d.srcElement;while(k&&k.nodeType==3){k=k.parentNode}if(h.test(/key/)){var c=d.which||d.keyCode;var e=Event.Keys.keyOf(c);if(h=="keydown"){var a=c-111;if(a>0&&a<13){e="f"+a}}e=e||String.fromCharCode(c).toLowerCase()}else{if(h.match(/(click|mouse|menu)/i)){g=(!g.compatMode||g.compatMode=="CSS1Compat")?g.html:g.body;var i={x:d.pageX||d.clientX+g.scrollLeft,y:d.pageY||d.clientY+g.scrollTop};var b={x:(d.pageX)?d.pageX-l.pageXOffset:d.clientX,y:(d.pageY)?d.pageY-l.pageYOffset:d.clientY};if(h.match(/DOMMouseScroll|mousewheel/)){var j=(d.wheelDelta)?d.wheelDelta/120:-(d.detail||0)/3}var m=(d.which==3)||(d.button==2);var f=null;if(h.match(/over|out/)){switch(h){case"mouseover":f=d.relatedTarget||d.fromElement;break;case"mouseout":f=d.relatedTarget||d.toElement}if(!(function(){while(f&&f.nodeType==3){f=f.parentNode}return true}).create({attempt:Browser.Engine.gecko})()){f=false}}}}return $extend(this,{event:d,type:h,page:i,client:b,rightClick:m,wheel:j,relatedTarget:f,target:k,code:c,key:e,shift:d.shiftKey,control:d.ctrlKey,alt:d.altKey,meta:d.metaKey})}});Event.Keys=new Hash({enter:13,up:38,down:40,left:37,right:39,esc:27,space:32,backspace:8,tab:9,"delete":46});Event.implement({stop:function(){return this.stopPropagation().preventDefault()},stopPropagation:function(){if(this.event.stopPropagation){this.event.stopPropagation()}else{this.event.cancelBubble=true}return this},preventDefault:function(){if(this.event.preventDefault){this.event.preventDefault()}else{this.event.returnValue=false}return this}});var Class=new Native({name:"Class",initialize:function(b){b=b||{};var a=function(d){for(var e in this){this[e]=$unlink(this[e])}for(var c in Class.Mutators){if(!this[c]){continue}Class.Mutators[c](this,this[c]);delete this[c]}this.constructor=a;if(d===$empty){return this}var f=(this.initialize)?this.initialize.apply(this,arguments):this;if(this.options&&this.options.initialize){this.options.initialize.call(this)}return f};$extend(a,this);a.constructor=Class;a.prototype=b;return a}});Class.implement({implement:function(){Class.Mutators.Implements(this.prototype,Array.slice(arguments));return this}});Class.Mutators={Implements:function(a,b){$splat(b).each(function(c){$extend(a,($type(c)=="class")?new c($empty):c)})},Extends:function(self,klass){var instance=new klass($empty);delete instance.parent;delete instance.parentOf;for(var key in instance){var current=self[key],previous=instance[key];if(current==undefined){self[key]=previous;continue}var ctype=$type(current),ptype=$type(previous);if(ctype!=ptype){continue}switch(ctype){case"function":if(!arguments.callee.caller){self[key]=eval("("+String(current).replace(/\bthis\.parent\(\s*(\))?/g,function(full,close){return"arguments.callee._parent_.call(this"+(close||", ")})+")")}self[key]._parent_=previous;break;case"object":self[key]=$merge(previous,current)}}self.parent=function(){return arguments.callee.caller._parent_.apply(this,arguments)};self.parentOf=function(descendant){return descendant._parent_.apply(this,Array.slice(arguments,1))}}};var Chain=new Class({chain:function(){this.$chain=(this.$chain||[]).extend(arguments);return this},callChain:function(){return(this.$chain&&this.$chain.length)?this.$chain.shift().apply(this,arguments):false},clearChain:function(){if(this.$chain){this.$chain.empty()}return this}});var Events=new Class({addEvent:function(b,c,a){b=Events.removeOn(b);if(c!=$empty){this.$events=this.$events||{};this.$events[b]=this.$events[b]||[];this.$events[b].include(c);if(a){c.internal=true}}return this},addEvents:function(a){for(var b in a){this.addEvent(b,a[b])}return this},fireEvent:function(b,c,a){b=Events.removeOn(b);if(!this.$events||!this.$events[b]){return this}this.$events[b].each(function(d){d.create({bind:this,delay:a,"arguments":c})()},this);return this},removeEvent:function(b,a){b=Events.removeOn(b);if(!this.$events||!this.$events[b]){return this}if(!a.internal){this.$events[b].erase(a)}return this},removeEvents:function(c){for(var b in this.$events){if(c&&c!=b){continue}var d=this.$events[b];for(var a=d.length;a--;a){this.removeEvent(b,d[a])}}return this}});Events.removeOn=function(a){return a.replace(/^on([A-Z])/,function(c,b){return b.toLowerCase()})};var Options=new Class({setOptions:function(){this.options=$merge.run([this.options].extend(arguments));if(!this.addEvent){return this}for(var a in this.options){if($type(this.options[a])!="function"||!(/^on[A-Z]/).test(a)){continue}this.addEvent(a,this.options[a]);delete this.options[a]}return this}});Document.implement({newElement:function(a,b){if(Browser.Engine.trident&&b){["name","type","checked"].each(function(c){if(!b[c]){return}a+=" "+c+'="'+b[c]+'"';if(c!="checked"){delete b[c]}});a="<"+a+">"}return $.element(this.createElement(a)).set(b)},newTextNode:function(a){return this.createTextNode(a)},getDocument:function(){return this},getWindow:function(){return this.defaultView||this.parentWindow},purge:function(){var b=this.getElementsByTagName("*");for(var c=0,a=b.length;c<a;c++){Browser.freeMem(b[c])}}});var Element=new Native({name:"Element",legacy:window.Element,initialize:function(a,c){var b=Element.Constructors.get(a);if(b){return b(c)}if(typeof a=="string"){return document.newElement(a,c)}return $(a).set(c)},afterImplement:function(a,b){if(!Array[a]){Elements.implement(a,Elements.multi(a))}Element.Prototype[a]=b}});Element.Prototype={$family:{name:"element"}};Element.Constructors=new Hash;var IFrame=new Native({name:"IFrame",generics:false,initialize:function(){var b=Array.link(arguments,{properties:Object.type,iframe:$defined});var d=b.properties||{};var e=$(b.iframe)||false;var c=d.onload||$empty;delete d.onload;d.id=d.name=$pick(d.id,d.name,e.id,e.name,"IFrame_"+$time());e=new Element(e||"iframe",d);var a=function(){var h=$try(function(){return e.contentWindow.location.host});if(h&&h==window.location.host){var f=new Window(e.contentWindow);var g=new Document(e.contentWindow.document);$extend(f.Element.prototype,Element.Prototype)}c.call(e.contentWindow,e.contentWindow.document)};(!window.frames[d.id])?e.addListener("load",a):a();return e}});var Elements=new Native({initialize:function(c,g){g=$extend({ddup:true,cash:true},g);c=c||[];if(g.ddup||g.cash){var b={},d=[];for(var f=0,a=c.length;f<a;f++){var e=$.element(c[f],!g.cash);if(g.ddup){if(b[e.uid]){continue}b[e.uid]=true}d.push(e)}c=d}return(g.cash)?$extend(c,this):c}});Elements.implement({filter:function(a,b){if(!a){return this}return new Elements(Array.filter(this,(typeof a=="string")?function(c){return c.match(a)}:a,b))}});Elements.multi=function(a){return function(){var f=[];var b=true;for(var d=0,e=this.length;d<e;d++){var c=this[d][a].apply(this[d],arguments);f.push(c);if(b){b=($type(c)=="element")}}return(b)?new Elements(f):f}};Window.implement({$:function(c,b){if(c&&c.$family&&c.uid){return c}var a=$type(c);return($[a])?$[a](c,b,this.document):null},$$:function(a){if(arguments.length==1&&typeof a=="string"){return this.document.getElements(a)}var b=[];var e=Array.flatten(arguments);for(var d=0,f=e.length;d<f;d++){var c=e[d];switch($type(c)){case"element":c=[c];break;case"string":c=this.document.getElements(c,true);break;default:c=false}if(c){b.extend(c)}}return new Elements(b)},getDocument:function(){return this.document},getWindow:function(){return this}});$.string=function(b,c,a){b=a.getElementById(b);return(b)?$.element(b,c):null};$.element=function(a,b){$uid(a);if(!b&&!a.$family&&!(/^object|embed$/i).test(a.tagName)){var d=Element.Prototype;for(var c in d){a[c]=d[c]}}return a};$.object=function(c,b,a){if(c.toElement){return $.element(c.toElement(a),b)}return null};$.textnode=$.whitespace=$.window=$.document=$arguments(0);Native.implement([Element,Document],{getElement:function(a,b){return $(this.getElements(a,true)[0]||null,b)},getElements:function(a,b){a=a.split(",");var c=[];var d=(a.length>1);a.each(function(f){var e=this.getElementsByTagName(f.trim());(d)?c.extend(e):c=e},this);return new Elements(c,{ddup:d,cash:!b})}});Element.Storage={get:function(a){return(this[a]||(this[a]={}))}};Element.Inserters=new Hash({before:function(b,a){if(a.parentNode){a.parentNode.insertBefore(b,a)}},after:function(c,a){if(!a.parentNode){return}var b=a.nextSibling;(b)?a.parentNode.insertBefore(c,b):a.parentNode.appendChild(c)},bottom:function(b,a){a.appendChild(b)},top:function(c,a){var b=a.firstChild;(b)?a.insertBefore(c,b):a.appendChild(c)}});Element.Inserters.inside=Element.Inserters.bottom;Element.Inserters.each(function(b,c){var a=c.capitalize();Element.implement("inject"+a,function(d){b(this,$(d,true));return this});Element.implement("grab"+a,function(d){b($(d,true),this);return this})});Element.implement({getDocument:function(){return this.ownerDocument},getWindow:function(){return this.ownerDocument.getWindow()},getElementById:function(b,c){var d=this.ownerDocument.getElementById(b);if(!d){return null}for(var a=d.parentNode;a!=this;a=a.parentNode){if(!a){return null}}return $.element(d,c)},set:function(b,d){switch($type(b)){case"object":for(var c in b){this.set(c,b[c])}break;case"string":var a=Element.Properties.get(b);(a&&a.set)?a.set.apply(this,Array.slice(arguments,1)):this.setProperty(b,d)}return this},get:function(b){var a=Element.Properties.get(b);return(a&&a.get)?a.get.apply(this,Array.slice(arguments,1)):this.getProperty(b)},erase:function(b){var a=Element.Properties.get(b);(a&&a.erase)?a.erase.apply(this,Array.slice(arguments,1)):this.removeProperty(b);return this},match:function(a){return(!a||Element.get(this,"tag")==a)},inject:function(b,a){Element.Inserters.get(a||"bottom")(this,$(b,true));return this},wraps:function(b,a){b=$(b,true);return this.replaces(b).grab(b,a)},grab:function(b,a){Element.Inserters.get(a||"bottom")($(b,true),this);return this},appendText:function(b,a){return this.grab(this.getDocument().newTextNode(b),a)},adopt:function(){Array.flatten(arguments).each(function(a){a=$(a,true);if(a){this.appendChild(a)}},this);return this},dispose:function(){return(this.parentNode)?this.parentNode.removeChild(this):this},clone:function(a,b){switch($type(this)){case"element":var i={};for(var j=0,l=this.attributes.length;j<l;j++){var c=this.attributes[j],e=c.nodeName.toLowerCase();if(Browser.Engine.trident&&(/input/i).test(this.tagName)&&(/width|height/).test(e)){continue}var f=(e=="style"&&this.style)?this.style.cssText:c.nodeValue;if(!$chk(f)||e=="uid"||(e=="id"&&!b)){continue}if(f!="inherit"&&["string","number"].contains($type(f))){i[e]=f}}var g=new Element(this.nodeName.toLowerCase(),i);if(a!==false){for(var h=0,k=this.childNodes.length;h<k;h++){var d=Element.clone(this.childNodes[h],true,b);if(d){g.grab(d)}}}return g;case"textnode":return document.newTextNode(this.nodeValue)}return null},replaces:function(a){a=$(a,true);a.parentNode.replaceChild(this,a);return this},hasClass:function(a){return this.className.contains(a," ")},addClass:function(a){if(!this.hasClass(a)){this.className=(this.className+" "+a).clean()}return this},removeClass:function(a){this.className=this.className.replace(new RegExp("(^|\\s)"+a+"(?:\\s|$)"),"$1").clean();return this},toggleClass:function(a){return this.hasClass(a)?this.removeClass(a):this.addClass(a)},getComputedStyle:function(b){if(this.currentStyle){return this.currentStyle[b.camelCase()]}var a=this.getWindow().getComputedStyle(this,null);return(a)?a.getPropertyValue([b.hyphenate()]):null},empty:function(){$A(this.childNodes).each(function(a){Browser.freeMem(a);Element.empty(a);Element.dispose(a)},this);return this},destroy:function(){Browser.freeMem(this.empty().dispose());return null},getSelected:function(){return new Elements($A(this.options).filter(function(a){return a.selected}))},toQueryString:function(){var a=[];this.getElements("input, select, textarea").each(function(c){if(!c.name||c.disabled){return}var b=(c.tagName.toLowerCase()=="select")?Element.getSelected(c).map(function(d){return d.value}):((c.type=="radio"||c.type=="checkbox")&&!c.checked)?null:c.value;$splat(b).each(function(d){if(d){a.push(c.name+"="+encodeURIComponent(d))}})});return a.join("&")},getProperty:function(c){var d=Element.Attributes,a=d.Props[c];var b=(a)?this[a]:this.getAttribute(c,2);return(d.Bools[c])?!!b:(a)?b:b||null},getProperties:function(){var a=$A(arguments);return a.map(function(b){return this.getProperty(b)},this).associate(a)},setProperty:function(c,b){var d=Element.Attributes,e=d.Props[c],a=$defined(b);if(e&&d.Bools[c]){b=(b||!a)?true:false}else{if(!a){return this.removeProperty(c)}}(e)?this[e]=b:this.setAttribute(c,b);return this},setProperties:function(a){for(var b in a){this.setProperty(b,a[b])}return this},removeProperty:function(b){var c=Element.Attributes,d=c.Props[b],a=(d&&c.Bools[b]);(d)?this[d]=(a)?false:"":this.removeAttribute(b);return this},removeProperties:function(){Array.each(arguments,this.removeProperty,this);return this}});(function(){var a=function(g,i,b,h,e,c){var f=g[b||i];var d=[];while(f){if(f.nodeType==1&&(!h||Element.match(f,h))){d.push(f);if(!e){break}}f=f[i]}return(e)?new Elements(d,{ddup:false,cash:!c}):$(d[0],c)};Element.implement({getPrevious:function(c,b){return a(this,"previousSibling",null,c,false,b)},getAllPrevious:function(c,b){return a(this,"previousSibling",null,c,true,b)},getNext:function(c,b){return a(this,"nextSibling",null,c,false,b)},getAllNext:function(c,b){return a(this,"nextSibling",null,c,true,b)},getFirst:function(c,b){return a(this,"nextSibling","firstChild",c,false,b)},getLast:function(c,b){return a(this,"previousSibling","lastChild",c,false,b)},getParent:function(c,b){return a(this,"parentNode",null,c,false,b)},getParents:function(c,b){return a(this,"parentNode",null,c,true,b)},getChildren:function(c,b){return a(this,"nextSibling","firstChild",c,true,b)},hasChild:function(b){b=$(b,true);return(!!b&&$A(this.getElementsByTagName(b.tagName)).contains(b))}})})();Element.Properties=new Hash;Element.Properties.style={set:function(a){this.style.cssText=a},get:function(){return this.style.cssText},erase:function(){this.style.cssText=""}};Element.Properties.tag={get:function(){return this.tagName.toLowerCase()}};Element.Properties.href={get:function(){return(!this.href)?null:this.href.replace(new RegExp("^"+document.location.protocol+"//"+document.location.host),"")}};Element.Properties.html={set:function(){return this.innerHTML=Array.flatten(arguments).join("")}};Native.implement([Element,Window,Document],{addListener:function(b,a){if(this.addEventListener){this.addEventListener(b,a,false)}else{this.attachEvent("on"+b,a)}return this},removeListener:function(b,a){if(this.removeEventListener){this.removeEventListener(b,a,false)}else{this.detachEvent("on"+b,a)}return this},retrieve:function(d,a){var b=Element.Storage.get(this.uid);var c=b[d];if($defined(a)&&!$defined(c)){c=b[d]=a}return $pick(c)},store:function(c,a){var b=Element.Storage.get(this.uid);b[c]=a;return this},eliminate:function(a){var b=Element.Storage.get(this.uid);delete b[a];return this}});Element.Attributes=new Hash({Props:{html:"innerHTML","class":"className","for":"htmlFor",text:(Browser.Engine.trident)?"innerText":"textContent"},Bools:["compact","nowrap","ismap","declare","noshade","checked","disabled","readonly","multiple","selected","noresize","defer"],Camels:["value","accessKey","cellPadding","cellSpacing","colSpan","frameBorder","maxLength","readOnly","rowSpan","tabIndex","useMap"]});Browser.freeMem=function(a){if(!a){return}if(Browser.Engine.trident&&(/object/i).test(a.tagName)){for(var b in a){if(typeof a[b]=="function"){a[b]=$empty}}Element.dispose(a)}if(a.uid&&a.removeEvents){a.removeEvents()}};(function(c){var b=c.Bools,a=c.Camels;c.Bools=b=b.associate(b);Hash.extend(Hash.combine(c.Props,b),a.associate(a.map(function(d){return d.toLowerCase()})));c.erase("Camels")})(Element.Attributes);window.addListener("unload",function(){window.removeListener("unload",arguments.callee);document.purge();if(Browser.Engine.trident){CollectGarbage()}});Element.Properties.events={set:function(a){this.addEvents(a)}};Native.implement([Element,Window,Document],{addEvent:function(i,g){var f=this.retrieve("events",{});f[i]=f[i]||{keys:[],values:[]};if(f[i].keys.contains(g)){return this}f[i].keys.push(g);var h=i,d=Element.Events.get(i),b=g,e=this;if(d){if(d.onAdd){d.onAdd.call(this,g)}if(d.condition){b=function(j){if(d.condition.call(this,j)){return g.call(this,j)}return false}}h=d.base||h}var a=function(){return g.call(e)};var c=Element.NativeEvents[h]||0;if(c){if(c==2){a=function(j){j=new Event(j,e.getWindow());if(b.call(e,j)===false){j.stop()}}}this.addListener(h,a)}f[i].values.push(a);return this},removeEvent:function(e,f){var g=this.retrieve("events");if(!g||!g[e]){return this}var b=g[e].keys.indexOf(f);if(b==-1){return this}var a=g[e].keys.splice(b,1)[0];var c=g[e].values.splice(b,1)[0];var d=Element.Events.get(e);if(d){if(d.onRemove){d.onRemove.call(this,f)}e=d.base||e}return(Element.NativeEvents[e])?this.removeListener(e,c):this},addEvents:function(a){for(var b in a){this.addEvent(b,a[b])}return this},removeEvents:function(c){var a=this.retrieve("events");if(!a){return this}if(!c){for(var b in a){this.removeEvents(b)}a=null}else{if(a[c]){while(a[c].keys[0]){this.removeEvent(c,a[c].keys[0])}a[c]=null}}return this},fireEvent:function(b,d,a){var c=this.retrieve("events");if(!c||!c[b]){return this}c[b].keys.each(function(e){e.create({bind:this,delay:a,"arguments":d})()},this);return this},cloneEvents:function(b,a){b=$(b);var c=b.retrieve("events");if(!c){return this}if(!a){for(var d in c){this.cloneEvents(b,d)}}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(c){var b=c.relatedTarget;if(b==undefined){return true}if(b===false){return false}return($type(this)!="document"&&b!=this&&b.prefix!="xul"&&!this.hasChild(b))};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(c,a){switch(c){case"opacity":return this.set("opacity",parseFloat(a));case"float":c=(Browser.Engine.trident)?"styleFloat":"cssFloat"}c=c.camelCase();if($type(a)!="string"){var b=(Element.Styles.get(c)||"@").split(" ");a=$splat(a).map(function(d,e){if(!b[e]){return""}return($type(d)=="number")?b[e].replace("@",Math.round(d)):d}).join(" ")}else{if(a==String(Number(a))){a=Math.round(a)}}this.style[c]=a;return this},getStyle:function(b){switch(b){case"opacity":return this.get("opacity");case"float":b=(Browser.Engine.trident)?"styleFloat":"cssFloat"}b=b.camelCase();var a=this.style[b];if(!$chk(a)){a=[];for(var c in Element.ShortStyles){if(b!=c){continue}for(var d in Element.ShortStyles[c]){a.push(this.getStyle(d))}return a.join(" ")}a=this.getComputedStyle(b)}if(a){a=String(a);var f=a.match(/rgba?\([\d\s,]+\)/);if(f){a=a.replace(f[0],f[0].rgbToHex())}}if(Browser.Engine.presto||(Browser.Engine.trident&&!$chk(parseInt(a)))){if(b.test(/^(height|width)$/)){var g=(b=="width")?["left","right"]:["top","bottom"],e=0;g.each(function(h){e+=this.getStyle("border-"+h+"-width").toInt()+this.getStyle("padding-"+h).toInt()},this);return this["offset"+b.capitalize()]-e+"px"}if(Browser.Engine.presto&&String(a).test("px")){return a}if(b.test(/(border(.+)Width|margin|padding)/)){return"0px"}}return a},setStyles:function(b){for(var a in b){this.setStyle(a,b[a])}return this},getStyles:function(){var a={};Array.each(arguments,function(b){a[b]=this.getStyle(b)},this);return a}});Element.Styles=new Hash({left:"@px",top:"@px",bottom:"@px",right:"@px",width:"@px",height:"@px",maxWidth:"@px",maxHeight:"@px",minWidth:"@px",minHeight:"@px",backgroundColor:"rgb(@, @, @)",backgroundPosition:"@px @px",color:"rgb(@, @, @)",fontSize:"@px",letterSpacing:"@px",lineHeight:"@px",clip:"rect(@px @px @px @px)",margin:"@px @px @px @px",padding:"@px @px @px @px",border:"@px @ rgb(@, @, @) @px @ rgb(@, @, @) @px @ rgb(@, @, @)",borderWidth:"@px @px @px @px",borderStyle:"@ @ @ @",borderColor:"rgb(@, @, @) rgb(@, @, @) rgb(@, @, @) rgb(@, @, @)",zIndex:"@",zoom:"@",fontWeight:"@",textIndent:"@px",opacity:"@"});Element.ShortStyles={margin:{},padding:{},border:{},borderWidth:{},borderStyle:{},borderColor:{}};["Top","Right","Bottom","Left"].each(function(b){var c=Element.ShortStyles;var g=Element.Styles;["margin","padding"].each(function(i){var h=i+b;c[i][h]=g[h]="@px"});var d="border"+b;c.border[d]=g[d]="@px @ rgb(@, @, @)";var e=d+"Width",a=d+"Style",f=d+"Color";c[d]={};c.borderWidth[e]=c[d][e]=g[e]="@px";c.borderStyle[a]=c[d][a]=g[a]="@";c.borderColor[f]=c[d][f]=g[f]="rgb(@, @, @)"});(function(){Element.implement({scrollTo:function(i,h){if(g(this)){this.getWindow().scrollTo(i,h)}else{this.scrollLeft=i;this.scrollTop=h}return this},getSize:function(){if(g(this)){return this.getWindow().getSize()}return{x:this.offsetWidth,y:this.offsetHeight}},getScrollSize:function(){if(g(this)){return this.getWindow().getScrollSize()}return{x:this.scrollWidth,y:this.scrollHeight}},getScroll:function(){if(g(this)){return this.getWindow().getScroll()}return{x:this.scrollLeft,y:this.scrollTop}},getScrolls:function(){var h=this,i={x:0,y:0};while(h&&!g(h)){i.x+=h.scrollLeft;i.y+=h.scrollTop;h=h.parentNode}return i},getOffsetParent:function(){var h=this;if(g(h)){return null}if(!Browser.Engine.trident){return h.offsetParent}while((h=h.parentNode)&&!g(h)){if(e(h,"position")!="static"){return h}}return null},getOffsets:function(){var i=this,j={x:0,y:0};if(g(this)){return j}while(i&&!g(i)){j.x+=i.offsetLeft;j.y+=i.offsetTop;if(Browser.Engine.gecko){if(!c(i)){j.x+=f(i);j.y+=b(i)}var h=i.parentNode;if(h&&e(h,"overflow")!="visible"){j.x+=f(h);j.y+=b(h)}}else{if(i!=this&&(Browser.Engine.trident||Browser.Engine.webkit)){j.x+=f(i);j.y+=b(i)}}i=i.offsetParent;if(Browser.Engine.trident){while(i&&!i.currentStyle.hasLayout){i=i.offsetParent}}}if(Browser.Engine.gecko&&!c(this)){j.x-=f(this);j.y-=b(this)}return j},getPosition:function(i){if(g(this)){return{x:0,y:0}}var h=this.getOffsets(),k=this.getScrolls();var l={x:h.x-k.x,y:h.y-k.y};var j=(i&&(i=$(i)))?i.getPosition():{x:0,y:0};return{x:l.x-j.x,y:l.y-j.y}},getCoordinates:function(i){if(g(this)){return this.getWindow().getCoordinates()}var k=this.getPosition(i),j=this.getSize();var h={left:k.x,top:k.y,width:j.x,height:j.y};h.right=h.left+h.width;h.bottom=h.top+h.height;return h},computePosition:function(h){return{left:h.x-d(this,"margin-left"),top:h.y-d(this,"margin-top")}},position:function(h){return this.setStyles(this.computePosition(h))}});Native.implement([Document,Window],{getSize:function(){var h=this.getWindow();if(Browser.Engine.presto||Browser.Engine.webkit){return{x:h.innerWidth,y:h.innerHeight}}var i=a(this);return{x:i.clientWidth,y:i.clientHeight}},getScroll:function(){var h=this.getWindow();var i=a(this);return{x:h.pageXOffset||i.scrollLeft,y:h.pageYOffset||i.scrollTop}},getScrollSize:function(){var h=a(this);var i=this.getSize();return{x:Math.max(h.scrollWidth,i.x),y:Math.max(h.scrollHeight,i.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 e=Element.getComputedStyle;function d(i,h){return e(i,h).toInt()||0}function c(h){return e(h,"-moz-box-sizing")=="border-box"}function b(h){return d(h,"border-top-width")}function f(h){return d(h,"border-left-width")}function g(h){return(/^(?:body|html)$/i).test(h.tagName)}function a(i){var h=i.getDocument();return(!h.compatMode||h.compatMode=="CSS1Compat")?h.html:h.body}})();Native.implement([Window,Document,Element],{getHeight:function(){return this.getSize().y},getWidth:function(){return this.getSize().x},getScrollTop:function(){return this.getScroll().y},getScrollLeft:function(){return this.getScroll().x},getScrollHeight:function(){return this.getScrollSize().y},getScrollWidth:function(){return this.getScrollSize().x},getTop:function(){return this.getPosition().y},getLeft:function(){return this.getPosition().x}});Native.implement([Document,Element],{getElements:function(b,c){b=b.split(",");var g,e={};for(var f=0,h=b.length;f<h;f++){var a=b[f],d=Selectors.Utils.search(this,a,e);if(f!=0&&d.item){d=$A(d)}g=(f==0)?d:(g.item)?$A(g).concat(d):g.concat(d)}return new Elements(g,{ddup:(b.length>1),cash:!c})}});Element.implement({match:function(e){if(!e){return true}var c=Selectors.Utils.parseTagAndID(e);var a=c[0],b=c[1];if(!Selectors.Filters.byID(this,b)||!Selectors.Filters.byTag(this,a)){return false}var d=Selectors.Utils.parseSelector(e);return(d)?Selectors.Utils.filter(this,d,{}):true}});var Selectors={Cache:{nth:{},parsed:{}}};Selectors.RegExps={id:(/#([\w-]+)/),tag:(/^(\w+|\*)/),quick:(/^(\w+|\*)$/),splitter:(/\s*([+>~\s])\s*([a-zA-Z#.*:\[])/g),combined:(/\.([\w-]+)|\[(\w+)(?:([!*^$~|]?=)["']?(.*?)["']?)?\]|:([\w-]+)(?:\(["']?(.*?)?["']?\)|$)/g)};Selectors.Utils={chk:function(c,b){if(!b){return true}var a=$uid(c);if(!b[a]){return b[a]=true}return false},parseNthArgument:function(b){if(Selectors.Cache.nth[b]){return Selectors.Cache.nth[b]}var e=b.match(/^([+-]?\d*)?([a-z]+)?([+-]?\d*)?$/);if(!e){return false}var c=parseInt(e[1]);var f=(c||c===0)?c:1;var d=e[2]||false;var a=parseInt(e[3])||0;if(f!=0){a--;while(a<1){a+=f}while(a>=f){a-=f}}else{f=a;d="index"}switch(d){case"n":e={a:f,b:a,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:(f-1),special:"index"}}return Selectors.Cache.nth[b]=e},parseSelector:function(j){if(Selectors.Cache.parsed[j]){return Selectors.Cache.parsed[j]}var a,g={classes:[],pseudos:[],attributes:[]};while((a=Selectors.RegExps.combined.exec(j))){var f=a[1],h=a[2],i=a[3],c=a[4],b=a[5],e=a[6];if(f){g.classes.push(f)}else{if(b){var d=Selectors.Pseudo.get(b);if(d){g.pseudos.push({parser:d,argument:e})}else{g.attributes.push({name:b,operator:"=",value:e})}}else{if(h){g.attributes.push({name:h,operator:i,value:c})}}}}if(!g.classes.length){delete g.classes}if(!g.attributes.length){delete g.attributes}if(!g.pseudos.length){delete g.pseudos}if(!g.classes&&!g.attributes&&!g.pseudos){g=null}return Selectors.Cache.parsed[j]=g},parseTagAndID:function(c){var a=c.match(Selectors.RegExps.tag);var b=c.match(Selectors.RegExps.id);return[(a)?a[1]:"*",(b)?b[1]:false]},filter:function(c,f,d){var e;if(f.classes){for(e=f.classes.length;e--;e){var b=f.classes[e];if(!Selectors.Filters.byClass(c,b)){return false}}}if(f.attributes){for(e=f.attributes.length;e--;e){var g=f.attributes[e];if(!Selectors.Filters.byAttribute(c,g.name,g.operator,g.value)){return false}}}if(f.pseudos){for(e=f.pseudos.length;e--;e){var a=f.pseudos[e];if(!Selectors.Filters.byPseudo(c,a.parser,a.argument,d)){return false}}}return true},getByTagAndID:function(d,a,b){if(b){var c=(d.getElementById)?d.getElementById(b,true):Element.getElementById(d,b,true);return(c&&Selectors.Filters.byTag(c,a))?[c]:[]}else{return d.getElementsByTagName(a)}},search:function(n,o,i){var v=[];var u=o.trim().replace(Selectors.RegExps.splitter,function(x,y,z){v.push(y);return":)"+z}).split(":)");var m,r,s,b;for(var c=0,g=u.length;c<g;c++){var d=u[c];if(c==0&&Selectors.RegExps.quick.test(d)){m=n.getElementsByTagName(d);continue}var w=v[c-1];var l=Selectors.Utils.parseTagAndID(d);var a=l[0],k=l[1];if(c==0){m=Selectors.Utils.getByTagAndID(n,a,k)}else{var t={},p=[];for(var e=0,f=m.length;e<f;e++){p=Selectors.Getters[w](p,m[e],a,k,t)}m=p}var q=Selectors.Utils.parseSelector(d);if(q){s=[];for(var h=0,j=m.length;h<j;h++){b=m[h];if(Selectors.Utils.filter(b,q,i)){s.push(b)}}m=s}}return m}};Selectors.Getters={" ":function(f,g,e,d,i){var a=Selectors.Utils.getByTagAndID(g,e,d);for(var b=0,c=a.length;b<c;b++){var h=a[b];if(Selectors.Utils.chk(h,i)){f.push(h)}}return f},">":function(f,g,e,d,h){var b=Selectors.Utils.getByTagAndID(g,e,d);for(var i=0,a=b.length;i<a;i++){var c=b[i];if(c.parentNode==g&&Selectors.Utils.chk(c,h)){f.push(c)}}return f},"+":function(d,e,a,b,c){while((e=e.nextSibling)){if(e.nodeType==1){if(Selectors.Utils.chk(e,c)&&Selectors.Filters.byTag(e,a)&&Selectors.Filters.byID(e,b)){d.push(e)}break}}return d},"~":function(d,e,a,b,c){while((e=e.nextSibling)){if(e.nodeType==1){if(!Selectors.Utils.chk(e,c)){break}if(Selectors.Filters.byTag(e,a)&&Selectors.Filters.byID(e,b)){d.push(e)}}}return d}};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,b,c,d){return b.call(a,c,d)},byAttribute:function(d,c,e,b){var a=Element.prototype.getProperty.call(d,c);if(!a){return false}if(!e||b==undefined){return true}switch(e){case"=":return(a==b);case"*=":return(a.contains(b));case"^=":return(a.substr(0,b.length)==b);case"$=":return(a.substr(a.length-b.length)==b);case"!=":return(a!=b);case"~=":return a.contains(b," ");case"|=":return a.contains(b,"-")}return false}};Selectors.Pseudo=new Hash({empty:function(){return !(this.innerText||this.textContent||"").length},not:function(a){return !Element.match(this,a)},contains:function(a){return(this.innerText||this.textContent||"").contains(a)},"first-child":function(){return Selectors.Pseudo.index.call(this,0)},"last-child":function(){var a=this;while((a=a.nextSibling)){if(a.nodeType==1){return false}}return true},"only-child":function(){var b=this;while((b=b.previousSibling)){if(b.nodeType==1){return false}}var a=this;while((a=a.nextSibling)){if(a.nodeType==1){return false}}return true},"nth-child":function(b,d){b=(b==undefined)?"n":b;var f=Selectors.Utils.parseNthArgument(b);if(f.special!="n"){return Selectors.Pseudo[f.special].call(this,f.a,d)}var c=0;d.positions=d.positions||{};var e=$uid(this);if(!d.positions[e]){var g=this;while((g=g.previousSibling)){if(g.nodeType!=1){continue}c++;var a=d.positions[$uid(g)];if(a!=undefined){c=a+c;break}}d.positions[e]=c}return(d.positions[e]%f.a==f.b)},index:function(a){var c=this,b=0;while((c=c.previousSibling)){if(c.nodeType==1&&++b>a){return false}}return(b==a)},even:function(b,a){return Selectors.Pseudo["nth-child"].call(this,"2n+1",a)},odd:function(b,a){return Selectors.Pseudo["nth-child"].call(this,"2n",a)}});Element.Events.domready={onAdd:function(a){if(Browser.loaded){a.call(this)}}};(function(){var b=function(){if(Browser.loaded){return}Browser.loaded=true;window.fireEvent("domready");document.fireEvent("domready")};switch(Browser.Engine.name){case"webkit":(function(){(["loaded","complete"].contains(document.readyState))?b():arguments.callee.delay(50)})();break;case"trident":var a=document.createElement("div");(function(){($try(function(){a.doScroll("left");return $(a).inject(document.body).set("html","temp").dispose()}))?b():arguments.callee.delay(50)})();break;default:window.addEvent("load",b);document.addEvent("DOMContentLoaded",b)}})();var JSON=new Hash({encode:function(b){switch($type(b)){case"string":return'"'+b.replace(/[\x00-\x1f\\"]/g,JSON.$replaceChars)+'"';case"array":return"["+String(b.map(JSON.encode).filter($defined))+"]";case"object":case"hash":var a=[];Hash.each(b,function(c,d){var e=JSON.encode(c);if(e){a.push(JSON.encode(d)+":"+e)}});return"{"+a+"}";case"number":case"boolean":return String(b);case false:return"null"}return null},$specialChars:{"\b":"\\b","\t":"\\t","\n":"\\n","\f":"\\f","\r":"\\r",'"':'\\"',"\\":"\\\\"},$replaceChars:function(a){return JSON.$specialChars[a]||"\\u00"+Math.floor(a.charCodeAt()/16).toString(16)+(a.charCodeAt()%16).toString(16)},decode:function(string,secure){if($type(string)!="string"||!string.length){return null}if(secure&&!(/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(string.replace(/\\./g,"@").replace(/"[^"\\\n\r]*"/g,""))){return null}return eval("("+string+")")}});Native.implement([Hash,Array,String,Number],{toJSON:function(){return JSON.encode(this)}});var Cookie=new Class({Implements:Options,options:{path:false,domain:false,duration:false,secure:false,document:document},initialize:function(b,a){this.key=b;this.setOptions(a)},write:function(b){b=encodeURIComponent(b);if(this.options.domain){b+="; domain="+this.options.domain}if(this.options.path){b+="; path="+this.options.path}if(this.options.duration){var a=new Date();a.setTime(a.getTime()+this.options.duration*24*60*60*1000);b+="; expires="+a.toGMTString()}if(this.options.secure){b+="; secure"}this.options.document.cookie=this.key+"="+b;return this},read:function(){var a=this.options.document.cookie.match("(?:^|;)\\s*"+this.key.escapeRegExp()+"=([^;]*)");return(a)?decodeURIComponent(a[1]):null},dispose:function(){new Cookie(this.key,$merge(this.options,{duration:-1})).write("");return this}});Cookie.write=function(c,b,a){return new Cookie(c,a).write(b)};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(f,e){this.instance="Swiff_"+$time();this.setOptions(e);e=this.options;var c=this.id=e.id||this.instance;var d=$(e.container);Swiff.CallBacks[this.instance]={};var m=e.params,k=e.vars,l=e.callBacks;var j=$extend({height:e.height,width:e.width},e.properties);var g=this;for(var a in l){Swiff.CallBacks[this.instance][a]=(function(n){return function(){return n.apply(g.object,arguments)}})(l[a]);k[a]="Swiff.CallBacks."+this.instance+"."+a}m.flashVars=Hash.toQueryString(k);if(Browser.Engine.trident){j.classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000";m.movie=f}else{j.type="application/x-shockwave-flash";j.data=f}var h='<object id="'+c+'"';for(var i in j){h+=" "+i+'="'+j[i]+'"'}h+=">";for(var b in m){if(m[b]){h+='<param name="'+b+'" value="'+m[b]+'" />'}}h+="</object>";this.object=((d)?d.empty():new Element("div")).set("html",h).firstChild},replaces:function(a){a=$(a,true);a.parentNode.replaceChild(this.toElement(),a);return this},inject:function(a){$(a,true).appendChild(this.toElement());return this},remote:function(){return Swiff.remote.apply(Swiff,[this.toElement()].extend(arguments))}});Swiff.CallBacks={};Swiff.remote=function(obj,fn){var rs=obj.CallFunction('<invoke name="'+fn+'" returntype="javascript">'+__flash__argumentsToXML(arguments,2)+"</invoke>");return eval(rs)};var Fx=new Class({Implements:[Chain,Events,Options],options:{fps:50,unit:false,duration:500,link:"ignore",transition:function(a){return -(Math.cos(Math.PI*a)-1)/2}},initialize:function(a){this.subject=this.subject||this;this.setOptions(a);this.options.duration=Fx.Durations[this.options.duration]||this.options.duration.toInt();var b=this.options.wait;if(b===false){this.options.link="cancel"}},step:function(){var a=$time();if(a<this.time+this.options.duration){var b=this.options.transition((a-this.time)/this.options.duration);this.set(this.compute(this.from,this.to,b))}else{this.set(this.compute(this.from,this.to,1));this.complete()}},set:function(a){return a},compute:function(b,c,a){return Fx.compute(b,c,a)},check:function(a){if(!this.timer){return true}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(a.bind(this,Array.slice(arguments,1)));return false}return false},start:function(b,a){if(!this.check(arguments.callee,b,a)){return this}this.from=b;this.to=a;this.time=0;this.startTimer();this.onStart();return this},complete:function(){if(this.stopTimer()){this.onComplete()}return this},cancel:function(){if(this.stopTimer()){this.onCancel()}return this},onStart:function(){this.fireEvent("start",this.subject)},onComplete:function(){this.fireEvent("complete",this.subject);if(!this.callChain()){this.fireEvent("chainComplete",this.subject)}},onCancel:function(){this.fireEvent("cancel",this.subject).clearChain()},pause:function(){this.stopTimer();return this},resume:function(){this.startTimer();return this},stopTimer:function(){if(!this.timer){return false}this.time=$time()-this.time;this.timer=$clear(this.timer);return true},startTimer:function(){if(this.timer){return false}this.time=$time()-this.time;this.timer=this.step.periodical(Math.round(1000/this.options.fps),this);return true}});Fx.compute=function(b,c,a){return(c-b)*a+b};Fx.Durations={"short":250,normal:500,"long":1000};Fx.CSS=new Class({Extends:Fx,prepare:function(c,b,e){e=$splat(e);var d=e[1];if(!$chk(d)){e[1]=e[0];e[0]=c.getStyle(b)}var a=e.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(b){b=String(b);var c=false;Fx.CSS.Parsers.each(function(d,e){if(c){return}var f=d.parse(b);if($chk(f)){c={value:f,parser:d}}});c=c||{value:b,parser:Fx.CSS.Parsers.String};return c})},compute:function(b,c,d){var a=[];(Math.min(b.length,c.length)).times(function(e){a.push({value:b[e].parser.compute(b[e].value,c[e].value,d),parser:b[e].parser})});a.$family={name:"fx:css:value"};return a},serve:function(b,c){if($type(b)!="fx:css:value"){b=this.parse(b)}var a=[];b.each(function(d){a=a.concat(d.parser.serve(d.value,c))});return a},render:function(a,b,c,d){a.setStyle(b,this.serve(c,d))},search:function(a){if(Fx.CSS.Cache[a]){return Fx.CSS.Cache[a]}var b={};Array.each(document.styleSheets,function(d,e){var f=d.href;if(f&&f.contains("://")&&!f.contains(document.domain)){return}var c=d.rules||d.cssRules;Array.each(c,function(g,i){if(!g.style){return}var h=(g.selectorText)?g.selectorText.replace(/^\w+/,function(j){return j.toLowerCase()}):null;if(!h||!h.test("^"+a+"$")){return}Element.Styles.each(function(j,k){if(!g.style[k]||Element.ShortStyles[k]){return}j=String(g.style[k]);b[k]=(j.test(/^rgb/))?j.rgbToHex():j})})});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(b,c,a){return b.map(function(d,e){return Math.round(Fx.compute(b[e],c[e],a))})},serve:function(a){return a.map(Number)}},Number:{parse:parseFloat,compute:Fx.compute,serve:function(b,a){return(a)?b+a:b}},String:{parse:$lambda(false),compute:$arguments(1),serve:$arguments(0)}});Fx.Tween=new Class({Extends:Fx.CSS,initialize:function(b,a){this.element=this.subject=$(b);this.parent(a)},set:function(b,a){if(arguments.length==1){a=b;b=this.property||this.options.property}this.render(this.element,b,a,this.options.unit);return this},start:function(d,b,c){if(!this.check(arguments.callee,d,b,c)){return this}var e=Array.flatten(arguments);this.property=this.options.property||e.shift();var a=this.prepare(this.element,this.property,e);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,b,c){this.get("tween").start(arguments);return this},fade:function(d){var b=this.get("tween"),c="opacity",a;d=$pick(d,"toggle");switch(d){case"in":b.start(c,1);break;case"out":b.start(c,0);break;case"show":b.set(c,1);break;case"hide":b.set(c,0);break;case"toggle":var e=this.retrieve("fade:flag",this.get("opacity")==1);b.start(c,(e)?0:1);this.store("fade:flag",!e);a=true;break;default:b.start(c,arguments)}if(!a){this.eliminate("fade:flag")}return this},highlight:function(b,a){if(!a){a=this.retrieve("highlight:original",this.getStyle("background-color"));a=(a=="transparent")?"#fff":a}var c=this.get("tween");c.start("background-color",b||"#ffff88",a).chain(function(){this.setStyle("background-color",this.retrieve("highlight:original"));c.callChain()}.bind(this));return this}});Fx.Morph=new Class({Extends:Fx.CSS,initialize:function(b,a){this.element=this.subject=$(b);this.parent(a)},set:function(a){if(typeof a=="string"){a=this.search(a)}for(var b in a){this.render(this.element,b,a[b],this.options.unit)}return this},compute:function(b,c,d){var a={};for(var e in b){a[e]=this.parent(b[e],c[e],d)}return a},start:function(e){if(!this.check(arguments.callee,e)){return this}if(typeof e=="string"){e=this.search(e)}var b={},c={};for(var d in e){var a=this.prepare(this.element,d,e[d]);b[d]=a.from;c[d]=a.to}return this.parent(b,c)}});Element.Properties.morph={set:function(a){var b=this.retrieve("morph");if(b){b.cancel()}return this.eliminate("morph").store("morph:options",$extend({link:"cancel"},a))},get:function(a){if(a||!this.retrieve("morph")){if(a||!this.retrieve("morph:options")){this.set("morph",a)}this.store("morph",new Fx.Morph(this,this.retrieve("morph:options")))}return this.retrieve("morph")}};Element.implement({morph:function(a){this.get("morph").start(a);return this}});(function(){var a=Fx.prototype.initialize;Fx.prototype.initialize=function(d){a.call(this,d);var c=this.options.transition;if(typeof c=="string"&&(c=c.split(":"))){var b=Fx.Transitions;b=b[c[0]]||b[c[0].capitalize()];if(c[1]){b=b["ease"+c[1].capitalize()+(c[2]?c[2].capitalize():"")]}this.options.transition=b}}})();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(b){var c;for(var d=0,a=1;1;d+=a,a/=2){if(b>=(7-4*d)/11){c=-Math.pow((11-6*d-11*b)/4,2)+a*a;break}}return c},Elastic:function(b,a){return Math.pow(2,10*--b)*Math.cos(20*b*Math.PI*(a[0]||1)/3)}});["Quad","Cubic","Quart","Quint"].each(function(b,a){Fx.Transitions[b]=new Fx.Transition(function(c){return Math.pow(c,[a+2])})});var Request=new Class({Implements:[Chain,Events,Options],options:{url:"",data:"",headers:{"X-Requested-With":"XMLHttpRequest",Accept:"text/javascript, text/html, application/xml, text/xml, */*"},async:true,format:false,method:"post",link:"ignore",isSuccess:null,emulation:true,urlEncoded:true,encoding:"utf-8",evalScripts:false,evalResponse:false},initialize:function(a){this.xhr=new Browser.Request();this.setOptions(a);this.options.isSuccess=this.options.isSuccess||this.isSuccess;this.headers=new Hash(this.options.headers)},onStateChange:function(){if(this.xhr.readyState!=4||!this.running){return}this.running=false;this.status=0;$try(function(){this.status=this.xhr.status}.bind(this));if(this.options.isSuccess.call(this,this.status)){this.response={text:this.xhr.responseText,xml:this.xhr.responseXML};this.success(this.response.text,this.response.xml)}else{this.response={text:null,xml:null};this.failure()}this.xhr.onreadystatechange=$empty},isSuccess:function(){return((this.status>=200)&&(this.status<300))},processScripts:function(a){if(this.options.evalResponse||(/(ecma|java)script/).test(this.getHeader("Content-type"))){return $exec(a)}return a.stripScripts(this.options.evalScripts)},success:function(b,a){this.onSuccess(this.processScripts(b),a)},onSuccess:function(){this.fireEvent("complete",arguments).fireEvent("success",arguments).callChain()},failure:function(){this.onFailure()},onFailure:function(){this.fireEvent("complete").fireEvent("failure",this.xhr)},setHeader:function(a,b){this.headers.set(a,b);return this},getHeader:function(a){return $try(function(){return this.xhr.getResponseHeader(a)}.bind(this))},check:function(a){if(!this.running){return true}switch(this.options.link){case"cancel":this.cancel();return true;case"chain":this.chain(a.bind(this,Array.slice(arguments,1)));return false}return false},send:function(e){if(!this.check(arguments.callee,e)){return this}this.running=true;var g=$type(e);if(g=="string"||g=="element"){e={data:e}}var a=this.options;e=$extend({data:a.data,url:a.url,method:a.method},e);var i=e.data,c=e.url,d=e.method;switch($type(i)){case"element":i=$(i).toQueryString();break;case"object":case"hash":i=Hash.toQueryString(i)}if(this.options.format){var f="format="+this.options.format;i=(i)?f+"&"+i:f}if(this.options.emulation&&["put","delete"].contains(d)){var h="_method="+d;i=(i)?h+"&"+i:h;d="post"}if(this.options.urlEncoded&&d=="post"){var b=(this.options.encoding)?"; charset="+this.options.encoding:"";this.headers.set("Content-type","application/x-www-form-urlencoded"+b)}if(i&&d=="get"){c=c+(c.contains("?")?"&":"?")+i;i=null}this.xhr.open(d.toUpperCase(),c,this.options.async);this.xhr.onreadystatechange=this.onStateChange.bind(this);this.headers.each(function(j,k){if(!$try(function(){this.xhr.setRequestHeader(k,j);return true}.bind(this))){this.fireEvent("exception",[k,j])}},this);this.fireEvent("request");this.xhr.send(i);if(!this.options.async){this.onStateChange()}return this},cancel:function(){if(!this.running){return this}this.running=false;this.xhr.abort();this.xhr.onreadystatechange=$empty;this.xhr=new Browser.Request();this.fireEvent("cancel");return this}});(function(){var a={};["get","post","put","delete","GET","POST","PUT","DELETE"].each(function(b){a[b]=function(){var c=Array.link(arguments,{url:String.type,data:$defined});return this.send($extend(c,{method:b.toLowerCase()}))}});Request.implement(a)})();Element.Properties.send={set:function(a){var b=this.retrieve("send");if(b){b.cancel()}return this.eliminate("send").store("send:options",$extend({data:this,link:"cancel",method:this.get("method")||"post",url:this.get("action")},a))},get:function(a){if(a||!this.retrieve("send")){if(a||!this.retrieve("send:options")){this.set("send",a)}this.store("send",new Request(this.retrieve("send:options")))}return this.retrieve("send")}};Element.implement({send:function(a){var b=this.get("send");b.send({data:this,url:a||b.options.url});return this}});Request.HTML=new Class({Extends:Request,options:{update:false,evalScripts:true,filter:false},processHTML:function(b){var c=b.match(/<body[^>]*>([\s\S]*?)<\/body>/i);b=(c)?c[1]:b;var a=new Element("div");return $try(function(){var h="<root>"+b+"</root>",e;if(Browser.Engine.trident){e=new ActiveXObject("Microsoft.XMLDOM");e.async=false;e.loadXML(h)}else{e=new DOMParser().parseFromString(h,"text/xml")}h=e.getElementsByTagName("root")[0];for(var f=0,g=h.childNodes.length;f<g;f++){var d=Element.clone(h.childNodes[f],true,true);if(d){a.grab(d)}}return a})||a.set("html",b)},success:function(b){var c=this.options,d=this.response;d.html=b.stripScripts(function(e){d.javascript=e});var a=this.processHTML(d.html);d.tree=a.childNodes;d.elements=a.getElements("*");if(c.filter){d.tree=d.elements.filter(c.filter)}if(c.update){$(c.update).empty().adopt(d.tree)}if(c.evalScripts){$exec(d.javascript)}this.onSuccess(d.tree,d.elements,d.html,d.javascript)}});Element.Properties.load={set:function(a){var b=this.retrieve("load");if(b){send.cancel()}return this.eliminate("load").store("load:options",$extend({data:this,link:"cancel",update:this,method:"get"},a))},get:function(a){if(a||!this.retrieve("load")){if(a||!this.retrieve("load:options")){this.set("load",a)}this.store("load",new Request.HTML(this.retrieve("load:options")))}return this.retrieve("load")}};Element.implement({load:function(){this.get("load").send(Array.link(arguments,{data:Object.type,url:String.type}));return this}});Request.JSON=new Class({Extends:Request,options:{secure:true},initialize:function(a){this.parent(a);this.headers.extend({Accept:"application/json","X-Request":"JSON"})},success:function(a){this.response.json=JSON.decode(a,this.options.secure);this.onSuccess(this.response.json,a)}});Fx.Slide=new Class({Extends:Fx,options:{mode:"vertical"},initialize:function(c,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=$(c);this.parent(a);var b=this.element.retrieve("wrapper");this.wrapper=b||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(b,c,d){var e=[];var a=2;a.times(function(f){e[f]=Fx.compute(b[f],c[f],d)});return e},start:function(g,d){if(!this.check(arguments.callee,g,d)){return this}this[d||this.options.mode]();var e=this.element.getStyle(this.margin).toInt();var f=this.wrapper.getStyle(this.layout).toInt();var a=[[e,f],[0,this.offset]];var b=[[e,f],[-this.offset,0]];var c;switch(g){case"in":c=a;break;case"out":c=b;break;case"toggle":c=(this.wrapper["offset"+this.layout.capitalize()]==0)?a:b}return this.parent(c[0],c[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(c,b){c=c||"toggle";var e=this.get("slide"),a;switch(c){case"hide":e.hide(b);break;case"show":e.show(b);break;case"toggle":var d=this.retrieve("slide:flag",e.open);e[(d)?"slideOut":"slideIn"](b);this.store("slide:flag",!d);a=true;break;default:e.start(c,b)}if(!a){this.eliminate("slide:flag")}return this}});Fx.Scroll=new Class({Extends:Fx,options:{offset:{x:0,y:0},wheelStops:true},initialize:function(d,a){this.element=this.subject=$(d);this.parent(a);var b=this.cancel.bind(this,false);if($type(this.element)!="element"){this.element=$(this.element.getDocument().body)}var c=this.element;if(this.options.wheelStops){this.addEvent("start",function(){c.addEvent("mousewheel",b)},true);this.addEvent("complete",function(){c.removeEvent("mousewheel",b)},true)}},set:function(){var a=Array.flatten(arguments);this.element.scrollTo(a[0],a[1])},compute:function(b,c,d){var e=[];var a=2;a.times(function(f){e.push(Fx.compute(b[f],c[f],d))});return e},start:function(g,b){if(!this.check(arguments.callee,g,b)){return this}var e=this.element.getSize(),d=this.element.getScrollSize();var h=this.element.getScroll(),f={x:g,y:b};for(var c in f){var a=d[c]-e[c];if($chk(f[c])){f[c]=($type(f[c])=="number")?f[c].limit(0,a):a}else{f[c]=h[c]}f[c]+=this.options.offset[c]}return this.parent([h.x,h.y],[f.x,f.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=$(b).getPosition(this.element);return this.start(a.x,a.y)}});Fx.Elements=new Class({Extends:Fx.CSS,initialize:function(b,a){this.elements=this.subject=$$(b);this.parent(a)},compute:function(g,f,e){var b={};for(var a in g){var d=g[a],i=f[a],h=b[a]={};for(var c in d){h[c]=this.parent(d[c],i[c],e)}}return b},set:function(d){for(var c in d){var a=d[c];for(var b in a){this.render(this.elements[c],b,a[b],this.options.unit)}}return this},start:function(b){if(!this.check(arguments.callee,b)){return this}var f={},e={};for(var a in b){var h=b[a],d=f[a]={},g=e[a]={};for(var c in h){var i=this.prepare(this.elements[a],c,h[c]);d[c]=i.from;g[c]=i.to}}return this.parent(f,e)}});var Drag=new Class({Implements:[Events,Options],options:{snap:6,unit:"px",grid:false,style:true,limit:false,handle:false,invert:false,preventDefault:false,modifiers:{x:"left",y:"top"}},initialize:function(){var b=Array.link(arguments,{options:Object.type,element:$defined});this.element=$(b.element);this.document=this.element.getDocument();this.setOptions(b.options||{});var a=$type(this.options.handle);this.handles=(a=="array"||a=="collection")?$$(this.options.handle):$(this.options.handle)||this.element;this.mouse={now:{},pos:{}};this.value={start:{},now:{}};this.selection=(Browser.Engine.trident)?"selectstart":"mousedown";this.bound={start:this.start.bind(this),check:this.check.bind(this),drag:this.drag.bind(this),stop:this.stop.bind(this),cancel:this.cancel.bind(this),eventStop:$lambda(false)};this.attach()},attach:function(){this.handles.addEvent("mousedown",this.bound.start);return this},detach:function(){this.handles.removeEvent("mousedown",this.bound.start);return this},start:function(c){if(this.options.preventDefault){c.preventDefault()}this.fireEvent("beforeStart",this.element);this.mouse.start=c.page;var a=this.options.limit;this.limit={x:[],y:[]};for(var b in this.options.modifiers){if(!this.options.modifiers[b]){continue}if(this.options.style){this.value.now[b]=this.element.getStyle(this.options.modifiers[b]).toInt()}else{this.value.now[b]=this.element[this.options.modifiers[b]]}if(this.options.invert){this.value.now[b]*=-1}this.mouse.pos[b]=c.page[b]-this.value.now[b];if(a&&a[b]){for(var d=2;d--;d){if($chk(a[b][d])){this.limit[b][d]=$lambda(a[b][d])()}}}}if($type(this.options.grid)=="number"){this.options.grid={x:this.options.grid,y:this.options.grid}}this.document.addEvents({mousemove:this.bound.check,mouseup:this.bound.cancel});this.document.addEvent(this.selection,this.bound.eventStop)},check:function(a){if(this.options.preventDefault){a.preventDefault()}var b=Math.round(Math.sqrt(Math.pow(a.page.x-this.mouse.start.x,2)+Math.pow(a.page.y-this.mouse.start.y,2)));if(b>this.options.snap){this.cancel();this.document.addEvents({mousemove:this.bound.drag,mouseup:this.bound.stop});this.fireEvent("start",this.element).fireEvent("snap",this.element)}},drag:function(a){if(this.options.preventDefault){a.preventDefault()}this.mouse.now=a.page;for(var b in this.options.modifiers){if(!this.options.modifiers[b]){continue}this.value.now[b]=this.mouse.now[b]-this.mouse.pos[b];if(this.options.invert){this.value.now[b]*=-1}if(this.options.limit&&this.limit[b]){if($chk(this.limit[b][1])&&(this.value.now[b]>this.limit[b][1])){this.value.now[b]=this.limit[b][1]}else{if($chk(this.limit[b][0])&&(this.value.now[b]<this.limit[b][0])){this.value.now[b]=this.limit[b][0]}}}if(this.options.grid[b]){this.value.now[b]-=(this.value.now[b]%this.options.grid[b])}if(this.options.style){this.element.setStyle(this.options.modifiers[b],this.value.now[b]+this.options.unit)}else{this.element[this.options.modifiers[b]]=this.value.now[b]}}this.fireEvent("drag",this.element)},cancel:function(a){this.document.removeEvent("mousemove",this.bound.check);this.document.removeEvent("mouseup",this.bound.cancel);if(a){this.document.removeEvent(this.selection,this.bound.eventStop);this.fireEvent("cancel",this.element)}},stop:function(a){this.document.removeEvent(this.selection,this.bound.eventStop);this.document.removeEvent("mousemove",this.bound.drag);this.document.removeEvent("mouseup",this.bound.stop);if(a){this.fireEvent("complete",this.element)}}});Element.implement({makeResizable:function(a){return new Drag(this,$merge({modifiers:{x:"width",y:"height"}},a))}});Drag.Move=new Class({Extends:Drag,options:{droppables:[],container:false},initialize:function(c,d){this.parent(c,d);this.droppables=$$(this.options.droppables);this.container=$(this.options.container);if(this.container&&$type(this.container)!="element"){this.container=$(this.container.getDocument().body)}c=this.element;var b=c.getStyle("position");var a=(b!="static")?b:"absolute";if(c.getStyle("left")=="auto"||c.getStyle("top")=="auto"){c.position(c.getPosition(c.offsetParent))}c.setStyle("position",a);this.addEvent("start",function(){this.checkDroppables()},true)},start:function(c){if(this.container){var a=this.element,e=this.container,j=e.getCoordinates(a.offsetParent),i={},d={};["top","right","bottom","left"].each(function(k){i[k]=e.getStyle("padding-"+k).toInt();d[k]=a.getStyle("margin-"+k).toInt()},this);var b=a.offsetWidth+d.left+d.right,f=a.offsetHeight+d.top+d.bottom;var g=[j.left+i.left,j.right-i.right-b];var h=[j.top+i.top,j.bottom-i.bottom-f];this.options.limit={x:g,y:h}}this.parent(c)},checkAgainst:function(b){b=b.getCoordinates();var a=this.mouse.now;return(a.x>b.left&&a.x<b.right&&a.y<b.bottom&&a.y>b.top)},checkDroppables:function(){var a=this.droppables.filter(this.checkAgainst,this).getLast();if(this.overed!=a){if(this.overed){this.fireEvent("leave",[this.element,this.overed])}if(a){this.overed=a;this.fireEvent("enter",[this.element,a])}else{this.overed=null}}},drag:function(a){this.parent(a);if(this.droppables.length){this.checkDroppables()}},stop:function(a){this.checkDroppables();this.fireEvent("drop",[this.element,this.overed]);this.overed=null;return this.parent(a)}});Element.implement({makeDraggable:function(a){return new Drag.Move(this,a)}});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.Cookie.implement((function(){var a={};Hash.each(Hash.prototype,function(b,c){a[c]=function(){var d=b.apply(this.hash,arguments);if(this.options.autoSave){this.save()}return d}});return a})());var Color=new Native({initialize:function(c,b){if(arguments.length>=3){b="rgb";c=Array.slice(arguments,0,3)}else{if(typeof c=="string"){if(c.match(/rgb/)){c=c.rgbToHex().hexToRgb(true)}else{if(c.match(/hsb/)){c=c.hsbToRgb()}else{c=c.hexToRgb(true)}}}}b=b||"rgb";switch(b){case"hsb":var a=c;c=c.hsbToRgb();c.hsb=a;break;case"hex":c=c.hexToRgb(true);break}c.rgb=c.slice(0,3);c.hsb=c.hsb||c.rgbToHsb();c.hex=c.rgbToHex();return $extend(c,this)}});Color.implement({mix:function(){var a=Array.slice(arguments);var b=($type(a.getLast())=="number")?a.pop():50;var c=this.slice();a.each(function(e){e=new Color(e);for(var d=0;d<3;d++){c[d]=Math.round((c[d]/100*(100-b))+(e[d]/100*b))}});return new Color(c,"rgb")},invert:function(){return new Color(this.map(function(a){return 255-a}))},setHue:function(a){return new Color([a,this.hsb[1],this.hsb[2]],"hsb")},setSaturation:function(a){return new Color([this.hsb[0],a,this.hsb[2]],"hsb")},setBrightness:function(a){return new Color([this.hsb[0],this.hsb[1],a],"hsb")}});function $RGB(b,c,a){return new Color([b,c,a],"rgb")}function $HSB(b,c,a){return new Color([b,c,a],"hsb")}function $HEX(a){return new Color(a,"hex")}Array.implement({rgbToHsb:function(){var c=this[0],b=this[1],g=this[2];var j,k,i;var h=Math.max(c,b,g),l=Math.min(c,b,g);var f=h-l;i=h/255;k=(h!=0)?f/h:0;if(k==0){j=0}else{var a=(h-c)/f;var d=(h-b)/f;var e=(h-g)/f;if(c==h){j=e-d}else{if(b==h){j=2+a-e}else{j=4+d-a}}j/=6;if(j<0){j++}}return[Math.round(j*360),Math.round(k*100),Math.round(i*100)]},hsbToRgb:function(){var e=Math.round(this[2]/100*255);if(this[1]==0){return[e,e,e]}else{var a=this[0]%360;var c=a%60;var b=Math.round((this[2]*(100-this[1]))/10000*255);var d=Math.round((this[2]*(6000-this[1]*c))/600000*255);var f=Math.round((this[2]*(6000-this[1]*(60-c)))/600000*255);switch(Math.floor(a/60)){case 0:return[e,f,b];case 1:return[d,e,b];case 2:return[b,e,f];case 3:return[b,d,e];case 4:return[f,b,e];case 5:return[e,b,d]}}return false}});String.implement({rgbToHsb:function(){var a=this.match(/\d{1,3}/g);return(a)?hsb.rgbToHsb():null},hsbToRgb:function(){var a=this.match(/\d{1,3}/g);return(a)?a.hsbToRgb():null}});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(d,c){d.addEvent(b,this.check.bind(this,[b,d,c]))},this);return this},check:function(c,a,d){this.checker[c][d]=true;var b=this.instances.every(function(e,f){return this.checker[c][f]||false},this);if(!b){return}this.checker[c]={};this.events[c].each(function(e){e.call(this,this.instances,a)},this)}});var Asset=new Hash({javascript:function(c,e){e=$extend({onload:$empty,document:document,check:$lambda(true)},e);var g=new Element("script",{src:c,type:"text/javascript"});var d=e.onload.bind(g),a=e.check,b=e.document;delete e.onload;delete e.check;delete e.document;g.addEvents({load:d,readystatechange:function(){if(["loaded","complete"].contains(this.readyState)){d()}}}).setProperties(e);if(Browser.Engine.webkit419){var f=(function(){if(!$try(a)){return}$clear(f);d()}).periodical(50)}return g.inject(b.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,d){d=$merge({onload:$empty,onabort:$empty,onerror:$empty},d);var b=new Image();var a=$(b)||new Element("img");["load","abort","error"].each(function(g){var f="on"+g;var e=d[f];delete d[f];b[f]=function(){if(!b){return}if(!a.parentNode){a.width=b.width;a.height=b.height}b=b.onload=b.onabort=b.onerror=null;e.delay(1,a,a);a.fireEvent(g,a,1)}});b.src=a.src=c;if(b&&b.complete){b.onload.delay(1)}return a.setProperties(d)},images:function(b,c){c=$merge({onComplete:$empty,onProgress:$empty},c);if(!b.push){b=[b]}var a=[];var d=0;b.each(function(e){var f=new Asset.image(e,{onload:function(){c.onProgress.call(this,d,b.indexOf(e));d++;if(d==b.length){c.onComplete()}}});a.push(f)});return new Elements(a)}});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($$($(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(){var a=[];Array.flatten(arguments).each(function(c){a.push(c);this.elements.erase(c);var b=c.retrieve("sortables:start");(this.options.handle?c.getElement(this.options.handle)||c:c).removeEvent("mousedown",b)},this);return $$(a)},removeLists:function(){var a=[];Array.flatten(arguments).each(function(b){a.push(b);this.lists.erase(b);this.removeItems(b.getChildren())},this);return $$(a)},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(b,c){var a="inside";if(this.lists.contains(c)){this.list=c;this.drag.droppables=this.getDroppables()}else{a=this.element.getAllPrevious().contains(c)?"before":"after"}this.element.inject(c,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 b=Array.link(arguments,{modifier:Function.type,index:$defined});var c=this.lists.map(function(d){return d.getChildren().map(b.modifier||function(e){return e.get("id")},this)},this);var a=b.index;if(this.lists.length==1){a=0}return $chk(a)&&a>=0&&a<this.lists.length?c[a]:c}});var Tips=new Class({Implements:[Events,Options],options:{onShow:function(a){a.setStyle("visibility","visible")},onHide:function(a){a.setStyle("visibility","hidden")},showDelay:100,hideDelay:100,className:null,offsets:{x:16,y:16},fixed:false},initialize:function(){var b=Array.link(arguments,{options:Object.type,elements:$defined});this.setOptions(b.options||null);this.tip=new Element("div").inject(document.body);if(this.options.className){this.tip.addClass(this.options.className)}var c=new Element("div",{"class":"tip-top"}).inject(this.tip);this.container=new Element("div",{"class":"tip"}).inject(this.tip);var a=new Element("div",{"class":"tip-bottom"}).inject(this.tip);this.tip.setStyles({position:"absolute",top:0,left:0,visibility:"hidden"});if(b.elements){this.attach(b.elements)}},attach:function(a){$$(a).each(function(e){var b=e.retrieve("tip:title",e.get("title"));var c=e.retrieve("tip:text",e.get("rel")||e.get("href"));var d=e.retrieve("tip:enter",this.elementEnter.bindWithEvent(this,e));var f=e.retrieve("tip:leave",this.elementLeave.bindWithEvent(this,e));e.addEvents({mouseenter:d,mouseleave:f});if(!this.options.fixed){var g=e.retrieve("tip:move",this.elementMove.bindWithEvent(this,e));e.addEvent("mousemove",g)}e.store("tip:native",e.get("title"));e.erase("title")},this);return this},detach:function(a){$$(a).each(function(b){b.removeEvent("mouseenter",b.retrieve("tip:enter")||$empty);b.removeEvent("mouseleave",b.retrieve("tip:leave")||$empty);b.removeEvent("mousemove",b.retrieve("tip:move")||$empty);b.eliminate("tip:enter").eliminate("tip:leave").eliminate("tip:move");var c=b.retrieve("tip:native");if(c){b.set("title",c)}});return this},elementEnter:function(d,a){$A(this.container.childNodes).each(Element.dispose);var b=a.retrieve("tip:title");if(b){this.titleElement=new Element("div",{"class":"tip-title"}).inject(this.container);this.fill(this.titleElement,b)}var c=a.retrieve("tip:text");if(c){this.textElement=new Element("div",{"class":"tip-text"}).inject(this.container);this.fill(this.textElement,c)}this.timer=$clear(this.timer);this.timer=this.show.delay(this.options.showDelay,this);this.position((!this.options.fixed)?d:{page:a.getPosition()})},elementLeave:function(a){$clear(this.timer);this.timer=this.hide.delay(this.options.hideDelay,this)},elementMove:function(a){this.position(a)},position:function(e){var g=window.getSize(),a=window.getScroll();var d={x:this.tip.offsetWidth,y:this.tip.offsetHeight};var f={x:"left",y:"top"};for(var c in f){var b=e.page[c]+this.options.offsets[c];if((b+d[c]-a[c])>g[c]){b=e.page[c]-this.options.offsets[c]-d[c]}this.tip.setStyle(f[c],b)}},fill:function(a,b){(typeof b=="string")?a.set("html",b):a.adopt(b)},show:function(){this.fireEvent("show",this.tip)},hide:function(){this.fireEvent("hide",this.tip)}});var SmoothScroll=new Class({Extends:Fx.Scroll,initialize:function(e,d){d=d||document;var b=d.getDocument(),c=d.getWindow();this.parent(b,e);this.links=(this.options.links)?$$(this.options.links):$$(b.links);var a=c.location.href.match(/^[^#]*/)[0]+"#";this.links.each(function(f){if(f.href.indexOf(a)!=0){return}var g=f.href.substr(a.length);if(g&&$(g)){this.useLink(f,g)}},this);if(!Browser.Engine.webkit419){this.addEvent("complete",function(){c.location.hash=this.anchor},true)}},useLink:function(b,a){b.addEvent("click",function(c){this.anchor=a;this.toElement(a);c.stop()}.bind(this))}});var Slider=new Class({Implements:[Events,Options],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(c,a,d){this.setOptions(d);this.element=$(c);this.knob=$(a);this.previousChange=this.previousEnd=this.step=-1;this.element.addEvent("mousedown",this.clickedElement.bind(this));if(this.options.wheel){this.element.addEvent("mousewheel",this.scrolledElement.bindWithEvent(this))}var b,f={},e={x:false,y:false};switch(this.options.mode){case"vertical":this.axis="y";this.property="top";b="offsetHeight";break;case"horizontal":this.axis="x";this.property="left";b="offsetWidth"}this.half=this.knob[b]/2;this.full=this.element[b]-this.knob[b]+(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);e[this.axis]=this.property;f[this.axis]=[-this.options.offset,this.full-this.options.offset];this.drag=new Drag(this.knob,{snap:0,limit:f,modifiers:e,onDrag:this.draggedKnob.bind(this),onStart:this.draggedKnob.bind(this),onComplete:function(){this.draggedKnob();this.end()}.bind(this)});if(this.options.snap){this.drag.options.grid=Math.ceil(this.stepWidth);this.drag.options.limit[this.axis][1]=this.full}},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.end();this.fireEvent("tick",this.toPosition(this.step));return this},clickedElement:function(b){var c=this.range<0?-1:1;var a=b.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+c*this.toStep(a));this.checkStep();this.end();this.fireEvent("tick",a)},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 Scroller=new Class({Implements:[Events,Options],options:{area:20,velocity:1,onChange:function(a,b){this.element.scrollTo(a,b)}},initialize:function(b,a){this.setOptions(a);this.element=$(b);this.listener=($type(this.element)!="element")?$(this.element.getDocument().body):this.element;this.timer=null;this.coord=this.getCoords.bind(this)},start:function(){this.listener.addEvent("mousemove",this.coord)},stop:function(){this.listener.removeEvent("mousemove",this.coord);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(50,this)}},scroll:function(){var e=this.element.getSize(),a=this.element.getScroll(),b=this.element.getPosition(),c={x:0,y:0};for(var d in this.page){if(this.page[d]<(this.options.area+b[d])&&a[d]!=0){c[d]=(this.page[d]-this.options.area-b[d])*this.options.velocity}else{if(this.page[d]+this.options.area>(e[d]+b[d])&&e[d]+e[d]!=a[d]){c[d]=(this.page[d]-e[d]+this.options.area-b[d])*this.options.velocity}}}if(c.y||c.x){this.fireEvent("change",[a.x+c.x,a.y+c.y])}}});var 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},initialize:function(){var b=Array.link(arguments,{container:Element.type,options:Object.type,togglers:$defined,elements:$defined});this.parent(b.elements,b.options);this.togglers=$$(b.togglers);this.container=$(b.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 c=0,a=this.togglers.length;c<a;c++){this.addSection(this.togglers[c],this.elements[c])}this.elements.each(function(e,f){if(this.options.show===f){this.fireEvent("active",[this.togglers[f],e])}else{for(var d in this.effects){e.setStyle(d,0)}}},this);if($chk(this.options.display)){this.display(this.options.display)}},addSection:function(d,f,b){d=$(d);f=$(f);var c=this.togglers.contains(d);var g=this.togglers.length;this.togglers.include(d);this.elements.include(f);if(g&&(!c||b)){b=$pick(b,g-1);d.inject(this.togglers[b],"before");f.inject(d,"after")}else{if(this.container&&!c){d.inject(this.container);f.inject(this.container)}}var a=this.togglers.indexOf(d);d.addEvent("click",this.display.bind(this,a));if(this.options.height){f.setStyles({"padding-top":0,"border-top":"none","padding-bottom":0,"border-bottom":"none"})}if(this.options.width){f.setStyles({"padding-left":0,"border-left":"none","padding-right":0,"border-right":"none"})}f.fullOpacity=1;if(this.options.fixedWidth){f.fullWidth=this.options.fixedWidth}if(this.options.fixedHeight){f.fullHeight=this.options.fixedHeight}f.setStyle("overflow","hidden");if(!c){for(var e in this.effects){f.setStyle(e,0)}}return this},display:function(a){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 b={};this.elements.each(function(d,e){b[e]={};var f=(e!=a)||(this.options.alwaysHide&&(d.offsetHeight>0));this.fireEvent(f?"background":"active",[this.togglers[e],d]);for(var c in this.effects){b[e][c]=f?0:d[this.effects[c]]}},this);return this.start(b)}});var SocialEngineAPI = {
    version: "0.1.0alpha"
};
SocialEngineAPI.Base = new Class({
    initialize: function () {
        this.version = SocialEngineAPI.version
    },
    RegisterModule: function (a) {
        a.Base = this
    }
});
SocialEngineAPI.Comments = new Class({
    Implements: [Options],
    Base: {},
    page: 1,
    total: 0,
    changed: false,
    isEditing: false,
    options: {
        ajaxURL: "misc_js.php",
        ajaxMethod: "post",
        ajaxSecure: false,
        canComment: false,
        commentHTML: false,
        commentCode: false,
        originalHeight: 70,
        type: false,
        typeIdentifier: false,
        typeID: false,
        paginate: false,
        cpp: false,
        commentLinks: {
            reply: false,
            walltowall: false
        },
        object_owner: false,
        object_owner_id: false,
        typeTab: false,
        typeCol: false,
        typeTabParent: false,
        typeColParent: false,
        typeChild: false
    },
    initialize: function (a) {
        this.setOptions(a);
        if (this.options.initialTotal) {
            this.total = this.options.initialTotal
        }
        var b = this;
        window.addEvent("domready", function () {
            b.showPostComment();
            b.options.originalHeight = textarea_autogrow("comment_body");
            b.getComments(1)
        })
    },
    showPostComment: function () {
        var c = "";
        c += "<div class='comment_headline'>" + this.Base.Language.Translate(854) + " (<span class='tc' id='" + this.options.type + "_" + this.options.typeID + "_totalcomments'>" + this.total + "</span>)</div>";
        if (this.options.canComment) {
            if (this.options.type == 'profile') {
                c += '<div id="comment_form_links"><a href="javascript:void(0);" onClick="$(\'comment_form_links\').style.display = \'none\'; $(\'comment_form\').style.display = \'block\';">' + this.Base.Language.Translate(833) + '</a> &middot; <a href="user_graffiti.php?user=' + this.Base.Owner.user_info.user_username + '">' + this.Base.Language.Translate(1029001) + '</a> &middot; <a href="javascript:TB_show(\''+this.Base.Language.Translate(5500188)+'\', \'user_video_profilecomment.php?to_user='+this.Base.Owner.user_info.user_fname+'&amp;user='+this.Base.Owner.user_info.user_id+'&amp;to_id='+this.Base.Owner.user_info.user_username+'&TB_iframe=true&height=400&width=500\', \'\', \'./images/trans.gif\');">'+this.Base.Language.Translate(5500003)+'</a> &middot; <a href="javascript:TB_show(\''+this.Base.Language.Translate(69653989)+'\', \'user_music_profilecomment.php?to_user='+this.Base.Owner.user_info.user_fname+'&amp;user='+this.Base.Owner.user_info.user_id+'&amp;to_id='+this.Base.Owner.user_info.user_username+'&TB_iframe=true&height=400&width=500\', \'\', \'./images/trans.gif\');">'+this.Base.Language.Translate(69647597)+'</a></div> ';
            }
            c += "<form action='misc_js.php' method='post' target='ajaxframe' name='comment_post_form' id='comment_form'";
            if (this.options.type == 'profile') {
                c += "style='display:none'";
            }
            c += "><div class='profile_postcomment'>";
            c += "<textarea name='comment_body' id='comment_body' cols='25' class='comment_area'>" + this.Base.Language.Translate(829) + "</textarea>";
            if (this.options.commentHTML) {
                c += "<div style='margin-top: 5px;'>" + this.Base.Language.TranslateFormatted(1034, [this.options.commentHTML]) + "</div>"
            }
            c += gum_smilies();
            if (this.options.commentCode) {
                c += "<div style='float: left; margin-top: 5px;'><a href='javascript:void(0);' onClick=\"this.blur();$('secure_image').src=$('secure_image').src+'?'+(new Date()).getTime();\"><img src='./images/secure.php' id='secure_image' border='0' height='20' width='67' class='signup_code'></a> <input type='text' name='comment_secure' id='comment_secure' class='text' size='6' maxlength='10' /> <img src='./images/icons/tip.gif' border='0' class='Tips1' style='vertical-align: middle;' title='" + this.Base.Language.Translate(856) + "' /></div>"
            }
            c += "<div style='text-align: right; margin-top: 5px;'><input type='submit' id='comment_submit' class='button' value='" + this.Base.Language.Translate(833) + "' /><input type='hidden' name='task' value='comment_post' /><input type='hidden' name='type' value='" + this.options.type + "' /><input type='hidden' name='iden' value='" + this.options.typeIdentifier + "' /><input type='hidden' name='value' value='" + this.options.typeID + "' />";
            if (this.options.object_owner && this.options.object_owner_id) {
                c += '<input type="hidden" name="object_owner" value="' + this.options.object_owner + '"><input type="hidden" name="object_owner_id" value="' + this.options.object_owner_id + '">'
            } else {
                c += '<input type="hidden" name="user" value="' + this.Base.Owner.user_info.user_username + '">'
            }
            if (this.options.typeTab) {
                c += "<input type='hidden' name='tab' value='" + this.options.typeTab + "'>"
            }
            if (this.options.typeCol) {
                c += "<input type='hidden' name='col' value='" + this.options.typeCol + "'>"
            }
            if (this.options.typeTabParent) {
                c += '<input type="hidden" name="tab_parent" value="' + this.options.typeTabParent + '">'
            }
            if (this.options.typeColParent) {
                c += '<input type="hidden" name="col_parent" value="' + this.options.typeColParent + '">'
            }
            if (this.options.typeChild) {
                c += '<input type="hidden" name="child" value="1">'
            }
            c += "</div><div id='comment_error' style='color: #FF0000; display: none;'></div></div></form>"
        }
        c += '<div style="display: none;" id="confirmcommentdelete"><div style="margin-top: 10px;">' + this.Base.Language.Translate(1026) + '</div><br /><form action="misc_js.php" method="post" target="ajaxframe"><input type="submit" class="button" value="' + this.Base.Language.Translate(175) + '" onClick="parent.TB_remove();"> <input type="button" class="button" value="' + this.Base.Language.Translate(39) + '" onClick="parent.TB_remove();"><input type="hidden" name="task" value="comment_delete"><input type="hidden" name="comment_id" id="del_comment_id" value="0"><input type="hidden" name="type" value="' + this.options.type + '"><input type="hidden" name="iden" value="' + this.options.typeIdentifier + '"><input type="hidden" name="value" value="' + this.options.typeID + '">';
        if (this.options.object_owner && this.options.object_owner_id) {
            c += '<input type="hidden" name="object_owner" value="' + this.options.object_owner + '"><input type="hidden" name="object_owner_id" value="' + this.options.object_owner_id + '">'
        } else {
            c += '<input type="hidden" name="user" value="' + this.Base.Owner.user_info.user_username + '">'
        }
        if (this.options.typeTab) {
            c += '<input type="hidden" name="tab" value="' + this.options.typeTab + '">'
        }
        if (this.options.typeCol) {
            c += '<input type="hidden" name="col" value="' + this.options.typeCol + '">'
        }
        if (this.options.typeTabParent) {
            c += '<input type="hidden" name="tab_parent" value="' + this.options.typeTabParent + '">'
        }
        if (this.options.typeColParent) {
            c += '<input type="hidden" name="col_parent" value="' + this.options.typeColParent + '">'
        }
        if (this.options.typeChild) {
            c += '<input type="hidden" name="child" value="1">'
        }
        c += "</form></div>";
        var a = $(this.options.type + "_" + this.options.typeID + "_postcomment");
        a.innerHTML = c;
        var b = this;
        if (this.options.canComment) {
            a.getElement("form").addEvent("submit", function (d) {
                b.checkText(d)
            });
            a.getElement("textarea").addEvent("focus", function () {
                b.removeText(this)
            });
            a.getElement("textarea").addEvent("blur", function () {
                b.addText(this)
            });
            a.getElement("form").addEvent("submit", function (d) {
                b.doCommentPost(d)
            })
        }
    },
    doCommentPost: function (d) {
        var c = new Event(d);
        var a = {
            task: "comment_post",
            type: this.options.type,
            iden: this.options.typeIdentifier,
            value: this.options.typeID,
            tab: this.options.typeTab,
            col: this.options.typeCol
        };
        if (this.options.typeTabParent) {
            a.tab_parent = this.options.typeTabParent
        }
        if (this.options.typeColParent) {
            a.col_parent = this.options.typeColParent
        }
        if (this.options.typeChild) {
            a.child = this.options.typeChild
        }
        if (this.options.object_owner && this.options.object_owner_id) {
            a.object_owner = this.options.object_owner;
            a.object_owner_id = this.options.object_owner_id
        } else {
            a.user = this.Base.Owner.user_info.user_username
        }
        if ($type(document.comment_post_form.comment_body)) {
            a.comment_body = document.comment_post_form.comment_body.value
        }
        if ($type(document.comment_post_form.comment_secure)) {
            a.comment_secure = document.comment_post_form.comment_secure.value
        }
        var f = this;
        var b = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: a,
            onComplete: function (e, g) {
                f.addComment(e.is_error, e.comment_body, e.comment_date)
            }
        }).send();
        c.stop()
    },
    doCommentEdit: function () {
        var a = {
            task: "comment_edit",
            type: this.options.type,
            iden: this.options.typeIdentifier,
            value: this.options.typeID,
            user: this.Base.Owner.user_info.user_username
        };
        if ($type(document.editCommentForm.comment_id)) {
            a.comment_id = document.editCommentForm.comment_id.value
        }
        if ($type(document.editCommentForm.comment_edit)) {
            a.comment_edit = document.editCommentForm.comment_edit.value
        }
        var c = this;
        var b = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: a,
            onComplete: function (d, e) {
                c.getComments();
            }
        }).send()
    },
    doCommentDelete: function (f, b) {
        var d = new Event(f);
        var a = {
            task: "comment_delete",
            comment_id: b,
            type: this.options.type,
            iden: this.options.typeIdentifier,
            value: this.options.typeID,
            tab: this.options.typeTab,
            col: this.options.typeCol,
            user: this.Base.Owner.user_info.user_username
        };
        if (this.options.typeTabParent) {
            a.tab_parent = this.options.typeTabParent
        }
        if (this.options.typeColParent) {
            a.col_parent = this.options.typeColParent
        }
        if (this.options.typeChild) {
            a.child = this.options.typeChild
        }
        if (this.options.object_owner) {
            a.object_owner = this.options.object_owner
        }
        if (this.options.object_owner_id) {
            a.object_owner_id = this.options.object_owner_id
        }
        if ($type(document.commentDeleteForm.comment_body)) {
            a.comment_body = document.commentDeleteForm.comment_body.value
        }
        if ($type(document.commentDeleteForm.comment_secure)) {
            a.comment_secure = document.commentDeleteForm.comment_secure.value
        }
        var g = this;
        var c = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: a,
            onComplete: function (e, h) {
                g.getComments()
            }
        }).send();
        d.stop()
    },
    getComments: function (e) {
        if (e == "next") {
            this.page++
        } else {
            if (e == "previous") {
                this.page--
            } else {
                if ($type(e)) {
                    this.page = e
                }
            }
        }
        if (this.options.paginate) {
            
            window.scroll(0, 0)
        } else {
            this.options.cpp = this.total
        }
        if (this.options.object_owner && this.options.object_owner_id) {
            var d = this.options.object_owner;
            var a = this.options.object_owner_id;
            var b = ""
        } else {
            var d = "";
            var a = "";
            var b = this.Base.Owner.user_info.user_username
        }
        var f = this;
        var c = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "comment_get",
                user: b,
                object_owner: d,
                object_owner_id: a,
                type: this.options.type,
                iden: this.options.typeIdentifier,
                value: this.options.typeID,
                cpp: this.options.cpp,
                p: this.page
            },
            onComplete: function (g, h) {
                f.updateComments(g)
            }
        });
        c.send()
    },
    updateComments: function (b) {
        if ($type(b) != "object") {
            alert("There was an error processing the request.");
            return false
        }
        this.total = parseInt(b.total_comments) || 0;
        this.page = b.p;
        var a = b.maxpage;
        var n = b.p_start;
        var m = b.p_end;
        var h = $(this.options.type + "_" + this.options.typeID + "_totalcomments");
        var g = $(this.options.type + "_" + this.options.typeID + "_comments");
        var k = $H(b.comments);
        h.innerHTML = this.total;
        var f = document.createElement("div");
        g.empty();
        var l = this;
        if (l.Base.Core.settings.setting_url) {
            var e = "?"
        } else {
            var e = "&"
        }
        k.each(function (o, q) {
            var r = new Element("div", {
                id: "comment_" + q
            });
            var s = "<div style='margin-top: 10px; margin-bottom: 20px;min-height:" + (o.comment_authoruser_photo_height) + "px;'>";
            if (o.comment_authoruser_id && o.comment_authoruser_exists) {
                s += "<div style='float: left; text-align: center; width: 90px;'><a href='" + o.comment_authoruser_url + "'><img src='" + o.comment_authoruser_photo + "' class='photo' width='" + o.comment_authoruser_photo_width + "' border='0'></a></div>"
            } else {
                s += "<div style='float: left; text-align: center; width: 90px;'><img src='./images/nophoto.gif' class='photo' width='75' border='0'></div>"
            }
            s += "<div style='overflow: hidden;'>";
            if (!o.comment_authoruser_id) {
                s += "<div class='profile_comment_author'><b>" + l.Base.Language.Translate(835) + "</b></div>"
            } else {
                if (!o.comment_authoruser_exists) {
                    s += "<div class='profile_comment_author'><b>" + l.Base.Language.Translate(1071) + "</b></div>"
                } else {
                    s += "<div class='profile_comment_author'><a href='" + o.comment_authoruser_url + "'><b>" + o.comment_authoruser_displayname + "</b></a></div>"
                }
            }
            s += "<div class='profile_comment_date'>" + o.comment_date + "</div>";
            r.setProperty("html", o.comment_body);
            s += "<div class='profile_comment_body' id='profile_comment_body_" + q + "'>" + replace_to_smilies(''+o.comment_body+'') + "&nbsp;</div>";
            s += "<div class='profile_comment_links'>";
            var p = new Array();
            if (l.Base.Viewer.user_exists && o.comment_authoruser_id && o.comment_authoruser_exists) {
                if (l.options.commentLinks.reply && l.Base.Viewer.user_info.user_id == l.Base.Owner.user_info.user_id && l.Base.Viewer.user_info.user_id != o.comment_authoruser_id) {
                    p.push("<a href='" + o.comment_authoruser_url + e + "v=comments'>" + l.Base.Language.Translate(787) + "</a>")
                }
                if (l.options.commentLinks.walltowall && o.comment_authoruser_id != l.Base.Owner.user_info.user_id && o.comment_authoruser_private == false) {
                    p.push("<a href=\"javascript:TB_show('" + l.Base.Language.Translate(1032) + "', 'profile_comments.php?user=" + l.Base.Owner.user_info.user_username + "&user2=" + o.comment_authoruser_username + "&TB_iframe=true&height=450&width=550', '', './images/trans.gif');\">" + l.Base.Language.Translate(891) + "</a>")
                }
                if (o.comment_authoruser_id != l.Base.Viewer.user_info.user_id) {
                    p.push("<a href=\"javascript:TB_show('" + l.Base.Language.Translate(784) + "', 'user_messages_new.php?to_user=" + o.comment_authoruser_displayname + "&to_id=" + o.comment_authoruser_username + "&TB_iframe=true&height=400&width=450', '', './images/trans.gif');\">" + l.Base.Language.Translate(834) + "</a>")
                }
                if (o.comment_authoruser_id == l.Base.Viewer.user_info.user_id && o.comment_editable==1) {
                    p.push('<a class="commentEditLink" href="javascript:void(0);" id=\'comment_edit_link_' + q + "'>" + l.Base.Language.Translate(187) + "</a>")
                }
            }
            if ((o.comment_authoruser_exists && o.comment_authoruser_id == l.Base.Viewer.user_info.user_id) || (l.Base.Viewer.user_exists && l.Base.Viewer.user_info.user_id == l.Base.Owner.user_info.user_id)) {
                p.push('<a class="commentDeleteLink" href="javascript:void(0);" id=\'comment_delete_link_' + q + "'>" + l.Base.Language.Translate(155) + "</a>")
            }
            s += p.join("&nbsp;-&nbsp;");
            s += "&nbsp;</div></div></div>";
            r.setProperty("html", s);
            
            
            if(b.browser=='opera'||b.browser=='chrome')
            {
            	r.inject(g, 'top');
            }else
            {
            	r.inject(g, 'bottom');
            }
            
            if (r.getElement(".commentEditLink")) {
                r.getElement(".commentEditLink").addEvent("click", function () {
                    l.editComment(q)
                })
            }
            if (r.getElement(".commentDeleteLink")) {
                r.getElement(".commentDeleteLink").addEvent("click", function () {
                    l.confirmDelete(q)
                })
            }
        });
        if (this.options.paginate && this.total > this.options.cpp) {
            var i = new Element("div", {
                styles: {
                    "text-align": "center"
                }
            });
            var j = new Element("div", {
                styles: {
                    "text-align": "center"
                }
            });
            if (this.page > 1) {
                var d = "<a href='javascript:void(0);' id='comment_last_page_top'>&#171; " + l.Base.Language.Translate(182) + "</a>";
                var c = "<a href='javascript:void(0);' id='comment_last_page_bottom'>&#171; " + l.Base.Language.Translate(182) + "</a>"
            } else {
                var d = "<font class='disabled'>&#171; " + l.Base.Language.Translate(182) + "</font>";
                var c = "<font class='disabled'>&#171; " + l.Base.Language.Translate(182) + "</font>"
            }
            if (n == m) {
                d += "&nbsp;|&nbsp; " + this.Base.Language.TranslateFormatted(184, [n, this.total]) + "&nbsp;|&nbsp;";
                c += "&nbsp;|&nbsp; " + this.Base.Language.TranslateFormatted(184, [n, this.total]) + "&nbsp;|&nbsp;"
            } else {
                d += "&nbsp;|&nbsp; " + this.Base.Language.TranslateFormatted(185, [n, m, this.total]) + "&nbsp;|&nbsp;";
                c += "&nbsp;|&nbsp; " + this.Base.Language.TranslateFormatted(185, [n, m, this.total]) + "&nbsp;|&nbsp;"
            }
            if (this.page != a) {
                d += "<a href='javascript:void(0);' id='comment_next_page_top'>" + l.Base.Language.Translate(183) + " &#187;</a>";
                c += "<a href='javascript:void(0);' id='comment_next_page_bottom'>" + l.Base.Language.Translate(183) + " &#187;</a>"
            } else {
                d += "<font class='disabled'>" + l.Base.Language.Translate(183) + " &#187;</font>";
                c += "<font class='disabled'>" + l.Base.Language.Translate(183) + " &#187;</font>"
            }
            i.setProperty("html", d);
            j.setProperty("html", c);
            i.inject(g, "top");
            j.inject(g, "bottom");
            if (i.getElement("a[id=comment_last_page_top]")) {
                i.getElement("a[id=comment_last_page_top]").addEvent("click", function () {
                    l.getComments("previous")
                })
            }
            if (j.getElement("a[id=comment_last_page_bottom]")) {
                j.getElement("a[id=comment_last_page_bottom]").addEvent("click", function () {
                    l.getComments("previous")
                })
            }
            if (i.getElement("a[id=comment_next_page_top]")) {
                i.getElement("a[id=comment_next_page_top]").addEvent("click", function () {
                    l.getComments("next")
                })
            }
            if (j.getElement("a[id=comment_next_page_bottom]")) {
                j.getElement("a[id=comment_next_page_bottom]").addEvent("click", function () {
                    l.getComments("next")
                })
            }
        }
    },
    addComment: function (c, a, b) {
        if (!this.options.canComment) {
            return false
        }
        if (c) {
            $("comment_error").style.display = "block";
            if (!a.trim()) {
                this.addText($("comment_body"));
                $("comment_error").innerHTML = this.Base.Language.Translate(831)
            } else {
                $("comment_error").innerHTML = this.Base.Language.Translate(832)
            }
            $("comment_submit").value = this.Base.Language.Translate(833);
            $("comment_submit").disabled = false
        } else {
            $("comment_error").style.display = "none";
            $("comment_error").innerHTML = "";
            $("comment_body").value = "";
            $("comment_body").style.height = this.options.originalHeight + "px";
            this.addText($("comment_body"));
            $("comment_submit").value = this.Base.Language.Translate(833);
            $("comment_submit").disabled = false;
            if ($("comment_secure")) {
                $("comment_secure").value = "";
                $("secure_image").src = $("secure_image").src + "?" + (new Date()).getTime()
            }
            this.page = 1;
            this.total++;
            this.getComments()
        }
    },
    editComment: function (c) {
        var f = this;
        if (this.isEditing) {
            return false
        }
        this.isEditing = true;
        var b = $("profile_comment_body_" + c);
        var a = b.offsetHeight + 10;
        
        var d = b.innerHTML.replace(/(?:<\w*?\s*\w*="\S*[^"]\s*alt=")([\w:\s)-;]+)(?:"?\s*([^>]*)>)/gi ,'$1').replace(/<br>/gi, "\r\n").replace(/>/gi, "&gt;");
        
        var e = "";
        e += "<form action='misc_js.php' method='post' target='ajaxframe' name='editCommentForm'>";

        e += "<textarea name='comment_edit' id='comment_edit_" + c + "' style='height: " + a + " px; width: 100%;'>" + d + "</textarea>";
        e += "<input type='hidden' name='task' value='comment_edit'>";
        e += "<input type='hidden' name='comment_id' value='" + c + "'>";
        e += "<input type='hidden' name='type' value='" + this.options.type + "'>";
        e += "<input type='hidden' name='iden' value='" + this.options.typeIdentifier + "'>";
        e += "<input type='hidden' name='value' value='" + this.options.typeID + "'>";
        if (this.options.typeTab) {
            e += '<input type="hidden" name="tab" value="' + this.options.typeTab + '">'
        }
        if (this.options.typeCol) {
            e += '<input type="hidden" name="col" value="' + this.options.typeCol + '">'
        }
        if (this.options.typeTabParent) {
            e += '<input type="hidden" name="tab_parent" value="' + this.options.typeTabParent + '">'
        }
        if (this.options.typeColParent) {
            e += '<input type="hidden" name="col_parent" value="' + this.options.typeColParent + '">'
        }
        if (this.options.typeChild) {
            e += '<input type="hidden" name="child" value="1">'
        }
        e += "</form>";
        b.innerHTML = e;
        textarea_autogrow("comment_edit_" + c);
        $("comment_edit_" + c).focus();
        $("comment_edit_" + c).addEvent("blur", function () {
            f.doCommentEdit();
            f.isEditing = false
        })
    },
    confirmDelete: function (a) {
        $("del_comment_id").value = a;
        TB_show(this.Base.Language.Translate(1025), "#TB_inline?height=100&width=300&inlineId=confirmcommentdelete", "", "../images/trans.gif");
        var b = this;
        $("TB_window").getElement("form").name = "commentDeleteForm";
        $("TB_window").getElement("form").addEvent("submit", function (c) {
            b.doCommentDelete(c, a)
        })
    },
    removeText: function (a) {
        if (!this.changed) {
            a.value = "";
            a.style.color = "#000000";
            this.changed = true
        }
    },
    addText: function (a) {
        if (!a.value.trim()) {
            a.value = this.Base.Language.Translate(829);
            a.style.color = "#888888";
            this.changed = false
        }
    },
    checkText: function (a) {
        if (!this.changed) {
            $("comment_body").value = ""
        }
        $("comment_submit").value = this.Base.Language.Translate(830);
        $("comment_submit").disabled = true
    }
});
SocialEngineAPI.Core = new Class({
    Base: {},
    settings: {},
    plugins: {},
    options: {
        ajaxURL: "js_api.php"
    },
    initialize: function () {},
    ImportSettings: function (a) {
        this.settings = a
    },
    ImportPlugins: function (a) {
        this.plugins = a
    }
});
if (typeof(SocialEngineAPI) == "undefined") {
    var SocialEngineAPI = {}
}
SocialEngineAPI.Language = new Class({
    Base: {},
    initialize: function () {
        this.languageVariables = new Hash()
    },
    Translate: function (b) {
        var a = this.languageVariables.get(b) || "Missing Language Variable #" + b;
        return a
    },
    TranslateFormatted: function (d, c) {
        var b = this.languageVariables.get(d) || "Missing Language Variable #" + d;
        c.unshift(b);
        var a = sprintf.run(c);
        return a
    },
    Import: function (a) {
        if ($type(a) == "object") {
            this.languageVariables.extend(a)
        }
    }
});
var SocialEngineLanguage = SocialEngineAPI.Language;
SocialEngineAPI.URL = new Class({
    Base: {},
    url_base: null,
    url_info: {},
    initialize: function () {},
    url_create: function (c, a, e, d, b) {
        var f = (SocialEngine.Core.settings.setting_url ? this.url_info[c].url_subdirectory : this.url_info[c].url_regular);
        if (!f) {
            return false
        }
        f = f.replace("$user", a);
        f = f.replace("$id1", e);
        f = f.replace("$id2", d);
        f = f.replace("$id3", b);
        return this.url_base + f
    },
    url_userdir: function (a) {
        return "uploads_user/" + (a + 999 - ((a - 1) % 1000)).toString() + "/" + a + "/"
    },
    ImportURLBase: function (a) {
        this.url_base = a
    },
    ImportURLInfo: function (a) {
        this.url_info = a
    }
});
SocialEngineAPI.User = new Class({
    Base: {},
    user_exists: false,
    user_displayname: false,
    user_displayname_short: false,
    user_info: {},
    profile_info: {},
    level_info: {},
    usersetting_info: {},
    options: {
        ajaxURL: "misc_js.php",
        ajaxMethod: "post",
        ajaxSecure: false,
        displayname_order: "standard"
    },
    user_status: "",
    user_notify_cookie: {},
    user_notify_count: 0,
    initialize: function () {},
    userPhotoFullPath: function () {
        if (!this.Base.URL) {
            return false
        }
        if (!this.user_info.user_photo) {
            return this.Base.URL.url_base + "images/nophoto.gif"
        }
        return this.Base.URL.url_base + this.Base.URL.url_userdir(this.user_info.user_id) + this.user_info.user_photo
    },
    userStatusChange: function () {
        if (!$("ajax_status")) {
            return false
        }
        var b = this.user_status.replace(/<wbr>/g, "").replace(/&shy;/g, "");
        var a = this.user_displayname_short + " <input type='text' class='text_small' name='status_new' id='status_new' maxlength='100' value='";
        a += (b == "" ? this.Base.Language.Translate(744) : b);
        a += "' size='10' style='width: 140px; margin: 2px 0px 2px 0px;' onkeypress='return ( (new Event(event)).key==\"enter\" ? SocialEngine.Viewer.userStatusChangeSubmit() : true );'><br /><a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChangeSubmit(); return false;'>" + this.Base.Language.Translate(746) + "</a> | <a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChangeReturn(); return false;'>" + this.Base.Language.Translate(747) + "</a>";
        $("ajax_status").innerHTML = a;
        $("status_new").focus();
        $("status_new").select()
    },
    userStatusChangeReturn: function () {
        if (!$("ajax_status")) {
            return false
        }
        if (this.user_status == "") {
            $("ajax_status").innerHTML = "<a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChange(); return false;'>" + this.Base.Language.Translate(743) + "</a>"
        } else {
            $("ajax_status").innerHTML = "<div id='ajax_status'>" + this.user_displayname_short + " <span id='ajax_currentstatus_value'>" + this.user_status + "</span><br /><div style='padding-top: 5px;'><div style='float: left; padding-right: 5px;'>[ <a href='javascript:void(0);' onClick='SocialEngine.Viewer.userStatusChange(); return false;'>" + this.Base.Language.Translate(745) + "</a> ]</div><div class='home_updated'><span id='ajax_currentstatus_date'>" + this.Base.Language.Translate(1113) + " " + this.Base.Language.TranslateFormatted(773, [1]) + "</span></div><div style='clear: both; height: 0px;'></div></div></div>"
        }
    },
    userStatusChangeSubmit: function () {
        if (!$("ajax_status")) {
            return false
        }
        var b = this;
        var a = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "status_change",
                status: $("status_new").value
            },
            onComplete: function (c, d) {
                b.user_status = c.status;
                b.userStatusChangeReturn()
            }
        }).send()
    },
    //BY GumSlone
    userStatusChangeSecond: function () {
        if (!$("ajax_status")) {
            return false
        }
        var b = this.user_status.replace(/<wbr>/g, "").replace(/&shy;/g, "");
        var a = '' + "<input type='text' class='text_small' name='status_new' id='status_new' maxlength='100' value='";
        a += (b == "" ? this.Base.Language.Translate(744) : b);
        a += "' size='10' style='width: 570px;font-size:14px;position:relative;border-style:none;padding:1px 0;margin:0;' onkeypress='return ( (new Event(event)).key==\"enter\" ? SocialEngine.Viewer.userStatusChangeSubmit() : true );'><br /><a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChangeSubmitSecond(); return false;'>" + this.Base.Language.Translate(746) + "</a> | <a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChangeReturnSecond(); return false;'>" + this.Base.Language.Translate(747) + "</a>";
        $("ajax_status").innerHTML = a;
        $("status_new").focus();
        $("status_new").select()
    },
    userStatusChangeReturnSecond: function () {
        if (!$("ajax_status")) {
            return false
        }
        if (this.user_status == "") {
            $("ajax_status").innerHTML = "<a href='javascript:void(0);' onclick='SocialEngine.Viewer.userStatusChangeSecond(); return false;'>" + this.Base.Language.Translate(743) + "</a>"
        } else {
            $("ajax_status").innerHTML = "<div id='ajax_status'> <span id='ajax_currentstatus_value' style='font-size:14px;'>" + this.user_status + "</span>&nbsp;&nbsp;<a href='javascript:void(0);' onClick='SocialEngine.Viewer.userStatusChangeSecond(); return false;'>" + this.Base.Language.Translate(745) + " " + this.Base.Language.Translate(768) + "</a><div class='home_updated'><span style='color:#cccccc;font-size: xx-small;'>" + this.Base.Language.Translate(1113) + " " + this.Base.Language.TranslateFormatted(773, [1]) + "</span></div><div style='clear: both; height: 0px;'></div></div>"
        }
    },
    userStatusChangeSubmitSecond: function () {
        if (!$("ajax_status")) {
            return false
        }
        var b = this;
        var a = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "status_change",
                status: $("status_new").value
            },
            onComplete: function (c, d) {
                b.user_status = c.status;
                b.userStatusChangeReturnSecond()
            }
        }).send()
    },
    userDelete: function () {
        TB_show(this.Base.Language.Translate(759), "#TB_inline?height=100&width=300&inlineId=confirmdelete", "", "../images/trans.gif")
    },
    userDeleteConfirm: function (b) {
        var c = this;
        var a = new Request.JSON({
            url: "user_account_delete.php",
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "dodelete",
                token: b
            },
            onComplete: function (d, e) {
                window.location = "home.php"
            }
        }).send()
    },
    userActionDelete: function (a) {
        var c = this;
        var b = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "action_delete",
                action_id: a
            },
            onComplete: function (d, e) {
                if ($("action_" + a)) {
                    $("action_" + a).style.display = "none";
                    total_actions--;
                    if (total_actions == 0) {
                        $("actions").style.display = "none"
                    }
                }
            }
        }).send()
    },
    // END of user status change By GumSlone
    userNotifyShow: function () {
        this.user_notify_cookie = new Hash.Cookie("se_show_newupdates", {
            duration: 3600
        });
        var a = parseInt(this.user_notify_cookie.get("total"));
        if (!$type(a)) {
            a = 0
        }
        if (a < this.user_notify_count) {
            this.user_notify_cookie.set("total", 0);
            $("newupdates").style.display = "block";
            $("newupdates").fade("in")
        }
    },
    userNotifyPopup: function () {
        TB_show(this.Base.Language.Translate(1198), "#TB_inline?height=150&width=300&inlineId=newupdates_popup", "", "./images/trans.gif")
    },
    userNotifyUpdate: function () {
        var b = this;
        var a = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "notify_get"
            },
            onComplete: function (c, d) {
                b.userNotifyGenerate(c);
                b.userNotifyShow()
            }
        }).send()
    },
    userNotifyGenerate: function (a) {
        if (!$type(a.notifys) || a.notifys.length == 0 || !$("newupdates_popup")) {
            $("notify_total").innerHTML = this.user_notify_count = 0;
            return
        }
        $("notify_total").innerHTML = this.user_notify_count = a.total;
        var b = "<div style='margin-top: 10px;'>" + this.Base.Language.TranslateFormatted(1199, ["<span id='notifyscount'>" + a.total_grouped + "</span>"]) + "</div>";
        a.notifys.each(function (c) {
            b += "<div style='font-weight: bold; padding-top: 5px;' id='notify_" + c.notifytype_id + "_" + c.notify_grouped + "'><a href='javascript:void(0);' onClick=\"SocialEngine.Viewer.userNotifyDelete('" + c.notifytype_id + "', '" + c.notify_grouped + "');\">X</a><img src='./images/icons/" + c.notify_icon + "' border='0' style='border: none; margin: 0px 5px 0px 5px; display: inline; vertical-align: middle;' class='icon' /><a href='" + c.notify_url + "'>" + c.notify_text_output + "</a></div>"
        });
        $("newupdates_popup").innerHTML = b
    },
    userNotifyDelete: function (a, c) {
        var d = this;
        var b = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "notify_delete",
                notifytype_id: a,
                notify_grouped: c
            },
            onComplete: function (e, f) {
                $("TB_window").getElements("div[id=notify_" + a + "_" + c + "]").each(function (g) {
                    if (g.id == "notify_" + a + "_" + c) {
                        g.style.display = "none";
                        d.user_notify_count--
                    }
                });
                $("newupdates_popup").getElements("div[id=notify_" + a + "_" + c + "]").each(function (g) {
                    if (g.id == "notify_" + a + "_" + c) {
                        g.style.display = "none"
                    }
                });
                $("notify_total").innerHTML = d.user_notify_count;
                $("TB_window").getElements("span[id=notifyscount]").each(function (g) {
                    if (g.id == "notifyscount") {
                        g.innerHTML = d.user_notify_count
                    }
                });
                if (d.user_notify_count == 0) {
                    TB_remove();
                    $("newupdates").style.display = "none"
                }
            }
        }).send()
    },
    userNotifyHide: function () {
        $("newupdates").fade("out");
        this.user_notify_cookie.set("total", this.user_notify_count)
    },
    userPhotoRemove: function () {
        var b = this;
        var a = new Request.JSON({
            url: "user_editprofile_photo.php",
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "remove"
            }
        }).send();
        if ($("userEditRemovePhotoLink") && $("userEditPhotoImg")) {
            $("userEditRemovePhotoLink").destroy();
            $("userEditPhotoImg").src = "images/nophoto.gif";
            $("cropped").src = "images/nophoto_mini.gif";
            $("UserPhotoBig").src = "images/nophoto_mini.gif"
        } else {
            window.location.reload(false)
        }
    },
    ImportUserInfo: function (a) {
        if (!a || $type(a) != "object" || !a.user_exists) {
            this.user_exists = false;
            return
        }
        this.user_exists = true;
        a.user_id = parseInt(a.user_id);
        delete a.user_exists;
        this.user_info = a;
        this.user_info.user_fname = this.user_info.user_fname.trim();
        this.user_info.user_lname = this.user_info.user_lname.trim();
        if (this.user_info.user_fname && this.user_info.user_lname) {
            if (this.options.displayname_order == "asian") {
                this.user_displayname_short = this.user_info.user_lname;
                this.user_displayname = this.user_info.user_lname + " " + this.user_info.user_fname
            } else {
                this.user_displayname_short = this.user_info.user_fname;
                this.user_displayname = this.user_info.user_fname + " " + this.user_info.user_lname
            }
        } else {
            if (this.user_info.user_fname) {
                this.user_displayname = this.user_displayname_short = this.user_info.user_fname
            } else {
                if (this.user_info.user_lname) {
                    this.user_displayname = this.user_displayname_short = this.user_info.user_lname
                } else {
                    if (this.user_info.user_username) {
                        this.user_displayname = this.user_displayname_short = this.user_info.user_username
                    }
                }
            }
        }
    }
});
SocialEngineAPI.Tags = new Class({
    Implements: [Options],
    Base: {},
    isTagging: false,
    newtag: false,
    tags: [],
    options: {
        ajaxURL: "misc_js.php",
        ajaxMethod: "post",
        ajaxSecure: false,
        canTag: false,
        type: false,
        media_id: false,
        media_dir: false,
        object_owner: false,
        object_owner_id: false
    },
    initialize: function (a) {
        this.setOptions(a);
        if (this.options.initialTotal) {
            this.total = this.options.initialTotal
        }
        var b = this;
        window.addEvent("domready", function () {
            b.showTagForm()
        })
    },
    showTagForm: function () {
        var e = "";
        var d = this;
        if (this.options.canTag) {
            e += "<div class='media_photo_tagform_titlebar'><img src='images/icons/photos16.gif' class='icon' />" + this.Base.Language.Translate(1212) + "</div><div style='padding: 7px;'><div style='text-align: left;'><div style='font-size: 7pt; margin-bottom: 5px;'>" + this.Base.Language.Translate(1213) + "</div><div style='text-align: center;'><input type='text' style='width: 130px; padding-left: 4px; font-size: 8pt;' name='media_photo_tag' id='media_photo_tag' class='text' maxlength='40'/></div></div><div id='media_photo_friendlist' class='media_photo_friendlist'>";
            if (d.Base.Viewer.user_exists) {
                e += "<div><a href='javascript:void(0)' id='tag_me'>" + d.Base.Viewer.user_displayname + d.Base.Language.Translate(1214) + "</a></div>"
            }
            e += "</div><div><input type='button' class='button' name='save' id='tag_save' value='" + d.Base.Language.Translate(1215) + "' />&nbsp;&nbsp;<input type='button' class='button' id='tag_cancel' name='cancel' value='" + d.Base.Language.Translate(39) + "' /></div></div>";
            var a = new Element("div", {
                id: "media_photo_tagform",
                "class": "media_photo_tagform",
                html: e
            });
            var c = $("media_photo_div");
            a.inject(c);
            if (a.getElement("input[id=tag_cancel]")) {
                a.getElement("input[id=tag_cancel]").addEvent("click", function () {
                    d.cancelTag()
                })
            }
            if (a.getElement("input[id=tag_save]")) {
                a.getElement("input[id=tag_save]").addEvent("click", function () {
                    d.saveTag(0)
                })
            }
            if (a.getElement("a[id=tag_me]")) {
                a.getElement("a[id=tag_me]").addEvent("click", function () {
                    d.saveTag(d.Base.Viewer.user_info.user_id)
                })
            }
            var b = new Request.JSON({
                url: "misc_js.php?task=friends_all",
                secure: this.options.ajaxSecure,
                onComplete: function (f) {
                    d.addFriendToList(f.friends)
                }
            }).send()
        }
    },
    addFriendToList: function (a) {
        var b = this;
        a.each(function (f) {
            for (var c in f) {
                var e = new Element("div", {
                    id: "friend_div_" + c
                });
                var d = new Element("a", {
                    href: "javascript:void(0)",
                    id: "friend_link_" + c,
                    html: f[c]
                }).inject(e);
                e.inject($("media_photo_friendlist"));
                $("friend_link_" + c).addEvent("click", function () {
                    b.saveTag(c)
                })
            }
        })
    },
    insertTag: function (a, l, m, j, h, k, i, c) {
        var f = "";
        var g = this;
        if ($("media_tags").style.display == "none") {
            $("media_tags").style.display = "block"
        } else {
            if (g.tags.length != 0) {
                f = '<span id="tag_comma_' + a + '">, </span>'
            }
        }
        var d = new Element("span", {
            id: "full_tag_" + a,
            html: f
        });
        if (l != "") {
            var e = new Element("a", {
                href: l,
                id: "tag_link_" + a,
                html: m
            }).inject(d)
        } else {
            var e = new Element("span", {
                id: "tag_link_" + a,
                html: m,
                styles: {
                    cursor: "pointer"
                }
            }).inject(d)
        }
        if (g.Base.Viewer.user_exists && (g.Base.Viewer.user_info.user_username == c || g.Base.Viewer.user_info.user_username == g.Base.Owner.user_info.user_username)) {
            var b = $(d).get("html");
            $(d).set("html", b, " (<a href='javascript:void(0);' id='new_removetag_link'>" + g.Base.Language.Translate(1228) + "</a>)")
        }
        d.inject($("media_tags"));
        g.createTag(a, m, j, h, k, i);
        $("tag_link_" + a).addEvent("mouseover", function () {
            g.showTag(a)
        });
        $("tag_link_" + a).addEvent("mouseout", function () {
            g.hideTag(a)
        });
        if ($("new_removetag_link")) {
            $("new_removetag_link").addEvent("click", function () {
                g.removeTag(a)
            });
            $("new_removetag_link").set("id", "removetag_link_" + a)
        }
        g.tags.push(a)
    },
    createTag: function (f, d, c, b, e, a) {
        var g = this;
        new Element("div", {
            id: "tag_" + f,
            html: '<img src="./images/trans.gif" width="100%" height="100%" />',
            "class": "tag_div_hidden",
            styles: {
                width: (parseInt(e) - 4) + "px",
                height: (parseInt(a) - 4) + "px",
                top: c + "px",
                left: b + "px"
            }
        }).inject($("media_photo_div"));
        new Element("div", {
            id: "tag_label_" + f,
            html: d,
            "class": "tag_label",
            styles: {
                display: "none",
                top: (parseInt(c) + parseInt(a) + 10) + "px",
                left: b + "px"
            }
        }).inject($("media_photo_div"));
        $("tag_" + f).addEvent("mouseover", function () {
            g.showTag(f)
        });
        $("tag_" + f).addEvent("mouseout", function () {
            g.hideTag(f)
        })
    },
    showTag: function (a) {
        $("tag_" + a).className = "tag_div";
        $("tag_label_" + a).style.display = "block"
    },
    hideTag: function (a) {
        $("tag_" + a).className = "tag_div_hidden";
        $("tag_label_" + a).style.display = "none"
    },
    addTag: function () {
        if (!this.isTagging) {
            this.isTagging = true;
            this.newtag = new MooCrop("media_photo");
            var b = this;
            var a = $("media_photo_tagform").inject(b.newtag.wrapper);
            a.setStyles({
                top: this.newtag.crop.bottom + 10,
                left: this.newtag.crop.right + 10,
                display: "block"
            });
            this.newtag.addEvent("onBegin", function (f, e, d, c) {
                a.setStyle("display", "none")
            });
            this.newtag.addEvent("onCrop", function (f, e, d, c) {
                a.setStyles({
                    top: e.bottom + 10,
                    left: e.right + 10,
                    display: "none"
                })
            });
            this.newtag.addEvent("onComplete", function (f, e, d, c) {
                a.setStyle("display", "block")
            })
        }
    },
    cancelTag: function () {
        if (this.isTagging) {
            $("media_photo_tag").value = "";
            $("media_photo_tagform").inject("media_photo_div").setStyle("display", "none");
            var a = this.newtag.removeOverlay.bind(this.newtag);
            a();
            this.isTagging = false
        }
    },
    saveTag: function (d) {
        if (this.isTagging) {
            if (this.options.object_owner && this.options.object_owner_id) {
                var f = this.options.object_owner;
                var b = this.options.object_owner_id;
                var c = ""
            } else {
                var f = "";
                var b = "";
                var c = this.Base.Owner.user_info.user_username
            }
            var g = this;
            var e = new Request.JSON({
                url: this.options.ajaxURL,
                method: this.options.ajaxMethod,
                secure: this.options.ajaxSecure,
                data: {
                    task: "tag_do",
                    ajax: true,
                    mediatag_user_id: d,
                    mediatag_text: $("media_photo_tag").value,
                    mediatag_x: this.newtag.crop.top,
                    mediatag_y: this.newtag.crop.left,
                    mediatag_height: this.newtag.crop.height,
                    mediatag_width: this.newtag.crop.width,
                    user: c,
                    object_owner: f,
                    object_owner_id: b,
                    type: this.options.type,
                    media_id: this.options.media_id,
                    media_dir: this.options.media_dir
                },
                onComplete: function (h) {
                    if ($type(h.mediatag_id)) {
                        g.insertTag(h.mediatag_id, h.mediatag_link, h.mediatag_text, h.mediatag_x, h.mediatag_y, h.mediatag_width, h.mediatag_height, h.mediatag_user_username)
                    }
                }
            }).send();
            $("media_photo_tag").value = "";
            $("media_photo_tagform").inject("media_photo_div").setStyle("display", "none");
            var a = this.newtag.removeOverlay.bind(this.newtag);
            a();
            this.isTagging = false
        }
    },
    removeTag: function (e) {
        if (this.options.object_owner && this.options.object_owner_id) {
            var d = this.options.object_owner;
            var a = this.options.object_owner_id;
            var b = ""
        } else {
            var d = "";
            var a = "";
            var b = this.Base.Owner.user_info.user_username
        }
        var f = this;
        var c = new Request.JSON({
            url: this.options.ajaxURL,
            method: this.options.ajaxMethod,
            secure: this.options.ajaxSecure,
            data: {
                task: "tag_remove",
                ajax: true,
                mediatag_id: e,
                user: b,
                object_owner: d,
                object_owner_id: a,
                type: this.options.type,
                media_id: this.options.media_id
            }
        }).send();
        $("tag_" + e).destroy();
        $("tag_label_" + e).destroy();
        $("full_tag_" + e).destroy();
        if (this.tags.indexOf(e) == 0 && $("tag_comma_" + this.tags[1])) {
            $("tag_comma_" + this.tags[1]).destroy()
        }
        this.tags.splice(this.tags.indexOf(e), 1);
        if (this.tags.length == 0) {
            $("media_tags").style.display = "none"
        }
    }
});
var MooCrop = new Class({
    calculateHandles: true,
    current: {},
    options: {
        maskColor: "black",
        maskOpacity: ".3",
        handleColor: "#FFFFFF",
        handleWidth: "5px",
        handleHeight: "5px",
        cropBorder: "1px dashed #FFFFFF",
        min: {
            width: 50,
            height: 50
        },
        showMask: true,
        showHandles: false
    },
    initialize: function (b, a) {
        this.setOptions(a);
        this.img = $(b);
        if (this.img.get("tag") != "img") {
            return false
        }
        this.resizeFunc = this.refresh.bindWithEvent(this);
        this.removeFunc = this.removeListener.bind(this);
        this.buildOverlay();
        this.setup()
    },
    setup: function () {
        $(this.cropArea).setStyles({
            width: this.options.min.width,
            height: this.options.min.height,
            top: (this.img.height - this.options.min.height) / 2,
            left: (this.img.width - this.options.min.width) / 2
        });
        this.current.crop = this.crop = this.getCropArea();
        this.handleWidthOffset = this.options.handleWidth.toInt() / 2;
        this.handleHeightOffset = this.options.handleHeight.toInt() / 2;
        this.fixBoxModel();
        this.drawMasks();
        this.positionHandles()
    },
    getCropArea: function () {
        var a = this.cropArea.getCoordinates();
        a.left -= this.offsets.x;
        a.right -= this.offsets.x;
        a.top -= this.offsets.y;
        a.bottom -= this.offsets.y;
        return a
    },
    fixBoxModel: function () {
        var c = this.boxDiff = (this.crop.width - this.options.min.width) / 2;
        var a = this.bounds = {
            top: c,
            left: c,
            right: this.img.width + (c * 2),
            bottom: this.img.height + (c * 2),
            width: this.options.min.width + (c * 2),
            height: this.options.min.height + (c * 2)
        };
        this.wrapper.setStyles({
            width: a.right,
            height: a.bottom,
            background: "url(" + this.img.src + ") no-repeat " + c + "px " + c + "px"
        });
        this.north.setStyle("width", a.right);
        this.south.setStyle("width", a.right)
    },
    activate: function (a, b) {
        a.stop();
        this.current = {
            x: a.page.x,
            y: a.page.y,
            handle: b,
            crop: this.current.crop
        };
        if (this.current.handle == "NESW" && !this.options.showHandles) {
            this.hideHandles()
        }
        this.fireEvent("onBegin", [this.img.src, this.getCropInfo(), this.bounds, b]);
        document.addEvent("mousemove", this.resizeFunc);
        document.addEvent("mouseup", this.removeFunc)
    },
    removeListener: function () {
        if (this.current.handle == "NESW" && !this.options.showHandles) {
            this.showHandles()
        }
        document.removeEvent("mousemove", this.resizeFunc);
        document.removeEvent("mouseup", this.removeFunc);
        this.crop = this.current.crop;
        this.fireEvent("onComplete", [this.img.src, this.getCropInfo(), this.bounds, this.current.handle])
    },
    refresh: function (a) {
        var e = this.current.x - a.page.x;
        var d = this.current.y - a.page.y;
        var i = this.bounds;
        var h = this.crop;
        var f = this.current.handle;
        var k = {};
        var j = (f.length > 2) ? true : false;
        if (f.contains("S")) {
            if (h.bottom - d > i.bottom) {
                d = h.bottom - i.bottom
            }
            if (!j) {
                if ((h.height - d) < i.height) {
                    d = h.height - i.height
                }
                k.height = h.height - d
            }
        }
        if (f.contains("N")) {
            if (h.top - d < i.top) {
                d = h.top
            }
            if (!j) {
                if ((h.height + d) < i.height) {
                    d = i.height - h.height
                }
                k.height = h.height + d
            }
            k.top = h.top - d
        }
        if (f.contains("E")) {
            if (h.right - e > i.right) {
                e = h.right - i.right
            }
            if (!j) {
                if ((h.width - e) < i.width) {
                    e = h.width - i.width
                }
                k.width = h.width - e
            }
        }
        if (f.contains("W")) {
            if (h.left - e < i.left) {
                e = h.left
            }
            if (!j) {
                if ((h.width + e) < i.width) {
                    e = i.width - h.width
                }
                k.width = h.width + e
            }
            k.left = h.left - e
        }
        var g = $merge(k);
        if ($defined(k.width)) {
            k.width -= this.boxDiff * 2
        }
        if ($defined(k.height)) {
            k.height -= this.boxDiff * 2
        }
        this.cropArea.setStyles(k);
        this.getCurrentCoords(g);
        this.drawMasks();
        this.positionHandles();
        this.fireEvent("onCrop", [this.img.src, this.getCropInfo(), i, f])
    },
    getCurrentCoords: function (b) {
        var a = $merge(this.crop);
        if ($defined(b.left)) {
            a.left = b.left;
            if ($defined(b.width)) {
                a.width = b.width
            } else {
                a.right = a.left + a.width
            }
        }
        if ($defined(b.top)) {
            a.top = b.top;
            if ($defined(b.height)) {
                a.height = b.height
            } else {
                a.bottom = a.top + a.height
            }
        }
        if ($defined(b.width) && !$defined(b.left)) {
            a.width = b.width;
            a.right = a.left + a.width
        }
        if ($defined(b.height) && !$defined(b.top)) {
            a.height = b.height;
            a.bottom = a.top + a.height
        }
        this.current.crop = a
    },
    drawMasks: function () {
        if (!this.options.showMask) {
            return
        }
        var a = this.bounds;
        var e = this.current.crop;
        var d = this.current.handle;
        this.north.setStyle("height", e.top + "px");
        this.south.setStyle("height", a.bottom - e.bottom + "px");
        this.east.setStyles({
            height: e.height + "px",
            width: a.right - e.right + "px",
            top: e.top + "px",
            left: e.right + "px"
        });
        this.west.setStyles({
            height: e.height + "px",
            width: e.left + "px",
            top: e.top + "px"
        })
    },
    positionHandles: function () {
        if (!this.calculateHandles) {
            return
        }
        var d = this.current.crop;
        var a = this.handleWidthOffset;
        var b = this.handleHeightOffset;
        this.handles.get("N").setStyles({
            left: d.width / 2 - a + "px",
            top: -b + "px"
        });
        this.handles.get("NE").setStyles({
            left: d.width - a + "px",
            top: -b + "px"
        });
        this.handles.get("E").setStyles({
            left: d.width - a + "px",
            top: d.height / 2 - b + "px"
        });
        this.handles.get("SE").setStyles({
            left: d.width - a + "px",
            top: d.height - b + "px"
        });
        this.handles.get("S").setStyles({
            left: d.width / 2 - a + "px",
            top: d.height - b + "px"
        });
        this.handles.get("SW").setStyles({
            left: -a + "px",
            top: d.height - b + "px"
        });
        this.handles.get("W").setStyles({
            left: -a + "px",
            top: d.height / 2 - b + "px"
        });
        this.handles.get("NW").setStyles({
            left: -a + "px",
            top: -b + "px"
        })
    },
    hideHandles: function () {
        this.calculateHandles = false;
        this.handles.each(function (a) {
            a.setStyle("display", "none")
        })
    },
    showHandles: function () {
        this.calculateHandles = true;
        this.positionHandles();
        this.handles.each(function (a) {
            a.setStyle("display", "block")
        })
    },
    buildOverlay: function () {
        var b = this.options;
        this.wrapper = new Element("div", {
            styles: {
                "z-index": 100,
                position: "relative",
                width: this.img.width,
                height: this.img.height,
                background: "url(" + this.img.src + ") no-repeat",
                "float": this.img.getStyle("float"),
                "margin-left": "auto",
                "margin-right": "auto"
            }
        }).injectBefore(this.img);
        this.img.setStyle("display", "none");
        this.offsets = {
            x: this.wrapper.getLeft(),
            y: this.wrapper.getTop()
        };
        this.wrapper.addEvent("mouseover", function (c) {
            return false
        });
        if (this.options.showMask) {
            var a = {
                position: "absolute",
                overflow: "hidden",
                "background-color": b.maskColor,
                opacity: b.maskOpacity
            };
            this.north = new Element("div", {
                styles: $merge(a, {
                    left: "0px"
                })
            }).injectInside(this.wrapper);
            this.south = new Element("div", {
                styles: $merge(a, {
                    bottom: "0px",
                    left: "0px"
                })
            }).injectInside(this.wrapper);
            this.east = new Element("div", {
                styles: a
            }).injectInside(this.wrapper);
            this.west = new Element("div", {
                styles: $merge(a, {
                    left: "0px"
                })
            }).injectInside(this.wrapper)
        }
        this.cropArea = new Element("div", {
            styles: {
                position: "absolute",
                top: "0px",
                left: "0px",
                border: b.cropBorder,
                cursor: "move"
            },
            events: {
                dblclick: function () {
                    this.fireEvent("onDblClk", [this.img.src, this.getCropInfo(), this.bounds])
                }.bind(this),
                mousedown: this.activate.bindWithEvent(this, "NESW")
            }
        }).injectInside(this.wrapper);
        this.handles = new Hash();
        ["N", "NE", "E", "SE", "S", "SW", "W", "NW"].each(function (c) {
            this.handles.set(c, new Element("div", {
                styles: {
                    position: "absolute",
                    "background-color": b.handleColor,
                    width: b.handleWidth,
                    height: b.handleHeight,
                    overflow: "hidden",
                    cursor: (c.toLowerCase() + "-resize")
                },
                events: {
                    mousedown: this.activate.bindWithEvent(this, c)
                }
            }).injectInside(this.cropArea))
        }, this)
    },
    getCropInfo: function () {
        var a = $merge(this.current.crop);
        a.width -= this.boxDiff * 2;
        a.height -= this.boxDiff * 2;
        return a
    },
    removeOverlay: function () {
        this.wrapper.destroy();
        this.img.setStyle("display", "")
    }
});
MooCrop.implement(new Events, new Options);
theObjects = document.getElementsByTagName("object");
for (var i = 0; i < theObjects.length; i++) {
    theObjects[i].outerHTML = theObjects[i].outerHTML
};
Function.prototype.bind = function (b) {
    var c = this,
        a = function () {
        return c.apply(b, arguments)
    };
    return (a)
};
SEMods = function () {};
SEMods.TextAreaControl = function (a) {
    this.obj = a;
    this.obj.style.overflow = "hidden";
    this.originalHeight = this.obj.getStyle("height").toInt();
    var b = this.update.bind(this);
    a.addEvent("focus", this.onFocus.bind(this));
    a.addEvent("blur", this.onBlur.bind(this));
    this.update()
};
SEMods.TextAreaControl.prototype = {
    obj: null,
    updating: false,
    autoGrow: false,
    originalHeight: null,
    shadowElement: null,
    increment: 0,
    timer: null,
    lastLength: 0,
    setAutoGrow: function (a) {
        this.autoGrow = a;
        this.createShadowElement();
        this.update()
    },
    onUpdate: function () {
        if (this.autoGrow && this.lastLength != this.obj.value.length) {
            this.lastLength = this.obj.value.length;
            this.updateShadowElement();
            this.obj.style.height = Math.max(this.originalHeight, this.shadowElement.offsetHeight + this.increment) + "px"
        }
    },
    beginUpdate: function () {
        if (this.updating) {
            return false
        }
        this.updating = true;
        return true
    },
    endUpdate: function () {
        this.updating = false
    },
    update: function () {
        if (!this.beginUpdate()) {
            return
        }
        this.onUpdate();
        this.endUpdate()
    },
    createShadowElement: function () {
        if (this.shadowElement) {
            return
        }
        this.shadowElement = document.createElement("DIV");
        this.shadowElement.style.position = "absolute";
        this.shadowElement.style.top = "-99999px";
        this.shadowElement.style.left = "-99999px";
        document.body.appendChild(this.shadowElement)
    },
    updateShadowElement: function () {
        if (this.shadowElement) {
            text = this.obj.value + "<br>";
            this.shadowElement.innerHTML = text.toString().replace(/&/g, "&amp;").replace(/"/g, "&quot;").replace(/'/g, "&#039;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/\n/g, "<br />");
            var b = this.getPXMetrics(this.obj.getStyle("font-size"), 10);
            var a = this.obj.getStyle("line-height");
            if ((/Opera/i.test(navigator.userAgent))) {
                a = this.getPXMetrics(a, 0) + 3 + "px"
            }
            this.increment = b + 10;
            this.shadowElement.style.width = this.obj.offsetWidth + "px";
            this.shadowElement.style.lineHeight = a;
            this.shadowElement.style.fontSize = this.obj.getStyle("font-size");
            this.shadowElement.style.fontFamily = this.obj.getStyle("font-family");
            this.shadowElement.style.paddingLeft = this.obj.getStyle("padding-left");
            this.shadowElement.style.paddingRight = this.obj.getStyle("padding-right")
        }
    },
    onFocus: function () {
        this.timer = setInterval(this.update.bind(this), 500)
    },
    onBlur: function () {
        if (this.timer) {
            clearInterval(this.timer);
            this.timer = null
        }
    },
    getPXMetrics: function (c, b) {
        var a = parseFloat(c);
        if (isNaN(a)) {
            return b != null ? b : a
        }
        return /px/i.test(c) ? a : /pt/i.test(c) ? 1.3333 * a : a
    }
};

function textarea_autogrow(a) {
    var b = $(a);
    if (b && !b._controlled) {
        b._controlled = true;
        new SEMods.TextAreaControl(b).setAutoGrow(true);
        return b.getStyle("height").toInt()
    }
};
if (typeof(bsn) == "undefined") {
    _b = bsn = {}
}
if (typeof(_b.Autosuggest) == "undefined") {
    _b.Autosuggest = {}
} else {
    alert("Autosuggest is already set!")
}
_b.AutoSuggest = function (e, d) {
    if (!document.getElementById) {
        return 0
    }
    this.fld = _b.DOM.gE(e);
    if (!this.fld) {
        return 0
    }
    this.sInp = "";
    this.nInpC = 0;
    this.aSug = [];
    this.iHigh = 0;
    this.oP = d ? d : {};
    var a, b = {
        minchars: 1,
        meth: "get",
        varname: "input",
        className: "autosuggest",
        timeout: 2500,
        delay: 0,
        offsety: -5,
        shownoresults: true,
        noresults: "No results!",
        maxheight: 250,
        cache: true,
        maxentries: 25,
        blurtrigger: false,
        multisuggest: true
    };
    for (a in b) {
        if (typeof(this.oP[a]) != typeof(b[a])) {
            this.oP[a] = b[a]
        }
    }
    var c = this;
    this.fld.onkeypress = function (f) {
        return c.onKeyPress(f)
    };
    this.fld.onkeyup = function (f) {
        return c.onKeyUp(f)
    };
    if (typeof(this.oP.callback) == "function" && this.oP.blurtrigger) {
        this.fld.onblur = function (g) {
            if (document.activeElement && typeof(g) === "undefined") {
                var f = document.activeElement
            } else {
                var f = g.explicitOriginalTarget;
                while (f.parentNode) {
                    if (f.tagName == "A" && typeof(f.id) == "string") {
                        if (f.id.substring(0, 10) == "bsnsuggest") {
                            break
                        }
                    }
                    f = f.parentNode
                }
                if (typeof(f.id) != "string") {
                    f.id = ""
                }
            }
            if (f.id.substring(0, 10) != "bsnsuggest") {
                c.oP.callback({
                    id: c.fld.value,
                    value: c.fld.value
                });
                c.clearSuggestions()
            }
        }
    }
    this.fld.setAttribute("autocomplete", "off")
};
_b.AutoSuggest.prototype.onKeyPress = function (f) {
    var e = (window.event) ? window.event.keyCode : f.keyCode;
    var d = 13;
    var c = 9;
    var g = 27;
    var b = 186;
    var a = 1;
    switch (e) {
    case d:
        if (this.aSug.length != 0 && this.iHigh) {
            this.setHighlightedValue();
            a = false
        } else {
            if (this.fld.value.length > 0) {
                if (typeof(this.oP.callback) == "function") {
                    this.clearSuggestions();
                    this.oP.callback({
                        id: this.fld.value,
                        value: this.fld.value
                    })
                }
                a = false
            } else {
                a = false
            }
        }
        break;
    case g:
        this.clearSuggestions();
        break
    }
    return a
};
_b.AutoSuggest.prototype.onKeyUp = function (f) {
    var d = (window.event) ? window.event.keyCode : f.keyCode;
    var c = 38;
    var e = 40;
    var a = 1;
    switch (d) {
    case c:
        this.changeHighlight(d);
        a = 0;
        break;
    case e:
        this.changeHighlight(d);
        a = 0;
        break;
    default:
        var b = this.fld.value.split(/[;]+/ig);
        this.getSuggestions(b[b.length - 1])
    }
    return a
};
_b.AutoSuggest.prototype.getSuggestions = function (g) {
    if (g == this.sInp) {
        return 0
    }
    _b.DOM.remE(this.idAs);
    this.sInp = g;
    if (g.length < this.oP.minchars) {
        this.aSug = [];
        this.nInpC = g.length;
        return 0
    }
    var d = this.nInpC;
    this.nInpC = g.length ? g.length : 0;
    var b = this.aSug.length;
    if (this.nInpC > d && b && b < this.oP.maxentries && this.oP.cache) {
        var a = [];
        for (var e = 0; e < b; e++) {
            if (this.aSug[e].value.substr(0, g.length).toLowerCase() == g.toLowerCase() || this.aSug[e].info.substr(0, g.length).toLowerCase() == g.toLowerCase()) {
                a.push(this.aSug[e])
            }
        }
        this.aSug = a;
        if (this.aSug.length < b) {
            var f = this;
            var c = this.sInp;
            clearTimeout(this.ajID);
            this.ajID = setTimeout(function () {
                f.doAjaxRequest(c)
            }, this.oP.delay)
        } else {
            this.createList(this.aSug)
        }
        return false
    } else {
        var f = this;
        var c = this.sInp;
        clearTimeout(this.ajID);
        this.ajID = setTimeout(function () {
            f.doAjaxRequest(c)
        }, this.oP.delay)
    }
    return false
};
_b.AutoSuggest.prototype.doAjaxRequest = function (c) {
    var e = this.fld.value.split(/[;]+/ig);
    if (c != e[e.length - 1]) {
        return false
    }
    var h = this;
    if (typeof(this.oP.script) == "function") {
        var d = this.oP.script(encodeURIComponent(this.sInp))
    } else {
        var d = this.oP.script + this.oP.varname + "=" + encodeURIComponent(this.sInp)
    }
    if (!d) {
        return false
    }
    var b = this.oP.meth;
    var c = this.sInp;
    var a = function (i) {
        h.setSuggestions(i, c)
    };
    var f = function (i) {};
    var g = new _b.Ajax();
    g.makeRequest(d, b, a, f)
};
_b.AutoSuggest.prototype.setSuggestions = function (req, input) {
    var new_value = this.fld.value.split(/[;]+/ig);
    if (input != new_value[new_value.length - 1]) {
        return false
    }
    this.aSug = [];
    if (this.oP.json) {
        var jsondata = eval("(" + req.responseText + ")");
        for (var i = 0; i < jsondata.results.length; i++) {
            this.aSug.push({
                id: jsondata.results[i].id,
                value: jsondata.results[i].value,
                info: jsondata.results[i].info,
                photo: jsondata.results[i].photo,
                photo_width: jsondata.results[i].photo_width
            })
        }
    } else {
        var xml = req.responseXML;
        var results = xml.getElementsByTagName("results")[0].childNodes;
        for (var i = 0; i < results.length; i++) {
            if (results[i].hasChildNodes()) {
                this.aSug.push({
                    id: results[i].getAttribute("id"),
                    value: results[i].childNodes[0].nodeValue,
                    info: results[i].getAttribute("info")
                })
            }
        }
    }
    this.idAs = "as_" + this.fld.id;
    this.createList(this.aSug)
};
_b.AutoSuggest.prototype.createList = function (b) {
    var r = this;
    _b.DOM.remE(this.idAs);
    this.killTimeout();
    if (b.length == 0 && !this.oP.shownoresults) {
        return false
    }
    var m = _b.DOM.cE("div", {
        id: this.idAs,
        className: this.oP.className
    });
    var e = _b.DOM.cE("div", {
        className: "as_corner"
    });
    var h = _b.DOM.cE("div", {
        className: "as_bar"
    });
    var t = _b.DOM.cE("div", {
        className: "as_header"
    });
    t.appendChild(e);
    t.appendChild(h);
    m.appendChild(t);
    var l = _b.DOM.cE("ul", {
        id: "as_ul"
    });
    for (var u = 0; u < b.length; u++) {
        var z = b[u].value;
        var x = b[u].info;
        var q = z.toLowerCase().indexOf(this.sInp.toLowerCase());
        var c = x.toLowerCase().indexOf(this.sInp.toLowerCase());
        if (q != -1) {
            var j = z.substring(0, q) + "<em>" + z.substring(q, q + this.sInp.length) + "</em>" + z.substring(q + this.sInp.length);
            var p = x
        } else {
            var j = z;
            var p = x.substring(0, c) + "<em>" + x.substring(q, c + this.sInp.length) + "</em>" + x.substring(c + this.sInp.length)
        }
        if (z != x) {
            j = p + " (" + j + ")"
        }
        var s = _b.DOM.cE("span", {}, j, true);
        var n = _b.DOM.cE("img", {
            src: b[u].photo,
            width: b[u].photo_width,
            border: "0"
        });
        n.removeAttribute("height");
        s.insertBefore(n, s.childNodes[0]);
        var w = _b.DOM.cE("a", {
            href: "javascript:void(0);"
        });
        var f = _b.DOM.cE("span", {
            className: "tl"
        }, " ");
        var d = _b.DOM.cE("span", {
            className: "tr"
        }, " ");
        w.appendChild(f);
        w.appendChild(d);
        w.appendChild(s);
        w.name = u + 1;
        w.id = "bsnsuggest_" + (u + 1);
        w.onclick = function () {
            r.setHighlightedValue();
            return false
        };
        w.onmouseover = function () {
            r.setHighlight(this.name)
        };
        var k = _b.DOM.cE("li", {}, w);
        l.appendChild(k)
    }
    if (b.length == 0 && this.oP.shownoresults) {
        var k = _b.DOM.cE("li", {
            className: "as_warning"
        }, this.oP.noresults);
        l.appendChild(k)
    }
    m.appendChild(l);
    var v = _b.DOM.cE("div", {
        className: "as_corner"
    });
    var y = _b.DOM.cE("div", {
        className: "as_bar"
    });
    var o = _b.DOM.cE("div", {
        className: "as_footer"
    });
    o.appendChild(v);
    o.appendChild(y);
    m.appendChild(o);
    var g = _b.DOM.getPos(this.fld);
    m.style.left = g.x + "px";
    m.style.top = (g.y + this.fld.offsetHeight + this.oP.offsety) + "px";
    m.style.width = this.fld.offsetWidth + "px";
    m.onmouseover = function () {
        r.killTimeout()
    };
    m.onmouseout = function () {
        r.resetTimeout()
    };
    document.getElementsByTagName("body")[0].appendChild(m);
    this.iHigh = 0;
    var r = this;
    this.toID = setTimeout(function () {
        r.clearSuggestions()
    }, this.oP.timeout)
};
_b.AutoSuggest.prototype.changeHighlight = function (a) {
    var b = _b.DOM.gE("as_ul");
    if (!b) {
        return false
    }
    var c;
    if (a == 40) {
        c = this.iHigh + 1
    } else {
        if (a == 38) {
            c = this.iHigh - 1
        }
    }
    if (c > b.childNodes.length) {
        c = b.childNodes.length
    }
    if (c < 1) {
        c = 1
    }
    this.setHighlight(c)
};
_b.AutoSuggest.prototype.setHighlight = function (b) {
    var a = _b.DOM.gE("as_ul");
    if (!a) {
        return false
    }
    if (this.iHigh > 0) {
        this.clearHighlight()
    }
    this.iHigh = Number(b);
    a.childNodes[this.iHigh - 1].className = "as_highlight";
    this.killTimeout()
};
_b.AutoSuggest.prototype.clearHighlight = function () {
    var a = _b.DOM.gE("as_ul");
    if (!a) {
        return false
    }
    if (this.iHigh > 0) {
        a.childNodes[this.iHigh - 1].className = "";
        this.iHigh = 0
    }
};
_b.AutoSuggest.prototype.setHighlightedValue = function () {
    if (this.iHigh) {
        var a = this.fld.value.split(/[;]+/ig);
        a.pop();
        a.push(this.aSug[this.iHigh - 1].value);
        if (this.oP.multisuggest) {
            var b = ";"
        } else {
            var b = ""
        }
        this.sInp = this.fld.value = a.join(";") + b;
        this.fld.focus();
        if (this.fld.selectionStart) {
            this.fld.setSelectionRange(this.sInp.length, this.sInp.length)
        }
        if (typeof(this.oP.callback) == "function") {
            this.oP.callback(this.aSug[this.iHigh - 1])
        }
        this.clearSuggestions()
    }
};
_b.AutoSuggest.prototype.killTimeout = function () {
    clearTimeout(this.toID)
};
_b.AutoSuggest.prototype.resetTimeout = function () {
    clearTimeout(this.toID);
    var a = this;
    this.toID = setTimeout(function () {
        a.clearSuggestions()
    }, 1000)
};
_b.AutoSuggest.prototype.clearSuggestions = function () {
    this.killTimeout();
    this.aSug = [];
    var a = _b.DOM.gE(this.idAs);
    var c = this;
    if (a) {
        var b = new _b.Fader(a, 1, 0, 250, function () {
            _b.DOM.remE(c.idAs)
        })
    }
};
if (typeof(_b.Ajax) == "undefined") {
    _b.Ajax = {}
}
_b.Ajax = function () {
    this.req = {};
    this.isIE = false
};
_b.Ajax.prototype.makeRequest = function (c, b, a, d) {
    if (b != "POST") {
        b = "GET"
    }
    this.onComplete = a;
    this.onError = d;
    var e = this;
    if (window.XMLHttpRequest) {
        this.req = new XMLHttpRequest();
        this.req.onreadystatechange = function () {
            e.processReqChange()
        };
        this.req.open("GET", c, true);
        this.req.send(null)
    } else {
        if (window.ActiveXObject) {
            this.req = new ActiveXObject("Microsoft.XMLHTTP");
            if (this.req) {
                this.req.onreadystatechange = function () {
                    e.processReqChange()
                };
                this.req.open(b, c, true);
                this.req.send()
            }
        }
    }
};
_b.Ajax.prototype.processReqChange = function () {
    if (this.req.readyState == 4) {
        if (this.req.status == 200) {
            this.onComplete(this.req)
        } else {
            this.onError(this.req.status)
        }
    }
};
if (typeof(_b.DOM) == "undefined") {
    _b.DOM = {}
}
_b.DOM.cE = function (g, c, b, f) {
    var h = document.createElement(g);
    if (!h) {
        return 0
    }
    for (var d in c) {
        h[d] = c[d]
    }
    var e = typeof(b);
    if (e == "string" && !f) {
        h.appendChild(document.createTextNode(b))
    } else {
        if (e == "string" && f) {
            h.innerHTML = b
        } else {
            if (e == "object") {
                h.appendChild(b)
            }
        }
    }
    return h
};
_b.DOM.gE = function (c) {
    var a = typeof(c);
    if (a == "undefined") {
        return 0
    } else {
        if (a == "string") {
            var b = document.getElementById(c);
            if (!b) {
                return 0
            } else {
                if (typeof(b.appendChild) != "undefined") {
                    return b
                } else {
                    return 0
                }
            }
        } else {
            if (typeof(c.appendChild) != "undefined") {
                return c
            } else {
                return 0
            }
        }
    }
};
_b.DOM.remE = function (a) {
    var b = this.gE(a);
    if (!b) {
        return 0
    } else {
        if (b.parentNode.removeChild(b)) {
            return true
        } else {
            return 0
        }
    }
};
_b.DOM.getPos = function (c) {
    var c = this.gE(c);
    var b = c;
    var d = 0;
    if (b.offsetParent) {
        while (b.offsetParent) {
            d += b.offsetLeft;
            b = b.offsetParent
        }
    } else {
        if (b.x) {
            d += b.x
        }
    }
    var b = c;
    var a = 0;
    if (b.offsetParent) {
        while (b.offsetParent) {
            a += b.offsetTop;
            b = b.offsetParent
        }
    } else {
        if (b.y) {
            a += b.y
        }
    }
    return {
        x: d,
        y: a
    }
};
if (typeof(_b.Fader) == "undefined") {
    _b.Fader = {}
}
_b.Fader = function (b, f, e, a, d) {
    if (!b) {
        return 0
    }
    this.e = b;
    this.from = f;
    this.to = e;
    this.cb = d;
    this.nDur = a;
    this.nInt = 50;
    this.nTime = 0;
    var c = this;
    this.nID = setInterval(function () {
        c._fade()
    }, this.nInt)
};
_b.Fader.prototype._fade = function () {
    this.nTime += this.nInt;
    var a = Math.round(this._tween(this.nTime, this.from, this.to, this.nDur) * 100);
    var c = a / 100;
    if (this.e.filters) {
        try {
            this.e.filters.item("DXImageTransform.Microsoft.Alpha").opacity = a
        } catch (b) {
            this.e.style.filter = "progid:DXImageTransform.Microsoft.Alpha(opacity=" + a + ")"
        }
    } else {
        this.e.style.opacity = c
    }
    if (this.nTime == this.nDur) {
        clearInterval(this.nID);
        if (this.cb != undefined) {
            this.cb()
        }
    }
};
_b.Fader.prototype._tween = function (e, a, g, f) {
    return a + ((g - a) * (e / f))
};
TB_WIDTH = 0;
TB_HEIGHT = 0;
var TB_doneOnce = 0;
var TB_ready = false;
var TB_useReady = true;

function TB_init() {
    TB_ready = true;
    $$("a.smoothbox").each(function (a) {
        a.onclick = TB_bind
    })
}
if(window.ie){
window.addEvent('load', TB_init);
}else{
window.addEvent('domready', TB_init);
}

function TB_bind(b) {
    if (TB_useReady && !TB_ready) {
        return
    }
    var b = new Event(b);
    b.preventDefault();
    this.blur();
    var a = this.title || this.name || "";
    var c = this.rel || false;
    TB_show(a, this.href, c);
    this.onclick = TB_bind;
    return false
}
function TB_show(j, b, k, e, h) {
    if (TB_useReady && !TB_ready) {
        return
    }
    if (!h) {
        h = 0
    }
    
    //Hide all flash and ÒselectÓ objects
    //TB_objectHide(true);
    
    
    if (!$("TB_overlay")) {
        (new Element("div").setProperty("id", "TB_overlay")).inject($("smoothbox_container") || document.body);
        $("TB_overlay").setOpacity(0.6);
        TB_overlaySize()
    }
    
    /*if (!$("TB_load")) {
	  new Element('div').setProperty('id', 'TB_load').inject($("smoothbox_container") || document.body);
	  $('TB_load').innerHTML = "<img src='./images/tbex_loadingAnimation.gif' alt='Loading' />";
	}
	
	$('TB_load').setStyle('display','block');*/
    
    if (!$("TB_window")) {
        (new Element("div").setProperty("id", "TB_window")).inject($("smoothbox_container") || document.body);
        $("TB_window").setOpacity(0)
    } else {
        $("TB_window").destroy();
        (new Element("div").setProperty("id", "TB_window")).inject($("smoothbox_container") || document.body);
        $("TB_window").setOpacity(0)
    }
    

	
    if (h == 0) {
        $("TB_overlay").onclick = TB_remove
    } else {
        $("TB_overlay").onclick = ""
    }
    window.onscroll = TB_position;
    var c = b.match(/(.+)?/)[1] || b;
    var a = b.match(/\?(.+)/)[1];
    var f = TB_parseQuery(a);
    TB_WIDTH = (f.width * 1) + 30;
    TB_HEIGHT = (f.height * 1) + 40;
    var d = TB_WIDTH - 30,
        i = TB_HEIGHT - 45;
        
        
if (b.indexOf("TB_iframe") != -1) {
        urlNoQuery = b.split("TB_");
        $("TB_window").innerHTML += "<div id='TB_title'><div id='TB_ajaxWindowTitle'>" + j + "</div><div id='TB_closeAjaxWindow'><a href='#' id='TB_closeWindowButton'>X</a></div></div><div id='TB_gum_frame' style='width:" + d + "px;height:" + i + "px;position:relative;top:-1;left:0;'><iframe src='" + urlNoQuery[0] + "&in_smoothbox=true' id='TB_iframeContent' name='TB_iframeContent' scrolling='auto' style='width:" + (d + 29) + "px;height:" + (i) + "px;border:0;' onload='TB_showWindow()'> </iframe></div>";
    }
    else
    {
      $("TB_window").innerHTML += "<div id='TB_title'><div id='TB_ajaxWindowTitle'>" + j + "</div><div id='TB_closeAjaxWindow'><a href='#' id='TB_closeWindowButton'>X</a></div></div><div id='TB_ajaxContent' style='width:" + d + "px;height:" + i + "px;'></div>";
    }
    
    if(window.webkit)
     $("TB_iframeContent").src = urlNoQuery;
    
    $("TB_closeWindowButton").onclick = TB_remove;
    if (b.indexOf("TB_inline") != -1) {
        $("TB_ajaxContent").innerHTML = ($(f.inlineId).innerHTML);
        TB_position();
        TB_showWindow()
    } else {
        if (b.indexOf("TB_iframe") != -1) {
            TB_position();
            if (frames.TB_iframeContent == undefined) {
                $(document).keyup(function (m) {
                    var l = m.keyCode;
                    if (l == 27) {
                        TB_remove()
                    }
                });
                TB_showWindow()
            }
        } else {
            var g = function () {
                TB_position();
                TB_showWindow()
            };
            new Request.HTML({
                method: "get",
                update: $("TB_ajaxContent"),
                onComplete: g
            }).get(b)
        }
    }
    window.onresize = function () {
        TB_position();
        TB_overlaySize()
    };
    document.onkeyup = function (l) {
        var l = new Event(l);
        if (l.code == 27) {
            TB_remove()
        }
    }
}
function TB_showWindow() {
    if($('TB_load')) {
    	$('TB_load').dispose();
    }
    
    if (TB_useReady && !TB_ready) {
        return
    }
    if (TB_doneOnce == 0) {
        TB_doneOnce = 1;
        $("TB_window").set("tween", {
            duration: 250
        });
        $("TB_window").tween("opacity", 0,1);
    } else {
        $("TB_window").setStyle("opacity", 1);
    }
}
function TB_remove() {
    if (TB_useReady && !TB_ready) {
        return
    }
    //Hide all flash and ÒselectÓ objects
    TB_objectHide(true);
    
    $("TB_overlay").onclick = null;
    document.onkeyup = null;
    document.onkeydown = null;
    if ($("TB_closeWindowButton")) {
        $("TB_closeWindowButton").onclick = null
    }
    $("TB_window").set("tween", {
        duration: 250,
        onComplete: function () {
            $("TB_window").destroy()
        }
    });
    $("TB_window").tween("opacity", 1, 0);
    $("TB_overlay").set("tween", {
        duration: 400,
        onComplete: function () {
            $("TB_overlay").destroy()
        }
    });
    $("TB_overlay").tween("opacity", 0.6, 0);
    window.onscroll = null;
    window.onresize = null;
    TB_init();
    TB_doneOnce = 0;
    return false
}
function TB_position() {
    if (TB_useReady && !TB_ready) {
        return
    }
    $("TB_window").set("morph", {
        duration: 75
    });
    $("TB_window").morph({
        width: TB_WIDTH + "px",
        left: (window.getScrollLeft() + (window.getWidth() - TB_WIDTH) / 2) + "px",
        top: (window.getScrollTop() + (window.getHeight() - TB_HEIGHT) / 2) + "px"
    })
}
function TB_overlaySize() {
    if (TB_useReady && !TB_ready) {
        return
    }
    $("TB_overlay").setStyles({
        height: "0px",
        width: "0px"
    });
    $("TB_overlay").setStyles({
        height: window.getScrollHeight() + "px",
        width: window.getScrollWidth() + "px"
    })
}
function TB_parseQuery(c) {
    if (TB_useReady && !TB_ready) {
        return
    }
    if (!c) {
        return {}
    }
    var e = {};
    var b = c.split(/[;&]/);
    for (var a = 0; a < b.length; a++) {
        var d = b[a].split("=");
        if (!d || d.length != 2) {
            continue
        }
        e[unescape(d[0])] = unescape(d[1]).replace(/\+/g, " ")
    }
    return e
};
function TB_objectHide(open){
/*var elements = $A(document.getElementsByTagName('object'));
elements.extend(document.getElementsByTagName(window.ie ? 'select' : 'embed'));
elements.each(function(el){
if (open) el.lbBackupStyle = el.style.visibility;
el.style.visibility = open ? 'hidden' : el.lbBackupStyle;
});*/
}

function str_repeat(b, a) {
    for (var c = []; a > 0; c[--a] = b) {}
    return (c.join(""))
}
function sprintf() {
    var g = 0,
        e, h = arguments[g++],
        k = [],
        d, j, l, b;
    while (h) {
        if (d = /^[^\x25]+/.exec(h)) {
            k.push(d[0])
        } else {
            if (d = /^\x25{2}/.exec(h)) {
                k.push("%")
            } else {
                if (d = /^\x25(?:(\d+)\$)?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-fosuxX])/.exec(h)) {
                    if (((e = arguments[d[1] || g++]) == null) || (e == undefined)) {
                        throw ("Too few arguments.")
                    }
                    if (/[^s]/.test(d[7]) && (typeof(e) != "number")) {
                        throw ("Expecting number but found " + typeof(e))
                    }
                    switch (d[7]) {
                    case "b":
                        e = e.toString(2);
                        break;
                    case "c":
                        e = String.fromCharCode(e);
                        break;
                    case "d":
                        e = parseInt(e);
                        break;
                    case "e":
                        e = d[6] ? e.toExponential(d[6]) : e.toExponential();
                        break;
                    case "f":
                        e = d[6] ? parseFloat(e).toFixed(d[6]) : parseFloat(e);
                        break;
                    case "o":
                        e = e.toString(8);
                        break;
                    case "s":
                        e = ((e = String(e)) && d[6] ? e.substring(0, d[6]) : e);
                        break;
                    case "u":
                        e = Math.abs(e);
                        break;
                    case "x":
                        e = e.toString(16);
                        break;
                    case "X":
                        e = e.toString(16).toUpperCase();
                        break
                    }
                    e = (/[def]/.test(d[7]) && d[2] && e > 0 ? "+" + e : e);
                    l = d[3] ? d[3] == "0" ? "0" : d[3].charAt(1) : " ";
                    b = d[5] - String(e).length;
                    j = d[5] ? str_repeat(l, b) : "";
                    k.push(d[4] ? e + j : j + e)
                } else {
                    throw ("Huh ?!")
                }
            }
        }
        h = h.substring(d[0].length)
    }
    return k.join("")
};



function gum_smilies() {
var html_code = '<div style="margin-top: 5px;"><img src="./images/smilies_new/01_Smile.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :smile: \';" />&nbsp;<img src="./images/smilies_new/02_Laugh.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :biggrin: \';" />&nbsp;<img src="./images/smilies_new/04_Wink.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :wink: \';" />&nbsp;<img src="./images/smilies_new/26_Kissy.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :kiss: \';" />&nbsp;<img src="./images/smilies_new/34_Minishock.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :shock: \';" />&nbsp;<img src="./images/smilies_new/17_Devil.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :devil: \';" />&nbsp;<img src="./images/smilies_new/18_Angel.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :angel: \';" />&nbsp;<img src="./images/smilies_new/07_Cool.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :cool: \';" />&nbsp;<img src="./images/smilies_new/15_Cry.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :cry: \';" />&nbsp;<img src="./images/smilies_new/12_Tease.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :razz: \';" />&nbsp;<img src="./images/smilies_new/29_Zzz.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :zzz: \';" />&nbsp;<img src="./images/smilies_new/31_In_love.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :in love: \';" />&nbsp;<img src="./images/smilies_new/08_Angry.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :mad: \';" />&nbsp;<img src="./images/smilies_new/19_Ill.png" class="icon" onclick="document.getElementById(\'comment_body\').focus();document.getElementById(\'comment_body\').value += \' :ill: \';" />&nbsp;</div>';
return html_code;
}

function replace_to_smilies(str)
{
      str = str.replace(/:blanco:/gi, '<img src="/images/smilies_new/00_Blanco.png" alt=":blanco:"/>');
      str = str.replace(/:smile:/gi, '<img src="/images/smilies_new/01_Smile.png" alt=":smile:"/>');
      str = str.replace(/:\)/gi, '<img src="/images/smilies_new/01_Smile.png" alt=":)"/>');
      str = str.replace(/:-\)/gi, '<img src="/images/smilies_new/01_Smile.png" alt=":-)"/>');
      str = str.replace(/:biggrin:/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":biggrin:"/>');
      str = str.replace(/:bigrin:/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":bigrin:"/>');
      str = str.replace(/:laugh:/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":laugh:"/>');
      str = str.replace(/:devil:/gi, '<img src="/images/smilies_new/17_Devil.png" alt="devil"/>');
      str = str.replace(/:devil laugh:/gi, '<img src="/images/smilies_new/35_Devil_laugh.png" alt="devil laugh"/>');
      str = str.replace(/:devil_laugh:/gi, '<img src="/images/smilies_new/35_Devil_laugh.png" alt="devil_laugh"/>');
      str = str.replace(/:D/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":D"/>');
      str = str.replace(/:-D/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":-D"/>');
      str = str.replace(/:phone:/gi, '<img src="/images/smilies_new/Cellphone.png" alt="phone"/>');
      str = str.replace(/:-d/gi, '<img src="/images/smilies_new/02_Laugh.png" alt=":-d"/>');
      str = str.replace(/:silly:/gi, '<img src="/images/smilies_new/03_Silly.png" alt=":silly:"/>');
      str = str.replace(/:sily:/gi, '<img src="/images/smilies_new/03_Silly.png" alt=":silly:"/>');
      str = str.replace(/:razz:/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":razz:"/>');
      str = str.replace(/:raz:/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":razz:"/>');
      str = str.replace(/:please:/gi, '<img src="/images/smilies_new/23_Please.png" alt="please"/>');
      str = str.replace(/:P/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":P"/>');
      str = str.replace(/:-P/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":-P"/>');
      str = str.replace(/:p/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":p"/>');
      str = str.replace(/:-p/gi, '<img src="/images/smilies_new/12_Tease.png" alt=":-p"/>');
      str = str.replace(/:wink:/gi, '<img src="/images/smilies_new/04_Wink.png" alt=":wink:"/>');
      str = str.replace(/;\)/gi, '<img src="/images/smilies_new/04_Wink.png" alt=";)"/>');
      str = str.replace(/;-\)/gi, '<img src="/images/smilies_new/04_Wink.png" alt=";-)"/>');
      str = str.replace(/:redface:/gi, '<img src="/images/smilies_new/05_Blush.png" alt=":redface:"/>');
      str = str.replace(/:blush:/gi, '<img src="/images/smilies_new/05_Blush.png" alt=":blush:"/>');
      str = str.replace(/:sad:/gi, '<img src="/images/smilies_new/06_Sad.png" alt=":sad:"/>');
      str = str.replace(/:\(/, '<img src="/images/smilies_new/06_Sad.png" alt=":(//>');
      str = str.replace(/:-\(/, '<img src="/images/smilies_new/06_Sad.png" alt=":-(//>');
      str = str.replace(/:cool:/gi, '<img src="/images/smilies_new/07_Cool.png" alt=":cool:"/>');
      str = str.replace(/B\)/gi, '<img src="/images/smilies_new/07_Cool.png" alt="B)"/>');
      str = str.replace(/B-\)/gi, '<img src="/images/smilies_new/07_Cool.png" alt="B-)"/>');
      str = str.replace(/:angry:/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":angry:"/>');
      str = str.replace(/:mad:/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":mad:"/>');
      str = str.replace(/:x/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":x"/>');
      str = str.replace(/:-x/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":-x"/>');
      str = str.replace(/:X/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":X"/>');
      str = str.replace(/:-X/gi, '<img src="/images/smilies_new/08_Angry.png" alt=":-X"/>');
      str = str.replace(/:surprised:/gi, '<img src="/images/smilies_new/09_Surprised.png" alt=":surprised:"/>');
      str = str.replace(/:speechless:/gi, '<img src="/images/smilies_new/10_Speechless.png" alt=":speechless:"/>');
      str = str.replace(/:\|/gi, '<img src="/images/smilies_new/10_Speechless.png" alt=":|"/>');
      str = str.replace(/:-\|/gi, '<img src="/images/smilies_new/10_Speechless.png" alt=":-|"/>');
      str = str.replace(/8\)/gi, '<img src="/images/smilies_new/11_Geek.png" alt="8)"/>');
      str = str.replace(/8-\)/gi, '<img src="/images/smilies_new/11_Geek.png" alt="8-)"/>');
      str = str.replace(/:geek:/gi, '<img src="/images/smilies_new/11_Geek.png" alt=":geek:"/>');
      str = str.replace(/:crazy:/gi, '<img src="/images/smilies_new/13_Crazy.png" alt=":crazy:"/>');
      str = str.replace(/:fools:/gi, '<img src="/images/smilies_new/14_Fools.png" alt=":fools:"/>');
      str = str.replace(/:cry:/gi, '<img src="/images/smilies_new/15_Cry.png" alt=":cry:"/>');
      str = str.replace(/;\(/, '<img src="/images/smilies_new/15_Cry.png" alt=";(//>');
      str = str.replace(/;-\(/, '<img src="/images/smilies_new/15_Cry.png" alt=";-(//>');
      str = str.replace(/XD/gi, '<img src="/images/smilies_new/16_XD.png" alt="XD"/>');
      str = str.replace(/:lol:/gi, '<img src="/images/smilies_new/16_XD.png" alt=":lol:"/>');
      str = str.replace(/:xd:/gi, '<img src="/images/smilies_new/16_XD.png" alt=":xd:"/>');
      str = str.replace(/:twisted:/gi, '<img src="/images/smilies_new/17_Devil.png" alt=":twisted:"/>');
      str = str.replace(/:evil:/gi, '<img src="/images/smilies_new/17_Devil.png" alt=":evil:"/>');
      str = str.replace(/:angel:/gi, '<img src="/images/smilies_new/18_Angel.png" alt=":angel:"/>');
      str = str.replace(/:ill:/gi, '<img src="/images/smilies_new/19_Ill.png" alt=":ill:"/>');
      str = str.replace(/:il:/gi, '<img src="/images/smilies_new/19_Ill.png" alt=":il:"/>');
      str = str.replace(/:meow:/gi, '<img src="/images/smilies_new/20_Meow.png" alt=":meow:"/>');
      str = str.replace(/:zip it:/gi, '<img src="/images/smilies_new/21_Zip_it.png" alt=":zip it:"/>');
      str = str.replace(/:zip_it:/gi, '<img src="/images/smilies_new/21_Zip_it.png" alt=":zip_it:"/>');
      str = str.replace(/:annoyed:/gi, '<img src="/images/smilies_new/22_Annoyed.png" alt=":annoyed:"/>');
      str = str.replace(/:anoyed:/gi, '<img src="/images/smilies_new/22_Annoyed.png" alt=":anoyed:"/>');
      str = str.replace(/:hay:/gi, '<img src="/images/smilies_new/24_Hay.png" alt=":hay:"/>');
      str = str.replace(/:not guilty:/gi, '<img src="/images/smilies_new/25_Not_guilty.png" alt=":not guilty:"/>');
      str = str.replace(/:not_guilty:/gi, '<img src="/images/smilies_new/25_Not_guilty.png" alt=":not_guilty:"/>');
      str = str.replace(/:whistle:/gi, '<img src="/images/smilies_new/25_Not_guilty.png" alt=":whistle:"/>');
      str = str.replace(/:kissy:/gi, '<img src="/images/smilies_new/26_Kissy.png" alt=":kissy:"/>');
      str = str.replace(/:kiss:/gi, '<img src="/images/smilies_new/26_Kissy.png" alt=":kiss:"/>');
      str = str.replace(/:mwah:/gi, '<img src="/images/smilies_new/26_Kissy.png" alt=":mwah:"/>');
      str = str.replace(/:@/gi, '<img src="/images/smilies_new/26_Kissy.png" alt=":@"/>');
      str = str.replace(/:-@/gi, '<img src="/images/smilies_new/26_Kissy.png" alt=":-@"/>');
      str = str.replace(/:goatse:/gi, '<img src="/images/smilies_new/27_Goatse.png" alt=":goatse:"/>');
      str = str.replace(/:nomnomnom:/gi, '<img src="/images/smilies_new/28_Nomnomnom.png" alt=":nomnomnom:"/>');
      str = str.replace(/:zzz:/gi, '<img src="/images/smilies_new/29_Zzz.png" alt=":zzz:"/>');
      str = str.replace(/:total shock:/gi, '<img src="/images/smilies_new/30_Total_shock.png" alt=":total shock:"/>');
      str = str.replace(/:total_shock:/gi, '<img src="/images/smilies_new/30_Total_shock.png" alt=":total_shock:"/>');
      str = str.replace(/:O/gi, '<img src="/images/smilies_new/30_Total_shock.png" alt=":O"/>');
      str = str.replace(/:-O/gi, '<img src="/images/smilies_new/30_Total_shock.png" alt=":-O"/>');
      str = str.replace(/:in love:/gi, '<img src="/images/smilies_new/31_In_love.png" alt=":in love:"/>');
      str = str.replace(/:in_love:/gi, '<img src="/images/smilies_new/31_In_love.png" alt=":in_love:"/>');
      str = str.replace(/:not one care:/gi, '<img src="/images/smilies_new/32_Not_one_care.png" alt=":not one care:"/>');
      str = str.replace(/:not_one_care:/gi, '<img src="/images/smilies_new/32_Not_one_care.png" alt=":not_one_care:"/>');
      str = str.replace(/:not care:/gi, '<img src="/images/smilies_new/32_Not_one_care.png" alt=":not care:"/>');
      str = str.replace(/:not_care:/gi, '<img src="/images/smilies_new/32_Not_one_care.png" alt=":not_care:"/>');
      str = str.replace(/:boring:/gi, '<img src="/images/smilies_new/33_Boring.png" alt=":boring:"/>');
      str = str.replace(/:minishock:/gi, '<img src="/images/smilies_new/34_Minishock.png" alt=":minishock:"/>');
      str = str.replace(/:shock:/gi, '<img src="/images/smilies_new/34_Minishock.png" alt=":shock:"/>');
      str = str.replace(/:shocked:/gi, '<img src="/images/smilies_new/34_Minishock.png" alt=":shocked:"/>');
      str = str.replace(/:oh:/gi, '<img src="/images/smilies_new/37_Oh.png" alt="oh"/>');
      str = str.replace(/:o/gi, '<img src="/images/smilies_new/34_Minishock.png" alt=":o"/>');
      str = str.replace(/:-o/gi, '<img src="/images/smilies_new/34_Minishock.png" alt=":-o"/>');
      str = str.replace(/:evil laugh:/gi, '<img src="/images/smilies_new/35_Devil_laugh.png" alt=":evil laugh:"/>');
      str = str.replace(/:evil_laugh:/gi, '<img src="/images/smilies_new/35_Devil_laugh.png" alt=":evil_laugh:"/>');
      str = str.replace(/:james:/gi, '<img src="/images/smilies_new/36_James.png" alt=":james:"/>');
      str = str.replace(/:why thank you:/gi, '<img src="/images/smilies_new/38_Why_thank_you.png" alt=":why thank you:"/>');
      str = str.replace(/:why_thank_you:/gi, '<img src="/images/smilies_new/38_Why_thank_you.png" alt=":why_thank_you:"/>');
      str = str.replace(/:alien:/gi, '<img src="/images/smilies_new/39_Alien_1.png" alt=":alien:"/>');
      str = str.replace(/:alien 1:/gi, '<img src="/images/smilies_new/39_Alien_1.png" alt=":alien 1:"/>');
      str = str.replace(/:alien_1:/gi, '<img src="/images/smilies_new/39_Alien_1.png" alt=":alien_1:"/>');
      str = str.replace(/:green alien:/gi, '<img src="/images/smilies_new/40_Alien_2.png" alt=":green alien:"/>');
      str = str.replace(/:green_alien:/gi, '<img src="/images/smilies_new/40_Alien_2.png" alt=":green alien:"/>');
      str = str.replace(/:alien 2:/gi, '<img src="/images/smilies_new/40_Alien_2.png" alt=":alien 2:"/>');
      str = str.replace(/:alien_2:/gi, '<img src="/images/smilies_new/40_Alien_2.png" alt=":alien_2:"/>');
      str = str.replace(/:green:/gi, '<img src="/images/smilies_new/40_Alien_2.png" alt=":green:"/>');
      str = str.replace(/:male:/gi, '<img src="/images/smilies_new/41_Male.png" alt=":male:"/>');
      str = str.replace(/:m:/gi, '<img src="/images/smilies_new/41_Male.png" alt=":m:"/>');
      str = str.replace(/:female:/gi, '<img src="/images/smilies_new/42_Female.png" alt=":female:"/>');
      str = str.replace(/:fem:/gi, '<img src="/images/smilies_new/42_Female.png" alt=":fem:"/>');
      str = str.replace(/:f:/gi, '<img src="/images/smilies_new/42_Female.png" alt=":f:"/>');
      str = str.replace(/:ghost:/gi, '<img src="/images/smilies_new/43_Ghost.png" alt=":ghost:"/>');
      str = str.replace(/:mario:/gi, '<img src="/images/smilies_new/44_Mario.png" alt=":mario:"/>');
      str = str.replace(/:brb:/gi, '<img src="/images/smilies_new/BRB.png" alt=":brb:"/>');
      str = str.replace(/:cell:/gi, '<img src="/images/smilies_new/Cellphone.png" alt=":cell:"/>');
      str = str.replace(/:cellphone:/gi, '<img src="/images/smilies_new/Cellphone.png" alt=":cellphone:"/>');
      str = str.replace(/:mobile:/gi, '<img src="/images/smilies_new/Cellphone.png" alt=":mobile:"/>');
      str = str.replace(/:clock:/gi, '<img src="/images/smilies_new/Clock.png" alt=":clock:"/>');
      str = str.replace(/:time:/gi, '<img src="/images/smilies_new/Clock.png" alt=":time:"/>');
      str = str.replace(/:heart:/gi, '<img src="/images/smilies_new/Heart.png" alt=":heart:"/>');
      str = str.replace(/:flower:/gi, '<img src="/images/smilies_new/Flower.png" alt=":flower:"/>');
      str = str.replace(/:music:/gi, '<img src="/images/smilies_new/Music_2.png" alt=":music:"/>');
      return str;
}
Element.implement({sep_nfa_show:function(){this.setStyle("display","")},sep_nfa_hide:function(){this.setStyle("display","none")},sep_nfa_visible:function(){if(this.getStyle("display")=="none"){return false}else{return true}},sep_nfa_toggle:function(){if(this.getStyle("display")=="none"){this.sep_nfa_show()}else{this.sep_nfa_hide()}},sep_nfa_update:function(a){this.innerHTML=a}});function NFA_post(a,b){data_string="";if(b==3){data_string=$("comment_post_form_"+a).toQueryString()}myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=post&type="+b+"&action_id="+a+"&"+data_string,onSuccess:function(c){$("ajax_inject_new_post_"+a).clone().injectBefore("ajax_inject_new_post_"+a).sep_nfa_update(c.replace(/\\n/g,"<br>"));$("comment_post_form_"+a).reset();if(b==1||b==2){$("likes_buttons_"+a).sep_nfa_hide()}},onFailure:function(){alert("Could not save your comment! Please try again!")}}).send()}function NFA_show_edit_form(a){if($("NFA_Edit_"+a).sep_nfa_visible()){NFA_hide_edit_form(a)}else{$("NFA_Text_"+a).sep_nfa_hide();$("NFA_Edit_"+a).sep_nfa_show();$("NFA_Textarea_Edit_"+a).focus()}}function NFA_hide_edit_form(a){$("NFA_Edit_"+a).sep_nfa_hide();$("NFA_Text_"+a).sep_nfa_show()}function NFA_edit(b,a){data_string="";if(a==3){data_string=$("comment_edit_form_"+b).toQueryString()}myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=edit&type="+a+"&id="+b+"&"+data_string,onSuccess:function(c){$("NFA_Text_"+b).sep_nfa_update(c.replace(/\\n/g,"<br>"));$("NFA_Edit_"+b).sep_nfa_hide();$("NFA_Text_"+b).sep_nfa_show()},onFailure:function(){alert("Could not save your changes! Please try again!")}}).send()}function NFA_delete(a){myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=delete&id="+a,onSuccess:function(b){$("NFA_BoxItem_"+a).destroy()},onFailure:function(){alert("Could not delete this comment! Please try again!")}}).send()}function NFA_report(a){myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=report&id="+a,onSuccess:function(){$("NFA_ReportButton_"+a).destroy();alert("Thank you for reporting this comment!")},onFailure:function(){alert("Could not send your report! Please try again!")}}).send()}function NFA_toggle_box(a,b){if(b=="preview"){$("NFA_Box_Final_"+a).sep_nfa_hide();if(NFA_AutoGrow_Instance){$("NFA_Textarea_"+a).setStyle("height",NFA_AutoGrow_Instance.textarea_old_height)}$("NFA_Box_Preview_"+a).sep_nfa_show()}else{$("NFA_Box_Preview_"+a).sep_nfa_hide();$("NFA_Box_Final_"+a).sep_nfa_show();$("NFA_Textarea_"+a).focus()}}function NFA_ScrollTo(a){offset=300;div_position_y=$("NFA_Box_Final_"+a).getPosition().y;window.scrollTo(0,div_position_y-offset)}function NFA_Show_Hidden_Boxes(a){$("NFA_ShowMoreButton_"+a).sep_nfa_hide();$$("div.NFA_Box_Hidden_"+a).each(function(b){b.sep_nfa_show()})}function NFA_Check_MaxLength(a,b){if($(a).value.length>b){alert("Your comment is too long!");return false}return true}function NFA_ItemOptions(a,b){if(a=="show"){$("NFA_Box_Header_Right_Inactive_"+b).sep_nfa_hide();$("NFA_Box_Header_Right_Active_"+b).sep_nfa_show()}else{$("NFA_Box_Header_Right_Active_"+b).sep_nfa_hide();$("NFA_Box_Header_Right_Inactive_"+b).sep_nfa_show()}}var NFA_AutoGrow_Instance=null;var AutoGrow=new Class({Implements:[Options,Events],options:{interval:333,margin:30,minHeight:20},periodical_timer:null,textarea_old_height:0,initialize:function(a,b){this.textarea=$(a);this.options.minHeight=a.clientHeight;this.setOptions(b);this.dummy=new Element("div",{styles:{"overflow-x":"hidden",position:"absolute",top:0,left:"-9999px"}}).setStyles(this.textarea.getStyles("font-size","font-family","width","line-height","padding")).inject(document.body);this.textarea_old_height=this.textarea.getStyle("height");this.resize();this.start()},resize:function(){var c=this.textarea.get("value").replace(/\n|\r\n/g,"<br>X");if(this.dummy.get("html").toLowerCase()!=c.toLowerCase()){this.dummy.set("html",c);var b=this.dummy.getSize().y+this.options.margin;if(this.textarea.clientHeight!=b){var a=Math.max(this.options.minHeight,b);this.textarea.tween("height",a)}}},start:function(){this.periodical_timer=this.resize.periodical(this.options.interval,this)},stop:function(){$clear(this.periodical_timer)}});var TipsX3=new Class({options:{onShow:function(c){c.setStyle('visibility','visible')},onHide:function(c){c.setStyle('visibility','hidden')},maxTitleChars:30,showDelay:100,hideDelay:100,className:'tool',offsets:{'x':16,'y':16},fixed:false,loadingText:'Loading...',errTitle:'Oops..',errText:'There was a problem retrieving the tooltip.'},initialize:function(c,a){this.setOptions(a);this.toolTip=new Element('div',{'class':this.options.className+'-tip','styles':{'position':'absolute','top':'0','left':'0','visibility':'hidden'}}).inject(document.body);this.wrapper=new Element('div').inject(this.toolTip);$$(c).each(this.build,this);if(this.options.initialize)this.options.initialize.call(this)},build:function(a){a.myTitle=(a.href&&a.get('tag')=='a')?a.href.replace('http://',''):(a.rel||false);if(a.title){if(a.title.test('^DOM:','i')){a.title=$(a.title.split(':')[1].trim()).innerHTML}if(a.title.test('^AJAX:','i')){a.title=this.options.loadingText+'::'+a.title}var b=a.title.split('::');if(b.length>1){a.myTitle=b[0].trim();a.myText=b[1].trim()}else{a.myText=a.title}a.removeAttribute('title')}else{a.myText=false}if(a.myTitle&&a.myTitle.length>this.options.maxTitleChars)a.myTitle=a.myTitle.substr(0,this.options.maxTitleChars-1)+"&hellip;";a.addEvent('mouseenter',function(c){this.start(a);if(!this.options.fixed)this.locate(c);else this.position(a)}.bind(this));if(!this.options.fixed)a.addEvent('mousemove',this.locate.bindWithEvent(this));var e=this.end.bind(this);a.addEvent('mouseleave',e);a.addEvent('trash',e)},start:function(b){this.wrapper.empty();if(b.myText&&b.myText.test('^AJAX:','i')){this.ajax=new Request({url:b.myText.replace(/AJAX:/i,''),onComplete:function(c,a){b.title=c;this.build(b);this.start(b)}.bind(this),onFailure:function(){b.title=this.options.errTitle+'::'+this.options.errText;this.build(b);this.start(b)}.bind(this),method:'get'}).send();b.myText='<div class="'+this.options.className+'-loading">&nbsp;</div>'}if(b.myTitle){this.title=new Element('span').inject(new Element('div',{'class':this.options.className+'-title'}).inject(this.wrapper)).set('html',b.myTitle)}if(b.myText){this.text=new Element('span').inject(new Element('div',{'class':this.options.className+'-text'}).inject(this.wrapper)).set('html',b.myText)}$clear(this.timer);this.timer=this.show.delay(this.options.showDelay,this)},end:function(c){$clear(this.timer);this.timer=this.hide.delay(this.options.hideDelay,this)},position:function(c){var a=c.getPosition();this.toolTip.setStyles({'left':a.x+this.options.offsets.x,'top':a.y+this.options.offsets.y})},locate:function(c){var a={'x':window.getWidth(),'y':window.getHeight()};var b={'x':window.getScrollLeft(),'y':window.getScrollTop()};var e={'x':this.toolTip.offsetWidth,'y':this.toolTip.offsetHeight};var g={'x':'left','y':'top'};for(var d in g){var f=c.page[d]+this.options.offsets[d];if((f+e[d]-b[d])>a[d])f=c.page[d]-this.options.offsets[d]-e[d];this.toolTip.setStyle(g[d],f)}},show:function(){if(this.options.timeout)this.timer=this.hide.delay(this.options.timeout,this);this.fireEvent('onShow',[this.toolTip])},hide:function(){this.fireEvent('onHide',[this.toolTip])}});TipsX3.implement(new Events,new Options);var ddajaxtabssettings={};ddajaxtabssettings.bustcachevar=1;ddajaxtabssettings.loadstatustext="<img src='images/loading2.gif' /> ";function ddajaxtabs(b,a){this.tabinterfaceid=b;this.tabs=document.getElementById(b).getElementsByTagName("a");this.enabletabpersistence=true;this.hottabspositions=[];this.currentTabIndex=0;this.contentdivid=a;this.defaultHTML="";this.defaultIframe='<iframe src="about:blank" marginwidth="0" marginheight="0" frameborder="0" vspace="0" hspace="0" class="tabcontentiframe" style="width:100%; height:auto; min-height: 100px"></iframe>';this.defaultIframe=this.defaultIframe.replace(/<iframe/i,'<iframe name="_ddajaxtabsiframe-'+a+'" ');this.revcontentids=[];this.selectedClassTarget="link"}ddajaxtabs.connect=function(a,b){var g=false;var f="";if(window.ActiveXObject){try{g=new ActiveXObject("Microsoft.XMLHTTP")}catch(c){try{g=new ActiveXObject("Microsoft.XMLHTTP")}catch(c){}}}else{if(window.XMLHttpRequest){g=new XMLHttpRequest()}else{return false}}var d=a.replace(/^http:\/\/[^\/]+\//i,"http://"+window.location.hostname+"/");g.onreadystatechange=function(){ddajaxtabs.loadpage(g,a,b)};if(ddajaxtabssettings.bustcachevar){f=(d.indexOf("?")!=-1)?"&"+new Date().getTime():"?"+new Date().getTime()}g.open("GET",d,true);g.send(null)};ddajaxtabs.loadpage=function(d,a,c){var b=c.contentdivid;document.getElementById(b).innerHTML=ddajaxtabssettings.loadstatustext;if(d.readyState==4&&(d.status==200||window.location.href.indexOf("http")==-1)){document.getElementById(b).innerHTML=d.responseText;ddajaxtabs.ajaxpageloadaction(a,c)}};ddajaxtabs.ajaxpageloadaction=function(a,b){b.onajaxpageload(a)};ddajaxtabs.getCookie=function(a){var b=new RegExp(a+"=[^;]+","i");if(document.cookie.match(b)){return document.cookie.match(b)[0].split("=")[1]}return""};ddajaxtabs.setCookie=function(a,b){document.cookie=a+"="+b+";path=/"};ddajaxtabs.prototype={expandit:function(a){this.cancelautorun();var b="";try{if(typeof a=="string"&&document.getElementById(a).getAttribute("rel")){b=document.getElementById(a)}else{if(parseInt(a)!=NaN&&this.tabs[a].getAttribute("rel")){b=this.tabs[a]}}}catch(c){alert("Invalid Tab ID or position entered!")}if(b!=""){this.expandtab(b)}},cycleit:function(b,a){if(b=="next"){var c=(this.currentTabIndex<this.hottabspositions.length-1)?this.currentTabIndex+1:0}else{if(b=="prev"){var c=(this.currentTabIndex>0)?this.currentTabIndex-1:this.hottabspositions.length-1}}if(typeof a=="undefined"){this.cancelautorun()}this.expandtab(this.tabs[this.hottabspositions[c]])},setpersist:function(a){this.enabletabpersistence=a},loadajaxpage:function(a){ddajaxtabs.connect(a,this)},loadiframepage:function(a){this.iframedisplay(a,this.contentdivid)},setselectedClassTarget:function(a){this.selectedClassTarget=a||"link"},getselectedClassTarget:function(a){return(this.selectedClassTarget==("linkparent".toLowerCase()))?a.parentNode:a},urlparamselect:function(b){var a=window.location.search.match(new RegExp(b+"=(\\d+)","i"));return(a==null)?null:parseInt(RegExp.$1)},onajaxpageload:function(a){},expandtab:function(b){var d=b.getAttribute("rel");var c=(b.getAttribute("rev"))?","+b.getAttribute("rev").replace(/\s+/,"")+",":"";if(d=="#default"){document.getElementById(this.contentdivid).innerHTML=this.defaultHTML}else{if(d=="#iframe"){this.iframedisplay(b.getAttribute("href"),this.contentdivid)}else{ddajaxtabs.connect(b.getAttribute("href"),this)}}this.expandrevcontent(c);for(var a=0;a<this.tabs.length;a++){this.getselectedClassTarget(this.tabs[a]).className=(this.tabs[a].getAttribute("href")==b.getAttribute("href"))?"selected":""}if(this.enabletabpersistence){ddajaxtabs.setCookie(this.tabinterfaceid,b.tabposition)}this.setcurrenttabindex(b.tabposition)},iframedisplay:function(b,a){if(typeof window.frames["_ddajaxtabsiframe-"+a]!="undefined"){try{delete window.frames["_ddajaxtabsiframe-"+a]}catch(c){}}document.getElementById(a).innerHTML=this.defaultIframe;window.frames["_ddajaxtabsiframe-"+a].location.replace(b)},expandrevcontent:function(c){var a=this.revcontentids;for(var b=0;b<a.length;b++){document.getElementById(a[b]).style.display=(c.indexOf(","+a[b]+",")!=-1)?"block":"none"}},setcurrenttabindex:function(a){for(var b=0;b<this.hottabspositions.length;b++){if(a==this.hottabspositions[b]){this.currentTabIndex=b;break}}},autorun:function(){this.cycleit("next",true)},cancelautorun:function(){if(typeof this.autoruntimer!="undefined"){clearInterval(this.autoruntimer)}},init:function(a){var e=ddajaxtabs.getCookie(this.tabinterfaceid);var d=-1;var f=this.urlparamselect(this.tabinterfaceid);this.automodeperiod=a||0;this.defaultHTML=document.getElementById(this.contentdivid).innerHTML;for(var c=0;c<this.tabs.length;c++){this.tabs[c].tabposition=c;if(this.tabs[c].getAttribute("rel")){var b=this;this.hottabspositions[this.hottabspositions.length]=c;this.tabs[c].onclick=function(){b.expandtab(this);b.cancelautorun();return false};if(this.tabs[c].getAttribute("rev")){this.revcontentids=this.revcontentids.concat(this.tabs[c].getAttribute("rev").split(/\s*,\s*/))}if(f==c||this.enabletabpersistence&&d==-1&&parseInt(e)==c||!this.enabletabpersistence&&d==-1&&this.getselectedClassTarget(this.tabs[c]).className=="selected"){d=c}}}if(d!=-1){this.expandtab(this.tabs[d])}else{this.expandtab(this.tabs[this.hottabspositions[0]])}if(parseInt(this.automodeperiod)>500&&this.hottabspositions.length>1){this.autoruntimer=setInterval(function(){b.autorun()},this.automodeperiod)}}};/***
 * MooCrop (v. 1.2 - 2008-08-31 )
 *
 * @version			rc-1
 * @license			BSD-style license
 * @author			nwhite - < nw [at] nwhite.net >
 * @infos			http://www.nwhite.net/MooCrop/
 * @copyright			Author
 *
 * Modifications made by Rok - rokmail [at] gmail.com
 * 1. Ported for MooTools 1.2 
 * 2. Ratio constraints added
 * Modifications made by Ash - ash [at] copyright86.com
 * 1. Fixed Ratio constraints to work in other directions
 */

var MooCrop = new Class({
 
	calculateHandles : true,
	current : {},
 
	options : {
		maskColor : 'black',
		maskOpacity : '.4',
		handleColor : 'white',
		handleWidth : '4px',
		handleHeight : '4px',
		cropBorder : '1px dashed white',
		min : { 'width' : 25, 'height' : 25 },
		showMask : true, // false to remove, helps on slow machines
		showHandles : false, // hide handles on drag
		//constrainRatio : true // hide handles on drag
	},
 
	initialize: function(el, options){
		this.setOptions(options);
		this.img = $(el); 
		if ( this.img.get('tag') != 'img') return false;
		this.resizeFunc = this.refresh.bindWithEvent(this);
		this.removeFunc = this.removeListener.bind(this);
 
		this.buildOverlay();
		this.setup();
	},
 
	setup: function(){
		$(this.cropArea).setStyles({
			'z-index':50,
			'width': this.options.min.width, 
			'height': this.options.min.height,
			'top' : (this.imgsize.height - this.options.min.height)/2,
			'left': (this.imgsize.width - this.options.min.width) / 2 
		});
 
		this.current.crop = this.crop = this.getCropArea();
 
		this.handleWidthOffset = this.options.handleWidth.toInt() / 2;
		this.handleHeightOffset = this.options.handleHeight.toInt() /2;
 
		this.fixBoxModel();
		this.drawMasks();
		this.positionHandles();
	},
 
	getCropArea : function(){
		var crop = this.cropArea.getCoordinates();
		crop.left -= this.offsets.x; crop.right -= this.offsets.x; // calculate relative (horizontal)
		crop.top -= this.offsets.y; crop.bottom  -= this.offsets.y; // calculate relative (vertical)
		return crop;
	},
 

	fixBoxModel : function(){
		var diff = this.boxDiff = (this.crop.width - this.options.min.width)/2;
		var b = this.bounds = { 'top' : diff, 'left' : diff, 
			'right' : this.imgsize.width+(diff*2), 'bottom' : this.imgsize.height+(diff*2),
			'width' : this.options.min.width+(diff*2), 'height' : this.options.min.height+(diff*2) };
 
		this.wrapper.setStyles({
			'width' : b.right, 'height' : b.bottom,
			'background' : 'url('+this.img.src+') no-repeat '+diff+'px '+diff+'px'
		});
		this.north.setStyle('width',b.right);
		this.south.setStyle('width',b.right);
	},
 
	activate : function(event,handle){
		event.stop();
		this.current = { 'x' : event.page.x, 'y' : event.page.y, 'handle' : handle, 'crop' : this.current.crop };
		if(this.current.handle == 'NESW' && !this.options.showHandles) this.hideHandles();
		this.fireEvent('onBegin',[this.img.src,this.getCropInfo(),this.bounds,handle]);
		document.addListener('mousemove', this.resizeFunc);
		document.addListener('mouseup', this.removeFunc);
	},
 
	removeListener : function(){
		if( this.current.handle == 'NESW' && !this.options.showHandles) this.showHandles();
		document.removeListener('mousemove', this.resizeFunc);
		document.removeListener('mouseup', this.removeFunc);
		this.crop = this.current.crop;
		this.fireEvent('onComplete',[this.img.src,this.getCropInfo(),this.bounds,this.current.handle]);
	},
	refresh : function(event){
		var pageX = event.clientX + $(document.body).getScroll().x;
		var pageY = event.clientY + $(document.body).getScroll().y;
		var xdiff = this.current.x - pageX;
		var ydiff = this.current.y - pageY;
		var b = this.bounds;  
		var c = this.crop;  
		var handle = this.current.handle; 
		var styles = {}; //saving bytes	
		var dragging = (handle.length > 2) ? true : false;
		var multiplier = 0;
		if (dragging) {
			if(c.bottom - ydiff > b.bottom ) ydiff = c.bottom - b.bottom; // box south
			if(c.top - ydiff < b.top ) ydiff = c.top; //box north
			if(c.right - xdiff > b.right) xdiff = c.right - b.right; //box east
			if(c.left - xdiff < b.left) xdiff = c.left; //box west
			styles.top = c.top - ydiff; 
			styles.left = c.left - xdiff;
		} else {
                	if( handle.contains("S") && !handle.contains("W") && !handle.contains("E")) {//SOUTH
                		if(c.bottom - ydiff > b.bottom ) ydiff = c.bottom - b.bottom; // box south
               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south
               			if (this.options.constrainRatio) { 
               				if(c.right - ydiff > b.right ) {
               					ydiff = c.right - b.right;
               					xdiff = ydiff;
               					styles.width = c.width - xdiff;
               					styles.height = c.height - ydiff;
               				} else {
               					styles.width = c.width - ydiff;
               					styles.height = c.height - ydiff;
               				}
               			} else {
               				styles.height = c.height - ydiff; 
               			}
                	} else 

                	if( handle.contains("N") && !handle.contains("W") && !handle.contains("E")) {//NORTH
                		if(c.top - ydiff < b.top ) ydiff = c.top; //box north
               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north
               			if (this.options.constrainRatio) { 
               				if(c.right + ydiff > b.right ) {
               					xdiff = b.right - c.right;
               					ydiff = xdiff;
               					styles.width = c.width + xdiff;
               					styles.height = c.height + ydiff;
               				} else {
               					styles.width = c.width + ydiff;
               					styles.height = c.height + ydiff;
               				}
               			} else {
               				styles.height = c.height + ydiff; 
               			}
                		styles.top = c.top - ydiff; 
                	} else

                	if( handle.contains("E") && !handle.contains("S") && !handle.contains("N")){//EAST
                		if(c.right - xdiff > b.right) xdiff = c.right - b.right; //box east
               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if (this.options.constrainRatio) { 
               				if(c.bottom - xdiff > b.bottom ) {
               					xdiff = c.bottom - b.bottom;
               					ydiff = xdiff;
              						styles.width = c.width - xdiff;
              						styles.height = c.height - ydiff;
               				} else {
              						styles.width = c.width - xdiff;
              						styles.height = c.height - xdiff;
               				}
               			} else {
               				styles.width = c.width - xdiff;
               			}
                	} else 

                	if( handle.contains("W") && !handle.contains("S") && !handle.contains("N")){//WEST
                		if(c.left - xdiff < b.left) xdiff = c.left; //box west
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west
               			if (this.options.constrainRatio) { 
               				if (c.bottom + xdiff > b.bottom ) {
               					xdiff = b.bottom - c.bottom;
               					ydiff = xdiff;
              						styles.width = c.width + xdiff;
              						styles.height = c.height + ydiff;
               				} else {
              						styles.width = c.width + xdiff;
              						styles.height = c.height + xdiff;
               				}
               			} else {
               				styles.width = c.width + xdiff;
               			}
                		styles.left = c.left - xdiff; 
                	} else
                	
                	if( this.options.constrainRatio )
                	{
                		
                		if( c.width > c.height) multiplier = c.height / c.width;
                		else multiplier = c.width / c.height;
                		
                	}

                	if( handle.contains("S") && handle.contains("E") ){//SOUTH & EAST

                		if(c.right - xdiff > b.right) { xdiff = c.right - b.right; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.bottom - xdiff > b.bottom ) { xdiff = c.bottom - b.bottom; }// box south
                		} else {
                			if(c.bottom - ydiff > b.bottom ) { ydiff = c.bottom - b.bottom; }// box south
                		}

               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south

               			if (this.options.constrainRatio) {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - (multiplier * xdiff); 
                		} else {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - ydiff; 
                		}


                	} else

                	if( handle.contains("N") && handle.contains("E") ){//NORTH & EAST

                		if(c.right - xdiff > b.right) { xdiff = c.right - b.right; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.top + xdiff < b.top ) { xdiff = b.top - c.top; }// box south
                		} else {
                			if(c.top - ydiff < b.top ) { ydiff = c.top - b.top; }// box south
                		}

               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north

               			if (this.options.constrainRatio) {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - (multiplier * xdiff); 
                			styles.top = c.top + xdiff; 
                		} else {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height + ydiff; 
                			styles.top = c.top - ydiff; 
                		}
                		
                	} else

                	if( handle.contains("S") && handle.contains("W") ){//SOUTH & WEST

                		if(c.left - xdiff < b.left) { xdiff = c.left - b.left; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.bottom + xdiff > b.bottom ) { xdiff = b.bottom - c.bottom; }// box south
                		} else {
                			if(c.bottom - ydiff > b.bottom ) { ydiff = c.bottom - b.bottom; }// box south
                		}

               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west

               			if (this.options.constrainRatio) {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + (multiplier * xdiff); 
                			styles.left = c.left - xdiff; 
                		} else {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height - ydiff; 
                			styles.left = c.left - xdiff; 
                		}

                	} else

                	if( handle.contains("N") && handle.contains("W") ){//WEST & NORTH

                		if(c.left - xdiff < b.left) { xdiff = c.left - b.left; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.top - xdiff < b.top ) { xdiff = c.top - b.top; }// box south
                		} else {
                			if(c.top - ydiff < b.top ) { ydiff = c.top - b.top; }// box south
                		}

               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west

               			if (this.options.constrainRatio) {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + (multiplier * xdiff); 
                			styles.left = c.left - xdiff; 
                			styles.top = c.top - xdiff; 
                		} else {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + ydiff; 
                			styles.left = c.left - xdiff; 
                			styles.top = c.top - ydiff; 
                		}


                	} 
		}

		var preCssStyles = $merge(styles);
		if( $defined(styles.width)) styles.width -= this.boxDiff*2;
		if( $defined(styles.height)) styles.height -= this.boxDiff*2;
		this.cropArea.setStyles(styles);
		this.getCurrentCoords(preCssStyles);
		this.drawMasks();
		this.positionHandles();
		this.fireEvent('onCrop',[this.img.src,this.getCropInfo(),b,handle]);

	},
 
	getCurrentCoords : function(changed){
		var current = $merge(this.crop);
 
		if($defined(changed.left)){
			current.left = changed.left;
			if($defined(changed.width)) current.width = changed.width;
			else current.right = current.left + current.width;
		}
		if($defined(changed.top)){
			current.top = changed.top;
			if($defined(changed.height)) current.height = changed.height;
			else current.bottom = current.top + current.height;
		}
		if($defined(changed.width) && !$defined(changed.left)){
			current.width = changed.width; 
			current.right = current.left + current.width;
		}
		if($defined(changed.height) && !$defined(changed.top)){
			current.height = changed.height;
			current.bottom = current.top + current.height;
		}
		this.current.crop = current;
	},
 
	drawMasks : function(){
		if(!this.options.showMask) return;
		var b = this.bounds;
		var c = this.current.crop; 
		var handle = this.current.handle;
		this.north.setStyle('height', c.top + 'px' );
		this.south.setStyle('height', b.bottom  - c.bottom  + 'px');
		this.east.setStyles({ 'height': c.height + 'px', 'width': b.right  - c.right + 'px',  'top': c.top  + 'px', 'left': c.right + 'px'});
		this.west.setStyles({ 'height': c.height + 'px', 'width': c.left + 'px', 'top': c.top + 'px'});
	},
 
	positionHandles: function(){
		if(!this.calculateHandles) return;
		var c = this.current.crop; var wOffset = this.handleWidthOffset; var hOffset = this.handleHeightOffset;
 
		this.handles.get('N').setStyles({'left' : c.width / 2 - wOffset + 'px', 'top' : - hOffset + 'px'});
		this.handles.get('NE').setStyles({'left' : c.width - wOffset + 'px', 'top' : - hOffset + 'px'});
		this.handles.get('E').setStyles({ 'left' : c.width - wOffset + 'px', 'top' : c.height / 2 - hOffset + 'px'});
		this.handles.get('SE').setStyles({'left' : c.width - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('S').setStyles({'left' : c.width / 2 - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('SW').setStyles({'left' : - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('W').setStyles({'left' : - wOffset + 'px', 'top' : c.height / 2 - hOffset + 'px'});
		this.handles.get('NW').setStyles({'left' : - wOffset + 'px', 'top' : - hOffset + 'px'});
	},
 
	hideHandles: function(){
		this.calculateHandles = false;
		this.handles.each(function(handle){
			handle.setStyle('display','none');
		});
	},
 
	showHandles: function(){
		this.calculateHandles = true;
		this.positionHandles();
		this.handles.each(function(handle){
			handle.setStyle('display','block');
		});
	},
 
	buildOverlay: function(){
		var o = this.options;
		this.img.setStyle('padding','0');
		this.wrapper = new Element('div', {
			'class': 'crop_wrapper',
			'styles' :  {'position' : 'relative', 'width' : this.img.width, 'height' : this.img.height, 'background' : 'url('+this.img.src+') no-repeat' , 'float' : this.img.getStyle('float')}
		}).inject(this.img,'before');

		this.imgsize = {'width' : this.img.width, 'height' : this.img.height};
		this.img.setStyle('display','none');
		this.offsets = { x : this.wrapper.getCoordinates().left, y : this.wrapper.getCoordinates().top };
 
		if(this.options.showMask){		// optional masks
			var maskStyles = { 'position' : 'absolute', 'overflow' : 'hidden', 'background-color' : o.maskColor, 'opacity' : o.maskOpacity};
			this.north = new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
			this.south = new Element("div", {'styles' : $merge(maskStyles,{'bottom':'0px'})}).inject(this.wrapper);
			this.east =  new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
			this.west =  new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
		}
		this.cropArea = new Element("div", { 'styles' : { 'position' : 'absolute', 'top' : '0px', 'left' : '0px', 'border' : o.cropBorder, 'cursor' : 'move' },
		'events' : {
			'dblclick' : function(){ this.fireEvent('onDblClk',[this.img.src,this.getCropInfo(),this.bounds])}.bind(this),
			'mousedown' : this.activate.bindWithEvent(this,'NESW')}
		}).inject(this.wrapper,'bottom');
 
		this.handles = new Hash();
		['N','NE','E','SE','S','SW','W','NW'].each(function(handle){
			this.handles.set(handle, new Element("div", {
			'styles' : { 'position' : 'absolute', 'background-color' : o.handleColor, 
						 'width' : o.handleWidth, 'height' : o.handleHeight, 'overflow' : 'hidden', 'cursor' : (handle.toLowerCase()+'-resize')},
			'events' : {'mousedown' : this.activate.bindWithEvent(this,handle)}
			}).inject(this.cropArea,'bottom'));
		},this);
	},
 
	getCropInfo : function(){
		var c = $merge(this.current.crop);
		c.width -= this.boxDiff*2; c.height -= this.boxDiff*2;
		return c;
	},
 
	removeOverlay: function(){
		this.wrapper.dispose();
		this.img.setStyle('display','block');
	}
 
});
MooCrop.implement(new Events, new Options);Request.HTML.implement({
 
    processHTML: function(text){
        var match = text.match(/<body[^>]*>([\s\S]*?)<\/body>/i);
        text = (match) ? match[1] : text;
           
        var container = new Element('div');
           
        return $try(function(){
        var root = '<root>' + text + '</root>', doc;
            doc = new DOMParser().parseFromString(root, 'text/html');
            root = doc.getElementsByTagName('root')[0];
            for (var i = 0, k = root.childNodes.length; i < k; i++){
                var child = Element.clone(root.childNodes[i], true, true);
                if (child) container.grab(child);
            }
            return container;
        }) || container.set('html', text);
    }
   
});Element.implement({sep_nfa_show:function(){this.setStyle("display","")},sep_nfa_hide:function(){this.setStyle("display","none")},sep_nfa_visible:function(){if(this.getStyle("display")=="none"){return false}else{return true}},sep_nfa_toggle:function(){if(this.getStyle("display")=="none"){this.sep_nfa_show()}else{this.sep_nfa_hide()}},sep_nfa_update:function(a){this.innerHTML=a}});function NFA_post(a,b){data_string="";if(b==3){data_string=$("comment_post_form_"+a).toQueryString()}myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=post&type="+b+"&action_id="+a+"&"+data_string,onSuccess:function(c){$("ajax_inject_new_post_"+a).clone().injectBefore("ajax_inject_new_post_"+a).sep_nfa_update(c.replace(/\\n/g,"<br>"));$("comment_post_form_"+a).reset();if(b==1||b==2){$("likes_buttons_"+a).sep_nfa_hide()}},onFailure:function(){alert("Could not save your comment! Please try again!")}}).send()}function NFA_show_edit_form(a){if($("NFA_Edit_"+a).sep_nfa_visible()){NFA_hide_edit_form(a)}else{$("NFA_Text_"+a).sep_nfa_hide();$("NFA_Edit_"+a).sep_nfa_show();$("NFA_Textarea_Edit_"+a).focus()}}function NFA_hide_edit_form(a){$("NFA_Edit_"+a).sep_nfa_hide();$("NFA_Text_"+a).sep_nfa_show()}function NFA_edit(b,a){data_string="";if(a==3){data_string=$("comment_edit_form_"+b).toQueryString()}myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=edit&type="+a+"&id="+b+"&"+data_string,onSuccess:function(c){$("NFA_Text_"+b).sep_nfa_update(c.replace(/\\n/g,"<br>"));$("NFA_Edit_"+b).sep_nfa_hide();$("NFA_Text_"+b).sep_nfa_show()},onFailure:function(){alert("Could not save your changes! Please try again!")}}).send()}function NFA_delete(a){myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=delete&id="+a,onSuccess:function(b){$("NFA_BoxItem_"+a).destroy()},onFailure:function(){alert("Could not delete this comment! Please try again!")}}).send()}function NFA_report(a){myreq2=new Request({method:"post",url:"./user_newsfeed_advanced_ajax.php",data:"_ajaxReq=1&task=report&id="+a,onSuccess:function(){$("NFA_ReportButton_"+a).destroy();alert("Thank you for reporting this comment!")},onFailure:function(){alert("Could not send your report! Please try again!")}}).send()}function NFA_toggle_box(a,b){if(b=="preview"){$("NFA_Box_Final_"+a).sep_nfa_hide();if(NFA_AutoGrow_Instance){$("NFA_Textarea_"+a).setStyle("height",NFA_AutoGrow_Instance.textarea_old_height)}$("NFA_Box_Preview_"+a).sep_nfa_show()}else{$("NFA_Box_Preview_"+a).sep_nfa_hide();$("NFA_Box_Final_"+a).sep_nfa_show();$("NFA_Textarea_"+a).focus()}}function NFA_ScrollTo(a){offset=300;div_position_y=$("NFA_Box_Final_"+a).getPosition().y;window.scrollTo(0,div_position_y-offset)}function NFA_Show_Hidden_Boxes(a){$("NFA_ShowMoreButton_"+a).sep_nfa_hide();$$("div.NFA_Box_Hidden_"+a).each(function(b){b.sep_nfa_show()})}function NFA_Check_MaxLength(a,b){if($(a).value.length>b){alert("Your comment is too long!");return false}return true}function NFA_ItemOptions(a,b){if(a=="show"){$("NFA_Box_Header_Right_Inactive_"+b).sep_nfa_hide();$("NFA_Box_Header_Right_Active_"+b).sep_nfa_show()}else{$("NFA_Box_Header_Right_Active_"+b).sep_nfa_hide();$("NFA_Box_Header_Right_Inactive_"+b).sep_nfa_show()}}var NFA_AutoGrow_Instance=null;var AutoGrow=new Class({Implements:[Options,Events],options:{interval:333,margin:30,minHeight:20},periodical_timer:null,textarea_old_height:0,initialize:function(a,b){this.textarea=$(a);this.options.minHeight=a.clientHeight;this.setOptions(b);this.dummy=new Element("div",{styles:{"overflow-x":"hidden",position:"absolute",top:0,left:"-9999px"}}).setStyles(this.textarea.getStyles("font-size","font-family","width","line-height","padding")).inject(document.body);this.textarea_old_height=this.textarea.getStyle("height");this.resize();this.start()},resize:function(){var c=this.textarea.get("value").replace(/\n|\r\n/g,"<br>X");if(this.dummy.get("html").toLowerCase()!=c.toLowerCase()){this.dummy.set("html",c);var b=this.dummy.getSize().y+this.options.margin;if(this.textarea.clientHeight!=b){var a=Math.max(this.options.minHeight,b);this.textarea.tween("height",a)}}},start:function(){this.periodical_timer=this.resize.periodical(this.options.interval,this)},stop:function(){$clear(this.periodical_timer)}});var ddajaxtabssettings={};ddajaxtabssettings.bustcachevar=1;ddajaxtabssettings.loadstatustext="<img src='images/loading2.gif' /> ";function ddajaxtabs(b,a){this.tabinterfaceid=b;this.tabs=document.getElementById(b).getElementsByTagName("a");this.enabletabpersistence=true;this.hottabspositions=[];this.currentTabIndex=0;this.contentdivid=a;this.defaultHTML="";this.defaultIframe='<iframe src="about:blank" marginwidth="0" marginheight="0" frameborder="0" vspace="0" hspace="0" class="tabcontentiframe" style="width:100%; height:auto; min-height: 100px"></iframe>';this.defaultIframe=this.defaultIframe.replace(/<iframe/i,'<iframe name="_ddajaxtabsiframe-'+a+'" ');this.revcontentids=[];this.selectedClassTarget="link"}ddajaxtabs.connect=function(a,b){var g=false;var f="";if(window.ActiveXObject){try{g=new ActiveXObject("Microsoft.XMLHTTP")}catch(c){try{g=new ActiveXObject("Microsoft.XMLHTTP")}catch(c){}}}else{if(window.XMLHttpRequest){g=new XMLHttpRequest()}else{return false}}var d=a.replace(/^http:\/\/[^\/]+\//i,"http://"+window.location.hostname+"/");g.onreadystatechange=function(){ddajaxtabs.loadpage(g,a,b)};if(ddajaxtabssettings.bustcachevar){f=(d.indexOf("?")!=-1)?"&"+new Date().getTime():"?"+new Date().getTime()}g.open("GET",d,true);g.send(null)};ddajaxtabs.loadpage=function(d,a,c){var b=c.contentdivid;document.getElementById(b).innerHTML=ddajaxtabssettings.loadstatustext;if(d.readyState==4&&(d.status==200||window.location.href.indexOf("http")==-1)){document.getElementById(b).innerHTML=d.responseText;ddajaxtabs.ajaxpageloadaction(a,c)}};ddajaxtabs.ajaxpageloadaction=function(a,b){b.onajaxpageload(a)};ddajaxtabs.getCookie=function(a){var b=new RegExp(a+"=[^;]+","i");if(document.cookie.match(b)){return document.cookie.match(b)[0].split("=")[1]}return""};ddajaxtabs.setCookie=function(a,b){document.cookie=a+"="+b+";path=/"};ddajaxtabs.prototype={expandit:function(a){this.cancelautorun();var b="";try{if(typeof a=="string"&&document.getElementById(a).getAttribute("rel")){b=document.getElementById(a)}else{if(parseInt(a)!=NaN&&this.tabs[a].getAttribute("rel")){b=this.tabs[a]}}}catch(c){alert("Invalid Tab ID or position entered!")}if(b!=""){this.expandtab(b)}},cycleit:function(b,a){if(b=="next"){var c=(this.currentTabIndex<this.hottabspositions.length-1)?this.currentTabIndex+1:0}else{if(b=="prev"){var c=(this.currentTabIndex>0)?this.currentTabIndex-1:this.hottabspositions.length-1}}if(typeof a=="undefined"){this.cancelautorun()}this.expandtab(this.tabs[this.hottabspositions[c]])},setpersist:function(a){this.enabletabpersistence=a},loadajaxpage:function(a){ddajaxtabs.connect(a,this)},loadiframepage:function(a){this.iframedisplay(a,this.contentdivid)},setselectedClassTarget:function(a){this.selectedClassTarget=a||"link"},getselectedClassTarget:function(a){return(this.selectedClassTarget==("linkparent".toLowerCase()))?a.parentNode:a},urlparamselect:function(b){var a=window.location.search.match(new RegExp(b+"=(\\d+)","i"));return(a==null)?null:parseInt(RegExp.$1)},onajaxpageload:function(a){},expandtab:function(b){var d=b.getAttribute("rel");var c=(b.getAttribute("rev"))?","+b.getAttribute("rev").replace(/\s+/,"")+",":"";if(d=="#default"){document.getElementById(this.contentdivid).innerHTML=this.defaultHTML}else{if(d=="#iframe"){this.iframedisplay(b.getAttribute("href"),this.contentdivid)}else{ddajaxtabs.connect(b.getAttribute("href"),this)}}this.expandrevcontent(c);for(var a=0;a<this.tabs.length;a++){this.getselectedClassTarget(this.tabs[a]).className=(this.tabs[a].getAttribute("href")==b.getAttribute("href"))?"selected":""}if(this.enabletabpersistence){ddajaxtabs.setCookie(this.tabinterfaceid,b.tabposition)}this.setcurrenttabindex(b.tabposition)},iframedisplay:function(b,a){if(typeof window.frames["_ddajaxtabsiframe-"+a]!="undefined"){try{delete window.frames["_ddajaxtabsiframe-"+a]}catch(c){}}document.getElementById(a).innerHTML=this.defaultIframe;window.frames["_ddajaxtabsiframe-"+a].location.replace(b)},expandrevcontent:function(c){var a=this.revcontentids;for(var b=0;b<a.length;b++){document.getElementById(a[b]).style.display=(c.indexOf(","+a[b]+",")!=-1)?"block":"none"}},setcurrenttabindex:function(a){for(var b=0;b<this.hottabspositions.length;b++){if(a==this.hottabspositions[b]){this.currentTabIndex=b;break}}},autorun:function(){this.cycleit("next",true)},cancelautorun:function(){if(typeof this.autoruntimer!="undefined"){clearInterval(this.autoruntimer)}},init:function(a){var e=ddajaxtabs.getCookie(this.tabinterfaceid);var d=-1;var f=this.urlparamselect(this.tabinterfaceid);this.automodeperiod=a||0;this.defaultHTML=document.getElementById(this.contentdivid).innerHTML;for(var c=0;c<this.tabs.length;c++){this.tabs[c].tabposition=c;if(this.tabs[c].getAttribute("rel")){var b=this;this.hottabspositions[this.hottabspositions.length]=c;this.tabs[c].onclick=function(){b.expandtab(this);b.cancelautorun();return false};if(this.tabs[c].getAttribute("rev")){this.revcontentids=this.revcontentids.concat(this.tabs[c].getAttribute("rev").split(/\s*,\s*/))}if(f==c||this.enabletabpersistence&&d==-1&&parseInt(e)==c||!this.enabletabpersistence&&d==-1&&this.getselectedClassTarget(this.tabs[c]).className=="selected"){d=c}}}if(d!=-1){this.expandtab(this.tabs[d])}else{this.expandtab(this.tabs[this.hottabspositions[0]])}if(parseInt(this.automodeperiod)>500&&this.hottabspositions.length>1){this.autoruntimer=setInterval(function(){b.autorun()},this.automodeperiod)}}};/***
 * MooCrop (v. 1.2 - 2008-08-31 )
 *
 * @version			rc-1
 * @license			BSD-style license
 * @author			nwhite - < nw [at] nwhite.net >
 * @infos			http://www.nwhite.net/MooCrop/
 * @copyright			Author
 *
 * Modifications made by Rok - rokmail [at] gmail.com
 * 1. Ported for MooTools 1.2 
 * 2. Ratio constraints added
 * Modifications made by Ash - ash [at] copyright86.com
 * 1. Fixed Ratio constraints to work in other directions
 */

var MooCrop = new Class({
 
	calculateHandles : true,
	current : {},
 
	options : {
		maskColor : 'black',
		maskOpacity : '.4',
		handleColor : 'white',
		handleWidth : '4px',
		handleHeight : '4px',
		cropBorder : '1px dashed white',
		min : { 'width' : 25, 'height' : 25 },
		showMask : true, // false to remove, helps on slow machines
		showHandles : false, // hide handles on drag
		//constrainRatio : true // hide handles on drag
	},
 
	initialize: function(el, options){
		this.setOptions(options);
		this.img = $(el); 
		if ( this.img.get('tag') != 'img') return false;
		this.resizeFunc = this.refresh.bindWithEvent(this);
		this.removeFunc = this.removeListener.bind(this);
 
		this.buildOverlay();
		this.setup();
	},
 
	setup: function(){
		$(this.cropArea).setStyles({
			'z-index':50,
			'width': this.options.min.width, 
			'height': this.options.min.height,
			'top' : (this.imgsize.height - this.options.min.height)/2,
			'left': (this.imgsize.width - this.options.min.width) / 2 
		});
 
		this.current.crop = this.crop = this.getCropArea();
 
		this.handleWidthOffset = this.options.handleWidth.toInt() / 2;
		this.handleHeightOffset = this.options.handleHeight.toInt() /2;
 
		this.fixBoxModel();
		this.drawMasks();
		this.positionHandles();
	},
 
	getCropArea : function(){
		var crop = this.cropArea.getCoordinates();
		crop.left -= this.offsets.x; crop.right -= this.offsets.x; // calculate relative (horizontal)
		crop.top -= this.offsets.y; crop.bottom  -= this.offsets.y; // calculate relative (vertical)
		return crop;
	},
 

	fixBoxModel : function(){
		var diff = this.boxDiff = (this.crop.width - this.options.min.width)/2;
		var b = this.bounds = { 'top' : diff, 'left' : diff, 
			'right' : this.imgsize.width+(diff*2), 'bottom' : this.imgsize.height+(diff*2),
			'width' : this.options.min.width+(diff*2), 'height' : this.options.min.height+(diff*2) };
 
		this.wrapper.setStyles({
			'width' : b.right, 'height' : b.bottom,
			'background' : 'url('+this.img.src+') no-repeat '+diff+'px '+diff+'px'
		});
		this.north.setStyle('width',b.right);
		this.south.setStyle('width',b.right);
	},
 
	activate : function(event,handle){
		event.stop();
		this.current = { 'x' : event.page.x, 'y' : event.page.y, 'handle' : handle, 'crop' : this.current.crop };
		if(this.current.handle == 'NESW' && !this.options.showHandles) this.hideHandles();
		this.fireEvent('onBegin',[this.img.src,this.getCropInfo(),this.bounds,handle]);
		document.addListener('mousemove', this.resizeFunc);
		document.addListener('mouseup', this.removeFunc);
	},
 
	removeListener : function(){
		if( this.current.handle == 'NESW' && !this.options.showHandles) this.showHandles();
		document.removeListener('mousemove', this.resizeFunc);
		document.removeListener('mouseup', this.removeFunc);
		this.crop = this.current.crop;
		this.fireEvent('onComplete',[this.img.src,this.getCropInfo(),this.bounds,this.current.handle]);
	},
	refresh : function(event){
		var pageX = event.clientX + $(document.body).getScroll().x;
		var pageY = event.clientY + $(document.body).getScroll().y;
		var xdiff = this.current.x - pageX;
		var ydiff = this.current.y - pageY;
		var b = this.bounds;  
		var c = this.crop;  
		var handle = this.current.handle; 
		var styles = {}; //saving bytes	
		var dragging = (handle.length > 2) ? true : false;
		var multiplier = 0;
		if (dragging) {
			if(c.bottom - ydiff > b.bottom ) ydiff = c.bottom - b.bottom; // box south
			if(c.top - ydiff < b.top ) ydiff = c.top; //box north
			if(c.right - xdiff > b.right) xdiff = c.right - b.right; //box east
			if(c.left - xdiff < b.left) xdiff = c.left; //box west
			styles.top = c.top - ydiff; 
			styles.left = c.left - xdiff;
		} else {
                	if( handle.contains("S") && !handle.contains("W") && !handle.contains("E")) {//SOUTH
                		if(c.bottom - ydiff > b.bottom ) ydiff = c.bottom - b.bottom; // box south
               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south
               			if (this.options.constrainRatio) { 
               				if(c.right - ydiff > b.right ) {
               					ydiff = c.right - b.right;
               					xdiff = ydiff;
               					styles.width = c.width - xdiff;
               					styles.height = c.height - ydiff;
               				} else {
               					styles.width = c.width - ydiff;
               					styles.height = c.height - ydiff;
               				}
               			} else {
               				styles.height = c.height - ydiff; 
               			}
                	} else 

                	if( handle.contains("N") && !handle.contains("W") && !handle.contains("E")) {//NORTH
                		if(c.top - ydiff < b.top ) ydiff = c.top; //box north
               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north
               			if (this.options.constrainRatio) { 
               				if(c.right + ydiff > b.right ) {
               					xdiff = b.right - c.right;
               					ydiff = xdiff;
               					styles.width = c.width + xdiff;
               					styles.height = c.height + ydiff;
               				} else {
               					styles.width = c.width + ydiff;
               					styles.height = c.height + ydiff;
               				}
               			} else {
               				styles.height = c.height + ydiff; 
               			}
                		styles.top = c.top - ydiff; 
                	} else

                	if( handle.contains("E") && !handle.contains("S") && !handle.contains("N")){//EAST
                		if(c.right - xdiff > b.right) xdiff = c.right - b.right; //box east
               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if (this.options.constrainRatio) { 
               				if(c.bottom - xdiff > b.bottom ) {
               					xdiff = c.bottom - b.bottom;
               					ydiff = xdiff;
              						styles.width = c.width - xdiff;
              						styles.height = c.height - ydiff;
               				} else {
              						styles.width = c.width - xdiff;
              						styles.height = c.height - xdiff;
               				}
               			} else {
               				styles.width = c.width - xdiff;
               			}
                	} else 

                	if( handle.contains("W") && !handle.contains("S") && !handle.contains("N")){//WEST
                		if(c.left - xdiff < b.left) xdiff = c.left; //box west
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west
               			if (this.options.constrainRatio) { 
               				if (c.bottom + xdiff > b.bottom ) {
               					xdiff = b.bottom - c.bottom;
               					ydiff = xdiff;
              						styles.width = c.width + xdiff;
              						styles.height = c.height + ydiff;
               				} else {
              						styles.width = c.width + xdiff;
              						styles.height = c.height + xdiff;
               				}
               			} else {
               				styles.width = c.width + xdiff;
               			}
                		styles.left = c.left - xdiff; 
                	} else
                	
                	if( this.options.constrainRatio )
                	{
                		
                		if( c.width > c.height) multiplier = c.height / c.width;
                		else multiplier = c.width / c.height;
                		
                	}

                	if( handle.contains("S") && handle.contains("E") ){//SOUTH & EAST

                		if(c.right - xdiff > b.right) { xdiff = c.right - b.right; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.bottom - xdiff > b.bottom ) { xdiff = c.bottom - b.bottom; }// box south
                		} else {
                			if(c.bottom - ydiff > b.bottom ) { ydiff = c.bottom - b.bottom; }// box south
                		}

               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south

               			if (this.options.constrainRatio) {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - (multiplier * xdiff); 
                		} else {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - ydiff; 
                		}


                	} else

                	if( handle.contains("N") && handle.contains("E") ){//NORTH & EAST

                		if(c.right - xdiff > b.right) { xdiff = c.right - b.right; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.top + xdiff < b.top ) { xdiff = b.top - c.top; }// box south
                		} else {
                			if(c.top - ydiff < b.top ) { ydiff = c.top - b.top; }// box south
                		}

               			if( (c.width - xdiff) < b.width ) xdiff = c.width - b.width; // size east
               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north

               			if (this.options.constrainRatio) {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height - (multiplier * xdiff); 
                			styles.top = c.top + xdiff; 
                		} else {
                			styles.width = c.width - xdiff; 
                			styles.height = c.height + ydiff; 
                			styles.top = c.top - ydiff; 
                		}
                		
                	} else

                	if( handle.contains("S") && handle.contains("W") ){//SOUTH & WEST

                		if(c.left - xdiff < b.left) { xdiff = c.left - b.left; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.bottom + xdiff > b.bottom ) { xdiff = b.bottom - c.bottom; }// box south
                		} else {
                			if(c.bottom - ydiff > b.bottom ) { ydiff = c.bottom - b.bottom; }// box south
                		}

               			if( (c.height - ydiff) < b.height ) ydiff = c.height - b.height; // size south
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west

               			if (this.options.constrainRatio) {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + (multiplier * xdiff); 
                			styles.left = c.left - xdiff; 
                		} else {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height - ydiff; 
                			styles.left = c.left - xdiff; 
                		}

                	} else

                	if( handle.contains("N") && handle.contains("W") ){//WEST & NORTH

                		if(c.left - xdiff < b.left) { xdiff = c.left - b.left; }//box east

               			if (this.options.constrainRatio) { 
                			if(c.top - xdiff < b.top ) { xdiff = c.top - b.top; }// box south
                		} else {
                			if(c.top - ydiff < b.top ) { ydiff = c.top - b.top; }// box south
                		}

               			if( (c.height + ydiff ) < b.height ) ydiff = b.height - c.height; // size north
               			if( (c.width + xdiff) < b.width ) xdiff = b.width - c.width; //size west

               			if (this.options.constrainRatio) {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + (multiplier * xdiff); 
                			styles.left = c.left - xdiff; 
                			styles.top = c.top - xdiff; 
                		} else {
                			styles.width = c.width + xdiff; 
                			styles.height = c.height + ydiff; 
                			styles.left = c.left - xdiff; 
                			styles.top = c.top - ydiff; 
                		}


                	} 
		}

		var preCssStyles = $merge(styles);
		if( $defined(styles.width)) styles.width -= this.boxDiff*2;
		if( $defined(styles.height)) styles.height -= this.boxDiff*2;
		this.cropArea.setStyles(styles);
		this.getCurrentCoords(preCssStyles);
		this.drawMasks();
		this.positionHandles();
		this.fireEvent('onCrop',[this.img.src,this.getCropInfo(),b,handle]);

	},
 
	getCurrentCoords : function(changed){
		var current = $merge(this.crop);
 
		if($defined(changed.left)){
			current.left = changed.left;
			if($defined(changed.width)) current.width = changed.width;
			else current.right = current.left + current.width;
		}
		if($defined(changed.top)){
			current.top = changed.top;
			if($defined(changed.height)) current.height = changed.height;
			else current.bottom = current.top + current.height;
		}
		if($defined(changed.width) && !$defined(changed.left)){
			current.width = changed.width; 
			current.right = current.left + current.width;
		}
		if($defined(changed.height) && !$defined(changed.top)){
			current.height = changed.height;
			current.bottom = current.top + current.height;
		}
		this.current.crop = current;
	},
 
	drawMasks : function(){
		if(!this.options.showMask) return;
		var b = this.bounds;
		var c = this.current.crop; 
		var handle = this.current.handle;
		this.north.setStyle('height', c.top + 'px' );
		this.south.setStyle('height', b.bottom  - c.bottom  + 'px');
		this.east.setStyles({ 'height': c.height + 'px', 'width': b.right  - c.right + 'px',  'top': c.top  + 'px', 'left': c.right + 'px'});
		this.west.setStyles({ 'height': c.height + 'px', 'width': c.left + 'px', 'top': c.top + 'px'});
	},
 
	positionHandles: function(){
		if(!this.calculateHandles) return;
		var c = this.current.crop; var wOffset = this.handleWidthOffset; var hOffset = this.handleHeightOffset;
 
		this.handles.get('N').setStyles({'left' : c.width / 2 - wOffset + 'px', 'top' : - hOffset + 'px'});
		this.handles.get('NE').setStyles({'left' : c.width - wOffset + 'px', 'top' : - hOffset + 'px'});
		this.handles.get('E').setStyles({ 'left' : c.width - wOffset + 'px', 'top' : c.height / 2 - hOffset + 'px'});
		this.handles.get('SE').setStyles({'left' : c.width - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('S').setStyles({'left' : c.width / 2 - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('SW').setStyles({'left' : - wOffset + 'px', 'top' : c.height - hOffset + 'px'});
		this.handles.get('W').setStyles({'left' : - wOffset + 'px', 'top' : c.height / 2 - hOffset + 'px'});
		this.handles.get('NW').setStyles({'left' : - wOffset + 'px', 'top' : - hOffset + 'px'});
	},
 
	hideHandles: function(){
		this.calculateHandles = false;
		this.handles.each(function(handle){
			handle.setStyle('display','none');
		});
	},
 
	showHandles: function(){
		this.calculateHandles = true;
		this.positionHandles();
		this.handles.each(function(handle){
			handle.setStyle('display','block');
		});
	},
 
	buildOverlay: function(){
		var o = this.options;
		this.img.setStyle('padding','0');
		this.wrapper = new Element('div', {
			'class': 'crop_wrapper',
			'styles' :  {'position' : 'relative', 'width' : this.img.width, 'height' : this.img.height, 'background' : 'url('+this.img.src+') no-repeat' , 'float' : this.img.getStyle('float')}
		}).inject(this.img,'before');

		this.imgsize = {'width' : this.img.width, 'height' : this.img.height};
		this.img.setStyle('display','none');
		this.offsets = { x : this.wrapper.getCoordinates().left, y : this.wrapper.getCoordinates().top };
 
		if(this.options.showMask){		// optional masks
			var maskStyles = { 'position' : 'absolute', 'overflow' : 'hidden', 'background-color' : o.maskColor, 'opacity' : o.maskOpacity};
			this.north = new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
			this.south = new Element("div", {'styles' : $merge(maskStyles,{'bottom':'0px'})}).inject(this.wrapper);
			this.east =  new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
			this.west =  new Element("div", {'styles' : maskStyles}).inject(this.wrapper);
		}
		this.cropArea = new Element("div", { 'styles' : { 'position' : 'absolute', 'top' : '0px', 'left' : '0px', 'border' : o.cropBorder, 'cursor' : 'move' },
		'events' : {
			'dblclick' : function(){ this.fireEvent('onDblClk',[this.img.src,this.getCropInfo(),this.bounds])}.bind(this),
			'mousedown' : this.activate.bindWithEvent(this,'NESW')}
		}).inject(this.wrapper,'bottom');
 
		this.handles = new Hash();
		['N','NE','E','SE','S','SW','W','NW'].each(function(handle){
			this.handles.set(handle, new Element("div", {
			'styles' : { 'position' : 'absolute', 'background-color' : o.handleColor, 
						 'width' : o.handleWidth, 'height' : o.handleHeight, 'overflow' : 'hidden', 'cursor' : (handle.toLowerCase()+'-resize')},
			'events' : {'mousedown' : this.activate.bindWithEvent(this,handle)}
			}).inject(this.cropArea,'bottom'));
		},this);
	},
 
	getCropInfo : function(){
		var c = $merge(this.current.crop);
		c.width -= this.boxDiff*2; c.height -= this.boxDiff*2;
		return c;
	},
 
	removeOverlay: function(){
		this.wrapper.dispose();
		this.img.setStyle('display','block');
	}
 
});
MooCrop.implement(new Events, new Options);Request.HTML.implement({
 
    processHTML: function(text){
        var match = text.match(/<body[^>]*>([\s\S]*?)<\/body>/i);
        text = (match) ? match[1] : text;
           
        var container = new Element('div');
           
        return $try(function(){
        var root = '<root>' + text + '</root>', doc;
            doc = new DOMParser().parseFromString(root, 'text/html');
            root = doc.getElementsByTagName('root')[0];
            for (var i = 0, k = root.childNodes.length; i < k; i++){
                var child = Element.clone(root.childNodes[i], true, true);
                if (child) container.grab(child);
            }
            return container;
        }) || container.set('html', text);
    }
   
});
