X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=dygraph-combined.js;h=6b90a708faef585e40de4859f59c2a97ad488c8d;hb=73a464171469a18a7f2cc55a98762c4b31e3754f;hp=ca0a3ee9254657227d0711ffb9a9f59ef85f810a;hpb=0949d3e5cd678e82717f01d6696e7e8abe763be2;p=dygraphs.git diff --git a/dygraph-combined.js b/dygraph-combined.js index ca0a3ee..6b90a70 100644 --- a/dygraph-combined.js +++ b/dygraph-combined.js @@ -1593,7 +1593,7 @@ throw MochiKit.Iter.StopIteration; return rval; }}; }}); -MochiKit.Iter.EXPORT_OK=["iteratorRegistry","arrayLikeIter","hasIterateNext","iterateNextIter",]; +MochiKit.Iter.EXPORT_OK=["iteratorRegistry","arrayLikeIter","hasIterateNext","iterateNextIter"]; MochiKit.Iter.EXPORT=["StopIteration","registerIteratorFactory","iter","count","cycle","repeat","next","izip","ifilter","ifilterfalse","islice","imap","applymap","chain","takewhile","dropwhile","tee","list","reduce","range","sum","exhaust","forEach","every","sorted","reversed","some","iextend","groupby","groupby_as_array"]; MochiKit.Iter.__new__=function(){ var m=MochiKit.Base; @@ -1614,7 +1614,7 @@ reduce=MochiKit.Iter.reduce; } MochiKit.Base._exportSymbols(this,MochiKit.Iter); if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.Logging"); +dojo.provide("MochiKit.DOM"); dojo.require("MochiKit.Base"); } if(typeof (JSAN)!="undefined"){ @@ -1626,1036 +1626,875 @@ throw ""; } } catch(e){ -throw "MochiKit.Logging depends on MochiKit.Base!"; +throw "MochiKit.DOM depends on MochiKit.Base!"; } -if(typeof (MochiKit.Logging)=="undefined"){ -MochiKit.Logging={}; +if(typeof (MochiKit.DOM)=="undefined"){ +MochiKit.DOM={}; } -MochiKit.Logging.NAME="MochiKit.Logging"; -MochiKit.Logging.VERSION="1.4"; -MochiKit.Logging.__repr__=function(){ +MochiKit.DOM.NAME="MochiKit.DOM"; +MochiKit.DOM.VERSION="1.4"; +MochiKit.DOM.__repr__=function(){ return "["+this.NAME+" "+this.VERSION+"]"; }; -MochiKit.Logging.toString=function(){ +MochiKit.DOM.toString=function(){ return this.__repr__(); }; -MochiKit.Logging.EXPORT=["LogLevel","LogMessage","Logger","alertListener","logger","log","logError","logDebug","logFatal","logWarning"]; -MochiKit.Logging.EXPORT_OK=["logLevelAtLeast","isLogMessage","compareLogMessage"]; -MochiKit.Logging.LogMessage=function(num,_1e6,info){ -this.num=num; -this.level=_1e6; -this.info=info; -this.timestamp=new Date(); -}; -MochiKit.Logging.LogMessage.prototype={repr:function(){ +MochiKit.DOM.EXPORT=["removeEmptyTextNodes","formContents","currentWindow","currentDocument","withWindow","withDocument","registerDOMConverter","coerceToDOM","createDOM","createDOMFunc","isChildNode","getNodeAttribute","removeNodeAttribute","setNodeAttribute","updateNodeAttributes","appendChildNodes","insertSiblingNodesAfter","insertSiblingNodesBefore","replaceChildNodes","removeElement","swapDOM","BUTTON","TT","PRE","H1","H2","H3","BR","CANVAS","HR","LABEL","TEXTAREA","FORM","STRONG","SELECT","OPTION","OPTGROUP","LEGEND","FIELDSET","P","UL","OL","LI","TD","TR","THEAD","TBODY","TFOOT","TABLE","TH","INPUT","SPAN","A","DIV","IMG","getElement","$","getElementsByTagAndClassName","addToCallStack","addLoadEvent","focusOnLoad","setElementClass","toggleElementClass","addElementClass","removeElementClass","swapElementClass","hasElementClass","escapeHTML","toHTML","emitHTML","scrapeText","isParent","getFirstParentByTagAndClassName","makeClipping","undoClipping","makePositioned","undoPositioned","getFirstElementByTagAndClassName"]; +MochiKit.DOM.EXPORT_OK=["domConverters"]; +MochiKit.DOM.DEPRECATED=[["computedStyle","MochiKit.Style.getStyle","1.4"],["elementDimensions","MochiKit.Style.getElementDimensions","1.4"],["elementPosition","MochiKit.Style.getElementPosition","1.4"],["hideElement","MochiKit.Style.hideElement","1.4"],["setElementDimensions","MochiKit.Style.setElementDimensions","1.4"],["setElementPosition","MochiKit.Style.setElementPosition","1.4"],["setDisplayForElement","MochiKit.Style.setDisplayForElement","1.4"],["setOpacity","MochiKit.Style.setOpacity","1.4"],["showElement","MochiKit.Style.showElement","1.4"],["Coordinates","MochiKit.Style.Coordinates","1.4"],["Dimensions","MochiKit.Style.Dimensions","1.4"]]; +MochiKit.DOM.getViewportDimensions=new Function(""+"if (!MochiKit[\"Style\"]) {"+" throw new Error(\"This function has been deprecated and depends on MochiKit.Style.\");"+"}"+"return MochiKit.Style.getViewportDimensions.apply(this, arguments);"); +MochiKit.Base.update(MochiKit.DOM,{currentWindow:function(){ +return MochiKit.DOM._window; +},currentDocument:function(){ +return MochiKit.DOM._document; +},withWindow:function(win,func){ +var self=MochiKit.DOM; +var _1e8=self._document; +var _1e9=self._window; +var rval; +try{ +self._window=win; +self._document=win.document; +rval=func(); +} +catch(e){ +self._window=_1e9; +self._document=_1e8; +throw e; +} +self._window=_1e9; +self._document=_1e8; +return rval; +},formContents:function(elem){ +var _1ec=[]; +var _1ed=[]; var m=MochiKit.Base; -return "LogMessage("+m.map(m.repr,[this.num,this.level,this.info]).join(", ")+")"; -},toString:MochiKit.Base.forwardCall("repr")}; -MochiKit.Base.update(MochiKit.Logging,{logLevelAtLeast:function(_1e9){ -var self=MochiKit.Logging; -if(typeof (_1e9)=="string"){ -_1e9=self.LogLevel[_1e9]; +var self=MochiKit.DOM; +if(typeof (elem)=="undefined"||elem===null){ +elem=self._document.body; +}else{ +elem=self.getElement(elem); } -return function(msg){ -var _1ec=msg.level; -if(typeof (_1ec)=="string"){ -_1ec=self.LogLevel[_1ec]; +m.nodeWalk(elem,function(elem){ +var name=elem.name; +if(m.isNotEmpty(name)){ +var _1f2=elem.tagName.toUpperCase(); +if(_1f2==="INPUT"&&(elem.type=="radio"||elem.type=="checkbox")&&!elem.checked){ +return null; } -return _1ec>=_1e9; -}; -},isLogMessage:function(){ -var _1ed=MochiKit.Logging.LogMessage; -for(var i=0;i=0){ +var opt=elem.options[elem.selectedIndex]; +var v=opt.value; +if(!v){ +var h=opt.outerHTML; +if(h&&!h.match(/^[^>]+\svalue\s*=/i)){ +v=opt.text; } } -return true; -},compareLogMessage:function(a,b){ -return MochiKit.Base.compare([a.level,a.info],[b.level,b.info]); -},alertListener:function(msg){ -alert("num: "+msg.num+"\nlevel: "+msg.level+"\ninfo: "+msg.info.join(" ")); -}}); -MochiKit.Logging.Logger=function(_1f2){ -this.counter=0; -if(typeof (_1f2)=="undefined"||_1f2===null){ -_1f2=-1; +_1ec.push(name); +_1ed.push(v); +return null; } -this.maxSize=_1f2; -this._messages=[]; -this.listeners={}; -this.useNativeConsole=false; -}; -MochiKit.Logging.Logger.prototype={clear:function(){ -this._messages.splice(0,this._messages.length); -},logToConsole:function(msg){ -if(typeof (window)!="undefined"&&window.console&&window.console.log){ -window.console.log(msg.replace(/%/g,"\uff05")); -}else{ -if(typeof (opera)!="undefined"&&opera.postError){ -opera.postError(msg); -}else{ -if(typeof (printfire)=="function"){ -printfire(msg); -}else{ -if(typeof (Debug)!="undefined"&&Debug.writeln){ -Debug.writeln(msg); +_1ec.push(name); +_1ed.push(""); +return null; }else{ -if(typeof (debug)!="undefined"&&debug.trace){ -debug.trace(msg); +var opts=elem.options; +if(!opts.length){ +_1ec.push(name); +_1ed.push(""); +return null; +} +for(var i=0;i]+\svalue\s*=/i)){ +v=opt.text; } } +_1ec.push(name); +_1ed.push(v); } +return null; } -},dispatchListeners:function(msg){ -for(var k in this.listeners){ -var pair=this.listeners[k]; -if(pair.ident!=k||(pair[0]&&!pair[0](msg))){ -continue; } -pair[1](msg); -} -},addListener:function(_1f7,_1f8,_1f9){ -if(typeof (_1f8)=="string"){ -_1f8=MochiKit.Logging.logLevelAtLeast(_1f8); -} -var _1fa=[_1f8,_1f9]; -_1fa.ident=_1f7; -this.listeners[_1f7]=_1fa; -},removeListener:function(_1fb){ -delete this.listeners[_1fb]; -},baseLog:function(_1fc,_1fd){ -var msg=new MochiKit.Logging.LogMessage(this.counter,_1fc,MochiKit.Base.extend(null,arguments,1)); -this._messages.push(msg); -this.dispatchListeners(msg); -if(this.useNativeConsole){ -this.logToConsole(msg.level+": "+msg.info.join(" ")); -} -this.counter+=1; -while(this.maxSize>=0&&this._messages.length>this.maxSize){ -this._messages.shift(); -} -},getMessages:function(_1ff){ -var _200=0; -if(!(typeof (_1ff)=="undefined"||_1ff===null)){ -_200=Math.max(0,this._messages.length-_1ff); +if(_1f2==="FORM"||_1f2==="P"||_1f2==="SPAN"||_1f2==="DIV"){ +return elem.childNodes; } -return this._messages.slice(_200); -},getMessageText:function(_201){ -if(typeof (_201)=="undefined"||_201===null){ -_201=30; +_1ec.push(name); +_1ed.push(elem.value||""); +return null; } -var _202=this.getMessages(_201); -if(_202.length){ -var lst=map(function(m){ -return "\n ["+m.num+"] "+m.level+": "+m.info.join(" "); -},_202); -lst.unshift("LAST "+_202.length+" MESSAGES:"); -return lst.join(""); +return elem.childNodes; +}); +return [_1ec,_1ed]; +},withDocument:function(doc,func){ +var self=MochiKit.DOM; +var _1fb=self._document; +var rval; +try{ +self._document=doc; +rval=func(); } -return ""; -},debuggingBookmarklet:function(_205){ -if(typeof (MochiKit.LoggingPane)=="undefined"){ -alert(this.getMessageText()); -}else{ -MochiKit.LoggingPane.createLoggingPane(_205||false); +catch(e){ +self._document=_1fb; +throw e; } -}}; -MochiKit.Logging.__new__=function(){ -this.LogLevel={ERROR:40,FATAL:50,WARNING:30,INFO:20,DEBUG:10}; +self._document=_1fb; +return rval; +},registerDOMConverter:function(name,_1fe,wrap,_200){ +MochiKit.DOM.domConverters.register(name,_1fe,wrap,_200); +},coerceToDOM:function(node,ctx){ var m=MochiKit.Base; -m.registerComparator("LogMessage",this.isLogMessage,this.compareLogMessage); -var _207=m.partial; -var _208=this.Logger; -var _209=_208.prototype.baseLog; -m.update(this.Logger.prototype,{debug:_207(_209,"DEBUG"),log:_207(_209,"INFO"),error:_207(_209,"ERROR"),fatal:_207(_209,"FATAL"),warning:_207(_209,"WARNING")}); -var self=this; -var _20b=function(name){ -return function(){ -self.logger[name].apply(self.logger,arguments); -}; -}; -this.log=_20b("log"); -this.logError=_20b("error"); -this.logDebug=_20b("debug"); -this.logFatal=_20b("fatal"); -this.logWarning=_20b("warning"); -this.logger=new _208(); -this.logger.useNativeConsole=true; -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -m.nameFunctions(this); -}; -if(typeof (printfire)=="undefined"&&typeof (document)!="undefined"&&document.createEvent&&typeof (dispatchEvent)!="undefined"){ -printfire=function(){ -printfire.args=arguments; -var ev=document.createEvent("Events"); -ev.initEvent("printfire",false,true); -dispatchEvent(ev); -}; +var im=MochiKit.Iter; +var self=MochiKit.DOM; +if(im){ +var iter=im.iter; +var _207=im.repeat; +var map=m.map; } -MochiKit.Logging.__new__(); -MochiKit.Base._exportSymbols(this,MochiKit.Logging); -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.DateTime"); +var _209=self.domConverters; +var _20a=arguments.callee; +var _20b=m.NotFound; +while(true){ +if(typeof (node)=="undefined"||node===null){ +return null; } -if(typeof (MochiKit)=="undefined"){ -MochiKit={}; +if(typeof (node)=="function"&&typeof (node.length)=="number"&&!(node instanceof Function)){ +node=im.list(node); } -if(typeof (MochiKit.DateTime)=="undefined"){ -MochiKit.DateTime={}; +if(typeof (node.nodeType)!="undefined"&&node.nodeType>0){ +return node; } -MochiKit.DateTime.NAME="MochiKit.DateTime"; -MochiKit.DateTime.VERSION="1.4"; -MochiKit.DateTime.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.DateTime.toString=function(){ -return this.__repr__(); -}; -MochiKit.DateTime.isoDate=function(str){ -str=str+""; -if(typeof (str)!="string"||str.length===0){ -return null; +if(typeof (node)=="number"||typeof (node)=="boolean"){ +node=node.toString(); } -var iso=str.split("-"); -if(iso.length===0){ -return null; +if(typeof (node)=="string"){ +return self._document.createTextNode(node); } -return new Date(iso[0],iso[1]-1,iso[2]); -}; -MochiKit.DateTime._isoRegexp=/(\d{4,})(?:-(\d{1,2})(?:-(\d{1,2})(?:[T ](\d{1,2}):(\d{1,2})(?::(\d{1,2})(?:\.(\d+))?)?(?:(Z)|([+-])(\d{1,2})(?::(\d{1,2}))?)?)?)?)?/; -MochiKit.DateTime.isoTimestamp=function(str){ -str=str+""; -if(typeof (str)!="string"||str.length===0){ -return null; +if(typeof (node.__dom__)=="function"){ +node=node.__dom__(ctx); +continue; } -var res=str.match(MochiKit.DateTime._isoRegexp); -if(typeof (res)=="undefined"||res===null){ -return null; +if(typeof (node.dom)=="function"){ +node=node.dom(ctx); +continue; } -var year,_213,day,hour,min,sec,msec; -year=parseInt(res[1],10); -if(typeof (res[2])=="undefined"||res[2]===""){ -return new Date(year); +if(typeof (node)=="function"){ +node=node.apply(ctx,[ctx]); +continue; } -_213=parseInt(res[2],10)-1; -day=parseInt(res[3],10); -if(typeof (res[4])=="undefined"||res[4]===""){ -return new Date(year,_213,day); +if(im){ +var _20c=null; +try{ +_20c=iter(node); } -hour=parseInt(res[4],10); -min=parseInt(res[5],10); -sec=(typeof (res[6])!="undefined"&&res[6]!=="")?parseInt(res[6],10):0; -if(typeof (res[7])!="undefined"&&res[7]!==""){ -msec=Math.round(1000*parseFloat("0."+res[7])); -}else{ -msec=0; +catch(e){ } -if((typeof (res[8])=="undefined"||res[8]==="")&&(typeof (res[9])=="undefined"||res[9]==="")){ -return new Date(year,_213,day,hour,min,sec,msec); +if(_20c){ +return map(_20a,_20c,_207(ctx)); } -var ofs; -if(typeof (res[9])!="undefined"&&res[9]!==""){ -ofs=parseInt(res[10],10)*3600000; -if(typeof (res[11])!="undefined"&&res[11]!==""){ -ofs+=parseInt(res[11],10)*60000; } -if(res[9]=="-"){ -ofs=-ofs; +try{ +node=_209.match(node,ctx); +continue; } -}else{ -ofs=0; +catch(e){ +if(e!=_20b){ +throw e; } -return new Date(Date.UTC(year,_213,day,hour,min,sec,msec)-ofs); -}; -MochiKit.DateTime.toISOTime=function(date,_21b){ -if(typeof (date)=="undefined"||date===null){ -return null; } -var hh=date.getHours(); -var mm=date.getMinutes(); -var ss=date.getSeconds(); -var lst=[((_21b&&(hh<10))?"0"+hh:hh),((mm<10)?"0"+mm:mm),((ss<10)?"0"+ss:ss)]; -return lst.join(":"); -}; -MochiKit.DateTime.toISOTimestamp=function(date,_221){ -if(typeof (date)=="undefined"||date===null){ -return null; +return self._document.createTextNode(node.toString()); } -var sep=_221?"T":" "; -var foot=_221?"Z":""; -if(_221){ -date=new Date(date.getTime()+(date.getTimezoneOffset()*60000)); +return undefined; +},isChildNode:function(node,_20e){ +var self=MochiKit.DOM; +if(typeof (node)=="string"){ +node=self.getElement(node); } -return MochiKit.DateTime.toISODate(date)+sep+MochiKit.DateTime.toISOTime(date,_221)+foot; -}; -MochiKit.DateTime.toISODate=function(date){ -if(typeof (date)=="undefined"||date===null){ -return null; +if(typeof (_20e)=="string"){ +_20e=self.getElement(_20e); } -var _225=MochiKit.DateTime._padTwo; -return [date.getFullYear(),_225(date.getMonth()+1),_225(date.getDate())].join("-"); -}; -MochiKit.DateTime.americanDate=function(d){ -d=d+""; -if(typeof (d)!="string"||d.length===0){ -return null; +if(node===_20e){ +return true; } -var a=d.split("/"); -return new Date(a[2],a[0]-1,a[1]); -}; -MochiKit.DateTime._padTwo=function(n){ -return (n>9)?n:"0"+n; -}; -MochiKit.DateTime.toPaddedAmericanDate=function(d){ -if(typeof (d)=="undefined"||d===null){ -return null; +while(node&&node.tagName.toUpperCase()!="BODY"){ +node=node.parentNode; +if(node===_20e){ +return true; } -var _22a=MochiKit.DateTime._padTwo; -return [_22a(d.getMonth()+1),_22a(d.getDate()),d.getFullYear()].join("/"); -}; -MochiKit.DateTime.toAmericanDate=function(d){ -if(typeof (d)=="undefined"||d===null){ -return null; } -return [d.getMonth()+1,d.getDate(),d.getFullYear()].join("/"); -}; -MochiKit.DateTime.EXPORT=["isoDate","isoTimestamp","toISOTime","toISOTimestamp","toISODate","americanDate","toPaddedAmericanDate","toAmericanDate"]; -MochiKit.DateTime.EXPORT_OK=[]; -MochiKit.DateTime.EXPORT_TAGS={":common":MochiKit.DateTime.EXPORT,":all":MochiKit.DateTime.EXPORT}; -MochiKit.DateTime.__new__=function(){ -var base=this.NAME+"."; -for(var k in this){ -var o=this[k]; -if(typeof (o)=="function"&&typeof (o.NAME)=="undefined"){ +return false; +},setNodeAttribute:function(node,attr,_212){ +var o={}; +o[attr]=_212; try{ -o.NAME=base+k; +return MochiKit.DOM.updateNodeAttributes(node,o); } catch(e){ } +return null; +},getNodeAttribute:function(node,attr){ +var self=MochiKit.DOM; +var _217=self.attributeArray.renames[attr]; +node=self.getElement(node); +try{ +if(_217){ +return node[_217]; } +return node.getAttribute(attr); } -}; -MochiKit.DateTime.__new__(); -if(typeof (MochiKit.Base)!="undefined"){ -MochiKit.Base._exportSymbols(this,MochiKit.DateTime); -}else{ -(function(_22f,_230){ -if((typeof (JSAN)=="undefined"&&typeof (dojo)=="undefined")||(MochiKit.__export__===false)){ -var all=_230.EXPORT_TAGS[":all"]; -for(var i=0;i_23a){ -var i=_242.length-_23a; -res=fmt.separator+_242.substring(i,_242.length)+res; -_242=_242.substring(0,i); -} -} -res=_242+res; -if(_238>0){ -while(frac.length<_23b){ -frac=frac+"0"; -} -res=res+fmt.decimal+frac; -} -return _23d+res+_23e; -}; -}; -MochiKit.Format.numberFormatter=function(_246,_247,_248){ -if(typeof (_247)=="undefined"){ -_247=""; -} -var _249=_246.match(/((?:[0#]+,)?[0#]+)(?:\.([0#]+))?(%)?/); -if(!_249){ -throw TypeError("Invalid pattern"); -} -var _24a=_246.substr(0,_249.index); -var _24b=_246.substr(_249.index+_249[0].length); -if(_24a.search(/-/)==-1){ -_24a=_24a+"-"; -} -var _24c=_249[1]; -var frac=(typeof (_249[2])=="string"&&_249[2]!="")?_249[2]:""; -var _24e=(typeof (_249[3])=="string"&&_249[3]!=""); -var tmp=_24c.split(/,/); -var _250; -if(typeof (_248)=="undefined"){ -_248="default"; -} -if(tmp.length==1){ -_250=null; -}else{ -_250=tmp[1].length; -} -var _251=_24c.length-_24c.replace(/0/g,"").length; -var _252=frac.length-frac.replace(/0/g,"").length; -var _253=frac.length; -var rval=MochiKit.Format._numberFormatter(_247,_24a,_24b,_248,_24e,_253,_251,_250,_252); -var m=MochiKit.Base; -if(m){ -var fn=arguments.callee; -var args=m.concat(arguments); -rval.repr=function(){ -return [self.NAME,"(",map(m.repr,args).join(", "),")"].join(""); -}; } -return rval; -}; -MochiKit.Format.formatLocale=function(_258){ -if(typeof (_258)=="undefined"||_258===null){ -_258="default"; } -if(typeof (_258)=="string"){ -var rval=MochiKit.Format.LOCALE[_258]; -if(typeof (rval)=="string"){ -rval=arguments.callee(rval); -MochiKit.Format.LOCALE[_258]=rval; +}else{ +var _223=self.attributeArray.renames; +for(var k in _21d){ +v=_21d[k]; +var _224=_223[k]; +if(k=="style"&&typeof (v)=="string"){ +elem.style.cssText=v; +}else{ +if(typeof (_224)=="string"){ +elem[_224]=v; +}else{ +if(typeof (elem[k])=="object"&&typeof (v)=="object"){ +if(k=="style"&&MochiKit.Style){ +MochiKit.Style.setStyle(elem,v); +}else{ +_220(elem[k],v); } -return rval; }else{ -return _258; +if(k.substring(0,2)=="on"){ +if(typeof (v)=="string"){ +v=new Function(v); } -}; -MochiKit.Format.twoDigitAverage=function(_25a,_25b){ -if(_25b){ -var res=_25a/_25b; -if(!isNaN(res)){ -return MochiKit.Format.twoDigitFloat(_25a/_25b); +elem[k]=v; +}else{ +elem.setAttribute(k,v); } } -return "0"; -}; -MochiKit.Format.twoDigitFloat=function(_25d){ -var sign=(_25d<0?"-":""); -var s=Math.floor(Math.abs(_25d)*100).toString(); -if(s=="0"){ -return s; } -if(s.length<3){ -while(s.charAt(s.length-1)=="0"){ -s=s.substring(0,s.length-1); } -return sign+"0."+s; } -var head=sign+s.substring(0,s.length-2); -var tail=s.substring(s.length-2,s.length); -if(tail=="00"){ -return head; -}else{ -if(tail.charAt(1)=="0"){ -return head+"."+tail.charAt(0); -}else{ -return head+"."+tail; } } -}; -MochiKit.Format.lstrip=function(str,_263){ -str=str+""; -if(typeof (str)!="string"){ -return null; +return elem; +},appendChildNodes:function(node){ +var elem=node; +var self=MochiKit.DOM; +if(typeof (node)=="string"){ +elem=self.getElement(node); } -if(!_263){ -return str.replace(/^\s+/,""); +var _228=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; +var _229=MochiKit.Base.concat; +while(_228.length){ +var n=_228.shift(); +if(typeof (n)=="undefined"||n===null){ }else{ -return str.replace(new RegExp("^["+_263+"]+"),""); -} -}; -MochiKit.Format.rstrip=function(str,_265){ -str=str+""; -if(typeof (str)!="string"){ -return null; -} -if(!_265){ -return str.replace(/\s+$/,""); +if(typeof (n.nodeType)=="number"){ +elem.appendChild(n); }else{ -return str.replace(new RegExp("["+_265+"]+$"),""); +_228=_229(n,_228); } -}; -MochiKit.Format.strip=function(str,_267){ -var self=MochiKit.Format; -return self.rstrip(self.lstrip(str,_267),_267); -}; -MochiKit.Format.truncToFixed=function(_269,_26a){ -_269=Math.floor(_269*Math.pow(10,_26a)); -var res=(_269*Math.pow(10,-_26a)).toFixed(_26a); -if(res.charAt(0)=="."){ -res="0"+res; } -return res; -}; -MochiKit.Format.roundToFixed=function(_26c,_26d){ -return MochiKit.Format.truncToFixed(_26c+0.5*Math.pow(10,-_26d),_26d); -}; -MochiKit.Format.percentFormat=function(_26e){ -return MochiKit.Format.twoDigitFloat(100*_26e)+"%"; -}; -MochiKit.Format.EXPORT=["truncToFixed","roundToFixed","numberFormatter","formatLocale","twoDigitAverage","twoDigitFloat","percentFormat","lstrip","rstrip","strip"]; -MochiKit.Format.LOCALE={en_US:{separator:",",decimal:".",percent:"%"},de_DE:{separator:".",decimal:",",percent:"%"},fr_FR:{separator:" ",decimal:",",percent:"%"},"default":"en_US"}; -MochiKit.Format.EXPORT_OK=[]; -MochiKit.Format.EXPORT_TAGS={":all":MochiKit.Format.EXPORT,":common":MochiKit.Format.EXPORT}; -MochiKit.Format.__new__=function(){ -var base=this.NAME+"."; -var k,v,o; -for(k in this.LOCALE){ -o=this.LOCALE[k]; -if(typeof (o)=="object"){ -o.repr=function(){ -return this.NAME; -}; -o.NAME=base+"LOCALE."+k; } +return elem; +},insertSiblingNodesBefore:function(node){ +var elem=node; +var self=MochiKit.DOM; +if(typeof (node)=="string"){ +elem=self.getElement(node); } -for(k in this){ -o=this[k]; -if(typeof (o)=="function"&&typeof (o.NAME)=="undefined"){ -try{ -o.NAME=base+k; +var _22e=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; +var _22f=elem.parentNode; +var _230=MochiKit.Base.concat; +while(_22e.length){ +var n=_22e.shift(); +if(typeof (n)=="undefined"||n===null){ +}else{ +if(typeof (n.nodeType)=="number"){ +_22f.insertBefore(n,elem); +}else{ +_22e=_230(n,_22e); } -catch(e){ } } +return _22f; +},insertSiblingNodesAfter:function(node){ +var elem=node; +var self=MochiKit.DOM; +if(typeof (node)=="string"){ +elem=self.getElement(node); } -}; -MochiKit.Format.__new__(); -if(typeof (MochiKit.Base)!="undefined"){ -MochiKit.Base._exportSymbols(this,MochiKit.Format); +var _235=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; +if(elem.nextSibling){ +return self.insertSiblingNodesBefore(elem.nextSibling,_235); }else{ -(function(_273,_274){ -if((typeof (JSAN)=="undefined"&&typeof (dojo)=="undefined")||(MochiKit.__export__===false)){ -var all=_274.EXPORT_TAGS[":all"]; -for(var i=0;i"; +_240=false; } -if(typeof (MochiKit.Async)=="undefined"){ -MochiKit.Async={}; } -MochiKit.Async.NAME="MochiKit.Async"; -MochiKit.Async.VERSION="1.4"; -MochiKit.Async.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.Async.toString=function(){ -return this.__repr__(); -}; -MochiKit.Async.Deferred=function(_277){ -this.chain=[]; -this.id=this._nextId(); -this.fired=-1; -this.paused=0; -this.results=[null,null]; -this.canceller=_277; -this.silentlyCancelled=false; -this.chained=false; -}; -MochiKit.Async.Deferred.prototype={repr:function(){ -var _278; -if(this.fired==-1){ -_278="unfired"; +var d=self._document; +if(_240&&d===document){ +elem=d.createElementNS("http://www.w3.org/1999/xhtml",name); }else{ -if(this.fired===0){ -_278="success"; +elem=d.createElement(name); +} }else{ -_278="error"; +elem=name; } +if(_23b){ +self.updateNodeAttributes(elem,_23b); } -return "Deferred("+this.id+", "+_278+")"; -},toString:MochiKit.Base.forwardCall("repr"),_nextId:MochiKit.Base.counter(),cancel:function(){ -var self=MochiKit.Async; -if(this.fired==-1){ -if(this.canceller){ -this.canceller(this); +if(arguments.length<=2){ +return elem; }else{ -this.silentlyCancelled=true; +var args=m.extend([elem],arguments,2); +return self.appendChildNodes.apply(this,args); } -if(this.fired==-1){ -this.errback(new self.CancelledError(this)); +},createDOMFunc:function(){ +var m=MochiKit.Base; +return m.partial.apply(this,m.extend([MochiKit.DOM.createDOM],arguments)); +},removeElement:function(elem){ +var e=MochiKit.DOM.getElement(elem); +e.parentNode.removeChild(e); +return e; +},swapDOM:function(dest,src){ +var self=MochiKit.DOM; +dest=self.getElement(dest); +var _249=dest.parentNode; +if(src){ +src=self.getElement(src); +_249.replaceChild(src,dest); +}else{ +_249.removeChild(dest); } +return src; +},getElement:function(id){ +var self=MochiKit.DOM; +if(arguments.length==1){ +return ((typeof (id)=="string")?self._document.getElementById(id):id); }else{ -if((this.fired===0)&&(this.results[0] instanceof self.Deferred)){ -this.results[0].cancel(); +return MochiKit.Base.map(self.getElement,arguments); } +},getElementsByTagAndClassName:function(_24c,_24d,_24e){ +var self=MochiKit.DOM; +if(typeof (_24c)=="undefined"||_24c===null){ +_24c="*"; } -},_resback:function(res){ -this.fired=((res instanceof Error)?1:0); -this.results[this.fired]=res; -this._fire(); -},_check:function(){ -if(this.fired!=-1){ -if(!this.silentlyCancelled){ -throw new MochiKit.Async.AlreadyCalledError(this); +if(typeof (_24e)=="undefined"||_24e===null){ +_24e=self._document; } -this.silentlyCancelled=false; -return; +_24e=self.getElement(_24e); +var _250=(_24e.getElementsByTagName(_24c)||self._document.all); +if(typeof (_24d)=="undefined"||_24d===null){ +return MochiKit.Base.extend(null,_250); } -},callback:function(res){ -this._check(); -if(res instanceof MochiKit.Async.Deferred){ -throw new Error("Deferred instances can only be chained if they are the result of a callback"); +var _251=[]; +for(var i=0;i<_250.length;i++){ +var _253=_250[i]; +var cls=_253.className; +if(!cls){ +continue; } -this._resback(res); -},errback:function(res){ -this._check(); -var self=MochiKit.Async; -if(res instanceof self.Deferred){ -throw new Error("Deferred instances can only be chained if they are the result of a callback"); +var _255=cls.split(" "); +for(var j=0;j<_255.length;j++){ +if(_255[j]==_24d){ +_251.push(_253); +break; } -if(!(res instanceof Error)){ -res=new self.GenericError(res); } -this._resback(res); -},addBoth:function(fn){ -if(arguments.length>1){ -fn=MochiKit.Base.partial.apply(null,arguments); } -return this.addCallbacks(fn,fn); -},addCallback:function(fn){ -if(arguments.length>1){ -fn=MochiKit.Base.partial.apply(null,arguments); +return _251; +},_newCallStack:function(path,once){ +var rval=function(){ +var _25a=arguments.callee.callStack; +for(var i=0;i<_25a.length;i++){ +if(_25a[i].apply(this,arguments)===false){ +break; } -return this.addCallbacks(fn,null); -},addErrback:function(fn){ -if(arguments.length>1){ -fn=MochiKit.Base.partial.apply(null,arguments); -} -return this.addCallbacks(null,fn); -},addCallbacks:function(cb,eb){ -if(this.chained){ -throw new Error("Chained Deferreds can not be re-used"); -} -this.chain.push([cb,eb]); -if(this.fired>=0){ -this._fire(); -} -return this; -},_fire:function(){ -var _283=this.chain; -var _284=this.fired; -var res=this.results[_284]; -var self=this; -var cb=null; -while(_283.length>0&&this.paused===0){ -var pair=_283.shift(); -var f=pair[_284]; -if(f===null){ -continue; } +if(once){ try{ -res=f(res); -_284=((res instanceof Error)?1:0); -if(res instanceof MochiKit.Async.Deferred){ -cb=function(res){ -self._resback(res); -self.paused--; -if((self.paused===0)&&(self.fired>=0)){ -self._fire(); +this[path]=null; +} +catch(e){ +} } }; -this.paused++; +rval.callStack=[]; +return rval; +},addToCallStack:function(_25c,path,func,once){ +var self=MochiKit.DOM; +var _261=_25c[path]; +var _262=_261; +if(!(typeof (_261)=="function"&&typeof (_261.callStack)=="object"&&_261.callStack!==null)){ +_262=self._newCallStack(path,once); +if(typeof (_261)=="function"){ +_262.callStack.push(_261); } +_25c[path]=_262; } -catch(err){ -_284=1; -if(!(err instanceof Error)){ -err=new MochiKit.Async.GenericError(err); +_262.callStack.push(func); +},addLoadEvent:function(func){ +var self=MochiKit.DOM; +self.addToCallStack(self._window,"onload",func,true); +},focusOnLoad:function(_265){ +var self=MochiKit.DOM; +self.addLoadEvent(function(){ +_265=self.getElement(_265); +if(_265){ +_265.focus(); } -res=err; +}); +},setElementClass:function(_267,_268){ +var self=MochiKit.DOM; +var obj=self.getElement(_267); +if(self.attributeArray.compliant){ +obj.setAttribute("class",_268); +}else{ +obj.setAttribute("className",_268); } +},toggleElementClass:function(_26b){ +var self=MochiKit.DOM; +for(var i=1;i/g,">"); +},toHTML:function(dom){ +return MochiKit.DOM.emitHTML(dom).join(""); +},emitHTML:function(dom,lst){ +if(typeof (lst)=="undefined"||lst===null){ +lst=[]; } -catch(e){ -try{ -req.onreadystatechange=MochiKit.Base.noop; +var _28e=[dom]; +var self=MochiKit.DOM; +var _290=self.escapeHTML; +var _291=self.attributeArray; +while(_28e.length){ +dom=_28e.pop(); +if(typeof (dom)=="string"){ +lst.push(dom); +}else{ +if(dom.nodeType==1){ +lst.push("<"+dom.tagName.toLowerCase()); +var _292=[]; +var _293=_291(dom); +for(var i=0;i<_293.length;i++){ +var a=_293[i]; +_292.push([" ",a.name,"=\"",_290(a.value),"\""]); } -catch(e){ +_292.sort(); +for(i=0;i<_292.length;i++){ +var _296=_292[i]; +for(var j=0;j<_296.length;j++){ +lst.push(_296[j]); } } -req.abort(); -},sendXMLHttpRequest:function(req,_299){ -if(typeof (_299)=="undefined"||_299===null){ -_299=""; +if(dom.hasChildNodes()){ +lst.push(">"); +_28e.push(""); +var _298=dom.childNodes; +for(i=_298.length-1;i>=0;i--){ +_28e.push(_298[i]); } -var m=MochiKit.Base; -var self=MochiKit.Async; -var d=new self.Deferred(m.partial(self._xhr_canceller,req)); -try{ -req.onreadystatechange=m.bind(self._xhr_onreadystatechange,req,d); -req.send(_299); +}else{ +lst.push("/>"); } -catch(e){ -try{ -req.onreadystatechange=null; +}else{ +if(dom.nodeType==3){ +lst.push(_290(dom.nodeValue)); } -catch(ignore){ } -d.errback(e); } -return d; -},doXHR:function(url,opts){ -var self=MochiKit.Async; -return self.callLater(0,self._doXHR,url,opts); -},_doXHR:function(url,opts){ -var m=MochiKit.Base; -opts=m.update({method:"GET",sendContent:""},opts); -var self=MochiKit.Async; -var req=self.getXMLHttpRequest(); -if(opts.queryString){ -var qs=m.queryString(opts.queryString); -if(qs){ -url+="?"+qs; } +return lst; +},scrapeText:function(node,_29a){ +var rval=[]; +(function(node){ +var cn=node.childNodes; +if(cn){ +for(var i=0;i1){ -var m=MochiKit.Base; -var qs=m.queryString.apply(null,m.extend(null,arguments,1)); -if(qs){ -return url+"?"+qs; -} -} -return url; -},doSimpleXMLHttpRequest:function(url){ -var self=MochiKit.Async; -url=self._buildURL.apply(self,arguments); -return self.doXHR(url); -},loadJSONDoc:function(url){ -var self=MochiKit.Async; -url=self._buildURL.apply(self,arguments); -var d=self.doXHR(url,{"mimeType":"text/plain","headers":[["Accept","application/json"]]}); -d=d.addCallback(self.evalJSONRequest); -return d; -},wait:function(_2b3,_2b4){ -var d=new MochiKit.Async.Deferred(); -var m=MochiKit.Base; -if(typeof (_2b4)!="undefined"){ -d.addCallback(function(){ -return _2b4; -}); +_2a5.style.overflow=_2a6; +},makePositioned:function(_2a7){ +_2a7=MochiKit.DOM.getElement(_2a7); +var pos=MochiKit.Style.getStyle(_2a7,"position"); +if(pos=="static"||!pos){ +_2a7.style.position="relative"; +if(/Opera/.test(navigator.userAgent)){ +_2a7.style.top=0; +_2a7.style.left=0; } -var _2b7=setTimeout(m.bind("callback",d),Math.floor(_2b3*1000)); -d.canceller=function(){ -try{ -clearTimeout(_2b7); } -catch(e){ +},undoPositioned:function(_2a9){ +_2a9=MochiKit.DOM.getElement(_2a9); +if(_2a9.style.position=="relative"){ +_2a9.style.position=_2a9.style.top=_2a9.style.left=_2a9.style.bottom=_2a9.style.right=""; } -}; -return d; -},callLater:function(_2b8,func){ -var m=MochiKit.Base; -var _2bb=m.partial.apply(m,m.extend(null,arguments,1)); -return MochiKit.Async.wait(_2b8).addCallback(function(res){ -return _2bb(); -}); -}}); -MochiKit.Async.DeferredLock=function(){ -this.waiting=[]; -this.locked=false; -this.id=this._nextId(); -}; -MochiKit.Async.DeferredLock.prototype={__class__:MochiKit.Async.DeferredLock,acquire:function(){ -var d=new MochiKit.Async.Deferred(); -if(this.locked){ -this.waiting.push(d); -}else{ -this.locked=true; -d.callback(this); +},getFirstElementByTagAndClassName:function(_2aa,_2ab,_2ac){ +var self=MochiKit.DOM; +if(typeof (_2aa)=="undefined"||_2aa===null){ +_2aa="*"; } -return d; -},release:function(){ -if(!this.locked){ -throw TypeError("Tried to release an unlocked DeferredLock"); +if(typeof (_2ac)=="undefined"||_2ac===null){ +_2ac=self._document; } -this.locked=false; -if(this.waiting.length>0){ -this.locked=true; -this.waiting.shift().callback(this); +_2ac=self.getElement(_2ac); +var _2ae=(_2ac.getElementsByTagName(_2aa)||self._document.all); +if(typeof (_2ab)=="undefined"||_2ab===null){ +return _2ae[0]; } -},_nextId:MochiKit.Base.counter(),repr:function(){ -var _2be; -if(this.locked){ -_2be="locked, "+this.waiting.length+" waiting"; +for(var i=0;i<_2ae.length;i++){ +var _2b0=_2ae[i]; +var _2b1=_2b0.className.split(" "); +for(var j=0;j<_2b1.length;j++){ +if(_2b1[j]==_2ab){ +return _2b0; +} +} +} +},getFirstParentByTagAndClassName:function(elem,_2b4,_2b5){ +var self=MochiKit.DOM; +elem=self.getElement(elem); +if(typeof (_2b4)=="undefined"||_2b4===null){ +_2b4="*"; }else{ -_2be="unlocked"; +_2b4=_2b4.toUpperCase(); } -return "DeferredLock("+this.id+", "+_2be+")"; -},toString:MochiKit.Base.forwardCall("repr")}; -MochiKit.Async.DeferredList=function(list,_2c0,_2c1,_2c2,_2c3){ -MochiKit.Async.Deferred.apply(this,[_2c3]); -this.list=list; -var _2c4=[]; -this.resultList=_2c4; -this.finishedCount=0; -this.fireOnOneCallback=_2c0; -this.fireOnOneErrback=_2c1; -this.consumeErrors=_2c2; -var cb=MochiKit.Base.bind(this._cbDeferred,this); -for(var i=0;i0){ +var _2c1=m.filter; +_2c0=function(node){ +return _2c1(_2c0.ignoreAttrFilter,node.attributes); +}; +_2c0.ignoreAttr={}; +var _2c3=_2bf.attributes; +var _2c4=_2c0.ignoreAttr; +for(var i=0;i<_2c3.length;i++){ +var a=_2c3[i]; +_2c4[a.name]=a.value; +} +_2c0.ignoreAttrFilter=function(a){ +return (_2c0.ignoreAttr[a.name]!=a.value); +}; +_2c0.compliant=false; +_2c0.renames={"class":"className","checked":"defaultChecked","usemap":"useMap","for":"htmlFor","readonly":"readOnly","colspan":"colSpan","bgcolor":"bgColor","cellspacing":"cellSpacing","cellpadding":"cellPadding"}; +}else{ +_2c0=function(node){ +return node.attributes; }; -MochiKit.Async.EXPORT=["AlreadyCalledError","CancelledError","BrowserComplianceError","GenericError","XMLHttpRequestError","Deferred","succeed","fail","getXMLHttpRequest","doSimpleXMLHttpRequest","loadJSONDoc","wait","callLater","sendXMLHttpRequest","DeferredLock","DeferredList","gatherResults","maybeDeferred","doXHR"]; -MochiKit.Async.EXPORT_OK=["evalJSONRequest"]; -MochiKit.Async.__new__=function(){ -var m=MochiKit.Base; -var ne=m.partial(m._newNamedError,this); -ne("AlreadyCalledError",function(_2d6){ -this.deferred=_2d6; -}); -ne("CancelledError",function(_2d7){ -this.deferred=_2d7; -}); -ne("BrowserComplianceError",function(msg){ -this.message=msg; -}); -ne("GenericError",function(msg){ -this.message=msg; -}); -ne("XMLHttpRequestError",function(req,msg){ -this.req=req; -this.message=msg; -try{ -this.number=req.status; -} -catch(e){ +_2c0.compliant=true; +_2c0.renames={}; } -}); +this.attributeArray=_2c0; +var _2c9=function(_2ca,arr){ +var _2cc=arr[1].split("."); +var str=""; +var obj={}; +str+="if (!MochiKit."+_2cc[1]+") { throw new Error(\""; +str+="This function has been deprecated and depends on MochiKit."; +str+=_2cc[1]+".\");}"; +str+="return MochiKit."+_2cc[1]+"."+arr[0]; +str+=".apply(this, arguments);"; +obj[_2cc[2]]=new Function(str); +MochiKit.Base.update(MochiKit[_2ca],obj); +}; +for(var i;i=0){ -var opt=elem.options[elem.selectedIndex]; -var v=opt.value; -if(!v){ -var h=opt.outerHTML; -if(h&&!h.match(/^[^>]+\svalue\s*=/i)){ -v=opt.text; } } -_2e3.push(name); -_2e4.push(v); -return null; +if(_2d7=="opacity"){ +_2db=parseFloat(_2db); } -_2e3.push(name); -_2e4.push(""); -return null; -}else{ -var opts=elem.options; -if(!opts.length){ -_2e3.push(name); -_2e4.push(""); -return null; +if(/Opera/.test(navigator.userAgent)&&(MochiKit.Base.find(["left","top","right","bottom"],_2d7)!=-1)){ +if(MochiKit.Style.getStyle(elem,"position")=="static"){ +_2db="auto"; } -for(var i=0;i]+\svalue\s*=/i)){ -v=opt.text; +return _2db=="auto"?null:_2db; +},setStyle:function(elem,_2de){ +elem=MochiKit.DOM.getElement(elem); +for(var name in _2de){ +if(name=="opacity"){ +MochiKit.Style.setOpacity(elem,_2de[name]); +}else{ +elem.style[MochiKit.Base.camelize(name)]=_2de[name]; } } -_2e3.push(name); -_2e4.push(v); +},setOpacity:function(elem,o){ +elem=MochiKit.DOM.getElement(elem); +var self=MochiKit.Style; +if(o==1){ +var _2e3=/Gecko/.test(navigator.userAgent)&&!(/Konqueror|AppleWebKit|KHTML/.test(navigator.userAgent)); +elem.style["opacity"]=_2e3?0.999999:1; +if(/MSIE/.test(navigator.userAgent)){ +elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,""); } -return null; +}else{ +if(o<0.00001){ +o=0; } +elem.style["opacity"]=o; +if(/MSIE/.test(navigator.userAgent)){ +elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,"")+"alpha(opacity="+o*100+")"; } -if(_2e9==="FORM"||_2e9==="P"||_2e9==="SPAN"||_2e9==="DIV"){ -return elem.childNodes; } -_2e3.push(name); -_2e4.push(elem.value||""); -return null; +},getElementPosition:function(elem,_2e5){ +var self=MochiKit.Style; +var dom=MochiKit.DOM; +elem=dom.getElement(elem); +if(!elem||(!(elem.x&&elem.y)&&(!elem.parentNode===null||self.getStyle(elem,"display")=="none"))){ +return undefined; } -return elem.childNodes; -}); -return [_2e3,_2e4]; -},withDocument:function(doc,func){ -var self=MochiKit.DOM; -var _2f2=self._document; -var rval; -try{ -self._document=doc; -rval=func(); +var c=new self.Coordinates(0,0); +var box=null; +var _2ea=null; +var d=MochiKit.DOM._document; +var de=d.documentElement; +var b=d.body; +if(!elem.parentNode&&elem.x&&elem.y){ +c.x+=elem.x||0; +c.y+=elem.y||0; +}else{ +if(elem.getBoundingClientRect){ +box=elem.getBoundingClientRect(); +c.x+=box.left+(de.scrollLeft||b.scrollLeft)-(de.clientLeft||0); +c.y+=box.top+(de.scrollTop||b.scrollTop)-(de.clientTop||0); +}else{ +if(elem.offsetParent){ +c.x+=elem.offsetLeft; +c.y+=elem.offsetTop; +_2ea=elem.offsetParent; +if(_2ea!=elem){ +while(_2ea){ +c.x+=_2ea.offsetLeft; +c.y+=_2ea.offsetTop; +_2ea=_2ea.offsetParent; } -catch(e){ -self._document=_2f2; -throw e; } -self._document=_2f2; -return rval; -},registerDOMConverter:function(name,_2f5,wrap,_2f7){ -MochiKit.DOM.domConverters.register(name,_2f5,wrap,_2f7); -},coerceToDOM:function(node,ctx){ -var m=MochiKit.Base; -var im=MochiKit.Iter; -var self=MochiKit.DOM; -if(im){ -var iter=im.iter; -var _2fe=im.repeat; -var map=m.map; +var ua=navigator.userAgent.toLowerCase(); +if((typeof (opera)!="undefined"&&parseFloat(opera.version())<9)||(ua.indexOf("AppleWebKit")!=-1&&self.getStyle(elem,"position")=="absolute")){ +c.x-=b.offsetLeft; +c.y-=b.offsetTop; } -var _300=self.domConverters; -var _301=arguments.callee; -var _302=m.NotFound; -while(true){ -if(typeof (node)=="undefined"||node===null){ -return null; } -if(typeof (node)=="function"&&typeof (node.length)=="number"&&!(node instanceof Function)){ -node=im.list(node); } -if(typeof (node.nodeType)!="undefined"&&node.nodeType>0){ -return node; } -if(typeof (node)=="number"||typeof (node)=="boolean"){ -node=node.toString(); +if(typeof (_2e5)!="undefined"){ +_2e5=arguments.callee(_2e5); +if(_2e5){ +c.x-=(_2e5.x||0); +c.y-=(_2e5.y||0); } -if(typeof (node)=="string"){ -return self._document.createTextNode(node); } -if(typeof (node.__dom__)=="function"){ -node=node.__dom__(ctx); -continue; +if(elem.parentNode){ +_2ea=elem.parentNode; +}else{ +_2ea=null; } -if(typeof (node.dom)=="function"){ -node=node.dom(ctx); -continue; +while(_2ea){ +var _2ef=_2ea.tagName.toUpperCase(); +if(_2ef==="BODY"||_2ef==="HTML"){ +break; } -if(typeof (node)=="function"){ -node=node.apply(ctx,[ctx]); -continue; +var disp=self.getStyle(_2ea,"display"); +if(disp!="inline"&&disp!="table-row"){ +c.x-=_2ea.scrollLeft; +c.y-=_2ea.scrollTop; } -if(im){ -var _303=null; -try{ -_303=iter(node); +if(_2ea.parentNode){ +_2ea=_2ea.parentNode; +}else{ +_2ea=null; } -catch(e){ } -if(_303){ -return map(_301,_303,_2fe(ctx)); +return c; +},setElementPosition:function(elem,_2f2,_2f3){ +elem=MochiKit.DOM.getElement(elem); +if(typeof (_2f3)=="undefined"){ +_2f3="px"; } +var _2f4={}; +var _2f5=MochiKit.Base.isUndefinedOrNull; +if(!_2f5(_2f2.x)){ +_2f4["left"]=_2f2.x+_2f3; } -try{ -node=_300.match(node,ctx); -continue; +if(!_2f5(_2f2.y)){ +_2f4["top"]=_2f2.y+_2f3; } -catch(e){ -if(e!=_302){ -throw e; +MochiKit.DOM.updateNodeAttributes(elem,{"style":_2f4}); +},getElementDimensions:function(elem){ +var self=MochiKit.Style; +var dom=MochiKit.DOM; +if(typeof (elem.w)=="number"||typeof (elem.h)=="number"){ +return new self.Dimensions(elem.w||0,elem.h||0); } +elem=dom.getElement(elem); +if(!elem){ +return undefined; } -return self._document.createTextNode(node.toString()); +var disp=self.getStyle(elem,"display"); +if(disp!="none"&&disp!==""&&typeof (disp)!="undefined"){ +return new self.Dimensions(elem.offsetWidth||0,elem.offsetHeight||0); } -return undefined; -},isChildNode:function(node,_305){ -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -node=self.getElement(node); +var s=elem.style; +var _2fb=s.visibility; +var _2fc=s.position; +s.visibility="hidden"; +s.position="absolute"; +s.display=""; +var _2fd=elem.offsetWidth; +var _2fe=elem.offsetHeight; +s.display="none"; +s.position=_2fc; +s.visibility=_2fb; +return new self.Dimensions(_2fd,_2fe); +},setElementDimensions:function(elem,_300,_301){ +elem=MochiKit.DOM.getElement(elem); +if(typeof (_301)=="undefined"){ +_301="px"; } -if(typeof (_305)=="string"){ -_305=self.getElement(_305); +var _302={}; +var _303=MochiKit.Base.isUndefinedOrNull; +if(!_303(_300.w)){ +_302["width"]=_300.w+_301; } -if(node===_305){ -return true; +if(!_303(_300.h)){ +_302["height"]=_300.h+_301; } -while(node&&node.tagName.toUpperCase()!="BODY"){ -node=node.parentNode; -if(node===_305){ -return true; +MochiKit.DOM.updateNodeAttributes(elem,{"style":_302}); +},setDisplayForElement:function(_304,_305){ +var _306=MochiKit.Base.extend(null,arguments,1); +var _307=MochiKit.DOM.getElement; +for(var i=0;i<_306.length;i++){ +_305=_307(_306[i]); +if(_305){ +_305.style.display=_304; } } -return false; -},setNodeAttribute:function(node,attr,_309){ -var o={}; -o[attr]=_309; -try{ -return MochiKit.DOM.updateNodeAttributes(node,o); -} -catch(e){ -} -return null; -},getNodeAttribute:function(node,attr){ -var self=MochiKit.DOM; -var _30e=self.attributeArray.renames[attr]; -node=self.getElement(node); -try{ -if(_30e){ -return node[_30e]; -} -return node.getAttribute(attr); -} -catch(e){ -} -return null; -},removeNodeAttribute:function(node,attr){ -var self=MochiKit.DOM; -var _312=self.attributeArray.renames[attr]; -node=self.getElement(node); -try{ -if(_312){ -return node[_312]; -} -return node.removeAttribute(attr); -} -catch(e){ -} -return null; -},updateNodeAttributes:function(node,_314){ -var elem=node; -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -elem=self.getElement(node); -} -if(_314){ -var _317=MochiKit.Base.updatetree; -if(self.attributeArray.compliant){ -for(var k in _314){ -var v=_314[k]; -if(typeof (v)=="object"&&typeof (elem[k])=="object"){ -if(k=="style"&&MochiKit.Style){ -MochiKit.Style.setStyle(elem,v); -}else{ -_317(elem[k],v); -} +},getViewportDimensions:function(){ +var d=new MochiKit.Style.Dimensions(); +var w=MochiKit.DOM._window; +var b=MochiKit.DOM._document.body; +if(w.innerWidth){ +d.w=w.innerWidth; +d.h=w.innerHeight; }else{ -if(k.substring(0,2)=="on"){ -if(typeof (v)=="string"){ -v=new Function(v); -} -elem[k]=v; +if(b.parentElement.clientWidth){ +d.w=b.parentElement.clientWidth; +d.h=b.parentElement.clientHeight; }else{ -elem.setAttribute(k,v); -} -} +if(b&&b.clientWidth){ +d.w=b.clientWidth; +d.h=b.clientHeight; } -}else{ -var _31a=self.attributeArray.renames; -for(var k in _314){ -v=_314[k]; -var _31b=_31a[k]; -if(k=="style"&&typeof (v)=="string"){ -elem.style.cssText=v; -}else{ -if(typeof (_31b)=="string"){ -elem[_31b]=v; -}else{ -if(typeof (elem[k])=="object"&&typeof (v)=="object"){ -if(k=="style"&&MochiKit.Style){ -MochiKit.Style.setStyle(elem,v); -}else{ -_317(elem[k],v); } -}else{ -if(k.substring(0,2)=="on"){ -if(typeof (v)=="string"){ -v=new Function(v); } -elem[k]=v; +return d; +},getViewportPosition:function(){ +var c=new MochiKit.Style.Coordinates(0,0); +var d=MochiKit.DOM._document; +var de=d.documentElement; +var db=d.body; +if(de&&(de.scrollTop||de.scrollLeft)){ +c.x=de.scrollLeft; +c.y=de.scrollTop; }else{ -elem.setAttribute(k,v); +if(db){ +c.x=db.scrollLeft; +c.y=db.scrollTop; } } +return c; +},__new__:function(){ +var m=MochiKit.Base; +this.elementPosition=this.getElementPosition; +this.elementDimensions=this.getElementDimensions; +this.hideElement=m.partial(this.setDisplayForElement,"none"); +this.showElement=m.partial(this.setDisplayForElement,"block"); +this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; +m.nameFunctions(this); +}}); +MochiKit.Style.__new__(); +MochiKit.Base._exportSymbols(this,MochiKit.Style); +if(typeof (dojo)!="undefined"){ +dojo.provide("MochiKit.Color"); +dojo.require("MochiKit.Base"); +dojo.require("MochiKit.DOM"); +dojo.require("MochiKit.Style"); } +if(typeof (JSAN)!="undefined"){ +JSAN.use("MochiKit.Base",[]); +JSAN.use("MochiKit.DOM",[]); +JSAN.use("MochiKit.Style",[]); } +try{ +if(typeof (MochiKit.Base)=="undefined"){ +throw ""; } } +catch(e){ +throw "MochiKit.Color depends on MochiKit.Base"; } -return elem; -},appendChildNodes:function(node){ -var elem=node; -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -elem=self.getElement(node); +try{ +if(typeof (MochiKit.DOM)=="undefined"){ +throw ""; } -var _31f=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; -var _320=MochiKit.Base.concat; -while(_31f.length){ -var n=_31f.shift(); -if(typeof (n)=="undefined"||n===null){ -}else{ -if(typeof (n.nodeType)=="number"){ -elem.appendChild(n); -}else{ -_31f=_320(n,_31f); } +catch(e){ +throw "MochiKit.Color depends on MochiKit.DOM"; } +try{ +if(typeof (MochiKit.Style)=="undefined"){ +throw ""; } -return elem; -},insertSiblingNodesBefore:function(node){ -var elem=node; -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -elem=self.getElement(node); } -var _325=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; -var _326=elem.parentNode; -var _327=MochiKit.Base.concat; -while(_325.length){ -var n=_325.shift(); -if(typeof (n)=="undefined"||n===null){ -}else{ -if(typeof (n.nodeType)=="number"){ -_326.insertBefore(n,elem); -}else{ -_325=_327(n,_325); +catch(e){ +throw "MochiKit.Color depends on MochiKit.Style"; } +if(typeof (MochiKit.Color)=="undefined"){ +MochiKit.Color={}; } +MochiKit.Color.NAME="MochiKit.Color"; +MochiKit.Color.VERSION="1.4"; +MochiKit.Color.__repr__=function(){ +return "["+this.NAME+" "+this.VERSION+"]"; +}; +MochiKit.Color.toString=function(){ +return this.__repr__(); +}; +MochiKit.Color.Color=function(red,_312,blue,_314){ +if(typeof (_314)=="undefined"||_314===null){ +_314=1; } -return _326; -},insertSiblingNodesAfter:function(node){ -var elem=node; -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -elem=self.getElement(node); +this.rgb={r:red,g:_312,b:blue,a:_314}; +}; +MochiKit.Color.Color.prototype={__class__:MochiKit.Color.Color,colorWithAlpha:function(_315){ +var rgb=this.rgb; +var m=MochiKit.Color; +return m.Color.fromRGB(rgb.r,rgb.g,rgb.b,_315); +},colorWithHue:function(hue){ +var hsl=this.asHSL(); +hsl.h=hue; +var m=MochiKit.Color; +return m.Color.fromHSL(hsl); +},colorWithSaturation:function(_31b){ +var hsl=this.asHSL(); +hsl.s=_31b; +var m=MochiKit.Color; +return m.Color.fromHSL(hsl); +},colorWithLightness:function(_31e){ +var hsl=this.asHSL(); +hsl.l=_31e; +var m=MochiKit.Color; +return m.Color.fromHSL(hsl); +},darkerColorWithLevel:function(_321){ +var hsl=this.asHSL(); +hsl.l=Math.max(hsl.l-_321,0); +var m=MochiKit.Color; +return m.Color.fromHSL(hsl); +},lighterColorWithLevel:function(_324){ +var hsl=this.asHSL(); +hsl.l=Math.min(hsl.l+_324,1); +var m=MochiKit.Color; +return m.Color.fromHSL(hsl); +},blendedColor:function(_327,_328){ +if(typeof (_328)=="undefined"||_328===null){ +_328=0.5; } -var _32c=[self.coerceToDOM(MochiKit.Base.extend(null,arguments,1),elem)]; -if(elem.nextSibling){ -return self.insertSiblingNodesBefore(elem.nextSibling,_32c); +var sf=1-_328; +var s=this.rgb; +var d=_327.rgb; +var df=_328; +return MochiKit.Color.Color.fromRGB((s.r*sf)+(d.r*df),(s.g*sf)+(d.g*df),(s.b*sf)+(d.b*df),(s.a*sf)+(d.a*df)); +},compareRGB:function(_32d){ +var a=this.asRGB(); +var b=_32d.asRGB(); +return MochiKit.Base.compare([a.r,a.g,a.b,a.a],[b.r,b.g,b.b,b.a]); +},isLight:function(){ +return this.asHSL().b>0.5; +},isDark:function(){ +return (!this.isLight()); +},toHSLString:function(){ +var c=this.asHSL(); +var ccc=MochiKit.Color.clampColorComponent; +var rval=this._hslString; +if(!rval){ +var mid=(ccc(c.h,360).toFixed(0)+","+ccc(c.s,100).toPrecision(4)+"%"+","+ccc(c.l,100).toPrecision(4)+"%"); +var a=c.a; +if(a>=1){ +a=1; +rval="hsl("+mid+")"; }else{ -return self.appendChildNodes(elem.parentNode,_32c); +if(a<=0){ +a=0; } -},replaceChildNodes:function(node){ -var elem=node; -var self=MochiKit.DOM; -if(typeof (node)=="string"){ -elem=self.getElement(node); -arguments[0]=elem; +rval="hsla("+mid+","+a+")"; } -var _330; -while((_330=elem.firstChild)){ -elem.removeChild(_330); +this._hslString=rval; } -if(arguments.length<2){ -return elem; +return rval; +},toRGBString:function(){ +var c=this.rgb; +var ccc=MochiKit.Color.clampColorComponent; +var rval=this._rgbString; +if(!rval){ +var mid=(ccc(c.r,255).toFixed(0)+","+ccc(c.g,255).toFixed(0)+","+ccc(c.b,255).toFixed(0)); +if(c.a!=1){ +rval="rgba("+mid+","+c.a+")"; }else{ -return self.appendChildNodes.apply(this,arguments); -} -},createDOM:function(name,_332){ -var elem; -var self=MochiKit.DOM; -var m=MochiKit.Base; -if(typeof (_332)=="string"||typeof (_332)=="number"){ -var args=m.extend([name,null],arguments,1); -return arguments.callee.apply(this,args); -} -if(typeof (name)=="string"){ -var _337=self._xhtml; -if(_332&&!self.attributeArray.compliant){ -var _338=""; -if("name" in _332){ -_338+=" name=\""+self.escapeHTML(_332.name)+"\""; +rval="rgb("+mid+")"; } -if(name=="input"&&"type" in _332){ -_338+=" type=\""+self.escapeHTML(_332.type)+"\""; +this._rgbString=rval; } -if(_338){ -name="<"+name+_338+">"; -_337=false; +return rval; +},asRGB:function(){ +return MochiKit.Base.clone(this.rgb); +},toHexString:function(){ +var m=MochiKit.Color; +var c=this.rgb; +var ccc=MochiKit.Color.clampColorComponent; +var rval=this._hexString; +if(!rval){ +rval=("#"+m.toColorPart(ccc(c.r,255))+m.toColorPart(ccc(c.g,255))+m.toColorPart(ccc(c.b,255))); +this._hexString=rval; } +return rval; +},asHSV:function(){ +var hsv=this.hsv; +var c=this.rgb; +if(typeof (hsv)=="undefined"||hsv===null){ +hsv=MochiKit.Color.rgbToHSV(this.rgb); +this.hsv=hsv; } -var d=self._document; -if(_337&&d===document){ -elem=d.createElementNS("http://www.w3.org/1999/xhtml",name); -}else{ -elem=d.createElement(name); +return MochiKit.Base.clone(hsv); +},asHSL:function(){ +var hsl=this.hsl; +var c=this.rgb; +if(typeof (hsl)=="undefined"||hsl===null){ +hsl=MochiKit.Color.rgbToHSL(this.rgb); +this.hsl=hsl; } -}else{ -elem=name; -} -if(_332){ -self.updateNodeAttributes(elem,_332); -} -if(arguments.length<=2){ -return elem; -}else{ -var args=m.extend([elem],arguments,2); -return self.appendChildNodes.apply(this,args); -} -},createDOMFunc:function(){ -var m=MochiKit.Base; -return m.partial.apply(this,m.extend([MochiKit.DOM.createDOM],arguments)); -},removeElement:function(elem){ -var e=MochiKit.DOM.getElement(elem); -e.parentNode.removeChild(e); -return e; -},swapDOM:function(dest,src){ -var self=MochiKit.DOM; -dest=self.getElement(dest); -var _340=dest.parentNode; -if(src){ -src=self.getElement(src); -_340.replaceChild(src,dest); -}else{ -_340.removeChild(dest); -} -return src; -},getElement:function(id){ -var self=MochiKit.DOM; -if(arguments.length==1){ -return ((typeof (id)=="string")?self._document.getElementById(id):id); -}else{ -return MochiKit.Base.map(self.getElement,arguments); -} -},getElementsByTagAndClassName:function(_343,_344,_345){ -var self=MochiKit.DOM; -if(typeof (_343)=="undefined"||_343===null){ -_343="*"; -} -if(typeof (_345)=="undefined"||_345===null){ -_345=self._document; -} -_345=self.getElement(_345); -var _347=(_345.getElementsByTagName(_343)||self._document.all); -if(typeof (_344)=="undefined"||_344===null){ -return MochiKit.Base.extend(null,_347); -} -var _348=[]; -for(var i=0;i<_347.length;i++){ -var _34a=_347[i]; -var cls=_34a.className; -if(!cls){ -continue; -} -var _34c=cls.split(" "); -for(var j=0;j<_34c.length;j++){ -if(_34c[j]==_344){ -_348.push(_34a); -break; -} -} -} -return _348; -},_newCallStack:function(path,once){ -var rval=function(){ -var _351=arguments.callee.callStack; -for(var i=0;i<_351.length;i++){ -if(_351[i].apply(this,arguments)===false){ -break; -} -} -if(once){ -try{ -this[path]=null; -} -catch(e){ -} -} -}; -rval.callStack=[]; -return rval; -},addToCallStack:function(_353,path,func,once){ -var self=MochiKit.DOM; -var _358=_353[path]; -var _359=_358; -if(!(typeof (_358)=="function"&&typeof (_358.callStack)=="object"&&_358.callStack!==null)){ -_359=self._newCallStack(path,once); -if(typeof (_358)=="function"){ -_359.callStack.push(_358); -} -_353[path]=_359; -} -_359.callStack.push(func); -},addLoadEvent:function(func){ -var self=MochiKit.DOM; -self.addToCallStack(self._window,"onload",func,true); -},focusOnLoad:function(_35c){ -var self=MochiKit.DOM; -self.addLoadEvent(function(){ -_35c=self.getElement(_35c); -if(_35c){ -_35c.focus(); -} -}); -},setElementClass:function(_35e,_35f){ -var self=MochiKit.DOM; -var obj=self.getElement(_35e); -if(self.attributeArray.compliant){ -obj.setAttribute("class",_35f); -}else{ -obj.setAttribute("className",_35f); -} -},toggleElementClass:function(_362){ -var self=MochiKit.DOM; -for(var i=1;i/g,">"); -},toHTML:function(dom){ -return MochiKit.DOM.emitHTML(dom).join(""); -},emitHTML:function(dom,lst){ -if(typeof (lst)=="undefined"||lst===null){ -lst=[]; -} -var _385=[dom]; -var self=MochiKit.DOM; -var _387=self.escapeHTML; -var _388=self.attributeArray; -while(_385.length){ -dom=_385.pop(); -if(typeof (dom)=="string"){ -lst.push(dom); -}else{ -if(dom.nodeType==1){ -lst.push("<"+dom.tagName.toLowerCase()); -var _389=[]; -var _38a=_388(dom); -for(var i=0;i<_38a.length;i++){ -var a=_38a[i]; -_389.push([" ",a.name,"=\"",_387(a.value),"\""]); -} -_389.sort(); -for(i=0;i<_389.length;i++){ -var _38d=_389[i]; -for(var j=0;j<_38d.length;j++){ -lst.push(_38d[j]); -} -} -if(dom.hasChildNodes()){ -lst.push(">"); -_385.push(""); -var _38f=dom.childNodes; -for(i=_38f.length-1;i>=0;i--){ -_385.push(_38f[i]); -} -}else{ -lst.push("/>"); -} -}else{ -if(dom.nodeType==3){ -lst.push(_387(dom.nodeValue)); -} -} -} -} -return lst; -},scrapeText:function(node,_391){ -var rval=[]; -(function(node){ -var cn=node.childNodes; -if(cn){ -for(var i=0;i0){ -var _3b8=m.filter; -_3b7=function(node){ -return _3b8(_3b7.ignoreAttrFilter,node.attributes); -}; -_3b7.ignoreAttr={}; -var _3ba=_3b6.attributes; -var _3bb=_3b7.ignoreAttr; -for(var i=0;i<_3ba.length;i++){ -var a=_3ba[i]; -_3bb[a.name]=a.value; -} -_3b7.ignoreAttrFilter=function(a){ -return (_3b7.ignoreAttr[a.name]!=a.value); -}; -_3b7.compliant=false; -_3b7.renames={"class":"className","checked":"defaultChecked","usemap":"useMap","for":"htmlFor","readonly":"readOnly","colspan":"colSpan","bgcolor":"bgColor","cellspacing":"cellSpacing","cellpadding":"cellPadding"}; -}else{ -_3b7=function(node){ -return node.attributes; -}; -_3b7.compliant=true; -_3b7.renames={}; -} -this.attributeArray=_3b7; -var _3c0=function(_3c1,arr){ -var _3c3=arr[1].split("."); -var str=""; -var obj={}; -str+="if (!MochiKit."+_3c3[1]+") { throw new Error(\""; -str+="This function has been deprecated and depends on MochiKit."; -str+=_3c3[1]+".\");}"; -str+="return MochiKit."+_3c3[1]+"."+arr[0]; -str+=".apply(this, arguments);"; -obj[_3c3[2]]=new Function(str); -MochiKit.Base.update(MochiKit[_3c1],obj); -}; -for(var i;i0){ -abort(repr(expr)); -} -},buildMatchExpression:function(){ -var repr=MochiKit.Base.repr; -var _3d1=this.params; -var _3d2=[]; -var _3d3,i; -function childElements(_3d5){ -return "MochiKit.Base.filter(function (node) { return node.nodeType == 1; }, "+_3d5+".childNodes)"; -} -if(_3d1.wildcard){ -_3d2.push("true"); -} -if(_3d3=_3d1.id){ -_3d2.push("element.id == "+repr(_3d3)); -} -if(_3d3=_3d1.tagName){ -_3d2.push("element.tagName.toUpperCase() == "+repr(_3d3)); -} -if((_3d3=_3d1.classNames).length>0){ -for(i=0;i<_3d3.length;i++){ -_3d2.push("MochiKit.DOM.hasElementClass(element, "+repr(_3d3[i])+")"); -} -} -if((_3d3=_3d1.pseudoClassNames).length>0){ -for(i=0;i<_3d3.length;i++){ -var _3d6=_3d3[i].match(/^([^(]+)(?:\((.*)\))?$/); -var _3d7=_3d6[1]; -var _3d8=_3d6[2]; -switch(_3d7){ -case "root": -_3d2.push("element.nodeType == 9 || element === element.ownerDocument.documentElement"); -break; -case "nth-child": -case "nth-last-child": -case "nth-of-type": -case "nth-last-of-type": -_3d6=_3d8.match(/^((?:(\d+)n\+)?(\d+)|odd|even)$/); -if(!_3d6){ -throw "Invalid argument to pseudo element nth-child: "+_3d8; -} -var a,b; -if(_3d6[0]=="odd"){ -a=2; -b=1; -}else{ -if(_3d6[0]=="even"){ -a=2; -b=0; -}else{ -a=_3d6[2]&&parseInt(_3d6)||null; -b=parseInt(_3d6[3]); -} -} -_3d2.push("this.nthChild(element,"+a+","+b+","+!!_3d7.match("^nth-last")+","+!!_3d7.match("of-type$")+")"); -break; -case "first-child": -_3d2.push("this.nthChild(element, null, 1)"); -break; -case "last-child": -_3d2.push("this.nthChild(element, null, 1, true)"); -break; -case "first-of-type": -_3d2.push("this.nthChild(element, null, 1, false, true)"); -break; -case "last-of-type": -_3d2.push("this.nthChild(element, null, 1, true, true)"); -break; -case "only-child": -_3d2.push(childElements("element.parentNode")+".length == 1"); -break; -case "only-of-type": -_3d2.push("MochiKit.Base.filter(function (node) { return node.tagName == element.tagName; }, "+childElements("element.parentNode")+").length == 1"); -break; -case "empty": -_3d2.push("element.childNodes.length == 0"); -break; -case "enabled": -_3d2.push("(this.isUIElement(element) && element.disabled === false)"); -break; -case "disabled": -_3d2.push("(this.isUIElement(element) && element.disabled === true)"); -break; -case "checked": -_3d2.push("(this.isUIElement(element) && element.checked === true)"); -break; -case "not": -var _3db=new MochiKit.Selector.Selector(_3d8); -_3d2.push("!( "+_3db.buildMatchExpression()+")"); -break; -} -} -} -if(_3d3=_3d1.attributes){ -MochiKit.Base.map(function(_3dc){ -var _3dd="MochiKit.DOM.getNodeAttribute(element, "+repr(_3dc.name)+")"; -var _3de=function(_3df){ -return _3dd+".split("+repr(_3df)+")"; -}; -switch(_3dc.operator){ -case "=": -_3d2.push(_3dd+" == "+repr(_3dc.value)); -break; -case "~=": -_3d2.push(_3dd+" && MochiKit.Base.findValue("+_3de(" ")+", "+repr(_3dc.value)+") > -1"); -break; -case "^=": -_3d2.push(_3dd+".substring(0, "+_3dc.value.length+") == "+repr(_3dc.value)); -break; -case "$=": -_3d2.push(_3dd+".substring("+_3dd+".length - "+_3dc.value.length+") == "+repr(_3dc.value)); -break; -case "*=": -_3d2.push(_3dd+".match("+repr(_3dc.value)+")"); -break; -case "|=": -_3d2.push(_3dd+" && "+_3de("-")+"[0].toUpperCase() == "+repr(_3dc.value.toUpperCase())); -break; -case "!=": -_3d2.push(_3dd+" != "+repr(_3dc.value)); -break; -case "": -case undefined: -_3d2.push(_3dd+" != null"); -break; -default: -throw "Unknown operator "+_3dc.operator+" in selector"; -} -},_3d3); -} -return _3d2.join(" && "); -},compileMatcher:function(){ -this.match=new Function("element","if (!element.tagName) return false; return "+this.buildMatchExpression()); -},nthChild:function(_3e0,a,b,_3e3,_3e4){ -var _3e5=MochiKit.Base.filter(function(node){ -return node.nodeType==1; -},_3e0.parentNode.childNodes); -if(_3e4){ -_3e5=MochiKit.Base.filter(function(node){ -return node.tagName==_3e0.tagName; -},_3e5); -} -if(_3e3){ -_3e5=MochiKit.Iter.reversed(_3e5); -} -if(a){ -var _3e8=MochiKit.Base.findIdentical(_3e5,_3e0); -return ((_3e8+1-b)/a)%1==0; -}else{ -return b==MochiKit.Base.findIdentical(_3e5,_3e0)+1; -} -},isUIElement:function(_3e9){ -return MochiKit.Base.findValue(["input","button","select","option","textarea","object"],_3e9.tagName.toLowerCase())>-1; -},findElements:function(_3ea,axis){ -var _3ec; -if(axis==undefined){ -axis=""; -} -function inScope(_3ed,_3ee){ -if(axis==""){ -return MochiKit.DOM.isChildNode(_3ed,_3ee); -}else{ -if(axis==">"){ -return _3ed.parentNode==_3ee; -}else{ -if(axis=="+"){ -return _3ed==nextSiblingElement(_3ee); -}else{ -if(axis=="~"){ -var _3ef=_3ee; -while(_3ef=nextSiblingElement(_3ef)){ -if(_3ed==_3ef){ -return true; -} -} -return false; -}else{ -throw "Invalid axis: "+axis; -} -} -} -} -} -if(_3ec=MochiKit.DOM.getElement(this.params.id)){ -if(this.match(_3ec)){ -if(!_3ea||inScope(_3ec,_3ea)){ -return [_3ec]; -} -} -} -function nextSiblingElement(node){ -node=node.nextSibling; -while(node&&node.nodeType!=1){ -node=node.nextSibling; -} -return node; -} -if(axis==""){ -_3ea=(_3ea||MochiKit.DOM.currentDocument()).getElementsByTagName(this.params.tagName||"*"); -}else{ -if(axis==">"){ -if(!_3ea){ -throw "> combinator not allowed without preceeding expression"; -} -_3ea=MochiKit.Base.filter(function(node){ -return node.nodeType==1; -},_3ea.childNodes); -}else{ -if(axis=="+"){ -if(!_3ea){ -throw "+ combinator not allowed without preceeding expression"; -} -_3ea=nextSiblingElement(_3ea)&&[nextSiblingElement(_3ea)]; -}else{ -if(axis=="~"){ -if(!_3ea){ -throw "~ combinator not allowed without preceeding expression"; -} -var _3f2=[]; -while(nextSiblingElement(_3ea)){ -_3ea=nextSiblingElement(_3ea); -_3f2.push(_3ea); -} -_3ea=_3f2; -} -} -} -} -if(!_3ea){ -return []; -} -var _3f3=MochiKit.Base.filter(MochiKit.Base.bind(function(_3f4){ -return this.match(_3f4); -},this),_3ea); -return _3f3; -},repr:function(){ -return "Selector("+this.expression+")"; -},toString:MochiKit.Base.forwardCall("repr")}; -MochiKit.Base.update(MochiKit.Selector,{findChildElements:function(_3f5,_3f6){ -return MochiKit.Base.flattenArray(MochiKit.Base.map(function(_3f7){ -var _3f8=""; -return MochiKit.Iter.reduce(function(_3f9,expr){ -if(match=expr.match(/^[>+~]$/)){ -_3f8=match[0]; -return _3f9; -}else{ -var _3fb=new MochiKit.Selector.Selector(expr); -var _3fc=MochiKit.Iter.reduce(function(_3fd,_3fe){ -return MochiKit.Base.extend(_3fd,_3fb.findElements(_3fe||_3f5,_3f8)); -},_3f9,[]); -_3f8=""; -return _3fc; -} -},_3f7.replace(/(^\s+|\s+$)/g,"").split(/\s+/),[null]); -},_3f6)); -},findDocElements:function(){ -return MochiKit.Selector.findChildElements(MochiKit.DOM.currentDocument(),arguments); -},__new__:function(){ -var m=MochiKit.Base; -this.$$=this.findDocElements; -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -m.nameFunctions(this); -}}); -MochiKit.Selector.__new__(); -MochiKit.Base._exportSymbols(this,MochiKit.Selector); -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.Style"); -dojo.require("MochiKit.Base"); -dojo.require("MochiKit.DOM"); -} -if(typeof (JSAN)!="undefined"){ -JSAN.use("MochiKit.Base",[]); -JSAN.use("MochiKit.DOM",[]); -} -try{ -if(typeof (MochiKit.Base)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.Style depends on MochiKit.Base!"; -} -try{ -if(typeof (MochiKit.DOM)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.Style depends on MochiKit.DOM!"; -} -if(typeof (MochiKit.Style)=="undefined"){ -MochiKit.Style={}; -} -MochiKit.Style.NAME="MochiKit.Style"; -MochiKit.Style.VERSION="1.4"; -MochiKit.Style.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.Style.toString=function(){ -return this.__repr__(); -}; -MochiKit.Style.EXPORT_OK=[]; -MochiKit.Style.EXPORT=["setStyle","setOpacity","getStyle","getElementDimensions","elementDimensions","setElementDimensions","getElementPosition","elementPosition","setElementPosition","setDisplayForElement","hideElement","showElement","getViewportDimensions","getViewportPosition","Dimensions","Coordinates"]; -MochiKit.Style.Dimensions=function(w,h){ -this.w=w; -this.h=h; -}; -MochiKit.Style.Dimensions.prototype.__repr__=function(){ -var repr=MochiKit.Base.repr; -return "{w: "+repr(this.w)+", h: "+repr(this.h)+"}"; -}; -MochiKit.Style.Dimensions.prototype.toString=function(){ -return this.__repr__(); -}; -MochiKit.Style.Coordinates=function(x,y){ -this.x=x; -this.y=y; -}; -MochiKit.Style.Coordinates.prototype.__repr__=function(){ -var repr=MochiKit.Base.repr; -return "{x: "+repr(this.x)+", y: "+repr(this.y)+"}"; -}; -MochiKit.Style.Coordinates.prototype.toString=function(){ -return this.__repr__(); -}; -MochiKit.Base.update(MochiKit.Style,{getStyle:function(elem,_407){ -var dom=MochiKit.DOM; -var d=dom._document; -elem=dom.getElement(elem); -_407=MochiKit.Base.camelize(_407); -if(!elem||elem==d){ -return undefined; -} -if(_407=="opacity"&&elem.filters){ -var _40a=(MochiKit.Style.getStyle(elem,"filter")||"").match(/alpha\(opacity=(.*)\)/); -if(_40a&&_40a[1]){ -return parseFloat(_40a[1])/100; -} -return 1; -} -var _40b=elem.style?elem.style[_407]:null; -if(!_40b){ -if(d.defaultView&&d.defaultView.getComputedStyle){ -var css=d.defaultView.getComputedStyle(elem,null); -_407=_407.replace(/([A-Z])/g,"-$1").toLowerCase(); -_40b=css?css.getPropertyValue(_407):null; -}else{ -if(elem.currentStyle){ -_40b=elem.currentStyle[_407]; -} -} -} -if(_407=="opacity"){ -_40b=parseFloat(_40b); -} -if(/Opera/.test(navigator.userAgent)&&(MochiKit.Base.find(["left","top","right","bottom"],_407)!=-1)){ -if(MochiKit.Style.getStyle(elem,"position")=="static"){ -_40b="auto"; -} -} -return _40b=="auto"?null:_40b; -},setStyle:function(elem,_40e){ -elem=MochiKit.DOM.getElement(elem); -for(var name in _40e){ -if(name=="opacity"){ -MochiKit.Style.setOpacity(elem,_40e[name]); -}else{ -elem.style[MochiKit.Base.camelize(name)]=_40e[name]; -} -} -},setOpacity:function(elem,o){ -elem=MochiKit.DOM.getElement(elem); -var self=MochiKit.Style; -if(o==1){ -var _413=/Gecko/.test(navigator.userAgent)&&!(/Konqueror|AppleWebKit|KHTML/.test(navigator.userAgent)); -elem.style["opacity"]=_413?0.999999:1; -if(/MSIE/.test(navigator.userAgent)){ -elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,""); -} -}else{ -if(o<0.00001){ -o=0; -} -elem.style["opacity"]=o; -if(/MSIE/.test(navigator.userAgent)){ -elem.style["filter"]=self.getStyle(elem,"filter").replace(/alpha\([^\)]*\)/gi,"")+"alpha(opacity="+o*100+")"; -} -} -},getElementPosition:function(elem,_415){ -var self=MochiKit.Style; -var dom=MochiKit.DOM; -elem=dom.getElement(elem); -if(!elem||(!(elem.x&&elem.y)&&(!elem.parentNode===null||self.getStyle(elem,"display")=="none"))){ -return undefined; -} -var c=new self.Coordinates(0,0); -var box=null; -var _41a=null; -var d=MochiKit.DOM._document; -var de=d.documentElement; -var b=d.body; -if(!elem.parentNode&&elem.x&&elem.y){ -c.x+=elem.x||0; -c.y+=elem.y||0; -}else{ -if(elem.getBoundingClientRect){ -box=elem.getBoundingClientRect(); -c.x+=box.left+(de.scrollLeft||b.scrollLeft)-(de.clientLeft||0); -c.y+=box.top+(de.scrollTop||b.scrollTop)-(de.clientTop||0); -}else{ -if(elem.offsetParent){ -c.x+=elem.offsetLeft; -c.y+=elem.offsetTop; -_41a=elem.offsetParent; -if(_41a!=elem){ -while(_41a){ -c.x+=_41a.offsetLeft; -c.y+=_41a.offsetTop; -_41a=_41a.offsetParent; -} -} -var ua=navigator.userAgent.toLowerCase(); -if((typeof (opera)!="undefined"&&parseFloat(opera.version())<9)||(ua.indexOf("AppleWebKit")!=-1&&self.getStyle(elem,"position")=="absolute")){ -c.x-=b.offsetLeft; -c.y-=b.offsetTop; -} -} -} -} -if(typeof (_415)!="undefined"){ -_415=arguments.callee(_415); -if(_415){ -c.x-=(_415.x||0); -c.y-=(_415.y||0); -} -} -if(elem.parentNode){ -_41a=elem.parentNode; -}else{ -_41a=null; -} -while(_41a){ -var _41f=_41a.tagName.toUpperCase(); -if(_41f==="BODY"||_41f==="HTML"){ -break; -} -var disp=self.getStyle(_41a,"display"); -if(disp!="inline"&&disp!="table-row"){ -c.x-=_41a.scrollLeft; -c.y-=_41a.scrollTop; -} -if(_41a.parentNode){ -_41a=_41a.parentNode; -}else{ -_41a=null; -} -} -return c; -},setElementPosition:function(elem,_422,_423){ -elem=MochiKit.DOM.getElement(elem); -if(typeof (_423)=="undefined"){ -_423="px"; -} -var _424={}; -var _425=MochiKit.Base.isUndefinedOrNull; -if(!_425(_422.x)){ -_424["left"]=_422.x+_423; -} -if(!_425(_422.y)){ -_424["top"]=_422.y+_423; -} -MochiKit.DOM.updateNodeAttributes(elem,{"style":_424}); -},getElementDimensions:function(elem){ -var self=MochiKit.Style; -var dom=MochiKit.DOM; -if(typeof (elem.w)=="number"||typeof (elem.h)=="number"){ -return new self.Dimensions(elem.w||0,elem.h||0); -} -elem=dom.getElement(elem); -if(!elem){ -return undefined; -} -var disp=self.getStyle(elem,"display"); -if(disp!="none"&&disp!==""&&typeof (disp)!="undefined"){ -return new self.Dimensions(elem.offsetWidth||0,elem.offsetHeight||0); -} -var s=elem.style; -var _42b=s.visibility; -var _42c=s.position; -s.visibility="hidden"; -s.position="absolute"; -s.display=""; -var _42d=elem.offsetWidth; -var _42e=elem.offsetHeight; -s.display="none"; -s.position=_42c; -s.visibility=_42b; -return new self.Dimensions(_42d,_42e); -},setElementDimensions:function(elem,_430,_431){ -elem=MochiKit.DOM.getElement(elem); -if(typeof (_431)=="undefined"){ -_431="px"; -} -var _432={}; -var _433=MochiKit.Base.isUndefinedOrNull; -if(!_433(_430.w)){ -_432["width"]=_430.w+_431; -} -if(!_433(_430.h)){ -_432["height"]=_430.h+_431; -} -MochiKit.DOM.updateNodeAttributes(elem,{"style":_432}); -},setDisplayForElement:function(_434,_435){ -var _436=MochiKit.Base.extend(null,arguments,1); -var _437=MochiKit.DOM.getElement; -for(var i=0;i<_436.length;i++){ -_435=_437(_436[i]); -if(_435){ -_435.style.display=_434; -} -} -},getViewportDimensions:function(){ -var d=new MochiKit.Style.Dimensions(); -var w=MochiKit.DOM._window; -var b=MochiKit.DOM._document.body; -if(w.innerWidth){ -d.w=w.innerWidth; -d.h=w.innerHeight; -}else{ -if(b.parentElement.clientWidth){ -d.w=b.parentElement.clientWidth; -d.h=b.parentElement.clientHeight; -}else{ -if(b&&b.clientWidth){ -d.w=b.clientWidth; -d.h=b.clientHeight; -} -} -} -return d; -},getViewportPosition:function(){ -var c=new MochiKit.Style.Coordinates(0,0); -var d=MochiKit.DOM._document; -var de=d.documentElement; -var db=d.body; -if(de&&(de.scrollTop||de.scrollLeft)){ -c.x=de.scrollLeft; -c.y=de.scrollTop; -}else{ -if(db){ -c.x=db.scrollLeft; -c.y=db.scrollTop; -} -} -return c; -},__new__:function(){ -var m=MochiKit.Base; -this.elementPosition=this.getElementPosition; -this.elementDimensions=this.getElementDimensions; -this.hideElement=m.partial(this.setDisplayForElement,"none"); -this.showElement=m.partial(this.setDisplayForElement,"block"); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -m.nameFunctions(this); -}}); -MochiKit.Style.__new__(); -MochiKit.Base._exportSymbols(this,MochiKit.Style); -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.LoggingPane"); -dojo.require("MochiKit.Logging"); -dojo.require("MochiKit.Base"); -} -if(typeof (JSAN)!="undefined"){ -JSAN.use("MochiKit.Logging",[]); -JSAN.use("MochiKit.Base",[]); -} -try{ -if(typeof (MochiKit.Base)=="undefined"||typeof (MochiKit.Logging)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.LoggingPane depends on MochiKit.Base and MochiKit.Logging!"; -} -if(typeof (MochiKit.LoggingPane)=="undefined"){ -MochiKit.LoggingPane={}; -} -MochiKit.LoggingPane.NAME="MochiKit.LoggingPane"; -MochiKit.LoggingPane.VERSION="1.4"; -MochiKit.LoggingPane.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.LoggingPane.toString=function(){ -return this.__repr__(); -}; -MochiKit.LoggingPane.createLoggingPane=function(_441){ -var m=MochiKit.LoggingPane; -_441=!(!_441); -if(m._loggingPane&&m._loggingPane.inline!=_441){ -m._loggingPane.closePane(); -m._loggingPane=null; -} -if(!m._loggingPane||m._loggingPane.closed){ -m._loggingPane=new m.LoggingPane(_441,MochiKit.Logging.logger); -} -return m._loggingPane; -}; -MochiKit.LoggingPane.LoggingPane=function(_443,_444){ -if(typeof (_444)=="undefined"||_444===null){ -_444=MochiKit.Logging.logger; -} -this.logger=_444; -var _445=MochiKit.Base.update; -var _446=MochiKit.Base.updatetree; -var bind=MochiKit.Base.bind; -var _448=MochiKit.Base.clone; -var win=window; -var uid="_MochiKit_LoggingPane"; -if(typeof (MochiKit.DOM)!="undefined"){ -win=MochiKit.DOM.currentWindow(); -} -if(!_443){ -var url=win.location.href.split("?")[0].replace(/[#:\/.><&-]/g,"_"); -var name=uid+"_"+url; -var nwin=win.open("",name,"dependent,resizable,height=200"); -if(!nwin){ -alert("Not able to open debugging window due to pop-up blocking."); -return undefined; -} -nwin.document.write(""+"[MochiKit.LoggingPane]"+""); -nwin.document.close(); -nwin.document.title+=" "+win.document.title; -win=nwin; -} -var doc=win.document; -this.doc=doc; -var _44f=doc.getElementById(uid); -var _450=!!_44f; -if(_44f&&typeof (_44f.loggingPane)!="undefined"){ -_44f.loggingPane.logger=this.logger; -_44f.loggingPane.buildAndApplyFilter(); -return _44f.loggingPane; -} -if(_450){ -var _451; -while((_451=_44f.firstChild)){ -_44f.removeChild(_451); -} -}else{ -_44f=doc.createElement("div"); -_44f.id=uid; -} -_44f.loggingPane=this; -var _452=doc.createElement("input"); -var _453=doc.createElement("input"); -var _454=doc.createElement("button"); -var _455=doc.createElement("button"); -var _456=doc.createElement("button"); -var _457=doc.createElement("button"); -var _458=doc.createElement("div"); -var _459=doc.createElement("div"); -var _45a=uid+"_Listener"; -this.colorTable=_448(this.colorTable); -var _45b=[]; -var _45c=null; -var _45d=function(msg){ -var _45f=msg.level; -if(typeof (_45f)=="number"){ -_45f=MochiKit.Logging.LogLevel[_45f]; -} -return _45f; -}; -var _460=function(msg){ -return msg.info.join(" "); -}; -var _462=bind(function(msg){ -var _464=_45d(msg); -var text=_460(msg); -var c=this.colorTable[_464]; -var p=doc.createElement("span"); -p.className="MochiKit-LogMessage MochiKit-LogLevel-"+_464; -p.style.cssText="margin: 0px; white-space: -moz-pre-wrap; white-space: -o-pre-wrap; white-space: pre-wrap; white-space: pre-line; word-wrap: break-word; wrap-option: emergency; color: "+c; -p.appendChild(doc.createTextNode(_464+": "+text)); -_459.appendChild(p); -_459.appendChild(doc.createElement("br")); -if(_458.offsetHeight>_458.scrollHeight){ -_458.scrollTop=0; -}else{ -_458.scrollTop=_458.scrollHeight; -} -},this); -var _468=function(msg){ -_45b[_45b.length]=msg; -_462(msg); -}; -var _46a=function(){ -var _46b,_46c; -try{ -_46b=new RegExp(_452.value); -_46c=new RegExp(_453.value); -} -catch(e){ -logDebug("Error in filter regex: "+e.message); -return null; -} -return function(msg){ -return (_46b.test(_45d(msg))&&_46c.test(_460(msg))); -}; -}; -var _46e=function(){ -while(_459.firstChild){ -_459.removeChild(_459.firstChild); -} -}; -var _46f=function(){ -_45b=[]; -_46e(); -}; -var _470=bind(function(){ -if(this.closed){ -return; -} -this.closed=true; -if(MochiKit.LoggingPane._loggingPane==this){ -MochiKit.LoggingPane._loggingPane=null; -} -this.logger.removeListener(_45a); -try{ -try{ -_44f.loggingPane=null; -} -catch(e){ -logFatal("Bookmarklet was closed incorrectly."); -} -if(_443){ -_44f.parentNode.removeChild(_44f); -}else{ -this.win.close(); -} -} -catch(e){ -} -},this); -var _471=function(){ -_46e(); -for(var i=0;i<_45b.length;i++){ -var msg=_45b[i]; -if(_45c===null||_45c(msg)){ -_462(msg); -} -} -}; -this.buildAndApplyFilter=function(){ -_45c=_46a(); -_471(); -this.logger.removeListener(_45a); -this.logger.addListener(_45a,_45c,_468); -}; -var _474=bind(function(){ -_45b=this.logger.getMessages(); -_471(); -},this); -var _475=bind(function(_476){ -_476=_476||window.event; -key=_476.which||_476.keyCode; -if(key==13){ -this.buildAndApplyFilter(); -} -},this); -var _477="display: block; z-index: 1000; left: 0px; bottom: 0px; position: fixed; width: 100%; background-color: white; font: "+this.logFont; -if(_443){ -_477+="; height: 10em; border-top: 2px solid black"; -}else{ -_477+="; height: 100%;"; -} -_44f.style.cssText=_477; -if(!_450){ -doc.body.appendChild(_44f); -} -_477={"cssText":"width: 33%; display: inline; font: "+this.logFont}; -_446(_452,{"value":"FATAL|ERROR|WARNING|INFO|DEBUG","onkeypress":_475,"style":_477}); -_44f.appendChild(_452); -_446(_453,{"value":".*","onkeypress":_475,"style":_477}); -_44f.appendChild(_453); -_477="width: 8%; display:inline; font: "+this.logFont; -_454.appendChild(doc.createTextNode("Filter")); -_454.onclick=bind("buildAndApplyFilter",this); -_454.style.cssText=_477; -_44f.appendChild(_454); -_455.appendChild(doc.createTextNode("Load")); -_455.onclick=_474; -_455.style.cssText=_477; -_44f.appendChild(_455); -_456.appendChild(doc.createTextNode("Clear")); -_456.onclick=_46f; -_456.style.cssText=_477; -_44f.appendChild(_456); -_457.appendChild(doc.createTextNode("Close")); -_457.onclick=_470; -_457.style.cssText=_477; -_44f.appendChild(_457); -_458.style.cssText="overflow: auto; width: 100%"; -_459.style.cssText="width: 100%; height: "+(_443?"8em":"100%"); -_458.appendChild(_459); -_44f.appendChild(_458); -this.buildAndApplyFilter(); -_474(); -if(_443){ -this.win=undefined; -}else{ -this.win=win; -} -this.inline=_443; -this.closePane=_470; -this.closed=false; -return this; -}; -MochiKit.LoggingPane.LoggingPane.prototype={"logFont":"8pt Verdana,sans-serif","colorTable":{"ERROR":"red","FATAL":"darkred","WARNING":"blue","INFO":"black","DEBUG":"green"}}; -MochiKit.LoggingPane.EXPORT_OK=["LoggingPane"]; -MochiKit.LoggingPane.EXPORT=["createLoggingPane"]; -MochiKit.LoggingPane.__new__=function(){ -this.EXPORT_TAGS={":common":this.EXPORT,":all":MochiKit.Base.concat(this.EXPORT,this.EXPORT_OK)}; -MochiKit.Base.nameFunctions(this); -MochiKit.LoggingPane._loggingPane=null; -}; -MochiKit.LoggingPane.__new__(); -MochiKit.Base._exportSymbols(this,MochiKit.LoggingPane); -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.Color"); -dojo.require("MochiKit.Base"); -dojo.require("MochiKit.DOM"); -dojo.require("MochiKit.Style"); -} -if(typeof (JSAN)!="undefined"){ -JSAN.use("MochiKit.Base",[]); -JSAN.use("MochiKit.DOM",[]); -JSAN.use("MochiKit.Style",[]); -} -try{ -if(typeof (MochiKit.Base)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.Color depends on MochiKit.Base"; -} -try{ -if(typeof (MochiKit.DOM)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.Color depends on MochiKit.DOM"; -} -try{ -if(typeof (MochiKit.Style)=="undefined"){ -throw ""; -} -} -catch(e){ -throw "MochiKit.Color depends on MochiKit.Style"; -} -if(typeof (MochiKit.Color)=="undefined"){ -MochiKit.Color={}; -} -MochiKit.Color.NAME="MochiKit.Color"; -MochiKit.Color.VERSION="1.4"; -MochiKit.Color.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.Color.toString=function(){ -return this.__repr__(); -}; -MochiKit.Color.Color=function(red,_479,blue,_47b){ -if(typeof (_47b)=="undefined"||_47b===null){ -_47b=1; -} -this.rgb={r:red,g:_479,b:blue,a:_47b}; -}; -MochiKit.Color.Color.prototype={__class__:MochiKit.Color.Color,colorWithAlpha:function(_47c){ -var rgb=this.rgb; -var m=MochiKit.Color; -return m.Color.fromRGB(rgb.r,rgb.g,rgb.b,_47c); -},colorWithHue:function(hue){ -var hsl=this.asHSL(); -hsl.h=hue; -var m=MochiKit.Color; -return m.Color.fromHSL(hsl); -},colorWithSaturation:function(_482){ -var hsl=this.asHSL(); -hsl.s=_482; -var m=MochiKit.Color; -return m.Color.fromHSL(hsl); -},colorWithLightness:function(_485){ -var hsl=this.asHSL(); -hsl.l=_485; -var m=MochiKit.Color; -return m.Color.fromHSL(hsl); -},darkerColorWithLevel:function(_488){ -var hsl=this.asHSL(); -hsl.l=Math.max(hsl.l-_488,0); -var m=MochiKit.Color; -return m.Color.fromHSL(hsl); -},lighterColorWithLevel:function(_48b){ -var hsl=this.asHSL(); -hsl.l=Math.min(hsl.l+_48b,1); -var m=MochiKit.Color; -return m.Color.fromHSL(hsl); -},blendedColor:function(_48e,_48f){ -if(typeof (_48f)=="undefined"||_48f===null){ -_48f=0.5; -} -var sf=1-_48f; -var s=this.rgb; -var d=_48e.rgb; -var df=_48f; -return MochiKit.Color.Color.fromRGB((s.r*sf)+(d.r*df),(s.g*sf)+(d.g*df),(s.b*sf)+(d.b*df),(s.a*sf)+(d.a*df)); -},compareRGB:function(_494){ -var a=this.asRGB(); -var b=_494.asRGB(); -return MochiKit.Base.compare([a.r,a.g,a.b,a.a],[b.r,b.g,b.b,b.a]); -},isLight:function(){ -return this.asHSL().b>0.5; -},isDark:function(){ -return (!this.isLight()); -},toHSLString:function(){ -var c=this.asHSL(); -var ccc=MochiKit.Color.clampColorComponent; -var rval=this._hslString; -if(!rval){ -var mid=(ccc(c.h,360).toFixed(0)+","+ccc(c.s,100).toPrecision(4)+"%"+","+ccc(c.l,100).toPrecision(4)+"%"); -var a=c.a; -if(a>=1){ -a=1; -rval="hsl("+mid+")"; -}else{ -if(a<=0){ -a=0; -} -rval="hsla("+mid+","+a+")"; -} -this._hslString=rval; -} -return rval; -},toRGBString:function(){ -var c=this.rgb; -var ccc=MochiKit.Color.clampColorComponent; -var rval=this._rgbString; -if(!rval){ -var mid=(ccc(c.r,255).toFixed(0)+","+ccc(c.g,255).toFixed(0)+","+ccc(c.b,255).toFixed(0)); -if(c.a!=1){ -rval="rgba("+mid+","+c.a+")"; -}else{ -rval="rgb("+mid+")"; -} -this._rgbString=rval; -} -return rval; -},asRGB:function(){ -return MochiKit.Base.clone(this.rgb); -},toHexString:function(){ -var m=MochiKit.Color; -var c=this.rgb; -var ccc=MochiKit.Color.clampColorComponent; -var rval=this._hexString; -if(!rval){ -rval=("#"+m.toColorPart(ccc(c.r,255))+m.toColorPart(ccc(c.g,255))+m.toColorPart(ccc(c.b,255))); -this._hexString=rval; -} -return rval; -},asHSV:function(){ -var hsv=this.hsv; -var c=this.rgb; -if(typeof (hsv)=="undefined"||hsv===null){ -hsv=MochiKit.Color.rgbToHSV(this.rgb); -this.hsv=hsv; -} -return MochiKit.Base.clone(hsv); -},asHSL:function(){ -var hsl=this.hsl; -var c=this.rgb; -if(typeof (hsl)=="undefined"||hsl===null){ -hsl=MochiKit.Color.rgbToHSL(this.rgb); -this.hsl=hsl; -} -return MochiKit.Base.clone(hsl); -},toString:function(){ -return this.toRGBString(); -},repr:function(){ -var c=this.rgb; -var col=[c.r,c.g,c.b,c.a]; -return this.__class__.NAME+"("+col.join(", ")+")"; -}}; -MochiKit.Base.update(MochiKit.Color.Color,{fromRGB:function(red,_4ab,blue,_4ad){ -var _4ae=MochiKit.Color.Color; -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_4ab=rgb.g; -blue=rgb.b; -if(typeof (rgb.a)=="undefined"){ -_4ad=undefined; -}else{ -_4ad=rgb.a; -} -} -return new _4ae(red,_4ab,blue,_4ad); -},fromHSL:function(hue,_4b1,_4b2,_4b3){ -var m=MochiKit.Color; -return m.Color.fromRGB(m.hslToRGB.apply(m,arguments)); -},fromHSV:function(hue,_4b6,_4b7,_4b8){ -var m=MochiKit.Color; -return m.Color.fromRGB(m.hsvToRGB.apply(m,arguments)); -},fromName:function(name){ -var _4bb=MochiKit.Color.Color; -if(name.charAt(0)=="\""){ -name=name.substr(1,name.length-2); -} -var _4bc=_4bb._namedColors[name.toLowerCase()]; -if(typeof (_4bc)=="string"){ -return _4bb.fromHexString(_4bc); -}else{ -if(name=="transparent"){ -return _4bb.transparentColor(); -} -} -return null; -},fromString:function(_4bd){ -var self=MochiKit.Color.Color; -var _4bf=_4bd.substr(0,3); -if(_4bf=="rgb"){ -return self.fromRGBString(_4bd); -}else{ -if(_4bf=="hsl"){ -return self.fromHSLString(_4bd); -}else{ -if(_4bd.charAt(0)=="#"){ -return self.fromHexString(_4bd); -} -} -} -return self.fromName(_4bd); -},fromHexString:function(_4c0){ -if(_4c0.charAt(0)=="#"){ -_4c0=_4c0.substring(1); -} -var _4c1=[]; -var i,hex; -if(_4c0.length==3){ -for(i=0;i<3;i++){ -hex=_4c0.substr(i,1); -_4c1.push(parseInt(hex+hex,16)/255); -} -}else{ -for(i=0;i<6;i+=2){ -hex=_4c0.substr(i,2); -_4c1.push(parseInt(hex,16)/255); -} -} -var _4c4=MochiKit.Color.Color; -return _4c4.fromRGB.apply(_4c4,_4c1); -},_fromColorString:function(pre,_4c6,_4c7,_4c8){ -if(_4c8.indexOf(pre)===0){ -_4c8=_4c8.substring(_4c8.indexOf("(",3)+1,_4c8.length-1); -} -var _4c9=_4c8.split(/\s*,\s*/); -var _4ca=[]; -for(var i=0;i<_4c9.length;i++){ -var c=_4c9[i]; -var val; -var _4ce=c.substring(c.length-3); -if(c.charAt(c.length-1)=="%"){ -val=0.01*parseFloat(c.substring(0,c.length-1)); -}else{ -if(_4ce=="deg"){ -val=parseFloat(c)/360; -}else{ -if(_4ce=="rad"){ -val=parseFloat(c)/(Math.PI*2); -}else{ -val=_4c7[i]*parseFloat(c); -} -} -} -_4ca.push(val); -} -return this[_4c6].apply(this,_4ca); -},fromComputedStyle:function(elem,_4d0){ -var d=MochiKit.DOM; -var cls=MochiKit.Color.Color; -for(elem=d.getElement(elem);elem;elem=elem.parentNode){ -var _4d3=MochiKit.Style.getStyle.apply(d,arguments); -if(!_4d3){ -continue; -} -var _4d4=cls.fromString(_4d3); -if(!_4d4){ -break; -} -if(_4d4.asRGB().a>0){ -return _4d4; -} -} -return null; -},fromBackground:function(elem){ -var cls=MochiKit.Color.Color; -return cls.fromComputedStyle(elem,"backgroundColor","background-color")||cls.whiteColor(); -},fromText:function(elem){ -var cls=MochiKit.Color.Color; -return cls.fromComputedStyle(elem,"color","color")||cls.blackColor(); -},namedColors:function(){ -return MochiKit.Base.clone(MochiKit.Color.Color._namedColors); -}}); -MochiKit.Base.update(MochiKit.Color,{clampColorComponent:function(v,_4da){ -v*=_4da; -if(v<0){ -return 0; -}else{ -if(v>_4da){ -return _4da; -}else{ -return v; -} -} -},_hslValue:function(n1,n2,hue){ -if(hue>6){ -hue-=6; -}else{ -if(hue<0){ -hue+=6; -} -} -var val; -if(hue<1){ -val=n1+(n2-n1)*hue; -}else{ -if(hue<3){ -val=n2; -}else{ -if(hue<4){ -val=n1+(n2-n1)*(4-hue); -}else{ -val=n1; -} -} -} -return val; -},hsvToRGB:function(hue,_4e0,_4e1,_4e2){ -if(arguments.length==1){ -var hsv=hue; -hue=hsv.h; -_4e0=hsv.s; -_4e1=hsv.v; -_4e2=hsv.a; -} -var red; -var _4e5; -var blue; -if(_4e0===0){ -red=_4e1; -_4e5=_4e1; -blue=_4e1; -}else{ -var i=Math.floor(hue*6); -var f=(hue*6)-i; -var p=_4e1*(1-_4e0); -var q=_4e1*(1-(_4e0*f)); -var t=_4e1*(1-(_4e0*(1-f))); -switch(i){ -case 1: -red=q; -_4e5=_4e1; -blue=p; -break; -case 2: -red=p; -_4e5=_4e1; -blue=t; -break; -case 3: -red=p; -_4e5=q; -blue=_4e1; -break; -case 4: -red=t; -_4e5=p; -blue=_4e1; -break; -case 5: -red=_4e1; -_4e5=p; -blue=q; -break; -case 6: -case 0: -red=_4e1; -_4e5=t; -blue=p; -break; -} -} -return {r:red,g:_4e5,b:blue,a:_4e2}; -},hslToRGB:function(hue,_4ed,_4ee,_4ef){ -if(arguments.length==1){ -var hsl=hue; -hue=hsl.h; -_4ed=hsl.s; -_4ee=hsl.l; -_4ef=hsl.a; -} -var red; -var _4f2; -var blue; -if(_4ed===0){ -red=_4ee; -_4f2=_4ee; -blue=_4ee; -}else{ -var m2; -if(_4ee<=0.5){ -m2=_4ee*(1+_4ed); -}else{ -m2=_4ee+_4ed-(_4ee*_4ed); -} -var m1=(2*_4ee)-m2; -var f=MochiKit.Color._hslValue; -var h6=hue*6; -red=f(m1,m2,h6+2); -_4f2=f(m1,m2,h6); -blue=f(m1,m2,h6-2); -} -return {r:red,g:_4f2,b:blue,a:_4ef}; -},rgbToHSV:function(red,_4f9,blue,_4fb){ -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_4f9=rgb.g; -blue=rgb.b; -_4fb=rgb.a; -} -var max=Math.max(Math.max(red,_4f9),blue); -var min=Math.min(Math.min(red,_4f9),blue); -var hue; -var _500; -var _501=max; -if(min==max){ -hue=0; -_500=0; -}else{ -var _502=(max-min); -_500=_502/max; -if(red==max){ -hue=(_4f9-blue)/_502; -}else{ -if(_4f9==max){ -hue=2+((blue-red)/_502); -}else{ -hue=4+((red-_4f9)/_502); -} -} -hue/=6; -if(hue<0){ -hue+=1; -} -if(hue>1){ -hue-=1; -} -} -return {h:hue,s:_500,v:_501,a:_4fb}; -},rgbToHSL:function(red,_504,blue,_506){ -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_504=rgb.g; -blue=rgb.b; -_506=rgb.a; -} -var max=Math.max(red,Math.max(_504,blue)); -var min=Math.min(red,Math.min(_504,blue)); -var hue; -var _50b; -var _50c=(max+min)/2; -var _50d=max-min; -if(_50d===0){ -hue=0; -_50b=0; -}else{ -if(_50c<=0.5){ -_50b=_50d/(max+min); -}else{ -_50b=_50d/(2-max-min); -} -if(red==max){ -hue=(_504-blue)/_50d; -}else{ -if(_504==max){ -hue=2+((blue-red)/_50d); -}else{ -hue=4+((red-_504)/_50d); -} -} -hue/=6; -if(hue<0){ -hue+=1; -} -if(hue>1){ -hue-=1; -} -} -return {h:hue,s:_50b,l:_50c,a:_506}; -},toColorPart:function(num){ -num=Math.round(num); -var _50f=num.toString(16); -if(num<16){ -return "0"+_50f; -} -return _50f; -},__new__:function(){ -var m=MochiKit.Base; -this.Color.fromRGBString=m.bind(this.Color._fromColorString,this.Color,"rgb","fromRGB",[1/255,1/255,1/255,1]); -this.Color.fromHSLString=m.bind(this.Color._fromColorString,this.Color,"hsl","fromHSL",[1/360,0.01,0.01,1]); -var _511=1/3; -var _512={black:[0,0,0],blue:[0,0,1],brown:[0.6,0.4,0.2],cyan:[0,1,1],darkGray:[_511,_511,_511],gray:[0.5,0.5,0.5],green:[0,1,0],lightGray:[2*_511,2*_511,2*_511],magenta:[1,0,1],orange:[1,0.5,0],purple:[0.5,0,0.5],red:[1,0,0],transparent:[0,0,0,0],white:[1,1,1],yellow:[1,1,0]}; -var _513=function(name,r,g,b,a){ -var rval=this.fromRGB(r,g,b,a); -this[name]=function(){ -return rval; -}; -return rval; -}; -for(var k in _512){ -var name=k+"Color"; -var _51c=m.concat([_513,this.Color,name],_512[k]); -this.Color[name]=m.bind.apply(null,_51c); -} -var _51d=function(){ -for(var i=0;i1){ -var src=MochiKit.DOM.getElement(arguments[0]); -var sig=arguments[1]; -var obj=arguments[2]; -var func=arguments[3]; -for(var i=_55f.length-1;i>=0;i--){ -var o=_55f[i]; -if(o.source===src&&o.signal===sig&&o.objOrFunc===obj&&o.funcOrStr===func){ -self._disconnect(o); -if(!self._lock){ -_55f.splice(i,1); -}else{ -self._dirty=true; +var _36d=cls.fromString(_36c); +if(!_36d){ +break; } -return true; +if(_36d.asRGB().a>0){ +return _36d; } } +return null; +},fromBackground:function(elem){ +var cls=MochiKit.Color.Color; +return cls.fromComputedStyle(elem,"backgroundColor","background-color")||cls.whiteColor(); +},fromText:function(elem){ +var cls=MochiKit.Color.Color; +return cls.fromComputedStyle(elem,"color","color")||cls.blackColor(); +},namedColors:function(){ +return MochiKit.Base.clone(MochiKit.Color.Color._namedColors); +}}); +MochiKit.Base.update(MochiKit.Color,{clampColorComponent:function(v,_373){ +v*=_373; +if(v<0){ +return 0; }else{ -var idx=m.findIdentical(_55f,_55d); -if(idx>=0){ -self._disconnect(_55d); -if(!self._lock){ -_55f.splice(idx,1); +if(v>_373){ +return _373; }else{ -self._dirty=true; +return v; } -return true; } +},_hslValue:function(n1,n2,hue){ +if(hue>6){ +hue-=6; +}else{ +if(hue<0){ +hue+=6; } -return false; -},disconnectAllTo:function(_568,_569){ -var self=MochiKit.Signal; -var _56b=self._observers; -var _56c=self._disconnect; -var _56d=self._lock; -var _56e=self._dirty; -if(typeof (_569)==="undefined"){ -_569=null; } -for(var i=_56b.length-1;i>=0;i--){ -var _570=_56b[i]; -if(_570.objOrFunc===_568&&(_569===null||_570.funcOrStr===_569)){ -_56c(_570); -if(_56d){ -_56e=true; +var val; +if(hue<1){ +val=n1+(n2-n1)*hue; }else{ -_56b.splice(i,1); +if(hue<3){ +val=n2; +}else{ +if(hue<4){ +val=n1+(n2-n1)*(4-hue); +}else{ +val=n1; } } } -self._dirty=_56e; -},disconnectAll:function(src,sig){ -src=MochiKit.DOM.getElement(src); -var m=MochiKit.Base; -var _574=m.flattenArguments(m.extend(null,arguments,1)); -var self=MochiKit.Signal; -var _576=self._disconnect; -var _577=self._observers; -var i,_579; -var _57a=self._lock; -var _57b=self._dirty; -if(_574.length===0){ -for(i=_577.length-1;i>=0;i--){ -_579=_577[i]; -if(_579.source===src){ -_576(_579); -if(!_57a){ -_577.splice(i,1); +return val; +},hsvToRGB:function(hue,_379,_37a,_37b){ +if(arguments.length==1){ +var hsv=hue; +hue=hsv.h; +_379=hsv.s; +_37a=hsv.v; +_37b=hsv.a; +} +var red; +var _37e; +var blue; +if(_379===0){ +red=_37a; +_37e=_37a; +blue=_37a; }else{ -_57b=true; +var i=Math.floor(hue*6); +var f=(hue*6)-i; +var p=_37a*(1-_379); +var q=_37a*(1-(_379*f)); +var t=_37a*(1-(_379*(1-f))); +switch(i){ +case 1: +red=q; +_37e=_37a; +blue=p; +break; +case 2: +red=p; +_37e=_37a; +blue=t; +break; +case 3: +red=p; +_37e=q; +blue=_37a; +break; +case 4: +red=t; +_37e=p; +blue=_37a; +break; +case 5: +red=_37a; +_37e=p; +blue=q; +break; +case 6: +case 0: +red=_37a; +_37e=t; +blue=p; +break; } } +return {r:red,g:_37e,b:blue,a:_37b}; +},hslToRGB:function(hue,_386,_387,_388){ +if(arguments.length==1){ +var hsl=hue; +hue=hsl.h; +_386=hsl.s; +_387=hsl.l; +_388=hsl.a; } +var red; +var _38b; +var blue; +if(_386===0){ +red=_387; +_38b=_387; +blue=_387; }else{ -var sigs={}; -for(i=0;i<_574.length;i++){ -sigs[_574[i]]=true; -} -for(i=_577.length-1;i>=0;i--){ -_579=_577[i]; -if(_579.source===src&&_579.signal in sigs){ -_576(_579); -if(!_57a){ -_577.splice(i,1); +var m2; +if(_387<=0.5){ +m2=_387*(1+_386); }else{ -_57b=true; -} -} +m2=_387+_386-(_387*_386); } +var m1=(2*_387)-m2; +var f=MochiKit.Color._hslValue; +var h6=hue*6; +red=f(m1,m2,h6+2); +_38b=f(m1,m2,h6); +blue=f(m1,m2,h6-2); } -self._dirty=_57b; -},signal:function(src,sig){ -var self=MochiKit.Signal; -var _580=self._observers; -src=MochiKit.DOM.getElement(src); -var args=MochiKit.Base.extend(null,arguments,2); -var _582=[]; -self._lock=true; -for(var i=0;i<_580.length;i++){ -var _584=_580[i]; -if(_584.source===src&&_584.signal===sig){ -try{ -_584.listener.apply(src,args); +return {r:red,g:_38b,b:blue,a:_388}; +},rgbToHSV:function(red,_392,blue,_394){ +if(arguments.length==1){ +var rgb=red; +red=rgb.r; +_392=rgb.g; +blue=rgb.b; +_394=rgb.a; } -catch(e){ -_582.push(e); +var max=Math.max(Math.max(red,_392),blue); +var min=Math.min(Math.min(red,_392),blue); +var hue; +var _399; +var _39a=max; +if(min==max){ +hue=0; +_399=0; +}else{ +var _39b=(max-min); +_399=_39b/max; +if(red==max){ +hue=(_392-blue)/_39b; +}else{ +if(_392==max){ +hue=2+((blue-red)/_39b); +}else{ +hue=4+((red-_392)/_39b); } } +hue/=6; +if(hue<0){ +hue+=1; } -self._lock=false; -if(self._dirty){ -self._dirty=false; -for(var i=_580.length-1;i>=0;i--){ -if(!_580[i].connected){ -_580.splice(i,1); +if(hue>1){ +hue-=1; } } +return {h:hue,s:_399,v:_39a,a:_394}; +},rgbToHSL:function(red,_39d,blue,_39f){ +if(arguments.length==1){ +var rgb=red; +red=rgb.r; +_39d=rgb.g; +blue=rgb.b; +_39f=rgb.a; } -if(_582.length==1){ -throw _582[0]; +var max=Math.max(red,Math.max(_39d,blue)); +var min=Math.min(red,Math.min(_39d,blue)); +var hue; +var _3a4; +var _3a5=(max+min)/2; +var _3a6=max-min; +if(_3a6===0){ +hue=0; +_3a4=0; }else{ -if(_582.length>1){ -var e=new Error("Multiple errors thrown in handling 'sig', see errors property"); -e.errors=_582; -throw e; -} -} -}}); -MochiKit.Signal.EXPORT_OK=[]; -MochiKit.Signal.EXPORT=["connect","disconnect","signal","disconnectAll","disconnectAllTo"]; -MochiKit.Signal.__new__=function(win){ -var m=MochiKit.Base; -this._document=document; -this._window=win; -this._lock=false; -this._dirty=false; -try{ -this.connect(window,"onunload",this._unloadCache); -} -catch(e){ -} -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -m.nameFunctions(this); -}; -MochiKit.Signal.__new__(this); -if(MochiKit.__export__){ -connect=MochiKit.Signal.connect; -disconnect=MochiKit.Signal.disconnect; -disconnectAll=MochiKit.Signal.disconnectAll; -signal=MochiKit.Signal.signal; +if(_3a5<=0.5){ +_3a4=_3a6/(max+min); +}else{ +_3a4=_3a6/(2-max-min); } -MochiKit.Base._exportSymbols(this,MochiKit.Signal); -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.Position"); -dojo.require("MochiKit.Base"); -dojo.require("MochiKit.DOM"); -dojo.require("MochiKit.Style"); +if(red==max){ +hue=(_39d-blue)/_3a6; +}else{ +if(_39d==max){ +hue=2+((blue-red)/_3a6); +}else{ +hue=4+((red-_39d)/_3a6); } -if(typeof (JSAN)!="undefined"){ -JSAN.use("MochiKit.Base",[]); -JSAN.use("MochiKit.DOM",[]); -JSAN.use("MochiKit.Style",[]); } -try{ -if(typeof (MochiKit.Base)=="undefined"||typeof (MochiKit.Style)=="undefined"||typeof (MochiKit.DOM)=="undefined"){ -throw ""; +hue/=6; +if(hue<0){ +hue+=1; } +if(hue>1){ +hue-=1; } -catch(e){ -throw "MochiKit.Style depends on MochiKit.Base, MochiKit.DOM, and MochiKit.Style!"; } -if(typeof (MochiKit.Position)=="undefined"){ -MochiKit.Position={}; +return {h:hue,s:_3a4,l:_3a5,a:_39f}; +},toColorPart:function(num){ +num=Math.round(num); +var _3a8=num.toString(16); +if(num<16){ +return "0"+_3a8; } -MochiKit.Position.NAME="MochiKit.Position"; -MochiKit.Position.VERSION="1.4"; -MochiKit.Position.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; +return _3a8; +},__new__:function(){ +var m=MochiKit.Base; +this.Color.fromRGBString=m.bind(this.Color._fromColorString,this.Color,"rgb","fromRGB",[1/255,1/255,1/255,1]); +this.Color.fromHSLString=m.bind(this.Color._fromColorString,this.Color,"hsl","fromHSL",[1/360,0.01,0.01,1]); +var _3aa=1/3; +var _3ab={black:[0,0,0],blue:[0,0,1],brown:[0.6,0.4,0.2],cyan:[0,1,1],darkGray:[_3aa,_3aa,_3aa],gray:[0.5,0.5,0.5],green:[0,1,0],lightGray:[2*_3aa,2*_3aa,2*_3aa],magenta:[1,0,1],orange:[1,0.5,0],purple:[0.5,0,0.5],red:[1,0,0],transparent:[0,0,0,0],white:[1,1,1],yellow:[1,1,0]}; +var _3ac=function(name,r,g,b,a){ +var rval=this.fromRGB(r,g,b,a); +this[name]=function(){ +return rval; }; -MochiKit.Position.toString=function(){ -return this.__repr__(); +return rval; }; -MochiKit.Position.EXPORT_OK=[]; -MochiKit.Position.EXPORT=[]; -MochiKit.Base.update(MochiKit.Position,{includeScrollOffsets:false,prepare:function(){ -var _588=window.pageXOffset||document.documentElement.scrollLeft||document.body.scrollLeft||0; -var _589=window.pageYOffset||document.documentElement.scrollTop||document.body.scrollTop||0; -this.windowOffset=new MochiKit.Style.Coordinates(_588,_589); -},cumulativeOffset:function(_58a){ -var _58b=0; -var _58c=0; -do{ -_58b+=_58a.offsetTop||0; -_58c+=_58a.offsetLeft||0; -_58a=_58a.offsetParent; -}while(_58a); -return new MochiKit.Style.Coordinates(_58c,_58b); -},realOffset:function(_58d){ -var _58e=0; -var _58f=0; -do{ -_58e+=_58d.scrollTop||0; -_58f+=_58d.scrollLeft||0; -_58d=_58d.parentNode; -}while(_58d); -return new MochiKit.Style.Coordinates(_58f,_58e); -},within:function(_590,x,y){ -if(this.includeScrollOffsets){ -return this.withinIncludingScrolloffsets(_590,x,y); -} -this.xcomp=x; -this.ycomp=y; -this.offset=this.cumulativeOffset(_590); -if(_590.style.position=="fixed"){ -this.offset.x+=this.windowOffset.x; -this.offset.y+=this.windowOffset.y; -} -return (y>=this.offset.y&&y=this.offset.x&&x=this.offset.y&&this.ycomp=this.offset.x&&this.xcomp"+el.innerHTML+""; -},_roundTopCorners:function(el,_5c2,_5c3){ -var _5c4=this._createCorner(_5c3); -for(var i=0;i=0;i--){ -_5c9.appendChild(this._createCornerSlice(_5c7,_5c8,i,"bottom")); -} -el.style.paddingBottom=0; -el.appendChild(_5c9); -},_createCorner:function(_5cb){ -var dom=MochiKit.DOM; -return dom.DIV({style:{backgroundColor:_5cb.toString()}}); -},_createCornerSlice:function(_5cd,_5ce,n,_5d0){ -var _5d1=MochiKit.DOM.SPAN(); -var _5d2=_5d1.style; -_5d2.backgroundColor=_5cd.toString(); -_5d2.display="block"; -_5d2.height="1px"; -_5d2.overflow="hidden"; -_5d2.fontSize="1px"; -var _5d3=this._borderColor(_5cd,_5ce); -if(this.options.border&&n===0){ -_5d2.borderTopStyle="solid"; -_5d2.borderTopWidth="1px"; -_5d2.borderLeftWidth="0px"; -_5d2.borderRightWidth="0px"; -_5d2.borderBottomWidth="0px"; -_5d2.height="0px"; -_5d2.borderColor=_5d3.toString(); -}else{ -if(_5d3){ -_5d2.borderColor=_5d3.toString(); -_5d2.borderStyle="solid"; -_5d2.borderWidth="0px 1px"; -} -} -if(!this.options.compact&&(n==(this.options.numSlices-1))){ -_5d2.height="2px"; -} -this._setMargin(_5d1,n,_5d0); -this._setBorder(_5d1,n,_5d0); -return _5d1; -},_setOptions:function(_5d4){ -this.options={corners:"all",color:"fromElement",bgColor:"fromParent",blend:true,border:false,compact:false,__unstable__wrapElement:false}; -MochiKit.Base.update(this.options,_5d4); -this.options.numSlices=(this.options.compact?2:4); -},_whichSideTop:function(){ -var _5d5=this.options.corners; -if(this._hasString(_5d5,"all","top")){ -return ""; -} -var _5d6=(_5d5.indexOf("tl")!=-1); -var _5d7=(_5d5.indexOf("tr")!=-1); -if(_5d6&&_5d7){ -return ""; -} -if(_5d6){ -return "left"; -} -if(_5d7){ -return "right"; -} -return ""; -},_whichSideBottom:function(){ -var _5d8=this.options.corners; -if(this._hasString(_5d8,"all","bottom")){ -return ""; -} -var _5d9=(_5d8.indexOf("bl")!=-1); -var _5da=(_5d8.indexOf("br")!=-1); -if(_5d9&&_5da){ -return ""; -} -if(_5d9){ -return "left"; -} -if(_5da){ -return "right"; -} -return ""; -},_borderColor:function(_5db,_5dc){ -if(_5db=="transparent"){ -return _5dc; -}else{ -if(this.options.border){ -return this.options.border; -}else{ -if(this.options.blend){ -return _5dc.blendedColor(_5db); -} -} -} -return ""; -},_setMargin:function(el,n,_5df){ -var _5e0=this._marginSize(n)+"px"; -var _5e1=(_5df=="top"?this._whichSideTop():this._whichSideBottom()); -var _5e2=el.style; -if(_5e1=="left"){ -_5e2.marginLeft=_5e0; -_5e2.marginRight="0px"; -}else{ -if(_5e1=="right"){ -_5e2.marginRight=_5e0; -_5e2.marginLeft="0px"; -}else{ -_5e2.marginLeft=_5e0; -_5e2.marginRight=_5e0; -} -} -},_setBorder:function(el,n,_5e5){ -var _5e6=this._borderSize(n)+"px"; -var _5e7=(_5e5=="top"?this._whichSideTop():this._whichSideBottom()); -var _5e8=el.style; -if(_5e7=="left"){ -_5e8.borderLeftWidth=_5e6; -_5e8.borderRightWidth="0px"; -}else{ -if(_5e7=="right"){ -_5e8.borderRightWidth=_5e6; -_5e8.borderLeftWidth="0px"; -}else{ -_5e8.borderLeftWidth=_5e6; -_5e8.borderRightWidth=_5e6; +if(this.type()&&this.type().indexOf("key")===0){ +str+=", key(): {code: "+repr(this.key().code)+", string: "+repr(this.key().string)+"}"; } +if(this.type()&&(this.type().indexOf("mouse")===0||this.type().indexOf("click")!=-1||this.type()=="contextmenu")){ +str+=", mouse(): {page: "+repr(this.mouse().page)+", client: "+repr(this.mouse().client); +if(this.type()!="mousemove"){ +str+=", button: {left: "+repr(this.mouse().button.left)+", middle: "+repr(this.mouse().button.middle)+", right: "+repr(this.mouse().button.right)+"}}"; +}else{ +str+="}"; } -},_marginSize:function(n){ -if(this.isTransparent){ -return 0; } -var o=this.options; -if(o.compact&&o.blend){ -var _5eb=[1,0]; -return _5eb[n]; +if(this.type()=="mouseover"||this.type()=="mouseout"){ +str+=", relatedTarget(): "+repr(this.relatedTarget()); +} +str+="}"; +return str; +},toString:function(){ +return this.__repr__(); +},src:function(){ +return this._src; +},event:function(){ +return this._event; +},type:function(){ +return this._event.type||undefined; +},target:function(){ +return this._event.target||this._event.srcElement; +},_relatedTarget:null,relatedTarget:function(){ +if(this._relatedTarget!==null){ +return this._relatedTarget; +} +var elem=null; +if(this.type()=="mouseover"){ +elem=(this._event.relatedTarget||this._event.fromElement); }else{ -if(o.compact){ -var _5ec=[2,1]; -return _5ec[n]; +if(this.type()=="mouseout"){ +elem=(this._event.relatedTarget||this._event.toElement); +} +} +if(elem!==null){ +this._relatedTarget=elem; +return elem; +} +return undefined; +},_modifier:null,modifier:function(){ +if(this._modifier!==null){ +return this._modifier; +} +var m={}; +m.alt=this._event.altKey; +m.ctrl=this._event.ctrlKey; +m.meta=this._event.metaKey||false; +m.shift=this._event.shiftKey; +m.any=m.alt||m.ctrl||m.shift||m.meta; +this._modifier=m; +return m; +},_key:null,key:function(){ +if(this._key!==null){ +return this._key; +} +var k={}; +if(this.type()&&this.type().indexOf("key")===0){ +if(this.type()=="keydown"||this.type()=="keyup"){ +k.code=this._event.keyCode; +k.string=(MochiKit.Signal._specialKeys[k.code]||"KEY_UNKNOWN"); +this._key=k; +return k; }else{ -if(o.blend){ -var _5ed=[3,2,1,0]; -return _5ed[n]; +if(this.type()=="keypress"){ +k.code=0; +k.string=""; +if(typeof (this._event.charCode)!="undefined"&&this._event.charCode!==0&&!MochiKit.Signal._specialMacKeys[this._event.charCode]){ +k.code=this._event.charCode; +k.string=String.fromCharCode(k.code); }else{ -var _5ee=[5,3,2,1]; -return _5ee[n]; +if(this._event.keyCode&&typeof (this._event.charCode)=="undefined"){ +k.code=this._event.keyCode; +k.string=String.fromCharCode(k.code); } } +this._key=k; +return k; } -},_borderSize:function(n){ -var o=this.options; -var _5f1; -if(o.compact&&(o.blend||this.isTransparent)){ -return 1; -}else{ -if(o.compact){ -_5f1=[1,0]; +} +} +return undefined; +},_mouse:null,mouse:function(){ +if(this._mouse!==null){ +return this._mouse; +} +var m={}; +var e=this._event; +if(this.type()&&(this.type().indexOf("mouse")===0||this.type().indexOf("click")!=-1||this.type()=="contextmenu")){ +m.client=new MochiKit.Style.Coordinates(0,0); +if(e.clientX||e.clientY){ +m.client.x=(!e.clientX||e.clientX<0)?0:e.clientX; +m.client.y=(!e.clientY||e.clientY<0)?0:e.clientY; +} +m.page=new MochiKit.Style.Coordinates(0,0); +if(e.pageX||e.pageY){ +m.page.x=(!e.pageX||e.pageX<0)?0:e.pageX; +m.page.y=(!e.pageY||e.pageY<0)?0:e.pageY; }else{ -if(o.blend){ -_5f1=[2,1,1,1]; +var de=MochiKit.DOM._document.documentElement; +var b=MochiKit.DOM._document.body; +m.page.x=e.clientX+(de.scrollLeft||b.scrollLeft)-(de.clientLeft||0); +m.page.y=e.clientY+(de.scrollTop||b.scrollTop)-(de.clientTop||0); +} +if(this.type()!="mousemove"){ +m.button={}; +m.button.left=false; +m.button.right=false; +m.button.middle=false; +if(e.which){ +m.button.left=(e.which==1); +m.button.middle=(e.which==2); +m.button.right=(e.which==3); }else{ -if(o.border){ -_5f1=[0,2,0,0]; +m.button.left=!!(e.button&1); +m.button.right=!!(e.button&2); +m.button.middle=!!(e.button&4); +} +} +this._mouse=m; +return m; +} +return undefined; +},stop:function(){ +this.stopPropagation(); +this.preventDefault(); +},stopPropagation:function(){ +if(this._event.stopPropagation){ +this._event.stopPropagation(); }else{ -if(this.isTransparent){ -_5f1=[5,3,2,1]; +this._event.cancelBubble=true; +} +},preventDefault:function(){ +if(this._event.preventDefault){ +this._event.preventDefault(); }else{ -return 0; +if(this._confirmUnload===null){ +this._event.returnValue=false; } } +},_confirmUnload:null,confirmUnload:function(msg){ +if(this.type()=="beforeunload"){ +this._confirmUnload=msg; +this._event.returnValue=msg; } +}}); +MochiKit.Signal._specialMacKeys={3:"KEY_ENTER",63289:"KEY_NUM_PAD_CLEAR",63276:"KEY_PAGE_UP",63277:"KEY_PAGE_DOWN",63275:"KEY_END",63273:"KEY_HOME",63234:"KEY_ARROW_LEFT",63232:"KEY_ARROW_UP",63235:"KEY_ARROW_RIGHT",63233:"KEY_ARROW_DOWN",63302:"KEY_INSERT",63272:"KEY_DELETE"}; +(function(){ +var _3c7=MochiKit.Signal._specialMacKeys; +for(i=63236;i<=63242;i++){ +_3c7[i]="KEY_F"+(i-63236+1); } +})(); +MochiKit.Signal._specialKeys={8:"KEY_BACKSPACE",9:"KEY_TAB",12:"KEY_NUM_PAD_CLEAR",13:"KEY_ENTER",16:"KEY_SHIFT",17:"KEY_CTRL",18:"KEY_ALT",19:"KEY_PAUSE",20:"KEY_CAPS_LOCK",27:"KEY_ESCAPE",32:"KEY_SPACEBAR",33:"KEY_PAGE_UP",34:"KEY_PAGE_DOWN",35:"KEY_END",36:"KEY_HOME",37:"KEY_ARROW_LEFT",38:"KEY_ARROW_UP",39:"KEY_ARROW_RIGHT",40:"KEY_ARROW_DOWN",44:"KEY_PRINT_SCREEN",45:"KEY_INSERT",46:"KEY_DELETE",59:"KEY_SEMICOLON",91:"KEY_WINDOWS_LEFT",92:"KEY_WINDOWS_RIGHT",93:"KEY_SELECT",106:"KEY_NUM_PAD_ASTERISK",107:"KEY_NUM_PAD_PLUS_SIGN",109:"KEY_NUM_PAD_HYPHEN-MINUS",110:"KEY_NUM_PAD_FULL_STOP",111:"KEY_NUM_PAD_SOLIDUS",144:"KEY_NUM_LOCK",145:"KEY_SCROLL_LOCK",186:"KEY_SEMICOLON",187:"KEY_EQUALS_SIGN",188:"KEY_COMMA",189:"KEY_HYPHEN-MINUS",190:"KEY_FULL_STOP",191:"KEY_SOLIDUS",192:"KEY_GRAVE_ACCENT",219:"KEY_LEFT_SQUARE_BRACKET",220:"KEY_REVERSE_SOLIDUS",221:"KEY_RIGHT_SQUARE_BRACKET",222:"KEY_APOSTROPHE"}; +(function(){ +var _3c8=MochiKit.Signal._specialKeys; +for(var i=48;i<=57;i++){ +_3c8[i]="KEY_"+(i-48); } -return _5f1[n]; -},_hasString:function(str){ -for(var i=1;i=(_61c||i)){ -_61c=i; -} -},this.effects); -_618=_61c||_618; -break; -case "break": -ma(function(e){ -e.finalize(); -},this.effects); -break; } -_617.startOn+=_618; -_617.finishOn+=_618; -if(!_617.options.queue.limit||this.effects.length<_617.options.queue.limit){ -this.effects.push(_617); -} -if(!this.interval){ -this.interval=this.startLoop(MochiKit.Base.bind(this.loop,this),40); -} -},startLoop:function(func,_621){ -return setInterval(func,_621); -},remove:function(_622){ -this.effects=MochiKit.Base.filter(function(e){ -return e!=_622; -},this.effects); -if(!this.effects.length){ -this.stopLoop(this.interval); -this.interval=null; -} -},stopLoop:function(_624){ -clearInterval(_624); -},loop:function(){ -var _625=new Date().getTime(); -MochiKit.Base.map(function(_626){ -_626.loop(_625); -},this.effects); -}}); -MochiKit.Visual.Queues={instances:{},get:function(_627){ -if(typeof (_627)!="string"){ -return _627; +}else{ +if(typeof (_3e2)!="function"){ +throw new Error("'objOrFunc' must be a function if 'funcOrStr' is not given"); +}else{ +func=_3e2; } -if(!this.instances[_627]){ -this.instances[_627]=new MochiKit.Visual.ScopedQueue(); } -return this.instances[_627]; -}}; -MochiKit.Visual.Queue=MochiKit.Visual.Queues.get("global"); -MochiKit.Visual.DefaultOptions={transition:MochiKit.Visual.Transitions.sinoidal,duration:1,fps:25,sync:false,from:0,to:1,delay:0,queue:"parallel"}; -MochiKit.Visual.Base=function(){ -}; -MochiKit.Visual.Base.prototype={__class__:MochiKit.Visual.Base,start:function(_628){ -var v=MochiKit.Visual; -this.options=MochiKit.Base.setdefault(_628||{},v.DefaultOptions); -this.currentFrame=0; -this.state="idle"; -this.startOn=this.options.delay*1000; -this.finishOn=this.startOn+(this.options.duration*1000); -this.event("beforeStart"); -if(!this.options.sync){ -v.Queues.get(typeof (this.options.queue)=="string"?"global":this.options.queue.scope).add(this); -} -},loop:function(_62a){ -if(_62a>=this.startOn){ -if(_62a>=this.finishOn){ -return this.finalize(); -} -var pos=(_62a-this.startOn)/(this.finishOn-this.startOn); -var _62c=Math.round(pos*this.options.fps*this.options.duration); -if(_62c>this.currentFrame){ -this.render(pos); -this.currentFrame=_62c; -} -} -},render:function(pos){ -if(this.state=="idle"){ -this.state="running"; -this.event("beforeSetup"); -this.setup(); -this.event("afterSetup"); -} -if(this.state=="running"){ -if(this.options.transition){ -pos=this.options.transition(pos); -} -pos*=(this.options.to-this.options.from); -pos+=this.options.from; -this.event("beforeUpdate"); -this.update(pos); -this.event("afterUpdate"); -} -},cancel:function(){ -if(!this.options.sync){ -MochiKit.Visual.Queues.get(typeof (this.options.queue)=="string"?"global":this.options.queue.scope).remove(this); -} -this.state="finished"; -},finalize:function(){ -this.render(1); -this.cancel(); -this.event("beforeFinish"); -this.finish(); -this.event("afterFinish"); -},setup:function(){ -},finish:function(){ -},update:function(_62e){ -},event:function(_62f){ -if(this.options[_62f+"Internal"]){ -this.options[_62f+"Internal"](this); -} -if(this.options[_62f]){ -this.options[_62f](this); +return [obj,func]; +},connect:function(src,sig,_3e8,_3e9){ +src=MochiKit.DOM.getElement(src); +var self=MochiKit.Signal; +if(typeof (sig)!="string"){ +throw new Error("'sig' must be a string"); } -},repr:function(){ -return "["+this.__class__.NAME+", options:"+MochiKit.Base.repr(this.options)+"]"; -}}; -MochiKit.Visual.Parallel=function(_630,_631){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_630,_631); -} -this.__init__(_630,_631); -}; -MochiKit.Visual.Parallel.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Parallel.prototype,{__class__:MochiKit.Visual.Parallel,__init__:function(_633,_634){ -this.effects=_633||[]; -this.start(_634); -},update:function(_635){ -MochiKit.Base.map(function(_636){ -_636.render(_635); -},this.effects); -},finish:function(){ -MochiKit.Base.map(function(_637){ -_637.finalize(); -},this.effects); -}}); -MochiKit.Visual.Opacity=function(_638,_639){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_638,_639); -} -this.__init__(_638,_639); -}; -MochiKit.Visual.Opacity.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Opacity.prototype,{__class__:MochiKit.Visual.Opacity,__init__:function(_63b,_63c){ -var b=MochiKit.Base; -var s=MochiKit.Style; -this.element=MochiKit.DOM.getElement(_63b); -if(this.element.currentStyle&&(!this.element.currentStyle.hasLayout)){ -s.setStyle(this.element,{zoom:1}); -} -_63c=b.update({from:s.getStyle(this.element,"opacity")||0,to:1},_63c||{}); -this.start(_63c); -},update:function(_63f){ -MochiKit.Style.setStyle(this.element,{"opacity":_63f}); -}}); -MochiKit.Visual.Move=function(_640,_641){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_640,_641); -} -this.__init__(_640,_641); -}; -MochiKit.Visual.Move.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Move.prototype,{__class__:MochiKit.Visual.Move,__init__:function(_643,_644){ -this.element=MochiKit.DOM.getElement(_643); -_644=MochiKit.Base.update({x:0,y:0,mode:"relative"},_644||{}); -this.start(_644); -},setup:function(){ -MochiKit.DOM.makePositioned(this.element); -var s=this.element.style; -var _646=s.visibility; -var _647=s.display; -if(_647=="none"){ -s.visibility="hidden"; -s.display=""; +var _3eb=self._getDestPair(_3e8,_3e9); +var obj=_3eb[0]; +var func=_3eb[1]; +if(typeof (obj)=="undefined"||obj===null){ +obj=src; } -this.originalLeft=parseFloat(MochiKit.Style.getStyle(this.element,"left")||"0"); -this.originalTop=parseFloat(MochiKit.Style.getStyle(this.element,"top")||"0"); -if(this.options.mode=="absolute"){ -this.options.x-=this.originalLeft; -this.options.y-=this.originalTop; +var _3ee=!!(src.addEventListener||src.attachEvent); +if(_3ee&&(sig==="onmouseenter"||sig==="onmouseleave")&&!self._browserAlreadyHasMouseEnterAndLeave()){ +var _3ef=self._mouseEnterListener(src,sig.substr(2),func,obj); +if(sig==="onmouseenter"){ +sig="onmouseover"; +}else{ +sig="onmouseout"; } -if(_647=="none"){ -s.visibility=_646; -s.display=_647; +}else{ +var _3ef=self._listener(src,sig,func,obj,_3ee); } -},update:function(_648){ -MochiKit.Style.setStyle(this.element,{left:Math.round(this.options.x*_648+this.originalLeft)+"px",top:Math.round(this.options.y*_648+this.originalTop)+"px"}); -}}); -MochiKit.Visual.Scale=function(_649,_64a,_64b){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_649,_64a,_64b); -} -this.__init__(_649,_64a,_64b); -}; -MochiKit.Visual.Scale.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Scale.prototype,{__class__:MochiKit.Visual.Scale,__init__:function(_64d,_64e,_64f){ -this.element=MochiKit.DOM.getElement(_64d); -_64f=MochiKit.Base.update({scaleX:true,scaleY:true,scaleContent:true,scaleFromCenter:false,scaleMode:"box",scaleFrom:100,scaleTo:_64e},_64f||{}); -this.start(_64f); -},setup:function(){ -this.restoreAfterFinish=this.options.restoreAfterFinish||false; -this.elementPositioning=MochiKit.Style.getStyle(this.element,"position"); -var ma=MochiKit.Base.map; -var b=MochiKit.Base.bind; -this.originalStyle={}; -ma(b(function(k){ -this.originalStyle[k]=this.element.style[k]; -},this),["top","left","width","height","fontSize"]); -this.originalTop=this.element.offsetTop; -this.originalLeft=this.element.offsetLeft; -var _653=MochiKit.Style.getStyle(this.element,"font-size")||"100%"; -ma(b(function(_654){ -if(_653.indexOf(_654)>0){ -this.fontSize=parseFloat(_653); -this.fontSizeType=_654; -} -},this),["em","px","%"]); -this.factor=(this.options.scaleTo-this.options.scaleFrom)/100; -if(/^content/.test(this.options.scaleMode)){ -this.dims=[this.element.scrollHeight,this.element.scrollWidth]; -}else{ -if(this.options.scaleMode=="box"){ -this.dims=[this.element.offsetHeight,this.element.offsetWidth]; -}else{ -this.dims=[this.options.scaleMode.originalHeight,this.options.scaleMode.originalWidth]; -} -} -},update:function(_655){ -var _656=(this.options.scaleFrom/100)+(this.factor*_655); -if(this.options.scaleContent&&this.fontSize){ -MochiKit.Style.setStyle(this.element,{fontSize:this.fontSize*_656+this.fontSizeType}); -} -this.setDimensions(this.dims[0]*_656,this.dims[1]*_656); -},finish:function(){ -if(this.restoreAfterFinish){ -MochiKit.Style.setStyle(this.element,this.originalStyle); -} -},setDimensions:function(_657,_658){ -var d={}; -var r=Math.round; -if(/MSIE/.test(navigator.userAgent)){ -r=Math.ceil; +if(src.addEventListener){ +src.addEventListener(sig.substr(2),_3ef,false); +}else{ +if(src.attachEvent){ +src.attachEvent(sig,_3ef); } -if(this.options.scaleX){ -d.width=r(_658)+"px"; } -if(this.options.scaleY){ -d.height=r(_657)+"px"; +var _3f0=new MochiKit.Signal.Ident({source:src,signal:sig,listener:_3ef,isDOM:_3ee,objOrFunc:_3e8,funcOrStr:_3e9,connected:true}); +self._observers.push(_3f0); +if(!_3ee&&typeof (src.__connect__)=="function"){ +var args=MochiKit.Base.extend([_3f0],arguments,1); +src.__connect__.apply(src,args); } -if(this.options.scaleFromCenter){ -var topd=(_657-this.dims[0])/2; -var _65c=(_658-this.dims[1])/2; -if(this.elementPositioning=="absolute"){ -if(this.options.scaleY){ -d.top=this.originalTop-topd+"px"; +return _3f0; +},_disconnect:function(_3f2){ +if(!_3f2.connected){ +return; } -if(this.options.scaleX){ -d.left=this.originalLeft-_65c+"px"; +_3f2.connected=false; +if(!_3f2.isDOM){ +return; } +var src=_3f2.source; +var sig=_3f2.signal; +var _3f5=_3f2.listener; +if(src.removeEventListener){ +src.removeEventListener(sig.substr(2),_3f5,false); +}else{ +if(src.detachEvent){ +src.detachEvent(sig,_3f5); }else{ -if(this.options.scaleY){ -d.top=-topd+"px"; +throw new Error("'src' must be a DOM element"); } -if(this.options.scaleX){ -d.left=-_65c+"px"; } +},disconnect:function(_3f6){ +var self=MochiKit.Signal; +var _3f8=self._observers; +var m=MochiKit.Base; +if(arguments.length>1){ +var src=MochiKit.DOM.getElement(arguments[0]); +var sig=arguments[1]; +var obj=arguments[2]; +var func=arguments[3]; +for(var i=_3f8.length-1;i>=0;i--){ +var o=_3f8[i]; +if(o.source===src&&o.signal===sig&&o.objOrFunc===obj&&o.funcOrStr===func){ +self._disconnect(o); +if(!self._lock){ +_3f8.splice(i,1); +}else{ +self._dirty=true; } +return true; } -MochiKit.Style.setStyle(this.element,d); -}}); -MochiKit.Visual.Highlight=function(_65d,_65e){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_65d,_65e); -} -this.__init__(_65d,_65e); -}; -MochiKit.Visual.Highlight.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Highlight.prototype,{__class__:MochiKit.Visual.Highlight,__init__:function(_660,_661){ -this.element=MochiKit.DOM.getElement(_660); -_661=MochiKit.Base.update({startcolor:"#ffff99"},_661||{}); -this.start(_661); -},setup:function(){ -var b=MochiKit.Base; -var s=MochiKit.Style; -if(s.getStyle(this.element,"display")=="none"){ -this.cancel(); -return; } -this.oldStyle={backgroundImage:s.getStyle(this.element,"background-image")}; -s.setStyle(this.element,{backgroundImage:"none"}); -if(!this.options.endcolor){ -this.options.endcolor=MochiKit.Color.Color.fromBackground(this.element).toHexString(); -} -if(b.isUndefinedOrNull(this.options.restorecolor)){ -this.options.restorecolor=s.getStyle(this.element,"background-color"); -} -this._base=b.map(b.bind(function(i){ -return parseInt(this.options.startcolor.slice(i*2+1,i*2+3),16); -},this),[0,1,2]); -this._delta=b.map(b.bind(function(i){ -return parseInt(this.options.endcolor.slice(i*2+1,i*2+3),16)-this._base[i]; -},this),[0,1,2]); -},update:function(_666){ -var m="#"; -MochiKit.Base.map(MochiKit.Base.bind(function(i){ -m+=MochiKit.Color.toColorPart(Math.round(this._base[i]+this._delta[i]*_666)); -},this),[0,1,2]); -MochiKit.Style.setStyle(this.element,{backgroundColor:m}); -},finish:function(){ -MochiKit.Style.setStyle(this.element,MochiKit.Base.update(this.oldStyle,{backgroundColor:this.options.restorecolor})); -}}); -MochiKit.Visual.ScrollTo=function(_669,_66a){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_669,_66a); -} -this.__init__(_669,_66a); -}; -MochiKit.Visual.ScrollTo.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.ScrollTo.prototype,{__class__:MochiKit.Visual.ScrollTo,__init__:function(_66c,_66d){ -this.element=MochiKit.DOM.getElement(_66c); -this.start(_66d||{}); -},setup:function(){ -var p=MochiKit.Position; -p.prepare(); -var _66f=p.cumulativeOffset(this.element); -if(this.options.offset){ -_66f.y+=this.options.offset; -} -var max; -if(window.innerHeight){ -max=window.innerHeight-window.height; -}else{ -if(document.documentElement&&document.documentElement.clientHeight){ -max=document.documentElement.clientHeight-document.body.scrollHeight; -}else{ -if(document.body){ -max=document.body.clientHeight-document.body.scrollHeight; -} -} -} -this.scrollStart=p.windowOffset.y; -this.delta=(_66f.y>max?max:_66f.y)-this.scrollStart; -},update:function(_671){ -var p=MochiKit.Position; -p.prepare(); -window.scrollTo(p.windowOffset.x,this.scrollStart+(_671*this.delta)); -}}); -MochiKit.Visual.CSS_LENGTH=/^(([\+\-]?[0-9\.]+)(em|ex|px|in|cm|mm|pt|pc|\%))|0$/; -MochiKit.Visual.Morph=function(_673,_674){ -var cls=arguments.callee; -if(!(this instanceof cls)){ -return new cls(_673,_674); -} -this.__init__(_673,_674); -}; -MochiKit.Visual.Morph.prototype=new MochiKit.Visual.Base(); -MochiKit.Base.update(MochiKit.Visual.Morph.prototype,{__class__:MochiKit.Visual.Morph,__init__:function(_676,_677){ -this.element=MochiKit.DOM.getElement(_676); -this.start(_677||{}); -},setup:function(){ -var b=MochiKit.Base; -var _679=this.options.style; -this.styleStart={}; -this.styleEnd={}; -this.units={}; -var _67a,unit; -for(var s in _679){ -_67a=_679[s]; -s=b.camelize(s); -if(MochiKit.Visual.CSS_LENGTH.test(_67a)){ -var _67d=_67a.match(/^([\+\-]?[0-9\.]+)(.*)$/); -_67a=parseFloat(_67d[1]); -unit=(_67d.length==3)?_67d[2]:null; -this.styleEnd[s]=_67a; -this.units[s]=unit; -_67a=MochiKit.Style.getStyle(this.element,s); -_67d=_67a.match(/^([\+\-]?[0-9\.]+)(.*)$/); -_67a=parseFloat(_67d[1]); -this.styleStart[s]=_67a; -}else{ -var c=MochiKit.Color.Color; -_67a=c.fromString(_67a); -if(_67a){ -this.units[s]="color"; -this.styleEnd[s]=_67a.toHexString(); -_67a=MochiKit.Style.getStyle(this.element,s); -this.styleStart[s]=c.fromString(_67a).toHexString(); -this.styleStart[s]=b.map(b.bind(function(i){ -return parseInt(this.styleStart[s].slice(i*2+1,i*2+3),16); -},this),[0,1,2]); -this.styleEnd[s]=b.map(b.bind(function(i){ -return parseInt(this.styleEnd[s].slice(i*2+1,i*2+3),16); -},this),[0,1,2]); -} -} -} -},update:function(_681){ -var _682; -for(var s in this.styleStart){ -if(this.units[s]=="color"){ -var m="#"; -var _685=this.styleStart[s]; -var end=this.styleEnd[s]; -MochiKit.Base.map(MochiKit.Base.bind(function(i){ -m+=MochiKit.Color.toColorPart(Math.round(_685[i]+(end[i]-_685[i])*_681)); -},this),[0,1,2]); -this.element.style[s]=m; -}else{ -_682=this.styleStart[s]+Math.round((this.styleEnd[s]-this.styleStart[s])*_681*1000)/1000+this.units[s]; -this.element.style[s]=_682; +}else{ +var idx=m.findIdentical(_3f8,_3f6); +if(idx>=0){ +self._disconnect(_3f6); +if(!self._lock){ +_3f8.splice(idx,1); +}else{ +self._dirty=true; } +return true; } -}}); -MochiKit.Visual.fade=function(_688,_689){ -var s=MochiKit.Style; -var _68b=s.getStyle(_688,"opacity"); -_689=MochiKit.Base.update({from:s.getStyle(_688,"opacity")||1,to:0,afterFinishInternal:function(_68c){ -if(_68c.options.to!==0){ -return; } -s.hideElement(_68c.element); -s.setStyle(_68c.element,{"opacity":_68b}); -}},_689||{}); -return new MochiKit.Visual.Opacity(_688,_689); -}; -MochiKit.Visual.appear=function(_68d,_68e){ -var s=MochiKit.Style; -var v=MochiKit.Visual; -_68e=MochiKit.Base.update({from:(s.getStyle(_68d,"display")=="none"?0:s.getStyle(_68d,"opacity")||0),to:1,afterFinishInternal:function(_691){ -v.forceRerendering(_691.element); -},beforeSetupInternal:function(_692){ -s.setStyle(_692.element,{"opacity":_692.options.from}); -s.showElement(_692.element); -}},_68e||{}); -return new v.Opacity(_68d,_68e); -}; -MochiKit.Visual.puff=function(_693,_694){ -var s=MochiKit.Style; -var v=MochiKit.Visual; -_693=MochiKit.DOM.getElement(_693); -var _697={position:s.getStyle(_693,"position"),top:_693.style.top,left:_693.style.left,width:_693.style.width,height:_693.style.height,opacity:s.getStyle(_693,"opacity")}; -_694=MochiKit.Base.update({beforeSetupInternal:function(_698){ -MochiKit.Position.absolutize(_698.effects[0].element); -},afterFinishInternal:function(_699){ -s.hideElement(_699.effects[0].element); -s.setStyle(_699.effects[0].element,_697); -},scaleContent:true,scaleFromCenter:true},_694||{}); -return new v.Parallel([new v.Scale(_693,200,{sync:true,scaleFromCenter:_694.scaleFromCenter,scaleContent:_694.scaleContent,restoreAfterFinish:true}),new v.Opacity(_693,{sync:true,to:0})],_694); -}; -MochiKit.Visual.blindUp=function(_69a,_69b){ -var d=MochiKit.DOM; -_69a=d.getElement(_69a); -var _69d=d.makeClipping(_69a); -_69b=MochiKit.Base.update({scaleContent:false,scaleX:false,restoreAfterFinish:true,afterFinishInternal:function(_69e){ -MochiKit.Style.hideElement(_69e.element); -d.undoClipping(_69e.element,_69d); -}},_69b||{}); -return new MochiKit.Visual.Scale(_69a,0,_69b); -}; -MochiKit.Visual.blindDown=function(_69f,_6a0){ -var d=MochiKit.DOM; -var s=MochiKit.Style; -_69f=d.getElement(_69f); -var _6a3=s.getElementDimensions(_69f); -var _6a4; -_6a0=MochiKit.Base.update({scaleContent:false,scaleX:false,scaleFrom:0,scaleMode:{originalHeight:_6a3.h,originalWidth:_6a3.w},restoreAfterFinish:true,afterSetupInternal:function(_6a5){ -_6a4=d.makeClipping(_6a5.element); -s.setStyle(_6a5.element,{height:"0px"}); -s.showElement(_6a5.element); -},afterFinishInternal:function(_6a6){ -d.undoClipping(_6a6.element,_6a4); -}},_6a0||{}); -return new MochiKit.Visual.Scale(_69f,100,_6a0); -}; -MochiKit.Visual.switchOff=function(_6a7,_6a8){ -var d=MochiKit.DOM; -_6a7=d.getElement(_6a7); -var _6aa=MochiKit.Style.getStyle(_6a7,"opacity"); -var _6ab; -_6a8=MochiKit.Base.update({duration:0.3,scaleFromCenter:true,scaleX:false,scaleContent:false,restoreAfterFinish:true,beforeSetupInternal:function(_6ac){ -d.makePositioned(_6ac.element); -_6ab=d.makeClipping(_6ac.element); -},afterFinishInternal:function(_6ad){ -MochiKit.Style.hideElement(_6ad.element); -d.undoClipping(_6ad.element,_6ab); -d.undoPositioned(_6ad.element); -MochiKit.Style.setStyle(_6ad.element,{"opacity":_6aa}); -}},_6a8||{}); -var v=MochiKit.Visual; -return new v.appear(_6a7,{duration:0.4,from:0,transition:v.Transitions.flicker,afterFinishInternal:function(_6af){ -new v.Scale(_6af.element,1,_6a8); -}}); -}; -MochiKit.Visual.dropOut=function(_6b0,_6b1){ -var d=MochiKit.DOM; -var s=MochiKit.Style; -_6b0=d.getElement(_6b0); -var _6b4={top:s.getStyle(_6b0,"top"),left:s.getStyle(_6b0,"left"),opacity:s.getStyle(_6b0,"opacity")}; -_6b1=MochiKit.Base.update({duration:0.5,distance:100,beforeSetupInternal:function(_6b5){ -d.makePositioned(_6b5.effects[0].element); -},afterFinishInternal:function(_6b6){ -s.hideElement(_6b6.effects[0].element); -d.undoPositioned(_6b6.effects[0].element); -s.setStyle(_6b6.effects[0].element,_6b4); -}},_6b1||{}); -var v=MochiKit.Visual; -return new v.Parallel([new v.Move(_6b0,{x:0,y:_6b1.distance,sync:true}),new v.Opacity(_6b0,{sync:true,to:0})],_6b1); -}; -MochiKit.Visual.shake=function(_6b8,_6b9){ -var d=MochiKit.DOM; -var v=MochiKit.Visual; -var s=MochiKit.Style; -_6b8=d.getElement(_6b8); -_6b9=MochiKit.Base.update({x:-20,y:0,duration:0.05,afterFinishInternal:function(_6bd){ -d.undoPositioned(_6bd.element); -s.setStyle(_6bd.element,_6be); -}},_6b9||{}); -var _6be={top:s.getStyle(_6b8,"top"),left:s.getStyle(_6b8,"left")}; -return new v.Move(_6b8,{x:20,y:0,duration:0.05,afterFinishInternal:function(_6bf){ -new v.Move(_6bf.element,{x:-40,y:0,duration:0.1,afterFinishInternal:function(_6c0){ -new v.Move(_6c0.element,{x:40,y:0,duration:0.1,afterFinishInternal:function(_6c1){ -new v.Move(_6c1.element,{x:-40,y:0,duration:0.1,afterFinishInternal:function(_6c2){ -new v.Move(_6c2.element,{x:40,y:0,duration:0.1,afterFinishInternal:function(_6c3){ -new v.Move(_6c3.element,_6b9); -}}); -}}); -}}); -}}); -}}); -}; -MochiKit.Visual.slideDown=function(_6c4,_6c5){ -var d=MochiKit.DOM; -var b=MochiKit.Base; -var s=MochiKit.Style; -_6c4=d.getElement(_6c4); -if(!_6c4.firstChild){ -throw "MochiKit.Visual.slideDown must be used on a element with a child"; -} -d.removeEmptyTextNodes(_6c4); -var _6c9=s.getStyle(_6c4.firstChild,"bottom")||0; -var _6ca=s.getElementDimensions(_6c4); -var _6cb; -_6c5=b.update({scaleContent:false,scaleX:false,scaleFrom:0,scaleMode:{originalHeight:_6ca.h,originalWidth:_6ca.w},restoreAfterFinish:true,afterSetupInternal:function(_6cc){ -d.makePositioned(_6cc.element); -d.makePositioned(_6cc.element.firstChild); -if(/Opera/.test(navigator.userAgent)){ -s.setStyle(_6cc.element,{top:""}); -} -_6cb=d.makeClipping(_6cc.element); -s.setStyle(_6cc.element,{height:"0px"}); -s.showElement(_6cc.element); -},afterUpdateInternal:function(_6cd){ -s.setStyle(_6cd.element.firstChild,{bottom:(_6cd.dims[0]-_6cd.element.clientHeight)+"px"}); -},afterFinishInternal:function(_6ce){ -d.undoClipping(_6ce.element,_6cb); -if(/MSIE/.test(navigator.userAgent)){ -d.undoPositioned(_6ce.element); -d.undoPositioned(_6ce.element.firstChild); +return false; +},disconnectAllTo:function(_401,_402){ +var self=MochiKit.Signal; +var _404=self._observers; +var _405=self._disconnect; +var _406=self._lock; +var _407=self._dirty; +if(typeof (_402)==="undefined"){ +_402=null; +} +for(var i=_404.length-1;i>=0;i--){ +var _409=_404[i]; +if(_409.objOrFunc===_401&&(_402===null||_409.funcOrStr===_402)){ +_405(_409); +if(_406){ +_407=true; }else{ -d.undoPositioned(_6ce.element.firstChild); -d.undoPositioned(_6ce.element); +_404.splice(i,1); } -s.setStyle(_6ce.element.firstChild,{bottom:_6c9}); -}},_6c5||{}); -return new MochiKit.Visual.Scale(_6c4,100,_6c5); -}; -MochiKit.Visual.slideUp=function(_6cf,_6d0){ -var d=MochiKit.DOM; -var b=MochiKit.Base; -var s=MochiKit.Style; -_6cf=d.getElement(_6cf); -if(!_6cf.firstChild){ -throw "MochiKit.Visual.slideUp must be used on a element with a child"; -} -d.removeEmptyTextNodes(_6cf); -var _6d4=s.getStyle(_6cf.firstChild,"bottom"); -var _6d5; -_6d0=b.update({scaleContent:false,scaleX:false,scaleMode:"box",scaleFrom:100,restoreAfterFinish:true,beforeStartInternal:function(_6d6){ -d.makePositioned(_6d6.element); -d.makePositioned(_6d6.element.firstChild); -if(/Opera/.test(navigator.userAgent)){ -s.setStyle(_6d6.element,{top:""}); -} -_6d5=d.makeClipping(_6d6.element); -s.showElement(_6d6.element); -},afterUpdateInternal:function(_6d7){ -s.setStyle(_6d7.element.firstChild,{bottom:(_6d7.dims[0]-_6d7.element.clientHeight)+"px"}); -},afterFinishInternal:function(_6d8){ -s.hideElement(_6d8.element); -d.undoClipping(_6d8.element,_6d5); -d.undoPositioned(_6d8.element.firstChild); -d.undoPositioned(_6d8.element); -s.setStyle(_6d8.element.firstChild,{bottom:_6d4}); -}},_6d0||{}); -return new MochiKit.Visual.Scale(_6cf,0,_6d0); -}; -MochiKit.Visual.squish=function(_6d9,_6da){ -var d=MochiKit.DOM; -var b=MochiKit.Base; -var _6dd; -_6da=b.update({restoreAfterFinish:true,beforeSetupInternal:function(_6de){ -_6dd=d.makeClipping(_6de.element); -},afterFinishInternal:function(_6df){ -MochiKit.Style.hideElement(_6df.element); -d.undoClipping(_6df.element,_6dd); -}},_6da||{}); -return new MochiKit.Visual.Scale(_6d9,/Opera/.test(navigator.userAgent)?1:0,_6da); -}; -MochiKit.Visual.grow=function(_6e0,_6e1){ -var d=MochiKit.DOM; -var v=MochiKit.Visual; -var s=MochiKit.Style; -_6e0=d.getElement(_6e0); -_6e1=MochiKit.Base.update({direction:"center",moveTransition:v.Transitions.sinoidal,scaleTransition:v.Transitions.sinoidal,opacityTransition:v.Transitions.full,scaleContent:true,scaleFromCenter:false},_6e1||{}); -var _6e5={top:_6e0.style.top,left:_6e0.style.left,height:_6e0.style.height,width:_6e0.style.width,opacity:s.getStyle(_6e0,"opacity")}; -var dims=s.getElementDimensions(_6e0); -var _6e7,_6e8; -var _6e9,_6ea; -switch(_6e1.direction){ -case "top-left": -_6e7=_6e8=_6e9=_6ea=0; -break; -case "top-right": -_6e7=dims.w; -_6e8=_6ea=0; -_6e9=-dims.w; -break; -case "bottom-left": -_6e7=_6e9=0; -_6e8=dims.h; -_6ea=-dims.h; -break; -case "bottom-right": -_6e7=dims.w; -_6e8=dims.h; -_6e9=-dims.w; -_6ea=-dims.h; -break; -case "center": -_6e7=dims.w/2; -_6e8=dims.h/2; -_6e9=-dims.w/2; -_6ea=-dims.h/2; -break; } -var _6eb=MochiKit.Base.update({beforeSetupInternal:function(_6ec){ -s.setStyle(_6ec.effects[0].element,{height:"0px"}); -s.showElement(_6ec.effects[0].element); -},afterFinishInternal:function(_6ed){ -d.undoClipping(_6ed.effects[0].element); -d.undoPositioned(_6ed.effects[0].element); -s.setStyle(_6ed.effects[0].element,_6e5); -}},_6e1||{}); -return new v.Move(_6e0,{x:_6e7,y:_6e8,duration:0.01,beforeSetupInternal:function(_6ee){ -s.hideElement(_6ee.element); -d.makeClipping(_6ee.element); -d.makePositioned(_6ee.element); -},afterFinishInternal:function(_6ef){ -new v.Parallel([new v.Opacity(_6ef.element,{sync:true,to:1,from:0,transition:_6e1.opacityTransition}),new v.Move(_6ef.element,{x:_6e9,y:_6ea,sync:true,transition:_6e1.moveTransition}),new v.Scale(_6ef.element,100,{scaleMode:{originalHeight:dims.h,originalWidth:dims.w},sync:true,scaleFrom:/Opera/.test(navigator.userAgent)?1:0,transition:_6e1.scaleTransition,scaleContent:_6e1.scaleContent,scaleFromCenter:_6e1.scaleFromCenter,restoreAfterFinish:true})],_6eb); -}}); -}; -MochiKit.Visual.shrink=function(_6f0,_6f1){ -var d=MochiKit.DOM; -var v=MochiKit.Visual; -var s=MochiKit.Style; -_6f0=d.getElement(_6f0); -_6f1=MochiKit.Base.update({direction:"center",moveTransition:v.Transitions.sinoidal,scaleTransition:v.Transitions.sinoidal,opacityTransition:v.Transitions.none,scaleContent:true,scaleFromCenter:false},_6f1||{}); -var _6f5={top:_6f0.style.top,left:_6f0.style.left,height:_6f0.style.height,width:_6f0.style.width,opacity:s.getStyle(_6f0,"opacity")}; -var dims=s.getElementDimensions(_6f0); -var _6f7,_6f8; -switch(_6f1.direction){ -case "top-left": -_6f7=_6f8=0; -break; -case "top-right": -_6f7=dims.w; -_6f8=0; -break; -case "bottom-left": -_6f7=0; -_6f8=dims.h; -break; -case "bottom-right": -_6f7=dims.w; -_6f8=dims.h; -break; -case "center": -_6f7=dims.w/2; -_6f8=dims.h/2; -break; } -var _6f9; -var _6fa=MochiKit.Base.update({beforeStartInternal:function(_6fb){ -_6f9=d.makePositioned(_6fb.effects[0].element); -d.makeClipping(_6fb.effects[0].element); -},afterFinishInternal:function(_6fc){ -s.hideElement(_6fc.effects[0].element); -d.undoClipping(_6fc.effects[0].element,_6f9); -d.undoPositioned(_6fc.effects[0].element); -s.setStyle(_6fc.effects[0].element,_6f5); -}},_6f1||{}); -return new v.Parallel([new v.Opacity(_6f0,{sync:true,to:0,from:1,transition:_6f1.opacityTransition}),new v.Scale(_6f0,/Opera/.test(navigator.userAgent)?1:0,{sync:true,transition:_6f1.scaleTransition,scaleContent:_6f1.scaleContent,scaleFromCenter:_6f1.scaleFromCenter,restoreAfterFinish:true}),new v.Move(_6f0,{x:_6f7,y:_6f8,sync:true,transition:_6f1.moveTransition})],_6fa); -}; -MochiKit.Visual.pulsate=function(_6fd,_6fe){ -var d=MochiKit.DOM; -var v=MochiKit.Visual; -var b=MochiKit.Base; -var _702=MochiKit.Style.getStyle(_6fd,"opacity"); -_6fe=b.update({duration:3,from:0,afterFinishInternal:function(_703){ -MochiKit.Style.setStyle(_703.element,{"opacity":_702}); -}},_6fe||{}); -var _704=_6fe.transition||v.Transitions.sinoidal; -var _705=b.bind(function(pos){ -return _704(1-v.Transitions.pulse(pos,_6fe.pulses)); -},_704); -b.bind(_705,_704); -return new v.Opacity(_6fd,b.update({transition:_705},_6fe)); -}; -MochiKit.Visual.fold=function(_707,_708){ -var d=MochiKit.DOM; -var v=MochiKit.Visual; -var s=MochiKit.Style; -_707=d.getElement(_707); -var _70c={top:_707.style.top,left:_707.style.left,width:_707.style.width,height:_707.style.height}; -var _70d=d.makeClipping(_707); -_708=MochiKit.Base.update({scaleContent:false,scaleX:false,afterFinishInternal:function(_70e){ -new v.Scale(_707,1,{scaleContent:false,scaleY:false,afterFinishInternal:function(_70f){ -s.hideElement(_70f.element); -d.undoClipping(_70f.element,_70d); -s.setStyle(_70f.element,_70c); -}}); -}},_708||{}); -return new v.Scale(_707,5,_708); -}; -MochiKit.Visual.Color=MochiKit.Color.Color; -MochiKit.Visual.getElementsComputedStyle=MochiKit.DOM.computedStyle; -MochiKit.Visual.__new__=function(){ +self._dirty=_407; +},disconnectAll:function(src,sig){ +src=MochiKit.DOM.getElement(src); var m=MochiKit.Base; -m.nameFunctions(this); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -}; -MochiKit.Visual.EXPORT=["roundElement","roundClass","tagifyText","multiple","toggle","Parallel","Opacity","Move","Scale","Highlight","ScrollTo","Morph","fade","appear","puff","blindUp","blindDown","switchOff","dropOut","shake","slideDown","slideUp","squish","grow","shrink","pulsate","fold"]; -MochiKit.Visual.EXPORT_OK=["Base","PAIRS"]; -MochiKit.Visual.__new__(); -MochiKit.Base._exportSymbols(this,MochiKit.Visual); -if(typeof (MochiKit)=="undefined"){ -MochiKit={}; +var _40d=m.flattenArguments(m.extend(null,arguments,1)); +var self=MochiKit.Signal; +var _40f=self._disconnect; +var _410=self._observers; +var i,_412; +var _413=self._lock; +var _414=self._dirty; +if(_40d.length===0){ +for(i=_410.length-1;i>=0;i--){ +_412=_410[i]; +if(_412.source===src){ +_40f(_412); +if(!_413){ +_410.splice(i,1); +}else{ +_414=true; } -if(typeof (MochiKit.MochiKit)=="undefined"){ -MochiKit.MochiKit={}; } -MochiKit.MochiKit.NAME="MochiKit.MochiKit"; -MochiKit.MochiKit.VERSION="1.4"; -MochiKit.MochiKit.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -MochiKit.MochiKit.toString=function(){ -return this.__repr__(); -}; -MochiKit.MochiKit.SUBMODULES=["Base","Iter","Logging","DateTime","Format","Async","DOM","Selector","Style","LoggingPane","Color","Signal","Position","Visual"]; -if(typeof (JSAN)!="undefined"||typeof (dojo)!="undefined"){ -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.MochiKit"); -dojo.require("MochiKit.*"); } -if(typeof (JSAN)!="undefined"){ -(function(lst){ -for(var i=0;i=0;i--){ +_412=_410[i]; +if(_412.source===src&&_412.signal in sigs){ +_40f(_412); +if(!_413){ +_410.splice(i,1); +}else{ +_414=true; } -(function(){ -var _713=MochiKit.Base.extend; -var self=MochiKit.MochiKit; -var _715=self.SUBMODULES; -var _716=[]; -var _717=[]; -var _718={}; -var i,k,m,all; -for(i=0;i<_715.length;i++){ -m=MochiKit[_715[i]]; -_713(_716,m.EXPORT); -_713(_717,m.EXPORT_OK); -for(k in m.EXPORT_TAGS){ -_718[k]=_713(_718[k],m.EXPORT_TAGS[k]); -} -all=m.EXPORT_TAGS[":all"]; -if(!all){ -all=_713(null,m.EXPORT,m.EXPORT_OK); -} -var j; -for(j=0;j=0;i--){ +if(!_419[i].connected){ +_419.splice(i,1); +} +} } -if(document.documentElement&&document.documentElement.namespaceURI==_71f){ -var s=document.createElementNS(_71f,"script"); -s.setAttribute("id","MochiKit_"+base+_725[i]); -s.setAttribute("src",uri); -s.setAttribute("type","application/x-javascript"); -_721.parentNode.appendChild(s); +if(_41b.length==1){ +throw _41b[0]; }else{ -document.write(""); +if(_41b.length>1){ +var e=new Error("Multiple errors thrown in handling 'sig', see errors property"); +e.errors=_41b; +throw e; } } -})(); +}}); +MochiKit.Signal.EXPORT_OK=[]; +MochiKit.Signal.EXPORT=["connect","disconnect","signal","disconnectAll","disconnectAllTo"]; +MochiKit.Signal.__new__=function(win){ +var m=MochiKit.Base; +this._document=document; +this._window=win; +this._lock=false; +this._dirty=false; +try{ +this.connect(window,"onunload",this._unloadCache); +} +catch(e){ +} +this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; +m.nameFunctions(this); +}; +MochiKit.Signal.__new__(this); +if(MochiKit.__export__){ +connect=MochiKit.Signal.connect; +disconnect=MochiKit.Signal.disconnect; +disconnectAll=MochiKit.Signal.disconnectAll; +signal=MochiKit.Signal.signal; } +MochiKit.Base._exportSymbols(this,MochiKit.Signal); /*** @@ -6917,12 +3872,12 @@ document.write(""); ***/ try{ -if(typeof (MochiKit.Base)=="undefined"||typeof (MochiKit.DOM)=="undefined"||typeof (MochiKit.Color)=="undefined"||typeof (MochiKit.Format)=="undefined"){ +if(typeof (MochiKit.Base)=="undefined"||typeof (MochiKit.DOM)=="undefined"||typeof (MochiKit.Color)=="undefined"){ throw ""; } } catch(e){ -throw "PlotKit depends on MochiKit.{Base,Color,DOM,Format}"; +throw "PlotKit depends on MochiKit.{Base,Color,DOM}"; } MochiKit.Base.update(MochiKit.Color.Color.prototype,{asFillColor:function(){ return this.lighterColorWithLevel(0.3); @@ -6961,186 +3916,135 @@ catch(e){ return false; } }; -MochiKit.Base.update(PlotKit.Base,{roundInterval:function(_1,_2,_3){ -var _4=MochiKit.Format.roundToFixed; -var _5=_1/_2; -return parseFloat(_4(_5,_3)); -},collapse:function(_6){ +MochiKit.Base.update(PlotKit.Base,{collapse:function(_1){ var m=MochiKit.Base; -var _8=new Array(); -for(var i=0;i<_6.length;i++){ -_8=m.concat(_8,_6[i]); +var _3=new Array(); +for(var i=0;i<_1.length;i++){ +_3=m.concat(_3,_1[i]); } if(PlotKit.Base.usingPrototype()){ -delete _8.extend; -delete _8.from; -delete _8.inspect; +delete _3.extend; +delete _3.from; +delete _3.inspect; } -return _8; -},uniq:function(_10){ +return _3; +},uniq:function(_5){ var m=MochiKit.Base; -if(!m.isArrayLike(_10)||(_10.length<1)){ +if(!m.isArrayLike(_5)||(_5.length<1)){ return new Array(); } -var _11=new Array(); -var _12=_10[0]; -_11.push(_10[0]); -for(var i=1;i<_10.length;i++){ -if(m.compare(_10[i],_12)!=0){ -_12=_10[i]; -_11.push(_10[i]); -} -} -return _11; -},colorScheme:function(){ -var mb=MochiKit.Base; -var mc=MochiKit.Color; -var _15=["red","orange","yellow","green","cyan","blue","purple","magenta"]; -var _16=function(_17){ -return mc.Color[_17+"Color"](); -}; -return mb.map(_16,_15); -},baseDarkPrimaryColors:function(){ -var _18=MochiKit.Color.Color.fromHexString; -return [_18("#ad3f40"),_18("#ddac2c"),_18("#dfdd0c"),_18("#5276c4"),_18("#739c5a")]; -},basePrimaryColors:function(){ -var _19=MochiKit.Color.Color.fromHexString; -return [_19("#d24c4d"),_19("#f2b32f"),_19("#ece90e"),_19("#5d83da"),_19("#78a15d")]; -},baseBlueColors:function(){ -var _20=MochiKit.Color.Color.fromHexString; -return [_20("#4b6b94"),_20("#5d81b4"),_20("#acbad2")]; -},palette:function(_21,_22,_23,_24){ -var _25=MochiKit.Base.isUndefinedOrNull; -var _26=new Array(); -if(_25(_24)){ -_24=0.1; -} -if(_25(_23)){ -_23=0.4; -} -if(_25(_22)){ -_22=-0.2; -} -var _27=_22; -while(_27<=_23){ -_26.push(_27); -_27+=_24; -} -var _28=function(_29,_30){ -return _29.lighterColorWithLevel(_30); -}; -return MochiKit.Base.map(partial(_28,_21),_26); +var _6=new Array(); +var _7=_5[0]; +_6.push(_5[0]); +for(var i=1;i<_5.length;i++){ +if(m.compare(_5[i],_7)!=0){ +_7=_5[i]; +_6.push(_5[i]); +} +} +return _6; +},palette:function(_8,_9,_10,_11){ +var _12=MochiKit.Base.isUndefinedOrNull; +var _13=new Array(); +if(_12(_11)){ +_11=0.1; +} +if(_12(_10)){ +_10=0.4; +} +if(_12(_9)){ +_9=-0.2; +} +var _14=_9; +while(_14<=_10){ +_13.push(_14); +_14+=_11; +} +var _15=function(_16,_17){ +return _16.lighterColorWithLevel(_17); +}; +return MochiKit.Base.map(partial(_15,_8),_13); },excanvasSupported:function(){ if(/MSIE/.test(navigator.userAgent)&&!window.opera){ return true; } return false; },findPosX:function(obj){ -var _32=0; +var _19=0; if(obj.offsetParent){ while(obj.offsetParent){ -_32+=obj.offsetLeft; +_19+=obj.offsetLeft; obj=obj.offsetParent; } }else{ if(obj.x){ -_32+=obj.x; +_19+=obj.x; } } -return _32; +return _19; },findPosY:function(obj){ -var _33=0; +var _20=0; if(obj.offsetParent){ while(obj.offsetParent){ -_33+=obj.offsetTop; +_20+=obj.offsetTop; obj=obj.offsetParent; } }else{ if(obj.y){ -_33+=obj.y; +_20+=obj.y; } } -return _33; +return _20; },isFuncLike:function(obj){ return (typeof (obj)=="function"); }}); PlotKit.Base.map=function(fn,lst){ if(PlotKit.Base.usingPrototype()){ -var _36=[]; +var _23=[]; for(var x in lst){ if(typeof (lst[x])=="function"){ continue; } -_36.push(fn(lst[x])); +_23.push(fn(lst[x])); } -return _36; +return _23; }else{ return MochiKit.Base.map(fn,lst); } }; PlotKit.Base.items=function(lst){ if(PlotKit.Base.usingPrototype()){ -var _38=[]; +var _25=[]; for(var x in lst){ if(typeof (lst[x])=="function"){ continue; } -_38.push([x,lst[x]]); +_25.push([x,lst[x]]); } -return _38; +return _25; }else{ return MochiKit.Base.items(lst); } }; PlotKit.Base.keys=function(lst){ if(PlotKit.Base.usingPrototype()){ -var _39=[]; +var _26=[]; for(var x in lst){ if(typeof (lst[x])=="function"){ continue; } -_39.push(x); +_26.push(x); } -return _39; +return _26; }else{ return MochiKit.Base.keys(lst); } }; PlotKit.Base.baseColors=function(){ -var _40=MochiKit.Color.Color.fromHexString; -return [_40("#476fb2"),_40("#be2c2b"),_40("#85b730"),_40("#734a99"),_40("#26a1c5"),_40("#fb8707"),_40("#000000")]; -}; -PlotKit.Base.officeBaseStyle={"axisLineWidth":2,"axisLabelColor":Color.grayColor(),"axisLineColor":Color.whiteColor(),"padding":{top:5,bottom:10,left:30,right:30}}; -MochiKit.Base.update(PlotKit.Base,{officeBlue:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[0]),"backgroundColor":PlotKit.Base.baseColors()[0].lighterColorWithLevel(0.45)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officeRed:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[1]),"backgroundColor":PlotKit.Base.baseColors()[1].lighterColorWithLevel(0.5)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officeGreen:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[2]),"backgroundColor":PlotKit.Base.baseColors()[2].lighterColorWithLevel(0.5)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officePurple:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[3]),"backgroundColor":PlotKit.Base.baseColors()[3].lighterColorWithLevel(0.5)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officeCyan:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[4]),"backgroundColor":PlotKit.Base.baseColors()[4].lighterColorWithLevel(0.5)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officeOrange:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[5]),"backgroundColor":PlotKit.Base.baseColors()[5].lighterColorWithLevel(0.4)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -},officeBlack:function(){ -var r={"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[6],0,0.6),"backgroundColor":PlotKit.Base.baseColors()[6].lighterColorWithLevel(0.9)}; -MochiKit.Base.update(r,PlotKit.Base.officeBaseStyle); -return r; -}}); -PlotKit.Base.EXPORT=["baseColors","collapse","colorScheme","findPosX","findPosY","officeBaseStyle","officeBlue","officeRed","officeGreen","officePurple","officeCyan","officeOrange","officeBlack","roundInterval","uniq","isFuncLike","excanvasSupported"]; +var _27=MochiKit.Color.Color.fromHexString; +return [_27("#476fb2"),_27("#be2c2b"),_27("#85b730"),_27("#734a99"),_27("#26a1c5"),_27("#fb8707"),_27("#000000")]; +}; +PlotKit.Base.EXPORT=["baseColors","collapse","findPosX","findPosY","uniq","isFuncLike","excanvasSupported"]; PlotKit.Base.EXPORT_OK=[]; PlotKit.Base.__new__=function(){ var m=MochiKit.Base; @@ -7169,10 +4073,10 @@ PlotKit.Layout.toString=function(){ return this.__repr__(); }; PlotKit.Layout.valid_styles=["bar","line","pie","point"]; -PlotKit.Layout=function(_42,_43){ +PlotKit.Layout=function(_28,_29){ this.options={"barWidthFillFraction":0.75,"barOrientation":"vertical","xOriginIsZero":true,"yOriginIsZero":true,"xAxis":null,"yAxis":null,"xTicks":null,"yTicks":null,"xNumberOfTicks":10,"yNumberOfTicks":5,"xTickPrecision":1,"yTickPrecision":1,"pieRadius":0.4}; -this.style=_42; -MochiKit.Base.update(this.options,_43?_43:{}); +this.style=_28; +MochiKit.Base.update(this.options,_29?_29:{}); if(!MochiKit.Base.isUndefinedOrNull(this.options.xAxis)){ this.minxval=this.options.xAxis[0]; this.maxxval=this.options.xAxis[1]; @@ -7202,153 +4106,48 @@ this.xrange=1; this.yrange=1; this.hitTestCache={x2maxy:null}; }; -PlotKit.Layout.prototype.addDataset=function(_44,_45){ -this.datasets[_44]=_45; -}; -PlotKit.Layout.prototype.removeDataset=function(_46,_47){ -delete this.datasets[_46]; +PlotKit.Layout.prototype.addDataset=function(_30,_31){ +this.datasets[_30]=_31; }; -PlotKit.Layout.prototype.addDatasetFromTable=function(_48,_49,_50,_51,_52){ -var _53=MochiKit.Base.isUndefinedOrNull; -var _54=MochiKit.DOM.scrapeText; -var _55=MochiKit.Format.strip; -if(_53(_50)){ -_50=0; -} -if(_53(_51)){ -_51=1; -} -if(_53(_52)){ -_52=-1; -} -var _56=_49.tBodies[0].rows; -var _57=new Array(); -var _58=new Array(); -if(!_53(_56)){ -for(var i=0;i<_56.length;i++){ -_57.push([parseFloat(_55(_54(_56[i].cells[_50]))),parseFloat(_55(_54(_56[i].cells[_51])))]); -if(_52>=0){ -_58.push({v:parseFloat(_55(_54(_56[i].cells[_50]))),label:_55(_54(_56[i].cells[_52]))}); -} -} -this.addDataset(_48,_57); -if(_52>=0){ -this.options.xTicks=_58; -} -return true; -} -return false; +PlotKit.Layout.prototype.removeDataset=function(_32,_33){ +delete this.datasets[_32]; }; PlotKit.Layout.prototype.evaluate=function(){ this._evaluateLimits(); this._evaluateScales(); -if(this.style=="bar"){ -if(this.options.barOrientation=="horizontal"){ -this._evaluateHorizBarCharts(); -}else{ -this._evaluateBarCharts(); -} -this._evaluateBarTicks(); -}else{ if(this.style=="line"){ this._evaluateLineCharts(); this._evaluateLineTicks(); -}else{ -if(this.style=="pie"){ -this._evaluatePieCharts(); -this._evaluatePieTicks(); -} -} -} -}; -PlotKit.Layout.prototype.hitTest=function(x,y){ -var f=MochiKit.Format.twoDigitFloat; -if((this.style=="bar")&&this.bars&&(this.bars.length>0)){ -for(var i=0;i=bar.x)&&(x<=bar.x+bar.w)&&(y>=bar.y)&&(y-bar.y<=bar.h)){ -return bar; -} -} -}else{ -if(this.style=="line"){ -if(this.hitTestCache.x2maxy==null){ -this._regenerateHitTestCache(); -} -var _62=x/this.xscale; -var _63=this.hitTestCache.xvalues; -var _64=null; -var _65=null; -for(var i=1;i<_63.length;i++){ -if(_63[i]>_62){ -_64=_63[i-1]; -_65=_63[i]; -break; } -} -if((_64!=null)){ -var _66=this.hitTestCache.x2maxy[_64]; -var _67=this.hitTestCache.x2maxy[_65]; -var _68=(1-y)/this.yscale; -var _69=(_67-_66)/(_65-_64); -var _70=_66+_69*(_62-_64); -if(_70>=_68){ -var obj={xval:_62,yval:_68,xafter:_65,yafter:_67,xbefore:_64,ybefore:_66,yprojected:_70}; -return obj; -} -} -}else{ -if(this.style=="pie"){ -var _71=Math.sqrt((y-0.5)*(y-0.5)+(x-0.5)*(x-0.5)); -if(_71>this.options.pieRadius){ -return null; -} -var _72=Math.atan2(y-0.5,x-0.5)-Math.PI/2; -for(var i=0;i=_72){ -return _73; -} -} -} -} -} -return null; -}; -PlotKit.Layout.prototype.rectForX=function(x){ -return null; -}; -PlotKit.Layout.prototype.angleRangeForX=function(x){ -return null; }; PlotKit.Layout.prototype._evaluateLimits=function(){ var map=PlotKit.Base.map; -var _75=PlotKit.Base.items; -var _76=MochiKit.Base.itemgetter; -var _77=PlotKit.Base.collapse; -var _78=MochiKit.Base.listMin; -var _79=MochiKit.Base.listMax; -var _80=MochiKit.Base.isUndefinedOrNull; -var all=_77(map(_76(1),_75(this.datasets))); -if(_80(this.options.xAxis)){ +var _35=PlotKit.Base.items; +var _36=MochiKit.Base.itemgetter; +var _37=PlotKit.Base.collapse; +var _38=MochiKit.Base.listMin; +var _39=MochiKit.Base.listMax; +var _40=MochiKit.Base.isUndefinedOrNull; +var all=_37(map(_36(1),_35(this.datasets))); +if(_40(this.options.xAxis)){ if(this.options.xOriginIsZero){ this.minxval=0; }else{ -this.minxval=_78(map(parseFloat,map(_76(0),all))); +this.minxval=_38(map(parseFloat,map(_36(0),all))); } -this.maxxval=_79(map(parseFloat,map(_76(0),all))); +this.maxxval=_39(map(parseFloat,map(_36(0),all))); }else{ this.minxval=this.options.xAxis[0]; this.maxxval=this.options.xAxis[1]; this.xscale=this.maxval-this.minxval; } -if(_80(this.options.yAxis)){ +if(_40(this.options.yAxis)){ if(this.options.yOriginIsZero){ this.minyval=0; }else{ -this.minyval=_78(map(parseFloat,map(_76(1),all))); +this.minyval=_38(map(parseFloat,map(_36(1),all))); } -this.maxyval=_79(map(parseFloat,map(_76(1),all))); +this.maxyval=_39(map(parseFloat,map(_36(1),all))); }else{ this.minyval=this.options.yAxis[0]; this.maxyval=this.options.yAxis[1]; @@ -7356,7 +4155,7 @@ this.yscale=this.maxyval-this.minyval; } }; PlotKit.Layout.prototype._evaluateScales=function(){ -var _82=MochiKit.Base.isUndefinedOrNull; +var _42=MochiKit.Base.isUndefinedOrNull; this.xrange=this.maxxval-this.minxval; if(this.xrange==0){ this.xscale=1; @@ -7370,194 +4169,76 @@ this.yscale=1; this.yscale=1/this.yrange; } }; -PlotKit.Layout.prototype._uniqueXValues=function(){ -var _83=PlotKit.Base.collapse; -var map=PlotKit.Base.map; -var _84=PlotKit.Base.uniq; -var _85=MochiKit.Base.itemgetter; -var _86=PlotKit.Base.items; -var _87=map(parseFloat,map(_85(0),_83(map(_85(1),_86(this.datasets))))); -_87.sort(MochiKit.Base.compare); -return _84(_87); -}; -PlotKit.Layout.prototype._evaluateBarCharts=function(){ -var _88=PlotKit.Base.items; -var _89=_88(this.datasets).length; -var _90=10000000; -var _91=this._uniqueXValues(); -for(var i=1;i<_91.length;i++){ -_90=Math.min(Math.abs(_91[i]-_91[i-1]),_90); -} -var _92=0; -var _93=0; -var _94=0; -if(_91.length==1){ -_90=1; -this.xscale=1; -this.minxval=_91[0]; -_92=1*this.options.barWidthFillFraction; -_93=_92/_89; -_94=(1-this.options.barWidthFillFraction)/2; -}else{ -if(this.xrange==1){ -this.xscale=0.5; -}else{ -if(this.xrange==2){ -this.xscale=1/3; -}else{ -this.xscale=(1-_90/this.xrange)/this.xrange; -} -} -_92=_90*this.xscale*this.options.barWidthFillFraction; -_93=_92/_89; -_94=_90*this.xscale*(1-this.options.barWidthFillFraction)/2; -} -this.minxdelta=_90; -this.bars=new Array(); -var i=0; -for(var _95 in this.datasets){ -var _96=this.datasets[_95]; -if(PlotKit.Base.isFuncLike(_96)){ -continue; -} -for(var j=0;j<_96.length;j++){ -var _98=_96[j]; -var _99={x:((parseFloat(_98[0])-this.minxval)*this.xscale)+(i*_93)+_94,y:1-((parseFloat(_98[1])-this.minyval)*this.yscale),w:_93,h:((parseFloat(_98[1])-this.minyval)*this.yscale),xval:parseFloat(_98[0]),yval:parseFloat(_98[1]),name:_95}; -if((_99.x>=0)&&(_99.x<=1)&&(_99.y>=0)&&(_99.y<=1)){ -this.bars.push(_99); -} -} -i++; -} -}; -PlotKit.Layout.prototype._evaluateHorizBarCharts=function(){ -var _100=PlotKit.Base.items; -var _101=_100(this.datasets).length; -var _102=10000000; -var _103=this._uniqueXValues(); -for(var i=1;i<_103.length;i++){ -_102=Math.min(Math.abs(_103[i]-_103[i-1]),_102); -} -var _104=0; -var _105=0; -var _106=0; -if(_103.length==1){ -_102=1; -this.xscale=1; -this.minxval=_103[0]; -_104=1*this.options.barWidthFillFraction; -_105=_104/_101; -_106=(1-this.options.barWidthFillFraction)/2; -}else{ -this.xscale=(1-_102/this.xrange)/this.xrange; -_104=_102*this.xscale*this.options.barWidthFillFraction; -_105=_104/_101; -_106=_102*this.xscale*(1-this.options.barWidthFillFraction)/2; -} -this.minxdelta=_102; -this.bars=new Array(); -var i=0; -for(var _107 in this.datasets){ -var _108=this.datasets[_107]; -if(PlotKit.Base.isFuncLike(_108)){ -continue; -} -for(var j=0;j<_108.length;j++){ -var item=_108[j]; -var rect={y:((parseFloat(item[0])-this.minxval)*this.xscale)+(i*_105)+_106,x:0,h:_105,w:((parseFloat(item[1])-this.minyval)*this.yscale),xval:parseFloat(item[0]),yval:parseFloat(item[1]),name:_107}; -if(rect.y<=0){ -rect.y=0; -} -if(rect.y>=1){ -rect.y=1; -} -if((rect.x>=0)&&(rect.x<=1)){ -this.bars.push(rect); -} -} -i++; -} +PlotKit.Layout.prototype._uniqueXValues=function(){ +var _43=PlotKit.Base.collapse; +var map=PlotKit.Base.map; +var _44=PlotKit.Base.uniq; +var _45=MochiKit.Base.itemgetter; +var _46=PlotKit.Base.items; +var _47=map(parseFloat,map(_45(0),_43(map(_45(1),_46(this.datasets))))); +_47.sort(MochiKit.Base.compare); +return _44(_47); }; PlotKit.Layout.prototype._evaluateLineCharts=function(){ -var _111=PlotKit.Base.items; -var _112=_111(this.datasets).length; +var _48=PlotKit.Base.items; +var _49=_48(this.datasets).length; this.points=new Array(); var i=0; -for(var _113 in this.datasets){ -var _114=this.datasets[_113]; -if(PlotKit.Base.isFuncLike(_114)){ +for(var _50 in this.datasets){ +var _51=this.datasets[_50]; +if(PlotKit.Base.isFuncLike(_51)){ continue; } -_114.sort(function(a,b){ +_51.sort(function(a,b){ return compare(parseFloat(a[0]),parseFloat(b[0])); }); -for(var j=0;j<_114.length;j++){ -var item=_114[j]; -var _117={x:((parseFloat(item[0])-this.minxval)*this.xscale),y:1-((parseFloat(item[1])-this.minyval)*this.yscale),xval:parseFloat(item[0]),yval:parseFloat(item[1]),name:_113}; -if(_117.y<=0){ -_117.y=0; +for(var j=0;j<_51.length;j++){ +var _55=_51[j]; +var _56={x:((parseFloat(_55[0])-this.minxval)*this.xscale),y:1-((parseFloat(_55[1])-this.minyval)*this.yscale),xval:parseFloat(_55[0]),yval:parseFloat(_55[1]),name:_50}; +if(_56.y<=0){ +_56.y=0; } -if(_117.y>=1){ -_117.y=1; +if(_56.y>=1){ +_56.y=1; } -if((_117.x>=0)&&(_117.x<=1)){ -this.points.push(_117); +if((_56.x>=0)&&(_56.x<=1)){ +this.points.push(_56); } } i++; } }; -PlotKit.Layout.prototype._evaluatePieCharts=function(){ -var _118=PlotKit.Base.items; -var sum=MochiKit.Iter.sum; -var _120=MochiKit.Base.itemgetter; -var _121=_118(this.datasets).length; -var _122=_118(this.datasets)[0][1]; -var _123=sum(map(_120(1),_122)); -this.slices=new Array(); -var _124=0; -for(var i=0;i<_122.length;i++){ -var _125=_122[i][1]/_123; -var _126=_124*Math.PI*2; -var _127=(_124+_125)*Math.PI*2; -var _128={fraction:_125,xval:_122[i][0],yval:_122[i][1],startAngle:_126,endAngle:_127}; -if(_122[i][1]!=0){ -this.slices.push(_128); -} -_124+=_125; -} -}; PlotKit.Layout.prototype._evaluateLineTicksForXAxis=function(){ -var _129=MochiKit.Base.isUndefinedOrNull; +var _57=MochiKit.Base.isUndefinedOrNull; if(this.options.xTicks){ this.xticks=new Array(); -var _130=function(tick){ -var _132=tick.label; -if(_129(_132)){ -_132=tick.v.toString(); +var _58=function(_59){ +var _60=_59.label; +if(_57(_60)){ +_60=_59.v.toString(); } -var pos=this.xscale*(tick.v-this.minxval); +var pos=this.xscale*(_59.v-this.minxval); if((pos>=0)&&(pos<=1)){ -this.xticks.push([pos,_132]); +this.xticks.push([pos,_60]); } }; -MochiKit.Iter.forEach(this.options.xTicks,bind(_130,this)); +MochiKit.Iter.forEach(this.options.xTicks,bind(_58,this)); }else{ if(this.options.xNumberOfTicks){ -var _134=this._uniqueXValues(); -var _135=this.xrange/this.options.xNumberOfTicks; -var _136=0; +var _62=this._uniqueXValues(); +var _63=this.xrange/this.options.xNumberOfTicks; +var _64=0; this.xticks=new Array(); -for(var i=0;i<=_134.length;i++){ -if((_134[i]-this.minxval)>=(_136*_135)){ -var pos=this.xscale*(_134[i]-this.minxval); +for(var i=0;i<=_62.length;i++){ +if((_62[i]-this.minxval)>=(_64*_63)){ +var pos=this.xscale*(_62[i]-this.minxval); if((pos>1)||(pos<0)){ continue; } -this.xticks.push([pos,_134[i]]); -_136++; +this.xticks.push([pos,_62[i]]); +_64++; } -if(_136>this.options.xNumberOfTicks){ +if(_64>this.options.xNumberOfTicks){ break; } } @@ -7565,111 +4246,26 @@ break; } }; PlotKit.Layout.prototype._evaluateLineTicksForYAxis=function(){ -var _137=MochiKit.Base.isUndefinedOrNull; +var _65=MochiKit.Base.isUndefinedOrNull; if(this.options.yTicks){ this.yticks=new Array(); -var _138=function(tick){ -var _139=tick.label; -if(_137(_139)){ -_139=tick.v.toString(); +var _66=function(_67){ +var _68=_67.label; +if(_65(_68)){ +_68=_67.v.toString(); } -var pos=1-(this.yscale*(tick.v-this.minyval)); +var pos=1-(this.yscale*(_67.v-this.minyval)); if((pos>=0)&&(pos<=1)){ -this.yticks.push([pos,_139]); +this.yticks.push([pos,_68]); } }; -MochiKit.Iter.forEach(this.options.yTicks,bind(_138,this)); -}else{ -if(this.options.yNumberOfTicks){ -this.yticks=new Array(); -var _140=PlotKit.Base.roundInterval; -var prec=this.options.yTickPrecision; -var _142=_140(this.yrange,this.options.yNumberOfTicks,prec); -for(var i=0;i<=this.options.yNumberOfTicks;i++){ -var yval=this.minyval+(i*_142); -var pos=1-((yval-this.minyval)*this.yscale); -if((pos>1)||(pos<0)){ -continue; -} -this.yticks.push([pos,MochiKit.Format.roundToFixed(yval,prec)]); -} -} +MochiKit.Iter.forEach(this.options.yTicks,bind(_66,this)); } }; PlotKit.Layout.prototype._evaluateLineTicks=function(){ this._evaluateLineTicksForXAxis(); this._evaluateLineTicksForYAxis(); }; -PlotKit.Layout.prototype._evaluateBarTicks=function(){ -this._evaluateLineTicks(); -var _144=function(tick){ -return [tick[0]+(this.minxdelta*this.xscale)/2,tick[1]]; -}; -this.xticks=MochiKit.Base.map(bind(_144,this),this.xticks); -if(this.options.barOrientation=="horizontal"){ -var _145=this.xticks; -this.xticks=this.yticks; -this.yticks=_145; -var _146=function(tick){ -return [1-tick[0],tick[1]]; -}; -this.xticks=MochiKit.Base.map(_146,this.xticks); -} -}; -PlotKit.Layout.prototype._evaluatePieTicks=function(){ -var _147=MochiKit.Base.isUndefinedOrNull; -var _148=MochiKit.Format.numberFormatter("#%"); -this.xticks=new Array(); -if(this.options.xTicks){ -var _149=new Array(); -for(var i=0;i0){ -this.__init__(_158,_159,_160); +this.__init__(_69,_70,_71); } }; -PlotKit.CanvasRenderer.prototype.__init__=function(_161,_162,_163){ -var _164=MochiKit.Base.isUndefinedOrNull; -var _165=MochiKit.Color.Color; -this.options={"drawBackground":true,"backgroundColor":_165.whiteColor(),"padding":{left:30,right:30,top:5,bottom:10},"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[0]),"strokeColor":_165.whiteColor(),"strokeColorTransform":"asStrokeColor","strokeWidth":0.5,"shouldFill":true,"shouldStroke":true,"drawXAxis":true,"drawYAxis":true,"axisLineColor":_165.blackColor(),"axisLineWidth":0.5,"axisTickSize":3,"axisLabelColor":_165.blackColor(),"axisLabelFont":"Arial","axisLabelFontSize":9,"axisLabelWidth":50,"pieRadius":0.4,"enableEvents":true}; -MochiKit.Base.update(this.options,_163?_163:{}); -this.layout=_162; -this.element=MochiKit.DOM.getElement(_161); +PlotKit.CanvasRenderer.prototype.__init__=function(_72,_73,_74){ +var _75=MochiKit.Base.isUndefinedOrNull; +var _76=MochiKit.Color.Color; +this.options={"drawBackground":true,"backgroundColor":_76.whiteColor(),"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[0]),"strokeColor":_76.whiteColor(),"strokeColorTransform":"asStrokeColor","strokeWidth":0.5,"shouldFill":true,"shouldStroke":true,"drawXAxis":true,"drawYAxis":true,"axisLineColor":_76.blackColor(),"axisLineWidth":0.5,"axisTickSize":3,"axisLabelColor":_76.blackColor(),"axisLabelFont":"Arial","axisLabelFontSize":9,"axisLabelWidth":50,"pieRadius":0.4,"enableEvents":true}; +MochiKit.Base.update(this.options,_74?_74:{}); +this.layout=_73; +this.element=MochiKit.DOM.getElement(_72); this.container=this.element.parentNode; this.isIE=PlotKit.Base.excanvasSupported(); -if(this.isIE&&!_164(G_vmlCanvasManager)){ +if(this.isIE&&!_75(G_vmlCanvasManager)){ this.IEDelay=0.5; this.maxTries=5; this.renderDelay=null; @@ -7723,19 +4319,21 @@ this.element=G_vmlCanvasManager.initElement(this.element); } this.height=this.element.height; this.width=this.element.width; -if(_164(this.element)){ +if(_75(this.element)){ throw "CanvasRenderer() - passed canvas is not found"; } if(!this.isIE&&!(PlotKit.CanvasRenderer.isSupported(this.element))){ throw "CanvasRenderer() - Canvas is not supported."; } -if(_164(this.container)||(this.container.nodeName.toLowerCase()!="div")){ +if(_75(this.container)||(this.container.nodeName.toLowerCase()!="div")){ throw "CanvasRenderer() - needs to be enclosed in
"; } this.xlabels=new Array(); this.ylabels=new Array(); this.isFirstRender=true; -this.area={x:this.options.padding.left,y:this.options.padding.top,w:this.width-this.options.padding.left-this.options.padding.right,h:this.height-this.options.padding.top-this.options.padding.bottom}; +this.area={x:this.options.yAxisLabelWidth+2*this.options.axisTickSize,y:0}; +this.area.w=this.width-this.area.x-this.options.rightGap; +this.area.h=this.height-this.options.axisLabelFontSize-2*this.options.axisTickSize; MochiKit.DOM.updateNodeAttributes(this.container,{"style":{"position":"relative","width":this.width+"px"}}); }; PlotKit.CanvasRenderer.prototype.render=function(){ @@ -7745,7 +4343,7 @@ if(this.renderDelay){ this.renderDelay.cancel(); this.renderDelay=null; } -var _166=this.element.getContext("2d"); +var _77=this.element.getContext("2d"); } catch(e){ this.isFirstRender=false; @@ -7759,160 +4357,56 @@ return; if(this.options.drawBackground){ this._renderBackground(); } -if(this.layout.style=="bar"){ -this._renderBarChart(); -this._renderBarAxis(); -}else{ -if(this.layout.style=="pie"){ -this._renderPieChart(); -this._renderPieAxis(); -}else{ if(this.layout.style=="line"){ this._renderLineChart(); this._renderLineAxis(); } -} -} -}; -PlotKit.CanvasRenderer.prototype._renderBarChartWrap=function(data,_168){ -var _169=this.element.getContext("2d"); -var _170=this.options.colorScheme.length; -var _171=this.options.colorScheme; -var _172=MochiKit.Base.keys(this.layout.datasets); -var _173=_172.length; -for(var i=0;i<_173;i++){ -var _174=_172[i]; -var _175=_171[i%_170]; -_169.save(); -_169.fillStyle=_175.toRGBString(); -if(this.options.strokeColor){ -_169.strokeStyle=this.options.strokeColor.toRGBString(); -}else{ -if(this.options.strokeColorTransform){ -_169.strokeStyle=_175[this.options.strokeColorTransform]().toRGBString(); -} -} -_169.lineWidth=this.options.strokeWidth; -var _176=function(obj){ -if(obj.name==_174){ -_168(_169,obj); -} -}; -MochiKit.Iter.forEach(data,bind(_176,this)); -_169.restore(); -} -}; -PlotKit.CanvasRenderer.prototype._renderBarChart=function(){ -var bind=MochiKit.Base.bind; -var _178=function(_179,bar){ -var x=this.area.w*bar.x+this.area.x; -var y=this.area.h*bar.y+this.area.y; -var w=this.area.w*bar.w; -var h=this.area.h*bar.h; -if((w<1)||(h<1)){ -return; -} -if(this.options.shouldFill){ -_179.fillRect(x,y,w,h); -} -if(this.options.shouldStroke){ -_179.strokeRect(x,y,w,h); -} -}; -this._renderBarChartWrap(this.layout.bars,bind(_178,this)); }; PlotKit.CanvasRenderer.prototype._renderLineChart=function(){ -var _182=this.element.getContext("2d"); -var _183=this.options.colorScheme.length; -var _184=this.options.colorScheme; -var _185=MochiKit.Base.keys(this.layout.datasets); -var _186=_185.length; -var bind=MochiKit.Base.bind; -var _187=MochiKit.Base.partial; -for(var i=0;i<_186;i++){ -var _188=_185[i]; -var _189=_184[i%_183]; -var _190=this.options.strokeColorTransform; -_182.save(); -_182.fillStyle=_189.toRGBString(); +var _78=this.element.getContext("2d"); +var _79=this.options.colorScheme.length; +var _80=this.options.colorScheme; +var _81=MochiKit.Base.keys(this.layout.datasets); +var _82=_81.length; +var _83=MochiKit.Base.bind; +var _84=MochiKit.Base.partial; +for(var i=0;i<_82;i++){ +var _85=_81[i]; +var _86=_80[i%_79]; +var _87=this.options.strokeColorTransform; +_78.save(); +_78.fillStyle=_86.toRGBString(); if(this.options.strokeColor){ -_182.strokeStyle=this.options.strokeColor.toRGBString(); +_78.strokeStyle=this.options.strokeColor.toRGBString(); }else{ if(this.options.strokeColorTransform){ -_182.strokeStyle=_189[_190]().toRGBString(); +_78.strokeStyle=_86[_87]().toRGBString(); } } -_182.lineWidth=this.options.strokeWidth; -var _191=function(ctx){ +_78.lineWidth=this.options.strokeWidth; +var _88=function(ctx){ ctx.beginPath(); ctx.moveTo(this.area.x,this.area.y+this.area.h); -var _193=function(ctx_,_195){ -if(_195.name==_188){ -ctx_.lineTo(this.area.w*_195.x+this.area.x,this.area.h*_195.y+this.area.y); +var _90=function(_91,_92){ +if(_92.name==_85){ +_91.lineTo(this.area.w*_92.x+this.area.x,this.area.h*_92.y+this.area.y); } }; -MochiKit.Iter.forEach(this.layout.points,_187(_193,ctx),this); +MochiKit.Iter.forEach(this.layout.points,_84(_90,ctx),this); ctx.lineTo(this.area.w+this.area.x,this.area.h+this.area.y); ctx.lineTo(this.area.x,this.area.y+this.area.h); ctx.closePath(); }; if(this.options.shouldFill){ -bind(_191,this)(_182); -_182.fill(); -} -if(this.options.shouldStroke){ -bind(_191,this)(_182); -_182.stroke(); -} -_182.restore(); -} -}; -PlotKit.CanvasRenderer.prototype._renderPieChart=function(){ -var _196=this.element.getContext("2d"); -var _197=this.options.colorScheme.length; -var _198=this.layout.slices; -var _199=this.area.x+this.area.w*0.5; -var _200=this.area.y+this.area.h*0.5; -var _201=Math.min(this.area.w*this.options.pieRadius,this.area.h*this.options.pieRadius); -if(this.isIE){ -_199=parseInt(_199); -_200=parseInt(_200); -_201=parseInt(_201); -} -for(var i=0;i<_198.length;i++){ -var _202=this.options.colorScheme[i%_197]; -_196.save(); -_196.fillStyle=_202.toRGBString(); -var _203=function(){ -_196.beginPath(); -_196.moveTo(_199,_200); -_196.arc(_199,_200,_201,_198[i].startAngle-Math.PI/2,_198[i].endAngle-Math.PI/2,false); -_196.lineTo(_199,_200); -_196.closePath(); -}; -if(Math.abs(_198[i].startAngle-_198[i].endAngle)>0.001){ -if(this.options.shouldFill){ -_203(); -_196.fill(); +_83(_88,this)(_78); +_78.fill(); } if(this.options.shouldStroke){ -_203(); -_196.lineWidth=this.options.strokeWidth; -if(this.options.strokeColor){ -_196.strokeStyle=this.options.strokeColor.toRGBString(); -}else{ -if(this.options.strokeColorTransform){ -_196.strokeStyle=_202[this.options.strokeColorTransform]().toRGBString(); -} +_83(_88,this)(_78); +_78.stroke(); } -_196.stroke(); +_78.restore(); } -} -_196.restore(); -} -}; -PlotKit.CanvasRenderer.prototype._renderBarAxis=function(){ -this._renderAxis(); }; PlotKit.CanvasRenderer.prototype._renderLineAxis=function(){ this._renderAxis(); @@ -7921,138 +4415,100 @@ PlotKit.CanvasRenderer.prototype._renderAxis=function(){ if(!this.options.drawXAxis&&!this.options.drawYAxis){ return; } -var _204=this.element.getContext("2d"); -var _205={"style":{"position":"absolute","fontSize":this.options.axisLabelFontSize+"px","zIndex":10,"color":this.options.axisLabelColor.toRGBString(),"width":this.options.axisLabelWidth+"px","overflow":"hidden"}}; -_204.save(); -_204.strokeStyle=this.options.axisLineColor.toRGBString(); -_204.lineWidth=this.options.axisLineWidth; +var _93=this.element.getContext("2d"); +var _94={"style":{"position":"absolute","fontSize":this.options.axisLabelFontSize+"px","zIndex":10,"color":this.options.axisLabelColor.toRGBString(),"width":this.options.axisLabelWidth+"px","overflow":"hidden"}}; +_93.save(); +_93.strokeStyle=this.options.axisLineColor.toRGBString(); +_93.lineWidth=this.options.axisLineWidth; if(this.options.drawYAxis){ if(this.layout.yticks){ -var _206=function(tick){ -if(typeof (tick)=="function"){ +var _95=function(_96){ +if(typeof (_96)=="function"){ return; } var x=this.area.x; -var y=this.area.y+tick[0]*this.area.h; -_204.beginPath(); -_204.moveTo(x,y); -_204.lineTo(x-this.options.axisTickSize,y); -_204.closePath(); -_204.stroke(); -var _207=DIV(_205,tick[1]); -_207.style.top=(y-this.options.axisLabelFontSize)+"px"; -_207.style.left=(x-this.options.padding.left-this.options.axisTickSize)+"px"; -_207.style.textAlign="right"; -_207.style.width=(this.options.padding.left-this.options.axisTickSize*2)+"px"; -MochiKit.DOM.appendChildNodes(this.container,_207); -this.ylabels.push(_207); -}; -MochiKit.Iter.forEach(this.layout.yticks,bind(_206,this)); -} -_204.beginPath(); -_204.moveTo(this.area.x,this.area.y); -_204.lineTo(this.area.x,this.area.y+this.area.h); -_204.closePath(); -_204.stroke(); +var y=this.area.y+_96[0]*this.area.h; +_93.beginPath(); +_93.moveTo(x,y); +_93.lineTo(x-this.options.axisTickSize,y); +_93.closePath(); +_93.stroke(); +var _98=DIV(_94,_96[1]); +var top=(y-this.options.axisLabelFontSize/2); +if(top<0){ +top=0; +} +if(top+this.options.axisLabelFontSize+3>this.height){ +_98.style.bottom="0px"; +}else{ +_98.style.top=top+"px"; +} +_98.style.left="0px"; +_98.style.textAlign="right"; +_98.style.width=this.options.yAxisLabelWidth+"px"; +MochiKit.DOM.appendChildNodes(this.container,_98); +this.ylabels.push(_98); +}; +MochiKit.Iter.forEach(this.layout.yticks,bind(_95,this)); +var _100=this.ylabels[0]; +var _101=this.options.axisLabelFontSize; +var _102=parseInt(_100.style.top)+_101; +if(_102>this.height-_101){ +_100.style.top=(parseInt(_100.style.top)-_101/2)+"px"; +} +} +_93.beginPath(); +_93.moveTo(this.area.x,this.area.y); +_93.lineTo(this.area.x,this.area.y+this.area.h); +_93.closePath(); +_93.stroke(); } if(this.options.drawXAxis){ if(this.layout.xticks){ -var _206=function(tick){ +var _95=function(tick){ if(typeof (dataset)=="function"){ return; } var x=this.area.x+tick[0]*this.area.w; var y=this.area.y+this.area.h; -_204.beginPath(); -_204.moveTo(x,y); -_204.lineTo(x,y+this.options.axisTickSize); -_204.closePath(); -_204.stroke(); -var _208=DIV(_205,tick[1]); -_208.style.top=(y+this.options.axisTickSize)+"px"; -_208.style.left=(x-this.options.axisLabelWidth/2)+"px"; -_208.style.textAlign="center"; -_208.style.width=this.options.axisLabelWidth+"px"; -MochiKit.DOM.appendChildNodes(this.container,_208); -this.xlabels.push(_208); -}; -MochiKit.Iter.forEach(this.layout.xticks,bind(_206,this)); -} -_204.beginPath(); -_204.moveTo(this.area.x,this.area.y+this.area.h); -_204.lineTo(this.area.x+this.area.w,this.area.y+this.area.h); -_204.closePath(); -_204.stroke(); -} -_204.restore(); -}; -PlotKit.CanvasRenderer.prototype._renderPieAxis=function(){ -if(!this.options.drawXAxis){ -return; -} -if(this.layout.xticks){ -var _209=new Array(); -for(var i=0;iMath.PI*2){ -_216=_216-Math.PI*2; -}else{ -if(_216<0){ -_216=_216+Math.PI*2; -} -} -var _217=_210+Math.sin(_216)*(_212+10); -var _218=_211-Math.cos(_216)*(_212+10); -var _219={"position":"absolute","zIndex":11,"width":_213+"px","fontSize":this.options.axisLabelFontSize+"px","overflow":"hidden","color":this.options.axisLabelColor.toHexString()}; -if(_216<=Math.PI*0.5){ -_219["textAlign"]="left"; -_219["verticalAlign"]="top"; -_219["left"]=_217+"px"; -_219["top"]=(_218-this.options.axisLabelFontSize)+"px"; -}else{ -if((_216>Math.PI*0.5)&&(_216<=Math.PI)){ -_219["textAlign"]="left"; -_219["verticalAlign"]="bottom"; -_219["left"]=_217+"px"; -_219["top"]=_218+"px"; -}else{ -if((_216>Math.PI)&&(_216<=Math.PI*1.5)){ -_219["textAlign"]="right"; -_219["verticalAlign"]="bottom"; -_219["left"]=(_217-_213)+"px"; -_219["top"]=_218+"px"; -}else{ -_219["textAlign"]="right"; -_219["verticalAlign"]="bottom"; -_219["left"]=(_217-_213)+"px"; -_219["top"]=(_218-this.options.axisLabelFontSize)+"px"; -} -} -} -var _220=DIV({"style":_219},this.layout.xticks[i][1]); -this.xlabels.push(_220); -MochiKit.DOM.appendChildNodes(this.container,_220); -} -} +_93.beginPath(); +_93.moveTo(x,y); +_93.lineTo(x,y+this.options.axisTickSize); +_93.closePath(); +_93.stroke(); +var _104=DIV(_94,tick[1]); +_104.style.textAlign="center"; +_104.style.bottom="0px"; +var left=(x-this.options.axisLabelWidth/2); +if(left+this.options.axisLabelWidth>this.width){ +left=this.width-this.options.xAxisLabelWidth; +_104.style.textAlign="right"; +} +if(left<0){ +left=0; +_104.style.textAlign="left"; +} +_104.style.left=left+"px"; +_104.style.width=this.options.xAxisLabelWidth+"px"; +MochiKit.DOM.appendChildNodes(this.container,_104); +this.xlabels.push(_104); +}; +MochiKit.Iter.forEach(this.layout.xticks,bind(_95,this)); +} +_93.beginPath(); +_93.moveTo(this.area.x,this.area.y+this.area.h); +_93.lineTo(this.area.x+this.area.w,this.area.y+this.area.h); +_93.closePath(); +_93.stroke(); +} +_93.restore(); }; PlotKit.CanvasRenderer.prototype._renderBackground=function(){ -var _221=this.element.getContext("2d"); -_221.save(); -_221.fillStyle=this.options.backgroundColor.toRGBString(); -_221.fillRect(0,0,this.width,this.height); -_221.restore(); +var _106=this.element.getContext("2d"); +_106.save(); +_106.fillStyle=this.options.backgroundColor.toRGBString(); +_106.fillRect(0,0,this.width,this.height); +_106.restore(); }; PlotKit.CanvasRenderer.prototype.clear=function(){ if(this.isIE){ @@ -8061,7 +4517,7 @@ if(this.clearDelay){ this.clearDelay.cancel(); this.clearDelay=null; } -var _222=this.element.getContext("2d"); +var _107=this.element.getContext("2d"); } catch(e){ this.isFirstRender=false; @@ -8070,88 +4526,88 @@ this.clearDelay.addCallback(bind(this.clear,this)); return; } } -var _222=this.element.getContext("2d"); -_222.clearRect(0,0,this.width,this.height); +var _107=this.element.getContext("2d"); +_107.clearRect(0,0,this.width,this.height); MochiKit.Iter.forEach(this.xlabels,MochiKit.DOM.removeElement); MochiKit.Iter.forEach(this.ylabels,MochiKit.DOM.removeElement); this.xlabels=new Array(); this.ylabels=new Array(); }; PlotKit.CanvasRenderer.prototype._initialiseEvents=function(){ -var _223=MochiKit.Signal.connect; +var _108=MochiKit.Signal.connect; var bind=MochiKit.Base.bind; -_223(this.element,"onclick",bind(this.onclick,this)); +_108(this.element,"onclick",bind(this.onclick,this)); }; PlotKit.CanvasRenderer.prototype._resolveObject=function(e){ var x=(e.mouse().page.x-PlotKit.Base.findPosX(this.element)-this.area.x)/this.area.w; var y=(e.mouse().page.y-PlotKit.Base.findPosY(this.element)-this.area.y)/this.area.h; -var _225=this.layout.hitTest(x,y); -if(_225){ -return _225; +var _111=this.layout.hitTest(x,y); +if(_111){ +return _111; } return null; }; -PlotKit.CanvasRenderer.prototype._createEventObject=function(_226,e){ -if(_226==null){ +PlotKit.CanvasRenderer.prototype._createEventObject=function(_112,e){ +if(_112==null){ return null; } -e.chart=_226; +e.chart=_112; return e; }; PlotKit.CanvasRenderer.prototype.onclick=function(e){ -var _227=this._resolveObject(e); -var _228=this._createEventObject(_227,e); -if(_228!=null){ -MochiKit.Signal.signal(this,"onclick",_228); +var _113=this._resolveObject(e); +var _114=this._createEventObject(_113,e); +if(_114!=null){ +MochiKit.Signal.signal(this,"onclick",_114); } }; PlotKit.CanvasRenderer.prototype.onmouseover=function(e){ -var _229=this._resolveObject(e); -var _230=this._createEventObject(_229,e); -if(_230!=null){ -signal(this,"onmouseover",_230); +var _115=this._resolveObject(e); +var _116=this._createEventObject(_115,e); +if(_116!=null){ +signal(this,"onmouseover",_116); } }; PlotKit.CanvasRenderer.prototype.onmouseout=function(e){ -var _231=this._resolveObject(e); -var _232=this._createEventObject(_231,e); -if(_232==null){ +var _117=this._resolveObject(e); +var _118=this._createEventObject(_117,e); +if(_118==null){ signal(this,"onmouseout",e); }else{ -signal(this,"onmouseout",_232); +signal(this,"onmouseout",_118); } }; PlotKit.CanvasRenderer.prototype.onmousemove=function(e){ -var _233=this._resolveObject(e); -var _234=this._createEventObject(_233,e); -if((_233==null)&&(this.event_isinside==null)){ +var _119=this._resolveObject(e); +var _120=this._createEventObject(_119,e); +if((_119==null)&&(this.event_isinside==null)){ return; } -if((_233!=null)&&(this.event_isinside==null)){ -signal(this,"onmouseover",_234); +if((_119!=null)&&(this.event_isinside==null)){ +signal(this,"onmouseover",_120); } -if((_233==null)&&(this.event_isinside!=null)){ -signal(this,"onmouseout",_234); +if((_119==null)&&(this.event_isinside!=null)){ +signal(this,"onmouseout",_120); } -if((_233!=null)&&(this.event_isinside!=null)){ -signal(this,"onmousemove",_234); +if((_119!=null)&&(this.event_isinside!=null)){ +signal(this,"onmousemove",_120); } -this.event_isinside=_233; +this.event_isinside=_119; }; -PlotKit.CanvasRenderer.isSupported=function(_235){ -var _236=null; +PlotKit.CanvasRenderer.isSupported=function(_121){ +var _122=null; try{ -if(MochiKit.Base.isUndefinedOrNull(_235)){ -_236=MochiKit.DOM.CANVAS({}); +if(MochiKit.Base.isUndefinedOrNull(_121)){ +_122=MochiKit.DOM.CANVAS({}); }else{ -_236=MochiKit.DOM.getElement(_235); +_122=MochiKit.DOM.getElement(_121); } -var _237=_236.getContext("2d"); +var _123=_122.getContext("2d"); } catch(e){ var ie=navigator.appVersion.match(/MSIE (\d\.\d)/); -var _239=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); -if((!ie)||(ie[1]<6)||(_239)){ +var _125=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); +if((!ie)||(ie[1]<6)||(_125)){ return false; } return true; @@ -8169,2207 +4625,1194 @@ this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_ }; PlotKit.Canvas.__new__(); MochiKit.Base._exportSymbols(this,PlotKit.Canvas); -try{ -if(typeof (PlotKit.Layout)=="undefined"){ -throw ""; + + +Date.ext={};Date.ext.util={};Date.ext.util.xPad=function(x,pad,r){if(typeof (r)=="undefined"){r=10}for(;parseInt(x,10)1;r/=10){x=pad.toString()+x}return x.toString()};Date.prototype.locale="en-GB";if(document.getElementsByTagName("html")&&document.getElementsByTagName("html")[0].lang){Date.prototype.locale=document.getElementsByTagName("html")[0].lang}Date.ext.locales={};Date.ext.locales.en={a:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],A:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],b:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],B:["January","February","March","April","May","June","July","August","September","October","November","December"],c:"%a %d %b %Y %T %Z",p:["AM","PM"],P:["am","pm"],x:"%d/%m/%y",X:"%T"};Date.ext.locales["en-US"]=Date.ext.locales.en;Date.ext.locales["en-US"].c="%a %d %b %Y %r %Z";Date.ext.locales["en-US"].x="%D";Date.ext.locales["en-US"].X="%r";Date.ext.locales["en-GB"]=Date.ext.locales.en;Date.ext.locales["en-AU"]=Date.ext.locales["en-GB"];Date.ext.formats={a:function(d){return Date.ext.locales[d.locale].a[d.getDay()]},A:function(d){return Date.ext.locales[d.locale].A[d.getDay()]},b:function(d){return Date.ext.locales[d.locale].b[d.getMonth()]},B:function(d){return Date.ext.locales[d.locale].B[d.getMonth()]},c:"toLocaleString",C:function(d){return Date.ext.util.xPad(parseInt(d.getFullYear()/100,10),0)},d:["getDate","0"],e:["getDate"," "],g:function(d){return Date.ext.util.xPad(parseInt(Date.ext.util.G(d)/100,10),0)},G:function(d){var y=d.getFullYear();var V=parseInt(Date.ext.formats.V(d),10);var W=parseInt(Date.ext.formats.W(d),10);if(W>V){y++}else{if(W===0&&V>=52){y--}}return y},H:["getHours","0"],I:function(d){var I=d.getHours()%12;return Date.ext.util.xPad(I===0?12:I,0)},j:function(d){var ms=d-new Date(""+d.getFullYear()+"/1/1 GMT");ms+=d.getTimezoneOffset()*60000;var doy=parseInt(ms/60000/60/24,10)+1;return Date.ext.util.xPad(doy,0,100)},m:function(d){return Date.ext.util.xPad(d.getMonth()+1,0)},M:["getMinutes","0"],p:function(d){return Date.ext.locales[d.locale].p[d.getHours()>=12?1:0]},P:function(d){return Date.ext.locales[d.locale].P[d.getHours()>=12?1:0]},S:["getSeconds","0"],u:function(d){var dow=d.getDay();return dow===0?7:dow},U:function(d){var doy=parseInt(Date.ext.formats.j(d),10);var rdow=6-d.getDay();var woy=parseInt((doy+rdow)/7,10);return Date.ext.util.xPad(woy,0)},V:function(d){var woy=parseInt(Date.ext.formats.W(d),10);var dow1_1=(new Date(""+d.getFullYear()+"/1/1")).getDay();var idow=woy+(dow1_1>4||dow1_1<=1?0:1);if(idow==53&&(new Date(""+d.getFullYear()+"/12/31")).getDay()<4){idow=1}else{if(idow===0){idow=Date.ext.formats.V(new Date(""+(d.getFullYear()-1)+"/12/31"))}}return Date.ext.util.xPad(idow,0)},w:"getDay",W:function(d){var doy=parseInt(Date.ext.formats.j(d),10);var rdow=7-Date.ext.formats.u(d);var woy=parseInt((doy+rdow)/7,10);return Date.ext.util.xPad(woy,0,10)},y:function(d){return Date.ext.util.xPad(d.getFullYear()%100,0)},Y:"getFullYear",z:function(d){var o=d.getTimezoneOffset();var H=Date.ext.util.xPad(parseInt(Math.abs(o/60),10),0);var M=Date.ext.util.xPad(o%60,0);return(o>0?"-":"+")+H+M},Z:function(d){return d.toString().replace(/^.*\(([^)]+)\)$/,"$1")},"%":function(d){return"%"}};Date.ext.aggregates={c:"locale",D:"%m/%d/%y",h:"%b",n:"\n",r:"%I:%M:%S %p",R:"%H:%M",t:"\t",T:"%H:%M:%S",x:"locale",X:"locale"};Date.ext.aggregates.z=Date.ext.formats.z(new Date());Date.ext.aggregates.Z=Date.ext.formats.Z(new Date());Date.ext.unsupported={};Date.prototype.strftime=function(fmt){if(!(this.locale in Date.ext.locales)){if(this.locale.replace(/-[a-zA-Z]+$/,"") in Date.ext.locales){this.locale=this.locale.replace(/-[a-zA-Z]+$/,"")}else{this.locale="en-GB"}}var d=this;while(fmt.match(/%[cDhnrRtTxXzZ]/)){fmt=fmt.replace(/%([cDhnrRtTxXzZ])/g,function(m0,m1){var f=Date.ext.aggregates[m1];return(f=="locale"?Date.ext.locales[d.locale][m1]:f)})}var str=fmt.replace(/%([aAbBCdegGHIjmMpPSuUVwWyY%])/g,function(m0,m1){var f=Date.ext.formats[m1];if(typeof (f)=="string"){return d[f]()}else{if(typeof (f)=="function"){return f.call(d,d)}else{if(typeof (f)=="object"&&typeof (f[0])=="string"){return Date.ext.util.xPad(d[f[0]](),f[1])}else{return m1}}}});d=null;return str}; +DygraphLayout=function(_1){ +PlotKit.Layout.call(this,"line",_1); +}; +DygraphLayout.prototype=new PlotKit.Layout(); +DygraphLayout.prototype.evaluateWithError=function(){ +this.evaluate(); +if(!this.options.errorBars){ +return; +} +var i=0; +for(var _3 in this.datasets){ +var j=0; +var _5=this.datasets[_3]; +if(PlotKit.Base.isFuncLike(_5)){ +continue; } +for(var j=0;j<_5.length;j++,i++){ +var _6=_5[j]; +var xv=parseFloat(_6[0]); +var yv=parseFloat(_6[1]); +if(xv==this.points[i].xval&&yv==this.points[i].yval){ +this.points[i].errorMinus=parseFloat(_6[2]); +this.points[i].errorPlus=parseFloat(_6[3]); } -catch(e){ -throw "PlotKit depends on MochiKit.{Base,Color,DOM,Format} and PlotKit.Layout"; } -PlotKit.SVGRenderer=function(_240,_241,_242){ -if(arguments.length>0){ -this.__init__(_240,_241,_242); } }; -PlotKit.SVGRenderer.NAME="PlotKit.SVGRenderer"; -PlotKit.SVGRenderer.VERSION=PlotKit.VERSION; -PlotKit.SVGRenderer.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -PlotKit.SVGRenderer.toString=function(){ -return this.__repr__(); +DygraphLayout.prototype.removeAllDatasets=function(){ +delete this.datasets; +this.datasets=new Array(); }; -PlotKit.SVGRenderer.SVGNS="http://www.w3.org/2000/svg"; -PlotKit.SVGRenderer.prototype.__init__=function(_243,_244,_245){ -var _246=MochiKit.Base.isUndefinedOrNull; -this.options={"drawBackground":true,"backgroundColor":Color.whiteColor(),"padding":{left:30,right:30,top:5,bottom:10},"colorScheme":PlotKit.Base.palette(PlotKit.Base.baseColors()[1]),"strokeColor":Color.whiteColor(),"strokeColorTransform":"asStrokeColor","strokeWidth":0.5,"shouldFill":true,"shouldStroke":true,"drawXAxis":true,"drawYAxis":true,"axisLineColor":Color.blackColor(),"axisLineWidth":0.5,"axisTickSize":3,"axisLabelColor":Color.blackColor(),"axisLabelFont":"Arial","axisLabelFontSize":9,"axisLabelWidth":50,"axisLabelUseDiv":true,"pieRadius":0.4,"enableEvents":true}; -MochiKit.Base.update(this.options,_245?_245:{}); -this.layout=_244; -this.element=MochiKit.DOM.getElement(_243); -this.container=this.element.parentNode; -this.height=parseInt(this.element.getAttribute("height")); -this.width=parseInt(this.element.getAttribute("width")); -this.document=document; -this.root=this.element; -try{ -this.document=this.element.getSVGDocument(); -this.root=_246(this.document.documentElement)?this.element:this.document.documentElement; +DygraphLayout.prototype.updateOptions=function(_9){ +MochiKit.Base.update(this.options,_9?_9:{}); +}; +DygraphCanvasRenderer=function(_10,_11,_12){ +PlotKit.CanvasRenderer.call(this,_10,_11,_12); +this.options.shouldFill=false; +this.options.shouldStroke=true; +this.options.drawYGrid=true; +this.options.drawXGrid=true; +this.options.gridLineColor=MochiKit.Color.Color.grayColor(); +MochiKit.Base.update(this.options,_12); +this.options.drawBackground=false; +}; +DygraphCanvasRenderer.prototype=new PlotKit.CanvasRenderer(); +DygraphCanvasRenderer.prototype.render=function(){ +var ctx=this.element.getContext("2d"); +if(this.options.drawYGrid){ +var _14=this.layout.yticks; +ctx.save(); +ctx.strokeStyle=this.options.gridLineColor.toRGBString(); +ctx.lineWidth=this.options.axisLineWidth; +for(var i=0;i<_14.length;i++){ +var x=this.area.x; +var y=this.area.y+_14[i][0]*this.area.h; +ctx.beginPath(); +ctx.moveTo(x,y); +ctx.lineTo(x+this.area.w,y); +ctx.closePath(); +ctx.stroke(); } -catch(e){ } -this.element.style.zIndex=1; -if(_246(this.element)){ -throw "SVGRenderer() - passed SVG object is not found"; +if(this.options.drawXGrid){ +var _14=this.layout.xticks; +ctx.save(); +ctx.strokeStyle=this.options.gridLineColor.toRGBString(); +ctx.lineWidth=this.options.axisLineWidth; +for(var i=0;i<_14.length;i++){ +var x=this.area.x+_14[i][0]*this.area.w; +var y=this.area.y+this.area.h; +ctx.beginPath(); +ctx.moveTo(x,y); +ctx.lineTo(x,this.area.y); +ctx.closePath(); +ctx.stroke(); +} } -if(_246(this.container)||this.container.nodeName.toLowerCase()!="div"){ -throw "SVGRenderer() - No DIV's around the SVG."; +this._renderLineChart(); +this._renderLineAxis(); +}; +DygraphCanvasRenderer.prototype._renderLineChart=function(){ +var _17=this.element.getContext("2d"); +var _18=this.options.colorScheme.length; +var _19=this.options.colorScheme; +var _20=MochiKit.Base.keys(this.layout.datasets); +var _21=this.layout.options.errorBars; +var _22=_20.length; +var _23=MochiKit.Base.bind; +var _24=MochiKit.Base.partial; +var _25=function(_26){ +_26.canvasx=this.area.w*_26.x+this.area.x; +_26.canvasy=this.area.h*_26.y+this.area.y; +}; +MochiKit.Iter.forEach(this.layout.points,_25,this); +var _27=function(ctx){ +for(var i=0;i<_22;i++){ +var _28=_20[i]; +var _29=_19[i%_18]; +var _30=this.options.strokeColorTransform; +_17.save(); +_17.strokeStyle=_29.toRGBString(); +_17.lineWidth=this.options.strokeWidth; +ctx.beginPath(); +var _31=this.layout.points[0]; +var _32=true; +var _33=function(_34,_31){ +if(_31.name==_28){ +if(_32){ +_34.moveTo(_31.canvasx,_31.canvasy); +}else{ +_34.lineTo(_31.canvasx,_31.canvasy); +} +_32=false; +} +}; +MochiKit.Iter.forEach(this.layout.points,_24(_33,ctx),this); +ctx.stroke(); +} +}; +var _35=function(ctx){ +for(var i=0;i<_22;i++){ +var _36=_20[i]; +var _37=_19[i%_18]; +var _38=this.options.strokeColorTransform; +_17.save(); +_17.strokeStyle=_37.toRGBString(); +_17.lineWidth=this.options.strokeWidth; +var _39=-1; +var _40=[-1,-1]; +var _41=0; +var _42=this.layout.yscale; +var _43=function(_44,_45){ +_41++; +if(_45.name==_36){ +var _46=[_45.y-_45.errorPlus*_42,_45.y+_45.errorMinus*_42]; +_46[0]=this.area.h*_46[0]+this.area.y; +_46[1]=this.area.h*_46[1]+this.area.y; +if(_39>=0){ +_44.moveTo(_39,_40[0]); +_44.lineTo(_45.canvasx,_46[0]); +_44.lineTo(_45.canvasx,_46[1]); +_44.lineTo(_39,_40[1]); +_44.closePath(); +} +_40[0]=_46[0]; +_40[1]=_46[1]; +_39=_45.canvasx; +} +}; +var _47=_37.colorWithAlpha(0.15); +ctx.fillStyle=_47.toRGBString(); +ctx.beginPath(); +MochiKit.Iter.forEach(this.layout.points,_24(_43,ctx),this); +ctx.fill(); } -this.xlabels=new Array(); -this.ylabels=new Array(); -this.defs=this.createSVGElement("defs"); -this.area={x:this.options.padding.left,y:this.options.padding.top,w:this.width-this.options.padding.left-this.options.padding.right,h:this.height-this.options.padding.top-this.options.padding.bottom}; -MochiKit.DOM.updateNodeAttributes(this.container,{"style":{"position":"relative","width":this.width+"px"}}); }; -PlotKit.SVGRenderer.prototype.render=function(){ -if(this.options.drawBackground){ -this._renderBackground(); +if(_21){ +_23(_35,this)(_17); } -if(this.layout.style=="bar"){ -this._renderBarChart(); -this._renderBarAxis(); +_23(_27,this)(_17); +_17.restore(); +}; +Dygraph=function(div,_49,_50){ +if(arguments.length>0){ +if(arguments.length==4){ +this.warn("Using deprecated four-argument dygraph constructor"); +this.__old_init__(div,_49,arguments[2],arguments[3]); }else{ -if(this.layout.style=="pie"){ -this._renderPieChart(); -this._renderPieAxis(); +this.__init__(div,_49,_50); +} +} +}; +Dygraph.NAME="Dygraph"; +Dygraph.VERSION="1.2"; +Dygraph.__repr__=function(){ +return "["+this.NAME+" "+this.VERSION+"]"; +}; +Dygraph.toString=function(){ +return this.__repr__(); +}; +Dygraph.DEFAULT_ROLL_PERIOD=1; +Dygraph.DEFAULT_WIDTH=480; +Dygraph.DEFAULT_HEIGHT=320; +Dygraph.AXIS_LINE_WIDTH=0.3; +Dygraph.DEFAULT_ATTRS={highlightCircleSize:3,pixelsPerXLabel:60,pixelsPerYLabel:30,labelsDivWidth:250,labelsDivStyles:{},labelsSeparateLines:false,labelsKMB:false,strokeWidth:1,axisTickSize:3,axisLabelFontSize:14,xAxisLabelWidth:50,yAxisLabelWidth:50,rightGap:5,showRoller:false,xValueFormatter:Dygraph.dateString_,xValueParser:Dygraph.dateParser,xTicker:Dygraph.dateTicker,sigma:2,errorBars:false,fractions:false,wilsonInterval:true,customBars:false}; +Dygraph.DEBUG=1; +Dygraph.INFO=2; +Dygraph.WARNING=3; +Dygraph.ERROR=3; +Dygraph.prototype.__old_init__=function(div,_51,_52,_53){ +if(_52!=null){ +var _54=["Date"]; +for(var i=0;i<_52.length;i++){ +_54.push(_52[i]); +} +MochiKit.Base.update(_53,{"labels":_54}); +} +this.__init__(div,_51,_53); +}; +Dygraph.prototype.__init__=function(div,_55,_56){ +if(_56==null){ +_56={}; +} +this.maindiv_=div; +this.file_=_55; +this.rollPeriod_=_56.rollPeriod||Dygraph.DEFAULT_ROLL_PERIOD; +this.previousVerticalX_=-1; +this.fractions_=_56.fractions||false; +this.dateWindow_=_56.dateWindow||null; +this.valueRange_=_56.valueRange||null; +this.wilsonInterval_=_56.wilsonInterval||true; +this.customBars_=_56.customBars||false; +div.innerHTML=""; +if(div.style.width==""){ +div.style.width=Dygraph.DEFAULT_WIDTH+"px"; +} +if(div.style.height==""){ +div.style.height=Dygraph.DEFAULT_HEIGHT+"px"; +} +this.width_=parseInt(div.style.width,10); +this.height_=parseInt(div.style.height,10); +this.user_attrs_={}; +MochiKit.Base.update(this.user_attrs_,_56); +this.attrs_={}; +MochiKit.Base.update(this.attrs_,Dygraph.DEFAULT_ATTRS); +this.labelsFromCSV_=(this.attr_("labels")==null); +this.createInterface_(); +this.layoutOptions_={"errorBars":(this.attr_("errorBars")||this.customBars_),"xOriginIsZero":false}; +MochiKit.Base.update(this.layoutOptions_,this.attrs_); +MochiKit.Base.update(this.layoutOptions_,this.user_attrs_); +this.layout_=new DygraphLayout(this.layoutOptions_); +this.renderOptions_={colorScheme:this.colors_,strokeColor:null,axisLineWidth:Dygraph.AXIS_LINE_WIDTH}; +MochiKit.Base.update(this.renderOptions_,this.attrs_); +MochiKit.Base.update(this.renderOptions_,this.user_attrs_); +this.plotter_=new DygraphCanvasRenderer(this.hidden_,this.layout_,this.renderOptions_); +this.createStatusMessage_(); +this.createRollInterface_(); +this.createDragInterface_(); +this.start_(); +}; +Dygraph.prototype.attr_=function(_57){ +if(typeof (this.user_attrs_[_57])!="undefined"){ +return this.user_attrs_[_57]; +}else{ +if(typeof (this.attrs_[_57])!="undefined"){ +return this.attrs_[_57]; }else{ -if(this.layout.style=="line"){ -this._renderLineChart(); -this._renderLineAxis(); +return null; +} } +}; +Dygraph.prototype.log=function(_58,_59){ +if(typeof (console)!="undefined"){ +switch(_58){ +case Dygraph.DEBUG: +console.debug("dygraphs: "+_59); +break; +case Dygraph.INFO: +console.info("dygraphs: "+_59); +break; +case Dygraph.WARNING: +console.warn("dygraphs: "+_59); +break; +case Dygraph.ERROR: +console.error("dygraphs: "+_59); +break; } } }; -PlotKit.SVGRenderer.prototype._renderBarOrLine=function(data,_247,_248,_249){ -var _250=this.options.colorScheme.length; -var _251=this.options.colorScheme; -var _252=MochiKit.Base.keys(this.layout.datasets); -var _253=_252.length; -for(var i=0;i<_253;i++){ -var _254=_252[i]; -var _255=new Array(); -var _256=_251[i%_250]; -if(this.options.shouldFill){ -_255["fill"]=_256.toRGBString(); -}else{ -_255["fill"]="none"; +Dygraph.prototype.info=function(_60){ +this.log(Dygraph.INFO,_60); +}; +Dygraph.prototype.warn=function(_61){ +this.log(Dygraph.WARNING,_61); +}; +Dygraph.prototype.error=function(_62){ +this.log(Dygraph.ERROR,_62); +}; +Dygraph.prototype.rollPeriod=function(){ +return this.rollPeriod_; +}; +Dygraph.prototype.createInterface_=function(){ +var _63=this.maindiv_; +this.graphDiv=MochiKit.DOM.DIV({style:{"width":this.width_+"px","height":this.height_+"px"}}); +appendChildNodes(_63,this.graphDiv); +var _64=MochiKit.DOM.CANVAS; +this.canvas_=_64({style:{"position":"absolute"},width:this.width_,height:this.height_}); +appendChildNodes(this.graphDiv,this.canvas_); +this.hidden_=this.createPlotKitCanvas_(this.canvas_); +connect(this.hidden_,"onmousemove",this,function(e){ +this.mouseMove_(e); +}); +connect(this.hidden_,"onmouseout",this,function(e){ +this.mouseOut_(e); +}); +}; +Dygraph.prototype.createPlotKitCanvas_=function(_66){ +var h=document.createElement("canvas"); +h.style.position="absolute"; +h.style.top=_66.style.top; +h.style.left=_66.style.left; +h.width=this.width_; +h.height=this.height_; +MochiKit.DOM.appendChildNodes(this.graphDiv,h); +return h; +}; +Dygraph.prototype.setColors_=function(){ +var num=this.attr_("labels").length-1; +this.colors_=[]; +var _69=this.attr_("colors"); +if(!_69){ +var sat=this.attr_("colorSaturation")||1; +var val=this.attr_("colorValue")||0.5; +for(var i=1;i<=num;i++){ +var hue=(1*i/(1+num)); +this.colors_.push(MochiKit.Color.Color.fromHSV(hue,sat,val)); +} +}else{ +for(var i=0;i=10){ +_80.doZoom_(Math.min(_82,_84),Math.max(_82,_84)); +}else{ +_80.canvas_.getContext("2d").clearRect(0,0,_80.canvas_.width,_80.canvas_.height); } -if(_248){ -_248(_255); +_82=null; +_83=null; } -var _257=function(obj){ -if(obj.name==_254){ -_247(_255,obj); +}); +connect(this.hidden_,"ondblclick",this,function(_98){ +_80.dateWindow_=null; +_80.drawGraph_(_80.rawData_); +var _99=_80.rawData_[0][0]; +var _100=_80.rawData_[_80.rawData_.length-1][0]; +if(_80.attr_("zoomCallback")){ +_80.attr_("zoomCallback")(_99,_100); } +}); }; -MochiKit.Iter.forEach(data,bind(_257,this)); -if(_249){ -_249(_255); +Dygraph.prototype.drawZoomRect_=function(_101,endX,_103){ +var ctx=this.canvas_.getContext("2d"); +if(_103){ +ctx.clearRect(Math.min(_101,_103),0,Math.abs(_101-_103),this.height_); } +if(endX&&_101){ +ctx.fillStyle="rgba(128,128,128,0.33)"; +ctx.fillRect(Math.min(_101,endX),0,Math.abs(endX-_101),this.height_); } }; -PlotKit.SVGRenderer.prototype._renderBarChart=function(){ -var bind=MochiKit.Base.bind; -var _258=function(_259,bar){ -var x=this.area.w*bar.x+this.area.x; -var y=this.area.h*bar.y+this.area.y; -var w=this.area.w*bar.w; -var h=this.area.h*bar.h; -this._drawRect(x,y,w,h,_259); -}; -this._renderBarOrLine(this.layout.bars,bind(_258,this)); -}; -PlotKit.SVGRenderer.prototype._renderLineChart=function(){ -var bind=MochiKit.Base.bind; -var _260=function(_261,_262){ -this._tempPointsBuffer+=(this.area.w*_262.x+this.area.x)+","+(this.area.h*_262.y+this.area.y)+" "; -}; -var _263=function(_264){ -this._tempPointsBuffer=""; -this._tempPointsBuffer+=(this.area.x)+","+(this.area.y+this.area.h)+" "; -}; -var _265=function(_266){ -this._tempPointsBuffer+=(this.area.w+this.area.x)+","+(this.area.h+this.area.y); -_266["points"]=this._tempPointsBuffer; -var elem=this.createSVGElement("polygon",_266); -this.root.appendChild(elem); -}; -this._renderBarOrLine(this.layout.points,bind(_260,this),bind(_263,this),bind(_265,this)); -}; -PlotKit.SVGRenderer.prototype._renderPieChart=function(){ -var _268=this.options.colorScheme.length; -var _269=this.layout.slices; -var _270=this.area.x+this.area.w*0.5; -var _271=this.area.y+this.area.h*0.5; -var _272=Math.min(this.area.w*this.options.pieRadius,this.area.h*this.options.pieRadius); -if(_269.length==1&&(Math.abs(_269[0].startAngle)-Math.abs(_269[0].endAngle)<0.1)){ -var _273={"cx":_270,"cy":_271,"r":_272}; -var _274=this.options.colorScheme[0]; -if(this.options.shouldFill){ -_273["fill"]=_274.toRGBString(); -}else{ -_273["fill"]="none"; +Dygraph.prototype.doZoom_=function(lowX,_105){ +var _106=this.layout_.points; +var _107=null; +var _108=null; +for(var i=0;i<_106.length;i++){ +var cx=_106[i].canvasx; +var x=_106[i].xval; +if(cx_107)){ +_107=x; } -if(this.options.shouldStroke&&(this.options.strokeColor||this.options.strokeColorTransform)){ -if(this.options.strokeColor){ -_273["stroke"]=this.options.strokeColor.toRGBString(); -}else{ -if(this.options.strokeColorTransform){ -_273["stroke"]=_274[this.options.strokeColorTransform]().toRGBString(); +if(cx>_105&&(_108==null||x<_108)){ +_108=x; } } -_273["style"]="stroke-width: "+this.options.strokeWidth; +if(_107==null){ +_107=_106[0].xval; } -this.root.appendChild(this.createSVGElement("circle",_273)); -return; +if(_108==null){ +_108=_106[_106.length-1].xval; } -for(var i=0;i<_269.length;i++){ -var _273=new Array(); -var _274=this.options.colorScheme[i%_268]; -if(this.options.shouldFill){ -_273["fill"]=_274.toRGBString(); -}else{ -_273["fill"]="none"; +this.dateWindow_=[_107,_108]; +this.drawGraph_(this.rawData_); +if(this.attr_("zoomCallback")){ +this.attr_("zoomCallback")(_107,_108); } -if(this.options.shouldStroke&&(this.options.strokeColor||this.options.strokeColorTransform)){ -if(this.options.strokeColor){ -_273["stroke"]=this.options.strokeColor.toRGBString(); +}; +Dygraph.prototype.mouseMove_=function(_110){ +var _111=_110.mouse().page.x-PlotKit.Base.findPosX(this.hidden_); +var _112=this.layout_.points; +var _113=-1; +var _114=-1; +var _115=1e+100; +var idx=-1; +for(var i=0;i<_112.length;i++){ +var dist=Math.abs(_112[i].canvasx-_111); +if(dist>_115){ +break; +} +_115=dist; +idx=i; +} +if(idx>=0){ +_113=_112[idx].xval; +} +if(_111>_112[_112.length-1].canvasx){ +_113=_112[_112.length-1].xval; +} +var _118=[]; +for(var i=0;i<_112.length;i++){ +if(_112[i].xval==_113){ +_118.push(_112[i]); +} +} +var _119=this.attr_("highlightCircleSize"); +var ctx=this.canvas_.getContext("2d"); +if(this.previousVerticalX_>=0){ +var px=this.previousVerticalX_; +ctx.clearRect(px-_119-1,0,2*_119+2,this.height_); +} +if(_118.length>0){ +var _111=_118[0].canvasx; +var _120=this.attr_("xValueFormatter")(_113,this)+":"; +var clen=this.colors_.length; +for(var i=0;i<_118.length;i++){ +if(this.attr_("labelsSeparateLines")){ +_120+="
"; +} +var _122=_118[i]; +_120+=" "+_122.name+":"+this.round_(_122.yval,2); +} +this.attr_("labelsDiv").innerHTML=_120; +this.lastx_=_113; +ctx.save(); +for(var i=0;i<_118.length;i++){ +ctx.beginPath(); +ctx.fillStyle=this.colors_[i%clen].toRGBString(); +ctx.arc(_111,_118[i%clen].canvasy,_119,0,360,false); +ctx.fill(); +} +ctx.restore(); +this.previousVerticalX_=_111; +} +}; +Dygraph.prototype.mouseOut_=function(_123){ +var ctx=this.canvas_.getContext("2d"); +ctx.clearRect(0,0,this.width_,this.height_); +this.attr_("labelsDiv").innerHTML=""; +}; +Dygraph.zeropad=function(x){ +if(x<10){ +return "0"+x; +}else{ +return ""+x; +} +}; +Dygraph.prototype.hmsString_=function(date){ +var _125=Dygraph.zeropad; +var d=new Date(date); +if(d.getSeconds()){ +return _125(d.getHours())+":"+_125(d.getMinutes())+":"+_125(d.getSeconds()); +}else{ +if(d.getMinutes()){ +return _125(d.getHours())+":"+_125(d.getMinutes()); +}else{ +return _125(d.getHours()); +} +} +}; +Dygraph.dateString_=function(date,self){ +var _128=Dygraph.zeropad; +var d=new Date(date); +var year=""+d.getFullYear(); +var _130=_128(d.getMonth()+1); +var day=_128(d.getDate()); +var ret=""; +var frac=d.getHours()*3600+d.getMinutes()*60+d.getSeconds(); +if(frac){ +ret=" "+self.hmsString_(date); +} +return year+"/"+_130+"/"+day+ret; +}; +Dygraph.prototype.round_=function(num,_134){ +var _135=Math.pow(10,_134); +return Math.round(num*_135)/_135; +}; +Dygraph.prototype.loadedEvent_=function(data){ +this.rawData_=this.parseCSV_(data); +this.drawGraph_(this.rawData_); +}; +Dygraph.prototype.months=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]; +Dygraph.prototype.quarters=["Jan","Apr","Jul","Oct"]; +Dygraph.prototype.addXTicks_=function(){ +var _137,endDate; +if(this.dateWindow_){ +_137=this.dateWindow_[0]; +endDate=this.dateWindow_[1]; }else{ -if(this.options.strokeColorTransform){ -_273["stroke"]=_274[this.options.strokeColorTransform]().toRGBString(); +_137=this.rawData_[0][0]; +endDate=this.rawData_[this.rawData_.length-1][0]; +} +var _138=this.attr_("xTicker")(_137,endDate,this); +this.layout_.updateOptions({xTicks:_138}); +}; +Dygraph.SECONDLY=0; +Dygraph.TEN_SECONDLY=1; +Dygraph.THIRTY_SECONDLY=2; +Dygraph.MINUTELY=3; +Dygraph.TEN_MINUTELY=4; +Dygraph.THIRTY_MINUTELY=5; +Dygraph.HOURLY=6; +Dygraph.SIX_HOURLY=7; +Dygraph.DAILY=8; +Dygraph.WEEKLY=9; +Dygraph.MONTHLY=10; +Dygraph.QUARTERLY=11; +Dygraph.BIANNUAL=12; +Dygraph.ANNUAL=13; +Dygraph.DECADAL=14; +Dygraph.NUM_GRANULARITIES=15; +Dygraph.SHORT_SPACINGS=[]; +Dygraph.SHORT_SPACINGS[Dygraph.SECONDLY]=1000*1; +Dygraph.SHORT_SPACINGS[Dygraph.TEN_SECONDLY]=1000*10; +Dygraph.SHORT_SPACINGS[Dygraph.THIRTY_SECONDLY]=1000*30; +Dygraph.SHORT_SPACINGS[Dygraph.MINUTELY]=1000*60; +Dygraph.SHORT_SPACINGS[Dygraph.TEN_MINUTELY]=1000*60*10; +Dygraph.SHORT_SPACINGS[Dygraph.THIRTY_MINUTELY]=1000*60*30; +Dygraph.SHORT_SPACINGS[Dygraph.HOURLY]=1000*3600; +Dygraph.SHORT_SPACINGS[Dygraph.HOURLY]=1000*3600*6; +Dygraph.SHORT_SPACINGS[Dygraph.DAILY]=1000*86400; +Dygraph.SHORT_SPACINGS[Dygraph.WEEKLY]=1000*604800; +Dygraph.prototype.NumXTicks=function(_139,_140,_141){ +if(_141=Dygraph.DAILY){ +_150.push({v:t,label:new Date(t+3600*1000).strftime(_152)}); +}else{ +_150.push({v:t,label:this.hmsString_(t)}); +} +} +}else{ +var _154; +var _155=1; +if(_149==Dygraph.MONTHLY){ +_154=[0,1,2,3,4,5,6,7,8,9,10,11,12]; +}else{ +if(_149==Dygraph.QUARTERLY){ +_154=[0,3,6,9]; +}else{ +if(_149==Dygraph.BIANNUAL){ +_154=[0,6]; +}else{ +if(_149==Dygraph.ANNUAL){ +_154=[0]; +}else{ +if(_149==Dygraph.DECADAL){ +_154=[0]; +_155=10; +} +} +} +} +} +var _156=new Date(_147).getFullYear(); +var _157=new Date(_148).getFullYear(); +var _158=Dygraph.zeropad; +for(var i=_156;i<=_157;i++){ +if(i%_155!=0){ +continue; } +for(var j=0;j<_154.length;j++){ +var _159=i+"/"+_158(1+_154[j])+"/01"; +var t=Date.parse(_159); +if(t<_147||t>_148){ +continue; } -_273["style"]="stroke-width:"+this.options.strokeWidth; +_150.push({v:t,label:new Date(t).strftime("%b %y")}); } -var _275=0; -if(Math.abs(_269[i].endAngle-_269[i].startAngle)>Math.PI){ -_275=1; } -var x1=Math.cos(_269[i].startAngle-Math.PI/2)*_272; -var y1=Math.sin(_269[i].startAngle-Math.PI/2)*_272; -var x2=Math.cos(_269[i].endAngle-Math.PI/2)*_272; -var y2=Math.sin(_269[i].endAngle-Math.PI/2)*_272; -var rx=x2-x1; -var ry=y2-y1; -var _282="M"+_270+","+_271+" "; -_282+="l"+x1+","+y1+" "; -_282+="a"+_272+","+_272+" 0 "+_275+",1 "+rx+","+ry+" z"; -_273["d"]=_282; -var elem=this.createSVGElement("path",_273); -this.root.appendChild(elem); } +return _150; }; -PlotKit.SVGRenderer.prototype._renderBarAxis=function(){ -this._renderAxis(); -}; -PlotKit.SVGRenderer.prototype._renderLineAxis=function(){ -this._renderAxis(); -}; -PlotKit.SVGRenderer.prototype._renderAxis=function(){ -if(!this.options.drawXAxis&&!this.options.drawYAxis){ -return; +Dygraph.dateTicker=function(_160,_161,self){ +var _162=-1; +for(var i=0;i=self.attr_("pixelsPerXLabel")){ +_162=i; +break; } -var _283={"style":{"position":"absolute","textAlign":"center","fontSize":this.options.axisLabelFontSize+"px","zIndex":10,"color":this.options.axisLabelColor.toRGBString(),"width":this.options.axisLabelWidth+"px","overflow":"hidden"}}; -var _284={"stroke":this.options.axisLineColor.toRGBString(),"strokeWidth":this.options.axisLineWidth}; -if(this.options.drawYAxis){ -if(this.layout.yticks){ -var _285=function(tick){ -var x=this.area.x; -var y=this.area.y+tick[0]*this.area.h; -this._drawLine(x,y,x-3,y,_284); -if(this.options.axisLabelUseDiv){ -var _286=DIV(_283,tick[1]); -_286.style.top=(y-this.options.axisLabelFontSize)+"px"; -_286.style.left=(x-this.options.padding.left+this.options.axisTickSize)+"px"; -_286.style.textAlign="left"; -_286.style.width=(this.options.padding.left-3)+"px"; -MochiKit.DOM.appendChildNodes(this.container,_286); -this.ylabels.push(_286); +} +if(_162>=0){ +return self.GetXAxis(_160,_161,_162); }else{ -var _287={y:y+3,x:(x-this.options.padding.left+3),width:(this.options.padding.left-this.options.axisTickSize)+"px",height:(this.options.axisLabelFontSize+3)+"px",fontFamily:"Arial",fontSize:this.options.axisLabelFontSize+"px",fill:this.options.axisLabelColor.toRGBString()}; -var _286=this.createSVGElement("text",_287); -_286.appendChild(this.document.createTextNode(tick[1])); -this.root.appendChild(_286); } }; -MochiKit.Iter.forEach(this.layout.yticks,bind(_285,this)); +Dygraph.numericTicks=function(minV,maxV,self){ +var _166=[1,2,5]; +var _167,low_val,high_val,nTicks; +var _168=self.attr_("pixelsPerYLabel"); +for(var i=-10;i<50;i++){ +var _169=Math.pow(10,i); +for(var j=0;j<_166.length;j++){ +_167=_169*_166[j]; +low_val=Math.floor(minV/_167)*_167; +high_val=Math.ceil(maxV/_167)*_167; +nTicks=(high_val-low_val)/_167; +var _170=self.height_/nTicks; +if(_170>_168){ +break; } -this._drawLine(this.area.x,this.area.y,this.area.x,this.area.y+this.area.h,_284); } -if(this.options.drawXAxis){ -if(this.layout.xticks){ -var _285=function(tick){ -var x=this.area.x+tick[0]*this.area.w; -var y=this.area.y+this.area.h; -this._drawLine(x,y,x,y+this.options.axisTickSize,_284); -if(this.options.axisLabelUseDiv){ -var _288=DIV(_283,tick[1]); -_288.style.top=(y+this.options.axisTickSize)+"px"; -_288.style.left=(x-this.options.axisLabelWidth/2)+"px"; -_288.style.textAlign="center"; -_288.style.width=this.options.axisLabelWidth+"px"; -MochiKit.DOM.appendChildNodes(this.container,_288); -this.xlabels.push(_288); +if(_170>_168){ +break; +} +} +var _171=[]; +for(var i=0;i=k*k*k){ +_173=self.round_(_172/(k*k*k),1)+"B"; +}else{ +if(_172>=k*k){ +_173=self.round_(_172/(k*k),1)+"M"; }else{ -var _289={y:(y+this.options.axisTickSize+this.options.axisLabelFontSize),x:x-3,width:this.options.axisLabelWidth+"px",height:(this.options.axisLabelFontSize+3)+"px",fontFamily:"Arial",fontSize:this.options.axisLabelFontSize+"px",fill:this.options.axisLabelColor.toRGBString(),textAnchor:"middle"}; -var _288=this.createSVGElement("text",_289); -_288.appendChild(this.document.createTextNode(tick[1])); -this.root.appendChild(_288); +if(_172>=k){ +_173=self.round_(_172/k,1)+"K"; +} } -}; -MochiKit.Iter.forEach(this.layout.xticks,bind(_285,this)); } -this._drawLine(this.area.x,this.area.y+this.area.h,this.area.x+this.area.w,this.area.y+this.area.h,_284); } +_171.push({label:_173,v:_172}); +} +return _171; }; -PlotKit.SVGRenderer.prototype._renderPieAxis=function(){ -if(this.layout.xticks){ -var _290=new Array(); -for(var i=0;iMath.PI*2){ -_297=_297-Math.PI*2; -}else{ -if(_297<0){ -_297=_297+Math.PI*2; +_178=this.rollingAverage(_178,this.rollPeriod_); +var bars=this.attr_("errorBars")||this.customBars_; +if(this.dateWindow_){ +var low=this.dateWindow_[0]; +var high=this.dateWindow_[1]; +var _182=[]; +for(var k=0;k<_178.length;k++){ +if(_178[k][0]>=low&&_178[k][0]<=high){ +_182.push(_178[k]); +var y=bars?_178[k][1][0]:_178[k][1]; +if(maxY==null||y>maxY){ +maxY=y; } } -var _298=_291+Math.sin(_297)*(_293+10); -var _299=_292-Math.cos(_297)*(_293+10); -var _300={"position":"absolute","zIndex":11,"width":_294+"px","fontSize":this.options.axisLabelFontSize+"px","overflow":"hidden","color":this.options.axisLabelColor.toHexString()}; -var _301={"width":_294+"px","fontSize":this.options.axisLabelFontSize+"px","height":(this.options.axisLabelFontSize+3)+"px","fill":this.options.axisLabelColor.toRGBString()}; -if(_297<=Math.PI*0.5){ -MochiKit.Base.update(_300,{"textAlign":"left","verticalAlign":"top","left":_298+"px","top":(_299-this.options.axisLabelFontSize)+"px"}); -MochiKit.Base.update(_301,{"x":_298,"y":(_299-this.options.axisLabelFontSize),"textAnchor":"left"}); -}else{ -if((_297>Math.PI*0.5)&&(_297<=Math.PI)){ -MochiKit.Base.update(_300,{"textAlign":"left","verticalAlign":"bottom","left":_298+"px","top":_299+"px"}); -MochiKit.Base.update(_301,{"textAnchor":"left","x":_298,"y":_299}); +} +_178=_182; }else{ -if((_297>Math.PI)&&(_297<=Math.PI*1.5)){ -MochiKit.Base.update(_300,{"textAlign":"right","verticalAlign":"bottom","left":_298+"px","top":_299+"px"}); -MochiKit.Base.update(_301,{"textAnchor":"right","x":_298-_294,"y":_299}); +if(!this.customBars_){ +for(var j=0;j<_178.length;j++){ +var y=bars?_178[j][1][0]:_178[j][1]; +if(maxY==null||y>maxY){ +maxY=bars?y+_178[j][1][1]:y; +} +} }else{ -MochiKit.Base.update(_300,{"textAlign":"left","verticalAlign":"bottom","left":_298+"px","top":_299+"px"}); -MochiKit.Base.update(_301,{"textAnchor":"left","x":_298-_294,"y":_299-this.options.axisLabelFontSize}); +for(var j=0;j<_178.length;j++){ +var y=_178[j][1][0]; +var high=_178[j][1][2]; +if(high>y){ +y=high; +} +if(maxY==null||y>maxY){ +maxY=y; +} +} } } +if(bars){ +var vals=[]; +for(var j=0;j<_178.length;j++){ +vals[j]=[_178[j][0],_178[j][1][0],_178[j][1][1],_178[j][1][2]]; } -if(this.options.axisLabelUseDiv){ -var _302=DIV({"style":_300},this.layout.xticks[i][1]); -this.xlabels.push(_302); -MochiKit.DOM.appendChildNodes(this.container,_302); +this.layout_.addDataset(this.attr_("labels")[i],vals); }else{ -var _302=this.createSVGElement("text",_301); -_302.appendChild(this.document.createTextNode(this.layout.xticks[i][1])); -this.root.appendChild(_302); +this.layout_.addDataset(this.attr_("labels")[i],_178); } } +if(this.valueRange_!=null){ +this.addYTicks_(this.valueRange_[0],this.valueRange_[1]); +}else{ +maxY*=1.1; +if(maxY<=0){ +maxY=1; } -}; -PlotKit.SVGRenderer.prototype._renderBackground=function(){ -var opts={"stroke":"none","fill":this.options.backgroundColor.toRGBString()}; -this._drawRect(0,0,this.width,this.height,opts); -}; -PlotKit.SVGRenderer.prototype._drawRect=function(x,y,w,h,_304){ -var _305={x:x+"px",y:y+"px",width:w+"px",height:h+"px"}; -if(_304){ -MochiKit.Base.update(_305,_304); +this.addYTicks_(0,maxY); } -var elem=this.createSVGElement("rect",_305); -this.root.appendChild(elem); +this.addXTicks_(); +this.layout_.evaluateWithError(); +this.plotter_.clear(); +this.plotter_.render(); +this.canvas_.getContext("2d").clearRect(0,0,this.canvas_.width,this.canvas_.height); }; -PlotKit.SVGRenderer.prototype._drawLine=function(x1,y1,x2,y2,_306){ -var _307={x1:x1+"px",y1:y1+"px",x2:x2+"px",y2:y2+"px"}; -if(_306){ -MochiKit.Base.update(_307,_306); +Dygraph.prototype.rollingAverage=function(_184,_185){ +if(_184.length<2){ +return _184; } -var elem=this.createSVGElement("line",_307); -this.root.appendChild(elem); -}; -PlotKit.SVGRenderer.prototype.clear=function(){ -while(this.element.firstChild){ -this.element.removeChild(this.element.firstChild); +var _185=Math.min(_185,_184.length-1); +var _186=[]; +var _187=this.attr_("sigma"); +if(this.fractions_){ +var num=0; +var den=0; +var mult=100; +for(var i=0;i<_184.length;i++){ +num+=_184[i][1][0]; +den+=_184[i][1][1]; +if(i-_185>=0){ +num-=_184[i-_185][1][0]; +den-=_184[i-_185][1][1]; } -if(this.options.axisLabelUseDiv){ -for(var i=0;i=0){ +var prev=_184[i-_185]; +low-=prev[1][0]; +mid-=prev[1][1]; +high-=prev[1][2]; +_196-=1; } -if(_309){ -MochiKit.DOM.updateNodeAttributes(elem,_309); +_186[i]=[_184[i][0],[1*mid/_196,1*(mid-low)/_196,1*(high-mid)/_196]]; } -return elem; -}; -PlotKit.SVGRenderer.SVG=function(_312){ -var ie=navigator.appVersion.match(/MSIE (\d\.\d)/); -var _313=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); -if(ie&&(ie[1]>=6)&&(!_313)){ -var _314=_312["width"]?_312["width"]:"100"; -var _315=_312["height"]?_312["height"]:"100"; -var eid=_312["id"]?_312["id"]:"notunique"; -var html=""; -var _318=document.createElement(html); -var _319=_318.getSVGDocument().createElementNS(PlotKit.SVGRenderer.SVGNS,"svg"); -_319.setAttribute("width",_314); -_319.setAttribute("height",_315); -_318.getSVGDocument().appendChild(_319); -return _318; -}else{ -return PlotKit.SVGRenderer.prototype.createSVGElement("svg",_312); -} -}; -PlotKit.SVGRenderer.isSupported=function(){ -var _320=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); -var _321=navigator.appVersion.match(/MSIE (\d\.\d)/); -var _322=navigator.userAgent.match(/AppleWebKit\/(\d+)/); -var _323=navigator.userAgent.match(/Opera\/(\d*\.\d*)/); -var _324=navigator.userAgent.match(/rv:(\d*\.\d*).*Gecko/); -var _325="http://www.w3.org/TR/SVG11/feature#SVG"; -if(_321&&(_321[1]>=6)&&!_320){ -return document.implementation.hasFeature(_325,"1.1"); -} -if(_323&&(_323[1]>8.9)){ -return true; +}else{ +var _198=Math.min(_185-1,_184.length-2); +if(!this.attr_("errorBars")){ +for(var i=0;i<_198;i++){ +var sum=0; +for(var j=0;j1.7)){ -return true; +_186[i]=[_184[i][0],sum/(i+1)]; } -return false; -}; -PlotKit.SVG={}; -PlotKit.SVG.SVGRenderer=PlotKit.SVGRenderer; -PlotKit.SVG.EXPORT=["SVGRenderer"]; -PlotKit.SVG.EXPORT_OK=["SVGRenderer"]; -PlotKit.SVG.__new__=function(){ -var m=MochiKit.Base; -m.nameFunctions(this); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -}; -PlotKit.SVG.__new__(); -MochiKit.Base._exportSymbols(this,PlotKit.SVG); -try{ -if(typeof (PlotKit.CanvasRenderer)=="undefined"){ -throw ""; +for(var i=Math.min(_185-1,_184.length-2);i<_184.length;i++){ +var sum=0; +for(var j=i-_185+1;j0){ -this.__init__(_326,_327,_328); } +} +} +return _186; }; -PlotKit.SweetCanvasRenderer.NAME="PlotKit.SweetCanvasRenderer"; -PlotKit.SweetCanvasRenderer.VERSION=PlotKit.VERSION; -PlotKit.SweetCanvasRenderer.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -PlotKit.SweetCanvasRenderer.toString=function(){ -return this.__repr__(); -}; -PlotKit.SweetCanvasRenderer.prototype=new PlotKit.CanvasRenderer(); -PlotKit.SweetCanvasRenderer.prototype.constructor=PlotKit.SweetCanvasRenderer; -PlotKit.SweetCanvasRenderer.__super__=PlotKit.CanvasRenderer.prototype; -PlotKit.SweetCanvasRenderer.prototype.__init__=function(el,_330,opts){ -var _331=PlotKit.Base.officeBlue(); -MochiKit.Base.update(_331,opts); -PlotKit.SweetCanvasRenderer.__super__.__init__.call(this,el,_330,_331); -}; -PlotKit.SweetCanvasRenderer.prototype._renderBarChart=function(){ -var bind=MochiKit.Base.bind; -var _332=Color.blackColor().colorWithAlpha(0.1).toRGBString(); -var _333=function(_334,x,y,w,h){ -_334.fillStyle=_332; -_334.fillRect(x-2,y-2,w+4,h+2); -_334.fillStyle=_332; -_334.fillRect(x-1,y-1,w+2,h+1); -}; -var _335=this.options.colorScheme.length; -var _336=this.options.colorScheme; -var _337=PlotKit.Base.keys(this.layout.datasets); -var _338=_337.length; -var _339=function(name){ -for(var i=0;i<_338;i++){ -if(name==_337[i]){ -return _336[i%_335]; -} -} -return _336[0]; -}; -var _340=function(_341,bar){ -var x=this.area.w*bar.x+this.area.x; -var y=this.area.h*bar.y+this.area.y; -var w=this.area.w*bar.w; -var h=this.area.h*bar.h; -if((w<1)||(h<1)){ -return; +Dygraph.dateParser=function(_201,self){ +var _202; +var d; +if(_201.length==10&&_201.search("-")!=-1){ +_202=_201.replace("-","/","g"); +while(_202.search("-")!=-1){ +_202=_202.replace("-","/"); } -_341.save(); -_341.shadowBlur=5; -_341.shadowColor=Color.fromHexString("#888888").toRGBString(); -if(this.isIE){ -_341.save(); -_341.fillStyle="#cccccc"; -_341.fillRect(x-2,y-2,w+4,h+2); -_341.restore(); +d=Date.parse(_202); }else{ -_333(_341,x,y,w,h); +if(_201.length==8){ +_202=_201.substr(0,4)+"/"+_201.substr(4,2)+"/"+_201.substr(6,2); +d=Date.parse(_202); +}else{ +d=Date.parse(_201); } -if(this.options.shouldFill){ -_341.fillStyle=_339(bar.name).toRGBString(); -_341.fillRect(x,y,w,h); } -_341.shadowBlur=0; -_341.strokeStyle=Color.whiteColor().toRGBString(); -_341.lineWidth=2; -if(this.options.shouldStroke){ -_341.strokeRect(x,y,w,h); +if(!d||isNaN(d)){ +self.error("Couldn't parse "+_201+" as a date"); } -_341.restore(); -}; -this._renderBarChartWrap(this.layout.bars,bind(_340,this)); +return d; }; -PlotKit.SweetCanvasRenderer.prototype._renderLineChart=function(){ -var _342=this.element.getContext("2d"); -var _343=this.options.colorScheme.length; -var _344=this.options.colorScheme; -var _345=PlotKit.Base.keys(this.layout.datasets); -var _346=_345.length; -var bind=MochiKit.Base.bind; -for(var i=0;i<_346;i++){ -var _347=_345[i]; -var _348=_344[i%_343]; -var _349=this.options.strokeColorTransform; -_342.save(); -var _350=function(ctx){ -ctx.beginPath(); -ctx.moveTo(this.area.x,this.area.y+this.area.h); -var _351=function(ctx_,_352){ -if(_352.name==_347){ -ctx_.lineTo(this.area.w*_352.x+this.area.x,this.area.h*_352.y+this.area.y); +Dygraph.prototype.detectTypeFromString_=function(str){ +var _204=false; +if(str.indexOf("-")>=0||str.indexOf("/")>=0||isNaN(parseFloat(str))){ +_204=true; +}else{ +if(str.length==8&&str>"19700101"&&str<"20371231"){ +_204=true; +} } +if(_204){ +this.attrs_.xValueFormatter=Dygraph.dateString_; +this.attrs_.xValueParser=Dygraph.dateParser; +this.attrs_.xTicker=Dygraph.dateTicker; +}else{ +this.attrs_.xValueFormatter=function(x){ +return x; }; -MochiKit.Iter.forEach(this.layout.points,partial(_351,ctx),this); -ctx.lineTo(this.area.w+this.area.x,this.area.h+this.area.y); -ctx.lineTo(this.area.x,this.area.y+this.area.h); -ctx.closePath(); +this.attrs_.xValueParser=function(x){ +return parseFloat(x); }; -if(this.options.shouldFill){ -_342.save(); -if(this.isIE){ -_342.fillStyle="#cccccc"; -}else{ -_342.fillStyle=Color.blackColor().colorWithAlpha(0.2).toRGBString(); +this.attrs_.xTicker=Dygraph.numericTicks; } -_342.translate(-1,-2); -bind(_350,this)(_342); -if(this.options.shouldFill){ -_342.fill(); +}; +Dygraph.prototype.parseCSV_=function(data){ +var ret=[]; +var _205=data.split("\n"); +var _206=0; +if(this.labelsFromCSV_){ +_206=1; +this.attrs_.labels=_205[0].split(","); +} +var _207; +var _208=false; +var _209=this.attr_("labels").length; +for(var i=_206;i<_205.length;i++){ +var line=_205[i]; +if(line.length==0){ +continue; } -_342.restore(); +var _211=line.split(","); +if(_211.length<2){ +continue; } -_342.shadowBlur=5; -_342.shadowColor=Color.fromHexString("#888888").toRGBString(); -_342.fillStyle=_348.toRGBString(); -_342.lineWidth=2; -_342.strokeStyle=Color.whiteColor().toRGBString(); -if(this.options.shouldFill){ -bind(_350,this)(_342); -_342.fill(); +var _212=[]; +if(!_208){ +this.detectTypeFromString_(_211[0]); +_207=this.attr_("xValueParser"); +_208=true; } -if(this.options.shouldStroke){ -bind(_350,this)(_342); -_342.stroke(); +_212[0]=_207(_211[0],this); +if(this.fractions_){ +for(var j=1;j<_211.length;j++){ +var vals=_211[j].split("/"); +_212[j]=[parseFloat(vals[0]),parseFloat(vals[1])]; } -_342.restore(); +}else{ +if(this.attr_("errorBars")){ +for(var j=1;j<_211.length;j+=2){ +_212[(j+1)/2]=[parseFloat(_211[j]),parseFloat(_211[j+1])]; } -}; -PlotKit.SweetCanvasRenderer.prototype._renderPieChart=function(){ -var _353=this.element.getContext("2d"); -var _354=this.options.colorScheme.length; -var _355=this.layout.slices; -var _356=this.area.x+this.area.w*0.5; -var _357=this.area.y+this.area.h*0.5; -var _358=Math.min(this.area.w*this.options.pieRadius,this.area.h*this.options.pieRadius); -if(this.isIE){ -_356=parseInt(_356); -_357=parseInt(_357); -_358=parseInt(_358); -} -if(!this.isIE){ -_353.save(); -var _359=Color.blackColor().colorWithAlpha(0.2); -_353.fillStyle=_359.toRGBString(); -_353.shadowBlur=5; -_353.shadowColor=Color.fromHexString("#888888").toRGBString(); -_353.translate(1,1); -_353.beginPath(); -_353.moveTo(_356,_357); -_353.arc(_356,_357,_358+2,0,Math.PI*2,false); -_353.closePath(); -_353.fill(); -_353.restore(); -} -_353.save(); -_353.strokeStyle=Color.whiteColor().toRGBString(); -_353.lineWidth=2; -for(var i=0;i<_355.length;i++){ -var _360=this.options.colorScheme[i%_354]; -_353.fillStyle=_360.toRGBString(); -var _361=function(){ -_353.beginPath(); -_353.moveTo(_356,_357); -_353.arc(_356,_357,_358,_355[i].startAngle-Math.PI/2,_355[i].endAngle-Math.PI/2,false); -_353.lineTo(_356,_357); -_353.closePath(); -}; -if(Math.abs(_355[i].startAngle-_355[i].endAngle)>0.0001){ -if(this.options.shouldFill){ -_361(); -_353.fill(); +}else{ +if(this.customBars_){ +for(var j=1;j<_211.length;j++){ +var vals=_211[j].split(";"); +_212[j]=[parseFloat(vals[0]),parseFloat(vals[1]),parseFloat(vals[2])]; } -if(this.options.shouldStroke){ -_361(); -_353.stroke(); -} -} -} -_353.restore(); -}; -PlotKit.SweetCanvasRenderer.prototype._renderBackground=function(){ -var _362=this.element.getContext("2d"); -if(this.layout.style=="bar"||this.layout.style=="line"){ -_362.save(); -_362.fillStyle=this.options.backgroundColor.toRGBString(); -_362.fillRect(this.area.x,this.area.y,this.area.w,this.area.h); -_362.strokeStyle=this.options.axisLineColor.toRGBString(); -_362.lineWidth=1; -var _363=this.layout.yticks; -var _364=false; -if(this.layout.style=="bar"&&this.layout.options.barOrientation=="horizontal"){ -_363=this.layout.xticks; -_364=true; -} -for(var i=0;i<_363.length;i++){ -var x1=0; -var y1=0; -var x2=0; -var y2=0; -if(_364){ -x1=_363[i][0]*this.area.w+this.area.x; -y1=this.area.y; -x2=x1; -y2=y1+this.area.h; -}else{ -x1=this.area.x; -y1=_363[i][0]*this.area.h+this.area.y; -x2=x1+this.area.w; -y2=y1; -} -_362.beginPath(); -_362.moveTo(x1,y1); -_362.lineTo(x2,y2); -_362.closePath(); -_362.stroke(); -} -_362.restore(); -}else{ -PlotKit.SweetCanvasRenderer.__super__._renderBackground.call(this); -} -}; -PlotKit.SweetCanvas={}; -PlotKit.SweetCanvas.SweetCanvasRenderer=PlotKit.SweetCanvasRenderer; -PlotKit.SweetCanvas.EXPORT=["SweetCanvasRenderer"]; -PlotKit.SweetCanvas.EXPORT_OK=["SweetCanvasRenderer"]; -PlotKit.SweetCanvas.__new__=function(){ -var m=MochiKit.Base; -m.nameFunctions(this); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -}; -PlotKit.SweetCanvas.__new__(); -MochiKit.Base._exportSymbols(this,PlotKit.SweetCanvas); -try{ -if(typeof (PlotKit.SVGRenderer)=="undefined"){ -throw ""; +}else{ +for(var j=1;j<_211.length;j++){ +_212[j]=parseFloat(_211[j]); } } -catch(e){ -throw "SweetSVG depends on MochiKit.{Base,Color,DOM,Format} and PlotKit.{Layout, SVG}"; } -if(typeof (PlotKit.SweetSVGRenderer)=="undefined"){ -PlotKit.SweetSVGRenderer={}; } -PlotKit.SweetSVGRenderer=function(_365,_366,_367){ -if(arguments.length>0){ -this.__init__(_365,_366,_367); +ret.push(_212); +if(_212.length!=_209){ +this.error("Number of columns in line "+i+" ("+_212.length+") does not agree with number of labels ("+_209+") "+line); } -}; -PlotKit.SweetSVGRenderer.NAME="PlotKit.SweetSVGRenderer"; -PlotKit.SweetSVGRenderer.VERSION=PlotKit.VERSION; -PlotKit.SweetSVGRenderer.__repr__=function(){ -return "["+this.NAME+" "+this.VERSION+"]"; -}; -PlotKit.SweetSVGRenderer.toString=function(){ -return this.__repr__(); -}; -PlotKit.SweetSVGRenderer.prototype=new PlotKit.SVGRenderer(); -PlotKit.SweetSVGRenderer.prototype.constructor=PlotKit.SweetSVGRenderer; -PlotKit.SweetSVGRenderer.__super__=PlotKit.SVGRenderer.prototype; -PlotKit.SweetSVGRenderer.prototype.__init__=function(_368,_369,_370){ -var _371=PlotKit.Base.officeBlue(); -MochiKit.Base.update(_371,_370); -PlotKit.SweetSVGRenderer.__super__.__init__.call(this,_368,_369,_371); -}; -PlotKit.SweetSVGRenderer.prototype._addDropShadowFilter=function(){ -var _372=this.createSVGElement("filter",{x:0,y:0,"id":"dropShadow"}); -var _373=this.createSVGElement("feOffset",{"in":"SourceGraphic","dx":0,"dy":0,"result":"topCopy"}); -var blur=this.createSVGElement("feGaussianBlur",{"in":"SourceAlpha","StdDeviation":2,"result":"shadow"}); -var _375=this.createSVGElement("feOffset",{"in":"shadow","dx":-1,"dy":-2,"result":"movedShadow"}); -var _376=this.createSVGElement("feMerge"); -var _377=this.createSVGElement("feMergeNode",{"in":"topCopy"}); -var _378=this.createSVGElement("feMergeNode",{"in":"movedShadow"}); -_376.appendChild(_377); -_376.appendChild(_378); -_372.appendChild(_373); -_372.appendChild(blur); -_372.appendChild(_375); -_372.appendChild(_376); -this.defs.appendChild(_372); -}; -PlotKit.SweetSVGRenderer.prototype._renderBarChart=function(){ -var bind=MochiKit.Base.bind; -var _379=Color.blackColor().toRGBString(); -var _380="fill:"+_379+";fill-opacity:0.15"; -var _381="stroke-width: 2.0; stroke:"+Color.whiteColor().toRGBString(); -var _382=function(_383,bar){ -var x=this.area.w*bar.x+this.area.x; -var y=this.area.h*bar.y+this.area.y; -var w=this.area.w*bar.w; -var h=this.area.h*bar.h; -if((w<1)||(h<1)){ -return; } -_383["style"]=_381; -this._drawRect(x-2,y-1,w+4,h+2,{"style":_380}); -this._drawRect(x,y,w,h,_383); -}; -this._renderBarOrLine(this.layout.bars,bind(_382,this)); -}; -PlotKit.SweetSVGRenderer.prototype._renderLineChart=function(){ -var bind=MochiKit.Base.bind; -var _384=Color.blackColor().toRGBString(); -var _385="fill:"+_384+";fill-opacity:0.15"; -var _386="stroke-width: 2.0; stroke:"+Color.whiteColor().toRGBString(); -var _387=function(_388,_389){ -this._tempPointsBuffer+=(this.area.w*_389.x+this.area.x)+","+(this.area.h*_389.y+this.area.y)+" "; -}; -var _390=function(_391){ -this._tempPointsBuffer=""; -this._tempPointsBuffer+=(this.area.x)+","+(this.area.y+this.area.h)+" "; -}; -var _392=function(_393){ -this._tempPointsBuffer+=(this.area.w+this.area.x)+","+(this.area.h+this.area.y); -_393["points"]=this._tempPointsBuffer; -_393["stroke"]="none"; -_393["transform"]="translate(-2, -1)"; -_393["style"]=_385; -var _394=this.createSVGElement("polygon",_393); -this.root.appendChild(_394); -_393["transform"]=""; -_393["style"]=_386; -var elem=this.createSVGElement("polygon",_393); -this.root.appendChild(elem); -}; -this._renderBarOrLine(this.layout.points,bind(_387,this),bind(_390,this),bind(_392,this)); -}; -PlotKit.SweetSVGRenderer.prototype._renderPieChart=function(){ -var _395=this.area.x+this.area.w*0.5; -var _396=this.area.y+this.area.h*0.5; -var _397=Color.blackColor().toRGBString(); -var _398=Math.min(this.area.w*this.options.pieRadius,this.area.h*this.options.pieRadius); -var _399="fill:"+_397+";fill-opacity:0.15"; -var _400=this.createSVGElement("circle",{"style":_399,"cx":_395+1,"cy":_396+1,"r":_398+1}); -this.root.appendChild(_400); -PlotKit.SweetSVGRenderer.__super__._renderPieChart.call(this); -}; -PlotKit.SweetSVGRenderer.prototype._renderBackground=function(){ -var _401={"fill":this.options.backgroundColor.toRGBString(),"stroke":"none"}; -if(this.layout.style=="bar"||this.layout.style=="line"){ -this._drawRect(this.area.x,this.area.y,this.area.w,this.area.h,_401); -var _402=this.layout.yticks; -var _403=false; -if(this.layout.style=="bar"&&this.layout.options.barOrientation=="horizontal"){ -_402=this.layout.xticks; -_403=true; -} -for(var i=0;i<_402.length;i++){ -var x=0; -var y=0; -var w=0; -var h=0; -if(_403){ -x=_402[i][0]*this.area.w+this.area.x; -y=this.area.y; -w=1; -h=this.area.w; -}else{ -x=this.area.x; -y=_402[i][0]*this.area.h+this.area.y; -w=this.area.w; -h=1; -} -this._drawRect(x,y,w,h,{"fill":this.options.axisLineColor.toRGBString()}); -} -}else{ -PlotKit.SweetSVGRenderer.__super__._renderBackground.call(this); -} -}; -PlotKit.SweetSVG={}; -PlotKit.SweetSVG.SweetSVGRenderer=PlotKit.SweetSVGRenderer; -PlotKit.SweetSVG.EXPORT=["SweetSVGRenderer"]; -PlotKit.SweetSVG.EXPORT_OK=["SweetSVGRenderer"]; -PlotKit.SweetSVG.__new__=function(){ -var m=MochiKit.Base; -m.nameFunctions(this); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; +return ret; }; -PlotKit.SweetSVG.__new__(); -MochiKit.Base._exportSymbols(this,PlotKit.SweetSVG); -try{ -if(typeof (PlotKit.CanvasRenderer)=="undefined"){ -throw ""; +Dygraph.prototype.parseArray_=function(data){ +if(data.length==0){ +this.error("Can't plot empty data set"); +return null; } +if(data[0].length==0){ +this.error("Data set cannot contain an empty row"); +return null; } -catch(e){ -throw "PlotKit.EasyPlot depends on all of PlotKit's components"; +if(this.attr_("labels")==null){ +this.warn("Using default labels. Set labels explicitly via 'labels' "+"in the options parameter"); +this.attrs_.labels=["X"]; +for(var i=1;i0)){ -this.layout.evaluate(); -this.renderer.clear(); -this.renderer.render(); } +return ret; }; -PlotKit.EasyPlot.onDataLoaded=function(_409){ -var _410=new Array(); -var _411=_409.responseText.split("\n"); -for(var i=0;i<_411.length;i++){ -var _412=MochiKit.Format.strip(_411[i]); -if((_412.length>1)&&(_412.charAt(0)!="#")){ -_410.push(_412.split(",")); -} +Dygraph.prototype.start_=function(){ +if(typeof this.file_=="function"){ +this.loadedEvent_(this.file_()); +}else{ +if(MochiKit.Base.isArrayLike(this.file_)){ +this.rawData_=this.parseArray_(this.file_); +this.drawGraph_(this.rawData_); +}else{ +if(typeof this.file_=="object"&&typeof this.file_.getColumnRange=="function"){ +this.rawData_=this.parseDataTable_(this.file_); +this.drawGraph_(this.rawData_); +}else{ +if(typeof this.file_=="string"){ +if(this.file_.indexOf("\n")>=0){ +this.loadedEvent_(this.file_); +}else{ +var req=new XMLHttpRequest(); +var _221=this; +req.onreadystatechange=function(){ +if(req.readyState==4){ +if(req.status==200){ +_221.loadedEvent_(req.responseText); } -this.layout.addDataset("data-ajax-"+this.deferredCount,_410); -this.deferredCount--; -if((this.deferredCount==0)&&(PlotKit.Base.keys(this.layout.datasets).length>0)){ -this.layout.evaluate(); -this.renderer.clear(); -this.renderer.render(); } }; -PlotKit.EasyPlot.prototype.reload=function(){ -this.layout.evaluate(); -this.renderer.clear(); -this.renderer.render(); -}; -PlotKit.EasyPlotModule={}; -PlotKit.EasyPlotModule.EasyPlot=PlotKit.EasyPlot; -PlotKit.EasyPlotModule.EXPORT=["EasyPlot"]; -PlotKit.EasyPlotModule.EXPORT_OK=[]; -PlotKit.EasyPlotModule.__new__=function(){ -var m=MochiKit.Base; -m.nameFunctions(this); -this.EXPORT_TAGS={":common":this.EXPORT,":all":m.concat(this.EXPORT,this.EXPORT_OK)}; -}; -PlotKit.EasyPlotModule.__new__(); -MochiKit.Base._exportSymbols(this,PlotKit.EasyPlotModule); - - -// Copyright 2006 Dan Vanderkam (danvdk@gmail.com) -// All Rights Reserved. - -/** - * @fileoverview Subclasses various parts of PlotKit to meet the additional - * needs of DateGraph: grid overlays and error bars - */ - -// Subclass PlotKit.Layout to add: -// 1. Sigma/errorBars properties -// 2. Copy error terms for PlotKit.CanvasRenderer._renderLineChart - -/** - * Creates a new DateGraphLayout object. Options are the same as those allowed - * by the PlotKit.Layout constructor. - * @param {Object} options Options for PlotKit.Layout - * @return {Object} The DateGraphLayout object - */ -DateGraphLayout = function(options) { - PlotKit.Layout.call(this, "line", options); -}; -DateGraphLayout.prototype = new PlotKit.Layout(); - -/** - * Behaves the same way as PlotKit.Layout, but also copies the errors - * @private - */ -DateGraphLayout.prototype.evaluateWithError = function() { - this.evaluate(); - if (!this.options.errorBars) return; - - // Copy over the error terms - var i = 0; // index in this.points - for (var setName in this.datasets) { - var j = 0; - var dataset = this.datasets[setName]; - if (PlotKit.Base.isFuncLike(dataset)) continue; - for (var j = 0; j < dataset.length; j++, i++) { - var item = dataset[j]; - var xv = parseFloat(item[0]); - var yv = parseFloat(item[1]); - - if (xv == this.points[i].xval && - yv == this.points[i].yval) { - this.points[i].errorMinus = parseFloat(item[2]); - this.points[i].errorPlus = parseFloat(item[3]); - } - } - } -}; - -/** - * Convenience function to remove all the data sets from a graph - */ -DateGraphLayout.prototype.removeAllDatasets = function() { - delete this.datasets; - this.datasets = new Array(); -}; - -/** - * Change the values of various layout options - * @param {Object} new_options an associative array of new properties - */ -DateGraphLayout.prototype.updateOptions = function(new_options) { - MochiKit.Base.update(this.options, new_options ? new_options : {}); -}; - -// Subclass PlotKit.CanvasRenderer to add: -// 1. X/Y grid overlay -// 2. Ability to draw error bars (if required) - -/** - * Sets some PlotKit.CanvasRenderer options - * @param {Object} element The canvas to attach to - * @param {Layout} layout The DateGraphLayout object for this graph. - * @param {Object} options Options to pass on to CanvasRenderer - */ -DateGraphCanvasRenderer = function(element, layout, options) { - PlotKit.CanvasRenderer.call(this, element, layout, options); - this.options.shouldFill = false; - this.options.shouldStroke = true; - this.options.drawYGrid = true; - this.options.drawXGrid = true; - this.options.gridLineColor = MochiKit.Color.Color.grayColor(); - MochiKit.Base.update(this.options, options); - - // TODO(danvk) This shouldn't be necessary: effects should be overlaid - this.options.drawBackground = false; -}; -DateGraphCanvasRenderer.prototype = new PlotKit.CanvasRenderer(); - -/** - * Draw an X/Y grid on top of the existing plot - */ -DateGraphCanvasRenderer.prototype.render = function() { - // Do the ordinary rendering, as before - // TODO(danvk) Call super.render() - this._renderLineChart(); - this._renderLineAxis(); - - // Draw the new X/Y grid - var ctx = this.element.getContext("2d"); - if (this.options.drawYGrid) { - var ticks = this.layout.yticks; - ctx.save(); - ctx.strokeStyle = this.options.gridLineColor.toRGBString(); - ctx.lineWidth = this.options.axisLineWidth; - for (var i = 0; i < ticks.length; i++) { - var x = this.area.x; - var y = this.area.y + ticks[i][0] * this.area.h; - ctx.beginPath(); - ctx.moveTo(x, y); - ctx.lineTo(x + this.area.w, y); - ctx.closePath(); - ctx.stroke(); - } - } - - if (this.options.drawXGrid) { - var ticks = this.layout.xticks; - ctx.save(); - ctx.strokeStyle = this.options.gridLineColor.toRGBString(); - ctx.lineWidth = this.options.axisLineWidth; - for (var i=0; i= 0) { - ctx_.moveTo(prevX, prevYs[0]); - ctx_.lineTo(point.canvasx, newYs[0]); - ctx_.lineTo(point.canvasx, newYs[1]); - ctx_.lineTo(prevX, prevYs[1]); - ctx_.closePath(); - } - prevYs[0] = newYs[0]; - prevYs[1] = newYs[1]; - prevX = point.canvasx; - } - }; - // should be same color as the lines - var err_color = color.colorWithAlpha(0.15); - ctx.fillStyle = err_color.toRGBString(); - ctx.beginPath(); - MochiKit.Iter.forEach(this.layout.points, partial(errorTrapezoid, ctx), this); - ctx.fill(); - } - }; - - if (errorBars) - bind(makeErrorBars, this)(context); - bind(makePath, this)(context); - context.restore(); -}; -// Copyright 2006 Dan Vanderkam (danvdk@gmail.com) -// All Rights Reserved. - -/** - * @fileoverview Creates an interactive, zoomable graph based on a CSV file or - * string. DateGraph can handle multiple series with or without error bars. The - * date/value ranges will be automatically set. DateGraph uses the - * <canvas> tag, so it only works in FF1.5+. - * @author danvdk@gmail.com (Dan Vanderkam) - - Usage: -
- - - The CSV file is of the form - - YYYYMMDD,A1,B1,C1 - YYYYMMDD,A2,B2,C2 - - If null is passed as the third parameter (series names), then the first line - of the CSV file is assumed to contain names for each series. - - If the 'errorBars' option is set in the constructor, the input should be of - the form - - YYYYMMDD,A1,sigmaA1,B1,sigmaB1,... - YYYYMMDD,A2,sigmaA2,B2,sigmaB2,... - - If the 'fractions' option is set, the input should be of the form: - - YYYYMMDD,A1/B1,A2/B2,... - YYYYMMDD,A1/B1,A2/B2,... - - And error bars will be calculated automatically using a binomial distribution. - - For further documentation and examples, see http://www/~danvk/dg/ - - */ - -/** - * An interactive, zoomable graph - * @param {String | Function} file A file containing CSV data or a function that - * returns this data. The expected format for each line is - * YYYYMMDD,val1,val2,... or, if attrs.errorBars is set, - * YYYYMMDD,val1,stddev1,val2,stddev2,... - * @param {Array.} labels Labels for the data series - * @param {Object} attrs Various other attributes, e.g. errorBars determines - * whether the input data contains error ranges. - */ -DateGraph = function(div, file, labels, attrs) { - if (arguments.length > 0) - this.__init__(div, file, labels, attrs); -}; - -DateGraph.NAME = "DateGraph"; -DateGraph.VERSION = "1.1"; -DateGraph.__repr__ = function() { - return "[" + this.NAME + " " + this.VERSION + "]"; -}; -DateGraph.toString = function() { - return this.__repr__(); -}; - -// Various default values -DateGraph.DEFAULT_ROLL_PERIOD = 1; -DateGraph.DEFAULT_WIDTH = 480; -DateGraph.DEFAULT_HEIGHT = 320; -DateGraph.DEFAULT_STROKE_WIDTH = 1.0; -DateGraph.AXIS_LINE_WIDTH = 0.3; - -/** - * Initializes the DateGraph. This creates a new DIV and constructs the PlotKit - * and interaction <canvas> inside of it. See the constructor for details - * on the parameters. - * @param {String | Function} file Source data - * @param {Array.} labels Names of the data series - * @param {Object} attrs Miscellaneous other options - * @private - */ -DateGraph.prototype.__init__ = function(div, file, labels, attrs) { - // Copy the important bits into the object - this.maindiv_ = div; - this.labels_ = labels; - this.file_ = file; - this.rollPeriod_ = attrs.rollPeriod || DateGraph.DEFAULT_ROLL_PERIOD; - this.previousVerticalX_ = -1; - this.width_ = parseInt(div.style.width, 10); - this.height_ = parseInt(div.style.height, 10); - this.errorBars_ = attrs.errorBars || false; - this.fractions_ = attrs.fractions || false; - this.strokeWidth_ = attrs.strokeWidth || DateGraph.DEFAULT_STROKE_WIDTH; - this.dateWindow_ = attrs.dateWindow || null; - this.valueRange_ = attrs.valueRange || null; - this.labelsSeparateLines = attrs.labelsSeparateLines || false; - this.labelsDiv_ = attrs.labelsDiv || null; - this.labelsKMB_ = attrs.labelsKMB || false; - this.minTickSize_ = attrs.minTickSize || 0; - this.xValueParser_ = attrs.xValueParser || DateGraph.prototype.dateParser; - this.xValueFormatter_ = attrs.xValueFormatter || - DateGraph.prototype.dateString_; - this.xTicker_ = attrs.xTicker || DateGraph.prototype.dateTicker; - this.sigma_ = attrs.sigma || 2.0; - this.wilsonInterval_ = attrs.wilsonInterval || true; - this.customBars_ = attrs.customBars || false; - this.attrs_ = attrs; - - // Make a note of whether labels will be pulled from the CSV file. - this.labelsFromCSV_ = (this.labels_ == null); - if (this.labels_ == null) - this.labels_ = []; - - // Prototype of the callback is "void clickCallback(event, date)" - this.clickCallback_ = attrs.clickCallback || null; - - // Prototype of zoom callback is "void dragCallback(minDate, maxDate)" - this.zoomCallback_ = attrs.zoomCallback || null; - - // Create the containing DIV and other interactive elements - this.createInterface_(); - - // Create the PlotKit grapher - this.layoutOptions_ = { 'errorBars': (this.errorBars_ || this.customBars_), - 'xOriginIsZero': false }; - MochiKit.Base.update(this.layoutOptions_, attrs); - this.setColors_(attrs); - - this.layout_ = new DateGraphLayout(this.layoutOptions_); - - this.renderOptions_ = { colorScheme: this.colors_, - strokeColor: null, - strokeWidth: this.strokeWidth_, - axisLabelFontSize: 14, - axisLineWidth: DateGraph.AXIS_LINE_WIDTH }; - MochiKit.Base.update(this.renderOptions_, attrs); - this.plotter_ = new DateGraphCanvasRenderer(this.hidden_, this.layout_, - this.renderOptions_); - - this.createStatusMessage_(); - this.createRollInterface_(); - this.createDragInterface_(); - - connect(window, 'onload', this, function(e) { this.start_(); }); -}; - -/** - * Returns the current rolling period, as set by the user or an option. - * @return {Number} The number of days in the rolling window - */ -DateGraph.prototype.rollPeriod = function() { - return this.rollPeriod_; +req.open("GET",this.file_,true); +req.send(null); } - -/** - * Generates interface elements for the DateGraph: a containing div, a div to - * display the current point, and a textbox to adjust the rolling average - * period. - * @private - */ -DateGraph.prototype.createInterface_ = function() { - // Create the all-enclosing graph div - var enclosing = this.maindiv_; - - this.graphDiv = MochiKit.DOM.DIV( { style: { 'width': this.width_ + "px", - 'height': this.height_ + "px" - }}); - appendChildNodes(enclosing, this.graphDiv); - - // Create the canvas to store - var canvas = MochiKit.DOM.CANVAS; - this.canvas_ = canvas( { style: { 'position': 'absolute' }, - width: this.width_, - height: this.height_}); - appendChildNodes(this.graphDiv, this.canvas_); - - this.hidden_ = this.createPlotKitCanvas_(this.canvas_); - connect(this.hidden_, 'onmousemove', this, function(e) { this.mouseMove_(e) }); - connect(this.hidden_, 'onmouseout', this, function(e) { this.mouseOut_(e) }); +}else{ +this.error("Unknown data format: "+(typeof this.file_)); } - -/** - * Creates the canvas containing the PlotKit graph. Only plotkit ever draws on - * this particular canvas. All DateGraph work is done on this.canvas_. - * @param {Object} canvas The DateGraph canvas to over which to overlay the plot - * @return {Object} The newly-created canvas - * @private - */ -DateGraph.prototype.createPlotKitCanvas_ = function(canvas) { - var h = document.createElement("canvas"); - h.style.position = "absolute"; - h.style.top = canvas.style.top; - h.style.left = canvas.style.left; - h.width = this.width_; - h.height = this.height_; - MochiKit.DOM.appendChildNodes(this.graphDiv, h); - return h; -}; - -/** - * Generate a set of distinct colors for the data series. This is done with a - * color wheel. Saturation/Value are customizable, and the hue is - * equally-spaced around the color wheel. If a custom set of colors is - * specified, that is used instead. - * @param {Object} attrs Various attributes, e.g. saturation and value - * @private - */ -DateGraph.prototype.setColors_ = function(attrs) { - var num = this.labels_.length; - this.colors_ = []; - if (!attrs.colors) { - var sat = attrs.colorSaturation || 1.0; - var val = attrs.colorValue || 0.5; - for (var i = 1; i <= num; i++) { - var hue = (1.0*i/(1+num)); - this.colors_.push( MochiKit.Color.Color.fromHSV(hue, sat, val) ); - } - } else { - for (var i = 0; i < num; i++) { - var colorStr = attrs.colors[i % attrs.colors.length]; - this.colors_.push( MochiKit.Color.Color.fromString(colorStr) ); - } - } } - -/** - * Create the div that contains information on the selected point(s) - * This goes in the top right of the canvas, unless an external div has already - * been specified. - * @private - */ -DateGraph.prototype.createStatusMessage_ = function(){ - if (!this.labelsDiv_) { - var divWidth = 250; - var messagestyle = { "style": { - "position": "absolute", - "fontSize": "14px", - "zIndex": 10, - "width": divWidth + "px", - "top": "0px", - "left": this.width_ - divWidth + "px", - "background": "white", - "textAlign": "left", - "overflow": "hidden"}}; - this.labelsDiv_ = MochiKit.DOM.DIV(messagestyle); - MochiKit.DOM.appendChildNodes(this.graphDiv, this.labelsDiv_); - } -}; - -/** - * Create the text box to adjust the averaging period - * @return {Object} The newly-created text box - * @private - */ -DateGraph.prototype.createRollInterface_ = function() { - var padding = this.plotter_.options.padding; - var textAttr = { "type": "text", - "size": "2", - "value": this.rollPeriod_, - "style": { "position": "absolute", - "zIndex": 10, - "top": (this.height_ - 25 - padding.bottom) + "px", - "left": (padding.left+1) + "px" } - }; - var roller = MochiKit.DOM.INPUT(textAttr); - var pa = this.graphDiv; - MochiKit.DOM.appendChildNodes(pa, roller); - connect(roller, 'onchange', this, - function() { this.adjustRoll(roller.value); }); - return roller; } - -/** - * Set up all the mouse handlers needed to capture dragging behavior for zoom - * events. Uses MochiKit.Signal to attach all the event handlers. - * @private - */ -DateGraph.prototype.createDragInterface_ = function() { - var self = this; - - // Tracks whether the mouse is down right now - var mouseDown = false; - var dragStartX = null; - var dragStartY = null; - var dragEndX = null; - var dragEndY = null; - var prevEndX = null; - - // Utility function to convert page-wide coordinates to canvas coords - var px = PlotKit.Base.findPosX(this.canvas_); - var py = PlotKit.Base.findPosY(this.canvas_); - var getX = function(e) { return e.mouse().page.x - px }; - var getY = function(e) { return e.mouse().page.y - py }; - - // Draw zoom rectangles when the mouse is down and the user moves around - connect(this.hidden_, 'onmousemove', function(event) { - if (mouseDown) { - dragEndX = getX(event); - dragEndY = getY(event); - - self.drawZoomRect_(dragStartX, dragEndX, prevEndX); - prevEndX = dragEndX; - } - }); - - // Track the beginning of drag events - connect(this.hidden_, 'onmousedown', function(event) { - mouseDown = true; - dragStartX = getX(event); - dragStartY = getY(event); - }); - - // If the user releases the mouse button during a drag, but not over the - // canvas, then it doesn't count as a zooming action. - connect(document, 'onmouseup', this, function(event) { - if (mouseDown) { - mouseDown = false; - dragStartX = null; - dragStartY = null; - } - }); - - // Temporarily cancel the dragging event when the mouse leaves the graph - connect(this.hidden_, 'onmouseout', this, function(event) { - if (mouseDown) { - dragEndX = null; - dragEndY = null; - } - }); - - // If the mouse is released on the canvas during a drag event, then it's a - // zoom. Only do the zoom if it's over a large enough area (>= 10 pixels) - connect(this.hidden_, 'onmouseup', this, function(event) { - if (mouseDown) { - mouseDown = false; - dragEndX = getX(event); - dragEndY = getY(event); - var regionWidth = Math.abs(dragEndX - dragStartX); - var regionHeight = Math.abs(dragEndY - dragStartY); - - if (regionWidth < 2 && regionHeight < 2 && - self.clickCallback_ != null && - self.lastx_ != undefined) { - self.clickCallback_(event, new Date(self.lastx_)); - } - - if (regionWidth >= 10) { - self.doZoom_(Math.min(dragStartX, dragEndX), - Math.max(dragStartX, dragEndX)); - } else { - self.canvas_.getContext("2d").clearRect(0, 0, - self.canvas_.width, - self.canvas_.height); - } - - dragStartX = null; - dragStartY = null; - } - }); - - // Double-clicking zooms back out - connect(this.hidden_, 'ondblclick', this, function(event) { - self.dateWindow_ = null; - self.drawGraph_(self.rawData_); - var minDate = self.rawData_[0][0]; - var maxDate = self.rawData_[self.rawData_.length - 1][0]; - self.zoomCallback_(minDate, maxDate); - }); -}; - -/** - * Draw a gray zoom rectangle over the desired area of the canvas. Also clears - * up any previous zoom rectangles that were drawn. This could be optimized to - * avoid extra redrawing, but it's tricky to avoid interactions with the status - * dots. - * @param {Number} startX The X position where the drag started, in canvas - * coordinates. - * @param {Number} endX The current X position of the drag, in canvas coords. - * @param {Number} prevEndX The value of endX on the previous call to this - * function. Used to avoid excess redrawing - * @private - */ -DateGraph.prototype.drawZoomRect_ = function(startX, endX, prevEndX) { - var ctx = this.canvas_.getContext("2d"); - - // Clean up from the previous rect if necessary - if (prevEndX) { - ctx.clearRect(Math.min(startX, prevEndX), 0, - Math.abs(startX - prevEndX), this.height_); - } - - // Draw a light-grey rectangle to show the new viewing area - if (endX && startX) { - ctx.fillStyle = "rgba(128,128,128,0.33)"; - ctx.fillRect(Math.min(startX, endX), 0, - Math.abs(endX - startX), this.height_); - } -}; - -/** - * Zoom to something containing [lowX, highX]. These are pixel coordinates - * in the canvas. The exact zoom window may be slightly larger if there are no - * data points near lowX or highX. This function redraws the graph. - * @param {Number} lowX The leftmost pixel value that should be visible. - * @param {Number} highX The rightmost pixel value that should be visible. - * @private - */ -DateGraph.prototype.doZoom_ = function(lowX, highX) { - // Find the earliest and latest dates contained in this canvasx range. - var points = this.layout_.points; - var minDate = null; - var maxDate = null; - // Find the nearest [minDate, maxDate] that contains [lowX, highX] - for (var i = 0; i < points.length; i++) { - var cx = points[i].canvasx; - var x = points[i].xval; - if (cx < lowX && (minDate == null || x > minDate)) minDate = x; - if (cx > highX && (maxDate == null || x < maxDate)) maxDate = x; - } - // Use the extremes if either is missing - if (minDate == null) minDate = points[0].xval; - if (maxDate == null) maxDate = points[points.length-1].xval; - - this.dateWindow_ = [minDate, maxDate]; - this.drawGraph_(this.rawData_); - this.zoomCallback_(minDate, maxDate); -}; - -/** - * When the mouse moves in the canvas, display information about a nearby data - * point and draw dots over those points in the data series. This function - * takes care of cleanup of previously-drawn dots. - * @param {Object} event The mousemove event from the browser. - * @private - */ -DateGraph.prototype.mouseMove_ = function(event) { - var canvasx = event.mouse().page.x - PlotKit.Base.findPosX(this.hidden_); - var points = this.layout_.points; - - var lastx = -1; - var lasty = -1; - - // Loop through all the points and find the date nearest to our current - // location. - var minDist = 1e+100; - var idx = -1; - for (var i = 0; i < points.length; i++) { - var dist = Math.abs(points[i].canvasx - canvasx); - if (dist > minDist) break; - minDist = dist; - idx = i; - } - if (idx >= 0) lastx = points[idx].xval; - // Check that you can really highlight the last day's data - if (canvasx > points[points.length-1].canvasx) - lastx = points[points.length-1].xval; - - // Extract the points we've selected - var selPoints = []; - for (var i = 0; i < points.length; i++) { - if (points[i].xval == lastx) { - selPoints.push(points[i]); - } - } - - // Clear the previously drawn vertical, if there is one - var circleSize = 3; - var ctx = this.canvas_.getContext("2d"); - if (this.previousVerticalX_ >= 0) { - var px = this.previousVerticalX_; - ctx.clearRect(px - circleSize - 1, 0, 2 * circleSize + 2, this.height_); - } - - if (selPoints.length > 0) { - var canvasx = selPoints[0].canvasx; - - // Set the status message to indicate the selected point(s) - var replace = this.xValueFormatter_(lastx) + ":"; - var clen = this.colors_.length; - for (var i = 0; i < selPoints.length; i++) { - if (this.labelsSeparateLines) { - replace += "
"; - } - var point = selPoints[i]; - replace += " " - + point.name + ":" - + this.round_(point.yval, 2); - } - this.labelsDiv_.innerHTML = replace; - - // Save last x position for callbacks. - this.lastx_ = lastx; - - // Draw colored circles over the center of each selected point - ctx.save() - for (var i = 0; i < selPoints.length; i++) { - ctx.beginPath(); - ctx.fillStyle = this.colors_[i%clen].toRGBString(); - ctx.arc(canvasx, selPoints[i%clen].canvasy, circleSize, 0, 360, false); - ctx.fill(); - } - ctx.restore(); - - this.previousVerticalX_ = canvasx; - } -}; - -/** - * The mouse has left the canvas. Clear out whatever artifacts remain - * @param {Object} event the mouseout event from the browser. - * @private - */ -DateGraph.prototype.mouseOut_ = function(event) { - // Get rid of the overlay data - var ctx = this.canvas_.getContext("2d"); - ctx.clearRect(0, 0, this.width_, this.height_); - this.labelsDiv_.innerHTML = ""; -}; - -/** - * Convert a JS date (millis since epoch) to YYYY/MM/DD - * @param {Number} date The JavaScript date (ms since epoch) - * @return {String} A date of the form "YYYY/MM/DD" - * @private - */ -DateGraph.prototype.dateString_ = function(date) { - var d = new Date(date); - - // Get the year: - var year = "" + d.getFullYear(); - // Get a 0 padded month string - var month = "" + (d.getMonth() + 1); //months are 0-offset, sigh - if (month.length < 2) month = "0" + month; - // Get a 0 padded day string - var day = "" + d.getDate(); - if (day.length < 2) day = "0" + day; - - return year + "/" + month + "/" + day; -}; - -/** - * Round a number to the specified number of digits past the decimal point. - * @param {Number} num The number to round - * @param {Number} places The number of decimals to which to round - * @return {Number} The rounded number - * @private - */ -DateGraph.prototype.round_ = function(num, places) { - var shift = Math.pow(10, places); - return Math.round(num * shift)/shift; -}; - -/** - * Fires when there's data available to be graphed. - * @param {String} data Raw CSV data to be plotted - * @private - */ -DateGraph.prototype.loadedEvent_ = function(data) { - this.rawData_ = this.parseCSV_(data); - this.drawGraph_(this.rawData_); -}; - -DateGraph.prototype.months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", - "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]; -DateGraph.prototype.quarters = ["Jan", "Apr", "Jul", "Oct"]; - -/** - * Add ticks on the x-axis representing years, months, quarters, weeks, or days - * @private - */ -DateGraph.prototype.addXTicks_ = function() { - // Determine the correct ticks scale on the x-axis: quarterly, monthly, ... - var startDate, endDate; - if (this.dateWindow_) { - startDate = this.dateWindow_[0]; - endDate = this.dateWindow_[1]; - } else { - startDate = this.rawData_[0][0]; - endDate = this.rawData_[this.rawData_.length - 1][0]; - } - - var xTicks = this.xTicker_(startDate, endDate); - this.layout_.updateOptions({xTicks: xTicks}); } - -/** - * Add ticks to the x-axis based on a date range. - * @param {Number} startDate Start of the date window (millis since epoch) - * @param {Number} endDate End of the date window (millis since epoch) - * @return {Array.} Array of {label, value} tuples. - * @public - */ -DateGraph.prototype.dateTicker = function(startDate, endDate) { - var ONE_DAY = 24*60*60*1000; - startDate = startDate / ONE_DAY; - endDate = endDate / ONE_DAY; - var dateSpan = endDate - startDate; - - var scale = []; - var isMonthly = false; - var yearMod = 1; - if (dateSpan > 30 * 366) { // decadal - isMonthly = true; - scale = ["Jan"]; - yearMod = 10; - } else if (dateSpan > 4*366) { // annual - scale = ["Jan"]; - isMonthly = true; - } else if (dateSpan > 366) { // quarterly - scale = this.quarters; - isMonthly = true; - } else if (dateSpan > 40) { // monthly - scale = this.months; - isMonthly = true; - } else if (dateSpan > 10) { // weekly - for (var week = startDate - 14; week < endDate + 14; week += 7) { - scale.push(week * ONE_DAY); - } - } else { // daily - for (var day = startDate - 14; day < endDate + 14; day += 1) { - scale.push(day * ONE_DAY); - } - } - - var xTicks = []; - - if (isMonthly) { - var startYear = 1900 + (new Date(startDate* ONE_DAY)).getYear(); - var endYear = 1900 + (new Date(endDate * ONE_DAY)).getYear(); - for (var i = startYear; i <= endYear; i++) { - if (i % yearMod != 0) continue; - for (var j = 0; j < scale.length; j++ ) { - var date = Date.parse(scale[j] + " 1, " + i); - xTicks.push( {label: scale[j] + "'" + ("" + i).substr(2,2), v: date } ); - } - } - } else { - for (var i = 0; i < scale.length; i++) { - var date = new Date(scale[i]); - var year = date.getFullYear().toString(); - var label = this.months[date.getMonth()] + date.getDate(); - label += "'" + year.substr(year.length - 2, 2); - xTicks.push( {label: label, v: date} ); - } - } - return xTicks; -}; - -/** - * Add ticks when the x axis has numbers on it (instead of dates) - * @param {Number} startDate Start of the date window (millis since epoch) - * @param {Number} endDate End of the date window (millis since epoch) - * @return {Array.} Array of {label, value} tuples. - * @public - */ -DateGraph.prototype.numericTicks = function(minV, maxV) { - var scale; - if (maxV <= 0.0) { - scale = 1.0; - } else { - scale = Math.pow( 10, Math.floor(Math.log(maxV)/Math.log(10.0)) ); - } - - // Add a smallish number of ticks at human-friendly points - var nTicks = (maxV - minV) / scale; - while (2 * nTicks < 20) { - nTicks *= 2; - } - if ((maxV - minV) / nTicks < this.minTickSize_) { - nTicks = this.round_((maxV - minV) / this.minTickSize_, 1); - } - - // Construct labels for the ticks - var ticks = []; - for (var i = 0; i <= nTicks; i++) { - var tickV = minV + i * (maxV - minV) / nTicks; - var label = this.round_(tickV, 2); - if (this.labelsKMB_) { - var k = 1000; - if (tickV >= k*k*k) { - label = this.round_(tickV/(k*k*k), 1) + "B"; - } else if (tickV >= k*k) { - label = this.round_(tickV/(k*k), 1) + "M"; - } else if (tickV >= k) { - label = this.round_(tickV/k, 1) + "K"; - } - } - ticks.push( {label: label, v: tickV} ); - } - return ticks; -}; - -/** - * Adds appropriate ticks on the y-axis - * @param {Number} minY The minimum Y value in the data set - * @param {Number} maxY The maximum Y value in the data set - * @private - */ -DateGraph.prototype.addYTicks_ = function(minY, maxY) { - // Set the number of ticks so that the labels are human-friendly. - var ticks = this.numericTicks(minY, maxY); - this.layout_.updateOptions( { yAxis: [minY, maxY], - yTicks: ticks } ); -}; - -/** - * Update the graph with new data. Data is in the format - * [ [date1, val1, val2, ...], [date2, val1, val2, ...] if errorBars=false - * or, if errorBars=true, - * [ [date1, [val1,stddev1], [val2,stddev2], ...], [date2, ...], ...] - * @param {Array.} data The data (see above) - * @private - */ -DateGraph.prototype.drawGraph_ = function(data) { - var maxY = null; - this.layout_.removeAllDatasets(); - // Loop over all fields in the dataset - for (var i = 1; i < data[0].length; i++) { - var series = []; - for (var j = 0; j < data.length; j++) { - var date = data[j][0]; - series[j] = [date, data[j][i]]; - } - series = this.rollingAverage(series, this.rollPeriod_); - - // Prune down to the desired range, if necessary (for zooming) - var bars = this.errorBars_ || this.customBars_; - if (this.dateWindow_) { - var low = this.dateWindow_[0]; - var high= this.dateWindow_[1]; - var pruned = []; - for (var k = 0; k < series.length; k++) { - if (series[k][0] >= low && series[k][0] <= high) { - pruned.push(series[k]); - var y = bars ? series[k][1][0] : series[k][1]; - if (maxY == null || y > maxY) maxY = y; - } - } - series = pruned; - } else { - for (var j = 0; j < series.length; j++) { - var y = bars ? series[j][1][0] : series[j][1]; - if (maxY == null || y > maxY) { - maxY = bars ? y + series[j][1][1] : y; - } - } - } - - if (bars) { - var vals = []; - for (var j=0; j= 0) { - num -= originalData[i - rollPeriod][1][0]; - den -= originalData[i - rollPeriod][1][1]; - } - - var date = originalData[i][0]; - var value = den ? num / den : 0.0; - if (this.errorBars_) { - if (this.wilsonInterval_) { - // For more details on this confidence interval, see: - // http://en.wikipedia.org/wiki/Binomial_confidence_interval - if (den) { - var p = value < 0 ? 0 : value, n = den; - var pm = sigma * Math.sqrt(p*(1-p)/n + sigma*sigma/(4*n*n)); - var denom = 1 + sigma * sigma / den; - var low = (p + sigma * sigma / (2 * den) - pm) / denom; - var high = (p + sigma * sigma / (2 * den) + pm) / denom; - rollingData[i] = [date, - [p * mult, (p - low) * mult, (high - p) * mult]]; - } else { - rollingData[i] = [date, [0, 0, 0]]; - } - } else { - var stddev = den ? sigma * Math.sqrt(value * (1 - value) / den) : 1.0; - rollingData[i] = [date, [mult * value, mult * stddev, mult * stddev]]; - } - } else { - rollingData[i] = [date, mult * value]; - } - } - } else if (this.customBars_) { - // just ignore the rolling for now. - // TODO(danvk): do something reasonable. - for (var i = 0; i < originalData.length; i++) { - var data = originalData[i][1]; - var y = data[1]; - rollingData[i] = [originalData[i][0], [y, y - data[0], data[2] - y]]; - } - } else { - // Calculate the rolling average for the first rollPeriod - 1 points where - // there is not enough data to roll over the full number of days - var num_init_points = Math.min(rollPeriod - 1, originalData.length - 2); - if (!this.errorBars_){ - for (var i = 0; i < num_init_points; i++) { - var sum = 0; - for (var j = 0; j < i + 1; j++) - sum += originalData[j][1]; - rollingData[i] = [originalData[i][0], sum / (i + 1)]; - } - // Calculate the rolling average for the remaining points - for (var i = Math.min(rollPeriod - 1, originalData.length - 2); - i < originalData.length; - i++) { - var sum = 0; - for (var j = i - rollPeriod + 1; j < i + 1; j++) - sum += originalData[j][1]; - rollingData[i] = [originalData[i][0], sum / rollPeriod]; - } - } else { - for (var i = 0; i < num_init_points; i++) { - var sum = 0; - var variance = 0; - for (var j = 0; j < i + 1; j++) { - sum += originalData[j][1][0]; - variance += Math.pow(originalData[j][1][1], 2); - } - var stddev = Math.sqrt(variance)/(i+1); - rollingData[i] = [originalData[i][0], - [sum/(i+1), sigma * stddev, sigma * stddev]]; - } - // Calculate the rolling average for the remaining points - for (var i = Math.min(rollPeriod - 1, originalData.length - 2); - i < originalData.length; - i++) { - var sum = 0; - var variance = 0; - for (var j = i - rollPeriod + 1; j < i + 1; j++) { - sum += originalData[j][1][0]; - variance += Math.pow(originalData[j][1][1], 2); - } - var stddev = Math.sqrt(variance) / rollPeriod; - rollingData[i] = [originalData[i][0], - [sum / rollPeriod, sigma * stddev, sigma * stddev]]; - } - } - } - - return rollingData; }; - -/** - * Parses a date, returning the number of milliseconds since epoch. This can be - * passed in as an xValueParser in the DateGraph constructor. - * @param {String} A date in YYYYMMDD format. - * @return {Number} Milliseconds since epoch. - * @public - */ -DateGraph.prototype.dateParser = function(dateStr) { - var dateStrSlashed; - if (dateStr.search("-") != -1) { - dateStrSlashed = dateStr.replace("-", "/", "g"); - } else if (dateStr.search("/") != -1) { - return Date.parse(dateStr); - } else { - dateStrSlashed = dateStr.substr(0,4) + "/" + dateStr.substr(4,2) - + "/" + dateStr.substr(6,2); - } - return Date.parse(dateStrSlashed); +Dygraph.prototype.updateOptions=function(_222){ +if(_222.customBars){ +this.customBars_=_222.customBars; +} +if(_222.rollPeriod){ +this.rollPeriod_=_222.rollPeriod; +} +if(_222.dateWindow){ +this.dateWindow_=_222.dateWindow; +} +if(_222.valueRange){ +this.valueRange_=_222.valueRange; +} +MochiKit.Base.update(this.user_attrs_,_222); +this.labelsFromCSV_=(this.attr_("labels")==null); +this.layout_.updateOptions({"errorBars":this.attr_("errorBars")}); +if(_222["file"]&&_222["file"]!=this.file_){ +this.file_=_222["file"]; +this.start_(); +}else{ +this.drawGraph_(this.rawData_); +} }; - -/** - * Parses a string in a special csv format. We expect a csv file where each - * line is a date point, and the first field in each line is the date string. - * We also expect that all remaining fields represent series. - * if this.errorBars_ is set, then interpret the fields as: - * date, series1, stddev1, series2, stddev2, ... - * @param {Array.} data See above. - * @private - */ -DateGraph.prototype.parseCSV_ = function(data) { - var ret = []; - var lines = data.split("\n"); - var start = this.labelsFromCSV_ ? 1 : 0; - if (this.labelsFromCSV_) { - var labels = lines[0].split(","); - labels.shift(); // a "date" parameter is assumed. - this.labels_ = labels; - // regenerate automatic colors. - this.setColors_(this.attrs_); - this.renderOptions_.colorScheme = this.colors_; - MochiKit.Base.update(this.plotter_.options, this.renderOptions_); - MochiKit.Base.update(this.layoutOptions_, this.attrs_); - } - - for (var i = start; i < lines.length; i++) { - var line = lines[i]; - if (line.length == 0) continue; // skip blank lines - var inFields = line.split(','); - if (inFields.length < 2) - continue; - - var fields = []; - fields[0] = this.xValueParser_(inFields[0]); - - // If fractions are expected, parse the numbers as "A/B" - if (this.fractions_) { - for (var j = 1; j < inFields.length; j++) { - // TODO(danvk): figure out an appropriate way to flag parse errors. - var vals = inFields[j].split("/"); - fields[j] = [parseFloat(vals[0]), parseFloat(vals[1])]; - } - } else if (this.errorBars_) { - // If there are error bars, values are (value, stddev) pairs - for (var j = 1; j < inFields.length; j += 2) - fields[(j + 1) / 2] = [parseFloat(inFields[j]), - parseFloat(inFields[j + 1])]; - } else if (this.customBars_) { - // Bars are a low;center;high tuple - for (var j = 1; j < inFields.length; j++) { - var vals = inFields[j].split(";"); - fields[j] = [ parseFloat(vals[0]), - parseFloat(vals[1]), - parseFloat(vals[2]) ]; - } - } else { - // Values are just numbers - for (var j = 1; j < inFields.length; j++) - fields[j] = parseFloat(inFields[j]); - } - ret.push(fields); - } - return ret; +Dygraph.prototype.adjustRoll=function(_223){ +this.rollPeriod_=_223; +this.drawGraph_(this.rawData_); }; - -/** - * Get the CSV data. If it's in a function, call that function. If it's in a - * file, do an XMLHttpRequest to get it. - * @private - */ -DateGraph.prototype.start_ = function() { - if (typeof this.file_ == 'function') { - // Stubbed out to allow this to run off a filesystem - this.loadedEvent_(this.file_()); - } else { - var req = new XMLHttpRequest(); - var caller = this; - req.onreadystatechange = function () { - if (req.readyState == 4) { - if (req.status == 200) { - caller.loadedEvent_(req.responseText); - } - } - }; - - req.open("GET", this.file_, true); - req.send(null); - } +Dygraph.GVizChart=function(_224){ +this.container=_224; }; - -/** - * Changes various properties of the graph. These can include: - *
    - *
  • file: changes the source data for the graph
  • - *
  • errorBars: changes whether the data contains stddev
  • - *
- * @param {Object} attrs The new properties and values - */ -DateGraph.prototype.updateOptions = function(attrs) { - if (attrs.errorBars) { - this.errorBars_ = attrs.errorBars; - } - if (attrs.customBars) { - this.customBars_ = attrs.customBars; - } - if (attrs.strokeWidth) { - this.strokeWidth_ = attrs.strokeWidth; - } - if (attrs.rollPeriod) { - this.rollPeriod_ = attrs.rollPeriod; - } - if (attrs.dateWindow) { - this.dateWindow_ = attrs.dateWindow; - } - if (attrs.valueRange) { - this.valueRange_ = attrs.valueRange; - } - if (attrs.minTickSize) { - this.minTickSize_ = attrs.minTickSize; - } - if (typeof(attrs.labels) != 'undefined') { - this.labels_ = attrs.labels; - this.labelsFromCSV_ = (attrs.labels == null); - } - this.layout_.updateOptions({ 'errorBars': this.errorBars_ }); - if (attrs['file'] && attrs['file'] != this.file_) { - this.file_ = attrs['file']; - this.start_(); - } else { - this.drawGraph_(this.rawData_); - } +Dygraph.GVizChart.prototype.draw=function(data,_225){ +this.container.innerHTML=""; +this.date_graph=new Dygraph(this.container,data,_225); }; +DateGraph=Dygraph; -/** - * Adjusts the number of days in the rolling average. Updates the graph to - * reflect the new averaging period. - * @param {Number} length Number of days over which to average the data. - */ -DateGraph.prototype.adjustRoll = function(length) { - this.rollPeriod_ = length; - this.drawGraph_(this.rawData_); -};