X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=dygraph-combined.js;h=e6380defa9e2bbfed1946475241d644bb7318ada;hb=e321ff2a4d3adfb640735f26c3eda1022e9e5f14;hp=946e587399d5cc1775e782ebdde11a49aa1060f8;hpb=bd597afc25767e952949ff79e8303327a02c6f82;p=dygraphs.git diff --git a/dygraph-combined.js b/dygraph-combined.js index 946e587..e6380de 100644 --- a/dygraph-combined.js +++ b/dygraph-combined.js @@ -1,3062 +1,7 @@ -/*** +This is not the file you are looking for. +A reasonably up-to-date version can be found at http://dygraphs.com/dygraph-combined.js - MochiKit.MochiKit 1.4 : PACKED VERSION - - THIS FILE IS AUTOMATICALLY GENERATED. If creating patches, please - diff against the source tree, not this file. - - See for documentation, downloads, license, etc. - - (c) 2005 Bob Ippolito. All rights Reserved. - -***/ - -if(typeof (dojo)!="undefined"){ -dojo.provide("MochiKit.Base"); -} -if(typeof (MochiKit)=="undefined"){ -MochiKit={}; -} -if(typeof (MochiKit.Base)=="undefined"){ -MochiKit.Base={}; -} -if(typeof (MochiKit.__export__)=="undefined"){ -MochiKit.__export__=(MochiKit.__compat__||(typeof (JSAN)=="undefined"&&typeof (dojo)=="undefined")); -} -MochiKit.Base.VERSION="1.4"; -MochiKit.Base.NAME="MochiKit.Base"; -MochiKit.Base.update=function(_1,_2){ -if(_1===null){ -_1={}; -} -for(var i=1;i=0;i--){ -_15.unshift(o[i]); -} -}else{ -res.push(o); -} -} -return res; -},extend:function(_18,obj,_1a){ -if(!_1a){ -_1a=0; -} -if(obj){ -var l=obj.length; -if(typeof (l)!="number"){ -if(typeof (MochiKit.Iter)!="undefined"){ -obj=MochiKit.Iter.list(obj); -l=obj.length; -}else{ -throw new TypeError("Argument not an array-like and MochiKit.Iter not present"); -} -} -if(!_18){ -_18=[]; -} -for(var i=_1a;i>b; -},zrshift:function(a,b){ -return a>>>b; -},eq:function(a,b){ -return a==b; -},ne:function(a,b){ -return a!=b; -},gt:function(a,b){ -return a>b; -},ge:function(a,b){ -return a>=b; -},lt:function(a,b){ -return al){ -_90=l; -} -} -_8e=[]; -for(i=0;i<_90;i++){ -var _92=[]; -for(var j=1;j=0;i--){ -_af=[_ab[i].apply(this,_af)]; -} -return _af[0]; -}; -},bind:function(_b1,_b2){ -if(typeof (_b1)=="string"){ -_b1=_b2[_b1]; -} -var _b3=_b1.im_func; -var _b4=_b1.im_preargs; -var _b5=_b1.im_self; -var m=MochiKit.Base; -if(typeof (_b1)=="function"&&typeof (_b1.apply)=="undefined"){ -_b1=m._wrapDumbFunction(_b1); -} -if(typeof (_b3)!="function"){ -_b3=_b1; -} -if(typeof (_b2)!="undefined"){ -_b5=_b2; -} -if(typeof (_b4)=="undefined"){ -_b4=[]; -}else{ -_b4=_b4.slice(); -} -m.extend(_b4,arguments,2); -var _b7=function(){ -var _b8=arguments; -var me=arguments.callee; -if(me.im_preargs.length>0){ -_b8=m.concat(me.im_preargs,_b8); -} -var _ba=me.im_self; -if(!_ba){ -_ba=this; -} -return me.im_func.apply(_ba,_b8); -}; -_b7.im_self=_b5; -_b7.im_func=_b3; -_b7.im_preargs=_b4; -return _b7; -},bindMethods:function(_bb){ -var _bc=MochiKit.Base.bind; -for(var k in _bb){ -var _be=_bb[k]; -if(typeof (_be)=="function"){ -_bb[k]=_bc(_be,_bb); -} -} -},registerComparator:function(_bf,_c0,_c1,_c2){ -MochiKit.Base.comparatorRegistry.register(_bf,_c0,_c1,_c2); -},_primitives:{"boolean":true,"string":true,"number":true},compare:function(a,b){ -if(a==b){ -return 0; -} -var _c5=(typeof (a)=="undefined"||a===null); -var _c6=(typeof (b)=="undefined"||b===null); -if(_c5&&_c6){ -return 0; -}else{ -if(_c5){ -return -1; -}else{ -if(_c6){ -return 1; -} -} -} -var m=MochiKit.Base; -var _c8=m._primitives; -if(!(typeof (a) in _c8&&typeof (b) in _c8)){ -try{ -return m.comparatorRegistry.match(a,b); -} -catch(e){ -if(e!=m.NotFound){ -throw e; -} -} -} -if(ab){ -return 1; -} -} -var _c9=m.repr; -throw new TypeError(_c9(a)+" and "+_c9(b)+" can not be compared"); -},compareDateLike:function(a,b){ -return MochiKit.Base.compare(a.getTime(),b.getTime()); -},compareArrayLike:function(a,b){ -var _ce=MochiKit.Base.compare; -var _cf=a.length; -var _d0=0; -if(_cf>b.length){ -_d0=1; -_cf=b.length; -}else{ -if(_cf=0;i--){ -sum+=o[i]; -} -}else{ -sum+=o; -} -} -if(_113<=0){ -throw new TypeError("mean() requires at least one argument"); -} -return sum/_113; -},median:function(){ -var data=MochiKit.Base.flattenArguments(arguments); -if(data.length===0){ -throw new TypeError("median() requires at least one argument"); -} -data.sort(compare); -if(data.length%2==0){ -var _117=data.length/2; -return (data[_117]+data[_117-1])/2; -}else{ -return data[(data.length-1)/2]; -} -},findValue:function(lst,_119,_11a,end){ -if(typeof (end)=="undefined"||end===null){ -end=lst.length; -} -if(typeof (_11a)=="undefined"||_11a===null){ -_11a=0; -} -var cmp=MochiKit.Base.compare; -for(var i=_11a;i0))){ -var kv=MochiKit.DOM.formContents(_127); -_127=kv[0]; -_128=kv[1]; -}else{ -if(arguments.length==1){ -if(typeof (_127.length)=="number"&&_127.length==2){ -return arguments.callee(_127[0],_127[1]); -} -var o=_127; -_127=[]; -_128=[]; -for(var k in o){ -var v=o[k]; -if(typeof (v)=="function"){ -continue; -}else{ -if(typeof (v)!="string"&&typeof (v.length)=="number"){ -for(var i=0;i0.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,_180,blue,_182){ -var _183=MochiKit.Color.Color; -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_180=rgb.g; -blue=rgb.b; -if(typeof (rgb.a)=="undefined"){ -_182=undefined; -}else{ -_182=rgb.a; -} -} -return new _183(red,_180,blue,_182); -},fromHSL:function(hue,_186,_187,_188){ -var m=MochiKit.Color; -return m.Color.fromRGB(m.hslToRGB.apply(m,arguments)); -},fromHSV:function(hue,_18b,_18c,_18d){ -var m=MochiKit.Color; -return m.Color.fromRGB(m.hsvToRGB.apply(m,arguments)); -},fromName:function(name){ -var _190=MochiKit.Color.Color; -if(name.charAt(0)=="\""){ -name=name.substr(1,name.length-2); -} -var _191=_190._namedColors[name.toLowerCase()]; -if(typeof (_191)=="string"){ -return _190.fromHexString(_191); -}else{ -if(name=="transparent"){ -return _190.transparentColor(); -} -} -return null; -},fromString:function(_192){ -var self=MochiKit.Color.Color; -var _194=_192.substr(0,3); -if(_194=="rgb"){ -return self.fromRGBString(_192); -}else{ -if(_194=="hsl"){ -return self.fromHSLString(_192); -}else{ -if(_192.charAt(0)=="#"){ -return self.fromHexString(_192); -} -} -} -return self.fromName(_192); -},fromHexString:function(_195){ -if(_195.charAt(0)=="#"){ -_195=_195.substring(1); -} -var _196=[]; -var i,hex; -if(_195.length==3){ -for(i=0;i<3;i++){ -hex=_195.substr(i,1); -_196.push(parseInt(hex+hex,16)/255); -} -}else{ -for(i=0;i<6;i+=2){ -hex=_195.substr(i,2); -_196.push(parseInt(hex,16)/255); -} -} -var _199=MochiKit.Color.Color; -return _199.fromRGB.apply(_199,_196); -},_fromColorString:function(pre,_19b,_19c,_19d){ -if(_19d.indexOf(pre)===0){ -_19d=_19d.substring(_19d.indexOf("(",3)+1,_19d.length-1); -} -var _19e=_19d.split(/\s*,\s*/); -var _19f=[]; -for(var i=0;i<_19e.length;i++){ -var c=_19e[i]; -var val; -var _1a3=c.substring(c.length-3); -if(c.charAt(c.length-1)=="%"){ -val=0.01*parseFloat(c.substring(0,c.length-1)); -}else{ -if(_1a3=="deg"){ -val=parseFloat(c)/360; -}else{ -if(_1a3=="rad"){ -val=parseFloat(c)/(Math.PI*2); -}else{ -val=_19c[i]*parseFloat(c); -} -} -} -_19f.push(val); -} -return this[_19b].apply(this,_19f); -},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,_1a9){ -v*=_1a9; -if(v<0){ -return 0; -}else{ -if(v>_1a9){ -return _1a9; -}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,_1af,_1b0,_1b1){ -if(arguments.length==1){ -var hsv=hue; -hue=hsv.h; -_1af=hsv.s; -_1b0=hsv.v; -_1b1=hsv.a; -} -var red; -var _1b4; -var blue; -if(_1af===0){ -red=_1b0; -_1b4=_1b0; -blue=_1b0; -}else{ -var i=Math.floor(hue*6); -var f=(hue*6)-i; -var p=_1b0*(1-_1af); -var q=_1b0*(1-(_1af*f)); -var t=_1b0*(1-(_1af*(1-f))); -switch(i){ -case 1: -red=q; -_1b4=_1b0; -blue=p; -break; -case 2: -red=p; -_1b4=_1b0; -blue=t; -break; -case 3: -red=p; -_1b4=q; -blue=_1b0; -break; -case 4: -red=t; -_1b4=p; -blue=_1b0; -break; -case 5: -red=_1b0; -_1b4=p; -blue=q; -break; -case 6: -case 0: -red=_1b0; -_1b4=t; -blue=p; -break; -} -} -return {r:red,g:_1b4,b:blue,a:_1b1}; -},hslToRGB:function(hue,_1bc,_1bd,_1be){ -if(arguments.length==1){ -var hsl=hue; -hue=hsl.h; -_1bc=hsl.s; -_1bd=hsl.l; -_1be=hsl.a; -} -var red; -var _1c1; -var blue; -if(_1bc===0){ -red=_1bd; -_1c1=_1bd; -blue=_1bd; -}else{ -var m2; -if(_1bd<=0.5){ -m2=_1bd*(1+_1bc); -}else{ -m2=_1bd+_1bc-(_1bd*_1bc); -} -var m1=(2*_1bd)-m2; -var f=MochiKit.Color._hslValue; -var h6=hue*6; -red=f(m1,m2,h6+2); -_1c1=f(m1,m2,h6); -blue=f(m1,m2,h6-2); -} -return {r:red,g:_1c1,b:blue,a:_1be}; -},rgbToHSV:function(red,_1c8,blue,_1ca){ -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_1c8=rgb.g; -blue=rgb.b; -_1ca=rgb.a; -} -var max=Math.max(Math.max(red,_1c8),blue); -var min=Math.min(Math.min(red,_1c8),blue); -var hue; -var _1cf; -var _1d0=max; -if(min==max){ -hue=0; -_1cf=0; -}else{ -var _1d1=(max-min); -_1cf=_1d1/max; -if(red==max){ -hue=(_1c8-blue)/_1d1; -}else{ -if(_1c8==max){ -hue=2+((blue-red)/_1d1); -}else{ -hue=4+((red-_1c8)/_1d1); -} -} -hue/=6; -if(hue<0){ -hue+=1; -} -if(hue>1){ -hue-=1; -} -} -return {h:hue,s:_1cf,v:_1d0,a:_1ca}; -},rgbToHSL:function(red,_1d3,blue,_1d5){ -if(arguments.length==1){ -var rgb=red; -red=rgb.r; -_1d3=rgb.g; -blue=rgb.b; -_1d5=rgb.a; -} -var max=Math.max(red,Math.max(_1d3,blue)); -var min=Math.min(red,Math.min(_1d3,blue)); -var hue; -var _1da; -var _1db=(max+min)/2; -var _1dc=max-min; -if(_1dc===0){ -hue=0; -_1da=0; -}else{ -if(_1db<=0.5){ -_1da=_1dc/(max+min); -}else{ -_1da=_1dc/(2-max-min); -} -if(red==max){ -hue=(_1d3-blue)/_1dc; -}else{ -if(_1d3==max){ -hue=2+((blue-red)/_1dc); -}else{ -hue=4+((red-_1d3)/_1dc); -} -} -hue/=6; -if(hue<0){ -hue+=1; -} -if(hue>1){ -hue-=1; -} -} -return {h:hue,s:_1da,l:_1db,a:_1d5}; -},toColorPart:function(num){ -num=Math.round(num); -var _1de=num.toString(16); -if(num<16){ -return "0"+_1de; -} -return _1de; -},__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 _1e0=1/3; -var _1e1={black:[0,0,0],blue:[0,0,1],brown:[0.6,0.4,0.2],cyan:[0,1,1],darkGray:[_1e0,_1e0,_1e0],gray:[0.5,0.5,0.5],green:[0,1,0],lightGray:[2*_1e0,2*_1e0,2*_1e0],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 _1e2=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 _1e1){ -var name=k+"Color"; -var _1eb=m.concat([_1e2,this.Color,name],_1e1[k]); -this.Color[name]=m.bind.apply(null,_1eb); -} -var _1ec=function(){ -for(var i=0;i1;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,_2){ -this.dygraph_=_1; -this.options={}; -MochiKit.Base.update(this.options,_2?_2:{}); -this.datasets=new Array(); -}; -DygraphLayout.prototype.attr_=function(_3){ -return this.dygraph_.attr_(_3); -}; -DygraphLayout.prototype.addDataset=function(_4,_5){ -this.datasets[_4]=_5; -}; -DygraphLayout.prototype.evaluate=function(){ -this._evaluateLimits(); -this._evaluateLineCharts(); -this._evaluateLineTicks(); -}; -DygraphLayout.prototype._evaluateLimits=function(){ -this.minxval=this.maxxval=null; -for(var _6 in this.datasets){ -var _7=this.datasets[_6]; -var x1=_7[0][0]; -if(!this.minxval||x1this.maxxval){ -this.maxxval=x2; -} -} -this.xrange=this.maxxval-this.minxval; -this.xscale=(this.xrange!=0?1/this.xrange:1); -this.minyval=this.options.yAxis[0]; -this.maxyval=this.options.yAxis[1]; -this.yrange=this.maxyval-this.minyval; -this.yscale=(this.yrange!=0?1/this.yrange:1); -}; -DygraphLayout.prototype._evaluateLineCharts=function(){ -this.points=new Array(); -for(var _10 in this.datasets){ -var _11=this.datasets[_10]; -for(var j=0;j<_11.length;j++){ -var _13=_11[j]; -var _14={x:((parseFloat(_13[0])-this.minxval)*this.xscale),y:1-((parseFloat(_13[1])-this.minyval)*this.yscale),xval:parseFloat(_13[0]),yval:parseFloat(_13[1]),name:_10}; -if(_14.y<=0){ -_14.y=0; -} -if(_14.y>=1){ -_14.y=1; -} -if((_14.x>=0)&&(_14.x<=1)){ -this.points.push(_14); -} -} -} -}; -DygraphLayout.prototype._evaluateLineTicks=function(){ -this.xticks=new Array(); -for(var i=0;i=0)&&(pos<=1)){ -this.xticks.push([pos,_17]); -} -} -this.yticks=new Array(); -for(var i=0;i=0)&&(pos<=1)){ -this.yticks.push([pos,_17]); -} -} -}; -DygraphLayout.prototype.evaluateWithError=function(){ -this.evaluate(); -if(!this.options.errorBars){ -return; -} -var i=0; -for(var _19 in this.datasets){ -var j=0; -var _20=this.datasets[_19]; -for(var j=0;j<_20.length;j++,i++){ -var _21=_20[j]; -var xv=parseFloat(_21[0]); -var yv=parseFloat(_21[1]); -if(xv==this.points[i].xval&&yv==this.points[i].yval){ -this.points[i].errorMinus=parseFloat(_21[2]); -this.points[i].errorPlus=parseFloat(_21[3]); -} -} -} -}; -DygraphLayout.prototype.removeAllDatasets=function(){ -delete this.datasets; -this.datasets=new Array(); -}; -DygraphLayout.prototype.updateOptions=function(_24){ -MochiKit.Base.update(this.options,_24?_24:{}); -}; -DygraphCanvasRenderer=function(_25,_26,_27,_28){ -this.dygraph_=_25; -this.options={"strokeWidth":0.5,"drawXAxis":true,"drawYAxis":true,"axisLineColor":Color.blackColor(),"axisLineWidth":0.5,"axisTickSize":3,"axisLabelColor":Color.blackColor(),"axisLabelFont":"Arial","axisLabelFontSize":9,"axisLabelWidth":50,"drawYGrid":true,"drawXGrid":true,"gridLineColor":MochiKit.Color.Color.grayColor()}; -MochiKit.Base.update(this.options,_28); -this.layout=_27; -this.element=_26; -this.container=this.element.parentNode; -this.isIE=(/MSIE/.test(navigator.userAgent)&&!window.opera); -if(this.isIE&&!isNil(G_vmlCanvasManager)){ -this.IEDelay=0.5; -this.maxTries=5; -this.renderDelay=null; -this.clearDelay=null; -this.element=G_vmlCanvasManager.initElement(this.element); -} -this.height=this.element.height; -this.width=this.element.width; -if(!this.isIE&&!(DygraphCanvasRenderer.isSupported(this.element))){ -throw "Canvas is not supported."; -} -this.xlabels=new Array(); -this.ylabels=new Array(); -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; -this.container.style.position="relative"; -this.container.style.width=this.width+"px"; -}; -DygraphCanvasRenderer.prototype.clear=function(){ -if(this.isIE){ -try{ -if(this.clearDelay){ -this.clearDelay.cancel(); -this.clearDelay=null; -} -var _29=this.element.getContext("2d"); -} -catch(e){ -this.clearDelay=MochiKit.Async.wait(this.IEDelay); -this.clearDelay.addCallback(bind(this.clear,this)); -return; -} -} -var _29=this.element.getContext("2d"); -_29.clearRect(0,0,this.width,this.height); -for(var i=0;ithis.height){ -_47.style.bottom="0px"; -}else{ -_47.style.top=top+"px"; -} -_47.style.left="0px"; -_47.style.textAlign="right"; -_47.style.width=this.options.yAxisLabelWidth+"px"; -this.container.appendChild(_47); -this.ylabels.push(_47); -} -var _49=this.ylabels[0]; -var _50=this.options.axisLabelFontSize; -var _51=parseInt(_49.style.top)+_50; -if(_51>this.height-_50){ -_49.style.top=(parseInt(_49.style.top)-_50/2)+"px"; -} -} -_40.beginPath(); -_40.moveTo(this.area.x,this.area.y); -_40.lineTo(this.area.x,this.area.y+this.area.h); -_40.closePath(); -_40.stroke(); -} -if(this.options.drawXAxis){ -if(this.layout.xticks){ -for(var i=0;ithis.width){ -_52=this.width-this.options.xAxisLabelWidth; -_47.style.textAlign="right"; -} -if(_52<0){ -_52=0; -_47.style.textAlign="left"; -} -_47.style.left=_52+"px"; -_47.style.width=this.options.xAxisLabelWidth+"px"; -this.container.appendChild(_47); -this.xlabels.push(_47); -} -} -_40.beginPath(); -_40.moveTo(this.area.x,this.area.y+this.area.h); -_40.lineTo(this.area.x+this.area.w,this.area.y+this.area.h); -_40.closePath(); -_40.stroke(); -} -_40.restore(); -}; -DygraphCanvasRenderer.prototype._renderLineChart=function(){ -var _53=this.element.getContext("2d"); -var _54=this.options.colorScheme.length; -var _55=this.options.colorScheme; -var _56=MochiKit.Base.keys(this.layout.datasets); -var _57=this.layout.options.errorBars; -var _58=_56.length; -var _59=MochiKit.Base.bind; -var _60=MochiKit.Base.partial; -for(var i=0;i=0){ -ctx.moveTo(_76,_77[0]); -ctx.lineTo(_81.canvasx,_82[0]); -ctx.lineTo(_81.canvasx,_82[1]); -ctx.lineTo(_76,_77[1]); -ctx.closePath(); -} -_77[0]=_82[0]; -_77[1]=_82[1]; -_76=_81.canvasx; -} -} -ctx.fill(); -} -}; -if(_57){ -_59(_72,this)(_53); -} -_59(_63,this)(_53); -_53.restore(); -}; -Dygraph=function(div,_83,_84){ -if(arguments.length>0){ -if(arguments.length==4){ -this.warn("Using deprecated four-argument dygraph constructor"); -this.__old_init__(div,_83,arguments[2],arguments[3]); -}else{ -this.__init__(div,_83,_84); -} -} -}; -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,_85,_86,_87){ -if(_86!=null){ -var _88=["Date"]; -for(var i=0;i<_86.length;i++){ -_88.push(_86[i]); -} -MochiKit.Base.update(_87,{"labels":_88}); -} -this.__init__(div,_85,_87); -}; -Dygraph.prototype.__init__=function(div,_89,_90){ -if(_90==null){ -_90={}; -} -this.maindiv_=div; -this.file_=_89; -this.rollPeriod_=_90.rollPeriod||Dygraph.DEFAULT_ROLL_PERIOD; -this.previousVerticalX_=-1; -this.fractions_=_90.fractions||false; -this.dateWindow_=_90.dateWindow||null; -this.valueRange_=_90.valueRange||null; -this.wilsonInterval_=_90.wilsonInterval||true; -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_,_90); -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.attr_("customBars")),"xOriginIsZero":false}; -MochiKit.Base.update(this.layoutOptions_,this.attrs_); -MochiKit.Base.update(this.layoutOptions_,this.user_attrs_); -this.layout_=new DygraphLayout(this,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,this.hidden_,this.layout_,this.renderOptions_); -this.createStatusMessage_(); -this.createRollInterface_(); -this.createDragInterface_(); -this.start_(); -}; -Dygraph.prototype.attr_=function(_91){ -if(typeof (this.user_attrs_[_91])!="undefined"){ -return this.user_attrs_[_91]; -}else{ -if(typeof (this.attrs_[_91])!="undefined"){ -return this.attrs_[_91]; -}else{ -return null; -} -} -}; -Dygraph.prototype.log=function(_92,_93){ -if(typeof (console)!="undefined"){ -switch(_92){ -case Dygraph.DEBUG: -console.debug("dygraphs: "+_93); -break; -case Dygraph.INFO: -console.info("dygraphs: "+_93); -break; -case Dygraph.WARNING: -console.warn("dygraphs: "+_93); -break; -case Dygraph.ERROR: -console.error("dygraphs: "+_93); -break; -} -} -}; -Dygraph.prototype.info=function(_94){ -this.log(Dygraph.INFO,_94); -}; -Dygraph.prototype.warn=function(_95){ -this.log(Dygraph.WARNING,_95); -}; -Dygraph.prototype.error=function(_96){ -this.log(Dygraph.ERROR,_96); -}; -Dygraph.prototype.rollPeriod=function(){ -return this.rollPeriod_; -}; -Dygraph.addEvent=function(el,evt,fn){ -var _99=function(e){ -if(!e){ -var e=window.event; -} -fn(e); -}; -if(window.addEventListener){ -el.addEventListener(evt,_99,false); -}else{ -el.attachEvent("on"+evt,_99); -} -}; -Dygraph.prototype.createInterface_=function(){ -var _101=this.maindiv_; -this.graphDiv=document.createElement("div"); -this.graphDiv.style.width=this.width_+"px"; -this.graphDiv.style.height=this.height_+"px"; -_101.appendChild(this.graphDiv); -this.canvas_=document.createElement("canvas"); -this.canvas_.style.position="absolute"; -this.canvas_.width=this.width_; -this.canvas_.height=this.height_; -this.graphDiv.appendChild(this.canvas_); -this.hidden_=this.createPlotKitCanvas_(this.canvas_); -var _102=this; -Dygraph.addEvent(this.hidden_,"mousemove",function(e){ -_102.mouseMove_(e); -}); -Dygraph.addEvent(this.hidden_,"mouseout",function(e){ -_102.mouseOut_(e); -}); -}; -Dygraph.prototype.createPlotKitCanvas_=function(_103){ -var h=document.createElement("canvas"); -h.style.position="absolute"; -h.style.top=_103.style.top; -h.style.left=_103.style.left; -h.width=this.width_; -h.height=this.height_; -this.graphDiv.appendChild(h); -return h; -}; -Dygraph.prototype.setColors_=function(){ -var num=this.attr_("labels").length-1; -this.colors_=[]; -var _106=this.attr_("colors"); -if(!_106){ -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){ -self.doZoom_(Math.min(_126,_128),Math.max(_126,_128)); -}else{ -self.canvas_.getContext("2d").clearRect(0,0,self.canvas_.width,self.canvas_.height); -} -_126=null; -_127=null; -} -}); -Dygraph.addEvent(this.hidden_,"dblclick",function(_142){ -self.dateWindow_=null; -self.drawGraph_(self.rawData_); -var _143=self.rawData_[0][0]; -var _144=self.rawData_[self.rawData_.length-1][0]; -if(self.attr_("zoomCallback")){ -self.attr_("zoomCallback")(_143,_144); -} -}); -}; -Dygraph.prototype.drawZoomRect_=function(_145,endX,_147){ -var ctx=this.canvas_.getContext("2d"); -if(_147){ -ctx.clearRect(Math.min(_145,_147),0,Math.abs(_145-_147),this.height_); -} -if(endX&&_145){ -ctx.fillStyle="rgba(128,128,128,0.33)"; -ctx.fillRect(Math.min(_145,endX),0,Math.abs(endX-_145),this.height_); -} -}; -Dygraph.prototype.doZoom_=function(lowX,_149){ -var _150=this.layout_.points; -var _151=null; -var _152=null; -for(var i=0;i<_150.length;i++){ -var cx=_150[i].canvasx; -var x=_150[i].xval; -if(cx_151)){ -_151=x; -} -if(cx>_149&&(_152==null||x<_152)){ -_152=x; -} -} -if(_151==null){ -_151=_150[0].xval; -} -if(_152==null){ -_152=_150[_150.length-1].xval; -} -this.dateWindow_=[_151,_152]; -this.drawGraph_(this.rawData_); -if(this.attr_("zoomCallback")){ -this.attr_("zoomCallback")(_151,_152); -} -}; -Dygraph.prototype.mouseMove_=function(_154){ -var _155=Dygraph.pageX(_154)-Dygraph.findPosX(this.hidden_); -var _156=this.layout_.points; -var _157=-1; -var _158=-1; -var _159=1e+100; -var idx=-1; -for(var i=0;i<_156.length;i++){ -var dist=Math.abs(_156[i].canvasx-_155); -if(dist>_159){ -break; -} -_159=dist; -idx=i; -} -if(idx>=0){ -_157=_156[idx].xval; -} -if(_155>_156[_156.length-1].canvasx){ -_157=_156[_156.length-1].xval; -} -var _162=[]; -for(var i=0;i<_156.length;i++){ -if(_156[i].xval==_157){ -_162.push(_156[i]); -} -} -var _163=this.attr_("highlightCircleSize"); -var ctx=this.canvas_.getContext("2d"); -if(this.previousVerticalX_>=0){ -var px=this.previousVerticalX_; -ctx.clearRect(px-_163-1,0,2*_163+2,this.height_); -} -var isOK=function(x){ -return x&&!isNaN(x); -}; -if(_162.length>0){ -var _155=_162[0].canvasx; -var _165=this.attr_("xValueFormatter")(_157,this)+":"; -var clen=this.colors_.length; -for(var i=0;i<_162.length;i++){ -if(!isOK(_162[i].canvasy)){ -continue; -} -if(this.attr_("labelsSeparateLines")){ -_165+="
"; -} -var _167=_162[i]; -_165+=" "+_167.name+":"+this.round_(_167.yval,2); -} -this.attr_("labelsDiv").innerHTML=_165; -this.lastx_=_157; -ctx.save(); -for(var i=0;i<_162.length;i++){ -if(!isOK(_162[i%clen].canvasy)){ -continue; -} -ctx.beginPath(); -ctx.fillStyle=this.colors_[i%clen].toRGBString(); -ctx.arc(_155,_162[i%clen].canvasy,_163,0,360,false); -ctx.fill(); -} -ctx.restore(); -this.previousVerticalX_=_155; -} -}; -Dygraph.prototype.mouseOut_=function(_168){ -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 _170=Dygraph.zeropad; -var d=new Date(date); -if(d.getSeconds()){ -return _170(d.getHours())+":"+_170(d.getMinutes())+":"+_170(d.getSeconds()); -}else{ -if(d.getMinutes()){ -return _170(d.getHours())+":"+_170(d.getMinutes()); -}else{ -return _170(d.getHours()); -} -} -}; -Dygraph.dateString_=function(date,self){ -var _172=Dygraph.zeropad; -var d=new Date(date); -var year=""+d.getFullYear(); -var _174=_172(d.getMonth()+1); -var day=_172(d.getDate()); -var ret=""; -var frac=d.getHours()*3600+d.getMinutes()*60+d.getSeconds(); -if(frac){ -ret=" "+self.hmsString_(date); -} -return year+"/"+_174+"/"+day+ret; -}; -Dygraph.prototype.round_=function(num,_178){ -var _179=Math.pow(10,_178); -return Math.round(num*_179)/_179; -}; -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 _181,endDate; -if(this.dateWindow_){ -_181=this.dateWindow_[0]; -endDate=this.dateWindow_[1]; -}else{ -_181=this.rawData_[0][0]; -endDate=this.rawData_[this.rawData_.length-1][0]; -} -var _182=this.attr_("xTicker")(_181,endDate,this); -this.layout_.updateOptions({xTicks:_182}); -}; -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(_183,_184,_185){ -if(_185=Dygraph.DAILY){ -_194.push({v:t,label:new Date(t+3600*1000).strftime(_196)}); -}else{ -_194.push({v:t,label:this.hmsString_(t)}); -} -} -}else{ -var _198; -var _199=1; -if(_193==Dygraph.MONTHLY){ -_198=[0,1,2,3,4,5,6,7,8,9,10,11,12]; -}else{ -if(_193==Dygraph.QUARTERLY){ -_198=[0,3,6,9]; -}else{ -if(_193==Dygraph.BIANNUAL){ -_198=[0,6]; -}else{ -if(_193==Dygraph.ANNUAL){ -_198=[0]; -}else{ -if(_193==Dygraph.DECADAL){ -_198=[0]; -_199=10; -} -} -} -} -} -var _200=new Date(_191).getFullYear(); -var _201=new Date(_192).getFullYear(); -var _202=Dygraph.zeropad; -for(var i=_200;i<=_201;i++){ -if(i%_199!=0){ -continue; -} -for(var j=0;j<_198.length;j++){ -var _203=i+"/"+_202(1+_198[j])+"/01"; -var t=Date.parse(_203); -if(t<_191||t>_192){ -continue; -} -_194.push({v:t,label:new Date(t).strftime("%b %y")}); -} -} -} -return _194; -}; -Dygraph.dateTicker=function(_204,_205,self){ -var _206=-1; -for(var i=0;i=self.attr_("pixelsPerXLabel")){ -_206=i; -break; -} -} -if(_206>=0){ -return self.GetXAxis(_204,_205,_206); -}else{ -} -}; -Dygraph.numericTicks=function(minV,maxV,self){ -var _210=[1,2,5]; -var _211,low_val,high_val,nTicks; -var _212=self.attr_("pixelsPerYLabel"); -for(var i=-10;i<50;i++){ -var _213=Math.pow(10,i); -for(var j=0;j<_210.length;j++){ -_211=_213*_210[j]; -low_val=Math.floor(minV/_211)*_211; -high_val=Math.ceil(maxV/_211)*_211; -nTicks=(high_val-low_val)/_211; -var _214=self.height_/nTicks; -if(_214>_212){ -break; -} -} -if(_214>_212){ -break; -} -} -var _215=[]; -for(var i=0;i=k*k*k){ -_217=self.round_(_216/(k*k*k),1)+"B"; -}else{ -if(_216>=k*k){ -_217=self.round_(_216/(k*k),1)+"M"; -}else{ -if(_216>=k){ -_217=self.round_(_216/k,1)+"K"; -} -} -} -} -_215.push({label:_217,v:_216}); -} -return _215; -}; -Dygraph.prototype.addYTicks_=function(minY,maxY){ -var _221=Dygraph.numericTicks(minY,maxY,this); -this.layout_.updateOptions({yAxis:[minY,maxY],yTicks:_221}); -}; -Dygraph.prototype.extremeValues_=function(_222){ -var minY=null,maxY=null; -var bars=this.attr_("errorBars")||this.attr_("customBars"); -if(bars){ -for(var j=0;j<_222.length;j++){ -var y=_222[j][1][0]; -if(!y){ -continue; -} -var low=y-_222[j][1][1]; -var high=y+_222[j][1][2]; -if(low>y){ -low=y; -} -if(highmaxY){ -maxY=high; -} -if(minY==null||lowmaxY){ -maxY=y; -} -if(minY==null||y=low&&_226[k][0]<=high){ -_227.push(_226[k]); -} -} -_226=_227; -} -var _228=this.extremeValues_(_226); -var _229=_228[0]; -var _230=_228[1]; -if(!minY||_229maxY){ -maxY=_230; -} -if(bars){ -var vals=[]; -for(var j=0;j<_226.length;j++){ -vals[j]=[_226[j][0],_226[j][1][0],_226[j][1][1],_226[j][1][2]]; -} -this.layout_.addDataset(this.attr_("labels")[i],vals); -}else{ -this.layout_.addDataset(this.attr_("labels")[i],_226); -} -} -if(this.valueRange_!=null){ -this.addYTicks_(this.valueRange_[0],this.valueRange_[1]); -}else{ -var span=maxY-minY; -var _233=maxY+0.1*span; -var _234=minY-0.1*span; -if(_234<0&&minY>=0){ -_234=0; -} -if(_233>0&&maxY<=0){ -_233=0; -} -if(this.attr_("includeZero")){ -if(maxY<0){ -_233=0; -} -if(minY>0){ -_234=0; -} -} -this.addYTicks_(_234,_233); -} -this.addXTicks_(); -this.layout_.evaluateWithError(); -this.plotter_.clear(); -this.plotter_.render(); -this.canvas_.getContext("2d").clearRect(0,0,this.canvas_.width,this.canvas_.height); -}; -Dygraph.prototype.rollingAverage=function(_235,_236){ -if(_235.length<2){ -return _235; -} -var _236=Math.min(_236,_235.length-1); -var _237=[]; -var _238=this.attr_("sigma"); -if(this.fractions_){ -var num=0; -var den=0; -var mult=100; -for(var i=0;i<_235.length;i++){ -num+=_235[i][1][0]; -den+=_235[i][1][1]; -if(i-_236>=0){ -num-=_235[i-_236][1][0]; -den-=_235[i-_236][1][1]; -} -var date=_235[i][0]; -var _241=den?num/den:0; -if(this.attr_("errorBars")){ -if(this.wilsonInterval_){ -if(den){ -var p=_241<0?0:_241,n=den; -var pm=_238*Math.sqrt(p*(1-p)/n+_238*_238/(4*n*n)); -var _244=1+_238*_238/den; -var low=(p+_238*_238/(2*den)-pm)/_244; -var high=(p+_238*_238/(2*den)+pm)/_244; -_237[i]=[date,[p*mult,(p-low)*mult,(high-p)*mult]]; -}else{ -_237[i]=[date,[0,0,0]]; -} -}else{ -var _245=den?_238*Math.sqrt(_241*(1-_241)/den):1; -_237[i]=[date,[mult*_241,mult*_245,mult*_245]]; -} -}else{ -_237[i]=[date,mult*_241]; -} -} -}else{ -if(this.attr_("customBars")){ -var low=0; -var mid=0; -var high=0; -var _247=0; -for(var i=0;i<_235.length;i++){ -var data=_235[i][1]; -var y=data[1]; -_237[i]=[_235[i][0],[y,y-data[0],data[2]-y]]; -low+=data[0]; -mid+=y; -high+=data[2]; -_247+=1; -if(i-_236>=0){ -var prev=_235[i-_236]; -low-=prev[1][0]; -mid-=prev[1][1]; -high-=prev[1][2]; -_247-=1; -} -_237[i]=[_235[i][0],[1*mid/_247,1*(mid-low)/_247,1*(high-mid)/_247]]; -} -}else{ -var _249=Math.min(_236-1,_235.length-2); -if(!this.attr_("errorBars")){ -if(_236==1){ -return _235; -} -for(var i=0;i<_235.length;i++){ -var sum=0; -var _251=0; -for(var j=Math.max(0,i-_236+1);j=0||str.indexOf("/")>=0||isNaN(parseFloat(str))){ -_256=true; -}else{ -if(str.length==8&&str>"19700101"&&str<"20371231"){ -_256=true; -} -} -if(_256){ -this.attrs_.xValueFormatter=Dygraph.dateString_; -this.attrs_.xValueParser=Dygraph.dateParser; -this.attrs_.xTicker=Dygraph.dateTicker; -}else{ -this.attrs_.xValueFormatter=function(x){ -return x; -}; -this.attrs_.xValueParser=function(x){ -return parseFloat(x); -}; -this.attrs_.xTicker=Dygraph.numericTicks; -} -}; -Dygraph.prototype.parseCSV_=function(data){ -var ret=[]; -var _257=data.split("\n"); -var _258=0; -if(this.labelsFromCSV_){ -_258=1; -this.attrs_.labels=_257[0].split(","); -} -var _259; -var _260=false; -var _261=this.attr_("labels").length; -for(var i=_258;i<_257.length;i++){ -var line=_257[i]; -if(line.length==0){ -continue; -} -var _263=line.split(","); -if(_263.length<2){ -continue; -} -var _264=[]; -if(!_260){ -this.detectTypeFromString_(_263[0]); -_259=this.attr_("xValueParser"); -_260=true; -} -_264[0]=_259(_263[0],this); -if(this.fractions_){ -for(var j=1;j<_263.length;j++){ -var vals=_263[j].split("/"); -_264[j]=[parseFloat(vals[0]),parseFloat(vals[1])]; -} -}else{ -if(this.attr_("errorBars")){ -for(var j=1;j<_263.length;j+=2){ -_264[(j+1)/2]=[parseFloat(_263[j]),parseFloat(_263[j+1])]; -} -}else{ -if(this.attr_("customBars")){ -for(var j=1;j<_263.length;j++){ -var vals=_263[j].split(";"); -_264[j]=[parseFloat(vals[0]),parseFloat(vals[1]),parseFloat(vals[2])]; -} -}else{ -for(var j=1;j<_263.length;j++){ -_264[j]=parseFloat(_263[j]); -} -} -} -} -ret.push(_264); -if(_264.length!=_261){ -this.error("Number of columns in line "+i+" ("+_264.length+") does not agree with number of labels ("+_261+") "+line); -} -} -return ret; -}; -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; -} -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;i=0){ -this.loadedEvent_(this.file_); -}else{ -var req=new XMLHttpRequest(); -var _272=this; -req.onreadystatechange=function(){ -if(req.readyState==4){ -if(req.status==200){ -_272.loadedEvent_(req.responseText); -} -} -}; -req.open("GET",this.file_,true); -req.send(null); -} -}else{ -this.error("Unknown data format: "+(typeof this.file_)); -} -} -} -} -}; -Dygraph.prototype.updateOptions=function(_273){ -if(_273.rollPeriod){ -this.rollPeriod_=_273.rollPeriod; -} -if(_273.dateWindow){ -this.dateWindow_=_273.dateWindow; -} -if(_273.valueRange){ -this.valueRange_=_273.valueRange; -} -MochiKit.Base.update(this.user_attrs_,_273); -this.labelsFromCSV_=(this.attr_("labels")==null); -this.layout_.updateOptions({"errorBars":this.attr_("errorBars")}); -if(_273["file"]&&_273["file"]!=this.file_){ -this.file_=_273["file"]; -this.start_(); -}else{ -this.drawGraph_(this.rawData_); -} -}; -Dygraph.prototype.adjustRoll=function(_274){ -this.rollPeriod_=_274; -this.drawGraph_(this.rawData_); -}; -Dygraph.GVizChart=function(_275){ -this.container=_275; -}; -Dygraph.GVizChart.prototype.draw=function(data,_276){ -this.container.innerHTML=""; -this.date_graph=new Dygraph(this.container,data,_276); -}; -DateGraph=Dygraph; +dygraph-combined.js is a "packed" version of the larger dygraphs JS files. It is +smaller and loads more quickly, but is harder to debug. +To generate this file, run "make" or generate-combined.sh.