var Prototype={Version:"1.6.0.3",Browser:{IE:!!(window.attachEvent&&navigator.userAgent.indexOf("Opera")===-1),Opera:navigator.userAgent.indexOf("Opera")>-1,WebKit:navigator.userAgent.indexOf("AppleWebKit/")>-1,Gecko:navigator.userAgent.indexOf("Gecko")>-1&&navigator.userAgent.indexOf("KHTML")===-1,MobileSafari:!!navigator.userAgent.match(/Apple.*Mobile.*Safari/)},BrowserFeatures:{XPath:!!document.evaluate,SelectorsAPI:!!document.querySelector,ElementExtensions:!!window.HTMLElement,SpecificElementExtensions:document.createElement("div")["__proto__"]&&document.createElement("div")["__proto__"]!==document.createElement("form")["__proto__"]},ScriptFragment:"<script[^>]*>([\\S\\s]*?)<\/script>",JSONFilter:/^\/\*-secure-([\s\S]*)\*\/\s*$/,emptyFunction:function(){},K:function(A){return A}};if(Prototype.Browser.MobileSafari){Prototype.BrowserFeatures.SpecificElementExtensions=false}var Class={create:function(){var E=null,D=$A(arguments);if(Object.isFunction(D[0])){E=D.shift()}function A(){this.initialize.apply(this,arguments)}Object.extend(A,Class.Methods);A.superclass=E;A.subclasses=[];if(E){var B=function(){};B.prototype=E.prototype;A.prototype=new B;E.subclasses.push(A)}for(var C=0;C<D.length;C++){A.addMethods(D[C])}if(!A.prototype.initialize){A.prototype.initialize=Prototype.emptyFunction}A.prototype.constructor=A;return A}};Class.Methods={addMethods:function(G){var C=this.superclass&&this.superclass.prototype;var B=Object.keys(G);if(!Object.keys({toString:true}).length){B.push("toString","valueOf")}for(var A=0,D=B.length;A<D;A++){var F=B[A],E=G[F];if(C&&Object.isFunction(E)&&E.argumentNames().first()=="$super"){var H=E;E=(function(I){return function(){return C[I].apply(this,arguments)}})(F).wrap(H);E.valueOf=H.valueOf.bind(H);E.toString=H.toString.bind(H)}this.prototype[F]=E}return this}};var Abstract={};Object.extend=function(A,C){for(var B in C){A[B]=C[B]}return A};Object.extend(Object,{inspect:function(A){try{if(Object.isUndefined(A)){return"undefined"}if(A===null){return"null"}return A.inspect?A.inspect():String(A)}catch(B){if(B instanceof RangeError){return"..."}throw B}},toJSON:function(A){var C=typeof A;switch(C){case"undefined":case"function":case"unknown":return ;case"boolean":return A.toString()}if(A===null){return"null"}if(A.toJSON){return A.toJSON()}if(Object.isElement(A)){return }var B=[];for(var E in A){var D=Object.toJSON(A[E]);if(!Object.isUndefined(D)){B.push(E.toJSON()+": "+D)}}return"{"+B.join(", ")+"}"},toQueryString:function(A){return $H(A).toQueryString()},toHTML:function(A){return A&&A.toHTML?A.toHTML():String.interpret(A)},keys:function(A){var B=[];for(var C in A){B.push(C)}return B},values:function(B){var A=[];for(var C in B){A.push(B[C])}return A},clone:function(A){return Object.extend({},A)},isElement:function(A){return !!(A&&A.nodeType==1)},isArray:function(A){return A!=null&&typeof A=="object"&&"splice" in A&&"join" in A},isHash:function(A){return A instanceof Hash},isFunction:function(A){return typeof A=="function"},isString:function(A){return typeof A=="string"},isNumber:function(A){return typeof A=="number"},isUndefined:function(A){return typeof A=="undefined"}});Object.extend(Function.prototype,{argumentNames:function(){var A=this.toString().match(/^[\s\(]*function[^(]*\(([^\)]*)\)/)[1].replace(/\s+/g,"").split(",");return A.length==1&&!A[0]?[]:A},bind:function(){if(arguments.length<2&&Object.isUndefined(arguments[0])){return this}var A=this,C=$A(arguments),B=C.shift();return function(){return A.apply(B,C.concat($A(arguments)))}},bindAsEventListener:function(){var A=this,C=$A(arguments),B=C.shift();return function(D){return A.apply(B,[D||window.event].concat(C))}},curry:function(){if(!arguments.length){return this}var A=this,B=$A(arguments);return function(){return A.apply(this,B.concat($A(arguments)))}},delay:function(){var A=this,B=$A(arguments),C=B.shift()*1000;return window.setTimeout(function(){return A.apply(A,B)},C)},defer:function(){var A=[0.01].concat($A(arguments));return this.delay.apply(this,A)},wrap:function(B){var A=this;return function(){return B.apply(this,[A.bind(this)].concat($A(arguments)))}},methodize:function(){if(this._methodized){return this._methodized}var A=this;return this._methodized=function(){return A.apply(null,[this].concat($A(arguments)))}}});Date.prototype.toJSON=function(){return'"'+this.getUTCFullYear()+"-"+(this.getUTCMonth()+1).toPaddedString(2)+"-"+this.getUTCDate().toPaddedString(2)+"T"+this.getUTCHours().toPaddedString(2)+":"+this.getUTCMinutes().toPaddedString(2)+":"+this.getUTCSeconds().toPaddedString(2)+'Z"'};var Try={these:function(){var C;for(var B=0,D=arguments.length;B<D;B++){var A=arguments[B];try{C=A();break}catch(E){}}return C}};RegExp.prototype.match=RegExp.prototype.test;RegExp.escape=function(A){return String(A).replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")};var PeriodicalExecuter=Class.create({initialize:function(B,A){this.callback=B;this.frequency=A;this.currentlyExecuting=false;this.registerCallback()},registerCallback:function(){this.timer=setInterval(this.onTimerEvent.bind(this),this.frequency*1000)},execute:function(){this.callback(this)},stop:function(){if(!this.timer){return }clearInterval(this.timer);this.timer=null},onTimerEvent:function(){if(!this.currentlyExecuting){try{this.currentlyExecuting=true;this.execute()}finally{this.currentlyExecuting=false}}}});Object.extend(String,{interpret:function(A){return A==null?"":String(A)},specialChar:{"\b":"\\b","\t":"\\t","\n":"\\n","\f":"\\f","\r":"\\r","\\":"\\\\"}});Object.extend(String.prototype,{gsub:function(E,C){var A="",D=this,B;C=arguments.callee.prepareReplacement(C);while(D.length>0){if(B=D.match(E)){A+=D.slice(0,B.index);A+=String.interpret(C(B));D=D.slice(B.index+B[0].length)}else{A+=D,D=""}}return A},sub:function(C,A,B){A=this.gsub.prepareReplacement(A);B=Object.isUndefined(B)?1:B;return this.gsub(C,function(D){if(--B<0){return D[0]}return A(D)})},scan:function(B,A){this.gsub(B,A);return String(this)},truncate:function(B,A){B=B||30;A=Object.isUndefined(A)?"...":A;return this.length>B?this.slice(0,B-A.length)+A:String(this)},strip:function(){return this.replace(/^\s+/,"").replace(/\s+$/,"")},stripTags:function(){return this.replace(/<\/?[^>]+>/gi,"")},stripScripts:function(){return this.replace(new RegExp(Prototype.ScriptFragment,"img"),"")},extractScripts:function(){var B=new RegExp(Prototype.ScriptFragment,"img");var A=new RegExp(Prototype.ScriptFragment,"im");return(this.match(B)||[]).map(function(C){return(C.match(A)||["",""])[1]})},evalScripts:function(){return this.extractScripts().map(function(script){return eval(script)})},escapeHTML:function(){var A=arguments.callee;A.text.data=this;return A.div.innerHTML},unescapeHTML:function(){var A=new Element("div");A.innerHTML=this.stripTags();return A.childNodes[0]?(A.childNodes.length>1?$A(A.childNodes).inject("",function(B,C){return B+C.nodeValue}):A.childNodes[0].nodeValue):""},toQueryParams:function(B){var A=this.strip().match(/([^?#]*)(#.*)?$/);if(!A){return{}}return A[1].split(B||"&").inject({},function(E,F){if((F=F.split("="))[0]){var C=decodeURIComponent(F.shift());var D=F.length>1?F.join("="):F[0];if(D!=undefined){D=decodeURIComponent(D)}if(C in E){if(!Object.isArray(E[C])){E[C]=[E[C]]}E[C].push(D)}else{E[C]=D}}return E})},toArray:function(){return this.split("")},succ:function(){return this.slice(0,this.length-1)+String.fromCharCode(this.charCodeAt(this.length-1)+1)},times:function(A){return A<1?"":new Array(A+1).join(this)},camelize:function(){var D=this.split("-"),A=D.length;if(A==1){return D[0]}var C=this.charAt(0)=="-"?D[0].charAt(0).toUpperCase()+D[0].substring(1):D[0];for(var B=1;B<A;B++){C+=D[B].charAt(0).toUpperCase()+D[B].substring(1)}return C},capitalize:function(){return this.charAt(0).toUpperCase()+this.substring(1).toLowerCase()},underscore:function(){return this.gsub(/::/,"/").gsub(/([A-Z]+)([A-Z][a-z])/,"#{1}_#{2}").gsub(/([a-z\d])([A-Z])/,"#{1}_#{2}").gsub(/-/,"_").toLowerCase()},dasherize:function(){return this.gsub(/_/,"-")},inspect:function(B){var A=this.gsub(/[\x00-\x1f\\]/,function(C){var D=String.specialChar[C[0]];return D?D:"\\u00"+C[0].charCodeAt().toPaddedString(2,16)});if(B){return'"'+A.replace(/"/g,'\\"')+'"'}return"'"+A.replace(/'/g,"\\'")+"'"},toJSON:function(){return this.inspect(true)},unfilterJSON:function(A){return this.sub(A||Prototype.JSONFilter,"#{1}")},isJSON:function(){var A=this;if(A.blank()){return false}A=this.replace(/\\./g,"@").replace(/"[^"\\\n\r]*"/g,"");return(/^[,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]*$/).test(A)},evalJSON:function(sanitize){var json=this.unfilterJSON();try{if(!sanitize||json.isJSON()){return eval("("+json+")")}}catch(e){}throw new SyntaxError("Badly formed JSON string: "+this.inspect())},include:function(A){return this.indexOf(A)>-1},startsWith:function(A){return this.indexOf(A)===0},endsWith:function(A){var B=this.length-A.length;return B>=0&&this.lastIndexOf(A)===B},empty:function(){return this==""},blank:function(){return/^\s*$/.test(this)},interpolate:function(A,B){return new Template(this,B).evaluate(A)}});if(Prototype.Browser.WebKit||Prototype.Browser.IE){Object.extend(String.prototype,{escapeHTML:function(){return this.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;")},unescapeHTML:function(){return this.stripTags().replace(/&amp;/g,"&").replace(/&lt;/g,"<").replace(/&gt;/g,">")}})}String.prototype.gsub.prepareReplacement=function(B){if(Object.isFunction(B)){return B}var A=new Template(B);return function(C){return A.evaluate(C)}};String.prototype.parseQuery=String.prototype.toQueryParams;Object.extend(String.prototype.escapeHTML,{div:document.createElement("div"),text:document.createTextNode("")});String.prototype.escapeHTML.div.appendChild(String.prototype.escapeHTML.text);var Template=Class.create({initialize:function(A,B){this.template=A.toString();this.pattern=B||Template.Pattern},evaluate:function(A){if(Object.isFunction(A.toTemplateReplacements)){A=A.toTemplateReplacements()}return this.template.gsub(this.pattern,function(D){if(A==null){return""}var F=D[1]||"";if(F=="\\"){return D[2]}var B=A,G=D[3];var E=/^([^.[]+|\[((?:.*?[^\\])?)\])(\.|\[|$)/;D=E.exec(G);if(D==null){return F}while(D!=null){var C=D[1].startsWith("[")?D[2].gsub("\\\\]","]"):D[1];B=B[C];if(null==B||""==D[3]){break}G=G.substring("["==D[3]?D[1].length:D[0].length);D=E.exec(G)}return F+String.interpret(B)})}});Template.Pattern=/(^|.|\r|\n)(#\{(.*?)\})/;var $break={};var Enumerable={each:function(C,B){var A=0;try{this._each(function(E){C.call(B,E,A++)})}catch(D){if(D!=$break){throw D}}return this},eachSlice:function(D,C,B){var A=-D,E=[],F=this.toArray();if(D<1){return F}while((A+=D)<F.length){E.push(F.slice(A,A+D))}return E.collect(C,B)},all:function(C,B){C=C||Prototype.K;var A=true;this.each(function(E,D){A=A&&!!C.call(B,E,D);if(!A){throw $break}});return A},any:function(C,B){C=C||Prototype.K;var A=false;this.each(function(E,D){if(A=!!C.call(B,E,D)){throw $break}});return A},collect:function(C,B){C=C||Prototype.K;var A=[];this.each(function(E,D){A.push(C.call(B,E,D))});return A},detect:function(C,B){var A;this.each(function(E,D){if(C.call(B,E,D)){A=E;throw $break}});return A},findAll:function(C,B){var A=[];this.each(function(E,D){if(C.call(B,E,D)){A.push(E)}});return A},grep:function(D,C,B){C=C||Prototype.K;var A=[];if(Object.isString(D)){D=new RegExp(D)}this.each(function(F,E){if(D.match(F)){A.push(C.call(B,F,E))}});return A},include:function(A){if(Object.isFunction(this.indexOf)){if(this.indexOf(A)!=-1){return true}}var B=false;this.each(function(C){if(C==A){B=true;throw $break}});return B},inGroupsOf:function(B,A){A=Object.isUndefined(A)?null:A;return this.eachSlice(B,function(C){while(C.length<B){C.push(A)}return C})},inject:function(A,C,B){this.each(function(E,D){A=C.call(B,A,E,D)});return A},invoke:function(B){var A=$A(arguments).slice(1);return this.map(function(C){return C[B].apply(C,A)})},max:function(C,B){C=C||Prototype.K;var A;this.each(function(E,D){E=C.call(B,E,D);if(A==null||E>=A){A=E}});return A},min:function(C,B){C=C||Prototype.K;var A;this.each(function(E,D){E=C.call(B,E,D);if(A==null||E<A){A=E}});return A},partition:function(D,B){D=D||Prototype.K;var C=[],A=[];this.each(function(F,E){(D.call(B,F,E)?C:A).push(F)});return[C,A]},pluck:function(B){var A=[];this.each(function(C){A.push(C[B])});return A},reject:function(C,B){var A=[];this.each(function(E,D){if(!C.call(B,E,D)){A.push(E)}});return A},sortBy:function(B,A){return this.map(function(D,C){return{value:D,criteria:B.call(A,D,C)}}).sort(function(F,E){var D=F.criteria,C=E.criteria;return D<C?-1:D>C?1:0}).pluck("value")},toArray:function(){return this.map()},zip:function(){var B=Prototype.K,A=$A(arguments);if(Object.isFunction(A.last())){B=A.pop()}var C=[this].concat(A).map($A);return this.map(function(E,D){return B(C.pluck(D))})},size:function(){return this.toArray().length},inspect:function(){return"#<Enumerable:"+this.toArray().inspect()+">"}};Object.extend(Enumerable,{map:Enumerable.collect,find:Enumerable.detect,select:Enumerable.findAll,filter:Enumerable.findAll,member:Enumerable.include,entries:Enumerable.toArray,every:Enumerable.all,some:Enumerable.any});function $A(C){if(!C){return[]}if(C.toArray){return C.toArray()}var B=C.length||0,A=new Array(B);while(B--){A[B]=C[B]}return A}if(Prototype.Browser.WebKit){$A=function(C){if(!C){return[]}if(!(typeof C==="function"&&typeof C.length==="number"&&typeof C.item==="function")&&C.toArray){return C.toArray()}var B=C.length||0,A=new Array(B);while(B--){A[B]=C[B]}return A}}Array.from=$A;Object.extend(Array.prototype,Enumerable);if(!Array.prototype._reverse){Array.prototype._reverse=Array.prototype.reverse}Object.extend(Array.prototype,{_each:function(B){for(var A=0,C=this.length;A<C;A++){B(this[A])}},clear:function(){this.length=0;return this},first:function(){return this[0]},last:function(){return this[this.length-1]},compact:function(){return this.select(function(A){return A!=null})},flatten:function(){return this.inject([],function(B,A){return B.concat(Object.isArray(A)?A.flatten():[A])})},without:function(){var A=$A(arguments);return this.select(function(B){return !A.include(B)})},reverse:function(A){return(A!==false?this:this.toArray())._reverse()},reduce:function(){return this.length>1?this:this[0]},uniq:function(A){return this.inject([],function(D,C,B){if(0==B||(A?D.last()!=C:!D.include(C))){D.push(C)}return D})},intersect:function(A){return this.uniq().findAll(function(B){return A.detect(function(C){return B===C})})},clone:function(){return[].concat(this)},size:function(){return this.length},inspect:function(){return"["+this.map(Object.inspect).join(", ")+"]"},toJSON:function(){var A=[];this.each(function(B){var C=Object.toJSON(B);if(!Object.isUndefined(C)){A.push(C)}});return"["+A.join(", ")+"]"}});if(Object.isFunction(Array.prototype.forEach)){Array.prototype._each=Array.prototype.forEach}if(!Array.prototype.indexOf){Array.prototype.indexOf=function(C,A){A||(A=0);var B=this.length;if(A<0){A=B+A}for(;A<B;A++){if(this[A]===C){return A}}return -1}}if(!Array.prototype.lastIndexOf){Array.prototype.lastIndexOf=function(B,A){A=isNaN(A)?this.length:(A<0?this.length+A:A)+1;var C=this.slice(0,A).reverse().indexOf(B);return(C<0)?C:A-C-1}}Array.prototype.toArray=Array.prototype.clone;function $w(A){if(!Object.isString(A)){return[]}A=A.strip();return A?A.split(/\s+/):[]}if(Prototype.Browser.Opera){Array.prototype.concat=function(){var E=[];for(var B=0,C=this.length;B<C;B++){E.push(this[B])}for(var B=0,C=arguments.length;B<C;B++){if(Object.isArray(arguments[B])){for(var A=0,D=arguments[B].length;A<D;A++){E.push(arguments[B][A])}}else{E.push(arguments[B])}}return E}}Object.extend(Number.prototype,{toColorPart:function(){return this.toPaddedString(2,16)},succ:function(){return this+1},times:function(B,A){$R(0,this,true).each(B,A);return this},toPaddedString:function(C,B){var A=this.toString(B||10);return"0".times(C-A.length)+A},toJSON:function(){return isFinite(this)?this.toString():"null"}});$w("abs round ceil floor").each(function(A){Number.prototype[A]=Math[A].methodize()});function $H(A){return new Hash(A)}var Hash=Class.create(Enumerable,(function(){function A(B,C){if(Object.isUndefined(C)){return B}return B+"="+encodeURIComponent(String.interpret(C))}return{initialize:function(B){this._object=Object.isHash(B)?B.toObject():Object.clone(B)},_each:function(C){for(var B in this._object){var D=this._object[B],E=[B,D];E.key=B;E.value=D;C(E)}},set:function(B,C){return this._object[B]=C},get:function(B){if(this._object[B]!==Object.prototype[B]){return this._object[B]}},unset:function(B){var C=this._object[B];delete this._object[B];return C},toObject:function(){return Object.clone(this._object)},keys:function(){return this.pluck("key")},values:function(){return this.pluck("value")},index:function(C){var B=this.detect(function(D){return D.value===C});return B&&B.key},merge:function(B){return this.clone().update(B)},update:function(B){return new Hash(B).inject(this,function(C,D){C.set(D.key,D.value);return C})},toQueryString:function(){return this.inject([],function(D,E){var C=encodeURIComponent(E.key),B=E.value;if(B&&typeof B=="object"){if(Object.isArray(B)){return D.concat(B.map(A.curry(C)))}}else{D.push(A(C,B))}return D}).join("&")},inspect:function(){return"#<Hash:{"+this.map(function(B){return B.map(Object.inspect).join(": ")}).join(", ")+"}>"},toJSON:function(){return Object.toJSON(this.toObject())},clone:function(){return new Hash(this)}}})());Hash.prototype.toTemplateReplacements=Hash.prototype.toObject;Hash.from=$H;var ObjectRange=Class.create(Enumerable,{initialize:function(C,A,B){this.start=C;this.end=A;this.exclusive=B},_each:function(A){var B=this.start;while(this.include(B)){A(B);B=B.succ()}},include:function(A){if(A<this.start){return false}if(this.exclusive){return A<this.end}return A<=this.end}});var $R=function(C,A,B){return new ObjectRange(C,A,B)};var Ajax={getTransport:function(){return Try.these(function(){return new XMLHttpRequest()},function(){return new ActiveXObject("Msxml2.XMLHTTP")},function(){return new ActiveXObject("Microsoft.XMLHTTP")})||false},activeRequestCount:0};Ajax.Responders={responders:[],_each:function(A){this.responders._each(A)},register:function(A){if(!this.include(A)){this.responders.push(A)}},unregister:function(A){this.responders=this.responders.without(A)},dispatch:function(D,B,C,A){this.each(function(E){if(Object.isFunction(E[D])){try{E[D].apply(E,[B,C,A])}catch(F){}}})}};Object.extend(Ajax.Responders,Enumerable);Ajax.Responders.register({onCreate:function(){Ajax.activeRequestCount++},onComplete:function(){Ajax.activeRequestCount--}});Ajax.Base=Class.create({initialize:function(A){this.options={method:"post",asynchronous:true,contentType:"application/x-www-form-urlencoded",encoding:"UTF-8",parameters:"",evalJSON:true,evalJS:true};Object.extend(this.options,A||{});this.options.method=this.options.method.toLowerCase();if(Object.isString(this.options.parameters)){this.options.parameters=this.options.parameters.toQueryParams()}else{if(Object.isHash(this.options.parameters)){this.options.parameters=this.options.parameters.toObject()}}}});Ajax.Request=Class.create(Ajax.Base,{_complete:false,initialize:function($super,B,A){$super(A);this.transport=Ajax.getTransport();this.request(B)},request:function(B){this.url=B;this.method=this.options.method;var D=Object.clone(this.options.parameters);if(!["get","post"].include(this.method)){D._method=this.method;this.method="post"}this.parameters=D;if(D=Object.toQueryString(D)){if(this.method=="get"){this.url+=(this.url.include("?")?"&":"?")+D}else{if(/Konqueror|Safari|KHTML/.test(navigator.userAgent)){D+="&_="}}}try{var A=new Ajax.Response(this);if(this.options.onCreate){this.options.onCreate(A)}Ajax.Responders.dispatch("onCreate",this,A);this.transport.open(this.method.toUpperCase(),this.url,this.options.asynchronous);if(this.options.asynchronous){this.respondToReadyState.bind(this).defer(1)}this.transport.onreadystatechange=this.onStateChange.bind(this);this.setRequestHeaders();this.body=this.method=="post"?(this.options.postBody||D):null;this.transport.send(this.body);if(!this.options.asynchronous&&this.transport.overrideMimeType){this.onStateChange()}}catch(C){this.dispatchException(C)}},onStateChange:function(){var A=this.transport.readyState;if(A>1&&!((A==4)&&this._complete)){this.respondToReadyState(this.transport.readyState)}},setRequestHeaders:function(){var E={"X-Requested-With":"XMLHttpRequest","X-Prototype-Version":Prototype.Version,Accept:"text/javascript, text/html, application/xml, text/xml, */*"};if(this.method=="post"){E["Content-type"]=this.options.contentType+(this.options.encoding?"; charset="+this.options.encoding:"");if(this.transport.overrideMimeType&&(navigator.userAgent.match(/Gecko\/(\d{4})/)||[0,2005])[1]<2005){E.Connection="close"}}if(typeof this.options.requestHeaders=="object"){var C=this.options.requestHeaders;if(Object.isFunction(C.push)){for(var B=0,D=C.length;B<D;B+=2){E[C[B]]=C[B+1]}}else{$H(C).each(function(F){E[F.key]=F.value})}}for(var A in E){this.transport.setRequestHeader(A,E[A])}},success:function(){var A=this.getStatus();return !A||(A>=200&&A<300)},getStatus:function(){try{return this.transport.status||0}catch(A){return 0}},respondToReadyState:function(A){var C=Ajax.Request.Events[A],B=new Ajax.Response(this);if(C=="Complete"){try{this._complete=true;(this.options["on"+B.status]||this.options["on"+(this.success()?"Success":"Failure")]||Prototype.emptyFunction)(B,B.headerJSON)}catch(D){this.dispatchException(D)}var E=B.getHeader("Content-type");if(this.options.evalJS=="force"||(this.options.evalJS&&this.isSameOrigin()&&E&&E.match(/^\s*(text|application)\/(x-)?(java|ecma)script(;.*)?\s*$/i))){this.evalResponse()}}try{(this.options["on"+C]||Prototype.emptyFunction)(B,B.headerJSON);Ajax.Responders.dispatch("on"+C,this,B,B.headerJSON)}catch(D){this.dispatchException(D)}if(C=="Complete"){this.transport.onreadystatechange=Prototype.emptyFunction}},isSameOrigin:function(){var A=this.url.match(/^\s*https?:\/\/[^\/]*/);return !A||(A[0]=="#{protocol}//#{domain}#{port}".interpolate({protocol:location.protocol,domain:document.domain,port:location.port?":"+location.port:""}))},getHeader:function(A){try{return this.transport.getResponseHeader(A)||null}catch(B){return null}},evalResponse:function(){try{return eval((this.transport.responseText||"").unfilterJSON())}catch(e){this.dispatchException(e)}},dispatchException:function(A){(this.options.onException||Prototype.emptyFunction)(this,A);Ajax.Responders.dispatch("onException",this,A)}});Ajax.Request.Events=["Uninitialized","Loading","Loaded","Interactive","Complete"];Ajax.Response=Class.create({initialize:function(C){this.request=C;var D=this.transport=C.transport,A=this.readyState=D.readyState;if((A>2&&!Prototype.Browser.IE)||A==4){this.status=this.getStatus();this.statusText=this.getStatusText();this.responseText=String.interpret(D.responseText);this.headerJSON=this._getHeaderJSON()}if(A==4){var B=D.responseXML;this.responseXML=Object.isUndefined(B)?null:B;this.responseJSON=this._getResponseJSON()}},status:0,statusText:"",getStatus:Ajax.Request.prototype.getStatus,getStatusText:function(){try{return this.transport.statusText||""}catch(A){return""}},getHeader:Ajax.Request.prototype.getHeader,getAllHeaders:function(){try{return this.getAllResponseHeaders()}catch(A){return null}},getResponseHeader:function(A){return this.transport.getResponseHeader(A)},getAllResponseHeaders:function(){return this.transport.getAllResponseHeaders()},_getHeaderJSON:function(){var A=this.getHeader("X-JSON");if(!A){return null}A=decodeURIComponent(escape(A));try{return A.evalJSON(this.request.options.sanitizeJSON||!this.request.isSameOrigin())}catch(B){this.request.dispatchException(B)}},_getResponseJSON:function(){var A=this.request.options;if(!A.evalJSON||(A.evalJSON!="force"&&!(this.getHeader("Content-type")||"").include("application/json"))||this.responseText.blank()){return null}try{return this.responseText.evalJSON(A.sanitizeJSON||!this.request.isSameOrigin())}catch(B){this.request.dispatchException(B)}}});Ajax.Updater=Class.create(Ajax.Request,{initialize:function($super,A,C,B){this.container={success:(A.success||A),failure:(A.failure||(A.success?null:A))};B=Object.clone(B);var D=B.onComplete;B.onComplete=(function(E,F){this.updateContent(E.responseText);if(Object.isFunction(D)){D(E,F)}}).bind(this);$super(C,B)},updateContent:function(D){var C=this.container[this.success()?"success":"failure"],A=this.options;if(!A.evalScripts){D=D.stripScripts()}if(C=$(C)){if(A.insertion){if(Object.isString(A.insertion)){var B={};B[A.insertion]=D;C.insert(B)}else{A.insertion(C,D)}}else{C.update(D)}}}});Ajax.PeriodicalUpdater=Class.create(Ajax.Base,{initialize:function($super,A,C,B){$super(B);this.onComplete=this.options.onComplete;this.frequency=(this.options.frequency||2);this.decay=(this.options.decay||1);this.updater={};this.container=A;this.url=C;this.start()},start:function(){this.options.onComplete=this.updateComplete.bind(this);this.onTimerEvent()},stop:function(){this.updater.options.onComplete=undefined;clearTimeout(this.timer);(this.onComplete||Prototype.emptyFunction).apply(this,arguments)},updateComplete:function(A){if(this.options.decay){this.decay=(A.responseText==this.lastText?this.decay*this.options.decay:1);this.lastText=A.responseText}this.timer=this.onTimerEvent.bind(this).delay(this.decay*this.frequency)},onTimerEvent:function(){this.updater=new Ajax.Updater(this.container,this.url,this.options)}});function $(B){if(arguments.length>1){for(var A=0,D=[],C=arguments.length;A<C;A++){D.push($(arguments[A]))}return D}if(Object.isString(B)){B=document.getElementById(B)}return Element.extend(B)}if(Prototype.BrowserFeatures.XPath){document._getElementsByXPath=function(F,A){var C=[];var E=document.evaluate(F,$(A)||document,null,XPathResult.ORDERED_NODE_SNAPSHOT_TYPE,null);for(var B=0,D=E.snapshotLength;B<D;B++){C.push(Element.extend(E.snapshotItem(B)))}return C}}if(!window.Node){var Node={}}if(!Node.ELEMENT_NODE){Object.extend(Node,{ELEMENT_NODE:1,ATTRIBUTE_NODE:2,TEXT_NODE:3,CDATA_SECTION_NODE:4,ENTITY_REFERENCE_NODE:5,ENTITY_NODE:6,PROCESSING_INSTRUCTION_NODE:7,COMMENT_NODE:8,DOCUMENT_NODE:9,DOCUMENT_TYPE_NODE:10,DOCUMENT_FRAGMENT_NODE:11,NOTATION_NODE:12})}(function(){var A=this.Element;this.Element=function(D,C){C=C||{};D=D.toLowerCase();var B=Element.cache;if(Prototype.Browser.IE&&C.name){D="<"+D+' name="'+C.name+'">';delete C.name;return Element.writeAttribute(document.createElement(D),C)}if(!B[D]){B[D]=Element.extend(document.createElement(D))}return Element.writeAttribute(B[D].cloneNode(false),C)};Object.extend(this.Element,A||{});if(A){this.Element.prototype=A.prototype}}).call(window);Element.cache={};Element.Methods={visible:function(A){return $(A).style.display!="none"},toggle:function(A){A=$(A);Element[Element.visible(A)?"hide":"show"](A);return A},hide:function(A){A=$(A);A.style.display="none";return A},show:function(A){A=$(A);A.style.display="";return A},remove:function(A){A=$(A);A.parentNode.removeChild(A);return A},update:function(A,B){A=$(A);if(B&&B.toElement){B=B.toElement()}if(Object.isElement(B)){return A.update().insert(B)}B=Object.toHTML(B);A.innerHTML=B.stripScripts();B.evalScripts.bind(B).defer();return A},replace:function(B,C){B=$(B);if(C&&C.toElement){C=C.toElement()}else{if(!Object.isElement(C)){C=Object.toHTML(C);var A=B.ownerDocument.createRange();A.selectNode(B);C.evalScripts.bind(C).defer();C=A.createContextualFragment(C.stripScripts())}}B.parentNode.replaceChild(C,B);return B},insert:function(C,E){C=$(C);if(Object.isString(E)||Object.isNumber(E)||Object.isElement(E)||(E&&(E.toElement||E.toHTML))){E={bottom:E}}var D,F,B,G;for(var A in E){D=E[A];A=A.toLowerCase();F=Element._insertionTranslations[A];if(D&&D.toElement){D=D.toElement()}if(Object.isElement(D)){F(C,D);continue}D=Object.toHTML(D);B=((A=="before"||A=="after")?C.parentNode:C).tagName.toUpperCase();G=Element._getContentFromAnonymousElement(B,D.stripScripts());if(A=="top"||A=="after"){G.reverse()}G.each(F.curry(C));D.evalScripts.bind(D).defer()}return C},wrap:function(B,C,A){B=$(B);if(Object.isElement(C)){$(C).writeAttribute(A||{})}else{if(Object.isString(C)){C=new Element(C,A)}else{C=new Element("div",C)}}if(B.parentNode){B.parentNode.replaceChild(C,B)}C.appendChild(B);return C},inspect:function(B){B=$(B);var A="<"+B.tagName.toLowerCase();$H({id:"id",className:"class"}).each(function(F){var E=F.first(),C=F.last();var D=(B[E]||"").toString();if(D){A+=" "+C+"="+D.inspect(true)}});return A+">"},recursivelyCollect:function(A,C){A=$(A);var B=[];while(A=A[C]){if(A.nodeType==1){B.push(Element.extend(A))}}return B},ancestors:function(A){return $(A).recursivelyCollect("parentNode")},descendants:function(A){return $(A).select("*")},firstDescendant:function(A){A=$(A).firstChild;while(A&&A.nodeType!=1){A=A.nextSibling}return $(A)},immediateDescendants:function(A){if(!(A=$(A).firstChild)){return[]}while(A&&A.nodeType!=1){A=A.nextSibling}if(A){return[A].concat($(A).nextSiblings())}return[]},previousSiblings:function(A){return $(A).recursivelyCollect("previousSibling")},nextSiblings:function(A){return $(A).recursivelyCollect("nextSibling")},siblings:function(A){A=$(A);return A.previousSiblings().reverse().concat(A.nextSiblings())},match:function(B,A){if(Object.isString(A)){A=new Selector(A)}return A.match($(B))},up:function(B,D,A){B=$(B);if(arguments.length==1){return $(B.parentNode)}var C=B.ancestors();return Object.isNumber(D)?C[D]:Selector.findElement(C,D,A)},down:function(B,C,A){B=$(B);if(arguments.length==1){return B.firstDescendant()}return Object.isNumber(C)?B.descendants()[C]:Element.select(B,C)[A||0]},previous:function(B,D,A){B=$(B);if(arguments.length==1){return $(Selector.handlers.previousElementSibling(B))}var C=B.previousSiblings();return Object.isNumber(D)?C[D]:Selector.findElement(C,D,A)},next:function(C,D,B){C=$(C);if(arguments.length==1){return $(Selector.handlers.nextElementSibling(C))}var A=C.nextSiblings();return Object.isNumber(D)?A[D]:Selector.findElement(A,D,B)},select:function(){var A=$A(arguments),B=$(A.shift());return Selector.findChildElements(B,A)},adjacent:function(){var A=$A(arguments),B=$(A.shift());return Selector.findChildElements(B.parentNode,A).without(B)},identify:function(B){B=$(B);var C=B.readAttribute("id"),A=arguments.callee;if(C){return C}do{C="anonymous_element_"+A.counter++}while($(C));B.writeAttribute("id",C);return C},readAttribute:function(C,A){C=$(C);if(Prototype.Browser.IE){var B=Element._attributeTranslations.read;if(B.values[A]){return B.values[A](C,A)}if(B.names[A]){A=B.names[A]}if(A.include(":")){return(!C.attributes||!C.attributes[A])?null:C.attributes[A].value}}return C.getAttribute(A)},writeAttribute:function(E,C,F){E=$(E);var B={},D=Element._attributeTranslations.write;if(typeof C=="object"){B=C}else{B[C]=Object.isUndefined(F)?true:F}for(var A in B){C=D.names[A]||A;F=B[A];if(D.values[A]){C=D.values[A](E,F)}if(F===false||F===null){E.removeAttribute(C)}else{if(F===true){E.setAttribute(C,C)}else{E.setAttribute(C,F)}}}return E},getHeight:function(A){return $(A).getDimensions().height},getWidth:function(A){return $(A).getDimensions().width},classNames:function(A){return new Element.ClassNames(A)},hasClassName:function(A,B){if(!(A=$(A))){return }var C=A.className;return(C.length>0&&(C==B||new RegExp("(^|\\s)"+B+"(\\s|$)").test(C)))},addClassName:function(A,B){if(!(A=$(A))){return }if(!A.hasClassName(B)){A.className+=(A.className?" ":"")+B}return A},removeClassName:function(A,B){if(!(A=$(A))){return }A.className=A.className.replace(new RegExp("(^|\\s+)"+B+"(\\s+|$)")," ").strip();return A},toggleClassName:function(A,B){if(!(A=$(A))){return }return A[A.hasClassName(B)?"removeClassName":"addClassName"](B)},cleanWhitespace:function(B){B=$(B);var C=B.firstChild;while(C){var A=C.nextSibling;if(C.nodeType==3&&!/\S/.test(C.nodeValue)){B.removeChild(C)}C=A}return B},empty:function(A){return $(A).innerHTML.blank()},descendantOf:function(B,A){B=$(B),A=$(A);if(B.compareDocumentPosition){return(B.compareDocumentPosition(A)&8)===8}if(A.contains){return A.contains(B)&&A!==B}while(B=B.parentNode){if(B==A){return true}}return false},scrollTo:function(A){A=$(A);var B=A.cumulativeOffset();window.scrollTo(B[0],B[1]);return A},getStyle:function(B,C){B=$(B);C=C=="float"?"cssFloat":C.camelize();var D=B.style[C];if(!D||D=="auto"){var A=document.defaultView.getComputedStyle(B,null);D=A?A[C]:null}if(C=="opacity"){return D?parseFloat(D):1}return D=="auto"?null:D},getOpacity:function(A){return $(A).getStyle("opacity")},setStyle:function(B,C){B=$(B);var E=B.style,A;if(Object.isString(C)){B.style.cssText+=";"+C;return C.include("opacity")?B.setOpacity(C.match(/opacity:\s*(\d?\.?\d*)/)[1]):B}for(var D in C){if(D=="opacity"){B.setOpacity(C[D])}else{E[(D=="float"||D=="cssFloat")?(Object.isUndefined(E.styleFloat)?"cssFloat":"styleFloat"):D]=C[D]}}return B},setOpacity:function(A,B){A=$(A);A.style.opacity=(B==1||B==="")?"":(B<0.00001)?0:B;return A},getDimensions:function(C){C=$(C);var G=C.getStyle("display");if(G!="none"&&G!=null){return{width:C.offsetWidth,height:C.offsetHeight}}var B=C.style;var F=B.visibility;var D=B.position;var A=B.display;B.visibility="hidden";B.position="absolute";B.display="block";var H=C.clientWidth;var E=C.clientHeight;B.display=A;B.position=D;B.visibility=F;return{width:H,height:E}},makePositioned:function(A){A=$(A);var B=Element.getStyle(A,"position");if(B=="static"||!B){A._madePositioned=true;A.style.position="relative";if(Prototype.Browser.Opera){A.style.top=0;A.style.left=0}}return A},undoPositioned:function(A){A=$(A);if(A._madePositioned){A._madePositioned=undefined;A.style.position=A.style.top=A.style.left=A.style.bottom=A.style.right=""}return A},makeClipping:function(A){A=$(A);if(A._overflow){return A}A._overflow=Element.getStyle(A,"overflow")||"auto";if(A._overflow!=="hidden"){A.style.overflow="hidden"}return A},undoClipping:function(A){A=$(A);if(!A._overflow){return A}A.style.overflow=A._overflow=="auto"?"":A._overflow;A._overflow=null;return A},cumulativeOffset:function(B){var A=0,C=0;do{A+=B.offsetTop||0;C+=B.offsetLeft||0;B=B.offsetParent}while(B);return Element._returnOffset(C,A)},positionedOffset:function(B){var A=0,D=0;do{A+=B.offsetTop||0;D+=B.offsetLeft||0;B=B.offsetParent;if(B){if(B.tagName.toUpperCase()=="BODY"){break}var C=Element.getStyle(B,"position");if(C!=="static"){break}}}while(B);return Element._returnOffset(D,A)},absolutize:function(B){B=$(B);if(B.getStyle("position")=="absolute"){return B}var D=B.positionedOffset();var F=D[1];var E=D[0];var C=B.clientWidth;var A=B.clientHeight;B._originalLeft=E-parseFloat(B.style.left||0);B._originalTop=F-parseFloat(B.style.top||0);B._originalWidth=B.style.width;B._originalHeight=B.style.height;B.style.position="absolute";B.style.top=F+"px";B.style.left=E+"px";B.style.width=C+"px";B.style.height=A+"px";return B},relativize:function(A){A=$(A);if(A.getStyle("position")=="relative"){return A}A.style.position="relative";var C=parseFloat(A.style.top||0)-(A._originalTop||0);var B=parseFloat(A.style.left||0)-(A._originalLeft||0);A.style.top=C+"px";A.style.left=B+"px";A.style.height=A._originalHeight;A.style.width=A._originalWidth;return A},cumulativeScrollOffset:function(B){var A=0,C=0;do{A+=B.scrollTop||0;C+=B.scrollLeft||0;B=B.parentNode}while(B);return Element._returnOffset(C,A)},getOffsetParent:function(A){if(A.offsetParent){return $(A.offsetParent)}if(A==document.body){return $(A)}while((A=A.parentNode)&&A!=document.body){if(Element.getStyle(A,"position")!="static"){return $(A)}}return $(document.body)},viewportOffset:function(D){var A=0,C=0;var B=D;do{A+=B.offsetTop||0;C+=B.offsetLeft||0;if(B.offsetParent==document.body&&Element.getStyle(B,"position")=="absolute"){break}}while(B=B.offsetParent);B=D;do{if(!Prototype.Browser.Opera||(B.tagName&&(B.tagName.toUpperCase()=="BODY"))){A-=B.scrollTop||0;C-=B.scrollLeft||0}}while(B=B.parentNode);return Element._returnOffset(C,A)},clonePosition:function(B,D){var A=Object.extend({setLeft:true,setTop:true,setWidth:true,setHeight:true,offsetTop:0,offsetLeft:0},arguments[2]||{});D=$(D);var E=D.viewportOffset();B=$(B);var F=[0,0];var C=null;if(Element.getStyle(B,"position")=="absolute"){C=B.getOffsetParent();F=C.viewportOffset()}if(C==document.body){F[0]-=document.body.offsetLeft;F[1]-=document.body.offsetTop}if(A.setLeft){B.style.left=(E[0]-F[0]+A.offsetLeft)+"px"}if(A.setTop){B.style.top=(E[1]-F[1]+A.offsetTop)+"px"}if(A.setWidth){B.style.width=D.offsetWidth+"px"}if(A.setHeight){B.style.height=D.offsetHeight+"px"}return B}};Element.Methods.identify.counter=1;Object.extend(Element.Methods,{getElementsBySelector:Element.Methods.select,childElements:Element.Methods.immediateDescendants});Element._attributeTranslations={write:{names:{className:"class",htmlFor:"for"},values:{}}};if(Prototype.Browser.Opera){Element.Methods.getStyle=Element.Methods.getStyle.wrap(function(D,B,C){switch(C){case"left":case"top":case"right":case"bottom":if(D(B,"position")==="static"){return null}case"height":case"width":if(!Element.visible(B)){return null}var E=parseInt(D(B,C),10);if(E!==B["offset"+C.capitalize()]){return E+"px"}var A;if(C==="height"){A=["border-top-width","padding-top","padding-bottom","border-bottom-width"]}else{A=["border-left-width","padding-left","padding-right","border-right-width"]}return A.inject(E,function(F,G){var H=D(B,G);return H===null?F:F-parseInt(H,10)})+"px";default:return D(B,C)}});Element.Methods.readAttribute=Element.Methods.readAttribute.wrap(function(C,A,B){if(B==="title"){return A.title}return C(A,B)})}else{if(Prototype.Browser.IE){Element.Methods.getOffsetParent=Element.Methods.getOffsetParent.wrap(function(C,B){B=$(B);try{B.offsetParent}catch(E){return $(document.body)}var A=B.getStyle("position");if(A!=="static"){return C(B)}B.setStyle({position:"relative"});var D=C(B);B.setStyle({position:A});return D});$w("positionedOffset viewportOffset").each(function(A){Element.Methods[A]=Element.Methods[A].wrap(function(E,C){C=$(C);try{C.offsetParent}catch(G){return Element._returnOffset(0,0)}var B=C.getStyle("position");if(B!=="static"){return E(C)}var D=C.getOffsetParent();if(D&&D.getStyle("position")==="fixed"){D.setStyle({zoom:1})}C.setStyle({position:"relative"});var F=E(C);C.setStyle({position:B});return F})});Element.Methods.cumulativeOffset=Element.Methods.cumulativeOffset.wrap(function(B,A){try{A.offsetParent}catch(C){return Element._returnOffset(0,0)}return B(A)});Element.Methods.getStyle=function(A,B){A=$(A);B=(B=="float"||B=="cssFloat")?"styleFloat":B.camelize();var C=A.style[B];if(!C&&A.currentStyle){C=A.currentStyle[B]}if(B=="opacity"){if(C=(A.getStyle("filter")||"").match(/alpha\(opacity=(.*)\)/)){if(C[1]){return parseFloat(C[1])/100}}return 1}if(C=="auto"){if((B=="width"||B=="height")&&(A.getStyle("display")!="none")){return A["offset"+B.capitalize()]+"px"}return null}return C};Element.Methods.setOpacity=function(B,E){function F(G){return G.replace(/alpha\([^\)]*\)/gi,"")}B=$(B);var A=B.currentStyle;if((A&&!A.hasLayout)||(!A&&B.style.zoom=="normal")){B.style.zoom=1}var D=B.getStyle("filter"),C=B.style;if(E==1||E===""){(D=F(D))?C.filter=D:C.removeAttribute("filter");return B}else{if(E<0.00001){E=0}}C.filter=F(D)+"alpha(opacity="+(E*100)+")";return B};Element._attributeTranslations={read:{names:{"class":"className","for":"htmlFor"},values:{_getAttr:function(A,B){return A.getAttribute(B,2)},_getAttrNode:function(A,C){var B=A.getAttributeNode(C);return B?B.value:""},_getEv:function(A,B){B=A.getAttribute(B);return B?B.toString().slice(23,-2):null},_flag:function(A,B){return $(A).hasAttribute(B)?B:null},style:function(A){return A.style.cssText.toLowerCase()},title:function(A){return A.title}}}};Element._attributeTranslations.write={names:Object.extend({cellpadding:"cellPadding",cellspacing:"cellSpacing"},Element._attributeTranslations.read.names),values:{checked:function(A,B){A.checked=!!B},style:function(A,B){A.style.cssText=B?B:""}}};Element._attributeTranslations.has={};$w("colSpan rowSpan vAlign dateTime accessKey tabIndex encType maxLength readOnly longDesc frameBorder").each(function(A){Element._attributeTranslations.write.names[A.toLowerCase()]=A;Element._attributeTranslations.has[A.toLowerCase()]=A});(function(A){Object.extend(A,{href:A._getAttr,src:A._getAttr,type:A._getAttr,action:A._getAttrNode,disabled:A._flag,checked:A._flag,readonly:A._flag,multiple:A._flag,onload:A._getEv,onunload:A._getEv,onclick:A._getEv,ondblclick:A._getEv,onmousedown:A._getEv,onmouseup:A._getEv,onmouseover:A._getEv,onmousemove:A._getEv,onmouseout:A._getEv,onfocus:A._getEv,onblur:A._getEv,onkeypress:A._getEv,onkeydown:A._getEv,onkeyup:A._getEv,onsubmit:A._getEv,onreset:A._getEv,onselect:A._getEv,onchange:A._getEv})})(Element._attributeTranslations.read.values)}else{if(Prototype.Browser.Gecko&&/rv:1\.8\.0/.test(navigator.userAgent)){Element.Methods.setOpacity=function(A,B){A=$(A);A.style.opacity=(B==1)?0.999999:(B==="")?"":(B<0.00001)?0:B;return A}}else{if(Prototype.Browser.WebKit){Element.Methods.setOpacity=function(A,B){A=$(A);A.style.opacity=(B==1||B==="")?"":(B<0.00001)?0:B;if(B==1){if(A.tagName.toUpperCase()=="IMG"&&A.width){A.width++;A.width--}else{try{var D=document.createTextNode(" ");A.appendChild(D);A.removeChild(D)}catch(C){}}}return A};Element.Methods.cumulativeOffset=function(B){var A=0,C=0;do{A+=B.offsetTop||0;C+=B.offsetLeft||0;if(B.offsetParent==document.body){if(Element.getStyle(B,"position")=="absolute"){break}}B=B.offsetParent}while(B);return Element._returnOffset(C,A)}}}}}if(Prototype.Browser.IE||Prototype.Browser.Opera){Element.Methods.update=function(B,C){B=$(B);if(C&&C.toElement){C=C.toElement()}if(Object.isElement(C)){return B.update().insert(C)}C=Object.toHTML(C);var A=B.tagName.toUpperCase();if(A in Element._insertionTranslations.tags){$A(B.childNodes).each(function(D){B.removeChild(D)});Element._getContentFromAnonymousElement(A,C.stripScripts()).each(function(D){B.appendChild(D)})}else{B.innerHTML=C.stripScripts()}C.evalScripts.bind(C).defer();return B}}if("outerHTML" in document.createElement("div")){Element.Methods.replace=function(C,E){C=$(C);if(E&&E.toElement){E=E.toElement()}if(Object.isElement(E)){C.parentNode.replaceChild(E,C);return C}E=Object.toHTML(E);var D=C.parentNode,B=D.tagName.toUpperCase();if(Element._insertionTranslations.tags[B]){var F=C.next();var A=Element._getContentFromAnonymousElement(B,E.stripScripts());D.removeChild(C);if(F){A.each(function(G){D.insertBefore(G,F)})}else{A.each(function(G){D.appendChild(G)})}}else{C.outerHTML=E.stripScripts()}E.evalScripts.bind(E).defer();return C}}Element._returnOffset=function(B,C){var A=[B,C];A.left=B;A.top=C;return A};Element._getContentFromAnonymousElement=function(C,B){var D=new Element("div"),A=Element._insertionTranslations.tags[C];if(A){D.innerHTML=A[0]+B+A[1];A[2].times(function(){D=D.firstChild})}else{D.innerHTML=B}return $A(D.childNodes)};Element._insertionTranslations={before:function(A,B){A.parentNode.insertBefore(B,A)},top:function(A,B){A.insertBefore(B,A.firstChild)},bottom:function(A,B){A.appendChild(B)},after:function(A,B){A.parentNode.insertBefore(B,A.nextSibling)},tags:{TABLE:["<table>","</table>",1],TBODY:["<table><tbody>","</tbody></table>",2],TR:["<table><tbody><tr>","</tr></tbody></table>",3],TD:["<table><tbody><tr><td>","</td></tr></tbody></table>",4],SELECT:["<select>","</select>",1]}};(function(){Object.extend(this.tags,{THEAD:this.tags.TBODY,TFOOT:this.tags.TBODY,TH:this.tags.TD})}).call(Element._insertionTranslations);Element.Methods.Simulated={hasAttribute:function(A,C){C=Element._attributeTranslations.has[C]||C;var B=$(A).getAttributeNode(C);return !!(B&&B.specified)}};Element.Methods.ByTag={};Object.extend(Element,Element.Methods);if(!Prototype.BrowserFeatures.ElementExtensions&&document.createElement("div")["__proto__"]){window.HTMLElement={};window.HTMLElement.prototype=document.createElement("div")["__proto__"];Prototype.BrowserFeatures.ElementExtensions=true}Element.extend=(function(){if(Prototype.BrowserFeatures.SpecificElementExtensions){return Prototype.K}var A={},B=Element.Methods.ByTag;var C=Object.extend(function(F){if(!F||F._extendedByPrototype||F.nodeType!=1||F==window){return F}var D=Object.clone(A),E=F.tagName.toUpperCase(),H,G;if(B[E]){Object.extend(D,B[E])}for(H in D){G=D[H];if(Object.isFunction(G)&&!(H in F)){F[H]=G.methodize()}}F._extendedByPrototype=Prototype.emptyFunction;return F},{refresh:function(){if(!Prototype.BrowserFeatures.ElementExtensions){Object.extend(A,Element.Methods);Object.extend(A,Element.Methods.Simulated)}}});C.refresh();return C})();Element.hasAttribute=function(A,B){if(A.hasAttribute){return A.hasAttribute(B)}return Element.Methods.Simulated.hasAttribute(A,B)};Element.addMethods=function(C){var I=Prototype.BrowserFeatures,D=Element.Methods.ByTag;if(!C){Object.extend(Form,Form.Methods);Object.extend(Form.Element,Form.Element.Methods);Object.extend(Element.Methods.ByTag,{FORM:Object.clone(Form.Methods),INPUT:Object.clone(Form.Element.Methods),SELECT:Object.clone(Form.Element.Methods),TEXTAREA:Object.clone(Form.Element.Methods)})}if(arguments.length==2){var B=C;C=arguments[1]}if(!B){Object.extend(Element.Methods,C||{})}else{if(Object.isArray(B)){B.each(H)}else{H(B)}}function H(F){F=F.toUpperCase();if(!Element.Methods.ByTag[F]){Element.Methods.ByTag[F]={}}Object.extend(Element.Methods.ByTag[F],C)}function A(L,K,F){F=F||false;for(var N in L){var M=L[N];if(!Object.isFunction(M)){continue}if(!F||!(N in K)){K[N]=M.methodize()}}}function E(L){var F;var K={OPTGROUP:"OptGroup",TEXTAREA:"TextArea",P:"Paragraph",FIELDSET:"FieldSet",UL:"UList",OL:"OList",DL:"DList",DIR:"Directory",H1:"Heading",H2:"Heading",H3:"Heading",H4:"Heading",H5:"Heading",H6:"Heading",Q:"Quote",INS:"Mod",DEL:"Mod",A:"Anchor",IMG:"Image",CAPTION:"TableCaption",COL:"TableCol",COLGROUP:"TableCol",THEAD:"TableSection",TFOOT:"TableSection",TBODY:"TableSection",TR:"TableRow",TH:"TableCell",TD:"TableCell",FRAMESET:"FrameSet",IFRAME:"IFrame"};if(K[L]){F="HTML"+K[L]+"Element"}if(window[F]){return window[F]}F="HTML"+L+"Element";if(window[F]){return window[F]}F="HTML"+L.capitalize()+"Element";if(window[F]){return window[F]}window[F]={};window[F].prototype=document.createElement(L)["__proto__"];return window[F]}if(I.ElementExtensions){A(Element.Methods,HTMLElement.prototype);A(Element.Methods.Simulated,HTMLElement.prototype,true)}if(I.SpecificElementExtensions){for(var J in Element.Methods.ByTag){var G=E(J);if(Object.isUndefined(G)){continue}A(D[J],G.prototype)}}Object.extend(Element,Element.Methods);delete Element.ByTag;if(Element.extend.refresh){Element.extend.refresh()}Element.cache={}};document.viewport={getDimensions:function(){var A={},C=Prototype.Browser;$w("width height").each(function(E){var B=E.capitalize();if(C.WebKit&&!document.evaluate){A[E]=self["inner"+B]}else{if(C.Opera&&parseFloat(window.opera.version())<9.5){A[E]=document.body["client"+B]}else{A[E]=document.documentElement["client"+B]}}});return A},getWidth:function(){return this.getDimensions().width},getHeight:function(){return this.getDimensions().height},getScrollOffsets:function(){return Element._returnOffset(window.pageXOffset||document.documentElement.scrollLeft||document.body.scrollLeft,window.pageYOffset||document.documentElement.scrollTop||document.body.scrollTop)}};var Selector=Class.create({initialize:function(A){this.expression=A.strip();if(this.shouldUseSelectorsAPI()){this.mode="selectorsAPI"}else{if(this.shouldUseXPath()){this.mode="xpath";this.compileXPathMatcher()}else{this.mode="normal";this.compileMatcher()}}},shouldUseXPath:function(){if(!Prototype.BrowserFeatures.XPath){return false}var A=this.expression;if(Prototype.Browser.WebKit&&(A.include("-of-type")||A.include(":empty"))){return false}if((/(\[[\w-]*?:|:checked)/).test(A)){return false}return true},shouldUseSelectorsAPI:function(){if(!Prototype.BrowserFeatures.SelectorsAPI){return false}if(!Selector._div){Selector._div=new Element("div")}try{Selector._div.querySelector(this.expression)}catch(A){return false}return true},compileMatcher:function(){var e=this.expression,ps=Selector.patterns,h=Selector.handlers,c=Selector.criteria,le,p,m;if(Selector._cache[e]){this.matcher=Selector._cache[e];return }this.matcher=["this.matcher = function(root) {","var r = root, h = Selector.handlers, c = false, n;"];while(e&&le!=e&&(/\S/).test(e)){le=e;for(var i in ps){p=ps[i];if(m=e.match(p)){this.matcher.push(Object.isFunction(c[i])?c[i](m):new Template(c[i]).evaluate(m));e=e.replace(m[0],"");break}}}this.matcher.push("return h.unique(n);\n}");eval(this.matcher.join("\n"));Selector._cache[this.expression]=this.matcher},compileXPathMatcher:function(){var E=this.expression,F=Selector.patterns,B=Selector.xpath,D,A;if(Selector._cache[E]){this.xpath=Selector._cache[E];return }this.matcher=[".//*"];while(E&&D!=E&&(/\S/).test(E)){D=E;for(var C in F){if(A=E.match(F[C])){this.matcher.push(Object.isFunction(B[C])?B[C](A):new Template(B[C]).evaluate(A));E=E.replace(A[0],"");break}}}this.xpath=this.matcher.join("");Selector._cache[this.expression]=this.xpath},findElements:function(A){A=A||document;var C=this.expression,B;switch(this.mode){case"selectorsAPI":if(A!==document){var D=A.id,E=$(A).identify();C="#"+E+" "+C}B=$A(A.querySelectorAll(C)).map(Element.extend);A.id=D;return B;case"xpath":return document._getElementsByXPath(this.xpath,A);default:return this.matcher(A)}},match:function(H){this.tokens=[];var L=this.expression,A=Selector.patterns,E=Selector.assertions;var B,D,F;while(L&&B!==L&&(/\S/).test(L)){B=L;for(var I in A){D=A[I];if(F=L.match(D)){if(E[I]){this.tokens.push([I,Object.clone(F)]);L=L.replace(F[0],"")}else{return this.findElements(document).include(H)}}}}var K=true,C,J;for(var I=0,G;G=this.tokens[I];I++){C=G[0],J=G[1];if(!Selector.assertions[C](H,J)){K=false;break}}return K},toString:function(){return this.expression},inspect:function(){return"#<Selector:"+this.expression.inspect()+">"}});Object.extend(Selector,{_cache:{},xpath:{descendant:"//*",child:"/*",adjacent:"/following-sibling::*[1]",laterSibling:"/following-sibling::*",tagName:function(A){if(A[1]=="*"){return""}return"[local-name()='"+A[1].toLowerCase()+"' or local-name()='"+A[1].toUpperCase()+"']"},className:"[contains(concat(' ', @class, ' '), ' #{1} ')]",id:"[@id='#{1}']",attrPresence:function(A){A[1]=A[1].toLowerCase();return new Template("[@#{1}]").evaluate(A)},attr:function(A){A[1]=A[1].toLowerCase();A[3]=A[5]||A[6];return new Template(Selector.xpath.operators[A[2]]).evaluate(A)},pseudo:function(A){var B=Selector.xpath.pseudos[A[1]];if(!B){return""}if(Object.isFunction(B)){return B(A)}return new Template(Selector.xpath.pseudos[A[1]]).evaluate(A)},operators:{"=":"[@#{1}='#{3}']","!=":"[@#{1}!='#{3}']","^=":"[starts-with(@#{1}, '#{3}')]","$=":"[substring(@#{1}, (string-length(@#{1}) - string-length('#{3}') + 1))='#{3}']","*=":"[contains(@#{1}, '#{3}')]","~=":"[contains(concat(' ', @#{1}, ' '), ' #{3} ')]","|=":"[contains(concat('-', @#{1}, '-'), '-#{3}-')]"},pseudos:{"first-child":"[not(preceding-sibling::*)]","last-child":"[not(following-sibling::*)]","only-child":"[not(preceding-sibling::* or following-sibling::*)]",empty:"[count(*) = 0 and (count(text()) = 0)]",checked:"[@checked]",disabled:"[(@disabled) and (@type!='hidden')]",enabled:"[not(@disabled) and (@type!='hidden')]",not:function(B){var H=B[6],G=Selector.patterns,A=Selector.xpath,E,C;var F=[];while(H&&E!=H&&(/\S/).test(H)){E=H;for(var D in G){if(B=H.match(G[D])){C=Object.isFunction(A[D])?A[D](B):new Template(A[D]).evaluate(B);F.push("("+C.substring(1,C.length-1)+")");H=H.replace(B[0],"");break}}}return"[not("+F.join(" and ")+")]"},"nth-child":function(A){return Selector.xpath.pseudos.nth("(count(./preceding-sibling::*) + 1) ",A)},"nth-last-child":function(A){return Selector.xpath.pseudos.nth("(count(./following-sibling::*) + 1) ",A)},"nth-of-type":function(A){return Selector.xpath.pseudos.nth("position() ",A)},"nth-last-of-type":function(A){return Selector.xpath.pseudos.nth("(last() + 1 - position()) ",A)},"first-of-type":function(A){A[6]="1";return Selector.xpath.pseudos["nth-of-type"](A)},"last-of-type":function(A){A[6]="1";return Selector.xpath.pseudos["nth-last-of-type"](A)},"only-of-type":function(A){var B=Selector.xpath.pseudos;return B["first-of-type"](A)+B["last-of-type"](A)},nth:function(E,C){var F,G=C[6],B;if(G=="even"){G="2n+0"}if(G=="odd"){G="2n+1"}if(F=G.match(/^(\d+)$/)){return"["+E+"= "+F[1]+"]"}if(F=G.match(/^(-?\d*)?n(([+-])(\d+))?/)){if(F[1]=="-"){F[1]=-1}var D=F[1]?Number(F[1]):1;var A=F[2]?Number(F[2]):0;B="[((#{fragment} - #{b}) mod #{a} = 0) and ((#{fragment} - #{b}) div #{a} >= 0)]";return new Template(B).evaluate({fragment:E,a:D,b:A})}}}},criteria:{tagName:'n = h.tagName(n, r, "#{1}", c);      c = false;',className:'n = h.className(n, r, "#{1}", c);    c = false;',id:'n = h.id(n, r, "#{1}", c);           c = false;',attrPresence:'n = h.attrPresence(n, r, "#{1}", c); c = false;',attr:function(A){A[3]=(A[5]||A[6]);return new Template('n = h.attr(n, r, "#{1}", "#{3}", "#{2}", c); c = false;').evaluate(A)},pseudo:function(A){if(A[6]){A[6]=A[6].replace(/"/g,'\\"')}return new Template('n = h.pseudo(n, "#{1}", "#{6}", r, c); c = false;').evaluate(A)},descendant:'c = "descendant";',child:'c = "child";',adjacent:'c = "adjacent";',laterSibling:'c = "laterSibling";'},patterns:{laterSibling:/^\s*~\s*/,child:/^\s*>\s*/,adjacent:/^\s*\+\s*/,descendant:/^\s/,tagName:/^\s*(\*|[\w\-]+)(\b|$)?/,id:/^#([\w\-\*]+)(\b|$)/,className:/^\.([\w\-\*]+)(\b|$)/,pseudo:/^:((first|last|nth|nth-last|only)(-child|-of-type)|empty|checked|(en|dis)abled|not)(\((.*?)\))?(\b|$|(?=\s|[:+~>]))/,attrPresence:/^\[((?:[\w]+:)?[\w]+)\]/,attr:/\[((?:[\w-]*:)?[\w-]+)\s*(?:([!^$*~|]?=)\s*((['"])([^\4]*?)\4|([^'"][^\]]*?)))?\]/},assertions:{tagName:function(A,B){return B[1].toUpperCase()==A.tagName.toUpperCase()},className:function(A,B){return Element.hasClassName(A,B[1])},id:function(A,B){return A.id===B[1]},attrPresence:function(A,B){return Element.hasAttribute(A,B[1])},attr:function(B,C){var A=Element.readAttribute(B,C[1]);return A&&Selector.operators[C[2]](A,C[5]||C[6])}},handlers:{concat:function(B,A){for(var C=0,D;D=A[C];C++){B.push(D)}return B},mark:function(A){var D=Prototype.emptyFunction;for(var B=0,C;C=A[B];B++){C._countedByPrototype=D}return A},unmark:function(A){for(var B=0,C;C=A[B];B++){C._countedByPrototype=undefined}return A},index:function(A,D,G){A._countedByPrototype=Prototype.emptyFunction;if(D){for(var B=A.childNodes,E=B.length-1,C=1;E>=0;E--){var F=B[E];if(F.nodeType==1&&(!G||F._countedByPrototype)){F.nodeIndex=C++}}}else{for(var E=0,C=1,B=A.childNodes;F=B[E];E++){if(F.nodeType==1&&(!G||F._countedByPrototype)){F.nodeIndex=C++}}}},unique:function(B){if(B.length==0){return B}var D=[],E;for(var C=0,A=B.length;C<A;C++){if(!(E=B[C])._countedByPrototype){E._countedByPrototype=Prototype.emptyFunction;D.push(Element.extend(E))}}return Selector.handlers.unmark(D)},descendant:function(A){var D=Selector.handlers;for(var C=0,B=[],E;E=A[C];C++){D.concat(B,E.getElementsByTagName("*"))}return B},child:function(A){var E=Selector.handlers;for(var D=0,C=[],F;F=A[D];D++){for(var B=0,G;G=F.childNodes[B];B++){if(G.nodeType==1&&G.tagName!="!"){C.push(G)}}}return C},adjacent:function(A){for(var C=0,B=[],E;E=A[C];C++){var D=this.nextElementSibling(E);if(D){B.push(D)}}return B},laterSibling:function(A){var D=Selector.handlers;for(var C=0,B=[],E;E=A[C];C++){D.concat(B,Element.nextSiblings(E))}return B},nextElementSibling:function(A){while(A=A.nextSibling){if(A.nodeType==1){return A}}return null},previousElementSibling:function(A){while(A=A.previousSibling){if(A.nodeType==1){return A}}return null},tagName:function(A,H,C,B){var I=C.toUpperCase();var E=[],G=Selector.handlers;if(A){if(B){if(B=="descendant"){for(var F=0,D;D=A[F];F++){G.concat(E,D.getElementsByTagName(C))}return E}else{A=this[B](A)}if(C=="*"){return A}}for(var F=0,D;D=A[F];F++){if(D.tagName.toUpperCase()===I){E.push(D)}}return E}else{return H.getElementsByTagName(C)}},id:function(B,A,H,F){var G=$(H),D=Selector.handlers;if(!G){return[]}if(!B&&A==document){return[G]}if(B){if(F){if(F=="child"){for(var C=0,E;E=B[C];C++){if(G.parentNode==E){return[G]}}}else{if(F=="descendant"){for(var C=0,E;E=B[C];C++){if(Element.descendantOf(G,E)){return[G]}}}else{if(F=="adjacent"){for(var C=0,E;E=B[C];C++){if(Selector.handlers.previousElementSibling(G)==E){return[G]}}}else{B=D[F](B)}}}}for(var C=0,E;E=B[C];C++){if(E==G){return[G]}}return[]}return(G&&Element.descendantOf(G,A))?[G]:[]},className:function(B,A,C,D){if(B&&D){B=this[D](B)}return Selector.handlers.byClassName(B,A,C)},byClassName:function(C,B,F){if(!C){C=Selector.handlers.descendant([B])}var H=" "+F+" ";for(var E=0,D=[],G,A;G=C[E];E++){A=G.className;if(A.length==0){continue}if(A==F||(" "+A+" ").include(H)){D.push(G)}}return D},attrPresence:function(C,B,A,G){if(!C){C=B.getElementsByTagName("*")}if(C&&G){C=this[G](C)}var E=[];for(var D=0,F;F=C[D];D++){if(Element.hasAttribute(F,A)){E.push(F)}}return E},attr:function(A,I,H,J,C,B){if(!A){A=I.getElementsByTagName("*")}if(A&&B){A=this[B](A)}var K=Selector.operators[C],F=[];for(var E=0,D;D=A[E];E++){var G=Element.readAttribute(D,H);if(G===null){continue}if(K(G,J)){F.push(D)}}return F},pseudo:function(B,C,E,A,D){if(B&&D){B=this[D](B)}if(!B){B=A.getElementsByTagName("*")}return Selector.pseudos[C](B,E,A)}},pseudos:{"first-child":function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(Selector.handlers.previousElementSibling(E)){continue}C.push(E)}return C},"last-child":function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(Selector.handlers.nextElementSibling(E)){continue}C.push(E)}return C},"only-child":function(B,G,A){var E=Selector.handlers;for(var D=0,C=[],F;F=B[D];D++){if(!E.previousElementSibling(F)&&!E.nextElementSibling(F)){C.push(F)}}return C},"nth-child":function(B,C,A){return Selector.pseudos.nth(B,C,A)},"nth-last-child":function(B,C,A){return Selector.pseudos.nth(B,C,A,true)},"nth-of-type":function(B,C,A){return Selector.pseudos.nth(B,C,A,false,true)},"nth-last-of-type":function(B,C,A){return Selector.pseudos.nth(B,C,A,true,true)},"first-of-type":function(B,C,A){return Selector.pseudos.nth(B,"1",A,false,true)},"last-of-type":function(B,C,A){return Selector.pseudos.nth(B,"1",A,true,true)},"only-of-type":function(B,D,A){var C=Selector.pseudos;return C["last-of-type"](C["first-of-type"](B,D,A),D,A)},getIndices:function(B,A,C){if(B==0){return A>0?[A]:[]}return $R(1,C).inject([],function(D,E){if(0==(E-A)%B&&(E-A)/B>=0){D.push(E)}return D})},nth:function(A,L,N,K,C){if(A.length==0){return[]}if(L=="even"){L="2n+0"}if(L=="odd"){L="2n+1"}var J=Selector.handlers,I=[],B=[],E;J.mark(A);for(var H=0,D;D=A[H];H++){if(!D.parentNode._countedByPrototype){J.index(D.parentNode,K,C);B.push(D.parentNode)}}if(L.match(/^\d+$/)){L=Number(L);for(var H=0,D;D=A[H];H++){if(D.nodeIndex==L){I.push(D)}}}else{if(E=L.match(/^(-?\d*)?n(([+-])(\d+))?/)){if(E[1]=="-"){E[1]=-1}var O=E[1]?Number(E[1]):1;var M=E[2]?Number(E[2]):0;var P=Selector.pseudos.getIndices(O,M,A.length);for(var H=0,D,F=P.length;D=A[H];H++){for(var G=0;G<F;G++){if(D.nodeIndex==P[G]){I.push(D)}}}}}J.unmark(A);J.unmark(B);return I},empty:function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(E.tagName=="!"||E.firstChild){continue}C.push(E)}return C},not:function(A,D,I){var G=Selector.handlers,J,C;var H=new Selector(D).findElements(I);G.mark(H);for(var F=0,E=[],B;B=A[F];F++){if(!B._countedByPrototype){E.push(B)}}G.unmark(H);return E},enabled:function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(!E.disabled&&(!E.type||E.type!=="hidden")){C.push(E)}}return C},disabled:function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(E.disabled){C.push(E)}}return C},checked:function(B,F,A){for(var D=0,C=[],E;E=B[D];D++){if(E.checked){C.push(E)}}return C}},operators:{"=":function(B,A){return B==A},"!=":function(B,A){return B!=A},"^=":function(B,A){return B==A||B&&B.startsWith(A)},"$=":function(B,A){return B==A||B&&B.endsWith(A)},"*=":function(B,A){return B==A||B&&B.include(A)},"$=":function(B,A){return B.endsWith(A)},"*=":function(B,A){return B.include(A)},"~=":function(B,A){return(" "+B+" ").include(" "+A+" ")},"|=":function(B,A){return("-"+(B||"").toUpperCase()+"-").include("-"+(A||"").toUpperCase()+"-")}},split:function(B){var A=[];B.scan(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/,function(C){A.push(C[1].strip())});return A},matchElements:function(F,G){var E=$$(G),D=Selector.handlers;D.mark(E);for(var C=0,B=[],A;A=F[C];C++){if(A._countedByPrototype){B.push(A)}}D.unmark(E);return B},findElement:function(B,C,A){if(Object.isNumber(C)){A=C;C=false}return Selector.matchElements(B,C||"*")[A||0]},findChildElements:function(E,G){G=Selector.split(G.join(","));var D=[],F=Selector.handlers;for(var C=0,B=G.length,A;C<B;C++){A=new Selector(G[C].strip());F.concat(D,A.findElements(E))}return(B>1)?F.unique(D):D}});if(Prototype.Browser.IE){Object.extend(Selector.handlers,{concat:function(B,A){for(var C=0,D;D=A[C];C++){if(D.tagName!=="!"){B.push(D)}}return B},unmark:function(A){for(var B=0,C;C=A[B];B++){C.removeAttribute("_countedByPrototype")}return A}})}function $$(){return Selector.findChildElements(document,$A(arguments))}var Form={reset:function(A){$(A).reset();return A},serializeElements:function(G,B){if(typeof B!="object"){B={hash:!!B}}else{if(Object.isUndefined(B.hash)){B.hash=true}}var C,F,A=false,E=B.submit;var D=G.inject({},function(H,I){if(!I.disabled&&I.name){C=I.name;F=$(I).getValue();if(F!=null&&I.type!="file"&&(I.type!="submit"||(!A&&E!==false&&(!E||C==E)&&(A=true)))){if(C in H){if(!Object.isArray(H[C])){H[C]=[H[C]]}H[C].push(F)}else{H[C]=F}}}return H});return B.hash?D:Object.toQueryString(D)}};Form.Methods={serialize:function(B,A){return Form.serializeElements(Form.getElements(B),A)},getElements:function(A){return $A($(A).getElementsByTagName("*")).inject([],function(B,C){if(Form.Element.Serializers[C.tagName.toLowerCase()]){B.push(Element.extend(C))}return B})},getInputs:function(G,C,D){G=$(G);var A=G.getElementsByTagName("input");if(!C&&!D){return $A(A).map(Element.extend)}for(var E=0,H=[],F=A.length;E<F;E++){var B=A[E];if((C&&B.type!=C)||(D&&B.name!=D)){continue}H.push(Element.extend(B))}return H},disable:function(A){A=$(A);Form.getElements(A).invoke("disable");return A},enable:function(A){A=$(A);Form.getElements(A).invoke("enable");return A},findFirstElement:function(B){var C=$(B).getElements().findAll(function(D){return"hidden"!=D.type&&!D.disabled});var A=C.findAll(function(D){return D.hasAttribute("tabIndex")&&D.tabIndex>=0}).sortBy(function(D){return D.tabIndex}).first();return A?A:C.find(function(D){return["input","select","textarea"].include(D.tagName.toLowerCase())})},focusFirstElement:function(A){A=$(A);A.findFirstElement().activate();return A},request:function(B,A){B=$(B),A=Object.clone(A||{});var D=A.parameters,C=B.readAttribute("action")||"";if(C.blank()){C=window.location.href}A.parameters=B.serialize(true);if(D){if(Object.isString(D)){D=D.toQueryParams()}Object.extend(A.parameters,D)}if(B.hasAttribute("method")&&!A.method){A.method=B.method}return new Ajax.Request(C,A)}};Form.Element={focus:function(A){$(A).focus();return A},select:function(A){$(A).select();return A}};Form.Element.Methods={serialize:function(A){A=$(A);if(!A.disabled&&A.name){var B=A.getValue();if(B!=undefined){var C={};C[A.name]=B;return Object.toQueryString(C)}}return""},getValue:function(A){A=$(A);var B=A.tagName.toLowerCase();return Form.Element.Serializers[B](A)},setValue:function(A,B){A=$(A);var C=A.tagName.toLowerCase();Form.Element.Serializers[C](A,B);return A},clear:function(A){$(A).value="";return A},present:function(A){return $(A).value!=""},activate:function(A){A=$(A);try{A.focus();if(A.select&&(A.tagName.toLowerCase()!="input"||!["button","reset","submit"].include(A.type))){A.select()}}catch(B){}return A},disable:function(A){A=$(A);A.disabled=true;return A},enable:function(A){A=$(A);A.disabled=false;return A}};var Field=Form.Element;var $F=Form.Element.Methods.getValue;Form.Element.Serializers={input:function(A,B){switch(A.type.toLowerCase()){case"checkbox":case"radio":return Form.Element.Serializers.inputSelector(A,B);default:return Form.Element.Serializers.textarea(A,B)}},inputSelector:function(A,B){if(Object.isUndefined(B)){return A.checked?A.value:null}else{A.checked=!!B}},textarea:function(A,B){if(Object.isUndefined(B)){return A.value}else{A.value=B}},select:function(C,F){if(Object.isUndefined(F)){return this[C.type=="select-one"?"selectOne":"selectMany"](C)}else{var B,D,G=!Object.isArray(F);for(var A=0,E=C.length;A<E;A++){B=C.options[A];D=this.optionValue(B);if(G){if(D==F){B.selected=true;return }}else{B.selected=F.include(D)}}}},selectOne:function(B){var A=B.selectedIndex;return A>=0?this.optionValue(B.options[A]):null},selectMany:function(D){var A,E=D.length;if(!E){return null}for(var C=0,A=[];C<E;C++){var B=D.options[C];if(B.selected){A.push(this.optionValue(B))}}return A},optionValue:function(A){return Element.extend(A).hasAttribute("value")?A.value:A.text}};Abstract.TimedObserver=Class.create(PeriodicalExecuter,{initialize:function($super,A,B,C){$super(C,B);this.element=$(A);this.lastValue=this.getValue()},execute:function(){var A=this.getValue();if(Object.isString(this.lastValue)&&Object.isString(A)?this.lastValue!=A:String(this.lastValue)!=String(A)){this.callback(this.element,A);this.lastValue=A}}});Form.Element.Observer=Class.create(Abstract.TimedObserver,{getValue:function(){return Form.Element.getValue(this.element)}});Form.Observer=Class.create(Abstract.TimedObserver,{getValue:function(){return Form.serialize(this.element)}});Abstract.EventObserver=Class.create({initialize:function(A,B){this.element=$(A);this.callback=B;this.lastValue=this.getValue();if(this.element.tagName.toLowerCase()=="form"){this.registerFormCallbacks()}else{this.registerCallback(this.element)}},onElementEvent:function(){var A=this.getValue();if(this.lastValue!=A){this.callback(this.element,A);this.lastValue=A}},registerFormCallbacks:function(){Form.getElements(this.element).each(this.registerCallback,this)},registerCallback:function(A){if(A.type){switch(A.type.toLowerCase()){case"checkbox":case"radio":Event.observe(A,"click",this.onElementEvent.bind(this));break;default:Event.observe(A,"change",this.onElementEvent.bind(this));break}}}});Form.Element.EventObserver=Class.create(Abstract.EventObserver,{getValue:function(){return Form.Element.getValue(this.element)}});Form.EventObserver=Class.create(Abstract.EventObserver,{getValue:function(){return Form.serialize(this.element)}});if(!window.Event){var Event={}}Object.extend(Event,{KEY_BACKSPACE:8,KEY_TAB:9,KEY_RETURN:13,KEY_ESC:27,KEY_LEFT:37,KEY_UP:38,KEY_RIGHT:39,KEY_DOWN:40,KEY_DELETE:46,KEY_HOME:36,KEY_END:35,KEY_PAGEUP:33,KEY_PAGEDOWN:34,KEY_INSERT:45,cache:{},relatedTarget:function(B){var A;switch(B.type){case"mouseover":A=B.fromElement;break;case"mouseout":A=B.toElement;break;default:return null}return Element.extend(A)}});Event.Methods=(function(){var A;if(Prototype.Browser.IE){var B={0:1,1:4,2:2};A=function(D,C){return D.button==B[C]}}else{if(Prototype.Browser.WebKit){A=function(D,C){switch(C){case 0:return D.which==1&&!D.metaKey;case 1:return D.which==1&&D.metaKey;default:return false}}}else{A=function(D,C){return D.which?(D.which===C+1):(D.button===C)}}}return{isLeftClick:function(C){return A(C,0)},isMiddleClick:function(C){return A(C,1)},isRightClick:function(C){return A(C,2)},element:function(E){E=Event.extend(E);var D=E.target,C=E.type,F=E.currentTarget;if(F&&F.tagName){if(C==="load"||C==="error"||(C==="click"&&F.tagName.toLowerCase()==="input"&&F.type==="radio")){D=F}}if(D.nodeType==Node.TEXT_NODE){D=D.parentNode}return Element.extend(D)},findElement:function(D,F){var C=Event.element(D);if(!F){return C}var E=[C].concat(C.ancestors());return Selector.findElement(E,F,0)},pointer:function(E){var D=document.documentElement,C=document.body||{scrollLeft:0,scrollTop:0};return{x:E.pageX||(E.clientX+(D.scrollLeft||C.scrollLeft)-(D.clientLeft||0)),y:E.pageY||(E.clientY+(D.scrollTop||C.scrollTop)-(D.clientTop||0))}},pointerX:function(C){return Event.pointer(C).x},pointerY:function(C){return Event.pointer(C).y},stop:function(C){Event.extend(C);C.preventDefault();C.stopPropagation();C.stopped=true}}})();Event.extend=(function(){var A=Object.keys(Event.Methods).inject({},function(B,C){B[C]=Event.Methods[C].methodize();return B});if(Prototype.Browser.IE){Object.extend(A,{stopPropagation:function(){this.cancelBubble=true},preventDefault:function(){this.returnValue=false},inspect:function(){return"[object Event]"}});return function(B){if(!B){return false}if(B._extendedByPrototype){return B}B._extendedByPrototype=Prototype.emptyFunction;var C=Event.pointer(B);Object.extend(B,{target:B.srcElement,relatedTarget:Event.relatedTarget(B),pageX:C.x,pageY:C.y});return Object.extend(B,A)}}else{Event.prototype=Event.prototype||document.createEvent("HTMLEvents")["__proto__"];Object.extend(Event.prototype,A);return Prototype.K}})();Object.extend(Event,(function(){var B=Event.cache;function C(J){if(J._prototypeEventID){return J._prototypeEventID[0]}arguments.callee.id=arguments.callee.id||1;return J._prototypeEventID=[++arguments.callee.id]}function G(J){if(J&&J.include(":")){return"dataavailable"}return J}function A(J){return B[J]=B[J]||{}}function F(L,J){var K=A(L);return K[J]=K[J]||[]}function H(K,J,L){var O=C(K);var N=F(O,J);if(N.pluck("handler").include(L)){return false}var M=function(P){if(!Event||!Event.extend||(P.eventName&&P.eventName!=J)){return false}Event.extend(P);L.call(K,P)};M.handler=L;N.push(M);return M}function I(M,J,K){var L=F(M,J);return L.find(function(N){return N.handler==K})}function D(M,J,K){var L=A(M);if(!L[J]){return false}L[J]=L[J].without(I(M,J,K))}function E(){for(var K in B){for(var J in B[K]){B[K][J]=null}}}if(window.attachEvent){window.attachEvent("onunload",E)}if(Prototype.Browser.WebKit){window.addEventListener("unload",Prototype.emptyFunction,false)}return{observe:function(L,J,M){L=$(L);var K=G(J);var N=H(L,J,M);if(!N){return L}if(L.addEventListener){L.addEventListener(K,N,false)}else{L.attachEvent("on"+K,N)}return L},stopObserving:function(L,J,M){L=$(L);var O=C(L),K=G(J);if(!M&&J){F(O,J).each(function(P){L.stopObserving(J,P.handler)});return L}else{if(!J){Object.keys(A(O)).each(function(P){L.stopObserving(P)});return L}}var N=I(O,J,M);if(!N){return L}if(L.removeEventListener){L.removeEventListener(K,N,false)}else{L.detachEvent("on"+K,N)}D(O,J,M);return L},fire:function(L,K,J){L=$(L);if(L==document&&document.createEvent&&!L.dispatchEvent){L=document.documentElement}var M;if(document.createEvent){M=document.createEvent("HTMLEvents");M.initEvent("dataavailable",true,true)}else{M=document.createEventObject();M.eventType="ondataavailable"}M.eventName=K;M.memo=J||{};if(document.createEvent){L.dispatchEvent(M)}else{L.fireEvent(M.eventType,M)}return Event.extend(M)}}})());Object.extend(Event,Event.Methods);Element.addMethods({fire:Event.fire,observe:Event.observe,stopObserving:Event.stopObserving});Object.extend(document,{fire:Element.Methods.fire.methodize(),observe:Element.Methods.observe.methodize(),stopObserving:Element.Methods.stopObserving.methodize(),loaded:false});(function(){var B;function A(){if(document.loaded){return }if(B){window.clearInterval(B)}document.fire("dom:loaded");document.loaded=true}if(document.addEventListener){if(Prototype.Browser.WebKit){B=window.setInterval(function(){if(/loaded|complete/.test(document.readyState)){A()}},0);Event.observe(window,"load",A)}else{document.addEventListener("DOMContentLoaded",A,false)}}else{document.write("<script id=__onDOMContentLoaded defer src=//:><\/script>");$("__onDOMContentLoaded").onreadystatechange=function(){if(this.readyState=="complete"){this.onreadystatechange=null;A()}}}})();Hash.toQueryString=Object.toQueryString;var Toggle={display:Element.toggle};Element.Methods.childOf=Element.Methods.descendantOf;var Insertion={Before:function(A,B){return Element.insert(A,{before:B})},Top:function(A,B){return Element.insert(A,{top:B})},Bottom:function(A,B){return Element.insert(A,{bottom:B})},After:function(A,B){return Element.insert(A,{after:B})}};var $continue=new Error('"throw $continue" is deprecated, use "return" instead');var Position={includeScrollOffsets:false,prepare:function(){this.deltaX=window.pageXOffset||document.documentElement.scrollLeft||document.body.scrollLeft||0;this.deltaY=window.pageYOffset||document.documentElement.scrollTop||document.body.scrollTop||0},within:function(B,A,C){if(this.includeScrollOffsets){return this.withinIncludingScrolloffsets(B,A,C)}this.xcomp=A;this.ycomp=C;this.offset=Element.cumulativeOffset(B);return(C>=this.offset[1]&&C<this.offset[1]+B.offsetHeight&&A>=this.offset[0]&&A<this.offset[0]+B.offsetWidth)},withinIncludingScrolloffsets:function(B,A,D){var C=Element.cumulativeScrollOffset(B);this.xcomp=A+C[0]-this.deltaX;this.ycomp=D+C[1]-this.deltaY;this.offset=Element.cumulativeOffset(B);return(this.ycomp>=this.offset[1]&&this.ycomp<this.offset[1]+B.offsetHeight&&this.xcomp>=this.offset[0]&&this.xcomp<this.offset[0]+B.offsetWidth)},overlap:function(B,A){if(!B){return 0}if(B=="vertical"){return((this.offset[1]+A.offsetHeight)-this.ycomp)/A.offsetHeight}if(B=="horizontal"){return((this.offset[0]+A.offsetWidth)-this.xcomp)/A.offsetWidth}},cumulativeOffset:Element.Methods.cumulativeOffset,positionedOffset:Element.Methods.positionedOffset,absolutize:function(A){Position.prepare();return Element.absolutize(A)},relativize:function(A){Position.prepare();return Element.relativize(A)},realOffset:Element.Methods.cumulativeScrollOffset,offsetParent:Element.Methods.getOffsetParent,page:Element.Methods.viewportOffset,clone:function(B,C,A){A=A||{};return Element.clonePosition(C,B,A)}};if(!document.getElementsByClassName){document.getElementsByClassName=function(B){function A(C){return C.blank()?null:"[contains(concat(' ', @class, ' '), ' "+C+" ')]"}B.getElementsByClassName=Prototype.BrowserFeatures.XPath?function(C,E){E=E.toString().strip();var D=/\s/.test(E)?$w(E).map(A).join(""):A(E);return D?document._getElementsByXPath(".//*"+D,C):[]}:function(E,F){F=F.toString().strip();var G=[],H=(/\s/.test(F)?$w(F):null);if(!H&&!F){return G}var C=$(E).getElementsByTagName("*");F=" "+F+" ";for(var D=0,J,I;J=C[D];D++){if(J.className&&(I=" "+J.className+" ")&&(I.include(F)||(H&&H.all(function(K){return !K.toString().blank()&&I.include(" "+K+" ")})))){G.push(Element.extend(J))}}return G};return function(D,C){return $(C||document.body).getElementsByClassName(D)}}(Element.Methods)}Element.ClassNames=Class.create();Element.ClassNames.prototype={initialize:function(A){this.element=$(A)},_each:function(A){this.element.className.split(/\s+/).select(function(B){return B.length>0})._each(A)},set:function(A){this.element.className=A},add:function(A){if(this.include(A)){return }this.set($A(this).concat(A).join(" "))},remove:function(A){if(!this.include(A)){return }this.set($A(this).without(A).join(" "))},toString:function(){return $A(this).join(" ")}};Object.extend(Element.ClassNames.prototype,Enumerable);Element.addMethods();var Scriptaculous={Version:"1.8.2",require:function(A){document.write('<script type="text/javascript" src="'+A+'"><\/script>')},REQUIRED_PROTOTYPE:"1.6.0.3",load:function(){function A(B){var C=B.replace(/_.*|\./g,"");C=parseInt(C+"0".times(4-C.length));return B.indexOf("_")>-1?C-1:C}if((typeof Prototype=="undefined")||(typeof Element=="undefined")||(typeof Element.Methods=="undefined")||(A(Prototype.Version)<A(Scriptaculous.REQUIRED_PROTOTYPE))){throw ("script.aculo.us requires the Prototype JavaScript framework >= "+Scriptaculous.REQUIRED_PROTOTYPE)}}};Scriptaculous.load();var Builder={NODEMAP:{AREA:"map",CAPTION:"table",COL:"table",COLGROUP:"table",LEGEND:"fieldset",OPTGROUP:"select",OPTION:"select",PARAM:"object",TBODY:"table",TD:"table",TFOOT:"table",TH:"table",THEAD:"table",TR:"table"},node:function(A){A=A.toUpperCase();var F=this.NODEMAP[A]||"div";var B=document.createElement(F);try{B.innerHTML="<"+A+"></"+A+">"}catch(E){}var D=B.firstChild||null;if(D&&(D.tagName.toUpperCase()!=A)){D=D.getElementsByTagName(A)[0]}if(!D){D=document.createElement(A)}if(!D){return }if(arguments[1]){if(this._isStringOrNumber(arguments[1])||(arguments[1] instanceof Array)||arguments[1].tagName){this._children(D,arguments[1])}else{var C=this._attributes(arguments[1]);if(C.length){try{B.innerHTML="<"+A+" "+C+"></"+A+">"}catch(E){}D=B.firstChild||null;if(!D){D=document.createElement(A);for(attr in arguments[1]){D[attr=="class"?"className":attr]=arguments[1][attr]}}if(D.tagName.toUpperCase()!=A){D=B.getElementsByTagName(A)[0]}}}}if(arguments[2]){this._children(D,arguments[2])}return $(D)},_text:function(A){return document.createTextNode(A)},ATTR_MAP:{className:"class",htmlFor:"for"},_attributes:function(A){var B=[];for(attribute in A){B.push((attribute in this.ATTR_MAP?this.ATTR_MAP[attribute]:attribute)+'="'+A[attribute].toString().escapeHTML().gsub(/"/,"&quot;")+'"')}return B.join(" ")},_children:function(B,A){if(A.tagName){B.appendChild(A);return }if(typeof A=="object"){A.flatten().each(function(C){if(typeof C=="object"){B.appendChild(C)}else{if(Builder._isStringOrNumber(C)){B.appendChild(Builder._text(C))}}})}else{if(Builder._isStringOrNumber(A)){B.appendChild(Builder._text(A))}}},_isStringOrNumber:function(A){return(typeof A=="string"||typeof A=="number")},build:function(B){var A=this.node("div");$(A).update(B.strip());return A.down()},dump:function(B){if(typeof B!="object"&&typeof B!="function"){B=window}var A=("A ABBR ACRONYM ADDRESS APPLET AREA B BASE BASEFONT BDO BIG BLOCKQUOTE BODY BR BUTTON CAPTION CENTER CITE CODE COL COLGROUP DD DEL DFN DIR DIV DL DT EM FIELDSET FONT FORM FRAME FRAMESET H1 H2 H3 H4 H5 H6 HEAD HR HTML I IFRAME IMG INPUT INS ISINDEX KBD LABEL LEGEND LI LINK MAP MENU META NOFRAMES NOSCRIPT OBJECT OL OPTGROUP OPTION P PARAM PRE Q S SAMP SCRIPT SELECT SMALL SPAN STRIKE STRONG STYLE SUB SUP TABLE TBODY TD TEXTAREA TFOOT TH THEAD TITLE TR TT U UL VAR").split(/\s+/);A.each(function(C){B[C]=function(){return Builder.node.apply(Builder,[C].concat($A(arguments)))}})}};String.prototype.parseColor=function(){var A="#";if(this.slice(0,4)=="rgb("){var C=this.slice(4,this.length-1).split(",");var B=0;do{A+=parseInt(C[B]).toColorPart()}while(++B<3)}else{if(this.slice(0,1)=="#"){if(this.length==4){for(var B=1;B<4;B++){A+=(this.charAt(B)+this.charAt(B)).toLowerCase()}}if(this.length==7){A=this.toLowerCase()}}}return(A.length==7?A:(arguments[0]||this))};Element.collectTextNodes=function(A){return $A($(A).childNodes).collect(function(B){return(B.nodeType==3?B.nodeValue:(B.hasChildNodes()?Element.collectTextNodes(B):""))}).flatten().join("")};Element.collectTextNodesIgnoreClass=function(A,B){return $A($(A).childNodes).collect(function(C){return(C.nodeType==3?C.nodeValue:((C.hasChildNodes()&&!Element.hasClassName(C,B))?Element.collectTextNodesIgnoreClass(C,B):""))}).flatten().join("")};Element.setContentZoom=function(A,B){A=$(A);A.setStyle({fontSize:(B/100)+"em"});if(Prototype.Browser.WebKit){window.scrollBy(0,0)}return A};Element.getInlineOpacity=function(A){return $(A).style.opacity||""};Element.forceRerendering=function(A){try{A=$(A);var C=document.createTextNode(" ");A.appendChild(C);A.removeChild(C)}catch(B){}};var Effect={_elementDoesNotExistError:{name:"ElementDoesNotExistError",message:"The specified DOM element does not exist, but is required for this effect to operate"},Transitions:{linear:Prototype.K,sinoidal:function(A){return(-Math.cos(A*Math.PI)/2)+0.5},reverse:function(A){return 1-A},flicker:function(A){var A=((-Math.cos(A*Math.PI)/4)+0.75)+Math.random()/4;return A>1?1:A},wobble:function(A){return(-Math.cos(A*Math.PI*(9*A))/2)+0.5},pulse:function(B,A){return(-Math.cos((B*((A||5)-0.5)*2)*Math.PI)/2)+0.5},spring:function(A){return 1-(Math.cos(A*4.5*Math.PI)*Math.exp(-A*6))},none:function(A){return 0},full:function(A){return 1}},DefaultOptions:{duration:1,fps:100,sync:false,from:0,to:1,delay:0,queue:"parallel"},tagifyText:function(A){var B="position:relative";if(Prototype.Browser.IE){B+=";zoom:1"}A=$(A);$A(A.childNodes).each(function(C){if(C.nodeType==3){C.nodeValue.toArray().each(function(D){A.insertBefore(new Element("span",{style:B}).update(D==" "?String.fromCharCode(160):D),C)});Element.remove(C)}})},multiple:function(B,C){var E;if(((typeof B=="object")||Object.isFunction(B))&&(B.length)){E=B}else{E=$(B).childNodes}var A=Object.extend({speed:0.1,delay:0},arguments[2]||{});var D=A.delay;$A(E).each(function(G,F){new C(G,Object.extend(A,{delay:F*A.speed+D}))})},PAIRS:{slide:["SlideDown","SlideUp"],blind:["BlindDown","BlindUp"],appear:["Appear","Fade"]},toggle:function(B,C){B=$(B);C=(C||"appear").toLowerCase();var A=Object.extend({queue:{position:"end",scope:(B.id||"global"),limit:1}},arguments[2]||{});Effect[B.visible()?Effect.PAIRS[C][1]:Effect.PAIRS[C][0]](B,A)}};Effect.DefaultOptions.transition=Effect.Transitions.sinoidal;Effect.ScopedQueue=Class.create(Enumerable,{initialize:function(){this.effects=[];this.interval=null},_each:function(A){this.effects._each(A)},add:function(B){var C=new Date().getTime();var A=Object.isString(B.options.queue)?B.options.queue:B.options.queue.position;switch(A){case"front":this.effects.findAll(function(D){return D.state=="idle"}).each(function(D){D.startOn+=B.finishOn;D.finishOn+=B.finishOn});break;case"with-last":C=this.effects.pluck("startOn").max()||C;break;case"end":C=this.effects.pluck("finishOn").max()||C;break}B.startOn+=C;B.finishOn+=C;if(!B.options.queue.limit||(this.effects.length<B.options.queue.limit)){this.effects.push(B)}if(!this.interval){this.interval=setInterval(this.loop.bind(this),15)}},remove:function(A){this.effects=this.effects.reject(function(B){return B==A});if(this.effects.length==0){clearInterval(this.interval);this.interval=null}},loop:function(){var C=new Date().getTime();for(var B=0,A=this.effects.length;B<A;B++){this.effects[B]&&this.effects[B].loop(C)}}});Effect.Queues={instances:$H(),get:function(A){if(!Object.isString(A)){return A}return this.instances.get(A)||this.instances.set(A,new Effect.ScopedQueue())}};Effect.Queue=Effect.Queues.get("global");Effect.Base=Class.create({position:null,start:function(A){function B(D,C){return((D[C+"Internal"]?"this.options."+C+"Internal(this);":"")+(D[C]?"this.options."+C+"(this);":""))}if(A&&A.transition===false){A.transition=Effect.Transitions.linear}this.options=Object.extend(Object.extend({},Effect.DefaultOptions),A||{});this.currentFrame=0;this.state="idle";this.startOn=this.options.delay*1000;this.finishOn=this.startOn+(this.options.duration*1000);this.fromToDelta=this.options.to-this.options.from;this.totalTime=this.finishOn-this.startOn;this.totalFrames=this.options.fps*this.options.duration;this.render=(function(){function C(E,D){if(E.options[D+"Internal"]){E.options[D+"Internal"](E)}if(E.options[D]){E.options[D](E)}}return function(D){if(this.state==="idle"){this.state="running";C(this,"beforeSetup");if(this.setup){this.setup()}C(this,"afterSetup")}if(this.state==="running"){D=(this.options.transition(D)*this.fromToDelta)+this.options.from;this.position=D;C(this,"beforeUpdate");if(this.update){this.update(D)}C(this,"afterUpdate")}}})();this.event("beforeStart");if(!this.options.sync){Effect.Queues.get(Object.isString(this.options.queue)?"global":this.options.queue.scope).add(this)}},loop:function(C){if(C>=this.startOn){if(C>=this.finishOn){this.render(1);this.cancel();this.event("beforeFinish");if(this.finish){this.finish()}this.event("afterFinish");return }var B=(C-this.startOn)/this.totalTime,A=(B*this.totalFrames).round();if(A>this.currentFrame){this.render(B);this.currentFrame=A}}},cancel:function(){if(!this.options.sync){Effect.Queues.get(Object.isString(this.options.queue)?"global":this.options.queue.scope).remove(this)}this.state="finished"},event:function(A){if(this.options[A+"Internal"]){this.options[A+"Internal"](this)}if(this.options[A]){this.options[A](this)}},inspect:function(){var A=$H();for(property in this){if(!Object.isFunction(this[property])){A.set(property,this[property])}}return"#<Effect:"+A.inspect()+",options:"+$H(this.options).inspect()+">"}});Effect.Parallel=Class.create(Effect.Base,{initialize:function(A){this.effects=A||[];this.start(arguments[1])},update:function(A){this.effects.invoke("render",A)},finish:function(A){this.effects.each(function(B){B.render(1);B.cancel();B.event("beforeFinish");if(B.finish){B.finish(A)}B.event("afterFinish")})}});Effect.Tween=Class.create(Effect.Base,{initialize:function(C,F,E){C=Object.isString(C)?$(C):C;var B=$A(arguments),D=B.last(),A=B.length==5?B[3]:null;this.method=Object.isFunction(D)?D.bind(C):Object.isFunction(C[D])?C[D].bind(C):function(G){C[D]=G};this.start(Object.extend({from:F,to:E},A||{}))},update:function(A){this.method(A)}});Effect.Event=Class.create(Effect.Base,{initialize:function(){this.start(Object.extend({duration:0},arguments[0]||{}))},update:Prototype.emptyFunction});Effect.Opacity=Class.create(Effect.Base,{initialize:function(B){this.element=$(B);if(!this.element){throw (Effect._elementDoesNotExistError)}if(Prototype.Browser.IE&&(!this.element.currentStyle.hasLayout)){this.element.setStyle({zoom:1})}var A=Object.extend({from:this.element.getOpacity()||0,to:1},arguments[1]||{});this.start(A)},update:function(A){this.element.setOpacity(A)}});Effect.Move=Class.create(Effect.Base,{initialize:function(B){this.element=$(B);if(!this.element){throw (Effect._elementDoesNotExistError)}var A=Object.extend({x:0,y:0,mode:"relative"},arguments[1]||{});this.start(A)},setup:function(){this.element.makePositioned();this.originalLeft=parseFloat(this.element.getStyle("left")||"0");this.originalTop=parseFloat(this.element.getStyle("top")||"0");if(this.options.mode=="absolute"){this.options.x=this.options.x-this.originalLeft;this.options.y=this.options.y-this.originalTop}},update:function(A){this.element.setStyle({left:(this.options.x*A+this.originalLeft).round()+"px",top:(this.options.y*A+this.originalTop).round()+"px"})}});Effect.MoveBy=function(B,A,C){return new Effect.Move(B,Object.extend({x:C,y:A},arguments[3]||{}))};Effect.Scale=Class.create(Effect.Base,{initialize:function(B,C){this.element=$(B);if(!this.element){throw (Effect._elementDoesNotExistError)}var A=Object.extend({scaleX:true,scaleY:true,scaleContent:true,scaleFromCenter:false,scaleMode:"box",scaleFrom:100,scaleTo:C},arguments[2]||{});this.start(A)},setup:function(){this.restoreAfterFinish=this.options.restoreAfterFinish||false;this.elementPositioning=this.element.getStyle("position");this.originalStyle={};["top","left","width","height","fontSize"].each(function(B){this.originalStyle[B]=this.element.style[B]}.bind(this));this.originalTop=this.element.offsetTop;this.originalLeft=this.element.offsetLeft;var A=this.element.getStyle("font-size")||"100%";["em","px","%","pt"].each(function(B){if(A.indexOf(B)>0){this.fontSize=parseFloat(A);this.fontSizeType=B}}.bind(this));this.factor=(this.options.scaleTo-this.options.scaleFrom)/100;this.dims=null;if(this.options.scaleMode=="box"){this.dims=[this.element.offsetHeight,this.element.offsetWidth]}if(/^content/.test(this.options.scaleMode)){this.dims=[this.element.scrollHeight,this.element.scrollWidth]}if(!this.dims){this.dims=[this.options.scaleMode.originalHeight,this.options.scaleMode.originalWidth]}},update:function(A){var B=(this.options.scaleFrom/100)+(this.factor*A);if(this.options.scaleContent&&this.fontSize){this.element.setStyle({fontSize:this.fontSize*B+this.fontSizeType})}this.setDimensions(this.dims[0]*B,this.dims[1]*B)},finish:function(A){if(this.restoreAfterFinish){this.element.setStyle(this.originalStyle)}},setDimensions:function(A,D){var E={};if(this.options.scaleX){E.width=D.round()+"px"}if(this.options.scaleY){E.height=A.round()+"px"}if(this.options.scaleFromCenter){var C=(A-this.dims[0])/2;var B=(D-this.dims[1])/2;if(this.elementPositioning=="absolute"){if(this.options.scaleY){E.top=this.originalTop-C+"px"}if(this.options.scaleX){E.left=this.originalLeft-B+"px"}}else{if(this.options.scaleY){E.top=-C+"px"}if(this.options.scaleX){E.left=-B+"px"}}}this.element.setStyle(E)}});Effect.Highlight=Class.create(Effect.Base,{initialize:function(B){this.element=$(B);if(!this.element){throw (Effect._elementDoesNotExistError)}var A=Object.extend({startcolor:"#ffff99"},arguments[1]||{});this.start(A)},setup:function(){if(this.element.getStyle("display")=="none"){this.cancel();return }this.oldStyle={};if(!this.options.keepBackgroundImage){this.oldStyle.backgroundImage=this.element.getStyle("background-image");this.element.setStyle({backgroundImage:"none"})}if(!this.options.endcolor){this.options.endcolor=this.element.getStyle("background-color").parseColor("#ffffff")}if(!this.options.restorecolor){this.options.restorecolor=this.element.getStyle("background-color")}this._base=$R(0,2).map(function(A){return parseInt(this.options.startcolor.slice(A*2+1,A*2+3),16)}.bind(this));this._delta=$R(0,2).map(function(A){return parseInt(this.options.endcolor.slice(A*2+1,A*2+3),16)-this._base[A]}.bind(this))},update:function(A){this.element.setStyle({backgroundColor:$R(0,2).inject("#",function(B,C,D){return B+((this._base[D]+(this._delta[D]*A)).round().toColorPart())}.bind(this))})},finish:function(){this.element.setStyle(Object.extend(this.oldStyle,{backgroundColor:this.options.restorecolor}))}});Effect.ScrollTo=function(C){var B=arguments[1]||{},A=document.viewport.getScrollOffsets(),D=$(C).cumulativeOffset();if(B.offset){D[1]+=B.offset}return new Effect.Tween(null,A.top,D[1],B,function(E){scrollTo(A.left,E.round())})};Effect.Fade=function(C){C=$(C);var A=C.getInlineOpacity();var B=Object.extend({from:C.getOpacity()||1,to:0,afterFinishInternal:function(D){if(D.options.to!=0){return }D.element.hide().setStyle({opacity:A})}},arguments[1]||{});return new Effect.Opacity(C,B)};Effect.Appear=function(B){B=$(B);var A=Object.extend({from:(B.getStyle("display")=="none"?0:B.getOpacity()||0),to:1,afterFinishInternal:function(C){C.element.forceRerendering()},beforeSetup:function(C){C.element.setOpacity(C.options.from).show()}},arguments[1]||{});return new Effect.Opacity(B,A)};Effect.Puff=function(B){B=$(B);var A={opacity:B.getInlineOpacity(),position:B.getStyle("position"),top:B.style.top,left:B.style.left,width:B.style.width,height:B.style.height};return new Effect.Parallel([new Effect.Scale(B,200,{sync:true,scaleFromCenter:true,scaleContent:true,restoreAfterFinish:true}),new Effect.Opacity(B,{sync:true,to:0})],Object.extend({duration:1,beforeSetupInternal:function(C){Position.absolutize(C.effects[0].element)},afterFinishInternal:function(C){C.effects[0].element.hide().setStyle(A)}},arguments[1]||{}))};Effect.BlindUp=function(A){A=$(A);A.makeClipping();return new Effect.Scale(A,0,Object.extend({scaleContent:false,scaleX:false,restoreAfterFinish:true,afterFinishInternal:function(B){B.element.hide().undoClipping()}},arguments[1]||{}))};Effect.BlindDown=function(B){B=$(B);var A=B.getDimensions();return new Effect.Scale(B,100,Object.extend({scaleContent:false,scaleX:false,scaleFrom:0,scaleMode:{originalHeight:A.height,originalWidth:A.width},restoreAfterFinish:true,afterSetup:function(C){C.element.makeClipping().setStyle({height:"0px"}).show()},afterFinishInternal:function(C){C.element.undoClipping()}},arguments[1]||{}))};Effect.SwitchOff=function(B){B=$(B);var A=B.getInlineOpacity();return new Effect.Appear(B,Object.extend({duration:0.4,from:0,transition:Effect.Transitions.flicker,afterFinishInternal:function(C){new Effect.Scale(C.element,1,{duration:0.3,scaleFromCenter:true,scaleX:false,scaleContent:false,restoreAfterFinish:true,beforeSetup:function(D){D.element.makePositioned().makeClipping()},afterFinishInternal:function(D){D.element.hide().undoClipping().undoPositioned().setStyle({opacity:A})}})}},arguments[1]||{}))};Effect.DropOut=function(B){B=$(B);var A={top:B.getStyle("top"),left:B.getStyle("left"),opacity:B.getInlineOpacity()};return new Effect.Parallel([new Effect.Move(B,{x:0,y:100,sync:true}),new Effect.Opacity(B,{sync:true,to:0})],Object.extend({duration:0.5,beforeSetup:function(C){C.effects[0].element.makePositioned()},afterFinishInternal:function(C){C.effects[0].element.hide().undoPositioned().setStyle(A)}},arguments[1]||{}))};Effect.Shake=function(D){D=$(D);var B=Object.extend({distance:20,duration:0.5},arguments[1]||{});var E=parseFloat(B.distance);var C=parseFloat(B.duration)/10;var A={top:D.getStyle("top"),left:D.getStyle("left")};return new Effect.Move(D,{x:E,y:0,duration:C,afterFinishInternal:function(F){new Effect.Move(F.element,{x:-E*2,y:0,duration:C*2,afterFinishInternal:function(G){new Effect.Move(G.element,{x:E*2,y:0,duration:C*2,afterFinishInternal:function(H){new Effect.Move(H.element,{x:-E*2,y:0,duration:C*2,afterFinishInternal:function(I){new Effect.Move(I.element,{x:E*2,y:0,duration:C*2,afterFinishInternal:function(J){new Effect.Move(J.element,{x:-E,y:0,duration:C,afterFinishInternal:function(K){K.element.undoPositioned().setStyle(A)}})}})}})}})}})}})};Effect.SlideDown=function(C){C=$(C).cleanWhitespace();var A=C.down().getStyle("bottom");var B=C.getDimensions();return new Effect.Scale(C,100,Object.extend({scaleContent:false,scaleX:false,scaleFrom:window.opera?0:1,scaleMode:{originalHeight:B.height,originalWidth:B.width},restoreAfterFinish:true,afterSetup:function(D){D.element.makePositioned();D.element.down().makePositioned();if(window.opera){D.element.setStyle({top:""})}D.element.makeClipping().setStyle({height:"0px"}).show()},afterUpdateInternal:function(D){D.element.down().setStyle({bottom:(D.dims[0]-D.element.clientHeight)+"px"})},afterFinishInternal:function(D){D.element.undoClipping().undoPositioned();D.element.down().undoPositioned().setStyle({bottom:A})}},arguments[1]||{}))};Effect.SlideUp=function(C){C=$(C).cleanWhitespace();var A=C.down().getStyle("bottom");var B=C.getDimensions();return new Effect.Scale(C,window.opera?0:1,Object.extend({scaleContent:false,scaleX:false,scaleMode:"box",scaleFrom:100,scaleMode:{originalHeight:B.height,originalWidth:B.width},restoreAfterFinish:true,afterSetup:function(D){D.element.makePositioned();D.element.down().makePositioned();if(window.opera){D.element.setStyle({top:""})}D.element.makeClipping().show()},afterUpdateInternal:function(D){D.element.down().setStyle({bottom:(D.dims[0]-D.element.clientHeight)+"px"})},afterFinishInternal:function(D){D.element.hide().undoClipping().undoPositioned();D.element.down().undoPositioned().setStyle({bottom:A})}},arguments[1]||{}))};Effect.Squish=function(A){return new Effect.Scale(A,window.opera?1:0,{restoreAfterFinish:true,beforeSetup:function(B){B.element.makeClipping()},afterFinishInternal:function(B){B.element.hide().undoClipping()}})};Effect.Grow=function(C){C=$(C);var B=Object.extend({direction:"center",moveTransition:Effect.Transitions.sinoidal,scaleTransition:Effect.Transitions.sinoidal,opacityTransition:Effect.Transitions.full},arguments[1]||{});var A={top:C.style.top,left:C.style.left,height:C.style.height,width:C.style.width,opacity:C.getInlineOpacity()};var G=C.getDimensions();var H,F;var E,D;switch(B.direction){case"top-left":H=F=E=D=0;break;case"top-right":H=G.width;F=D=0;E=-G.width;break;case"bottom-left":H=E=0;F=G.height;D=-G.height;break;case"bottom-right":H=G.width;F=G.height;E=-G.width;D=-G.height;break;case"center":H=G.width/2;F=G.height/2;E=-G.width/2;D=-G.height/2;break}return new Effect.Move(C,{x:H,y:F,duration:0.01,beforeSetup:function(I){I.element.hide().makeClipping().makePositioned()},afterFinishInternal:function(I){new Effect.Parallel([new Effect.Opacity(I.element,{sync:true,to:1,from:0,transition:B.opacityTransition}),new Effect.Move(I.element,{x:E,y:D,sync:true,transition:B.moveTransition}),new Effect.Scale(I.element,100,{scaleMode:{originalHeight:G.height,originalWidth:G.width},sync:true,scaleFrom:window.opera?1:0,transition:B.scaleTransition,restoreAfterFinish:true})],Object.extend({beforeSetup:function(J){J.effects[0].element.setStyle({height:"0px"}).show()},afterFinishInternal:function(J){J.effects[0].element.undoClipping().undoPositioned().setStyle(A)}},B))}})};Effect.Shrink=function(C){C=$(C);var B=Object.extend({direction:"center",moveTransition:Effect.Transitions.sinoidal,scaleTransition:Effect.Transitions.sinoidal,opacityTransition:Effect.Transitions.none},arguments[1]||{});var A={top:C.style.top,left:C.style.left,height:C.style.height,width:C.style.width,opacity:C.getInlineOpacity()};var F=C.getDimensions();var E,D;switch(B.direction){case"top-left":E=D=0;break;case"top-right":E=F.width;D=0;break;case"bottom-left":E=0;D=F.height;break;case"bottom-right":E=F.width;D=F.height;break;case"center":E=F.width/2;D=F.height/2;break}return new Effect.Parallel([new Effect.Opacity(C,{sync:true,to:0,from:1,transition:B.opacityTransition}),new Effect.Scale(C,window.opera?1:0,{sync:true,transition:B.scaleTransition,restoreAfterFinish:true}),new Effect.Move(C,{x:E,y:D,sync:true,transition:B.moveTransition})],Object.extend({beforeStartInternal:function(G){G.effects[0].element.makePositioned().makeClipping()},afterFinishInternal:function(G){G.effects[0].element.hide().undoClipping().undoPositioned().setStyle(A)}},B))};Effect.Pulsate=function(C){C=$(C);var B=arguments[1]||{},A=C.getInlineOpacity(),E=B.transition||Effect.Transitions.linear,D=function(F){return 1-E((-Math.cos((F*(B.pulses||5)*2)*Math.PI)/2)+0.5)};return new Effect.Opacity(C,Object.extend(Object.extend({duration:2,from:0,afterFinishInternal:function(F){F.element.setStyle({opacity:A})}},B),{transition:D}))};Effect.Fold=function(B){B=$(B);var A={top:B.style.top,left:B.style.left,width:B.style.width,height:B.style.height};B.makeClipping();return new Effect.Scale(B,5,Object.extend({scaleContent:false,scaleX:false,afterFinishInternal:function(C){new Effect.Scale(B,1,{scaleContent:false,scaleY:false,afterFinishInternal:function(D){D.element.hide().undoClipping().setStyle(A)}})}},arguments[1]||{}))};Effect.Morph=Class.create(Effect.Base,{initialize:function(C){this.element=$(C);if(!this.element){throw (Effect._elementDoesNotExistError)}var A=Object.extend({style:{}},arguments[1]||{});if(!Object.isString(A.style)){this.style=$H(A.style)}else{if(A.style.include(":")){this.style=A.style.parseStyle()}else{this.element.addClassName(A.style);this.style=$H(this.element.getStyles());this.element.removeClassName(A.style);var B=this.element.getStyles();this.style=this.style.reject(function(D){return D.value==B[D.key]});A.afterFinishInternal=function(D){D.element.addClassName(D.options.style);D.transforms.each(function(E){D.element.style[E.style]=""})}}}this.start(A)},setup:function(){function A(B){if(!B||["rgba(0, 0, 0, 0)","transparent"].include(B)){B="#ffffff"}B=B.parseColor();return $R(0,2).map(function(C){return parseInt(B.slice(C*2+1,C*2+3),16)})}this.transforms=this.style.map(function(G){var F=G[0],E=G[1],D=null;if(E.parseColor("#zzzzzz")!="#zzzzzz"){E=E.parseColor();D="color"}else{if(F=="opacity"){E=parseFloat(E);if(Prototype.Browser.IE&&(!this.element.currentStyle.hasLayout)){this.element.setStyle({zoom:1})}}else{if(Element.CSS_LENGTH.test(E)){var C=E.match(/^([\+\-]?[0-9\.]+)(.*)$/);E=parseFloat(C[1]);D=(C.length==3)?C[2]:null}}}var B=this.element.getStyle(F);return{style:F.camelize(),originalValue:D=="color"?A(B):parseFloat(B||0),targetValue:D=="color"?A(E):E,unit:D}}.bind(this)).reject(function(B){return((B.originalValue==B.targetValue)||(B.unit!="color"&&(isNaN(B.originalValue)||isNaN(B.targetValue))))})},update:function(A){var D={},B,C=this.transforms.length;while(C--){D[(B=this.transforms[C]).style]=B.unit=="color"?"#"+(Math.round(B.originalValue[0]+(B.targetValue[0]-B.originalValue[0])*A)).toColorPart()+(Math.round(B.originalValue[1]+(B.targetValue[1]-B.originalValue[1])*A)).toColorPart()+(Math.round(B.originalValue[2]+(B.targetValue[2]-B.originalValue[2])*A)).toColorPart():(B.originalValue+(B.targetValue-B.originalValue)*A).toFixed(3)+(B.unit===null?"":B.unit)}this.element.setStyle(D,true)}});Effect.Transform=Class.create({initialize:function(A){this.tracks=[];this.options=arguments[1]||{};this.addTracks(A)},addTracks:function(A){A.each(function(B){B=$H(B);var C=B.values().first();this.tracks.push($H({ids:B.keys().first(),effect:Effect.Morph,options:{style:C}}))}.bind(this));return this},play:function(){return new Effect.Parallel(this.tracks.map(function(A){var D=A.get("ids"),C=A.get("effect"),B=A.get("options");var E=[$(D)||$$(D)].flatten();return E.map(function(F){return new C(F,Object.extend({sync:true},B))})}).flatten(),this.options)}});Element.CSS_PROPERTIES=$w("backgroundColor backgroundPosition borderBottomColor borderBottomStyle borderBottomWidth borderLeftColor borderLeftStyle borderLeftWidth borderRightColor borderRightStyle borderRightWidth borderSpacing borderTopColor borderTopStyle borderTopWidth bottom clip color fontSize fontWeight height left letterSpacing lineHeight marginBottom marginLeft marginRight marginTop markerOffset maxHeight maxWidth minHeight minWidth opacity outlineColor outlineOffset outlineWidth paddingBottom paddingLeft paddingRight paddingTop right textIndent top width wordSpacing zIndex");Element.CSS_LENGTH=/^(([\+\-]?[0-9\.]+)(em|ex|px|in|cm|mm|pt|pc|\%))|0$/;String.__parseStyleElement=document.createElement("div");String.prototype.parseStyle=function(){var B,A=$H();if(Prototype.Browser.WebKit){B=new Element("div",{style:this}).style}else{String.__parseStyleElement.innerHTML='<div style="'+this+'"></div>';B=String.__parseStyleElement.childNodes[0].style}Element.CSS_PROPERTIES.each(function(C){if(B[C]){A.set(C,B[C])}});if(Prototype.Browser.IE&&this.include("opacity")){A.set("opacity",this.match(/opacity:\s*((?:0|1)?(?:\.\d*)?)/)[1])}return A};if(document.defaultView&&document.defaultView.getComputedStyle){Element.getStyles=function(B){var A=document.defaultView.getComputedStyle($(B),null);return Element.CSS_PROPERTIES.inject({},function(C,D){C[D]=A[D];return C})}}else{Element.getStyles=function(B){B=$(B);var A=B.currentStyle,C;C=Element.CSS_PROPERTIES.inject({},function(D,E){D[E]=A[E];return D});if(!C.opacity){C.opacity=B.getOpacity()}return C}}Effect.Methods={morph:function(A,B){A=$(A);new Effect.Morph(A,Object.extend({style:B},arguments[2]||{}));return A},visualEffect:function(C,E,B){C=$(C);var D=E.dasherize().camelize(),A=D.charAt(0).toUpperCase()+D.substring(1);new Effect[A](C,B);return C},highlight:function(B,A){B=$(B);new Effect.Highlight(B,A);return B}};$w("fade appear grow shrink fold blindUp blindDown slideUp slideDown pulsate shake puff squish switchOff dropOut").each(function(A){Effect.Methods[A]=function(C,B){C=$(C);Effect[A.charAt(0).toUpperCase()+A.substring(1)](C,B);return C}});$w("getInlineOpacity forceRerendering setContentZoom collectTextNodes collectTextNodesIgnoreClass getStyles").each(function(A){Effect.Methods[A]=Element[A]});Element.addMethods(Effect.Methods);if(Object.isUndefined(Effect)){throw ("dragdrop.js requires including script.aculo.us' effects.js library")}var Droppables={drops:[],remove:function(A){this.drops=this.drops.reject(function(B){return B.element==$(A)})},add:function(B){B=$(B);var A=Object.extend({greedy:true,hoverclass:null,tree:false},arguments[1]||{});if(A.containment){A._containers=[];var C=A.containment;if(Object.isArray(C)){C.each(function(D){A._containers.push($(D))})}else{A._containers.push($(C))}}if(A.accept){A.accept=[A.accept].flatten()}Element.makePositioned(B);A.element=B;this.drops.push(A)},findDeepestChild:function(A){deepest=A[0];for(i=1;i<A.length;++i){if(Element.isParent(A[i].element,deepest.element)){deepest=A[i]}}return deepest},isContained:function(B,A){var C;if(A.tree){C=B.treeNode}else{C=B.parentNode}return A._containers.detect(function(D){return C==D})},isAffected:function(A,C,B){return((B.element!=C)&&((!B._containers)||this.isContained(C,B))&&((!B.accept)||(Element.classNames(C).detect(function(D){return B.accept.include(D)})))&&Position.within(B.element,A[0],A[1]))},deactivate:function(A){if(A.hoverclass){Element.removeClassName(A.element,A.hoverclass)}this.last_active=null},activate:function(A){if(A.hoverclass){Element.addClassName(A.element,A.hoverclass)}this.last_active=A},show:function(A,C){if(!this.drops.length){return }var B,D=[];this.drops.each(function(E){if(Droppables.isAffected(A,C,E)){D.push(E)}});if(D.length>0){B=Droppables.findDeepestChild(D)}if(this.last_active&&this.last_active!=B){this.deactivate(this.last_active)}if(B){Position.within(B.element,A[0],A[1]);if(B.onHover){B.onHover(C,B.element,Position.overlap(B.overlap,B.element))}if(B!=this.last_active){Droppables.activate(B)}}},fire:function(B,A){if(!this.last_active){return }Position.prepare();if(this.isAffected([Event.pointerX(B),Event.pointerY(B)],A,this.last_active)){if(this.last_active.onDrop){this.last_active.onDrop(A,this.last_active.element,B);return true}}},reset:function(){if(this.last_active){this.deactivate(this.last_active)}}};var Draggables={drags:[],observers:[],register:function(A){if(this.drags.length==0){this.eventMouseUp=this.endDrag.bindAsEventListener(this);this.eventMouseMove=this.updateDrag.bindAsEventListener(this);this.eventKeypress=this.keyPress.bindAsEventListener(this);Event.observe(document,"mouseup",this.eventMouseUp);Event.observe(document,"mousemove",this.eventMouseMove);Event.observe(document,"keypress",this.eventKeypress)}this.drags.push(A)},unregister:function(A){this.drags=this.drags.reject(function(B){return B==A});if(this.drags.length==0){Event.stopObserving(document,"mouseup",this.eventMouseUp);Event.stopObserving(document,"mousemove",this.eventMouseMove);Event.stopObserving(document,"keypress",this.eventKeypress)}},activate:function(A){if(A.options.delay){this._timeout=setTimeout(function(){Draggables._timeout=null;window.focus();Draggables.activeDraggable=A}.bind(this),A.options.delay)}else{window.focus();this.activeDraggable=A}},deactivate:function(){this.activeDraggable=null},updateDrag:function(A){if(!this.activeDraggable){return }var B=[Event.pointerX(A),Event.pointerY(A)];if(this._lastPointer&&(this._lastPointer.inspect()==B.inspect())){return }this._lastPointer=B;this.activeDraggable.updateDrag(A,B)},endDrag:function(A){if(this._timeout){clearTimeout(this._timeout);this._timeout=null}if(!this.activeDraggable){return }this._lastPointer=null;this.activeDraggable.endDrag(A);this.activeDraggable=null},keyPress:function(A){if(this.activeDraggable){this.activeDraggable.keyPress(A)}},addObserver:function(A){this.observers.push(A);this._cacheObserverCallbacks()},removeObserver:function(A){this.observers=this.observers.reject(function(B){return B.element==A});this._cacheObserverCallbacks()},notify:function(B,A,C){if(this[B+"Count"]>0){this.observers.each(function(D){if(D[B]){D[B](B,A,C)}})}if(A.options[B]){A.options[B](A,C)}},_cacheObserverCallbacks:function(){["onStart","onEnd","onDrag"].each(function(A){Draggables[A+"Count"]=Draggables.observers.select(function(B){return B[A]}).length})}};var Draggable=Class.create({initialize:function(B){var C={handle:false,reverteffect:function(F,E,D){var G=Math.sqrt(Math.abs(E^2)+Math.abs(D^2))*0.02;new Effect.Move(F,{x:-D,y:-E,duration:G,queue:{scope:"_draggable",position:"end"}})},endeffect:function(E){var D=Object.isNumber(E._opacity)?E._opacity:1;new Effect.Opacity(E,{duration:0.2,from:0.7,to:D,queue:{scope:"_draggable",position:"end"},afterFinish:function(){Draggable._dragging[E]=false}})},zindex:1000,revert:false,quiet:false,scroll:false,scrollSensitivity:20,scrollSpeed:15,snap:false,delay:0};if(!arguments[1]||Object.isUndefined(arguments[1].endeffect)){Object.extend(C,{starteffect:function(D){D._opacity=Element.getOpacity(D);Draggable._dragging[D]=true;new Effect.Opacity(D,{duration:0.2,from:D._opacity,to:0.7})}})}var A=Object.extend(C,arguments[1]||{});this.element=$(B);if(A.handle&&Object.isString(A.handle)){this.handle=this.element.down("."+A.handle,0)}if(!this.handle){this.handle=$(A.handle)}if(!this.handle){this.handle=this.element}if(A.scroll&&!A.scroll.scrollTo&&!A.scroll.outerHTML){A.scroll=$(A.scroll);this._isScrollChild=Element.childOf(this.element,A.scroll)}Element.makePositioned(this.element);this.options=A;this.dragging=false;this.eventMouseDown=this.initDrag.bindAsEventListener(this);Event.observe(this.handle,"mousedown",this.eventMouseDown);Draggables.register(this)},destroy:function(){Event.stopObserving(this.handle,"mousedown",this.eventMouseDown);Draggables.unregister(this)},currentDelta:function(){return([parseInt(Element.getStyle(this.element,"left")||"0"),parseInt(Element.getStyle(this.element,"top")||"0")])},initDrag:function(A){if(!Object.isUndefined(Draggable._dragging[this.element])&&Draggable._dragging[this.element]){return }if(Event.isLeftClick(A)){var C=Event.element(A);if((tag_name=C.tagName.toUpperCase())&&(tag_name=="INPUT"||tag_name=="SELECT"||tag_name=="OPTION"||tag_name=="BUTTON"||tag_name=="TEXTAREA")){return }var B=[Event.pointerX(A),Event.pointerY(A)];var D=Position.cumulativeOffset(this.element);this.offset=[0,1].map(function(E){return(B[E]-D[E])});Draggables.activate(this);Event.stop(A)}},startDrag:function(B){this.dragging=true;if(!this.delta){this.delta=this.currentDelta()}if(this.options.zindex){this.originalZ=parseInt(Element.getStyle(this.element,"z-index")||0);this.element.style.zIndex=this.options.zindex}if(this.options.ghosting){this._clone=this.element.cloneNode(true);this._originallyAbsolute=(this.element.getStyle("position")=="absolute");if(!this._originallyAbsolute){Position.absolutize(this.element)}this.element.parentNode.insertBefore(this._clone,this.element)}if(this.options.scroll){if(this.options.scroll==window){var A=this._getWindowScroll(this.options.scroll);this.originalScrollLeft=A.left;this.originalScrollTop=A.top}else{this.originalScrollLeft=this.options.scroll.scrollLeft;this.originalScrollTop=this.options.scroll.scrollTop}}Draggables.notify("onStart",this,B);if(this.options.starteffect){this.options.starteffect(this.element)}},updateDrag:function(event,pointer){if(!this.dragging){this.startDrag(event)}if(!this.options.quiet){Position.prepare();Droppables.show(pointer,this.element)}Draggables.notify("onDrag",this,event);this.draw(pointer);if(this.options.change){this.options.change(this)}if(this.options.scroll){this.stopScrolling();var p;if(this.options.scroll==window){with(this._getWindowScroll(this.options.scroll)){p=[left,top,left+width,top+height]}}else{p=Position.page(this.options.scroll);p[0]+=this.options.scroll.scrollLeft+Position.deltaX;p[1]+=this.options.scroll.scrollTop+Position.deltaY;p.push(p[0]+this.options.scroll.offsetWidth);p.push(p[1]+this.options.scroll.offsetHeight)}var speed=[0,0];if(pointer[0]<(p[0]+this.options.scrollSensitivity)){speed[0]=pointer[0]-(p[0]+this.options.scrollSensitivity)}if(pointer[1]<(p[1]+this.options.scrollSensitivity)){speed[1]=pointer[1]-(p[1]+this.options.scrollSensitivity)}if(pointer[0]>(p[2]-this.options.scrollSensitivity)){speed[0]=pointer[0]-(p[2]-this.options.scrollSensitivity)}if(pointer[1]>(p[3]-this.options.scrollSensitivity)){speed[1]=pointer[1]-(p[3]-this.options.scrollSensitivity)}this.startScrolling(speed)}if(Prototype.Browser.WebKit){window.scrollBy(0,0)}Event.stop(event)},finishDrag:function(B,E){this.dragging=false;if(this.options.quiet){Position.prepare();var D=[Event.pointerX(B),Event.pointerY(B)];Droppables.show(D,this.element)}if(this.options.ghosting){if(!this._originallyAbsolute){Position.relativize(this.element)}delete this._originallyAbsolute;Element.remove(this._clone);this._clone=null}var F=false;if(E){F=Droppables.fire(B,this.element);if(!F){F=false}}if(F&&this.options.onDropped){this.options.onDropped(this.element)}Draggables.notify("onEnd",this,B);var A=this.options.revert;if(A&&Object.isFunction(A)){A=A(this.element)}var C=this.currentDelta();if(A&&this.options.reverteffect){if(F==0||A!="failure"){this.options.reverteffect(this.element,C[1]-this.delta[1],C[0]-this.delta[0])}}else{this.delta=C}if(this.options.zindex){this.element.style.zIndex=this.originalZ}if(this.options.endeffect){this.options.endeffect(this.element)}Draggables.deactivate(this);Droppables.reset()},keyPress:function(A){if(A.keyCode!=Event.KEY_ESC){return }this.finishDrag(A,false);Event.stop(A)},endDrag:function(A){if(!this.dragging){return }this.stopScrolling();this.finishDrag(A,true);Event.stop(A)},draw:function(A){var F=Position.cumulativeOffset(this.element);if(this.options.ghosting){var C=Position.realOffset(this.element);F[0]+=C[0]-Position.deltaX;F[1]+=C[1]-Position.deltaY}var E=this.currentDelta();F[0]-=E[0];F[1]-=E[1];if(this.options.scroll&&(this.options.scroll!=window&&this._isScrollChild)){F[0]-=this.options.scroll.scrollLeft-this.originalScrollLeft;F[1]-=this.options.scroll.scrollTop-this.originalScrollTop}var D=[0,1].map(function(G){return(A[G]-F[G]-this.offset[G])}.bind(this));if(this.options.snap){if(Object.isFunction(this.options.snap)){D=this.options.snap(D[0],D[1],this)}else{if(Object.isArray(this.options.snap)){D=D.map(function(G,H){return(G/this.options.snap[H]).round()*this.options.snap[H]}.bind(this))}else{D=D.map(function(G){return(G/this.options.snap).round()*this.options.snap}.bind(this))}}}var B=this.element.style;if((!this.options.constraint)||(this.options.constraint=="horizontal")){B.left=D[0]+"px"}if((!this.options.constraint)||(this.options.constraint=="vertical")){B.top=D[1]+"px"}if(B.visibility=="hidden"){B.visibility=""}},stopScrolling:function(){if(this.scrollInterval){clearInterval(this.scrollInterval);this.scrollInterval=null;Draggables._lastScrollPointer=null}},startScrolling:function(A){if(!(A[0]||A[1])){return }this.scrollSpeed=[A[0]*this.options.scrollSpeed,A[1]*this.options.scrollSpeed];this.lastScrolled=new Date();this.scrollInterval=setInterval(this.scroll.bind(this),10)},scroll:function(){var current=new Date();var delta=current-this.lastScrolled;this.lastScrolled=current;if(this.options.scroll==window){with(this._getWindowScroll(this.options.scroll)){if(this.scrollSpeed[0]||this.scrollSpeed[1]){var d=delta/1000;this.options.scroll.scrollTo(left+d*this.scrollSpeed[0],top+d*this.scrollSpeed[1])}}}else{this.options.scroll.scrollLeft+=this.scrollSpeed[0]*delta/1000;this.options.scroll.scrollTop+=this.scrollSpeed[1]*delta/1000}Position.prepare();Droppables.show(Draggables._lastPointer,this.element);Draggables.notify("onDrag",this);if(this._isScrollChild){Draggables._lastScrollPointer=Draggables._lastScrollPointer||$A(Draggables._lastPointer);Draggables._lastScrollPointer[0]+=this.scrollSpeed[0]*delta/1000;Draggables._lastScrollPointer[1]+=this.scrollSpeed[1]*delta/1000;if(Draggables._lastScrollPointer[0]<0){Draggables._lastScrollPointer[0]=0}if(Draggables._lastScrollPointer[1]<0){Draggables._lastScrollPointer[1]=0}this.draw(Draggables._lastScrollPointer)}if(this.options.change){this.options.change(this)}},_getWindowScroll:function(w){var T,L,W,H;with(w.document){if(w.document.documentElement&&documentElement.scrollTop){T=documentElement.scrollTop;L=documentElement.scrollLeft}else{if(w.document.body){T=body.scrollTop;L=body.scrollLeft}}if(w.innerWidth){W=w.innerWidth;H=w.innerHeight}else{if(w.document.documentElement&&documentElement.clientWidth){W=documentElement.clientWidth;H=documentElement.clientHeight}else{W=body.offsetWidth;H=body.offsetHeight}}}return{top:T,left:L,width:W,height:H}}});Draggable._dragging={};var SortableObserver=Class.create({initialize:function(B,A){this.element=$(B);this.observer=A;this.lastValue=Sortable.serialize(this.element)},onStart:function(){this.lastValue=Sortable.serialize(this.element)},onEnd:function(){Sortable.unmark();if(this.lastValue!=Sortable.serialize(this.element)){this.observer(this.element)}}});var Sortable={SERIALIZE_RULE:/^[^_\-](?:[A-Za-z0-9\-\_]*)[_](.*)$/,sortables:{},_findRootElement:function(A){while(A.tagName.toUpperCase()!="BODY"){if(A.id&&Sortable.sortables[A.id]){return A}A=A.parentNode}},options:function(A){A=Sortable._findRootElement($(A));if(!A){return }return Sortable.sortables[A.id]},destroy:function(A){A=$(A);var B=Sortable.sortables[A.id];if(B){Draggables.removeObserver(B.element);B.droppables.each(function(C){Droppables.remove(C)});B.draggables.invoke("destroy");delete Sortable.sortables[B.element.id]}},create:function(C){C=$(C);var B=Object.extend({element:C,tag:"li",dropOnEmpty:false,tree:false,treeTag:"ul",overlap:"vertical",constraint:"vertical",containment:C,handle:false,only:false,delay:0,hoverclass:null,ghosting:false,quiet:false,scroll:false,scrollSensitivity:20,scrollSpeed:15,format:this.SERIALIZE_RULE,elements:false,handles:false,onChange:Prototype.emptyFunction,onUpdate:Prototype.emptyFunction},arguments[1]||{});this.destroy(C);var A={revert:true,quiet:B.quiet,scroll:B.scroll,scrollSpeed:B.scrollSpeed,scrollSensitivity:B.scrollSensitivity,delay:B.delay,ghosting:B.ghosting,constraint:B.constraint,handle:B.handle};if(B.starteffect){A.starteffect=B.starteffect}if(B.reverteffect){A.reverteffect=B.reverteffect}else{if(B.ghosting){A.reverteffect=function(F){F.style.top=0;F.style.left=0}}}if(B.endeffect){A.endeffect=B.endeffect}if(B.zindex){A.zindex=B.zindex}var D={overlap:B.overlap,containment:B.containment,tree:B.tree,hoverclass:B.hoverclass,onHover:Sortable.onHover};var E={onHover:Sortable.onEmptyHover,overlap:B.overlap,containment:B.containment,hoverclass:B.hoverclass};Element.cleanWhitespace(C);B.draggables=[];B.droppables=[];if(B.dropOnEmpty||B.tree){Droppables.add(C,E);B.droppables.push(C)}(B.elements||this.findElements(C,B)||[]).each(function(H,F){var G=B.handles?$(B.handles[F]):(B.handle?$(H).select("."+B.handle)[0]:H);B.draggables.push(new Draggable(H,Object.extend(A,{handle:G})));Droppables.add(H,D);if(B.tree){H.treeNode=C}B.droppables.push(H)});if(B.tree){(Sortable.findTreeElements(C,B)||[]).each(function(F){Droppables.add(F,E);F.treeNode=C;B.droppables.push(F)})}this.sortables[C.id]=B;Draggables.addObserver(new SortableObserver(C,B.onUpdate))},findElements:function(B,A){return Element.findChildren(B,A.only,A.tree?true:false,A.tag)},findTreeElements:function(B,A){return Element.findChildren(B,A.only,A.tree?true:false,A.treeTag)},onHover:function(E,D,A){if(Element.isParent(D,E)){return }if(A>0.33&&A<0.66&&Sortable.options(D).tree){return }else{if(A>0.5){Sortable.mark(D,"before");if(D.previousSibling!=E){var B=E.parentNode;E.style.visibility="hidden";D.parentNode.insertBefore(E,D);if(D.parentNode!=B){Sortable.options(B).onChange(E)}Sortable.options(D.parentNode).onChange(E)}}else{Sortable.mark(D,"after");var C=D.nextSibling||null;if(C!=E){var B=E.parentNode;E.style.visibility="hidden";D.parentNode.insertBefore(E,C);if(D.parentNode!=B){Sortable.options(B).onChange(E)}Sortable.options(D.parentNode).onChange(E)}}}},onEmptyHover:function(E,G,H){var I=E.parentNode;var A=Sortable.options(G);if(!Element.isParent(G,E)){var F;var C=Sortable.findElements(G,{tag:A.tag,only:A.only});var B=null;if(C){var D=Element.offsetSize(G,A.overlap)*(1-H);for(F=0;F<C.length;F+=1){if(D-Element.offsetSize(C[F],A.overlap)>=0){D-=Element.offsetSize(C[F],A.overlap)}else{if(D-(Element.offsetSize(C[F],A.overlap)/2)>=0){B=F+1<C.length?C[F+1]:null;break}else{B=C[F];break}}}}G.insertBefore(E,B);Sortable.options(I).onChange(E);A.onChange(E)}},unmark:function(){if(Sortable._marker){Sortable._marker.hide()}},mark:function(B,A){var D=Sortable.options(B.parentNode);if(D&&!D.ghosting){return }if(!Sortable._marker){Sortable._marker=($("dropmarker")||Element.extend(document.createElement("DIV"))).hide().addClassName("dropmarker").setStyle({position:"absolute"});document.getElementsByTagName("body").item(0).appendChild(Sortable._marker)}var C=Position.cumulativeOffset(B);Sortable._marker.setStyle({left:C[0]+"px",top:C[1]+"px"});if(A=="after"){if(D.overlap=="horizontal"){Sortable._marker.setStyle({left:(C[0]+B.clientWidth)+"px"})}else{Sortable._marker.setStyle({top:(C[1]+B.clientHeight)+"px"})}}Sortable._marker.show()},_tree:function(E,B,F){var D=Sortable.findElements(E,B)||[];for(var C=0;C<D.length;++C){var A=D[C].id.match(B.format);if(!A){continue}var G={id:encodeURIComponent(A?A[1]:null),element:E,parent:F,children:[],position:F.children.length,container:$(D[C]).down(B.treeTag)};if(G.container){this._tree(G.container,B,G)}F.children.push(G)}return F},tree:function(D){D=$(D);var C=this.options(D);var B=Object.extend({tag:C.tag,treeTag:C.treeTag,only:C.only,name:D.id,format:C.format},arguments[1]||{});var A={id:null,parent:null,children:[],container:D,position:0};return Sortable._tree(D,B,A)},_constructIndex:function(B){var A="";do{if(B.id){A="["+B.position+"]"+A}}while((B=B.parent)!=null);return A},sequence:function(B){B=$(B);var A=Object.extend(this.options(B),arguments[1]||{});return $(this.findElements(B,A)||[]).map(function(C){return C.id.match(A.format)?C.id.match(A.format)[1]:""})},setSequence:function(B,C){B=$(B);var A=Object.extend(this.options(B),arguments[2]||{});var D={};this.findElements(B,A).each(function(E){if(E.id.match(A.format)){D[E.id.match(A.format)[1]]=[E,E.parentNode]}E.parentNode.removeChild(E)});C.each(function(E){var F=D[E];if(F){F[1].appendChild(F[0]);delete D[E]}})},serialize:function(C){C=$(C);var B=Object.extend(Sortable.options(C),arguments[1]||{});var A=encodeURIComponent((arguments[1]&&arguments[1].name)?arguments[1].name:C.id);if(B.tree){return Sortable.tree(C,arguments[1]).children.map(function(D){return[A+Sortable._constructIndex(D)+"[id]="+encodeURIComponent(D.id)].concat(D.children.map(arguments.callee))}).flatten().join("&")}else{return Sortable.sequence(C,arguments[1]).map(function(D){return A+"[]="+encodeURIComponent(D)}).join("&")}}};Element.isParent=function(B,A){if(!B.parentNode||B==A){return false}if(B.parentNode==A){return true}return Element.isParent(B.parentNode,A)};Element.findChildren=function(D,B,A,C){if(!D.hasChildNodes()){return null}C=C.toUpperCase();if(B){B=[B].flatten()}var E=[];$A(D.childNodes).each(function(G){if(G.tagName&&G.tagName.toUpperCase()==C&&(!B||(Element.classNames(G).detect(function(H){return B.include(H)})))){E.push(G)}if(A){var F=Element.findChildren(G,B,A,C);if(F){E.push(F)}}});return(E.length>0?E.flatten():[])};Element.offsetSize=function(A,B){return A["offset"+((B=="vertical"||B=="height")?"Height":"Width")]};if(typeof Effect=="undefined"){throw ("controls.js requires including script.aculo.us' effects.js library")}var Autocompleter={};Autocompleter.Base=Class.create({baseInitialize:function(B,C,A){B=$(B);this.element=B;this.update=$(C);this.hasFocus=false;this.changed=false;this.active=false;this.index=0;this.entryCount=0;this.oldElementValue=this.element.value;if(this.setOptions){this.setOptions(A)}else{this.options=A||{}}this.options.paramName=this.options.paramName||this.element.name;this.options.tokens=this.options.tokens||[];this.options.frequency=this.options.frequency||0.4;this.options.minChars=this.options.minChars||1;this.options.onShow=this.options.onShow||function(D,E){if(!E.style.position||E.style.position=="absolute"){E.style.position="absolute";Position.clone(D,E,{setHeight:false,offsetTop:D.offsetHeight})}Effect.Appear(E,{duration:0.15})};this.options.onHide=this.options.onHide||function(D,E){new Effect.Fade(E,{duration:0.15})};if(typeof (this.options.tokens)=="string"){this.options.tokens=new Array(this.options.tokens)}if(!this.options.tokens.include("\n")){this.options.tokens.push("\n")}this.observer=null;this.element.setAttribute("autocomplete","off");Element.hide(this.update);Event.observe(this.element,"blur",this.onBlur.bindAsEventListener(this));Event.observe(this.element,"keydown",this.onKeyPress.bindAsEventListener(this))},show:function(){if(Element.getStyle(this.update,"display")=="none"){this.options.onShow(this.element,this.update)}if(!this.iefix&&(Prototype.Browser.IE)&&(Element.getStyle(this.update,"position")=="absolute")){new Insertion.After(this.update,'<iframe id="'+this.update.id+'_iefix" style="display:none;position:absolute;filter:progid:DXImageTransform.Microsoft.Alpha(opacity=0);" src="javascript:false;" frameborder="0" scrolling="no"></iframe>');this.iefix=$(this.update.id+"_iefix")}if(this.iefix){setTimeout(this.fixIEOverlapping.bind(this),50)}},fixIEOverlapping:function(){Position.clone(this.update,this.iefix,{setTop:(!this.update.style.height)});this.iefix.style.zIndex=1;this.update.style.zIndex=2;Element.show(this.iefix)},hide:function(){this.stopIndicator();if(Element.getStyle(this.update,"display")!="none"){this.options.onHide(this.element,this.update)}if(this.iefix){Element.hide(this.iefix)}},startIndicator:function(){if(this.options.indicator){Element.show(this.options.indicator)}},stopIndicator:function(){if(this.options.indicator){Element.hide(this.options.indicator)}},onKeyPress:function(A){if(this.active){switch(A.keyCode){case Event.KEY_TAB:case Event.KEY_RETURN:this.selectEntry();Event.stop(A);case Event.KEY_ESC:this.hide();this.active=false;Event.stop(A);return ;case Event.KEY_LEFT:case Event.KEY_RIGHT:return ;case Event.KEY_UP:this.markPrevious();this.render();Event.stop(A);return ;case Event.KEY_DOWN:this.markNext();this.render();Event.stop(A);return }}else{if(A.keyCode==Event.KEY_TAB||A.keyCode==Event.KEY_RETURN||(Prototype.Browser.WebKit>0&&A.keyCode==0)){return }}this.changed=true;this.hasFocus=true;if(this.observer){clearTimeout(this.observer)}this.observer=setTimeout(this.onObserverEvent.bind(this),this.options.frequency*1000)},activate:function(){this.changed=false;this.hasFocus=true;this.getUpdatedChoices()},onHover:function(B){var A=Event.findElement(B,"LI");if(this.index!=A.autocompleteIndex){this.index=A.autocompleteIndex;this.render()}Event.stop(B)},onClick:function(B){var A=Event.findElement(B,"LI");this.index=A.autocompleteIndex;this.selectEntry();this.hide()},onBlur:function(A){setTimeout(this.hide.bind(this),250);this.hasFocus=false;this.active=false},render:function(){if(this.entryCount>0){for(var A=0;A<this.entryCount;A++){this.index==A?Element.addClassName(this.getEntry(A),"selected"):Element.removeClassName(this.getEntry(A),"selected")}if(this.hasFocus){this.show();this.active=true}}else{this.active=false;this.hide()}},markPrevious:function(){if(this.index>0){this.index--}else{this.index=this.entryCount-1}this.getEntry(this.index).scrollIntoView(true)},markNext:function(){if(this.index<this.entryCount-1){this.index++}else{this.index=0}this.getEntry(this.index).scrollIntoView(false)},getEntry:function(A){return this.update.firstChild.childNodes[A]},getCurrentEntry:function(){return this.getEntry(this.index)},selectEntry:function(){this.active=false;this.updateElement(this.getCurrentEntry())},updateElement:function(F){if(this.options.updateElement){this.options.updateElement(F);return }var D="";if(this.options.select){var A=$(F).select("."+this.options.select)||[];if(A.length>0){D=Element.collectTextNodes(A[0],this.options.select)}}else{D=Element.collectTextNodesIgnoreClass(F,"informal")}var C=this.getTokenBounds();if(C[0]!=-1){var E=this.element.value.substr(0,C[0]);var B=this.element.value.substr(C[0]).match(/^\s+/);if(B){E+=B[0]}this.element.value=E+D+this.element.value.substr(C[1])}else{this.element.value=D}this.oldElementValue=this.element.value;this.element.focus();if(this.options.afterUpdateElement){this.options.afterUpdateElement(this.element,F)}},updateChoices:function(C){if(!this.changed&&this.hasFocus){this.update.innerHTML=C;Element.cleanWhitespace(this.update);Element.cleanWhitespace(this.update.down());if(this.update.firstChild&&this.update.down().childNodes){this.entryCount=this.update.down().childNodes.length;for(var A=0;A<this.entryCount;A++){var B=this.getEntry(A);B.autocompleteIndex=A;this.addObservers(B)}}else{this.entryCount=0}this.stopIndicator();this.index=0;if(this.entryCount==1&&this.options.autoSelect){this.selectEntry();this.hide()}else{this.render()}}},addObservers:function(A){Event.observe(A,"mouseover",this.onHover.bindAsEventListener(this));Event.observe(A,"click",this.onClick.bindAsEventListener(this))},onObserverEvent:function(){this.changed=false;this.tokenBounds=null;if(this.getToken().length>=this.options.minChars){this.getUpdatedChoices()}else{this.active=false;this.hide()}this.oldElementValue=this.element.value},getToken:function(){var A=this.getTokenBounds();return this.element.value.substring(A[0],A[1]).strip()},getTokenBounds:function(){if(null!=this.tokenBounds){return this.tokenBounds}var E=this.element.value;if(E.strip().empty()){return[-1,0]}var F=arguments.callee.getFirstDifferencePos(E,this.oldElementValue);var H=(F==this.oldElementValue.length?1:0);var D=-1,C=E.length;var G;for(var B=0,A=this.options.tokens.length;B<A;++B){G=E.lastIndexOf(this.options.tokens[B],F+H-1);if(G>D){D=G}G=E.indexOf(this.options.tokens[B],F+H);if(-1!=G&&G<C){C=G}}return(this.tokenBounds=[D+1,C])}});Autocompleter.Base.prototype.getTokenBounds.getFirstDifferencePos=function(C,A){var D=Math.min(C.length,A.length);for(var B=0;B<D;++B){if(C[B]!=A[B]){return B}}return D};Ajax.Autocompleter=Class.create(Autocompleter.Base,{initialize:function(C,D,B,A){this.baseInitialize(C,D,A);this.options.asynchronous=true;this.options.onComplete=this.onComplete.bind(this);this.options.defaultParams=this.options.parameters||null;this.url=B},getUpdatedChoices:function(){this.startIndicator();var A=encodeURIComponent(this.options.paramName)+"="+encodeURIComponent(this.getToken());this.options.parameters=this.options.callback?this.options.callback(this.element,A):A;if(this.options.defaultParams){this.options.parameters+="&"+this.options.defaultParams}new Ajax.Request(this.url,this.options)},onComplete:function(A){this.updateChoices(A.responseText)}});Autocompleter.Local=Class.create(Autocompleter.Base,{initialize:function(B,D,C,A){this.baseInitialize(B,D,A);this.options.array=C},getUpdatedChoices:function(){this.updateChoices(this.options.selector(this))},setOptions:function(A){this.options=Object.extend({choices:10,partialSearch:true,partialChars:2,ignoreCase:true,fullSearch:false,selector:function(B){var D=[];var C=[];var H=B.getToken();var G=0;for(var E=0;E<B.options.array.length&&D.length<B.options.choices;E++){var F=B.options.array[E];var I=B.options.ignoreCase?F.toLowerCase().indexOf(H.toLowerCase()):F.indexOf(H);while(I!=-1){if(I==0&&F.length!=H.length){D.push("<li><strong>"+F.substr(0,H.length)+"</strong>"+F.substr(H.length)+"</li>");break}else{if(H.length>=B.options.partialChars&&B.options.partialSearch&&I!=-1){if(B.options.fullSearch||/\s/.test(F.substr(I-1,1))){C.push("<li>"+F.substr(0,I)+"<strong>"+F.substr(I,H.length)+"</strong>"+F.substr(I+H.length)+"</li>");break}}}I=B.options.ignoreCase?F.toLowerCase().indexOf(H.toLowerCase(),I+1):F.indexOf(H,I+1)}}if(C.length){D=D.concat(C.slice(0,B.options.choices-D.length))}return"<ul>"+D.join("")+"</ul>"}},A||{})}});Field.scrollFreeActivate=function(A){setTimeout(function(){Field.activate(A)},1)};Ajax.InPlaceEditor=Class.create({initialize:function(C,B,A){this.url=B;this.element=C=$(C);this.prepareOptions();this._controls={};arguments.callee.dealWithDeprecatedOptions(A);Object.extend(this.options,A||{});if(!this.options.formId&&this.element.id){this.options.formId=this.element.id+"-inplaceeditor";if($(this.options.formId)){this.options.formId=""}}if(this.options.externalControl){this.options.externalControl=$(this.options.externalControl)}if(!this.options.externalControl){this.options.externalControlOnly=false}this._originalBackground=this.element.getStyle("background-color")||"transparent";this.element.title=this.options.clickToEditText;this._boundCancelHandler=this.handleFormCancellation.bind(this);this._boundComplete=(this.options.onComplete||Prototype.emptyFunction).bind(this);this._boundFailureHandler=this.handleAJAXFailure.bind(this);this._boundSubmitHandler=this.handleFormSubmission.bind(this);this._boundWrapperHandler=this.wrapUp.bind(this);this.registerListeners()},checkForEscapeOrReturn:function(A){if(!this._editing||A.ctrlKey||A.altKey||A.shiftKey){return }if(Event.KEY_ESC==A.keyCode){this.handleFormCancellation(A)}else{if(Event.KEY_RETURN==A.keyCode){this.handleFormSubmission(A)}}},createControl:function(G,C,B){var E=this.options[G+"Control"];var F=this.options[G+"Text"];if("button"==E){var A=document.createElement("input");A.type="submit";A.value=F;A.className="editor_"+G+"_button";if("cancel"==G){A.onclick=this._boundCancelHandler}this._form.appendChild(A);this._controls[G]=A}else{if("link"==E){var D=document.createElement("a");D.href="#";D.appendChild(document.createTextNode(F));D.onclick="cancel"==G?this._boundCancelHandler:this._boundSubmitHandler;D.className="editor_"+G+"_link";if(B){D.className+=" "+B}this._form.appendChild(D);this._controls[G]=D}}},createEditField:function(){var C=(this.options.loadTextURL?this.options.loadingText:this.getText());var B;if(1>=this.options.rows&&!/\r|\n/.test(this.getText())){B=document.createElement("input");B.type="text";var A=this.options.size||this.options.cols||0;if(0<A){B.size=A}}else{B=document.createElement("textarea");B.rows=(1>=this.options.rows?this.options.autoRows:this.options.rows);B.cols=this.options.cols||40}B.name=this.options.paramName;B.value=C;B.className="editor_field";if(this.options.submitOnBlur){B.onblur=this._boundSubmitHandler}this._controls.editor=B;if(this.options.loadTextURL){this.loadExternalText()}this._form.appendChild(this._controls.editor)},createForm:function(){var B=this;function A(D,E){var C=B.options["text"+D+"Controls"];if(!C||E===false){return }B._form.appendChild(document.createTextNode(C))}this._form=$(document.createElement("form"));this._form.id=this.options.formId;this._form.addClassName(this.options.formClassName);this._form.onsubmit=this._boundSubmitHandler;this.createEditField();if("textarea"==this._controls.editor.tagName.toLowerCase()){this._form.appendChild(document.createElement("br"))}if(this.options.onFormCustomization){this.options.onFormCustomization(this,this._form)}A("Before",this.options.okControl||this.options.cancelControl);this.createControl("ok",this._boundSubmitHandler);A("Between",this.options.okControl&&this.options.cancelControl);this.createControl("cancel",this._boundCancelHandler,"editor_cancel");A("After",this.options.okControl||this.options.cancelControl)},destroy:function(){if(this._oldInnerHTML){this.element.innerHTML=this._oldInnerHTML}this.leaveEditMode();this.unregisterListeners()},enterEditMode:function(A){if(this._saving||this._editing){return }this._editing=true;this.triggerCallback("onEnterEditMode");if(this.options.externalControl){this.options.externalControl.hide()}this.element.hide();this.createForm();this.element.parentNode.insertBefore(this._form,this.element);if(!this.options.loadTextURL){this.postProcessEditField()}if(A){Event.stop(A)}},enterHover:function(A){if(this.options.hoverClassName){this.element.addClassName(this.options.hoverClassName)}if(this._saving){return }this.triggerCallback("onEnterHover")},getText:function(){return this.element.innerHTML.unescapeHTML()},handleAJAXFailure:function(A){this.triggerCallback("onFailure",A);if(this._oldInnerHTML){this.element.innerHTML=this._oldInnerHTML;this._oldInnerHTML=null}},handleFormCancellation:function(A){this.wrapUp();if(A){Event.stop(A)}},handleFormSubmission:function(D){var B=this._form;var C=$F(this._controls.editor);this.prepareSubmission();var E=this.options.callback(B,C)||"";if(Object.isString(E)){E=E.toQueryParams()}E.editorId=this.element.id;if(this.options.htmlResponse){var A=Object.extend({evalScripts:true},this.options.ajaxOptions);Object.extend(A,{parameters:E,onComplete:this._boundWrapperHandler,onFailure:this._boundFailureHandler});new Ajax.Updater({success:this.element},this.url,A)}else{var A=Object.extend({method:"get"},this.options.ajaxOptions);Object.extend(A,{parameters:E,onComplete:this._boundWrapperHandler,onFailure:this._boundFailureHandler});new Ajax.Request(this.url,A)}if(D){Event.stop(D)}},leaveEditMode:function(){this.element.removeClassName(this.options.savingClassName);this.removeForm();this.leaveHover();this.element.style.backgroundColor=this._originalBackground;this.element.show();if(this.options.externalControl){this.options.externalControl.show()}this._saving=false;this._editing=false;this._oldInnerHTML=null;this.triggerCallback("onLeaveEditMode")},leaveHover:function(A){if(this.options.hoverClassName){this.element.removeClassName(this.options.hoverClassName)}if(this._saving){return }this.triggerCallback("onLeaveHover")},loadExternalText:function(){this._form.addClassName(this.options.loadingClassName);this._controls.editor.disabled=true;var A=Object.extend({method:"get"},this.options.ajaxOptions);Object.extend(A,{parameters:"editorId="+encodeURIComponent(this.element.id),onComplete:Prototype.emptyFunction,onSuccess:function(C){this._form.removeClassName(this.options.loadingClassName);var B=C.responseText;if(this.options.stripLoadedTextTags){B=B.stripTags()}this._controls.editor.value=B;this._controls.editor.disabled=false;this.postProcessEditField()}.bind(this),onFailure:this._boundFailureHandler});new Ajax.Request(this.options.loadTextURL,A)},postProcessEditField:function(){var A=this.options.fieldPostCreation;if(A){$(this._controls.editor)["focus"==A?"focus":"activate"]()}},prepareOptions:function(){this.options=Object.clone(Ajax.InPlaceEditor.DefaultOptions);Object.extend(this.options,Ajax.InPlaceEditor.DefaultCallbacks);[this._extraDefaultOptions].flatten().compact().each(function(A){Object.extend(this.options,A)}.bind(this))},prepareSubmission:function(){this._saving=true;this.removeForm();this.leaveHover();this.showSaving()},registerListeners:function(){this._listeners={};var A;$H(Ajax.InPlaceEditor.Listeners).each(function(B){A=this[B.value].bind(this);this._listeners[B.key]=A;if(!this.options.externalControlOnly){this.element.observe(B.key,A)}if(this.options.externalControl){this.options.externalControl.observe(B.key,A)}}.bind(this))},removeForm:function(){if(!this._form){return }this._form.remove();this._form=null;this._controls={}},showSaving:function(){this._oldInnerHTML=this.element.innerHTML;this.element.innerHTML=this.options.savingText;this.element.addClassName(this.options.savingClassName);this.element.style.backgroundColor=this._originalBackground;this.element.show()},triggerCallback:function(B,A){if("function"==typeof this.options[B]){this.options[B](this,A)}},unregisterListeners:function(){$H(this._listeners).each(function(A){if(!this.options.externalControlOnly){this.element.stopObserving(A.key,A.value)}if(this.options.externalControl){this.options.externalControl.stopObserving(A.key,A.value)}}.bind(this))},wrapUp:function(A){this.leaveEditMode();this._boundComplete(A,this.element)}});Object.extend(Ajax.InPlaceEditor.prototype,{dispose:Ajax.InPlaceEditor.prototype.destroy});Ajax.InPlaceCollectionEditor=Class.create(Ajax.InPlaceEditor,{initialize:function($super,C,B,A){this._extraDefaultOptions=Ajax.InPlaceCollectionEditor.DefaultOptions;$super(C,B,A)},createEditField:function(){var A=document.createElement("select");A.name=this.options.paramName;A.size=1;this._controls.editor=A;this._collection=this.options.collection||[];if(this.options.loadCollectionURL){this.loadCollection()}else{this.checkForExternalText()}this._form.appendChild(this._controls.editor)},loadCollection:function(){this._form.addClassName(this.options.loadingClassName);this.showLoadingText(this.options.loadingCollectionText);var options=Object.extend({method:"get"},this.options.ajaxOptions);Object.extend(options,{parameters:"editorId="+encodeURIComponent(this.element.id),onComplete:Prototype.emptyFunction,onSuccess:function(transport){var js=transport.responseText.strip();if(!/^\[.*\]$/.test(js)){throw ("Server returned an invalid collection representation.")}this._collection=eval(js);this.checkForExternalText()}.bind(this),onFailure:this.onFailure});new Ajax.Request(this.options.loadCollectionURL,options)},showLoadingText:function(B){this._controls.editor.disabled=true;var A=this._controls.editor.firstChild;if(!A){A=document.createElement("option");A.value="";this._controls.editor.appendChild(A);A.selected=true}A.update((B||"").stripScripts().stripTags())},checkForExternalText:function(){this._text=this.getText();if(this.options.loadTextURL){this.loadExternalText()}else{this.buildOptionList()}},loadExternalText:function(){this.showLoadingText(this.options.loadingText);var A=Object.extend({method:"get"},this.options.ajaxOptions);Object.extend(A,{parameters:"editorId="+encodeURIComponent(this.element.id),onComplete:Prototype.emptyFunction,onSuccess:function(B){this._text=B.responseText.strip();this.buildOptionList()}.bind(this),onFailure:this.onFailure});new Ajax.Request(this.options.loadTextURL,A)},buildOptionList:function(){this._form.removeClassName(this.options.loadingClassName);this._collection=this._collection.map(function(D){return 2===D.length?D:[D,D].flatten()});var B=("value" in this.options)?this.options.value:this._text;var A=this._collection.any(function(D){return D[0]==B}.bind(this));this._controls.editor.update("");var C;this._collection.each(function(E,D){C=document.createElement("option");C.value=E[0];C.selected=A?E[0]==B:0==D;C.appendChild(document.createTextNode(E[1]));this._controls.editor.appendChild(C)}.bind(this));this._controls.editor.disabled=false;Field.scrollFreeActivate(this._controls.editor)}});Ajax.InPlaceEditor.prototype.initialize.dealWithDeprecatedOptions=function(A){if(!A){return }function B(C,D){if(C in A||D===undefined){return }A[C]=D}B("cancelControl",(A.cancelLink?"link":(A.cancelButton?"button":A.cancelLink==A.cancelButton==false?false:undefined)));B("okControl",(A.okLink?"link":(A.okButton?"button":A.okLink==A.okButton==false?false:undefined)));B("highlightColor",A.highlightcolor);B("highlightEndColor",A.highlightendcolor)};Object.extend(Ajax.InPlaceEditor,{DefaultOptions:{ajaxOptions:{},autoRows:3,cancelControl:"link",cancelText:"cancel",clickToEditText:"Click to edit",externalControl:null,externalControlOnly:false,fieldPostCreation:"activate",formClassName:"inplaceeditor-form",formId:null,highlightColor:"#ffff99",highlightEndColor:"#ffffff",hoverClassName:"",htmlResponse:true,loadingClassName:"inplaceeditor-loading",loadingText:"Loading...",okControl:"button",okText:"ok",paramName:"value",rows:1,savingClassName:"inplaceeditor-saving",savingText:"Saving...",size:0,stripLoadedTextTags:false,submitOnBlur:false,textAfterControls:"",textBeforeControls:"",textBetweenControls:""},DefaultCallbacks:{callback:function(A){return Form.serialize(A)},onComplete:function(B,A){new Effect.Highlight(A,{startcolor:this.options.highlightColor,keepBackgroundImage:true})},onEnterEditMode:null,onEnterHover:function(A){A.element.style.backgroundColor=A.options.highlightColor;if(A._effect){A._effect.cancel()}},onFailure:function(B,A){alert("Error communication with the server: "+B.responseText.stripTags())},onFormCustomization:null,onLeaveEditMode:null,onLeaveHover:function(A){A._effect=new Effect.Highlight(A.element,{startcolor:A.options.highlightColor,endcolor:A.options.highlightEndColor,restorecolor:A._originalBackground,keepBackgroundImage:true})}},Listeners:{click:"enterEditMode",keydown:"checkForEscapeOrReturn",mouseover:"enterHover",mouseout:"leaveHover"}});Ajax.InPlaceCollectionEditor.DefaultOptions={loadingCollectionText:"Loading options..."};Form.Element.DelayedObserver=Class.create({initialize:function(B,A,C){this.delay=A||0.5;this.element=$(B);this.callback=C;this.timer=null;this.lastValue=$F(this.element);Event.observe(this.element,"keyup",this.delayedListener.bindAsEventListener(this))},delayedListener:function(A){if(this.lastValue==$F(this.element)){return }if(this.timer){clearTimeout(this.timer)}this.timer=setTimeout(this.onTimerEvent.bind(this),this.delay*1000);this.lastValue=$F(this.element)},onTimerEvent:function(){this.timer=null;this.callback(this.element,$F(this.element))}});if(!Control){var Control={}}Control.Slider=Class.create({initialize:function(D,A,B){var C=this;if(Object.isArray(D)){this.handles=D.collect(function(E){return $(E)})}else{this.handles=[$(D)]}this.track=$(A);this.options=B||{};this.axis=this.options.axis||"horizontal";this.increment=this.options.increment||1;this.step=parseInt(this.options.step||"1");this.range=this.options.range||$R(0,1);this.value=0;this.values=this.handles.map(function(){return 0});this.spans=this.options.spans?this.options.spans.map(function(E){return $(E)}):false;this.options.startSpan=$(this.options.startSpan||null);this.options.endSpan=$(this.options.endSpan||null);this.restricted=this.options.restricted||false;this.maximum=this.options.maximum||this.range.end;this.minimum=this.options.minimum||this.range.start;this.alignX=parseInt(this.options.alignX||"0");this.alignY=parseInt(this.options.alignY||"0");this.trackLength=this.maximumOffset()-this.minimumOffset();this.handleLength=this.isVertical()?(this.handles[0].offsetHeight!=0?this.handles[0].offsetHeight:this.handles[0].style.height.replace(/px$/,"")):(this.handles[0].offsetWidth!=0?this.handles[0].offsetWidth:this.handles[0].style.width.replace(/px$/,""));this.active=false;this.dragging=false;this.disabled=false;if(this.options.disabled){this.setDisabled()}this.allowedValues=this.options.values?this.options.values.sortBy(Prototype.K):false;if(this.allowedValues){this.minimum=this.allowedValues.min();this.maximum=this.allowedValues.max()}this.eventMouseDown=this.startDrag.bindAsEventListener(this);this.eventMouseUp=this.endDrag.bindAsEventListener(this);this.eventMouseMove=this.update.bindAsEventListener(this);this.handles.each(function(F,E){E=C.handles.length-1-E;C.setValue(parseFloat((Object.isArray(C.options.sliderValue)?C.options.sliderValue[E]:C.options.sliderValue)||C.range.start),E);F.makePositioned().observe("mousedown",C.eventMouseDown)});this.track.observe("mousedown",this.eventMouseDown);document.observe("mouseup",this.eventMouseUp);document.observe("mousemove",this.eventMouseMove);this.initialized=true},dispose:function(){var A=this;Event.stopObserving(this.track,"mousedown",this.eventMouseDown);Event.stopObserving(document,"mouseup",this.eventMouseUp);Event.stopObserving(document,"mousemove",this.eventMouseMove);this.handles.each(function(B){Event.stopObserving(B,"mousedown",A.eventMouseDown)})},setDisabled:function(){this.disabled=true},setEnabled:function(){this.disabled=false},getNearestValue:function(A){if(this.allowedValues){if(A>=this.allowedValues.max()){return(this.allowedValues.max())}if(A<=this.allowedValues.min()){return(this.allowedValues.min())}var C=Math.abs(this.allowedValues[0]-A);var B=this.allowedValues[0];this.allowedValues.each(function(D){var E=Math.abs(D-A);if(E<=C){B=D;C=E}});return B}if(A>this.range.end){return this.range.end}if(A<this.range.start){return this.range.start}return A},setValue:function(B,A){if(!this.active){this.activeHandleIdx=A||0;this.activeHandle=this.handles[this.activeHandleIdx];this.updateStyles()}A=A||this.activeHandleIdx||0;if(this.initialized&&this.restricted){if((A>0)&&(B<this.values[A-1])){B=this.values[A-1]}if((A<(this.handles.length-1))&&(B>this.values[A+1])){B=this.values[A+1]}}B=this.getNearestValue(B);this.values[A]=B;this.value=this.values[0];this.handles[A].style[this.isVertical()?"top":"left"]=this.translateToPx(B);this.drawSpans();if(!this.dragging||!this.event){this.updateFinished()}},setValueBy:function(B,A){this.setValue(this.values[A||this.activeHandleIdx||0]+B,A||this.activeHandleIdx||0)},translateToPx:function(A){return Math.round(((this.trackLength-this.handleLength)/(this.range.end-this.range.start))*(A-this.range.start))+"px"},translateToValue:function(A){return((A/(this.trackLength-this.handleLength)*(this.range.end-this.range.start))+this.range.start)},getRange:function(B){var A=this.values.sortBy(Prototype.K);B=B||0;return $R(A[B],A[B+1])},minimumOffset:function(){return(this.isVertical()?this.alignY:this.alignX)},maximumOffset:function(){return(this.isVertical()?(this.track.offsetHeight!=0?this.track.offsetHeight:this.track.style.height.replace(/px$/,""))-this.alignY:(this.track.offsetWidth!=0?this.track.offsetWidth:this.track.style.width.replace(/px$/,""))-this.alignX)},isVertical:function(){return(this.axis=="vertical")},drawSpans:function(){var A=this;if(this.spans){$R(0,this.spans.length-1).each(function(B){A.setSpan(A.spans[B],A.getRange(B))})}if(this.options.startSpan){this.setSpan(this.options.startSpan,$R(0,this.values.length>1?this.getRange(0).min():this.value))}if(this.options.endSpan){this.setSpan(this.options.endSpan,$R(this.values.length>1?this.getRange(this.spans.length-1).max():this.value,this.maximum))}},setSpan:function(B,A){if(this.isVertical()){B.style.top=this.translateToPx(A.start);B.style.height=this.translateToPx(A.end-A.start+this.range.start)}else{B.style.left=this.translateToPx(A.start);B.style.width=this.translateToPx(A.end-A.start+this.range.start)}},updateStyles:function(){this.handles.each(function(A){Element.removeClassName(A,"selected")});Element.addClassName(this.activeHandle,"selected")},startDrag:function(C){if(Event.isLeftClick(C)){if(!this.disabled){this.active=true;var D=Event.element(C);var E=[Event.pointerX(C),Event.pointerY(C)];var A=D;if(A==this.track){var B=Position.cumulativeOffset(this.track);this.event=C;this.setValue(this.translateToValue((this.isVertical()?E[1]-B[1]:E[0]-B[0])-(this.handleLength/2)));var B=Position.cumulativeOffset(this.activeHandle);this.offsetX=(E[0]-B[0]);this.offsetY=(E[1]-B[1])}else{while((this.handles.indexOf(D)==-1)&&D.parentNode){D=D.parentNode}if(this.handles.indexOf(D)!=-1){this.activeHandle=D;this.activeHandleIdx=this.handles.indexOf(this.activeHandle);this.updateStyles();var B=Position.cumulativeOffset(this.activeHandle);this.offsetX=(E[0]-B[0]);this.offsetY=(E[1]-B[1])}}}Event.stop(C)}},update:function(A){if(this.active){if(!this.dragging){this.dragging=true}this.draw(A);if(Prototype.Browser.WebKit){window.scrollBy(0,0)}Event.stop(A)}},draw:function(B){var C=[Event.pointerX(B),Event.pointerY(B)];var A=Position.cumulativeOffset(this.track);C[0]-=this.offsetX+A[0];C[1]-=this.offsetY+A[1];this.event=B;this.setValue(this.translateToValue(this.isVertical()?C[1]:C[0]));if(this.initialized&&this.options.onSlide){this.options.onSlide(this.values.length>1?this.values:this.value,this)}},endDrag:function(A){if(this.active&&this.dragging){this.finishDrag(A,true);Event.stop(A)}this.active=false;this.dragging=false},finishDrag:function(A,B){this.active=false;this.dragging=false;this.updateFinished()},updateFinished:function(){if(this.initialized&&this.options.onChange){this.options.onChange(this.values.length>1?this.values:this.value,this)}this.event=null}});Sound={tracks:{},_enabled:true,template:new Template('<embed style="height:0" id="sound_#{track}_#{id}" src="#{url}" loop="false" autostart="true" hidden="true"/>'),enable:function(){Sound._enabled=true},disable:function(){Sound._enabled=false},play:function(B){if(!Sound._enabled){return }var A=Object.extend({track:"global",url:B,replace:false},arguments[1]||{});if(A.replace&&this.tracks[A.track]){$R(0,this.tracks[A.track].id).each(function(D){var C=$("sound_"+A.track+"_"+D);C.Stop&&C.Stop();C.remove()});this.tracks[A.track]=null}if(!this.tracks[A.track]){this.tracks[A.track]={id:0}}else{this.tracks[A.track].id++}A.id=this.tracks[A.track].id;$$("body")[0].insert(Prototype.Browser.IE?new Element("bgsound",{id:"sound_"+A.track+"_"+A.id,src:A.url,loop:1,autostart:true}):Sound.template.evaluate(A))}};if(Prototype.Browser.Gecko&&navigator.userAgent.indexOf("Win")>0){if(navigator.plugins&&$A(navigator.plugins).detect(function(A){return A.name.indexOf("QuickTime")!=-1})){Sound.template=new Template('<object id="sound_#{track}_#{id}" width="0" height="0" type="audio/mpeg" data="#{url}"/>')}else{Sound.play=function(){}}};
/**
* DD_roundies, this adds rounded-corner CSS in standard browsers and VML sublayers in IE that accomplish a similar appearance when comparing said browsers.
* Author: Drew Diller
* Email: drew.diller@gmail.com
* URL: http://www.dillerdesign.com/experiment/DD_roundies/
* Version: 0.0.2a
* Licensed under the MIT License: http://dillerdesign.com/experiment/DD_roundies/#license
*
* Usage:
* DD_roundies.addRule('#doc .container', '10px 5px'); // selector and multiple radii
* DD_roundies.addRule('.box', 5, true); // selector, radius, and optional addition of border-radius code for standard browsers.
* 
* Just want the PNG fixing effect for IE6, and don't want to also use the DD_belatedPNG library?  Don't give any additional arguments after the CSS selector.
* DD_roundies.addRule('.your .example img');
**/

var DD_roundies = {

    ns: 'DD_roundies',

    IE6: false,
    IE7: false,
    IE8: false,
    IEversion: function() {
        if (document.documentMode != 8 && document.namespaces && !document.namespaces[this.ns]) {
            this.IE6 = true;
            this.IE7 = true;
        }
        else if (document.documentMode == 8) {
            this.IE8 = true;
        }
    },
    querySelector: document.querySelectorAll,
    selectorsToProcess: [],
    imgSize: {},

    createVmlNameSpace: function() { /* enable VML */
        if (this.IE6 || this.IE7) {
            document.namespaces.add(this.ns, 'urn:schemas-microsoft-com:vml');
        }
        if (this.IE8) {
            document.writeln('<?import namespace="' + this.ns + '" implementation="#default#VML" ?>');
        }
    },

    createVmlStyleSheet: function() { /* style VML, enable behaviors */
        /*
        Just in case lots of other developers have added
        lots of other stylesheets using document.createStyleSheet
        and hit the 31-limit mark, let's not use that method!
        further reading: http://msdn.microsoft.com/en-us/library/ms531194(VS.85).aspx
        */
        var style = document.createElement('style');
        document.documentElement.firstChild.insertBefore(style, document.documentElement.firstChild.firstChild);
        if (style.styleSheet) { /* IE */
            try {
                var styleSheet = style.styleSheet;
                styleSheet.addRule(this.ns + '\\:*', '{behavior:url(#default#VML)}');
                this.styleSheet = styleSheet;
            } catch (err) { }
        }
        else {
            this.styleSheet = style;
        }
    },

    /**
    * Method to use from afar - refer to it whenever.
    * Example for IE only: DD_roundies.addRule('div.boxy_box', '10px 5px');
    * Example for IE, Firefox, and WebKit: DD_roundies.addRule('div.boxy_box', '10px 5px', true);
    * @param {String} selector - REQUIRED - a CSS selector, such as '#doc .container'
    * @param {Integer} radius - REQUIRED - the desired radius for the box corners
    * @param {Boolean} standards - OPTIONAL - true if you also wish to output -moz-border-radius/-webkit-border-radius/border-radius declarations
    **/
    addRule: function(selector, rad, standards) {
        if (typeof rad == 'undefined' || rad === null) {
            rad = 0;
        }
        if (rad.constructor.toString().search('Array') == -1) {
            rad = rad.toString().replace(/[^0-9 ]/g, '').split(' ');
        }
        for (var i = 0; i < 4; i++) {
            rad[i] = (!rad[i] && rad[i] !== 0) ? rad[Math.max((i - 2), 0)] : rad[i];
        }
        if (this.styleSheet) {
            if (this.styleSheet.addRule) { /* IE */
                var selectors = selector.split(','); /* multiple selectors supported, no need for multiple calls to this anymore */
                for (var i = 0; i < selectors.length; i++) {
                    this.styleSheet.addRule(selectors[i], 'behavior:expression(DD_roundies.roundify.call(this, [' + rad.join(',') + ']))'); /* seems to execute the function without adding it to the stylesheet - interesting... */
                }
            }
            else if (standards) {
                var moz_implementation = rad.join('px ') + 'px';
                this.styleSheet.appendChild(document.createTextNode(selector + ' {border-radius:' + moz_implementation + '; -moz-border-radius:' + moz_implementation + ';}'));
                this.styleSheet.appendChild(document.createTextNode(selector + ' {-webkit-border-top-left-radius:' + rad[0] + 'px ' + rad[0] + 'px; -webkit-border-top-right-radius:' + rad[1] + 'px ' + rad[1] + 'px; -webkit-border-bottom-right-radius:' + rad[2] + 'px ' + rad[2] + 'px; -webkit-border-bottom-left-radius:' + rad[3] + 'px ' + rad[3] + 'px;}'));
            }
        }
        else if (this.IE8) {
            this.selectorsToProcess.push({ 'selector': selector, 'radii': rad });
        }
    },

    readPropertyChanges: function(el) {
        switch (event.propertyName) {
            case 'style.border':
            case 'style.borderWidth':
            case 'style.padding':
                this.applyVML(el);
                break;
            case 'style.borderColor':
                this.vmlStrokeColor(el);
                break;
            case 'style.backgroundColor':
            case 'style.backgroundPosition':
            case 'style.backgroundRepeat':
                this.applyVML(el);
                break;
            case 'style.display':
                el.vmlBox.style.display = (el.style.display == 'none') ? 'none' : 'block';
                break;
            case 'style.filter':
                this.vmlOpacity(el);
                break;
            case 'style.zIndex':
                el.vmlBox.style.zIndex = el.style.zIndex;
                break;
            case 'className':
                el.vmlBox.style.zIndex = el.style.zIndex;
                this.applyVML(el);
                break;
        }
    },

    applyVML: function(el) {
        el.runtimeStyle.cssText = '';
        this.vmlFill(el);
        this.vmlStrokeColor(el);
        this.vmlStrokeWeight(el);
        this.vmlOffsets(el);
        this.vmlPath(el);
        this.nixBorder(el);
        this.vmlOpacity(el);
    },

    vmlOpacity: function(el) {
        if (el.currentStyle.filter.search('lpha') != -1) {
            var trans = el.currentStyle.filter;
            trans = parseInt(trans.substring(trans.lastIndexOf('=') + 1, trans.lastIndexOf(')')), 10) / 100;
            for (var v in el.vml) {
                el.vml[v].filler.opacity = trans;
            }
        }
    },

    vmlFill: function(el) {
        if (!el.currentStyle) {
            return;
        } else {
            var elStyle = el.currentStyle;
        }
        el.runtimeStyle.backgroundColor = '';
        el.runtimeStyle.backgroundImage = '';
        var noColor = (elStyle.backgroundColor == 'transparent');
        var noImg = true;
        if (elStyle.backgroundImage != 'none' || el.isImg) {
            if (!el.isImg) {
                el.vmlBg = elStyle.backgroundImage;
                el.vmlBg = el.vmlBg.substr(5, el.vmlBg.lastIndexOf('")') - 5);
            }
            else {
                el.vmlBg = el.src;
            }
            var lib = this;
            if (!lib.imgSize[el.vmlBg]) { /* determine size of loaded image */
                var img = document.createElement('img');
                img.attachEvent('onload', function() {
                    this.width = this.offsetWidth; /* weird cache-busting requirement! */
                    this.height = this.offsetHeight;
                    lib.vmlOffsets(el);
                });
                img.className = lib.ns + '_sizeFinder';
                img.runtimeStyle.cssText = 'behavior:none; position:absolute; top:-10000px; left:-10000px; border:none;'; /* make sure to set behavior to none to prevent accidental matching of the helper elements! */
                img.src = el.vmlBg;
                img.removeAttribute('width');
                img.removeAttribute('height');
                document.body.insertBefore(img, document.body.firstChild);
                lib.imgSize[el.vmlBg] = img;
            }
            el.vml.image.filler.src = el.vmlBg;
            noImg = false;
        }
        el.vml.image.filled = !noImg;
        el.vml.image.fillcolor = 'none';
        el.vml.color.filled = !noColor;
        el.vml.color.fillcolor = elStyle.backgroundColor;
        el.runtimeStyle.backgroundImage = 'none';
        el.runtimeStyle.backgroundColor = 'transparent';
    },

    vmlStrokeColor: function(el) {
        el.vml.stroke.fillcolor = el.currentStyle.borderColor;
    },

    vmlStrokeWeight: function(el) {
        var borders = ['Top', 'Right', 'Bottom', 'Left'];
        el.bW = {};
        for (var b = 0; b < 4; b++) {
            el.bW[borders[b]] = parseInt(el.currentStyle['border' + borders[b] + 'Width'], 10) || 0;
        }
    },

    vmlOffsets: function(el) {
        var dims = ['Left', 'Top', 'Width', 'Height'];
        for (var d = 0; d < 4; d++) {
            el.dim[dims[d]] = el['offset' + dims[d]];
        }
        var assign = function(obj, topLeft) {
            obj.style.left = (topLeft ? 0 : el.dim.Left) + 'px';
            obj.style.top = (topLeft ? 0 : el.dim.Top) + 'px';
            obj.style.width = el.dim.Width + 'px';
            obj.style.height = el.dim.Height + 'px';
        };
        for (var v in el.vml) {
            var mult = (v == 'image') ? 1 : 2;
            el.vml[v].coordsize = (el.dim.Width * mult) + ', ' + (el.dim.Height * mult);
            assign(el.vml[v], true);
        }
        assign(el.vmlBox, false);

        if (DD_roundies.IE8) {
            el.vml.stroke.style.margin = '-1px';
            if (typeof el.bW == 'undefined') {
                this.vmlStrokeWeight(el);
            }
            el.vml.color.style.margin = (el.bW.Top - 1) + 'px ' + (el.bW.Left - 1) + 'px';
        }
    },

    vmlPath: function(el) {
        var coords = function(direction, w, h, r, aL, aT, mult) {
            var cmd = direction ? ['m', 'qy', 'l', 'qx', 'l', 'qy', 'l', 'qx', 'l'] : ['qx', 'l', 'qy', 'l', 'qx', 'l', 'qy', 'l', 'm']; /* whoa */
            aL *= mult;
            aT *= mult;
            w *= mult;
            h *= mult;
            var R = r.slice(); /* do not affect original array */
            for (var i = 0; i < 4; i++) {
                R[i] *= mult;
                R[i] = Math.min(w / 2, h / 2, R[i]); /* make sure you do not get funky shapes - pick the smallest: half of the width, half of the height, or current value */
            }
            var coords = [
				cmd[0] + Math.floor(0 + aL) + ',' + Math.floor(R[0] + aT),
				cmd[1] + Math.floor(R[0] + aL) + ',' + Math.floor(0 + aT),
				cmd[2] + Math.ceil(w - R[1] + aL) + ',' + Math.floor(0 + aT),
				cmd[3] + Math.ceil(w + aL) + ',' + Math.floor(R[1] + aT),
				cmd[4] + Math.ceil(w + aL) + ',' + Math.ceil(h - R[2] + aT),
				cmd[5] + Math.ceil(w - R[2] + aL) + ',' + Math.ceil(h + aT),
				cmd[6] + Math.floor(R[3] + aL) + ',' + Math.ceil(h + aT),
				cmd[7] + Math.floor(0 + aL) + ',' + Math.ceil(h - R[3] + aT),
				cmd[8] + Math.floor(0 + aL) + ',' + Math.floor(R[0] + aT)
			];
            if (!direction) {
                coords.reverse();
            }
            var path = coords.join('');
            return path;
        };

        if (typeof el.bW == 'undefined') {
            this.vmlStrokeWeight(el);
        }
        var bW = el.bW;
        var rad = el.DD_radii.slice();

        /* determine outer curves */
        var outer = coords(true, el.dim.Width, el.dim.Height, rad, 0, 0, 2);

        /* determine inner curves */
        rad[0] -= Math.max(bW.Left, bW.Top);
        rad[1] -= Math.max(bW.Top, bW.Right);
        rad[2] -= Math.max(bW.Right, bW.Bottom);
        rad[3] -= Math.max(bW.Bottom, bW.Left);
        for (var i = 0; i < 4; i++) {
            rad[i] = Math.max(rad[i], 0);
        }
        var inner = coords(false, el.dim.Width - bW.Left - bW.Right, el.dim.Height - bW.Top - bW.Bottom, rad, bW.Left, bW.Top, 2);
        var image = coords(true, el.dim.Width - bW.Left - bW.Right + 1, el.dim.Height - bW.Top - bW.Bottom + 1, rad, bW.Left, bW.Top, 1);

        /* apply huge path string */
        el.vml.color.path = inner;
        el.vml.image.path = image;
        el.vml.stroke.path = outer + inner;

        this.clipImage(el);
    },

    nixBorder: function(el) {
        var s = el.currentStyle;
        var sides = ['Top', 'Left', 'Right', 'Bottom'];
        for (var i = 0; i < 4; i++) {
            el.runtimeStyle['padding' + sides[i]] = (parseInt(s['padding' + sides[i]], 10) || 0) + (parseInt(s['border' + sides[i] + 'Width'], 10) || 0) + 'px';
        }
        el.runtimeStyle.border = 'none';
    },

    clipImage: function(el) {
        var lib = DD_roundies;
        if (!el.vmlBg || !lib.imgSize[el.vmlBg]) {
            return;
        }
        var thisStyle = el.currentStyle;
        var bg = { 'X': 0, 'Y': 0 };
        var figurePercentage = function(axis, position) {
            var fraction = true;
            switch (position) {
                case 'left':
                case 'top':
                    bg[axis] = 0;
                    break;
                case 'center':
                    bg[axis] = 0.5;
                    break;
                case 'right':
                case 'bottom':
                    bg[axis] = 1;
                    break;
                default:
                    if (position.search('%') != -1) {
                        bg[axis] = parseInt(position, 10) * 0.01;
                    }
                    else {
                        fraction = false;
                    }
            }
            var horz = (axis == 'X');
            bg[axis] = Math.ceil(fraction ? ((el.dim[horz ? 'Width' : 'Height'] - (el.bW[horz ? 'Left' : 'Top'] + el.bW[horz ? 'Right' : 'Bottom'])) * bg[axis]) - (lib.imgSize[el.vmlBg][horz ? 'width' : 'height'] * bg[axis]) : parseInt(position, 10));
            bg[axis] += 1;
        };
        for (var b in bg) {
            figurePercentage(b, thisStyle['backgroundPosition' + b]);
        }

        var bW = Object.extend({ "Left": 0, "Right": 0, "Top": 0, "Bottom": 0 }, el.bW);
        el.vml.image.filler.position = (bg.X / (el.dim.Width - bW.Left - bW.Right + 1)) + ',' + (bg.Y / (el.dim.Height - bW.Top - bW.Bottom + 1));
        var bgR = thisStyle.backgroundRepeat;
        var c = { 'T': 1, 'R': el.dim.Width + 1, 'B': el.dim.Height + 1, 'L': 1 }; /* these are defaults for repeat of any kind */
        var altC = { 'X': { 'b1': 'L', 'b2': 'R', 'd': 'Width' }, 'Y': { 'b1': 'T', 'b2': 'B', 'd': 'Height'} };
        if (bgR != 'repeat') {
            c = { 'T': (bg.Y), 'R': (bg.X + lib.imgSize[el.vmlBg].width), 'B': (bg.Y + lib.imgSize[el.vmlBg].height), 'L': (bg.X) }; /* these are defaults for no-repeat - clips down to the image location */
            if (bgR.search('repeat-') != -1) { /* now let's revert to dC for repeat-x or repeat-y */
                var v = bgR.split('repeat-')[1].toUpperCase();
                c[altC[v].b1] = 1;
                c[altC[v].b2] = el.dim[altC[v].d] + 1;
            }
            if (c.B > el.dim.Height) {
                c.B = el.dim.Height + 1;
            }
        }
        el.vml.image.style.clip = 'rect(' + c.T + 'px ' + c.R + 'px ' + c.B + 'px ' + c.L + 'px)';
    },

    pseudoClass: function(el) {
        var self = this;
        setTimeout(function() { /* would not work as intended without setTimeout */
            self.applyVML(el);
        }, 1);
    },

    reposition: function(el) {
        this.vmlOffsets(el);
        this.vmlPath(el);
    },

    roundify: function(rad) {
        this.style.behavior = 'none';
        if (!this.currentStyle) {
            return;
        }
        else {
            var thisStyle = this.currentStyle;
        }
        var allowed = { BODY: false, TABLE: false, TR: false, TD: false, SELECT: false, OPTION: false, TEXTAREA: false };
        if (allowed[this.nodeName] === false) { /* elements not supported yet */
            return;
        }
        var self = this; /* who knows when you might need a setTimeout */
        var lib = DD_roundies;
        this.DD_radii = rad;
        this.dim = {};

        /* attach handlers */
        var handlers = { resize: 'reposition', move: 'reposition' };
        if (this.nodeName == 'A') {
            var moreForAs = { mouseleave: 'pseudoClass', mouseenter: 'pseudoClass', focus: 'pseudoClass', blur: 'pseudoClass' };
            for (var a in moreForAs) {
                handlers[a] = moreForAs[a];
            }
        }
        for (var h in handlers) {
            this.attachEvent('on' + h, function() {
                lib[handlers[h]](self);
            });
        }
        this.attachEvent('onpropertychange', function() {
            lib.readPropertyChanges(self);
        });

        /* ensure that this elent and its parent is given hasLayout (needed for accurate positioning) */
        var giveLayout = function(el) {
            el.style.zoom = 1;
            if (el.currentStyle.position == 'static') {
                el.style.position = 'relative';
            }
        };
        giveLayout(this.offsetParent);
        giveLayout(this);

        /* create vml elements */
        this.vmlBox = document.createElement('ignore'); /* IE8 really wants to be encased in a wrapper element for the VML to work, and I don't want to disturb getElementsByTagName('div') - open to suggestion on how to do this differently */
        this.vmlBox.attachEvent('onclick', function(evt) {
            evt.cancelBubble = true;
            if (self.simulate)
                self.simulate('click');
        });
        this.vmlBox.runtimeStyle.cssText = 'behavior:none; position:absolute; margin:0; padding:0; border:0; background:none;'; /* super important - if something accidentally matches this (you yourseld did this once, Drew), you'll get infinitely-created elements and a frozen browser! */
        this.vmlBox.style.zIndex = thisStyle.zIndex;
        this.vml = { 'color': true, 'image': true, 'stroke': true };
        for (var v in this.vml) {
            this.vml[v] = document.createElement(lib.ns + ':shape');
            this.vml[v].filler = document.createElement(lib.ns + ':fill');
            this.vml[v].appendChild(this.vml[v].filler);
            this.vml[v].stroked = false;
            this.vml[v].style.position = 'absolute';
            this.vml[v].style.zIndex = thisStyle.zIndex;
            this.vml[v].coordorigin = '1,1';
            this.vmlBox.appendChild(this.vml[v]);
        }
        this.vml.image.fillcolor = 'none';
        this.vml.image.filler.type = 'tile';
        this.parentNode.insertBefore(this.vmlBox, this);

        this.isImg = false;
        if (this.nodeName == 'IMG') {
            this.isImg = true;
            this.style.visibility = 'hidden';
        }

        setTimeout(function() {
            lib.applyVML(self);
        }, 1);
    }

};

try {
	document.execCommand("BackgroundImageCache", false, true);
} catch(err) {}
DD_roundies.IEversion();
DD_roundies.createVmlNameSpace();
DD_roundies.createVmlStyleSheet();

if (DD_roundies.IE8 && document.attachEvent && DD_roundies.querySelector) {
	document.attachEvent('onreadystatechange', function() {
		if (document.readyState == 'complete') {
			var selectors = DD_roundies.selectorsToProcess;
			var length = selectors.length;
			var delayedCall = function(node, radii, index) {
				setTimeout(function() {
					DD_roundies.roundify.call(node, radii);
				}, index*100);
			};
			for (var i=0; i<length; i++) {
				var results = document.querySelectorAll(selectors[i].selector);
				var rLength = results.length;
				for (var r=0; r<rLength; r++) {
					if (results[r].nodeName != 'INPUT') { /* IE8 doesn't like to do this to inputs yet */
						delayedCall(results[r], selectors[i].radii, r);
					}
				}
			}
		}
	});
}

var niftySelectorParser = /\b((tl)|(tr)|(bl)|(br)|(top)|(bottom)|(left)|(right)|(all)|(none)|(small)|(normal)|(big)|(fixed-height)|(same-height))\b/i
function Nifty(selector, config){
    
    var size = 5,
        corners = $A([false,false,false,false]);
        cornersSet = false;
    
    function translateConfig(value) {
        switch (value){
            case "tl":
                cornersSet = true;
                corners[0] = true;
                break;
            case "tr":
                cornersSet = true;
                corners[1] = true;
                break;
            case "br":
                cornersSet = true;
                corners[2] = true;
                break;
            case "bl":
                cornersSet = true;
                corners[3] = true;
                break;
            case "top":
                cornersSet = true;
                corners[1] = corners[0] = true;
                break;
            case "bot":
            case "bottom":
                cornersSet = true;
                corners[2] = corners[3] = true;
                break;
            case "left":
                cornersSet = true;
                corners[0] = corners[3] = true;
                break;
            case "right":
                cornersSet = true;
                corners[1] = corners[2] = true;
                break;
            case "all":
                cornersSet = true;
                corners = $A([true,true,true,true]);
                break;
            case "none":
                cornersSet = true;
                corners = $A([false,false,false,false])
                break;
            case "small":
                size = 2;
                break;
            case "normal":
                size = 5;
                break;
            case "big":
                size = 10;
                break;
            case "fixed-height":
                break;
            case "same-height":
                SproutJS.Util.EnforceHeight($$(selector), true);
                break;
        }
    }
    
    config.scan(niftySelectorParser, function(n) { translateConfig(n.shift()); })
    
    if (!cornersSet){
        corners = $A([true,true,true,true]);
    }
    
    var css = corners.collect(function(n) {
        if (!n) {
            return 0;
        }
        return size + "px";
    }).join(' ');
    
    DD_roundies.addRule(selector, css, true);
}
if (typeof SproutJS == 'undefined') {
    SproutJS = {};
}
if (typeof SproutJS.Controls == 'undefined') {
    SproutJS.Controls = {};
}
SproutJS.Config = {
    shouldDebug: function() {
        var host = window.location.host;
        return window.console && (host == "localhost" || host == "127.0.0.1" || host.indexOf('beta') === 0 || host.indexOf('staging') === 0);
    } ()
};
Popup = {
    open: function(options) {
        Popup.directOpen(options);
        return false;
    },
    directOpen: function(options) {
        options = Object.extend({
            url: '#',
            width: 977,
            height: 500,
            name: "_blank",
            location: "no",
            menubar: "yes",
            toolbar: "no",
            status: "no",
            scrollbars: "yes",
            resizable: "yes",
            left: "",
            top: "",
            normal: false
        }, options);

        if (options.normal) {
            options.menubar = options.status = options.toolbar = options.location = "yes";
        }

        options.width = options.width < screen.availWidth ? options.width : screen.availWidth;
        options.height = options.height < screen.availHeight ? options.height : screen.availHeight;
        var openoptions = 'width=' + options.width + ',height=' + options.height + ',location=' + options.location + ',menubar=' + options.menubar + ',toolbar=' + options.toolbar + ',scrollbars=' + options.scrollbars + ',resizable=' + options.resizable + ',status=' + options.status;
        if (options.top !== "") {
            openoptions += ",top=" + options.top;
        }
        if (options.left !== "") {
            openoptions += ",left=" + options.left;
        }
        return window.open(options.url, options.name, openoptions);
    }
};
URLUtil = (function() {
    var baseAppVirtualPath;
    var ensureInited = function() {
        if (baseAppVirtualPath === null) {
            console.error('urlutil is not initialized');
        }
    };

    var init = function(baseUrl) {
        baseAppVirtualPath = baseUrl;
    };

    var resolveUrl = function(url) {
        ensureInited();
        if (url && url.indexOf("~/") >= 0) {
            return url.replace("~/", baseAppVirtualPath);
        }
        return url;
    };
    return {
        init: init,
        resolveUrl: resolveUrl
    };
})();
LengthEnforcer = Class.create({
    initialize: function(element, length) {
        this.length = length;
        this.element = $(element);
        this.element.observe('keydown', this.enforceLength.bind(this));
        this.element.observe('keyup', this.enforceLength.bind(this));
    },
    enforceLength: function(evt) {
        if (this.element.value.length > this.length) {
            this.element.value = this.element.value.substr(0, this.length);
        }
    }
});
PromptUser = function() {
    var UserPrompt = function(element, options) {
        element = $(element);
        var pExe = null,
            timeLimitContainer;

        var remove = function() {
            cleanup();
        };

        var cleanup = function() {
            element.update();
            if (pExe) {
                pExe.stop();
            }
        };

        var defaultAction = function() {
            cleanup();
            if (options.newwindow) {
                Popup.open({ url: options.url });
            }
            else {
                window.location = options.url;
            }
        };

        var createTimer = function(timeLimit) {
            var step = function() {
                if (--timeLimit === 0) {
                    defaultAction();
                }
                timeLimitContainer.update(timeLimit);
            };
            return new PeriodicalExecuter(step, 1);
        };

        timeLimitContainer = element.select('.countdown .limit').first();
        if (timeLimitContainer) {
            pExe = createTimer(parseInt(timeLimitContainer.innerHTML.strip(), 10));
        } else if (options.url && options.timeout && options.timeout > 0) {
            timeLimitContainerWrap = new Element('p', { 'class': 'countdown' }).update('You will automatically be redirected in <span class="seconds limit">' + options.timeout + '</span> seconds.');
            timeLimitContainer = timeLimitContainerWrap.select('.limit').first();
            element.childElements().last().insert(timeLimitContainerWrap);
            pExe = createTimer(options.timeout);
        }

        element.select('iframe').invoke("observe", 'load', function(evt) {
            if (evt.element())
                SproutJS.Util.ResizeToContent(evt.element());
        });
        SproutJS.Util.Center(element);

        return {
            remove: remove
        };
    };

    var handlerUrl = '~/handlers/userprompt.aspx',
        shim = 'user_prompts',
        current = null;

    var prompt = function(id, url, newWindow, backUrl, timeout) { //{id:'', url: '', newwindow: true, backUrl: '', timeout:0}
        if (inited) {
            var defaultParams = { timeout: defaultTimeout };
            //for backwards compatibility (id should be an object literal going forward)
            var params = Object.isString(id) ? { id: id, url: url, newwindow: newWindow, backUrl: backUrl} : id;
            if (typeof timeout != 'undefined') {
                params.timeout = timeout;
            }
            //disable timeout for login requests.  this is a temporary measure.
            if (params.id === 'login_required') {
                params.timeout = -1;
            }
            params = Object.extend(defaultParams, params);
            var req = new Ajax.Request(handlerUrl, { 'method': 'POST', 'parameters': params,
                onSuccess: success, onException: exception
            });
        } else {
            pendingPrompt = arguments;
        }
    };

    var exception = function() {
        throw (arguments[1]);
    };

    var success = function(res) {
        shim.update(res.responseText);
        current = new UserPrompt(shim, res.request.parameters);
    };

    var removePrompt = function() {
        if (current) {
            current.remove();
        }
        current = null;
    };

    var init = function() {
        if (Object.isString(shim)) {
            if ($(shim)) {
                if (window.console) {
                    window.console.warn('PromptUser: #user_prompts already existed on init.');
                }
                shim = $(shim);
            } else {
                shim = new Element('div', { id: shim });
                $(document.body).insert(shim);
            }
        }
        handlerUrl = URLUtil.resolveUrl(handlerUrl);

        inited = true;
        if (pendingPrompt) {
            prompt.apply(null, pendingPrompt);
            pendingPrompt = null;
        }
    };

    var inited,
        pendingPrompt = null,
        defaultTimeout = 5;

    if (document.loaded) {
        init();
    }
    else {
        document.observe('dom:loaded', init);
    }

    return {
        prompt: prompt,
        removePrompt: removePrompt,
        defaultTimeout: defaultTimeout
    };
} ();
Bumpers = function() {
    var getTimeout = function(anchor) {
        var rev = anchor.attributes["rev"].value;
        if (!rev.include('|')) {
            return 5;
        }
        return parseInt(rev.split('|').pop(), 10);
    };
    var protectKids = function() {
        var generic_leavings = $$('a[rev^="bumpered"], button[rev^="bumpered"]');
        document.observe('click', function(evt) {
            var a = evt.findElement('a');
            if (a && generic_leavings.member(a)) {
                evt.stop();
                PromptUser.prompt((a.rel ? a.rel : 'leaving'), a.href, a.target == '_blank', null, getTimeout(a));
            }
            else {
                var btn = evt.findElement('button');
                if (btn && generic_leavings.member(btn)) {
                    evt.stop();
                    var rel = btn.attributes["rel"] ? btn.attributes["rel"].value : 'leaving';
                    PromptUser.prompt(rel, "", "", null, getTimeout(btn));
                }
            }
        });
    };
    if (document.loaded) {
        protectKids();
    }
    else {
        document.observe('dom:loaded', protectKids);
    }
} ();

//general version of the parent display toggle
AccordianList = Class.create({
    initialize: function(elements) {
        $(elements).each(function(n, i) {
            var req = new Accordian(n, (i > 0) ? { display: 'none'} : {});
        });
    }
});
Accordian = Class.create({
    initialize: function(element, style) {
        this.element = $(element);
        var anchor = this.element.down('a[title="expand"]');
        if (anchor) {
            this.pane = this.element.down('div');
        } else {
            anchor = this.element.down('button.toggle-container');
            this.pane = this.element.down('.container');
        }
        this.pane.setStyle(style);
        if (this.pane.visible()) {
            this.markExpanded();
        }
        anchor.observe('click', this.toggleView.bindAsEventListener(this));
    },
    toggleView: function(evt) {
        if (!this.pane.visible()) {
            this.markExpanded();
            Effect.BlindDown(this.pane, { duration: 0.25, queue: { scope: 'promos', position: 'end'} });
        } else {
            this.markCollapsed();
            Effect.BlindUp(this.pane, { duration: 0.25, queue: { scope: 'promos', position: 'end'} });
        }
    },
    markExpanded: function() {
        this.element.addClassName('expanded');
    },
    markCollapsed: function() {
        this.element.removeClassName('expanded');
    }
});
BestOfPlaylistItem = Class.create({
    initialize: function(element, manager) {
        this.element = $(element);
        this.manager = manager;
        this.id = null;
        this.element.select('a').each(function(n) {
            this.id = n.href.toQueryParams().id;
            n.observe('click', this.play.bindAsEventListener(this));
        }, this);
    },
    play: function(evt) {
        if (evt) {
            evt.stop();
        }
        var a = evt.findElement('a');
        var id = a.href.toQueryParams().id;
        Player.playById(id);
    }
});
BestOfPlaylist = Class.create(Enumerable, {
    initialize: function(elements) {
        this.elements = $(elements).collect(function(n) {
            return new BestOfPlaylistItem(n, this);
        }, this);
        Player.playlist = this;
    },
    isPlaylist: function() {
        return true;
    },
    _each: function(iterator, context) {
        this.elements.each(function(n) {
            iterator(n.element, context);
        });
    }
});
PageTools = Class.create({
    initialize: function() {
        if (!this.inited) {
            this.shares = $$('.share_page a');
            this.prints = $$('.print_page a');
            this.assignPrints();
            this.assignShares();
        }
        this.inited = true;
    },
    assignPrints: function() {
        this.prints.each(function(n) {
            n.observe('click', function(evt) { evt.stop(); window.print(); });
        });
    },
    assignShares: function() {
        this.shares.each(function(n) {
            n.observe('click', function() { alert('not yet implemented'); });
        });
    }
});
function clear_textbox(id, value) {
    if ($(id).value == value) {
        $(id).value = "";
    }
}
function fireEvent(eventName) {
    s.events = eventName;
}
function ajaxGalleryTracker(galleryName, pageNumber, themeName) {

    var as = s_gi(s_account);
    as.linkTrackVars = "prop11,prop12,prop14";
    as.pageName = as.pageName;
    as.prop11 = galleryName;
    as.prop12 = pageNumber;
    as.prop14 = themeName;
    as.tl(this, 'o', 'Gallery Pagination Event');
    if (s_code) {
        document.write(s_code);
    }
}
function printIt(fileName) {
    Popup.open({ url: URLUtil.resolveUrl('~/print/printtemp.aspx?fname=' + fileName) });
}
function saveIt(fileName) {
    Popup.open({ url: URLUtil.resolveUrl('~/membership/galleryupload.aspx?fname=' + fileName) });
}
function selectInputs(parent, state) {
    var inputs = parent.getElementsByTagName('input');
    for (var i = 0; i < inputs.length; i++) {
        if (inputs[i].type == 'checkbox') {
            inputs[i].checked = state;
        }
    }
}
function markAsInappropriate(value, context) {
    if (value) {
        context.parentNode.innerHTML = "The moderator has been notified";
    }
}
function reload() {
    setInterval(function() { window.location = window.location; }, 1000);
}
function leaving_confirm(dest) {
    PromptUser.prompt('leaving', dest);
}
function leaving_confirm(dest, newWindow) {
    PromptUser.prompt('leaving', dest, newWindow);
}
function login_required() {
    PromptUser.prompt('login_required');
}
function setInterstatialTargetUrl(interstatialId) {
    PromptUser.prompt(interstatialId);
}
function setSrc(value, context) {
    $(context).src = value;
}
function createCookie(name, value, days) {
    var expires = "";
    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + (days * 5184000)); //24*60*60*1000
        expires = "; expires=" + date.toGMTString();
    }
    document.cookie = name + "=" + value + expires + "; path=/";
}
//if Scriptaculous is loaded create the Scroll Effect
if (typeof (Effect) != 'undefined') {
    Object.extend(Effect, {
        Scroll: Class.create(Effect.Base, {
            initialize: function(element) {
                this.element = $(element);
                var options = Object.extend({
                    x: 0,
                    y: 0,
                    mode: 'absolute'
                }, arguments[1] || {});

                if (options.element && Object.isElement(options.element)) {
                    options.x = options.element.offsetLeft;
                    options.y = options.element.offsetTop;
                }

                this.start(options);
            },
            setup: function() {
                this.originalLeft = this.element.scrollLeft;
                this.originalTop = this.element.scrollTop;
                if (this.options.mode == 'absolute') {
                    this.options.x -= this.originalLeft;
                    this.options.y -= this.originalTop;
                }
            },
            update: function(position) {
                this.element.scrollLeft = this.options.x * position + this.originalLeft;
                this.element.scrollTop = this.options.y * position + this.originalTop;
            }
        }),
        SoftScrollTo: function(element, options) {
            var options = Object.extend({ offset: 0 }, options);
            function killScroll(evt) {
                if (effect) {
                    effect.cancel();
                }
                document.stopObserving('mousewheel', killScroll);
                document.stopObserving('DOMMouseScroll', killScroll);
            }
            document.observe('mousewheel', killScroll);
            document.observe('DOMMouseScroll', killScroll);
            var effect = new Effect.ScrollTo($(element), options);
            return effect;
        }
    });
}
Element.addMethods({
    isAdjacentSibling: function(element, anotherElement) {
        element = $(element);
        return element.siblings().member(anotherElement) && (element.next() == anotherElement || element.previous() == anotherElement);
    },
    graft: function(element, insertions, clone) {
        element = $(element);
        if (Object.isArray(insertions) && insertions.length < 1) {
            return;
        }
        if (Object.isString(insertions) || Object.isNumber(insertions) || Object.isArray(insertions) ||
            Object.isElement(insertions) || (insertions && (insertions.toElement || insertions.toHTML))) {
            insertions = { bottom: insertions };
        }
        $H(insertions).each(function(kv) {
            var content = kv.value.clone(),
                position = kv.key.toLowerCase(),
                insert = Element._insertionTranslations[position];

            if (position == 'top' || position == 'after') {
                content.reverse();
            }
            content.each(function(node) {
                insert(element, clone ? node.cloneNode(node) : node);
            });
        });
        return element;
    }
});

(function() {
    var eventMatchers = {
        'HTMLEvents': /^(?:load|unload|abort|error|select|change|submit|reset|focus|blur|resize|scroll)$/,
        'MouseEvents': /^(?:click|mouse(?:down|up|over|move|out))$/
    };
    var defaultOptions = {
        pointerX: 0,
        pointerY: 0,
        button: 0,
        ctrlKey: false,
        altKey: false,
        shiftKey: false,
        metaKey: false,
        bubbles: true,
        cancelable: true
    };

    Event.simulate = function(element, eventName, options) {
        options = Object.extend(Object.clone(defaultOptions), options || {});
        var oEvent, eventType = null;

        element = $(element);

        for (var name in eventMatchers) {
            if (eventMatchers[name].test(eventName)) {
                eventType = name; break;
            }
        }

        if (!eventType) {
            throw new SyntaxError('Only HTMLEvents and MouseEvents interfaces are supported');
        }

        if (document.createEvent) {
            oEvent = document.createEvent(eventType);
            if (eventType == 'HTMLEvents') {
                oEvent.initEvent(eventName, options.bubbles, options.cancelable);
            }
            else {
                oEvent.initMouseEvent(eventName, options.bubbles, options.cancelable, document.defaultView,
                    options.button, options.pointerX, options.pointerY, options.pointerX, options.pointerY,
                    options.ctrlKey, options.altKey, options.shiftKey, options.metaKey, options.button, element);
            }
            element.dispatchEvent(oEvent);
        }
        else {
            options.clientX = options.pointerX;
            options.clientY = options.pointerY;
            oEvent = Object.extend(document.createEventObject(), options);
            element.fireEvent('on' + eventName, oEvent);
        }
        return element;
    };

    Element.addMethods({ simulate: Event.simulate });
})();
Object.extend(SproutJS.Controls, {
    AdvancedControls: function() {
        var buttonCollection = Class.create({
            initialize: function(elements, fnct) {
                this.elements = elements.collect(
                    function(n) {
                        return new button(n, fnct);
                    }
                );
                this.fnct = fnct;
            },
            add: function(ele) {
                this.elements.push(new button(ele, this.fnct));
            },
            _each: function(iterator) {
                for (var i = 0; i < this.elements.length; i++) {
                    iterator(this.elements[i], i);
                }
            }
        });
        Object.extend(buttonCollection.prototype, Enumerable);
        var button = Class.create({
            initialize: function(element, click) {
                if (typeof element == 'undefined') {
                    return;
                }
                this.element = $(element);
                if (this.element) {
                    /// for browsers that don't implement css attribute selectors
                    if (this.element.disabled == 'disabled') {
                        this.disable();
                    }
                    if (click) {
                        this.element.observe('click', click.wrap(
                            function(proceed) {
                                if (!this.isDisabled()) {
                                    proceed.apply(null, arguments);
                                }
                            }
                        ).bind(this));
                    }
                }
            },
            isDisabled: function() {
                return this.element.disabled && this.element.disabled === 'disabled';
            },
            disable: function() {
                this.element.addClassName('disabled');
                this.element.disabled = 'disabled';
            },
            enable: function() {
                this.element.removeClassName('disabled');
                this.element.disabled = null;
            },
            setState: function(enable) {
                this[enable ? "enable" : "disable"]();
            }
        });
        var track = function(vars) {
            SproutJS.Controls.OmniTrack({ vars: vars, events: ['event20'], name: 'Advanced Player Control Click' });
        };
        var favorite = function() {
            var id = nowPlaying.releaseId ? nowPlaying.releaseId : nowPlaying.id;
            SproutJS.Controls.AddFavorite.byReleaseId(id, 'video_favorite');
            track({ eVar13: 'Add to Favorites' });
        };
        var downloadVideo = function() {
            Popup.open({ url: nowPlaying.downloadVideo });
            track({ eVar12: 'DownloadVideo' });
        };
        var downloadMp3 = function() {
            //SproutJS.Util.ForceDownload(nowPlaying.downloadMp3, 'music.mp3'); 
            Popup.open({ url: nowPlaying.downloadMp3 });
            track({ eVar12: 'downloadMp3' });
        };
        var print = function() {
            Popup.open({ url: URLUtil.resolveUrl(nowPlaying.print) });
            track({ eVar14: 'Print' });
        };
        var share = function() {
            track({ eVar11: 'Email' });
        };
        var nowPlayingHandler = function(evt) {
            nowPlaying = evt.memo;
            maintainButtonState();
        };
        var maintainButtonState = function() {
            btns.get('download').invoke('setState', nowPlaying && nowPlaying.downloadVideo && nowPlaying.downloadVideo !== '');
            btns.get('mp3').invoke('setState', nowPlaying && nowPlaying.downloadMp3 && nowPlaying.downloadMp3 !== '');
            btns.get('print').invoke('setState', nowPlaying && nowPlaying.print && nowPlaying.print !== '');
        };
        var favsHack = function(evt) {
            if (!nowPlaying) {
                nowPlaying = {};
            }
            nowPlaying.releaseId = evt.memo.id;
        };
        var register = function(element, type) {
            var targetBtns = btns.get(type);
            if (!targetBtns) {
                return targetBtns;
            }
            maintainButtonState();
            targetBtns.add(element);
        };
        var nowPlaying,
            root = $('player-utilities'),
            btns = $H({
                'favorite': new buttonCollection(root ? root.select('.favorite') : [], favorite),
                'download': new buttonCollection(root ? root.select('.download') : [], downloadVideo),
                'mp3': new buttonCollection(root ? root.select('.mp3') : [], downloadMp3),
                'print': new buttonCollection(root ? root.select('.print') : [], print)
            });

        document.observe('Video:nowPlaying', nowPlayingHandler);
        document.observe('TPlayer:nowPlaying', favsHack);

        return {
            register: register
        };
    },
    Anfo: function(_obj) {
        var create = function() {
            obj.flashvars = buildFlashVars();
            var test = UFO.create(obj, obj.replacementId);
            return obj;
        };
        var buildFlashVars = function() {
            //enables us to use functions to set flash vars at creation time
            if (obj.variables) {
                var tmp = $H(obj.variables);
                tmp.each(function(pair) {
                    if (Object.isFunction(pair.value)) {
                        tmp.set(pair.key, pair.value());
                    }
                });
                return tmp.toQueryString();
            }
        };
        var obj = Object.extend(_obj, { create: create });
        return obj;
    },
    Captcha: function() {
        var getNewCaptcha = function() {
            var elem = $('captchaImage');
            if (elem) {
                elem.src = URLUtil.resolveUrl("~/handlers/captchaimage.aspx?rnd=" + Math.floor(Math.random() * 1000000));
            }
        };
        var cycleCaptcha = function() {
            getNewCaptcha();
            setTimeout(cycleCaptcha, 60000);
        };
        if (!document.loaded) {
            document.observe('dom:loaded', cycleCaptcha);
        }
        else {
            cycleCaptcha();
        }
        return {
            cycleCaptcha: cycleCaptcha,
            getNewCaptcha: getNewCaptcha
        }
    } (),
    Ad: Class.create({
        initialize: function(id, options) {
            this.id = id;
            this.options = Object.extend({
                autoLoad: true
                    , iframe: {
                        frameborder: 0
                        , className: 'ad'
                        , scrolling: 'no'
                    }
            },
                options
            );

            if (this.options.autoLoad) {
                if (document.loaded) {
                    this.renderTag();
                }
                else {
                    document.observe('dom:loaded', this.renderTag.bindAsEventListener(this));
                }
            }
        },
        renderTag: function() {
            $(this.id).update(new Element('iframe', this.options.iframe));
        },
        toQueryParams: function() {
            var match = this.options.iframe.src.strip().match(/^([^;]+);(.*);?/);

            if (!match) {
                return {};
            }

            return {
                "path": match[1]
                , "params": match[2].split(';').inject({}, function(hash, pair) {
                    if ((pair = pair.split('='))[0]) {
                        var key = decodeURIComponent(pair.shift());
                        var value = pair.length > 1 ? pair.join('=') : pair[0];
                        if (value != undefined) {
                            value = decodeURIComponent(value);
                        }
                        if (key in hash) {
                            if (!Object.isArray(hash[key])) {
                                hash[key] = [hash[key]];
                            }
                            hash[key].push(value);
                        }
                        else {
                            hash[key] = value;
                        }
                    }
                    return hash;
                })
            }
        },
        toQueryPair: function(key, value) {
            if (Object.isUndefined(value)) {
                return key;
            }
            return key + '=' + encodeURIComponent(String.interpret(value));
        },
        toQueryString: function(queryParams) {
            return queryParams.path + ";" + $H(queryParams.params).inject([], function(results, pair) {
                var key = encodeURIComponent(pair.key), values = pair.value;

                if (values && typeof values == 'object') {
                    if (Object.isArray(values)) {
                        return results.concat(values.map(this.toQueryPair.curry(key)));
                    }
                } else {
                    results.push(this.toQueryPair(key, values));
                }

                return results;
            }, this).join(';') + ";";

        }
    }),
    Dart: function() {
        var ads = $H();
        var add = function(id, options) {
            ads.set(id, new SproutJS.Controls.Ad(id, options));
        };
        var get = function(id) {
            return ads.get(id);
        };
        var reload = function(force) {
            ads.each(function(n) {
                if (force || n.value.options.autoLoad) {
                    n.value.renderTag();
                }
            });
        };
        var count = function() {
            return ads.keys().length;
        };
        return {
            reload: reload,
            count: count,
            add: add,
            get: get
        };
    } (),
    AddFavorite: function() {
        var cb = function(promptName, returnValue) {
            if (returnValue) {
                PromptUser.prompt(promptName ? promptName : 'add_favorite');
                track(returnValue);
            } else {
                PromptUser.prompt({ id: 'login_required', url: window.location.href });
            }
        };
        var track = function(assetName) {
            SproutJS.Controls.OmniTrack({ vars: { eVar7: assetName }, events: ['event8'], name: 'Add to a Favorites Event' });
        };
        var byReleaseId = function(releaseId, promptName) {
            return Sprout.Web.Handlers.Scripts.AddToFavoritesByReleaseID(releaseId, cb.bind(null, promptName));
        };
        var byId = function(id) {
            return Sprout.Web.Handlers.Scripts.AddToFavoritesByID(id, cb.bind(null, null));
        };
        return {
            byReleaseId: byReleaseId,
            byId: byId
        };
    } (),
    //builds lists from arrays, customize templates by specifying spec.templates
    ListBuilder: function(spec) {
        var templates = spec.templates ||
        {
            content: new Template('<div class="disp_unit">\
                    <a class="port" href="#{navUrl}" rel="#{releaseId}">\
                        <img height="90" width="122" alt="#{name}" src="#{imgSrc}" \/>\
                    <\/a>\
                    <a href="#{navUrl}" rel="#{releaseId}" class="title">#{name}<\/a>\
                    <p>#{caption}<\/p>\
                <\/div>'),
            listItem: new Template('<li class="#{className}">#{contents}<\/li>')
        };
        var build = function(json) {
            var items = json.collect(
                spec.build || function(n, i) {
                    var markup = templates.content.evaluate(n);
                    return templates.listItem.evaluate({
                        className: getClassName(i),
                        contents: markup
                    });
                });
            //add markup to a dummy div so we can return the list as elements
            return new Element('ul').update(items.join('')).childElements();
        };
        //adds class name to list item, by default it adds 'first' and 'last' based on the itemsPerRow spec value
        var getClassName = spec.getClassName || function(n) {
            switch (n % itemsPerRow) {
                case 0:
                    return 'first';
                case itemsPerRow - 1:
                    return 'last';
            }
            return '';
        };
        var itemsPerRow = spec.itemsPerRow || 4;
        return {
            build: build
        };
    },
    ImageManipulator: function() {
        var nowPlaying = function(src) {
            return URLUtil.resolveUrl("~/handlers/overlay.aspx?img=nowplaying&src=" + encodeURIComponent(src));
        };
        var markNew = function(src) {
            return URLUtil.resolveUrl("~/handlers/overlay.aspx?img=new&src=" + encodeURIComponent(src));
        };
        var revert = function(src) {
            return src.toQueryParams().src;
        };
        return {
            nowPlaying: nowPlaying,
            markNew: markNew,
            revert: revert
        };
    } (),
    Playlist: function() {
        var markNowPlaying = function(evt) {
            var name = "";
            $$('a[rel] img[src*="img=nowplaying"]').each(function(n) {
                n.src = SproutJS.Controls.ImageManipulator.revert(n.src);
            });
            var them = $$('a[rel="' + evt.memo.id + '"]').each(function(n) {
                var img = n.select('img');
                if (img && img.length > 0) {
                    img[0].src = SproutJS.Controls.ImageManipulator.nowPlaying(img[0].src);
                }
                else {
                    name = n.innerHTML;
                }
            });
            $('now-playing').update('<span>Now Playing:</span> ' + name);
        };
        document.observe('TPlayer:nowPlaying', markNowPlaying);
        //this is what is called from pages
        var InnerPlaylist = function(assets, options) { // autoplay=b, supressNewDemark=b, repeat=b, keywords='', provider=url Templates=...
            options = Object.extend({
                keywords: '',
                provider: '~/handlers/platformcache.aspx'
            }, options);

            var playlistItem = function(element) {
                var play = function(evt) {
                    evt.stop();
                    SproutJS.TPlayer.playById(evt.findElement('a').rel);
                };
                element = $(element);
                element.select('a[rel]').each(function(n) {
                    n.observe('click', play);
                });
                return element;
            };

            var elements, ids;
            // if assets is a json object then build the list
            if (!Object.isElement(assets.first())) {
                var localAssets = assets.collect(function(n) { return Object.clone(n); });
                if (!options.supressNewDemark) {
                    var now = new Date();
                    elements = localAssets.collect(function(n) {
                        if (!n.dateScreened) {
                            n.dateScreened = true;
                            var published = new Date(n.releaseDate);
                            if (now - published < 1209600000) { //2weeks 
                                n.imgSrc = SproutJS.Controls.ImageManipulator.markNew(n.imgSrc);
                            }
                        }
                    });
                }
                elements = SproutJS.Controls.ListBuilder({}).build(localAssets);
                ids = localAssets.pluck("releaseId");
                // otherwise just pull the ids
            } else {
                elements = assets;
                ids = elements.collect(function(n) {
                    var link = n.select('[rel]').first();
                    if (link) {
                        return link.rel;
                    }
                    return null;
                });
                ids = ids.select(function(n) { return n !== null; });
            }
            elements = elements.collect(function(n) {
                return playlistItem(n);
            });
            var channel = s_gi(s_account).channel;

            SproutJS.TPlayer.setIds(ids, URLUtil.resolveUrl(options.provider), options.repeat, { s1: channel, kw: options.keywords });

            if (options.autoplay) {
                SproutJS.TPlayer.play();
            }
            return elements;
        };
        return InnerPlaylist;
    } (),
    PlaylistScroller: function(element, assets, options) {
        var findAndScrollTo = function(evt) {
            var target = element.select('a[rel="' + evt.memo.id + '"]').first();
            if (target) {
                slider.goTo(target.up('li'));
            }
        };
        options = Object.extend({
            setupPlayer: false,
            keywords: '',
            provider: '~/handlers/platformcache.aspx'
        }, options);

        var listAssets;
        if (assets && Object.isElement(assets.first())) {
            listAssets = assets;
        }
        else {
            listAssets = SproutJS.Controls.ListBuilder({}).build(assets);
        }

        if (options.setupPlayer) {
            var channel = s_gi(s_account).channel;
            SproutJS.TPlayer.setIds(assets.pluck('releaseId'), URLUtil.resolveUrl(options.provider), true, { s1: channel, kw: options.keywords });
        }

        element = $(element);
        var slider = new SproutJS.Controls.Slider.DefaultSlider(listAssets, { offset: 3, fps: 21, duration: 0.7 }, element);

        element.observe('click', function(evt) {
            var element = evt.findElement('a[rel]');
            if (element) {
                evt.stop();
                SproutJS.TPlayer.playById(element.rel);
            }
        });
        document.observe('TPlayer:nowPlaying', findAndScrollTo);
        return slider;
    },
    ///when a .container-button is clicked we follow the href of it's first .default-btn descendant
    ///doesn't fire any onclick handling.
    ContainerButton: function() {
        var setUp = function(element) {
            var btn = element.down('.default-btn');
            var fire = function(evt) {
                evt.stop();
                window.location = btn.href;
            };
            element.observe('click', fire);
            element.setStyle({ cursor: 'pointer' });
        };

        document.observe('dom:loaded', function() {
            $$('.container-button').each(setUp);
        });

        return { setUp: setUp };
    } (),
    AjaxPager: function(element, options) { // required: page, totalPages
        options = Object.extend({
            page: 1,
            rangeLength: 10,
            baseUrl: window.location.protocol + "//" + window.location.host + window.location.pathname,
            query: window.location.search.toQueryParams()
        }, options);

        var setPage = function(val) {
            if (val > 0 && val < options.totalPages) {
                options.page = val;
            }
        };

        var listBuilder = function() {
            var getClassName = function(n) {
                if (Object.isNumber(n.val)) {
                    return options.page == n.val ? 'selected' : '';
                }
                return n.val == '&laquo;' ? 'previous' : 'next';
            };
            var spec = {};
            spec.templates = { listItem: new Template('<li>#{contents}'),
                content: new Template('<a class="#{className}" href="#{href}" rel="page">#{val}</a>')
            };
            spec.build = function(n, i) {
                var markup = spec.templates.content.evaluate(Object.extend(n, { className: getClassName(n) }));
                return spec.templates.listItem.evaluate({ contents: markup });
            };

            return SproutJS.Controls.ListBuilder(spec);
        } ();

        var pageArray = function() {
            if (options.totalPages < options.rangeLength) {
                return $R(1, options.totalPages).toArray();
            }

            var disp = Math.floor(options.rangeLength / 2);
            var lowBound = Math.max(options.page - disp, 1);
            var highBound = Math.min(options.page + disp, options.totalPages);

            var binding = function() {
                if (lowBound == 1) {
                    return -1;
                }
                if (highBound == options.totalPages) {
                    return 1;
                }
                return 0;
            } ();

            var range;
            if (binding < 0) {
                range = $R(1, options.rangeLength);
            }
            else if (binding > 0) {
                range = $R(options.totalPages - options.rangeLength, options.totalPages);
            }
            else {
                range = $R(lowBound, highBound);
            }
            return range.toArray();
        };

        var build = function() {
            var pages = pageArray();
            if (!pages || pages.length < 2) {
                return;
            }
            var linkPrimatives = $A(['&laquo;', pageArray(), '&raquo;']).flatten();
            var links = linkPrimatives.collect(
                function(n) {
                    return {
                        href: options.baseUrl + '?' + Object.toQueryString(Object.extend(options.query, { page: n })),
                        val: n
                    };
                }
            );
            element.update().graft(listBuilder.build(links).invoke("observe", "click", click));
        };
        build = Prototype.emptyFunction;
        var click = function(evt) {
            evt.stop();
            var ele = evt.element(), val;
            if (ele.className == 'previous') {
                setPage(options.page - 1);
            }
            else if (ele.className == 'next') {
                setPage(options.page + 1);
            }
            else {
                setPage(options.page = Number(ele.innerHTML));
            }
            build();
            document.fire('AjaxPager:pageClick', { page: options.page });
        };

        element = $(element).update();
        build();
    },
    OmniTrack: function(state) { //vars = {}, events = [], misc ={}, name = ""
        state = Object.extend({
            vars: {},
            events: $A(),
            name: 'default event name'
        }, state);

        var as = s_gi(s_account);

        if (state.vars.events) {
            state.events = state.events.concat(state.vars.events.split(','));
        }
        if (state.events.length > 0) {
            state.vars.events = as.linkTrackEvents = state.events.join(',');
        }
        as.linkTrackVars = $H(state.vars).keys().join(',');
        as = Object.extend(as, state.vars);
        as = Object.extend(as, state.misc);
        if (state.name) {
            as.tl(this, 'o', state.name);
        }
        if (s_code) {
            document.write(s_code);
        }
    },
    DefaultButton: function(container, button) {
        function init() {
            var cont = $(container),
                btn = $(button);

            if (cont && btn) {
                cont.stopObserving('keypress');
                cont.observe('keypress', function(evt) {
                    if (evt.keyCode == 13) {
                        var src = evt.element();
                        if (!src || (src.tagName.toLowerCase() != "textarea")) {
                            if (btn && btn.onclick && typeof (btn.click) !== "undefined") {
                                btn.click();
                                return false;
                            }
                            if (btn.href.indexOf('javascript:') === 0) {
                                window.location = btn.href;
                            }
                            btn.simulate('click');
                            evt.stop();
                        }
                    }
                    return true;
                });
            }
        }
        if (document.loaded) {
            init();
        }
        else {
            document.observe('dom:loaded', init);
        }
    }
});

if (Object.isUndefined(SproutJS.Util)) {
    SproutJS.Util = {};
}

Object.extend(SproutJS.Util, {
    CompanionAdManager: function() {
        var tile = null;

        function renderRequestedAds(evt) {
            if (!tile) {
                tile = SproutJS.Controls.Dart.count();
            }
            function render(banner) {
                var ad = SproutJS.Controls.Dart.get(banner.region);
                var oldUrl = ad.toQueryParams();
                var newUrl = new SproutJS.Controls.Ad(banner.region, {
                    "autoLoad": false
                                , "iframe": {
                                    "src": banner.src
                                }
                }).toQueryParams();

                if (oldUrl.params.pos) {
                    newUrl.params.pos = oldUrl.params.pos;
                }

                newUrl.params.tile = ++tile;
                ad.options.iframe.src = ad.toQueryString(newUrl);
                ad.renderTag();
            };
            evt.memo.banners.each(render);
        }

        function initializeAds() {
            SproutJS.Controls.Dart.reload(true);
            document.stopObserving('TPlayer:noAdStart', initializeAds);
        }
        document.observe('TPlayer:noAdStart', initializeAds);
        document.observe('TPlayer:adStart', renderRequestedAds);
    },
    Cookies: function() {
        var getCookie = function(cookieName) {
            var cookieValue = null;
            if (document.cookie.length > 0) {
                var cookieStart = document.cookie.indexOf(cookieName + '=');
                if (cookieStart != -1) {
                    cookieStart += cookieName.length + 1;
                    var cookieEnd = document.cookie.indexOf(';', cookieStart);
                    if (cookieEnd == -1) {
                        cookieEnd = document.cookie.length;
                    }
                    cookieValue = unescape(document.cookie.substring(cookieStart, cookieEnd));
                }
            }
            return cookieValue;
        };
        var setCookie = function(options) { //name, value, expires, domain, path
            options = Object.extend({
                "path": '/'
            }, options);

            if (Object.isNumber(options.expires)) {
                options.expires = new Date(new Date().getTime() + (options.expires * 24 * 60 * 60 * 1000)).toGMTString();
            }
            document.cookie = toCookieString(options);
        };
        var toCookieString = function(options) {
            var hash = $H(options);
            var result = $A([options.name + "=" + options.value]);
            hash.unset('name');
            hash.unset('value');
            hash.each(function(n) { result.push(n.key + "=" + n.value); });
            return result.join('; ');
        }
        return {
            setCookie: setCookie,
            getCookie: getCookie
        };
    } (),
    //(optional) last argument supplied is a bool that specifies wheather to make the shims class name backwards compatible
    EnforceHeight: function(elements, backCompat) {
        if (!elements || elements.length < 1)
            return;

        var highest = elements.invoke('getHeight').max();

        elements.each(function(n) {
            var myHeight = n.getHeight();
            if (myHeight < highest) {
                n.insert({
                    bottom: new Element('div', {
                        'class': backCompat === true ? 'niftyfill' : 'niftier_fill'
                    }).setStyle({ height: highest - myHeight + "px" })
                });
            }
        });
    },
    ForceDownload: function(url, filename) {
        var failure = function() {
            if (console && console.log) {
                console.log('failure');
            }
        };
        var exception = function() {
            if (console && console.error) {
                console.error(arguments);
            }
        };

        Popup.open({ url: URLUtil.resolveUrl('~/handlers/filefactory.aspx?loc=') + url + '&fn=' + filename });
    },
    ResizeToContent: function(element) {
        //untested!  use at your own risk
        var ele = $(element);
        ele.setStyle({ overflow: 'hidden' });
        ele.setStyle({ height: ele.contentWindow.document.body.scrollHeight + 'px', overflow: 'visible' });
    },
    ResizeIFrames: function() {
        document.observe('dom:loaded', function() {
            $$('iframe.resizeable').invoke('observe', 'load', function(evt) {
                SproutJS.Util.ResizeToContent(evt.element());
            });
        });
    } (),
    MuteParentPagePlayer: function() {
        try {
            if (opener.SproutJS.TPlayer.TryMuteOnBlur) {
                opener.SproutJS.TPlayer.mute(true);
            }
        } catch (e) { }
    } (),
    Center: function(elem) {
        var vp = document.viewport,
            offsets = vp.getScrollOffsets(),
			pTop = offsets.top + 100,
			pLeft = offsets.left,
			element = $(elem);

        pLeft += (vp.getWidth() - element.getWidth()) / 2;
        element.setStyle({ 'top': pTop + "px", 'left': pLeft + "px" });
    },
    
/*  SproutJS.Util.Sifr(elements, options)

    elements = prototype enumeration (i.e. $$())
    options = css and js options
    { 
	   'css' : { 'selector' : {'cssproperty': 'value' } }
	   'js'  : {'js option'  : 'value' }
    }
   
    there is a special case css selector '@all', which will apply to the root element */
    Sifr: function() {
        var SifrWrap = Class.create({
            permissableStyles: $A(['background-color', 'leading', 'kerning', 'text-transform', 'cursor', 'font-size',
                                   'text-align', 'text-decoration', 'font-weight', 'font-style', 'text-indent', 'color', 'display']),

            events: { 'click': 'onRelease', 'mouseover': 'onRollOver', 'mouseout': 'onRollOut' },
            simulateEvent: function(eventName, interceptor) {
                $(interceptor.getAncestor()).simulate(eventName);
            },
            fireEvent: function(eventName, fnct, interceptor) {
                this.simulateEvent(eventName, interceptor);
                if (fnct) {
                    fnct(interceptor);
                }
            },
            wrapEvent: function(eventName, fnct) {
                return (fnct ? fnct.wrap(this.fireEvent.curry(eventName)) : this.simulateEvent.curry(eventName)).bind(this);
            },
            getHandler: function(eventName) {
                return this.options.js[this.events[eventName]];
            },
            setHandler: function(eventName, value) {
                this.js[this.events[eventName]] = value;
            },
            getStyles: function(element, overrides) {
                var valids = $H();
                this.permissableStyles.each(function(attrib) {
                    var style = (overrides && overrides.get(attrib)) || element.getStyle(attrib);
                    if (attrib == 'color' && style) {
                        style = style.parseColor();
                    }
                    if (style) {
                        valids.set(attrib, style);
                    }
                });
                return valids.toObject();
            },
            buildCSS: function() {
                if (this.options && this.options.css) {
                    var overrides = $H(this.options.css['@all']);
                }

                var hash = $H({ '.sIFR-root': this.getStyles(this.element, overrides) });
                this.element.descendants().each(function(descendant) {
                    var baseStyle = this.getStyles(descendant, overrides);
                    hash.set(descendant.tagName.toLowerCase(), baseStyle);
                }, this);

                if (this.options && this.options.css) {
                    hash.update(this.options.css);
                }

                this.css = hash.toObject();
            },
            buildJS: function() {
                var jsOptions = this.options.js;
                if (!jsOptions) {
                    return;
                }
                if (this.element.getStyle('white-space') === 'nowrap' && !jsOptions.preventWrap) {
                    this.js.preventWrap = true;
                }

                $H(jsOptions).each(function(opt) {
                    if (opt.key == 'simulate') {
                        $A(opt.value).each(function(n) {
                            this.setHandler(n, this.wrapEvent(n, this.getHandler(n)));
                        }, this);
                    }
                    else {
                        this.js[opt.key] = opt.value;
                    }
                }, this);
            },
            initialize: function(element, options) {
                this.element = $(element);
                this.options = Object.extend({ js: {}, css: {} }, options);
                this.js = {};
                this.css = {};

                this.buildCSS();
                this.buildJS();

                sIFR.replace(bryant, Object.extend({
                    elements: [this.element],
                    wmode: 'transparent',
                    css: this.css
                }, this.js));
            }
        });
        return function(elements, options) {
            elements.each(function(n) {
                var wrap = new SifrWrap(n, options);
            });
        };
    } (),
    SelectTextboxFocus: function() {
        document.observe('dom:loaded', function() {
            $$('.select-on-focus').invoke('observe', 'focus', function(evt) { evt.element().select(); });
        });
    } ()
});
SproutJS.Templates = {
    AssetGroupSliderItem: (function() {
        var defaultClass = 'slider-item',
            selectedClass = 'selected';

        function getClass(item) {
            if (item.assets && item.assets.length > 0) {
                return defaultClass + " " + selectedClass;
            }
            return defaultClass;
        }
        var templates = {
            content: new Template(
                '<li class="#{className}">                                                  \
                    <div class="disp_unit">                                                 \
                        <a class="port" href="#{navUrl}" rel="#{id}">                       \
                            <img height="90" width="122" alt="#{name}" src="#{imgSrc}" /> \
                        </a>                                                                \
                        <a href="#{navUrl}" rel="#{id}">#{name}</a></div></li>')
        };
        var build = function(n) {
            return templates.content.evaluate(
                Object.extend(n, {
                    className: getClass(n)
                }));
        };

        return {
            templates: templates,
            build: build
        };
    })()
};
getElementNodes = function(elem) {
	var kids = [];
	for (var i = 0; i < elem.childNodes.length; i++) {
		if (elem.childNodes[i].nodeType == 1) {
			kids.push(elem.childNodes[i]);
		}
	}
	return kids;
}

errMsg = function(res) { 
	if (res.error.Status == 12029) return 'Unable to reach Sprout. Please check your internet connection.';
	if (res.error.Type == 'Sprout.Core.Exceptions.EndUserException') return res.error.Message;
	var result = ''; 
	for (x in res.error) result += x + ": " + res.error[x] + '\r\n' 
	if (result == '') return 'Unknown'
	return result
}
addClass = function (ele, addendum) { if (ele.className.indexOf(addendum) == -1) { ele.className = " " + addendum; } };
gid = function(id) { return document.getElementById(id); };
ce = function(element) { return Element.extend(document.createElement(element)); } 
jmpTo = function(loc) { 
	window.location = loc 
}

updateInnerHtmlCallback = function(res) {
    if (res.error) { if (console) console.debug(errMsg(res)); return; }
    if (res.value) $(res.context).innerHTML = res.value;
}

invokeElemCB = function(value, context) {
    var err = function(msg) { if (console) console.error(msg); }
    var i = 0;
    if (value && context) {
        context.each(function(o) {
            var val = value;
            if (val instanceof (Array) && val[i] != undefined) val = val[i];
            if (o instanceof (Array)) {
                if (!($(o[0]))) err("invokeElemCB: object named '" + o[0] + "' not found!");
                else {
                    if (!($(o[0])[o[1]])) err("invokeElemCB: object named '" + o[0] + "' does not have function named '" + o[1] + "'!");
                    else $(o[0])[o[1]](val);
                }
            }
            else if (typeof o == "function")
                o(val);
            else err("Unknown context element: " + o.inspect());
            i++;
        });
    }
}
var	AjaxPager =	Class.create();

Object.extend(AjaxPager, {
	pagers:[]
,
	updateAll: function(name,pg,total) {
		AjaxPager.pagers.each(function (pager) {
			if (pager.name==name) pager.update(pg,total);
		});
	}
});

Object.extend(AjaxPager.prototype, {
   initialize: function(root,props) {
		this.name =	props.name;
		this.varname = root;
		this.onpageclick = props.onpageclick;
		this.onpagechanged = props.onpagechanged;
		
		this.selected =	props.selected;
		this.total = props.total;
		this.max = props.max;		
		
		this.root =	$(root);
		if (this.root) {
			this.first = this.root.down("li.first");
			this.prev =	this.root.down("li.prev");
			this.last =	this.root.down("li.last");
			this.next =	this.root.down("li.next");
			this.pages = this.root.down("ol.pages");
		}
		
		AjaxPager.pagers.push(this);
	}
,
	update:	function(pg,total) 
	{
		if (total != undefined)	this.total = total;
		showPages =	this.total > this.max ?	this.max : this.total;
		startPage =	pg - this.max/2;

		while (startPage + showPages - 1 > this.total) startPage--;
		if (startPage <	1) startPage = 1;
		
		if (this.total<=0) 
			Element.hide(this.root);
		else
		{
			html = "";
			for(i =	startPage; i < startPage + showPages; i++)
			{
				if (html!="") html+=" ";
				html +=	"<li><a	";
				if (i==pg) html	+= "class='on' "
				html +=	"href='javascript:"+this.varname+".click("+i+");'>"+i+"</a></li>";
			}
			this.pages.update(html);

			Element.show(this.root);
			$(this.first, this.prev).invoke((pg>1)?'show':'hide');
			$(this.last, this.next).invoke((pg<this.total)?'show':'hide'); 
		}	
		this.selected=pg;
	}
,
	click: function(pg)
	{
		if (this.onpageclick) if (this.onpageclick.apply(this, [pg])==false) return;
		if (this.selected==pg) return;
		this.update(pg);
		if (this.onpagechanged) if (this.onpagechanged.apply(this, [pg])==false) return;
	}
});


/********************************************************* Alpha *********************************************************/
var	AjaxAlphaPager = Class.create();

Object.extend(AjaxAlphaPager, {
	pagers:[]
,
	updateAll: function(name,alpha)	{
		AjaxAlphaPager.pagers.each(function	(pager)	{
			if (pager.name==name) pager.update(alpha);
		});
	}
});

Object.extend(AjaxAlphaPager.prototype,	{
   initialize: function(root,props) {
		this.root =	$(root);
		this.name =	props.name;
		this.onpageclick = props.onpageclick;
		this.onpagechanged = props.onpagechanged;
		this.alpha = props.alpha;
		this.on = this.root.down("a.on");
		AjaxAlphaPager.pagers.push(this);
	}
,
	update:	function(alpha)
	{
		if(this.on) $(this.on).removeClassName("on");
		this.on=this.root.down("a."+(alpha==""?"all":alpha));
		this.alpha=alpha;
		if(this.on) $(this.on).addClassName("on");
	}
,
	click: function(alpha)
	{
		if (this.onpageclick) if (this.onpageclick.apply(this, [alpha])==false) return;
		if (this.alpha==alpha) return;
		this.update(alpha);
		if (this.onpagechanged)	if (this.onpagechanged.apply(this, [alpha])==false) return;
	}
});


/*****************************************************************************
scalable Inman Flash Replacement (sIFR) version 3, revision 436.

Copyright 2006 – 2008 Mark Wubben, <http://novemberborn.net/>

Older versions:
* IFR by Shaun Inman
* sIFR 1.0 by Mike Davidson, Shaun Inman and Tomas Jogin
* sIFR 2.0 by Mike Davidson, Shaun Inman, Tomas Jogin and Mark Wubben

See also <http://novemberborn.net/sifr3> and <http://wiki.novemberborn.net/sifr3>.

This software is licensed and provided under the CC-GNU LGPL.
See <http://creativecommons.org/licenses/LGPL/2.1/>
*****************************************************************************/

var sIFR = new function()
{
    var self = this;

    var ClassNames = {
        ACTIVE: 'sIFR-active',
        REPLACED: 'sIFR-replaced',
        IGNORE: 'sIFR-ignore',
        ALTERNATE: 'sIFR-alternate',
        CLASS: 'sIFR-class',
        LAYOUT: 'sIFR-layout',
        FLASH: 'sIFR-flash',
        FIX_FOCUS: 'sIFR-fixfocus',
        DUMMY: 'sIFR-dummy'
    };

    ClassNames.IGNORE_CLASSES = [ClassNames.REPLACED, ClassNames.IGNORE, ClassNames.ALTERNATE];

    this.MIN_FONT_SIZE = 6;
    this.MAX_FONT_SIZE = 126;
    this.FLASH_PADDING_BOTTOM = 5;
    this.VERSION = '436';

    this.isActive = false;
    this.isEnabled = true;
    this.fixHover = true;
    this.autoInitialize = true;
    this.setPrefetchCookie = true;
    this.cookiePath = '/';
    this.domains = [];
    this.forceWidth = true;
    this.fitExactly = false;
    this.forceTextTransform = true;
    this.useDomLoaded = true;
    this.useStyleCheck = false;
    this.hasFlashClassSet = false;
    this.repaintOnResize = true;
    this.replacements = [];

    var elementCount = 0; // The number of replaced elements.
    var isInitialized = false;

    function Errors()
    {
        this.fire = function(id)
        {
            if (this[id + 'Alert']) alert(this[id + 'Alert']);
            throw new Error(this[id]);
        };

        this.isFile = 'sIFR: Did not activate because the page is being loaded from the filesystem.';
        this.isFileAlert = 'Hi!\n\nThanks for using sIFR on your page. Unfortunately sIFR couldn\'t activate, because it was loaded '
                        + 'directly from your computer.\nDue to Flash security restrictions, you need to load sIFR through a web'
                        + ' server.\n\nWe apologize for the inconvenience.';
    };

    function Util(sIFR)
    {
        function capitalize($)
        {
            return $.toLocaleUpperCase();
        }

        this.normalize = function(str)
        {
            // Replace linebreaks and &nbsp; by whitespace, then normalize.
            // Flash doesn't support no-breaking space characters, hence they're replaced by a normal space.
            return str.replace(/\n|\r|\xA0/g, Util.SINGLE_WHITESPACE).replace(/\s+/g, Util.SINGLE_WHITESPACE);
        };

        this.textTransform = function(type, str)
        {
            switch (type)
            {
                case 'uppercase':
                    return str.toLocaleUpperCase();
                case 'lowercase':
                    return str.toLocaleLowerCase();
                case 'capitalize':
                    return str.replace(/^\w|\s\w/g, capitalize);
            }
            return str;
        };

        this.toHexString = function(str)
        {
            if (str.charAt(0) != '#' || str.length != 4 && str.length != 7) return str;

            str = str.substring(1);
            return '0x' + (str.length == 3 ? str.replace(/(.)(.)(.)/, '$1$1$2$2$3$3') : str);
        };

        this.toJson = function(obj, strFunc)
        {
            var json = '';

            switch (typeof (obj))
            {
                case 'string':
                    json = '"' + strFunc(obj) + '"';
                    break;
                case 'number':
                case 'boolean':
                    json = obj.toString();
                    break;
                case 'object':
                    json = [];
                    for (var prop in obj)
                    {
                        if (obj[prop] == Object.prototype[prop]) continue;
                        json.push('"' + prop + '":' + this.toJson(obj[prop]));
                    }
                    json = '{' + json.join(',') + '}';
                    break;
            }

            return json;
        };

        this.convertCssArg = function(arg)
        {
            if (!arg) return {};
            if (typeof (arg) == 'object')
            {
                if (arg.constructor == Array) arg = arg.join('');
                else return arg;
            }

            var obj = {};
            var rules = arg.split('}');

            for (var i = 0; i < rules.length; i++)
            {
                var $ = rules[i].match(/([^\s{]+)\s*\{(.+)\s*;?\s*/);
                if (!$ || $.length != 3) continue;

                if (!obj[$[1]]) obj[$[1]] = {};

                var properties = $[2].split(';');
                for (var j = 0; j < properties.length; j++)
                {
                    var $2 = properties[j].match(/\s*([^:\s]+)\s*\:\s*([^;]+)/);
                    if (!$2 || $2.length != 3) continue;
                    obj[$[1]][$2[1]] = $2[2].replace(/\s+$/, '');
                }
            }

            return obj;
        };

        this.extractFromCss = function(css, selector, property, remove)
        {
            var value = null;

            if (css && css[selector] && css[selector][property])
            {
                value = css[selector][property];
                if (remove) delete css[selector][property];
            }

            return value;
        };

        this.cssToString = function(arg)
        {
            var css = [];
            for (var selector in arg)
            {
                var rule = arg[selector];
                if (rule == Object.prototype[selector]) continue;

                css.push(selector, '{');
                for (var property in rule)
                {
                    if (rule[property] == Object.prototype[property]) continue;
                    var value = rule[property];
                    if (Util.UNIT_REMOVAL_PROPERTIES[property]) value = parseInt(value, 10);
                    css.push(property, ':', value, ';');
                }
                css.push('}');
            }

            return css.join('');
        };

        this.escape = function(str)
        {
            return escape(str).replace(/\+/g, '%2B');
        };

        this.encodeVars = function(vars)
        {
            return vars.join('&').replace(/%/g, '%25');
        };

        this.copyProperties = function(from, to)
        {
            for (var property in from)
            {
                if (to[property] === undefined) to[property] = from[property];
            }
            return to;
        };

        this.domain = function()
        {
            var domain = '';
            // When trying to access document.domain on a Google-translated page with Firebug, I got an exception. 
            // Try/catch to be safe.
            try { domain = document.domain } catch (e) { };
            return domain;
        };

        this.domainMatches = function(domain, match)
        {
            if (match == '*' || match == domain) return true;

            var wildcard = match.lastIndexOf('*');
            if (wildcard > -1)
            {
                match = match.substr(wildcard + 1);
                var matchPosition = domain.lastIndexOf(match);
                if (matchPosition > -1 && (matchPosition + match.length) == domain.length) return true;
            }

            return false;
        };

        this.uriEncode = function(s)
        {
            return encodeURI(decodeURIComponent(s));  // Decode first, in case the URI was already encoded.
        };

        this.delay = function(ms, func, scope)
        {
            var args = Array.prototype.slice.call(arguments, 3);
            setTimeout(function() { func.apply(scope, args) }, ms);
        };
    };

    Util.UNIT_REMOVAL_PROPERTIES = { leading: true, 'margin-left': true, 'margin-right': true, 'text-indent': true };
    Util.SINGLE_WHITESPACE = ' ';


    function DomUtil(sIFR)
    {
        var self = this;

        function getDimensionFromStyle(node, property, offsetProperty)
        {
            var dimension = self.getStyleAsInt(node, property, sIFR.ua.ie);
            if (dimension == 0)
            {
                dimension = node[offsetProperty];
                for (var i = 3; i < arguments.length; i++) dimension -= self.getStyleAsInt(node, arguments[i], true);
            }
            return dimension;
        }

        this.getBody = function()
        {
            return document.getElementsByTagName('body')[0] || null;
        };

        this.querySelectorAll = function(selector)
        {
            return window.parseSelector(selector);
        };

        this.addClass = function(name, node)
        {
            if (node) node.className = ((node.className || '') == '' ? '' : node.className + ' ') + name;
        };

        this.removeClass = function(name, node)
        {
            if (node) node.className = node.className.replace(new RegExp('(^|\\s)' + name + '(\\s|$)'), '').replace(/^\s+|(\s)\s+/g, '$1');
        };

        this.hasClass = function(name, node)
        {
            return new RegExp('(^|\\s)' + name + '(\\s|$)').test(node.className);
        };

        this.hasOneOfClassses = function(names, node)
        {
            for (var i = 0; i < names.length; i++)
            {
                if (this.hasClass(names[i], node)) return true;
            }
            return false;
        };

        this.ancestorHasClass = function(node, name)
        {
            node = node.parentNode;
            while (node && node.nodeType == 1)
            {
                if (this.hasClass(name, node)) return true;
                node = node.parentNode;
            }
            return false;
        };

        this.create = function(name, className)
        {
            var node = document.createElementNS ? document.createElementNS(DomUtil.XHTML_NS, name) : document.createElement(name);
            if (className) node.className = className;
            return node;
        };

        this.getComputedStyle = function(node, property)
        {
            var result;
            if (document.defaultView && document.defaultView.getComputedStyle)
            {
                var style = document.defaultView.getComputedStyle(node, null);
                result = style ? style[property] : null;
            } else
            {
                if (node.currentStyle) result = node.currentStyle[property];
            }
            return result || ''; // Ensuring a string.
        };

        this.getStyleAsInt = function(node, property, requirePx)
        {
            var value = this.getComputedStyle(node, property);
            if (requirePx && !/px$/.test(value)) return 0;
            return parseInt(value) || 0;
        };

        this.getWidthFromStyle = function(node)
        {
            return getDimensionFromStyle(node, 'width', 'offsetWidth', 'paddingRight', 'paddingLeft', 'borderRightWidth', 'borderLeftWidth');
        };

        this.getHeightFromStyle = function(node)
        {
            return getDimensionFromStyle(node, 'height', 'offsetHeight', 'paddingTop', 'paddingBottom', 'borderTopWidth', 'borderBottomWidth');
        };

        this.getDimensions = function(node)
        {
            var width = node.offsetWidth;
            var height = node.offsetHeight;

            if (width == 0 || height == 0)
            {
                for (var i = 0; i < node.childNodes.length; i++)
                {
                    var child = node.childNodes[i];
                    if (child.nodeType != 1) continue;
                    width = Math.max(width, child.offsetWidth);
                    height = Math.max(height, child.offsetHeight);
                }
            }

            return { width: width, height: height };
        };

        this.getViewport = function()
        {
            return {
                width: window.innerWidth || document.documentElement.clientWidth || this.getBody().clientWidth,
                height: window.innerHeight || document.documentElement.clientHeight || this.getBody().clientHeight
            };
        };

        this.blurElement = function(element)
        {
            try
            {
                element.blur();
                return;
            } catch (e) { };

            // Move the focus to an input element, and then destroy it.
            var input = this.create('input');
            input.style.width = '0px';
            input.style.height = '0px';
            element.parentNode.appendChild(input);
            input.focus();
            input.blur();
            input.parentNode.removeChild(input);
        };
    };

    DomUtil.XHTML_NS = 'http://www.w3.org/1999/xhtml';

    function UserAgentDetection(sIFR)
    {
        var ua = navigator.userAgent.toLowerCase();
        var product = (navigator.product || '').toLowerCase();
        var platform = navigator.platform.toLowerCase();

        this.parseVersion = UserAgentDetection.parseVersion;

        this.macintosh = /^mac/.test(platform);
        this.windows = /^win/.test(platform);
        this.linux = /^linux/.test(platform);
        this.quicktime = false;

        this.opera = /opera/.test(ua);
        this.konqueror = /konqueror/.test(ua);
        this.ie = false/*@cc_on || true@*/;
        this.ieSupported = this.ie && !/ppc|smartphone|iemobile|msie\s5\.5/.test(ua)/*@cc_on && @_jscript_version >= 5.5@*/
        this.ieWin = this.windows && this.ie/*@cc_on && @_jscript_version >= 5.1@*/;
        this.windows = this.windows && (!this.ie || this.ieWin);
        this.ieMac = this.macintosh && this.ie/*@cc_on && @_jscript_version < 5.1@*/;
        this.macintosh = this.macintosh && (!this.ie || this.ieMac);
        this.safari = /safari/.test(ua);
        this.webkit = !this.konqueror && /applewebkit/.test(ua);
        this.khtml = this.webkit || this.konqueror;
        this.gecko = !this.khtml && product == 'gecko';

        this.ieVersion = this.ie && /.*msie\s(\d\.\d)/.exec(ua) ? this.parseVersion(RegExp.$1) : '0';
        this.operaVersion = this.opera && /.*opera(\s|\/)(\d+\.\d+)/.exec(ua) ? this.parseVersion(RegExp.$2) : '0';
        this.webkitVersion = this.webkit && /.*applewebkit\/(\d+).*/.exec(ua) ? this.parseVersion(RegExp.$1) : '0';
        this.geckoVersion = this.gecko && /.*rv:\s*([^\)]+)\)\s+gecko/.exec(ua) ? this.parseVersion(RegExp.$1) : '0';
        this.konquerorVersion = this.konqueror && /.*konqueror\/([\d\.]+).*/.exec(ua) ? this.parseVersion(RegExp.$1) : '0';

        this.flashVersion = 0;

        if (this.ieWin)
        {
            var axo;
            var stop = false;
            try
            {
                axo = new ActiveXObject('ShockwaveFlash.ShockwaveFlash.7');
            } catch (e)
            {
                // In case the Flash 7 registry key does not exist, we need to test for specific 
                // Flash 6 installs before we can use the general key. 
                // See also <http://blog.deconcept.com/2006/01/11/getvariable-setvariable-crash-internet-explorer-flash-6/>.
                // Many thanks to Geoff Stearns and Bobby van der Sluis for clarifying the problem and providing
                // examples of non-crashing code.
                try
                {
                    axo = new ActiveXObject('ShockwaveFlash.ShockwaveFlash.6');
                    this.flashVersion = this.parseVersion('6');
                    axo.AllowScriptAccess = 'always';
                } catch (e) { stop = this.flashVersion == this.parseVersion('6'); }

                if (!stop) try { axo = new ActiveXObject('ShockwaveFlash.ShockwaveFlash'); } catch (e) { }
            }

            if (!stop && axo)
            {
                this.flashVersion = this.parseVersion((axo.GetVariable('$version') || '').replace(/^\D+(\d+)\D+(\d+)\D+(\d+).*/g, '$1.$2.$3'));
            }
        } else if (navigator.plugins && navigator.plugins['Shockwave Flash'])
        {
            var d = navigator.plugins['Shockwave Flash'].description.replace(/^.*\s+(\S+\s+\S+$)/, '$1');
            var v = d.replace(/^\D*(\d+\.\d+).*$/, '$1');
            if (/r/.test(d)) v += d.replace(/^.*r(\d*).*$/, '.$1');
            else if (/d/.test(d)) v += '.0';
            this.flashVersion = this.parseVersion(v);

            // Watch out for QuickTime, which could be stealing the Flash handling! Also check to make sure the plugin for the Flash
            // MIMEType is enabled.
            var foundEnabled = false;
            for (var i = 0, valid = this.flashVersion >= UserAgentDetection.MIN_FLASH_VERSION; valid && i < navigator.mimeTypes.length; i++)
            {
                var mime = navigator.mimeTypes[i];
                if (mime.type != 'application/x-shockwave-flash') continue;
                if (mime.enabledPlugin)
                {
                    foundEnabled = true;
                    if (mime.enabledPlugin.description.toLowerCase().indexOf('quicktime') > -1)
                    {
                        valid = false;
                        this.quicktime = true;
                    }
                }
            }

            if (this.quicktime || !foundEnabled) this.flashVersion = this.parseVersion('0');
        }
        this.flash = this.flashVersion >= UserAgentDetection.MIN_FLASH_VERSION;
        this.transparencySupport = this.macintosh || this.windows
                                               || this.linux && (
                                                    this.flashVersion >= this.parseVersion('10')
                                                    && (
                                                      this.gecko && this.geckoVersion >= this.parseVersion('1.9')
                                                      || this.opera
                                                    )
                                                  );
        this.computedStyleSupport = this.ie || !!document.defaultView.getComputedStyle;
        this.fixFocus = this.gecko && this.windows;
        this.nativeDomLoaded = this.gecko || this.webkit && this.webkitVersion >= this.parseVersion('525')
                                            || this.konqueror && this.konquerorMajor > this.parseVersion('03') || this.opera;
        this.mustCheckStyle = this.khtml || this.opera;
        this.forcePageLoad = this.webkit && this.webkitVersion < this.parseVersion('523')
        this.properDocument = typeof (document.location) == 'object';

        this.supported = this.flash && this.properDocument && (!this.ie || this.ieSupported) && this.computedStyleSupport
                                            && (!this.opera || this.operaVersion >= this.parseVersion('9.61'))
                                            && (!this.webkit || this.webkitVersion >= this.parseVersion('412'))
                                            && (!this.gecko || this.geckoVersion >= this.parseVersion('1.8.0.12'))
                                            && (!this.konqueror/* || this.konquerorVersion >= this.parseVersion('4.1')*/);
    };

    UserAgentDetection.parseVersion = function(s)
    {
        return s.replace(
      /(^|\D)(\d+)(?=\D|$)/g,
      function(s, nonDigit, digits)
      {
          s = nonDigit;
          for (var i = 4 - digits.length; i >= 0; i--) s += '0';
          return s + digits;
      }
    );
    };
    UserAgentDetection.MIN_FLASH_VERSION = UserAgentDetection.parseVersion('8');

    function FragmentIdentifier(sIFR)
    {
        this.fix = sIFR.ua.ieWin && window.location.hash != '';

        var cachedTitle;
        this.cache = function()
        {
            cachedTitle = document.title;
        };

        function doFix()
        {
            document.title = cachedTitle;
        }

        this.restore = function()
        {
            if (this.fix) setTimeout(doFix, 0);
        };
    };
    function PageLoad(sIFR)
    {
        var dummy = null;
        var unloaded = false;

        function pollLoad()
        {
            try
            {
                // IE hack courtesy of Diego Perini – <http://javascript.nwbox.com/IEContentLoaded/>.
                // Merged polling taken from jQuery – <http://dev.jquery.com/browser/trunk/jquery/src/event.js>
                if (sIFR.ua.ie || document.readyState != 'loaded' && document.readyState != 'complete')
                {
                    document.documentElement.doScroll('left');
                }
            } catch (e)
            {
                return setTimeout(pollLoad, 10);
            }
            afterDomLoad();
        };

        function afterDomLoad()
        {
            if (sIFR.useStyleCheck) checkStyle();
            else if (!sIFR.ua.mustCheckStyle) fire(null, true);
        };

        function checkStyle()
        {
            dummy = sIFR.dom.create("div", ClassNames.DUMMY);
            sIFR.dom.getBody().appendChild(dummy);
            pollStyle();
        };

        function pollStyle()
        {
            if (sIFR.dom.getComputedStyle(dummy, 'marginLeft') == '42px') afterStyle();
            else setTimeout(pollStyle, 10);
        };

        function afterStyle()
        {
            if (dummy && dummy.parentNode) dummy.parentNode.removeChild(dummy);
            dummy = null;
            fire(null, true);
        };

        function fire(evt, preserveReplacements)
        {
            sIFR.initialize(preserveReplacements);

            // Remove handlers to prevent memory leak in Firefox 1.5, but only after onload.
            if (evt && evt.type == 'load')
            {
                if (document.removeEventListener) document.removeEventListener('DOMContentLoaded', fire, false);
                if (window.removeEventListener) window.removeEventListener('load', fire, false);
            }
        };

        // Unload detection based on the research from Moxiecode. <http://blog.moxiecode.com/2008/04/08/unload-event-never-fires-in-ie/>
        function verifyUnload()
        {
            sIFR.prepareClearReferences();
            if (document.readyState == 'interactive')
            {
                document.attachEvent('onstop', unloadByStop);
                setTimeout(function() { document.detachEvent('onstop', unloadByStop) }, 0);
            }
        };

        function unloadByStop()
        {
            document.detachEvent('onstop', unloadByStop);
            fireUnload();
        };

        function fireUnload()
        {
            if (!unloaded)
            {
                sIFR.clearReferences();
            }
            unloaded = true;
        };

        this.attach = function()
        {
            if (window.addEventListener) window.addEventListener('load', fire, false);
            else window.attachEvent('onload', fire);

            if (!sIFR.useDomLoaded || sIFR.ua.forcePageLoad || sIFR.ua.ie && window.top != window) return;

            if (sIFR.ua.nativeDomLoaded)
            {
                document.addEventListener('DOMContentLoaded', afterDomLoad, false);
            } else if (sIFR.ua.ie || sIFR.ua.khtml)
            {
                pollLoad();
            }
        };

        this.attachUnload = function()
        {
            if (!sIFR.ua.ie) return;
            window.attachEvent('onbeforeunload', verifyUnload);
            window.attachEvent('onunload', fireUnload);
        }
    };

    var PREFETCH_COOKIE = 'sifrFetch';

    function Prefetch(sIFR)
    {
        var hasPrefetched = false;

        this.fetchMovies = function(movies)
        {
            if (sIFR.setPrefetchCookie && new RegExp(';?' + PREFETCH_COOKIE + '=true;?').test(document.cookie)) return;

            try
            { // We don't know which DOM actions the user agent will allow
                hasPrefetched = true;
                prefetch(movies);
            } catch (e) { }

            if (sIFR.setPrefetchCookie) document.cookie = PREFETCH_COOKIE + '=true;path=' + sIFR.cookiePath;
        };

        this.clear = function()
        {
            if (!hasPrefetched) return;

            try
            {
                var nodes = document.getElementsByTagName('script');
                for (var i = nodes.length - 1; i >= 0; i--)
                {
                    var node = nodes[i];
                    if (node.type == 'sifr/prefetch') node.parentNode.removeChild(node);
                }
            } catch (e) { }
        };

        function prefetch(args)
        {
            for (var i = 0; i < args.length; i++)
            {
                document.write('<scr' + 'ipt defer type="sifr/prefetch" src="' + args[i].src + '"></' + 'script>');
            }
        }
    };

    function BrokenFlashIE(sIFR)
    {
        var active = sIFR.ua.ie;
        var fixFlash = active && sIFR.ua.flashVersion < sIFR.ua.parseVersion('9.0.115');
        var resetMovies = {};
        var registry = {};

        this.fixFlash = fixFlash;

        this.register = function(flashNode)
        {
            if (!active) return;

            var id = flashNode.getAttribute('id');
            // Try cleaning up previous Flash <object>
            this.cleanup(id, false);

            registry[id] = flashNode;
            delete resetMovies[id];

            if (fixFlash) window[id] = flashNode;
        };

        this.reset = function()
        {
            if (!active) return false;

            for (var i = 0; i < sIFR.replacements.length; i++)
            {
                var flash = sIFR.replacements[i];
                var flashNode = registry[flash.id];
                if (!resetMovies[flash.id] && (!flashNode.parentNode || flashNode.parentNode.nodeType == 11))
                {
                    flash.resetMovie();
                    resetMovies[flash.id] = true;
                }
            }

            return true;
        };

        this.cleanup = function(id, usePlaceholder)
        {
            var node = registry[id];
            if (!node) return;

            for (var expando in node)
            {
                if (typeof (node[expando]) == 'function') node[expando] = null;
            }
            registry[id] = null;
            if (fixFlash) window[id] = null;

            if (node.parentNode)
            {
                if (usePlaceholder && node.parentNode.nodeType == 1)
                {
                    // Replace the Flash node by a placeholde element with the same dimensions. This stops the page from collapsing
                    // when the Flash movies are removed.
                    var placeholder = document.createElement('div');
                    placeholder.style.width = node.offsetWidth + 'px';
                    placeholder.style.height = node.offsetHeight + 'px';
                    node.parentNode.replaceChild(placeholder, node);
                } else
                {
                    node.parentNode.removeChild(node);
                }
            }
        };

        this.prepareClearReferences = function()
        {
            if (!fixFlash) return;

            // Disable Flash cleanup, see <http://blog.deconcept.com/2006/05/18/flash-player-bug-streaming-content-innerhtml-ie/>
            // for more info.
            __flash_unloadHandler = function() { };
            __flash_savedUnloadHandler = function() { };
        };

        this.clearReferences = function()
        {
            // Since we've disabled Flash' own cleanup, add all objects on the page to our registry so they can be cleaned up.
            if (fixFlash)
            {
                var objects = document.getElementsByTagName('object');
                for (var i = objects.length - 1; i >= 0; i--) registry[objects[i].getAttribute('id')] = objects[i];
            }

            for (var id in registry)
            {
                if (Object.prototype[id] != registry[id]) this.cleanup(id, true);
            }
        };
    }

    function FlashInteractor(sIFR, id, vars, forceWidth, events)
    {
        this.sIFR = sIFR;
        this.id = id;
        this.vars = vars;
        // Type of value depends on SWF builder. This could use some improvement!
        this.movie = null;

        this.__forceWidth = forceWidth;
        this.__events = events;
        this.__resizing = 0;
    }

    FlashInteractor.prototype = {
        getFlashElement: function()
        {
            return document.getElementById(this.id);
        },

        getAlternate: function()
        {
            return document.getElementById(this.id + '_alternate');
        },

        getAncestor: function()
        {
            var ancestor = this.getFlashElement().parentNode;
            return !this.sIFR.dom.hasClass(ClassNames.FIX_FOCUS, ancestor) ? ancestor : ancestor.parentNode;
        },

        available: function()
        {
            var flashNode = this.getFlashElement();
            return flashNode && flashNode.parentNode;
        },

        call: function(type)
        {
            var flashNode = this.getFlashElement();

            if (!flashNode[type])
            {
                return false;
            }
            // In Firefox 2, exposed Flash methods aren't proper functions, there's no `apply()` method! This workaround
            // does work, though.
            return Function.prototype.apply.call(flashNode[type], flashNode, Array.prototype.slice.call(arguments, 1));
        },

        attempt: function()
        {
            if (!this.available()) return false;

            try
            {
                this.call.apply(this, arguments);
            } catch (e)
            {
                if (this.sIFR.debug) throw e;
                return false;
            }

            return true;
        },

        updateVars: function(name, value)
        {
            for (var i = 0; i < this.vars.length; i++)
            {
                if (this.vars[i].split('=')[0] == name)
                {
                    this.vars[i] = name + '=' + value;
                    break;
                }
            }

            var vars = this.sIFR.util.encodeVars(this.vars);
            this.movie.injectVars(this.getFlashElement(), vars);
            this.movie.injectVars(this.movie.html, vars);
        },

        storeSize: function(type, value)
        {
            this.movie.setSize(type, value);
            this.updateVars(type, value);
        },

        fireEvent: function(name)
        {
            if (this.available() && this.__events[name]) this.sIFR.util.delay(0, this.__events[name], this, this);
        },

        resizeFlashElement: function(height, width, firstResize)
        {
            if (!this.available()) return;

            this.__resizing++;

            var flashNode = this.getFlashElement();
            flashNode.setAttribute('height', height);

            // Reset element height as declared by `MovieCreator`
            this.getAncestor().style.minHeight = '';

            this.updateVars('renderheight', height);
            this.storeSize('height', height);
            if (width !== null)
            {
                flashNode.setAttribute('width', width);
                // Don't store the size, it may cause Flash to wrap the text when the movie is reset.
                this.movie.setSize('width', width);
            }
            if (this.__events.onReplacement)
            {
                this.sIFR.util.delay(0, this.__events.onReplacement, this, this);
                delete this.__events.onReplacement;
            }

            if (firstResize)
            {
                this.sIFR.util.delay(0, function()
                {
                    this.attempt('scaleMovie');
                    this.__resizing--;
                }, this);
            } else
            {
                this.__resizing--;
            }
        },

        blurFlashElement: function()
        {
            if (this.available()) this.sIFR.dom.blurElement(this.getFlashElement());
        },

        resetMovie: function()
        {
            this.sIFR.util.delay(0, this.movie.reset, this.movie, this.getFlashElement(), this.getAlternate());
        },

        resizeAfterScale: function()
        {
            if (this.available() && this.__resizing == 0) this.sIFR.util.delay(0, this.resize, this);
        },

        resize: function()
        {
            if (!this.available()) return;

            this.__resizing++;

            var flashNode = this.getFlashElement();
            var currentWidth = flashNode.offsetWidth;

            // The Flash movie has no dimensions, which means it's not visible anyway. No need to recalculate.
            if (currentWidth == 0) return;

            var originalWidth = flashNode.getAttribute('width');
            var originalHeight = flashNode.getAttribute('height');

            var ancestor = this.getAncestor();
            var minHeight = this.sIFR.dom.getHeightFromStyle(ancestor);

            // Remove Flash movie from flow
            flashNode.style.width = '1px';
            flashNode.style.height = '1px';

            // Set a minimal height on the flashNode's parent, to stop a reflow
            ancestor.style.minHeight = minHeight + 'px';

            // Restore original content
            var nodes = this.getAlternate().childNodes;
            var clones = [];
            for (var i = 0; i < nodes.length; i++)
            {
                var node = nodes[i].cloneNode(true);
                clones.push(node);
                ancestor.appendChild(node);
            }

            // Calculate width
            var width = this.sIFR.dom.getWidthFromStyle(ancestor);

            // Remove original content again
            for (var i = 0; i < clones.length; i++) ancestor.removeChild(clones[i]);

            // Reset Flash movie flow
            flashNode.style.width = flashNode.style.height = ancestor.style.minHeight = '';
            flashNode.setAttribute('width', this.__forceWidth ? width : originalWidth);
            flashNode.setAttribute('height', originalHeight);

            // IE can get mightily confused about where to draw the Flash <object>. This is a workaround to force IE to repaint
            // the <object>.
            if (sIFR.ua.ie)
            {
                flashNode.style.display = 'none';
                var repaint = flashNode.offsetHeight;
                flashNode.style.display = '';
            }

            // Resize!
            if (width != currentWidth)
            {
                if (this.__forceWidth) this.storeSize('width', width);
                this.attempt('resize', width);
            }

            this.__resizing--;
        },

        // `content` must not be util.escaped when passed in.
        // alternate may be an array of nodes to be appended to the alternate content, use this
        // in XHTML documents.
        replaceText: function(content, alternate)
        {
            var escapedContent = this.sIFR.util.escape(content);
            if (!this.attempt('replaceText', escapedContent)) return false;

            this.updateVars('content', escapedContent);
            var node = this.getAlternate();
            if (alternate)
            {
                while (node.firstChild) node.removeChild(node.firstChild);
                for (var i = 0; i < alternate.length; i++) node.appendChild(alternate[i]);
            } else
            {
                try { node.innerHTML = content; } catch (e) { };
            }

            return true;
        },

        changeCSS: function(css)
        {
            css = this.sIFR.util.escape(this.sIFR.util.cssToString(this.sIFR.util.convertCssArg(css)));
            this.updateVars('css', css);
            return this.attempt('changeCSS', css);
        },

        remove: function()
        {
            if (this.movie && this.available()) this.movie.remove(this.getFlashElement(), this.id);
        }
    };

    var MovieCreator = new function()
    {
        this.create = function(sIFR, brokenFlash, node, fixFocus, id, src, width, height, vars, wmode, backgroundColor)
        {
            var klass = sIFR.ua.ie ? IEFlashMovie : FlashMovie;
            return new klass(
        sIFR, brokenFlash, node, fixFocus,
        id, src, width, height,
        ['flashvars', vars, 'wmode', wmode, 'bgcolor', backgroundColor, 'allowScriptAccess', 'always', 'quality', 'best']
      );
        }

        function FlashMovie(sIFR, brokenFlash, node, fixFocus, id, src, width, height, params)
        {
            var object = sIFR.dom.create('object', ClassNames.FLASH);
            var attrs = ['type', 'application/x-shockwave-flash', 'id', id, 'name', id, 'data', src, 'width', width, 'height', height];
            for (var i = 0; i < attrs.length; i += 2) object.setAttribute(attrs[i], attrs[i + 1]);

            var insertion = object;
            if (fixFocus)
            {
                insertion = dom.create("div", ClassNames.FIX_FOCUS);
                insertion.appendChild(object);
            }

            for (var i = 0; i < params.length; i += 2)
            {
                if (params[i] == 'name') continue;

                var param = dom.create('param');
                param.setAttribute('name', params[i]);
                param.setAttribute('value', params[i + 1]);
                object.appendChild(param);
            }

            // Before removing the existing content, set its height such that the element
            // does not collapse. Height is restored in `FlashInteractor#resizeFlashElement`.
            node.style.minHeight = height + 'px';

            while (node.firstChild) node.removeChild(node.firstChild);
            node.appendChild(insertion);

            this.html = insertion.cloneNode(true);
        }

        FlashMovie.prototype = {
            reset: function(flashNode, alternate)
            {
                flashNode.parentNode.replaceChild(this.html.cloneNode(true), flashNode);
            },

            remove: function(flashNode, id)
            {
                flashNode.parentNode.removeChild(flashNode);
            },

            setSize: function(type, value)
            {
                this.html.setAttribute(type, value);
            },

            injectVars: function(flash, encodedVars)
            {
                var params = flash.getElementsByTagName('param');
                for (var i = 0; i < params.length; i++)
                {
                    if (params[i].getAttribute('name') == 'flashvars')
                    {
                        params[i].setAttribute('value', encodedVars);
                        break;
                    }
                }
            }
        };

        function IEFlashMovie(sIFR, brokenFlash, node, fixFocus, id, src, width, height, params)
        {
            this.dom = sIFR.dom;
            this.broken = brokenFlash;

            this.html = '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="' + id +
        '" width="' + width + '" height="' + height + '" class="' + ClassNames.FLASH + '">' +
        '<param name="movie" value="' + src + '"></param></object>'
        ;
            var paramsHtml = '';
            for (var i = 0; i < params.length; i += 2)
            {
                paramsHtml += '<param name="' + params[i] + '" value="' + params[i + 1] + '"></param>';
            }
            this.html = this.html.replace(/(<\/object>)/, paramsHtml + '$1');

            // Before removing the existing content, set its height such that the element
            // does not collapse. Height is restored in `FlashInteractor#resizeFlashElement`.
            node.style.minHeight = height + 'px';

            node.innerHTML = this.html;

            this.broken.register(node.firstChild);
        }

        IEFlashMovie.prototype = {
            reset: function(flashNode, alternate)
            {
                alternate = alternate.cloneNode(true);
                var parent = flashNode.parentNode;
                parent.innerHTML = this.html;
                this.broken.register(parent.firstChild);
                parent.appendChild(alternate);
            },

            remove: function(flashNode, id)
            {
                this.broken.cleanup(id);
            },

            setSize: function(type, value)
            {
                this.html = this.html.replace(type == 'height' ? /(height)="\d+"/ : /(width)="\d+"/, '$1="' + value + '"');
            },

            injectVars: function(flash, encodedVars)
            {
                if (flash != this.html) return;
                this.html = this.html.replace(/(flashvars(=|\"\svalue=)\")[^\"]+/, '$1' + encodedVars);
            }
        };
    }

    this.errors = new Errors(self);
    var util = this.util = new Util(self);
    var dom = this.dom = new DomUtil(self);
    var ua = this.ua = new UserAgentDetection(self);
    var hacks = {
        fragmentIdentifier: new FragmentIdentifier(self),
        pageLoad: new PageLoad(self),
        prefetch: new Prefetch(self),
        brokenFlashIE: new BrokenFlashIE(self)
    };
    this.__resetBrokenMovies = hacks.brokenFlashIE.reset;

    var replaceKwargsStore = {
        kwargs: [],
        replaceAll: function(preserve)
        {
            for (var i = 0; i < this.kwargs.length; i++) self.replace(this.kwargs[i]);
            if (!preserve) this.kwargs = [];
        }
    };

    this.activate = function(/* … */)
    {
        if (!ua.supported || !this.isEnabled || this.isActive || !isValidDomain() || isFile()) return;
        hacks.prefetch.fetchMovies(arguments);

        this.isActive = true;
        this.setFlashClass();
        hacks.fragmentIdentifier.cache();
        hacks.pageLoad.attachUnload();

        if (!this.autoInitialize) return;

        hacks.pageLoad.attach();
    };

    this.setFlashClass = function()
    {
        if (this.hasFlashClassSet) return;

        dom.addClass(ClassNames.ACTIVE, dom.getBody() || document.documentElement);
        this.hasFlashClassSet = true;
    };

    this.removeFlashClass = function()
    {
        if (!this.hasFlashClassSet) return;

        dom.removeClass(ClassNames.ACTIVE, dom.getBody());
        dom.removeClass(ClassNames.ACTIVE, document.documentElement);
        this.hasFlashClassSet = false;
    };

    this.initialize = function(preserveReplacements)
    {
        if (!this.isActive || !this.isEnabled) return;
        if (isInitialized)
        {
            if (!preserveReplacements) replaceKwargsStore.replaceAll(false);
            return;
        }

        isInitialized = true;
        replaceKwargsStore.replaceAll(preserveReplacements);

        if (self.repaintOnResize)
        {
            if (window.addEventListener) window.addEventListener('resize', resize, false);
            else window.attachEvent('onresize', resize);
        }

        hacks.prefetch.clear();
    };

    this.replace = function(kwargs, mergeKwargs)
    {
        if (!ua.supported) return;

        // This lets you specify two kwarg objects so you don't have to repeat common settings.
        // The first object will be merged with the second, while properties in the second 
        // object have priority over those in the first. The first object is unmodified
        // for further use, the resulting second object will be used in the replacement.
        if (mergeKwargs) kwargs = util.copyProperties(kwargs, mergeKwargs);

        if (!isInitialized) return replaceKwargsStore.kwargs.push(kwargs);

        if (this.onReplacementStart) this.onReplacementStart(kwargs);

        var nodes = kwargs.elements || dom.querySelectorAll(kwargs.selector);
        if (nodes.length == 0) return;

        var src = getSource(kwargs.src);
        var css = util.convertCssArg(kwargs.css);
        var filters = getFilters(kwargs.filters);

        var forceSingleLine = kwargs.forceSingleLine === true;
        var preventWrap = kwargs.preventWrap === true && !forceSingleLine;
        var fitExactly = forceSingleLine || (kwargs.fitExactly == null ? this.fitExactly : kwargs.fitExactly) === true;
        var forceWidth = fitExactly || (kwargs.forceWidth == null ? this.forceWidth : kwargs.forceWidth) === true;
        var ratios = kwargs.ratios || [];
        var pixelFont = kwargs.pixelFont === true;
        var tuneHeight = parseInt(kwargs.tuneHeight) || 0;
        var events = !!kwargs.onRelease || !!kwargs.onRollOver || !!kwargs.onRollOut;

        // Alignment should be handled by the browser in this case.
        if (fitExactly) util.extractFromCss(css, '.sIFR-root', 'text-align', true);

        var fontSize = util.extractFromCss(css, '.sIFR-root', 'font-size', true) || '0';
        var backgroundColor = util.extractFromCss(css, '.sIFR-root', 'background-color', true) || '#FFFFFF';
        var kerning = util.extractFromCss(css, '.sIFR-root', 'kerning', true) || '';
        var opacity = util.extractFromCss(css, '.sIFR-root', 'opacity', true) || '100';
        var cursor = util.extractFromCss(css, '.sIFR-root', 'cursor', true) || 'default';
        var leading = parseInt(util.extractFromCss(css, '.sIFR-root', 'leading')) || 0;
        var gridFitType = kwargs.gridFitType ||
                            (util.extractFromCss(css, '.sIFR-root', 'text-align') == 'right') ? 'subpixel' : 'pixel';
        var textTransform = this.forceTextTransform === false
                            ? 'none'
                            : util.extractFromCss(css, '.sIFR-root', 'text-transform', true) || 'none';
        // Only font sizes specified in pixels are supported.
        fontSize = /^\d+(px)?$/.test(fontSize) ? parseInt(fontSize) : 0;
        // Make sure to support percentages and decimals
        opacity = parseFloat(opacity) < 1 ? 100 * parseFloat(opacity) : opacity;

        var cssText = kwargs.modifyCss ? '' : util.cssToString(css);
        var wmode = kwargs.wmode || '';
        if (!wmode)
        {
            if (kwargs.transparent) wmode = 'transparent';
            else if (kwargs.opaque) wmode = 'opaque';
        }
        if (wmode == 'transparent')
        {
            if (!ua.transparencySupport) wmode = 'opaque';
            else backgroundColor = 'transparent';
        } else if (backgroundColor == 'transparent')
        {
            backgroundColor = '#FFFFFF';
        }

        for (var i = 0; i < nodes.length; i++)
        {
            var node = nodes[i];

            if (dom.hasOneOfClassses(ClassNames.IGNORE_CLASSES, node) || dom.ancestorHasClass(node, ClassNames.ALTERNATE)) continue;

            // Opera does not allow communication with hidden Flash movies. Visibility is tackled by sIFR itself, but
            // `display:none` isn't. Additionally, WebKit does not return computed style information for elements with
            // `display:none`. We'll prevent elements which have `display:none` or are contained in such an element from
            // being replaced. It's a bit hard to detect this, but we'll check for the dimensions of the element and its
            // `display` property.

            var dimensions = dom.getDimensions(node);
            var height = dimensions.height;
            var width = dimensions.width;
            var display = dom.getComputedStyle(node, 'display');

            if (!height || !width || !display || display == 'none') continue;

            // Get the width (to approximate the final size).
            width = dom.getWidthFromStyle(node);

            var size, lines;
            if (!fontSize)
            {
                var calculation = calculate(node);
                size = Math.min(this.MAX_FONT_SIZE, Math.max(this.MIN_FONT_SIZE, calculation.fontSize));
                if (pixelFont) size = Math.max(8, 8 * Math.round(size / 8));

                lines = calculation.lines;
            } else
            {
                size = fontSize;
                lines = 1;
            }

            var alternate = dom.create('span', ClassNames.ALTERNATE);
            // Clone the original content to the alternate element.
            var contentNode = node.cloneNode(true);
            // Temporarily append the contentNode to the document, to get around IE problems with resolved hrefs
            node.parentNode.appendChild(contentNode);
            for (var j = 0, l = contentNode.childNodes.length; j < l; j++)
            {
                var child = contentNode.childNodes[j];
                // Let's not keep <style> or <script> in the alternate content, since it may be
                // reintroduced to the DOM after resizing.
                if (!/^(style|script)$/i.test(child.nodeName))
                {
                    alternate.appendChild(child.cloneNode(true));
                }
            }

            // Allow the sIFR content to be modified
            if (kwargs.modifyContent) kwargs.modifyContent(contentNode, kwargs.selector);
            if (kwargs.modifyCss) cssText = kwargs.modifyCss(css, contentNode, kwargs.selector);

            var content = parseContent(contentNode, textTransform, kwargs.uriEncode);
            // Remove the contentNode again
            contentNode.parentNode.removeChild(contentNode);
            if (kwargs.modifyContentString) content.text = kwargs.modifyContentString(content.text, kwargs.selector);
            if (content.text == '') continue;

            // Approximate the final height to avoid annoying movements of the page
            var renderHeight = Math.round(lines * getRatio(size, ratios) * size) + this.FLASH_PADDING_BOTTOM + tuneHeight;
            if (lines > 1 && leading)
            {
                renderHeight += Math.round((lines - 1) * leading);
            }

            var forcedWidth = forceWidth ? width : '100%';

            var id = 'sIFR_replacement_' + elementCount++;
            var vars = ['id=' + id,
                  'content=' + util.escape(content.text),
                  'width=' + width,
                  'renderheight=' + renderHeight,
                  'link=' + util.escape(content.primaryLink.href || ''),
                  'target=' + util.escape(content.primaryLink.target || ''),
                  'size=' + size,
                  'css=' + util.escape(cssText),
                  'cursor=' + cursor,
                  'tunewidth=' + (kwargs.tuneWidth || 0),
                  'tuneheight=' + tuneHeight,
                  'offsetleft=' + (kwargs.offsetLeft || ''),
                  'offsettop=' + (kwargs.offsetTop || ''),
                  'fitexactly=' + fitExactly,
                  'preventwrap=' + preventWrap,
                  'forcesingleline=' + forceSingleLine,
                  'antialiastype=' + (kwargs.antiAliasType || ''),
                  'thickness=' + (kwargs.thickness || ''),
                  'sharpness=' + (kwargs.sharpness || ''),
                  'kerning=' + kerning,
                  'gridfittype=' + gridFitType,
                  'flashfilters=' + filters,
                  'opacity=' + opacity,
                  'blendmode=' + (kwargs.blendMode || ''),
                  'selectable=' + (kwargs.selectable == null || wmode != '' && !sIFR.ua.macintosh && sIFR.ua.gecko && sIFR.ua.geckoVersion >= sIFR.ua.parseVersion('1.9')
                                         ? 'true'
                                         : kwargs.selectable === true
                                       ),
                  'fixhover=' + (this.fixHover === true),
                  'events=' + events,
                  'delayrun=' + hacks.brokenFlashIE.fixFlash,
                  'version=' + this.VERSION];

            var encodedVars = util.encodeVars(vars);
            var interactor = new FlashInteractor(self, id, vars, forceWidth, {
                onReplacement: kwargs.onReplacement,
                onRollOver: kwargs.onRollOver,
                onRollOut: kwargs.onRollOut,
                onRelease: kwargs.onRelease
            });
            interactor.movie = MovieCreator.create(
        sIFR, hacks.brokenFlashIE, node, ua.fixFocus && kwargs.fixFocus,
        id, src, forcedWidth, renderHeight,
        encodedVars, wmode, backgroundColor
      );
            this.replacements.push(interactor);
            this.replacements[id] = interactor;
            if (kwargs.selector)
            {
                if (!this.replacements[kwargs.selector]) this.replacements[kwargs.selector] = [interactor];
                else this.replacements[kwargs.selector].push(interactor);
            }
            alternate.setAttribute('id', id + '_alternate');
            node.appendChild(alternate);
            dom.addClass(ClassNames.REPLACED, node);
        }

        hacks.fragmentIdentifier.restore();
    };

    this.getReplacementByFlashElement = function(node)
    {
        for (var i = 0; i < self.replacements.length; i++)
        {
            if (self.replacements[i].id == node.getAttribute('id')) return self.replacements[i];
        }
    };

    this.redraw = function()
    {
        for (var i = 0; i < self.replacements.length; i++) self.replacements[i].resetMovie();
    };

    this.prepareClearReferences = function()
    {
        hacks.brokenFlashIE.prepareClearReferences();
    };

    this.clearReferences = function()
    {
        hacks.brokenFlashIE.clearReferences();
        hacks = null;
        replaceKwargsStore = null;
        delete self.replacements;
    };

    // The goal here is not to prevent usage of the Flash movie, but running sIFR on possibly translated pages
    function isValidDomain()
    {
        if (self.domains.length == 0) return true;

        var domain = util.domain();
        for (var i = 0; i < self.domains.length; i++)
        {
            if (util.domainMatches(domain, self.domains[i]))
            {
                return true;
            }
        }

        return false;
    }

    function isFile()
    {
        if (document.location.protocol == 'file:')
        {
            if (self.debug) self.errors.fire('isFile');
            return true;
        }
        return false;
    }

    function getSource(src)
    {
        if (ua.ie && src.charAt(0) == '/')
        {
            src = window.location.toString().replace(/([^:]+)(:\/?\/?)([^\/]+).*/, '$1$2$3') + src;
        }

        return src;
    }

    // Gives a font-size to required vertical space ratio
    function getRatio(size, ratios)
    {
        for (var i = 0; i < ratios.length; i += 2)
        {
            if (size <= ratios[i]) return ratios[i + 1];
        }
        return ratios[ratios.length - 1] || 1;
    }

    function getFilters(obj)
    {
        var filters = [];
        for (var filter in obj)
        {
            if (obj[filter] == Object.prototype[filter]) continue;

            var properties = obj[filter];
            filter = [filter.replace(/filter/i, '') + 'Filter'];

            for (var property in properties)
            {
                if (properties[property] == Object.prototype[property]) continue;
                // Double-escaping (see end of function) makes it easier to parse the resulting string
                // in AS.
                filter.push(property + ':' + util.escape(util.toJson(properties[property], util.toHexString)));
            }

            filters.push(filter.join(','));
        }

        return util.escape(filters.join(';'));
    }

    function resize(evt)
    {
        var current = resize.viewport;
        var viewport = dom.getViewport();

        if (current && viewport.width == current.width && viewport.height == current.height) return;
        resize.viewport = viewport;

        if (self.replacements.length == 0) return; // Nothing replaced yet, resize event is not important.

        if (resize.timer) clearTimeout(resize.timer);
        resize.timer = setTimeout(function()
        {
            delete resize.timer;
            for (var i = 0; i < self.replacements.length; i++) self.replacements[i].resize();
        }, 200);
    }

    function calculate(node)
    {
        var fontSize = dom.getComputedStyle(node, 'fontSize');
        var deduce = fontSize.indexOf('px') == -1;

        var html = node.innerHTML;
        if (deduce)
        {
            node.innerHTML = 'X';
        }

        // Reset padding and border, so offsetHeight works properly
        node.style.paddingTop = node.style.paddingBottom = node.style.borderTopWidth = node.style.borderBottomWidth = '0px';
        // 2em magically makes offsetHeight correct in IE
        node.style.lineHeight = '2em';
        // Provided display is block
        node.style.display = 'block';

        fontSize = deduce ? node.offsetHeight / 2 : parseInt(fontSize, 10);

        if (deduce)
        {
            node.innerHTML = html;
        }

        var lines = Math.round(node.offsetHeight / (2 * fontSize));

        node.style.paddingTop = node.style.paddingBottom = node.style.borderTopWidth = node.style.borderBottomWidth
                          = node.style.lineHeight = node.style.display = '';

        if (isNaN(lines) || !isFinite(lines) || lines == 0)
        {
            lines = 1;
        }

        return { fontSize: fontSize, lines: lines };
    }

    function parseContent(source, textTransform, uriEncode)
    {
        uriEncode = uriEncode || util.uriEncode;
        var stack = [], content = [];
        var primaryLink = null;
        var nodes = source.childNodes;
        var whiteSpaceEnd = false, firstText = false;

        var i = 0;
        while (i < nodes.length)
        {
            var node = nodes[i];

            if (node.nodeType == 3)
            {
                var text = util.textTransform(textTransform, util.normalize(node.nodeValue)).replace(/</g, '&lt;');
                if (whiteSpaceEnd && firstText) text = text.replace(/^\s+/, '');
                content.push(text);
                whiteSpaceEnd = /\s$/.test(text);
                firstText = false;
            }

            if (node.nodeType == 1 && !/^(style|script)$/i.test(node.nodeName))
            {
                var attributes = [];
                var nodeName = node.nodeName.toLowerCase();
                var className = node.className || '';
                // If there are multiple classes, look for the specified sIFR class
                if (/\s+/.test(className))
                {
                    if (className.indexOf(ClassNames.CLASS) > -1) className = className.match('(\\s|^)' + ClassNames.CLASS + '-([^\\s$]*)(\\s|$)')[2];
                    // or use the first class. This is because Flash does not support the use of multiple class names.
                    // Flash doesn't support IDs either.
                    else className = className.match(/^([^\s]+)/)[1];
                }
                if (className != '') attributes.push('class="' + className + '"');

                if (nodeName == 'a')
                {
                    var href = uriEncode(node.getAttribute('href') || '');
                    var target = node.getAttribute('target') || '';
                    attributes.push('href="' + href + '"', 'target="' + target + '"');

                    if (!primaryLink)
                    {
                        primaryLink = {
                            href: href,
                            target: target
                        };
                    }
                }

                content.push('<' + nodeName + (attributes.length > 0 ? ' ' : '') + attributes.join(' ') + '>');
                firstText = true;

                if (node.hasChildNodes())
                {
                    // Push the current index to the stack and prepare to iterate
                    // over the childNodes.
                    stack.push(i);
                    i = 0;
                    nodes = node.childNodes;
                    continue;
                } else if (!/^(br|img)$/i.test(node.nodeName)) content.push('</', node.nodeName.toLowerCase(), '>');
            }

            if (stack.length > 0 && !node.nextSibling)
            {
                // Iterating the childNodes has been completed. Go back to the position
                // before we started the iteration. If that position was the last child,
                // go back even further.
                do
                {
                    i = stack.pop();
                    nodes = node.parentNode.parentNode.childNodes;
                    node = nodes[i];
                    if (node) content.push('</', node.nodeName.toLowerCase(), '>');
                } while (i == nodes.length - 1 && stack.length > 0);
            }

            i++;
        }

        return { text: content.join('').replace(/^\s+|\s+$|\s*(<br>)\s*/g, '$1'), primaryLink: primaryLink || {} };
    }
};

/*=:project
parseSelector 2.0.2
    
=:description
Provides an extensible way of parsing CSS selectors against a DOM in 
JavaScript.

=:file
Copyright: 2006-2008 Mark Wubben.
Author: Mark Wubben, <http://novemberborn.net/>
       
=:license
This software is licensed and provided under the CC-GNU LGPL. 
See <http://creativecommons.org/licenses/LGPL/2.1/>
    
=:support
parseSelector supports the following user agents:
* Internet Explorer 6 and above
* Firefox 1.0 and above, and equivalent Gecko engine versions
* Safari 2.0 and above
* Opera 8.0 and above
* Konqueror 3.5.5 and above
It might work in other browsers and versions, but there are no guarantees. There is
no verification made when parseSelector is run to ascertain the browser is supported.
  
=:notes
The parsing of CSS selectors as streams has been based on Dean Edwards
excellent work with cssQuery. See <http://dean.edwards.name/my/cssQuery/>
for more info.
*/

var parseSelector = (function()
{
    var SEPERATOR = /\s*,\s*/
    var WHITESPACE = /\s*([\s>+~(),]|^|$)\s*/g;
    var IMPLIED_ALL = /([\s>+~,]|[^(]\+|^)([#.:@])/g;
    var STANDARD_SELECT = /(^|\))[^\s>+~]/g;
    var INSERT_SPACE = /(\)|^)/;
    var STREAM = /[\s#.:>+~()@]|[^\s#.:>+~()@]+/g;

    function parseSelector(selector, node)
    {
        node = node || document.documentElement;
        var argSelectors = selector.split(SEPERATOR), result = [];

        for (var i = 0; i < argSelectors.length; i++)
        {
            var nodes = [node], stream = toStream(argSelectors[i]);
            for (var j = 0; j < stream.length; )
            {
                var token = stream[j++], filter = stream[j++], args = '';
                if (stream[j] == '(')
                {
                    while (stream[j++] != ')' && j < stream.length) args += stream[j];
                    args = args.slice(0, -1);
                }
                nodes = select(nodes, token, filter, args);
            }
            result = result.concat(nodes);
        }

        return result;
    }

    function toStream(selector)
    {
        var stream = selector.replace(WHITESPACE, '$1').replace(IMPLIED_ALL, '$1*$2').replace(STANDARD_SELECT, insertSpaces);
        return stream.match(STREAM) || [];
    }

    function insertSpaces(str)
    {
        return str.replace(INSERT_SPACE, '$1 ');
    }

    function select(nodes, token, filter, args)
    {
        return (parseSelector.selectors[token]) ? parseSelector.selectors[token](nodes, filter, args) : [];
    }

    var util = {
        toArray: function(enumerable)
        {
            var a = [];
            for (var i = 0; i < enumerable.length; i++) a.push(enumerable[i]);
            return a;
        }
    };

    var dom = {
        isTag: function(node, tag)
        {
            return (tag == '*') || (tag.toLowerCase() == node.nodeName.toLowerCase());
        },

        previousSiblingElement: function(node)
        {
            do node = node.previousSibling; while (node && node.nodeType != 1);
            return node;
        },

        nextSiblingElement: function(node)
        {
            do node = node.nextSibling; while (node && node.nodeType != 1);
            return node;
        },

        hasClass: function(name, node)
        {
            return (node.className || '').match('(^|\\s)' + name + '(\\s|$)');
        },

        getByTag: function(tag, node)
        {
            return node.getElementsByTagName(tag);
        }
    };

    var selectors = {
        '#': function(nodes, filter)
        {
            for (var i = 0; i < nodes.length; i++)
            {
                if (nodes[i].getAttribute('id') == filter) return [nodes[i]];
            }
            return [];
        },

        ' ': function(nodes, filter)
        {
            var result = [];
            for (var i = 0; i < nodes.length; i++)
            {
                result = result.concat(util.toArray(dom.getByTag(filter, nodes[i])));
            }
            return result;
        },

        '>': function(nodes, filter)
        {
            var result = [];
            for (var i = 0, node; i < nodes.length; i++)
            {
                node = nodes[i];
                for (var j = 0, child; j < node.childNodes.length; j++)
                {
                    child = node.childNodes[j];
                    if (child.nodeType == 1 && dom.isTag(child, filter)) result.push(child);
                }
            }
            return result;
        },

        '.': function(nodes, filter)
        {
            var result = [];
            for (var i = 0, node; i < nodes.length; i++)
            {
                node = nodes[i];
                if (dom.hasClass([filter], node)) result.push(node);
            }
            return result;
        },

        ':': function(nodes, filter, args)
        {
            return (parseSelector.pseudoClasses[filter]) ? parseSelector.pseudoClasses[filter](nodes, args) : [];
        }

    };

    parseSelector.selectors = selectors;
    parseSelector.pseudoClasses = {};
    parseSelector.util = util;
    parseSelector.dom = dom;

    return parseSelector;
})();


TextTabs = function(elem, name) {
	this.root = $(elem);
	if (!this.root) return;
	this.kids = [];
	this.selected = null;
	this.name = name;
		
	this.setCurrent = function(index, f) {
		if (f != undefined && !f()) return false;
		if (this.selected) Element.removeClassName(this.selected, "active");
		this.selected = this.kids[index];
		Element.addClassName(this.selected, "active");
		//AjaxState.setValue(this.name,index?index:null);
		return true;
	}
		
	for (var i = 0; i < this.root.childNodes.length; i++) {
		if (this.root.childNodes[i].nodeType == 1) {
			node = this.root.childNodes[i];
			if (Element.hasClassName(node, "active")) this.selected = node;
			this.kids.push(node);
		}
	}
	
	/*
	if (AjaxState) {
	    var sel = AjaxState.getValue(name)
	    if (sel) {
		    this.setCurrent(sel);
		    var but = this.kids[sel].down('a');
		    if (but) {
			    if (but.href.indexOf('javascript:')==0) eval(but.href.substring(11));
			    else window.location=but.href;
		    }
	    }
	}
	*/
};

ImageTabs = function(elem) {
	this.root = $(elem);
	this.kids = [];
	this.selected = null;
		
	this.setCurrent = function(index) {
		if (this.selected) {
			Element.removeClassName(this.selected, "active");
			this.selected.image.src = this.selected.image.offsrc;
		}
		this.selected = this.kids[index];
		Element.addClassName(this.selected, "active");
		this.selected.image.src = this.selected.image.onsrc;
	}
	
	this.tabOver = function(event) {
		this.src = this.oversrc;
	}
	this.tabOut = function(event) {
		this.src = this.offsrc;
	};
	
	for (var i = 0; i < this.root.childNodes.length; i++) {
		if (this.root.childNodes[i].nodeType == 1) {
			node = this.root.childNodes[i];
			
			node.image = node.down("img");
			suffix = image.src.substring(image.src.lastIndexOf('.'));
			node.offsrc = image.src;
			node.onsrc = image.src.substring(0,image.src.lastIndexOf('.')) + "_on" + this.suffix;
			node.oversrc = image.src.substring(0,image.src.lastIndexOf('.')) + "_over" + this.suffix;
			
			if (Element.hasClassName(node, "active")) {
				this.selected = node;
				this.selected.image.src = this.selected.image.onsrc;
			}
			
			Event.observe(node.image, 'mouseover', this.tabOver.bindAsEventListener(node.image));
			Event.observe(node.image, 'mouseout', this.tabOut.bindAsEventListener(node.image));
			
			this.kids.push(node);
		}
	}
};

var TabPageManager = { 
	showPage: function(elem, f) {
		elem = $(elem);
		if (elem) {
			elem.siblings().each(function(e){if(e.hasClassName("tab_page"))e.hide();});
			if (typeof f == "function") f.apply(elem);
			elem.show();
		}
	}
};
/*	Unobtrusive Flash Objects (UFO) v3.21 <http://www.bobbyvandersluis.com/ufo/>
	Copyright 2005, 2006 Bobby van der Sluis
	This software is licensed under the CC-GNU LGPL <http://creativecommons.org/licenses/LGPL/2.1/>
*/

/* Modified by Jack: now implements subscribes to dom:loaded */
/* Modified by Jack: http://www.extremefx.com.ar/blog/fixing-flash-external-interface-inside-form-on-internet-explorer */
/* Modified by Darrell: How do I fix a "Line 56: Out of Memory" error on http://www.bobbyvandersluis.com/ufo/ */


var UFO = {
	req: ["movie", "width", "height", "majorversion", "build"],
	opt: ["play", "loop", "menu", "quality", "scale", "salign", "wmode", "bgcolor", "base", "flashvars", "devicefont", "allowscriptaccess", "seamlesstabbing", "allowfullscreen"],
	optAtt: ["id", "name", "align"],
	optExc: ["swliveconnect"],
	ximovie: "ufo.swf",
	xiwidth: "215",
	xiheight: "138",
	ua: navigator.userAgent.toLowerCase(),
	pluginType: "",
	fv: [0,0],
	foList: [],
		
	create: function(FO, id) {
		if (!UFO.uaHas("w3cdom") || UFO.uaHas("ieMac")) return;
		UFO.getFlashVersion();
		UFO.foList[id] = UFO.updateFO(FO);
		UFO.createCSS("#" + id, "visibility:hidden;");
		UFO.domLoad(id);
	},

	updateFO: function(FO) {
		if (typeof FO.xi != "undefined" && FO.xi == "true") {
			if (typeof FO.ximovie == "undefined") FO.ximovie = UFO.ximovie;
			if (typeof FO.xiwidth == "undefined") FO.xiwidth = UFO.xiwidth;
			if (typeof FO.xiheight == "undefined") FO.xiheight = UFO.xiheight;
		}
		FO.mainCalled = false;
		return FO;
	},

	domLoad: function(id) {		
	    if (document.loaded) {
		    UFO.main(id);
		} else {
		    document.observe("dom:loaded", function() { UFO.main(id);}); 
    		Event.observe(window, "load", function() { UFO.main(id); }); // IE
		}
	},

	main: function(id) {
		var _fo = UFO.foList[id];
		if (_fo.mainCalled) return;
		UFO.foList[id].mainCalled = true;
		$(id).setStyle({visibility : "hidden" });
		if (UFO.hasRequired(id)) {
			if (UFO.hasFlashVersion(parseInt(_fo.majorversion, 10), parseInt(_fo.build, 10))) {
				if (typeof _fo.setcontainercss != "undefined" && _fo.setcontainercss == "true") UFO.setContainerCSS(id);
				UFO.writeSWF(id);
			}
			else if (_fo.xi == "true" && UFO.hasFlashVersion(6, 65)) {
				UFO.createDialog(id);
			}
		}
		document.getElementById(id).style.visibility = "visible";
	},
	
	createCSS: function(selector, declaration) {
		var _h = document.getElementsByTagName("head")[0]; 
		var _s = UFO.createElement("style");
		if (!UFO.uaHas("ieWin")) _s.appendChild(document.createTextNode(selector + " {" + declaration + "}")); // bugs in IE/Win
		_s.setAttribute("type", "text/css");
		_s.setAttribute("media", "screen"); 
		_h.appendChild(_s);
		if (UFO.uaHas("ieWin") && document.styleSheets && document.styleSheets.length > 0) {
			var _ls = document.styleSheets[document.styleSheets.length - 1];
			if (typeof _ls.addRule == "object") _ls.addRule(selector, declaration);
		}
	},
	
	setContainerCSS: function(id) {
		var _fo = UFO.foList[id];
		var _w = /%/.test(_fo.width) ? "" : "px";
		var _h = /%/.test(_fo.height) ? "" : "px";
		UFO.createCSS("#" + id, "width:" + _fo.width + _w +"; height:" + _fo.height + _h +";");
		if (_fo.width == "100%") {
			UFO.createCSS("body", "margin-left:0; margin-right:0; padding-left:0; padding-right:0;");
		}
		if (_fo.height == "100%") {
			UFO.createCSS("html", "height:100%; overflow:hidden;");
			UFO.createCSS("body", "margin-top:0; margin-bottom:0; padding-top:0; padding-bottom:0; height:100%;");
		}
	},

	createElement: function(el) {
		return (UFO.uaHas("xml") && typeof document.createElementNS != "undefined") ?  document.createElementNS("http://www.w3.org/1999/xhtml", el) : document.createElement(el);
	},

	createObjParam: function(el, aName, aValue) {
		var _p = UFO.createElement("param");
		_p.setAttribute("name", aName);	
		_p.setAttribute("value", aValue);
		el.appendChild(_p);
	},

	uaHas: function(ft) {
		var _u = UFO.ua;
		switch(ft) {
			case "w3cdom":
				return (typeof document.getElementById != "undefined" && typeof document.getElementsByTagName != "undefined" && (typeof document.createElement != "undefined" || typeof document.createElementNS != "undefined"));
			case "xml":
				var _m = document.getElementsByTagName("meta");
				var _l = _m.length;
				for (var i = 0; i < _l; i++) {
					if (/content-type/i.test(_m[i].getAttribute("http-equiv")) && /xml/i.test(_m[i].getAttribute("content"))) return true;
				}
				return false;
			case "ieMac":
				return /msie/.test(_u) && !/opera/.test(_u) && /mac/.test(_u);
			case "ieWin":
				return /msie/.test(_u) && !/opera/.test(_u) && /win/.test(_u);
			case "gecko":
				return /gecko/.test(_u) && !/applewebkit/.test(_u);
			case "opera":
				return /opera/.test(_u);
			case "safari":
				return /applewebkit/.test(_u);
			default:
				return false;
		}
	},
	
	getFlashVersion: function() {
		if (UFO.fv[0] != 0) return;  
		if (navigator.plugins && typeof navigator.plugins["Shockwave Flash"] == "object") {
			UFO.pluginType = "npapi";
			var _d = navigator.plugins["Shockwave Flash"].description;
			if (typeof _d != "undefined") {
				_d = _d.replace(/^.*\s+(\S+\s+\S+$)/, "$1");
				var _m = parseInt(_d.replace(/^(.*)\..*$/, "$1"), 10);
				var _r = /r/.test(_d) ? parseInt(_d.replace(/^.*r(.*)$/, "$1"), 10) : 0;
				UFO.fv = [_m, _r];
			}
		}
		else if (window.ActiveXObject) {
			UFO.pluginType = "ax";
			try { // avoid fp 6 crashes
				var _a = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");
			}
			catch(e) {
				try { 
					var _a = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
					UFO.fv = [6, 0];
					_a.AllowScriptAccess = "always"; // throws if fp < 6.47 
				}
				catch(e) {
					if (UFO.fv[0] == 6) return;
				}
				try {
					var _a = new ActiveXObject("ShockwaveFlash.ShockwaveFlash");
				}
				catch(e) {}
			}
			if (typeof _a == "object") {
				var _d = _a.GetVariable("$version"); // bugs in fp 6.21/6.23
				if (typeof _d != "undefined") {
					_d = _d.replace(/^\S+\s+(.*)$/, "$1").split(",");
					UFO.fv = [parseInt(_d[0], 10), parseInt(_d[2], 10)];
				}
			}
		}
	},

	hasRequired: function(id) {
		var _l = UFO.req.length;
		for (var i = 0; i < _l; i++) {
			if (typeof UFO.foList[id][UFO.req[i]] == "undefined") return false;
		}
		return true;
	},
	
	hasFlashVersion: function(major, release) {
		return (UFO.fv[0] > major || (UFO.fv[0] == major && UFO.fv[1] >= release)) ? true : false;
	},

	writeSWF: function(id) {
		var _fo = UFO.foList[id];
		var _e = document.getElementById(id);
		if (UFO.pluginType == "npapi") {
			if (UFO.uaHas("gecko") || UFO.uaHas("xml")) {
				while(_e.hasChildNodes()) {
					_e.removeChild(_e.firstChild);
				}
				var _obj = UFO.createElement("object");
				_obj.setAttribute("type", "application/x-shockwave-flash");
				_obj.setAttribute("data", _fo.movie);
				_obj.setAttribute("width", _fo.width);
				_obj.setAttribute("height", _fo.height);
				var _l = UFO.optAtt.length;
				for (var i = 0; i < _l; i++) {
					if (typeof _fo[UFO.optAtt[i]] != "undefined") _obj.setAttribute(UFO.optAtt[i], _fo[UFO.optAtt[i]]);
				}
				var _o = UFO.opt.concat(UFO.optExc);
				var _l = _o.length;
				for (var i = 0; i < _l; i++) {
					if (typeof _fo[_o[i]] != "undefined") UFO.createObjParam(_obj, _o[i], _fo[_o[i]]);
				}
				_e.appendChild(_obj);
			}
			else {
				var _emb = "";
				var _o = UFO.opt.concat(UFO.optAtt).concat(UFO.optExc);
				var _l = _o.length;
				for (var i = 0; i < _l; i++) {
					if (typeof _fo[_o[i]] != "undefined") _emb += ' ' + _o[i] + '="' + _fo[_o[i]] + '"';
				}
				_e.innerHTML = '<embed type="application/x-shockwave-flash" src="' + _fo.movie + '" width="' + _fo.width + '" height="' + _fo.height + '" pluginspage="http://www.macromedia.com/go/getflashplayer"' + _emb + '></embed>';
			}
		}
		else if (UFO.pluginType == "ax") {
			var _objAtt = "";
			var _l = UFO.optAtt.length;
			for (var i = 0; i < _l; i++) {
				if (typeof _fo[UFO.optAtt[i]] != "undefined") _objAtt += ' ' + UFO.optAtt[i] + '="' + _fo[UFO.optAtt[i]] + '"';
			}
			var _objPar = "";
			var _l = UFO.opt.length;
			for (var i = 0; i < _l; i++) {
				if (typeof _fo[UFO.opt[i]] != "undefined") _objPar += '<param name="' + UFO.opt[i] + '" value="' + _fo[UFO.opt[i]] + '" />';
			}
			var _p = window.location.protocol == "https:" ? "https:" : "http:";
			_e.innerHTML = '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"' + _objAtt + ' width="' + _fo.width + '" height="' + _fo.height + '" codebase="' + _p + '//download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=' + _fo.majorversion + ',0,' + _fo.build + ',0"><param name="movie" value="' + _fo.movie + '" />' + _objPar + '</object>';
			if (_fo["id"]) window[_fo["id"]] = document.getElementById(_fo["id"]);
		}
	},
		
	createDialog: function(id) {
		var _fo = UFO.foList[id];
		UFO.createCSS("html", "height:100%; overflow:hidden;");
		UFO.createCSS("body", "height:100%; overflow:hidden;");
		UFO.createCSS("#xi-con", "position:absolute; left:0; top:0; z-index:1000; width:100%; height:100%; background-color:#fff; filter:alpha(opacity:75); opacity:0.75;");
		UFO.createCSS("#xi-dia", "position:absolute; left:50%; top:50%; margin-left: -" + Math.round(parseInt(_fo.xiwidth, 10) / 2) + "px; margin-top: -" + Math.round(parseInt(_fo.xiheight, 10) / 2) + "px; width:" + _fo.xiwidth + "px; height:" + _fo.xiheight + "px;");
		var _b = document.getElementsByTagName("body")[0];
		var _c = UFO.createElement("div");
		_c.setAttribute("id", "xi-con");
		var _d = UFO.createElement("div");
		_d.setAttribute("id", "xi-dia");
		_c.appendChild(_d);
		_b.appendChild(_c);
		var _mmu = window.location;
		if (UFO.uaHas("xml") && UFO.uaHas("safari")) {
			var _mmd = document.getElementsByTagName("title")[0].firstChild.nodeValue = document.getElementsByTagName("title")[0].firstChild.nodeValue.slice(0, 47) + " - Flash Player Installation";
		}
		else {
			var _mmd = document.title = document.title.slice(0, 47) + " - Flash Player Installation";
		}
		var _mmp = UFO.pluginType == "ax" ? "ActiveX" : "PlugIn";
		var _uc = typeof _fo.xiurlcancel != "undefined" ? "&xiUrlCancel=" + _fo.xiurlcancel : "";
		var _uf = typeof _fo.xiurlfailed != "undefined" ? "&xiUrlFailed=" + _fo.xiurlfailed : "";
		UFO.foList["xi-dia"] = { movie:_fo.ximovie, width:_fo.xiwidth, height:_fo.xiheight, majorversion:"6", build:"65", flashvars:"MMredirectURL=" + _mmu + "&MMplayerType=" + _mmp + "&MMdoctitle=" + _mmd + _uc + _uf };
		UFO.writeSWF("xi-dia");
	},

	expressInstallCallback: function() {
		var _b = document.getElementsByTagName("body")[0];
		var _c = document.getElementById("xi-con");
		_b.removeChild(_c);
		UFO.createCSS("body", "height:auto; overflow:auto;");
		UFO.createCSS("html", "height:auto; overflow:auto;");
	},

	cleanupIELeaks: function() {
		var _o = document.getElementsByTagName("object");
		var _l = _o.length
		for (var i = 0; i < _l; i++) {
			_o[i].style.display = "none";
			for (var x in _o[i]) {
				if (typeof _o[i][x] == "function") {
					_o[i][x] = null;
				}
			}
		}
	}

};

if (typeof window.attachEvent != "undefined" && UFO.uaHas("ieWin")) {
	window.attachEvent("onunload", UFO.cleanupIELeaks);
}

function cleanupFP9IELeaks() {
  __flash_unloadHandler = function() {};
  __flash_savedUnloadHandler = function() {};
}

if (typeof window.attachEvent != "undefined" && UFO.uaHas("ieWin")) {
  window.attachEvent("onbeforeunload", cleanupFP9IELeaks);
}
if (typeof SproutJS == 'undefined') SproutJS = {};
if (typeof SproutJS.Controls == 'undefined') SproutJS.Controls = {};

Object.extend(SproutJS.Controls, { 
    CFWidget : function(){ 
        var trackFocus = function(evt) {
            currentWidget = evt.element();
        }
        function tryStyleElement(element, style){
            return style ? element.setStyle(style) : element;
        }
        function getResultsContainer(style){
            return tryStyleElement(getWidgetContainer().siblings('.cf-results').first(), style);
        }
        function getWidgetContainer(style){
            return tryStyleElement(currentWidget.up('.cf-widget'), style);
        }
        function styleResults(style){
            getResultsContainer(style);
        }
        function styleWidget(style){
            getWidgetContainer(style);
        }
        var currentWidget;
        
        Event.observe(window, 'load', function() {
            $$('.cf-widget object, .cf-widget embed').invoke('observe', 'focus', trackFocus); 
        });
        
        return { 
            getResultsContainer: getResultsContainer,
            getWidgetContainer: getWidgetContainer,
            styleResults: styleResults,
            styleWidget: styleWidget
        }
    }()
});
var divMoved = false;
function setFlashSize_right(flashFile) {
    var container = SproutJS.Controls.CFWidget.getResultsContainer({visibility:'visible', width:'351px', height:'260px'});
    container.setStyle({ left: container.offsetLeft - 187 + "px" });
    var movie = flashFile == 'results' ? 'http://sprout.channelfinder.net/flash/resultsNewWin.asp?jsConnection=true&ver=1.0.0.0' : 'http://sprout.channelfinder.net/flash/unavailable.swf?jsConnection=true&ver=1.0.0.0';
    var ANFO4 = { movie: movie, allowscriptaccess: 'always', build: '0', height: '100%', id: 'resultsFlash', majorversion: '7', name: 'resultsFlash', quality: 'high', salign: 'T', scale: 'noscale', swliveconnect: 'true', width: '100%', wmode: 'transparent', flashvars: '', create: function() { UFO.create(this, container.identify()); } }; ANFO4.create();
}
function setFlashSize_right_close() {
    var container = SproutJS.Controls.CFWidget.getResultsContainer();
    container.setStyle({ visibility: 'hidden', left: container.offsetLeft + 187 + 'px' });
}
function setFlashSizeOrig_right() {
    SproutJS.Controls.CFWidget.styleWidget({height: "195px", width: "160px"});
    SproutJS.Controls.CFWidget.styleResults({ visibility:'hidden'});
}
function setFlashSize() {
    SproutJS.Controls.CFWidget.styleWidget({height: "260px"});
}
function SetCallLetters(callLetters) {
    createCookie("call_letters", callLetters, 50000);
}
function setWidgetPos() {
}
