X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;ds=sidebyside;f=dygraph-combined.js;h=6cf8d2d9c7b3370bf51d23749350ee39c5311c99;hb=8846615af9608d77ed1d526a52f065922b2af9cd;hp=2ea5555ec5b357d0a208dc4fcc234895df1a1c6f;hpb=223ddf66a6b79373044f178c87c69065e4dba75c;p=dygraphs.git diff --git a/dygraph-combined.js b/dygraph-combined.js index 2ea5555..6cf8d2d 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; @@ -4304,7 +4304,7 @@ this.__init__(_69,_70,_71); 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(),"padding":{left:30,right:30,top:5,bottom:10},"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}; +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); @@ -4331,7 +4331,9 @@ 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(){ @@ -4432,14 +4434,29 @@ _93.lineTo(x-this.options.axisTickSize,y); _93.closePath(); _93.stroke(); var _98=DIV(_94,_96[1]); -_98.style.top=(y-this.options.axisLabelFontSize)+"px"; -_98.style.left=(x-this.options.padding.left-this.options.axisTickSize)+"px"; +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.padding.left-this.options.axisTickSize*2)+"px"; +_98.style.border="1px solid black"; +_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); @@ -4449,24 +4466,34 @@ _93.stroke(); } if(this.options.drawXAxis){ if(this.layout.xticks){ -var _95=function(_99){ +var _95=function(tick){ if(typeof (dataset)=="function"){ return; } -var x=this.area.x+_99[0]*this.area.w; +var x=this.area.x+tick[0]*this.area.w; var y=this.area.y+this.area.h; _93.beginPath(); _93.moveTo(x,y); _93.lineTo(x,y+this.options.axisTickSize); _93.closePath(); _93.stroke(); -var _100=DIV(_94,_99[1]); -_100.style.top=(y+this.options.axisTickSize)+"px"; -_100.style.left=(x-this.options.axisLabelWidth/2)+"px"; -_100.style.textAlign="center"; -_100.style.width=this.options.axisLabelWidth+"px"; -MochiKit.DOM.appendChildNodes(this.container,_100); -this.xlabels.push(_100); +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.border="1px solid black"; +_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)); } @@ -4479,11 +4506,11 @@ _93.stroke(); _93.restore(); }; PlotKit.CanvasRenderer.prototype._renderBackground=function(){ -var _101=this.element.getContext("2d"); -_101.save(); -_101.fillStyle=this.options.backgroundColor.toRGBString(); -_101.fillRect(0,0,this.width,this.height); -_101.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){ @@ -4492,7 +4519,7 @@ if(this.clearDelay){ this.clearDelay.cancel(); this.clearDelay=null; } -var _102=this.element.getContext("2d"); +var _107=this.element.getContext("2d"); } catch(e){ this.isFirstRender=false; @@ -4501,88 +4528,88 @@ this.clearDelay.addCallback(bind(this.clear,this)); return; } } -var _102=this.element.getContext("2d"); -_102.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 _103=MochiKit.Signal.connect; +var _108=MochiKit.Signal.connect; var bind=MochiKit.Base.bind; -_103(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 _106=this.layout.hitTest(x,y); -if(_106){ -return _106; +var _111=this.layout.hitTest(x,y); +if(_111){ +return _111; } return null; }; -PlotKit.CanvasRenderer.prototype._createEventObject=function(_107,e){ -if(_107==null){ +PlotKit.CanvasRenderer.prototype._createEventObject=function(_112,e){ +if(_112==null){ return null; } -e.chart=_107; +e.chart=_112; return e; }; PlotKit.CanvasRenderer.prototype.onclick=function(e){ -var _108=this._resolveObject(e); -var _109=this._createEventObject(_108,e); -if(_109!=null){ -MochiKit.Signal.signal(this,"onclick",_109); +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 _110=this._resolveObject(e); -var _111=this._createEventObject(_110,e); -if(_111!=null){ -signal(this,"onmouseover",_111); +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 _112=this._resolveObject(e); -var _113=this._createEventObject(_112,e); -if(_113==null){ +var _117=this._resolveObject(e); +var _118=this._createEventObject(_117,e); +if(_118==null){ signal(this,"onmouseout",e); }else{ -signal(this,"onmouseout",_113); +signal(this,"onmouseout",_118); } }; PlotKit.CanvasRenderer.prototype.onmousemove=function(e){ -var _114=this._resolveObject(e); -var _115=this._createEventObject(_114,e); -if((_114==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((_114!=null)&&(this.event_isinside==null)){ -signal(this,"onmouseover",_115); +if((_119!=null)&&(this.event_isinside==null)){ +signal(this,"onmouseover",_120); } -if((_114==null)&&(this.event_isinside!=null)){ -signal(this,"onmouseout",_115); +if((_119==null)&&(this.event_isinside!=null)){ +signal(this,"onmouseout",_120); } -if((_114!=null)&&(this.event_isinside!=null)){ -signal(this,"onmousemove",_115); +if((_119!=null)&&(this.event_isinside!=null)){ +signal(this,"onmousemove",_120); } -this.event_isinside=_114; +this.event_isinside=_119; }; -PlotKit.CanvasRenderer.isSupported=function(_116){ -var _117=null; +PlotKit.CanvasRenderer.isSupported=function(_121){ +var _122=null; try{ -if(MochiKit.Base.isUndefinedOrNull(_116)){ -_117=MochiKit.DOM.CANVAS({}); +if(MochiKit.Base.isUndefinedOrNull(_121)){ +_122=MochiKit.DOM.CANVAS({}); }else{ -_117=MochiKit.DOM.getElement(_116); +_122=MochiKit.DOM.getElement(_121); } -var _118=_117.getContext("2d"); +var _123=_122.getContext("2d"); } catch(e){ var ie=navigator.appVersion.match(/MSIE (\d\.\d)/); -var _120=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); -if((!ie)||(ie[1]<6)||(_120)){ +var _125=(navigator.userAgent.toLowerCase().indexOf("opera")!=-1); +if((!ie)||(ie[1]<6)||(_125)){ return false; } return true; @@ -4602,11 +4629,12 @@ PlotKit.Canvas.__new__(); MochiKit.Base._exportSymbols(this,PlotKit.Canvas); -DateGraphLayout=function(_1){ +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); }; -DateGraphLayout.prototype=new PlotKit.Layout(); -DateGraphLayout.prototype.evaluateWithError=function(){ +DygraphLayout.prototype=new PlotKit.Layout(); +DygraphLayout.prototype.evaluateWithError=function(){ this.evaluate(); if(!this.options.errorBars){ return; @@ -4629,14 +4657,14 @@ this.points[i].errorPlus=parseFloat(_6[3]); } } }; -DateGraphLayout.prototype.removeAllDatasets=function(){ +DygraphLayout.prototype.removeAllDatasets=function(){ delete this.datasets; this.datasets=new Array(); }; -DateGraphLayout.prototype.updateOptions=function(_9){ +DygraphLayout.prototype.updateOptions=function(_9){ MochiKit.Base.update(this.options,_9?_9:{}); }; -DateGraphCanvasRenderer=function(_10,_11,_12){ +DygraphCanvasRenderer=function(_10,_11,_12){ PlotKit.CanvasRenderer.call(this,_10,_11,_12); this.options.shouldFill=false; this.options.shouldStroke=true; @@ -4646,10 +4674,8 @@ this.options.gridLineColor=MochiKit.Color.Color.grayColor(); MochiKit.Base.update(this.options,_12); this.options.drawBackground=false; }; -DateGraphCanvasRenderer.prototype=new PlotKit.CanvasRenderer(); -DateGraphCanvasRenderer.prototype.render=function(){ -this._renderLineChart(); -this._renderLineAxis(); +DygraphCanvasRenderer.prototype=new PlotKit.CanvasRenderer(); +DygraphCanvasRenderer.prototype.render=function(){ var ctx=this.element.getContext("2d"); if(this.options.drawYGrid){ var _14=this.layout.yticks; @@ -4681,8 +4707,10 @@ ctx.closePath(); ctx.stroke(); } } +this._renderLineChart(); +this._renderLineAxis(); }; -DateGraphCanvasRenderer.prototype._renderLineChart=function(){ +DygraphCanvasRenderer.prototype._renderLineChart=function(){ var _17=this.element.getContext("2d"); var _18=this.options.colorScheme.length; var _19=this.options.colorScheme; @@ -4764,78 +4792,130 @@ _23(_35,this)(_17); _23(_27,this)(_17); _17.restore(); }; -DateGraph=function(div,_49,_50,_51){ +Dygraph=function(div,_49,_50){ if(arguments.length>0){ -this.__init__(div,_49,_50,_51); +if(arguments.length==4){ +this.warn("Using deprecated four-argument dygraph constructor"); +this.__old_init__(div,_49,arguments[2],arguments[3]); +}else{ +this.__init__(div,_49,_50); +} } }; -DateGraph.NAME="DateGraph"; -DateGraph.VERSION="1.1"; -DateGraph.__repr__=function(){ +Dygraph.NAME="Dygraph"; +Dygraph.VERSION="1.2"; +Dygraph.__repr__=function(){ return "["+this.NAME+" "+this.VERSION+"]"; }; -DateGraph.toString=function(){ +Dygraph.toString=function(){ return this.__repr__(); }; -DateGraph.DEFAULT_ROLL_PERIOD=1; -DateGraph.DEFAULT_WIDTH=480; -DateGraph.DEFAULT_HEIGHT=320; -DateGraph.DEFAULT_STROKE_WIDTH=1; -DateGraph.AXIS_LINE_WIDTH=0.3; -DateGraph.prototype.__init__=function(div,_52,_53,_54){ +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.labels_=_53; -this.file_=_52; -this.rollPeriod_=_54.rollPeriod||DateGraph.DEFAULT_ROLL_PERIOD; +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; +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.errorBars_=_54.errorBars||false; -this.fractions_=_54.fractions||false; -this.strokeWidth_=_54.strokeWidth||DateGraph.DEFAULT_STROKE_WIDTH; -this.dateWindow_=_54.dateWindow||null; -this.valueRange_=_54.valueRange||null; -this.labelsSeparateLines=_54.labelsSeparateLines||false; -this.labelsDiv_=_54.labelsDiv||null; -this.labelsKMB_=_54.labelsKMB||false; -this.minTickSize_=_54.minTickSize||0; -this.xValueParser_=_54.xValueParser||DateGraph.prototype.dateParser; -this.xValueFormatter_=_54.xValueFormatter||DateGraph.prototype.dateString_; -this.xTicker_=_54.xTicker||DateGraph.prototype.dateTicker; -this.sigma_=_54.sigma||2; -this.wilsonInterval_=_54.wilsonInterval||true; -this.customBars_=_54.customBars||false; -this.attrs_=_54; -this.labelsFromCSV_=(this.labels_==null); -if(this.labels_==null){ -this.labels_=[]; -} -this.clickCallback_=_54.clickCallback||null; -this.zoomCallback_=_54.zoomCallback||null; +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.errorBars_||this.customBars_),"xOriginIsZero":false}; -MochiKit.Base.update(this.layoutOptions_,_54); -this.setColors_(_54); -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_,_54); -this.plotter_=new DateGraphCanvasRenderer(this.hidden_,this.layout_,this.renderOptions_); +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_(); -connect(window,"onload",this,function(e){ this.start_(); -}); }; -DateGraph.prototype.rollPeriod=function(){ +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{ +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; +} +} +}; +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_; }; -DateGraph.prototype.createInterface_=function(){ -var _56=this.maindiv_; +Dygraph.prototype.createInterface_=function(){ +var _63=this.maindiv_; this.graphDiv=MochiKit.DOM.DIV({style:{"width":this.width_+"px","height":this.height_+"px"}}); -appendChildNodes(_56,this.graphDiv); -var _57=MochiKit.DOM.CANVAS; -this.canvas_=_57({style:{"position":"absolute"},width:this.width_,height:this.height_}); +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){ @@ -4845,395 +4925,511 @@ connect(this.hidden_,"onmouseout",this,function(e){ this.mouseOut_(e); }); }; -DateGraph.prototype.createPlotKitCanvas_=function(_58){ +Dygraph.prototype.createPlotKitCanvas_=function(_66){ var h=document.createElement("canvas"); h.style.position="absolute"; -h.style.top=_58.style.top; -h.style.left=_58.style.left; +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; }; -DateGraph.prototype.setColors_=function(_60){ -var num=this.labels_.length; +Dygraph.prototype.setColors_=function(){ +var num=this.attr_("labels").length-1; this.colors_=[]; -if(!_60.colors){ -var sat=_60.colorSaturation||1; -var val=_60.colorValue||0.5; +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){ -_72.doZoom_(Math.min(_74,_76),Math.max(_74,_76)); +if(_96>=10){ +_80.doZoom_(Math.min(_82,_84),Math.max(_82,_84)); }else{ -_72.canvas_.getContext("2d").clearRect(0,0,_72.canvas_.width,_72.canvas_.height); +_80.canvas_.getContext("2d").clearRect(0,0,_80.canvas_.width,_80.canvas_.height); } -_74=null; -_75=null; +_82=null; +_83=null; } }); -connect(this.hidden_,"ondblclick",this,function(_90){ -_72.dateWindow_=null; -_72.drawGraph_(_72.rawData_); -var _91=_72.rawData_[0][0]; -var _92=_72.rawData_[_72.rawData_.length-1][0]; -_72.zoomCallback_(_91,_92); +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); +} }); }; -DateGraph.prototype.drawZoomRect_=function(_93,_94,_95){ +Dygraph.prototype.drawZoomRect_=function(_101,endX,_103){ var ctx=this.canvas_.getContext("2d"); -if(_95){ -ctx.clearRect(Math.min(_93,_95),0,Math.abs(_93-_95),this.height_); +if(_103){ +ctx.clearRect(Math.min(_101,_103),0,Math.abs(_101-_103),this.height_); } -if(_94&&_93){ +if(endX&&_101){ ctx.fillStyle="rgba(128,128,128,0.33)"; -ctx.fillRect(Math.min(_93,_94),0,Math.abs(_94-_93),this.height_); +ctx.fillRect(Math.min(_101,endX),0,Math.abs(endX-_101),this.height_); } }; -DateGraph.prototype.doZoom_=function(_96,_97){ -var _98=this.layout_.points; -var _99=null; -var _100=null; -for(var i=0;i<_98.length;i++){ -var cx=_98[i].canvasx; -var x=_98[i].xval; -if(cx<_96&&(_99==null||x>_99)){ -_99=x; +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(cx>_97&&(_100==null||x<_100)){ -_100=x; +if(cx>_105&&(_108==null||x<_108)){ +_108=x; } } -if(_99==null){ -_99=_98[0].xval; +if(_107==null){ +_107=_106[0].xval; } -if(_100==null){ -_100=_98[_98.length-1].xval; +if(_108==null){ +_108=_106[_106.length-1].xval; } -this.dateWindow_=[_99,_100]; +this.dateWindow_=[_107,_108]; this.drawGraph_(this.rawData_); -this.zoomCallback_(_99,_100); -}; -DateGraph.prototype.mouseMove_=function(_102){ -var _103=_102.mouse().page.x-PlotKit.Base.findPosX(this.hidden_); -var _104=this.layout_.points; -var _105=-1; -var _106=-1; -var _107=1e+100; +if(this.attr_("zoomCallback")){ +this.attr_("zoomCallback")(_107,_108); +} +}; +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<_104.length;i++){ -var dist=Math.abs(_104[i].canvasx-_103); -if(dist>_107){ +for(var i=0;i<_112.length;i++){ +var dist=Math.abs(_112[i].canvasx-_111); +if(dist>_115){ break; } -_107=dist; +_115=dist; idx=i; } if(idx>=0){ -_105=_104[idx].xval; +_113=_112[idx].xval; } -if(_103>_104[_104.length-1].canvasx){ -_105=_104[_104.length-1].xval; +if(_111>_112[_112.length-1].canvasx){ +_113=_112[_112.length-1].xval; } -var _110=[]; -for(var i=0;i<_104.length;i++){ -if(_104[i].xval==_105){ -_110.push(_104[i]); +var _118=[]; +for(var i=0;i<_112.length;i++){ +if(_112[i].xval==_113){ +_118.push(_112[i]); } } -var _111=3; +var _119=this.attr_("highlightCircleSize"); var ctx=this.canvas_.getContext("2d"); if(this.previousVerticalX_>=0){ var px=this.previousVerticalX_; -ctx.clearRect(px-_111-1,0,2*_111+2,this.height_); +ctx.clearRect(px-_119-1,0,2*_119+2,this.height_); } -if(_110.length>0){ -var _103=_110[0].canvasx; -var _112=this.xValueFormatter_(_105)+":"; +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<_110.length;i++){ -if(this.labelsSeparateLines){ -_112+="
"; +for(var i=0;i<_118.length;i++){ +if(this.attr_("labelsSeparateLines")){ +_120+="
"; } -var _114=_110[i]; -_112+=" "+_114.name+":"+this.round_(_114.yval,2); +var _122=_118[i]; +_120+=" "+_122.name+":"+this.round_(_122.yval,2); } -this.labelsDiv_.innerHTML=_112; -this.lastx_=_105; +this.attr_("labelsDiv").innerHTML=_120; +this.lastx_=_113; ctx.save(); -for(var i=0;i<_110.length;i++){ +for(var i=0;i<_118.length;i++){ ctx.beginPath(); ctx.fillStyle=this.colors_[i%clen].toRGBString(); -ctx.arc(_103,_110[i%clen].canvasy,_111,0,360,false); +ctx.arc(_111,_118[i%clen].canvasy,_119,0,360,false); ctx.fill(); } ctx.restore(); -this.previousVerticalX_=_103; +this.previousVerticalX_=_111; } }; -DateGraph.prototype.mouseOut_=function(_115){ +Dygraph.prototype.mouseOut_=function(_123){ var ctx=this.canvas_.getContext("2d"); ctx.clearRect(0,0,this.width_,this.height_); -this.labelsDiv_.innerHTML=""; +this.attr_("labelsDiv").innerHTML=""; }; -DateGraph.prototype.dateString_=function(date){ +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); -var year=""+d.getFullYear(); -var _119=""+(d.getMonth()+1); -if(_119.length<2){ -_119="0"+_119; +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()); } -var day=""+d.getDate(); -if(day.length<2){ -day="0"+day; } -return year+"/"+_119+"/"+day; }; -DateGraph.prototype.round_=function(num,_121){ -var _122=Math.pow(10,_121); -return Math.round(num*_122)/_122; +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; }; -DateGraph.prototype.loadedEvent_=function(data){ +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_); }; -DateGraph.prototype.months=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]; -DateGraph.prototype.quarters=["Jan","Apr","Jul","Oct"]; -DateGraph.prototype.addXTicks_=function(){ -var _124,endDate; +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_){ -_124=this.dateWindow_[0]; +_137=this.dateWindow_[0]; endDate=this.dateWindow_[1]; }else{ -_124=this.rawData_[0][0]; +_137=this.rawData_[0][0]; endDate=this.rawData_[this.rawData_.length-1][0]; } -var _125=this.xTicker_(_124,endDate); -this.layout_.updateOptions({xTicks:_125}); -}; -DateGraph.prototype.dateTicker=function(_126,_127){ -var _128=24*60*60*1000; -_126=_126/_128; -_127=_127/_128; -var _129=_127-_126; -var _130=[]; -var _131=false; -var _132=1; -if(_129>30*366){ -_131=true; -_130=["Jan"]; -_132=10; -}else{ -if(_129>4*366){ -_130=["Jan"]; -_131=true; -}else{ -if(_129>366){ -_130=this.quarters; -_131=true; -}else{ -if(_129>40){ -_130=this.months; -_131=true; -}else{ -if(_129>10){ -for(var week=_126-14;week<_127+14;week+=7){ -_130.push(week*_128); -} -}else{ -for(var day=_126-14;day<_127+14;day+=1){ -_130.push(day*_128); -} -} +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; } +_150.push({v:t,label:new Date(t).strftime("%b %y")}); } } -var _134=[]; -if(_131){ -var _135=1900+(new Date(_126*_128)).getYear(); -var _136=1900+(new Date(_127*_128)).getYear(); -for(var i=_135;i<=_136;i++){ -if(i%_132!=0){ -continue; } -for(var j=0;j<_130.length;j++){ -var date=Date.parse(_130[j]+" 1, "+i); -_134.push({label:_130[j]+"'"+(""+i).substr(2,2),v:date}); +return _150; +}; +Dygraph.dateTicker=function(_160,_161,self){ +var _162=-1; +for(var i=0;i=self.attr_("pixelsPerXLabel")){ +_162=i; +break; } } +if(_162>=0){ +return self.GetXAxis(_160,_161,_162); }else{ -for(var i=0;i<_130.length;i++){ -var date=new Date(_130[i]); -var year=date.getFullYear().toString(); -var _137=this.months[date.getMonth()]+date.getDate(); -_137+="'"+year.substr(year.length-2,2); -_134.push({label:_137,v:date}); } -} -return _134; }; -DateGraph.prototype.numericTicks=function(minV,maxV){ -var _140; -if(maxV<=0){ -_140=1; -}else{ -_140=Math.pow(10,Math.floor(Math.log(maxV)/Math.log(10))); +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; +} } -var _141=(maxV-minV)/_140; -while(2*_141<20){ -_141*=2; +if(_170>_168){ +break; } -if((maxV-minV)/_141=k*k*k){ -_144=this.round_(_143/(k*k*k),1)+"B"; +if(_172>=k*k*k){ +_173=self.round_(_172/(k*k*k),1)+"B"; }else{ -if(_143>=k*k){ -_144=this.round_(_143/(k*k),1)+"M"; +if(_172>=k*k){ +_173=self.round_(_172/(k*k),1)+"M"; }else{ -if(_143>=k){ -_144=this.round_(_143/k,1)+"K"; +if(_172>=k){ +_173=self.round_(_172/k,1)+"K"; } } } } -_142.push({label:_144,v:_143}); +_171.push({label:_173,v:_172}); } -return _142; +return _171; }; -DateGraph.prototype.addYTicks_=function(minY,maxY){ -var _148=this.numericTicks(minY,maxY); -this.layout_.updateOptions({yAxis:[minY,maxY],yTicks:_148}); +Dygraph.prototype.addYTicks_=function(minY,maxY){ +var _177=Dygraph.numericTicks(minY,maxY,this); +this.layout_.updateOptions({yAxis:[minY,maxY],yTicks:_177}); }; -DateGraph.prototype.drawGraph_=function(data){ +Dygraph.prototype.drawGraph_=function(data){ var maxY=null; this.layout_.removeAllDatasets(); +this.setColors_(); for(var i=1;i=low&&_149[k][0]<=high){ -_153.push(_149[k]); -var y=bars?_149[k][1][0]:_149[k][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; } } } -_149=_153; +_178=_182; }else{ -for(var j=0;j<_149.length;j++){ -var y=bars?_149[j][1][0]:_149[j][1]; +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+_149[j][1][1]:y; +maxY=bars?y+_178[j][1][1]:y; +} +} +}else{ +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<_149.length;j++){ -vals[j]=[_149[j][0],_149[j][1][0],_149[j][1][1],_149[j][1][2]]; +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]]; } -this.layout_.addDataset(this.labels_[i-1],vals); +this.layout_.addDataset(this.attr_("labels")[i],vals); }else{ -this.layout_.addDataset(this.labels_[i-1],_149); +this.layout_.addDataset(this.attr_("labels")[i],_178); } } if(this.valueRange_!=null){ @@ -5242,9 +5438,6 @@ this.addYTicks_(this.valueRange_[0],this.valueRange_[1]); maxY*=1.1; if(maxY<=0){ maxY=1; -}else{ -var _155=Math.pow(10,Math.floor(Math.log(maxY)/Math.log(10))); -maxY=_155*Math.ceil(maxY/_155); } this.addYTicks_(0,maxY); } @@ -5254,213 +5447,364 @@ this.plotter_.clear(); this.plotter_.render(); this.canvas_.getContext("2d").clearRect(0,0,this.canvas_.width,this.canvas_.height); }; -DateGraph.prototype.rollingAverage=function(_156,_157){ -if(_156.length<2){ -return _156; +Dygraph.prototype.rollingAverage=function(_184,_185){ +if(_184.length<2){ +return _184; } -var _157=Math.min(_157,_156.length-1); -var _158=[]; -var _159=this.sigma_; +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<_156.length;i++){ -num+=_156[i][1][0]; -den+=_156[i][1][1]; -if(i-_157>=0){ -num-=_156[i-_157][1][0]; -den-=_156[i-_157][1][1]; -} -var date=_156[i][0]; -var _162=den?num/den:0; -if(this.errorBars_){ +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]; +} +var date=_184[i][0]; +var _190=den?num/den:0; +if(this.attr_("errorBars")){ if(this.wilsonInterval_){ if(den){ -var p=_162<0?0:_162,n=den; -var pm=_159*Math.sqrt(p*(1-p)/n+_159*_159/(4*n*n)); -var _165=1+_159*_159/den; -var low=(p+_159*_159/(2*den)-pm)/_165; -var high=(p+_159*_159/(2*den)+pm)/_165; -_158[i]=[date,[p*mult,(p-low)*mult,(high-p)*mult]]; +var p=_190<0?0:_190,n=den; +var pm=_187*Math.sqrt(p*(1-p)/n+_187*_187/(4*n*n)); +var _193=1+_187*_187/den; +var low=(p+_187*_187/(2*den)-pm)/_193; +var high=(p+_187*_187/(2*den)+pm)/_193; +_186[i]=[date,[p*mult,(p-low)*mult,(high-p)*mult]]; }else{ -_158[i]=[date,[0,0,0]]; +_186[i]=[date,[0,0,0]]; } }else{ -var _166=den?_159*Math.sqrt(_162*(1-_162)/den):1; -_158[i]=[date,[mult*_162,mult*_166,mult*_166]]; +var _194=den?_187*Math.sqrt(_190*(1-_190)/den):1; +_186[i]=[date,[mult*_190,mult*_194,mult*_194]]; } }else{ -_158[i]=[date,mult*_162]; +_186[i]=[date,mult*_190]; } } }else{ if(this.customBars_){ -for(var i=0;i<_156.length;i++){ -var data=_156[i][1]; +var low=0; +var mid=0; +var high=0; +var _196=0; +for(var i=0;i<_184.length;i++){ +var data=_184[i][1]; var y=data[1]; -_158[i]=[_156[i][0],[y,y-data[0],data[2]-y]]; -} -}else{ -var _167=Math.min(_157-1,_156.length-2); -if(!this.errorBars_){ -for(var i=0;i<_167;i++){ +_186[i]=[_184[i][0],[y,y-data[0],data[2]-y]]; +low+=data[0]; +mid+=y; +high+=data[2]; +_196+=1; +if(i-_185>=0){ +var prev=_184[i-_185]; +low-=prev[1][0]; +mid-=prev[1][1]; +high-=prev[1][2]; +_196-=1; +} +_186[i]=[_184[i][0],[1*mid/_196,1*(mid-low)/_196,1*(high-mid)/_196]]; +} +}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;j=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; +}; +this.attrs_.xValueParser=function(x){ +return parseFloat(x); }; -DateGraph.prototype.parseCSV_=function(data){ +this.attrs_.xTicker=Dygraph.numericTicks; +} +}; +Dygraph.prototype.parseCSV_=function(data){ var ret=[]; -var _173=data.split("\n"); -var _174=this.labelsFromCSV_?1:0; +var _205=data.split("\n"); +var _206=0; if(this.labelsFromCSV_){ -var _175=_173[0].split(","); -_175.shift(); -this.labels_=_175; -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=_174;i<_173.length;i++){ -var line=_173[i]; +_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; } -var _177=line.split(","); -if(_177.length<2){ +var _211=line.split(","); +if(_211.length<2){ continue; } -var _178=[]; -_178[0]=this.xValueParser_(_177[0]); +var _212=[]; +if(!_208){ +this.detectTypeFromString_(_211[0]); +_207=this.attr_("xValueParser"); +_208=true; +} +_212[0]=_207(_211[0],this); if(this.fractions_){ -for(var j=1;j<_177.length;j++){ -var vals=_177[j].split("/"); -_178[j]=[parseFloat(vals[0]),parseFloat(vals[1])]; +for(var j=1;j<_211.length;j++){ +var vals=_211[j].split("/"); +_212[j]=[parseFloat(vals[0]),parseFloat(vals[1])]; } }else{ -if(this.errorBars_){ -for(var j=1;j<_177.length;j+=2){ -_178[(j+1)/2]=[parseFloat(_177[j]),parseFloat(_177[j+1])]; +if(this.attr_("errorBars")){ +for(var j=1;j<_211.length;j+=2){ +_212[(j+1)/2]=[parseFloat(_211[j]),parseFloat(_211[j+1])]; } }else{ if(this.customBars_){ -for(var j=1;j<_177.length;j++){ -var vals=_177[j].split(";"); -_178[j]=[parseFloat(vals[0]),parseFloat(vals[1]),parseFloat(vals[2])]; +for(var j=1;j<_211.length;j++){ +var vals=_211[j].split(";"); +_212[j]=[parseFloat(vals[0]),parseFloat(vals[1]),parseFloat(vals[2])]; +} +}else{ +for(var j=1;j<_211.length;j++){ +_212[j]=parseFloat(_211[j]); +} +} +} +} +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); +} +} +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 _180=this; +var _220=this; req.onreadystatechange=function(){ if(req.readyState==4){ if(req.status==200){ -_180.loadedEvent_(req.responseText); +_220.loadedEvent_(req.responseText); } } }; req.open("GET",this.file_,true); req.send(null); } -}; -DateGraph.prototype.updateOptions=function(_181){ -if(_181.errorBars){ -this.errorBars_=_181.errorBars; +}else{ +this.error("Unknown data format: "+(typeof this.file_)); } -if(_181.customBars){ -this.customBars_=_181.customBars; } -if(_181.strokeWidth){ -this.strokeWidth_=_181.strokeWidth; } -if(_181.rollPeriod){ -this.rollPeriod_=_181.rollPeriod; } -if(_181.dateWindow){ -this.dateWindow_=_181.dateWindow; +}; +Dygraph.prototype.updateOptions=function(_221){ +if(_221.customBars){ +this.customBars_=_221.customBars; } -if(_181.valueRange){ -this.valueRange_=_181.valueRange; +if(_221.rollPeriod){ +this.rollPeriod_=_221.rollPeriod; } -if(_181.minTickSize){ -this.minTickSize_=_181.minTickSize; +if(_221.dateWindow){ +this.dateWindow_=_221.dateWindow; } -if(typeof (_181.labels)!="undefined"){ -this.labels_=_181.labels; -this.labelsFromCSV_=(_181.labels==null); +if(_221.valueRange){ +this.valueRange_=_221.valueRange; } -this.layout_.updateOptions({"errorBars":this.errorBars_}); -if(_181["file"]&&_181["file"]!=this.file_){ -this.file_=_181["file"]; +MochiKit.Base.update(this.user_attrs_,_221); +this.labelsFromCSV_=(this.attr_("labels")==null); +this.layout_.updateOptions({"errorBars":this.attr_("errorBars")}); +if(_221["file"]&&_221["file"]!=this.file_){ +this.file_=_221["file"]; this.start_(); }else{ this.drawGraph_(this.rawData_); } }; -DateGraph.prototype.adjustRoll=function(_182){ -this.rollPeriod_=_182; +Dygraph.prototype.adjustRoll=function(_222){ +this.rollPeriod_=_222; this.drawGraph_(this.rawData_); }; +Dygraph.GVizChart=function(_223){ +this.container=_223; +}; +Dygraph.GVizChart.prototype.draw=function(data,_224){ +this.container.innerHTML=""; +this.date_graph=new Dygraph(this.container,data,_224); +}; +DateGraph=Dygraph;