jqplot-on-rails 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +22 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +22 -0
- data/README.md +31 -0
- data/Rakefile +2 -0
- data/jqplot-on-rails.gemspec +20 -0
- data/lib/jqplot-on-rails/version.rb +5 -0
- data/lib/jqplot-on-rails.rb +8 -0
- data/vendor/assets/javascripts/jqplot/excanvas.js +1438 -0
- data/vendor/assets/javascripts/jqplot/jquery.jqplot.js +11411 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.BezierCurveRenderer.js +314 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.BezierCurveRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.barRenderer.js +801 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.barRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.blockRenderer.js +235 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.blockRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.bubbleRenderer.js +759 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.bubbleRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasAxisLabelRenderer.js +203 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasAxisLabelRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasAxisTickRenderer.js +253 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasAxisTickRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasOverlay.js +1021 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasOverlay.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasTextRenderer.js +449 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.canvasTextRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.categoryAxisRenderer.js +679 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.categoryAxisRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.ciParser.js +116 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.ciParser.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.cursor.js +1108 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.cursor.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.dateAxisRenderer.js +741 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.dateAxisRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.donutRenderer.js +805 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.donutRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.dragable.js +225 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.dragable.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.enhancedLegendRenderer.js +305 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.enhancedLegendRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.funnelRenderer.js +943 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.funnelRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.highlighter.js +465 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.highlighter.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.json2.js +475 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.json2.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.logAxisRenderer.js +534 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.logAxisRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mekkoAxisRenderer.js +611 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mekkoAxisRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mekkoRenderer.js +437 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mekkoRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.meterGaugeRenderer.js +1029 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.meterGaugeRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mobile.js +45 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.mobile.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.ohlcRenderer.js +373 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.ohlcRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pieRenderer.js +904 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pieRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pointLabels.js +377 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pointLabels.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidAxisRenderer.js +728 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidAxisRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidGridRenderer.js +429 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidGridRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidRenderer.js +514 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.pyramidRenderer.min.js +3 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.trendline.js +223 -0
- data/vendor/assets/javascripts/jqplot/plugins/jqplot.trendline.min.js +3 -0
- data/vendor/assets/stylesheets/jquery.jqplot.css +259 -0
- metadata +128 -0
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/* jqPlot 1.0.8r1250 | (c) 2009-2013 Chris Leonello | jplot.com
|
|
2
|
+
jsDate | (c) 2010-2013 Chris Leonello
|
|
3
|
+
*/(function(d){d.jqplot.BarRenderer=function(){d.jqplot.LineRenderer.call(this)};d.jqplot.BarRenderer.prototype=new d.jqplot.LineRenderer();d.jqplot.BarRenderer.prototype.constructor=d.jqplot.BarRenderer;d.jqplot.BarRenderer.prototype.init=function(o,q){this.barPadding=8;this.barMargin=10;this.barDirection="vertical";this.barWidth=null;this.shadowOffset=2;this.shadowDepth=5;this.shadowAlpha=0.08;this.waterfall=false;this.groups=1;this.varyBarColor=false;this.highlightMouseOver=true;this.highlightMouseDown=false;this.highlightColors=[];this.transposedData=true;this.renderer.animation={show:false,direction:"down",speed:3000,_supported:true};this._type="bar";if(o.highlightMouseDown&&o.highlightMouseOver==null){o.highlightMouseOver=false}d.extend(true,this,o);d.extend(true,this.renderer,o);this.fill=true;if(this.barDirection==="horizontal"&&this.rendererOptions.animation&&this.rendererOptions.animation.direction==null){this.renderer.animation.direction="left"}if(this.waterfall){this.fillToZero=false;this.disableStack=true}if(this.barDirection=="vertical"){this._primaryAxis="_xaxis";this._stackAxis="y";this.fillAxis="y"}else{this._primaryAxis="_yaxis";this._stackAxis="x";this.fillAxis="x"}this._highlightedPoint=null;this._plotSeriesInfo=null;this._dataColors=[];this._barPoints=[];var p={lineJoin:"miter",lineCap:"round",fill:true,isarc:false,strokeStyle:this.color,fillStyle:this.color,closePath:this.fill};this.renderer.shapeRenderer.init(p);var n={lineJoin:"miter",lineCap:"round",fill:true,isarc:false,angle:this.shadowAngle,offset:this.shadowOffset,alpha:this.shadowAlpha,depth:this.shadowDepth,closePath:this.fill};this.renderer.shadowRenderer.init(n);q.postInitHooks.addOnce(h);q.postDrawHooks.addOnce(j);q.eventListenerHooks.addOnce("jqplotMouseMove",b);q.eventListenerHooks.addOnce("jqplotMouseDown",a);q.eventListenerHooks.addOnce("jqplotMouseUp",l);q.eventListenerHooks.addOnce("jqplotClick",e);q.eventListenerHooks.addOnce("jqplotRightClick",m)};function g(t,p,o,w){if(this.rendererOptions.barDirection=="horizontal"){this._stackAxis="x";this._primaryAxis="_yaxis"}if(this.rendererOptions.waterfall==true){this._data=d.extend(true,[],this.data);var s=0;var u=(!this.rendererOptions.barDirection||this.rendererOptions.barDirection==="vertical"||this.transposedData===false)?1:0;for(var q=0;q<this.data.length;q++){s+=this.data[q][u];if(q>0){this.data[q][u]+=this.data[q-1][u]}}this.data[this.data.length]=(u==1)?[this.data.length+1,s]:[s,this.data.length+1];this._data[this._data.length]=(u==1)?[this._data.length+1,s]:[s,this._data.length+1]}if(this.rendererOptions.groups>1){this.breakOnNull=true;var n=this.data.length;var v=parseInt(n/this.rendererOptions.groups,10);var r=0;for(var q=v;q<n;q+=v){this.data.splice(q+r,0,[null,null]);this._plotData.splice(q+r,0,[null,null]);this._stackData.splice(q+r,0,[null,null]);r++}for(q=0;q<this.data.length;q++){if(this._primaryAxis=="_xaxis"){this.data[q][0]=q+1;this._plotData[q][0]=q+1;this._stackData[q][0]=q+1}else{this.data[q][1]=q+1;this._plotData[q][1]=q+1;this._stackData[q][1]=q+1}}}}d.jqplot.preSeriesInitHooks.push(g);d.jqplot.BarRenderer.prototype.calcSeriesNumbers=function(){var r=0;var t=0;var q=this[this._primaryAxis];var p,o,u;for(var n=0;n<q._series.length;n++){o=q._series[n];if(o===this){u=n}if(o.renderer.constructor==d.jqplot.BarRenderer){r+=o.data.length;t+=1}}return[r,t,u]};d.jqplot.BarRenderer.prototype.setBarWidth=function(){var q;var n=0;var o=0;var t=this[this._primaryAxis];var x,r,v;var w=this._plotSeriesInfo=this.renderer.calcSeriesNumbers.call(this);n=w[0];o=w[1];var u=t.numberTicks;var p=(u-1)/2;if(t.name=="xaxis"||t.name=="x2axis"){if(this._stack){this.barWidth=(t._offsets.max-t._offsets.min)/n*o-this.barMargin}else{this.barWidth=((t._offsets.max-t._offsets.min)/p-this.barPadding*(o-1)-this.barMargin*2)/o}}else{if(this._stack){this.barWidth=(t._offsets.min-t._offsets.max)/n*o-this.barMargin}else{this.barWidth=((t._offsets.min-t._offsets.max)/p-this.barPadding*(o-1)-this.barMargin*2)/o}}return[n,o]};function f(o){var q=[];for(var s=0;s<o.length;s++){var r=d.jqplot.getColorComponents(o[s]);var n=[r[0],r[1],r[2]];var t=n[0]+n[1]+n[2];for(var p=0;p<3;p++){n[p]=(t>570)?n[p]*0.8:n[p]+0.3*(255-n[p]);n[p]=parseInt(n[p],10)}q.push("rgb("+n[0]+","+n[1]+","+n[2]+")")}return q}function i(v,u,s,t,o){var q=v,w=v-1,n,p,r=(o==="x")?0:1;if(q>0){p=t.series[w]._plotData[u][r];if((s*p)<0){n=i(w,u,s,t,o)}else{n=t.series[w].gridData[u][r]}}else{n=(r===0)?t.series[q]._xaxis.series_u2p(0):t.series[q]._yaxis.series_u2p(0)}return n}d.jqplot.BarRenderer.prototype.draw=function(E,L,q,G){var I;var A=d.extend({},q);var w=(A.shadow!=undefined)?A.shadow:this.shadow;var O=(A.showLine!=undefined)?A.showLine:this.showLine;var F=(A.fill!=undefined)?A.fill:this.fill;var p=this.xaxis;var J=this.yaxis;var y=this._xaxis.series_u2p;var K=this._yaxis.series_u2p;var D,C;this._dataColors=[];this._barPoints=[];if(this.barWidth==null){this.renderer.setBarWidth.call(this)}var N=this._plotSeriesInfo=this.renderer.calcSeriesNumbers.call(this);var x=N[0];var v=N[1];var s=N[2];var H=[];if(this._stack){this._barNudge=0}else{this._barNudge=(-Math.abs(v/2-0.5)+s)*(this.barWidth+this.barPadding)}if(O){var u=new d.jqplot.ColorGenerator(this.negativeSeriesColors);var B=new d.jqplot.ColorGenerator(this.seriesColors);var M=u.get(this.index);if(!this.useNegativeColors){M=A.fillStyle}var t=A.fillStyle;var r;var P;var o;if(this.barDirection=="vertical"){for(var I=0;I<L.length;I++){if(!this._stack&&this.data[I][1]==null){continue}H=[];r=L[I][0]+this._barNudge;if(this._stack&&this._prevGridData.length){o=i(this.index,I,this._plotData[I][1],G,"y")}else{if(this.fillToZero){o=this._yaxis.series_u2p(0)}else{if(this.waterfall&&I>0&&I<this.gridData.length-1){o=this.gridData[I-1][1]}else{if(this.waterfall&&I==0&&I<this.gridData.length-1){if(this._yaxis.min<=0&&this._yaxis.max>=0){o=this._yaxis.series_u2p(0)}else{if(this._yaxis.min>0){o=E.canvas.height}else{o=0}}}else{if(this.waterfall&&I==this.gridData.length-1){if(this._yaxis.min<=0&&this._yaxis.max>=0){o=this._yaxis.series_u2p(0)}else{if(this._yaxis.min>0){o=E.canvas.height}else{o=0}}}else{o=E.canvas.height}}}}}if((this.fillToZero&&this._plotData[I][1]<0)||(this.waterfall&&this._data[I][1]<0)){if(this.varyBarColor&&!this._stack){if(this.useNegativeColors){A.fillStyle=u.next()}else{A.fillStyle=B.next()}}else{A.fillStyle=M}}else{if(this.varyBarColor&&!this._stack){A.fillStyle=B.next()}else{A.fillStyle=t}}if(!this.fillToZero||this._plotData[I][1]>=0){H.push([r-this.barWidth/2,o]);H.push([r-this.barWidth/2,L[I][1]]);H.push([r+this.barWidth/2,L[I][1]]);H.push([r+this.barWidth/2,o])}else{H.push([r-this.barWidth/2,L[I][1]]);H.push([r-this.barWidth/2,o]);H.push([r+this.barWidth/2,o]);H.push([r+this.barWidth/2,L[I][1]])}this._barPoints.push(H);if(w&&!this._stack){var z=d.extend(true,{},A);delete z.fillStyle;this.renderer.shadowRenderer.draw(E,H,z)}var n=A.fillStyle||this.color;this._dataColors.push(n);this.renderer.shapeRenderer.draw(E,H,A)}}else{if(this.barDirection=="horizontal"){for(var I=0;I<L.length;I++){if(!this._stack&&this.data[I][0]==null){continue}H=[];r=L[I][1]-this._barNudge;P;if(this._stack&&this._prevGridData.length){P=i(this.index,I,this._plotData[I][0],G,"x")}else{if(this.fillToZero){P=this._xaxis.series_u2p(0)}else{if(this.waterfall&&I>0&&I<this.gridData.length-1){P=this.gridData[I-1][0]}else{if(this.waterfall&&I==0&&I<this.gridData.length-1){if(this._xaxis.min<=0&&this._xaxis.max>=0){P=this._xaxis.series_u2p(0)}else{if(this._xaxis.min>0){P=0}else{P=0}}}else{if(this.waterfall&&I==this.gridData.length-1){if(this._xaxis.min<=0&&this._xaxis.max>=0){P=this._xaxis.series_u2p(0)}else{if(this._xaxis.min>0){P=0}else{P=E.canvas.width}}}else{P=0}}}}}if((this.fillToZero&&this._plotData[I][0]<0)||(this.waterfall&&this._data[I][0]<0)){if(this.varyBarColor&&!this._stack){if(this.useNegativeColors){A.fillStyle=u.next()}else{A.fillStyle=B.next()}}else{A.fillStyle=M}}else{if(this.varyBarColor&&!this._stack){A.fillStyle=B.next()}else{A.fillStyle=t}}if(!this.fillToZero||this._plotData[I][0]>=0){H.push([P,r+this.barWidth/2]);H.push([P,r-this.barWidth/2]);H.push([L[I][0],r-this.barWidth/2]);H.push([L[I][0],r+this.barWidth/2])}else{H.push([L[I][0],r+this.barWidth/2]);H.push([L[I][0],r-this.barWidth/2]);H.push([P,r-this.barWidth/2]);H.push([P,r+this.barWidth/2])}this._barPoints.push(H);if(w&&!this._stack){var z=d.extend(true,{},A);delete z.fillStyle;this.renderer.shadowRenderer.draw(E,H,z)}var n=A.fillStyle||this.color;this._dataColors.push(n);this.renderer.shapeRenderer.draw(E,H,A)}}}}if(this.highlightColors.length==0){this.highlightColors=d.jqplot.computeHighlightColors(this._dataColors)}else{if(typeof(this.highlightColors)=="string"){var N=this.highlightColors;this.highlightColors=[];for(var I=0;I<this._dataColors.length;I++){this.highlightColors.push(N)}}}};d.jqplot.BarRenderer.prototype.drawShadow=function(z,G,p,B){var D;var w=(p!=undefined)?p:{};var t=(w.shadow!=undefined)?w.shadow:this.shadow;var I=(w.showLine!=undefined)?w.showLine:this.showLine;var A=(w.fill!=undefined)?w.fill:this.fill;var o=this.xaxis;var E=this.yaxis;var v=this._xaxis.series_u2p;var F=this._yaxis.series_u2p;var y,C,x,u,s,r;if(this._stack&&this.shadow){if(this.barWidth==null){this.renderer.setBarWidth.call(this)}var H=this._plotSeriesInfo=this.renderer.calcSeriesNumbers.call(this);u=H[0];s=H[1];r=H[2];if(this._stack){this._barNudge=0}else{this._barNudge=(-Math.abs(s/2-0.5)+r)*(this.barWidth+this.barPadding)}if(I){if(this.barDirection=="vertical"){for(var D=0;D<G.length;D++){if(this.data[D][1]==null){continue}C=[];var q=G[D][0]+this._barNudge;var n;if(this._stack&&this._prevGridData.length){n=i(this.index,D,this._plotData[D][1],B,"y")}else{if(this.fillToZero){n=this._yaxis.series_u2p(0)}else{n=z.canvas.height}}C.push([q-this.barWidth/2,n]);C.push([q-this.barWidth/2,G[D][1]]);C.push([q+this.barWidth/2,G[D][1]]);C.push([q+this.barWidth/2,n]);this.renderer.shadowRenderer.draw(z,C,w)}}else{if(this.barDirection=="horizontal"){for(var D=0;D<G.length;D++){if(this.data[D][0]==null){continue}C=[];var q=G[D][1]-this._barNudge;var J;if(this._stack&&this._prevGridData.length){J=i(this.index,D,this._plotData[D][0],B,"x")}else{if(this.fillToZero){J=this._xaxis.series_u2p(0)}else{J=0}}C.push([J,q+this.barWidth/2]);C.push([G[D][0],q+this.barWidth/2]);C.push([G[D][0],q-this.barWidth/2]);C.push([J,q-this.barWidth/2]);this.renderer.shadowRenderer.draw(z,C,w)}}}}}};function h(q,p,n){for(var o=0;o<this.series.length;o++){if(this.series[o].renderer.constructor==d.jqplot.BarRenderer){if(this.series[o].highlightMouseOver){this.series[o].highlightMouseDown=false}}}}function j(){if(this.plugins.barRenderer&&this.plugins.barRenderer.highlightCanvas){this.plugins.barRenderer.highlightCanvas.resetCanvas();this.plugins.barRenderer.highlightCanvas=null}this.plugins.barRenderer={highlightedSeriesIndex:null};this.plugins.barRenderer.highlightCanvas=new d.jqplot.GenericCanvas();this.eventCanvas._elem.before(this.plugins.barRenderer.highlightCanvas.createElement(this._gridPadding,"jqplot-barRenderer-highlight-canvas",this._plotDimensions,this));this.plugins.barRenderer.highlightCanvas.setContext();this.eventCanvas._elem.bind("mouseleave",{plot:this},function(n){k(n.data.plot)})}function c(u,t,q,p){var o=u.series[t];var n=u.plugins.barRenderer.highlightCanvas;n._ctx.clearRect(0,0,n._ctx.canvas.width,n._ctx.canvas.height);o._highlightedPoint=q;u.plugins.barRenderer.highlightedSeriesIndex=t;var r={fillStyle:o.highlightColors[q]};o.renderer.shapeRenderer.draw(n._ctx,p,r);n=null}function k(p){var n=p.plugins.barRenderer.highlightCanvas;n._ctx.clearRect(0,0,n._ctx.canvas.width,n._ctx.canvas.height);for(var o=0;o<p.series.length;o++){p.series[o]._highlightedPoint=null}p.plugins.barRenderer.highlightedSeriesIndex=null;p.target.trigger("jqplotDataUnhighlight");n=null}function b(r,q,u,t,s){if(t){var p=[t.seriesIndex,t.pointIndex,t.data];var o=jQuery.Event("jqplotDataMouseOver");o.pageX=r.pageX;o.pageY=r.pageY;s.target.trigger(o,p);if(s.series[p[0]].show&&s.series[p[0]].highlightMouseOver&&!(p[0]==s.plugins.barRenderer.highlightedSeriesIndex&&p[1]==s.series[p[0]]._highlightedPoint)){var n=jQuery.Event("jqplotDataHighlight");n.which=r.which;n.pageX=r.pageX;n.pageY=r.pageY;s.target.trigger(n,p);c(s,t.seriesIndex,t.pointIndex,t.points)}}else{if(t==null){k(s)}}}function a(q,p,t,s,r){if(s){var o=[s.seriesIndex,s.pointIndex,s.data];if(r.series[o[0]].highlightMouseDown&&!(o[0]==r.plugins.barRenderer.highlightedSeriesIndex&&o[1]==r.series[o[0]]._highlightedPoint)){var n=jQuery.Event("jqplotDataHighlight");n.which=q.which;n.pageX=q.pageX;n.pageY=q.pageY;r.target.trigger(n,o);c(r,s.seriesIndex,s.pointIndex,s.points)}}else{if(s==null){k(r)}}}function l(p,o,s,r,q){var n=q.plugins.barRenderer.highlightedSeriesIndex;if(n!=null&&q.series[n].highlightMouseDown){k(q)}}function e(q,p,t,s,r){if(s){var o=[s.seriesIndex,s.pointIndex,s.data];var n=jQuery.Event("jqplotDataClick");n.which=q.which;n.pageX=q.pageX;n.pageY=q.pageY;r.target.trigger(n,o)}}function m(r,q,u,t,s){if(t){var p=[t.seriesIndex,t.pointIndex,t.data];var n=s.plugins.barRenderer.highlightedSeriesIndex;if(n!=null&&s.series[n].highlightMouseDown){k(s)}var o=jQuery.Event("jqplotDataRightClick");o.which=r.which;o.pageX=r.pageX;o.pageY=r.pageY;s.target.trigger(o,p)}}})(jQuery);
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* jqPlot
|
|
3
|
+
* Pure JavaScript plotting plugin using jQuery
|
|
4
|
+
*
|
|
5
|
+
* Version: 1.0.8
|
|
6
|
+
* Revision: 1250
|
|
7
|
+
*
|
|
8
|
+
* Copyright (c) 2009-2013 Chris Leonello
|
|
9
|
+
* jqPlot is currently available for use in all personal or commercial projects
|
|
10
|
+
* under both the MIT (http://www.opensource.org/licenses/mit-license.php) and GPL
|
|
11
|
+
* version 2.0 (http://www.gnu.org/licenses/gpl-2.0.html) licenses. This means that you can
|
|
12
|
+
* choose the license that best suits your project and use it accordingly.
|
|
13
|
+
*
|
|
14
|
+
* Although not required, the author would appreciate an email letting him
|
|
15
|
+
* know of any substantial use of jqPlot. You can reach the author at:
|
|
16
|
+
* chris at jqplot dot com or see http://www.jqplot.com/info.php .
|
|
17
|
+
*
|
|
18
|
+
* If you are feeling kind and generous, consider supporting the project by
|
|
19
|
+
* making a donation at: http://www.jqplot.com/donate.php .
|
|
20
|
+
*
|
|
21
|
+
* sprintf functions contained in jqplot.sprintf.js by Ash Searle:
|
|
22
|
+
*
|
|
23
|
+
* version 2007.04.27
|
|
24
|
+
* author Ash Searle
|
|
25
|
+
* http://hexmen.com/blog/2007/03/printf-sprintf/
|
|
26
|
+
* http://hexmen.com/js/sprintf.js
|
|
27
|
+
* The author (Ash Searle) has placed this code in the public domain:
|
|
28
|
+
* "This code is unrestricted: you are free to use it however you like."
|
|
29
|
+
*
|
|
30
|
+
*/
|
|
31
|
+
(function($) {
|
|
32
|
+
/**
|
|
33
|
+
* Class: $.jqplot.BlockRenderer
|
|
34
|
+
* Plugin renderer to draw a x-y block chart. A Block chart has data points displayed as
|
|
35
|
+
* colored squares with a text label inside. Data must be supplied in the form:
|
|
36
|
+
*
|
|
37
|
+
* > [[x1, y1, "label 1", {css}], [x2, y2, "label 2", {css}], ...]
|
|
38
|
+
*
|
|
39
|
+
* The label and css object are optional. If the label is ommitted, the
|
|
40
|
+
* box will collapse unless a css height and/or width is specified.
|
|
41
|
+
*
|
|
42
|
+
* The css object is an object specifying css properties
|
|
43
|
+
* such as:
|
|
44
|
+
*
|
|
45
|
+
* > {background:'#4f98a5', border:'3px solid gray', padding:'1px'}
|
|
46
|
+
*
|
|
47
|
+
* Note that css properties specified with the data point override defaults
|
|
48
|
+
* specified with the series.
|
|
49
|
+
*
|
|
50
|
+
*/
|
|
51
|
+
$.jqplot.BlockRenderer = function(){
|
|
52
|
+
$.jqplot.LineRenderer.call(this);
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
$.jqplot.BlockRenderer.prototype = new $.jqplot.LineRenderer();
|
|
56
|
+
$.jqplot.BlockRenderer.prototype.constructor = $.jqplot.BlockRenderer;
|
|
57
|
+
|
|
58
|
+
// called with scope of a series
|
|
59
|
+
$.jqplot.BlockRenderer.prototype.init = function(options) {
|
|
60
|
+
// Group: Properties
|
|
61
|
+
//
|
|
62
|
+
// prop: css
|
|
63
|
+
// default css styles that will be applied to all data blocks.
|
|
64
|
+
// these values will be overridden by css styles supplied with the
|
|
65
|
+
// individulal data points.
|
|
66
|
+
this.css = {padding:'2px', border:'1px solid #999', textAlign:'center'};
|
|
67
|
+
// prop: escapeHtml
|
|
68
|
+
// true to escape html in the box label.
|
|
69
|
+
this.escapeHtml = false;
|
|
70
|
+
// prop: insertBreaks
|
|
71
|
+
// true to turn spaces in data block label into html breaks <br />.
|
|
72
|
+
this.insertBreaks = true;
|
|
73
|
+
// prop: varyBlockColors
|
|
74
|
+
// true to vary the color of each block in this series according to
|
|
75
|
+
// the seriesColors array. False to set each block to the color
|
|
76
|
+
// specified on this series. This has no effect if a css background color
|
|
77
|
+
// option is specified in the renderer css options.
|
|
78
|
+
this.varyBlockColors = false;
|
|
79
|
+
$.extend(true, this, options);
|
|
80
|
+
if (this.css.backgroundColor) {
|
|
81
|
+
this.color = this.css.backgroundColor;
|
|
82
|
+
}
|
|
83
|
+
else if (this.css.background) {
|
|
84
|
+
this.color = this.css.background;
|
|
85
|
+
}
|
|
86
|
+
else if (!this.varyBlockColors) {
|
|
87
|
+
this.css.background = this.color;
|
|
88
|
+
}
|
|
89
|
+
this.canvas = new $.jqplot.BlockCanvas();
|
|
90
|
+
this.shadowCanvas = new $.jqplot.BlockCanvas();
|
|
91
|
+
this.canvas._plotDimensions = this._plotDimensions;
|
|
92
|
+
this.shadowCanvas._plotDimensions = this._plotDimensions;
|
|
93
|
+
this._type = 'block';
|
|
94
|
+
|
|
95
|
+
// group: Methods
|
|
96
|
+
//
|
|
97
|
+
// Method: moveBlock
|
|
98
|
+
// Moves an individual block. More efficient than redrawing
|
|
99
|
+
// the whole series by calling plot.drawSeries().
|
|
100
|
+
// Properties:
|
|
101
|
+
// idx - the 0 based index of the block or point in this series.
|
|
102
|
+
// x - the x coordinate in data units (value on x axis) to move the block to.
|
|
103
|
+
// y - the y coordinate in data units (value on the y axis) to move the block to.
|
|
104
|
+
// duration - optional parameter to create an animated movement. Can be a
|
|
105
|
+
// number (higher is slower animation) or 'fast', 'normal' or 'slow'. If not
|
|
106
|
+
// provided, the element is moved without any animation.
|
|
107
|
+
this.moveBlock = function (idx, x, y, duration) {
|
|
108
|
+
// update plotData, stackData, data and gridData
|
|
109
|
+
// x and y are in data coordinates.
|
|
110
|
+
var el = this.canvas._elem.children(':eq('+idx+')');
|
|
111
|
+
this.data[idx][0] = x;
|
|
112
|
+
this.data[idx][1] = y;
|
|
113
|
+
this._plotData[idx][0] = x;
|
|
114
|
+
this._plotData[idx][1] = y;
|
|
115
|
+
this._stackData[idx][0] = x;
|
|
116
|
+
this._stackData[idx][1] = y;
|
|
117
|
+
this.gridData[idx][0] = this._xaxis.series_u2p(x);
|
|
118
|
+
this.gridData[idx][1] = this._yaxis.series_u2p(y);
|
|
119
|
+
var w = el.outerWidth();
|
|
120
|
+
var h = el.outerHeight();
|
|
121
|
+
var left = this.gridData[idx][0] - w/2 + 'px';
|
|
122
|
+
var top = this.gridData[idx][1] - h/2 + 'px';
|
|
123
|
+
if (duration) {
|
|
124
|
+
if (parseInt(duration, 10)) {
|
|
125
|
+
duration = parseInt(duration, 10);
|
|
126
|
+
}
|
|
127
|
+
el.animate({left:left, top:top}, duration);
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
el.css({left:left, top:top});
|
|
131
|
+
}
|
|
132
|
+
el = null;
|
|
133
|
+
};
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
// called with scope of series
|
|
137
|
+
$.jqplot.BlockRenderer.prototype.draw = function (ctx, gd, options) {
|
|
138
|
+
if (this.plugins.pointLabels) {
|
|
139
|
+
this.plugins.pointLabels.show = false;
|
|
140
|
+
}
|
|
141
|
+
var i, el, d, gd, t, css, w, h, left, top;
|
|
142
|
+
var opts = (options != undefined) ? options : {};
|
|
143
|
+
var colorGenerator = new $.jqplot.ColorGenerator(this.seriesColors);
|
|
144
|
+
this.canvas._elem.empty();
|
|
145
|
+
for (i=0; i<this.gridData.length; i++) {
|
|
146
|
+
d = this.data[i];
|
|
147
|
+
gd = this.gridData[i];
|
|
148
|
+
t = '';
|
|
149
|
+
css = {};
|
|
150
|
+
if (typeof d[2] == 'string') {
|
|
151
|
+
t = d[2];
|
|
152
|
+
}
|
|
153
|
+
else if (typeof d[2] == 'object') {
|
|
154
|
+
css = d[2];
|
|
155
|
+
}
|
|
156
|
+
if (typeof d[3] == 'object') {
|
|
157
|
+
css = d[3];
|
|
158
|
+
}
|
|
159
|
+
if (this.insertBreaks){
|
|
160
|
+
t = t.replace(/ /g, '<br />');
|
|
161
|
+
}
|
|
162
|
+
css = $.extend(true, {}, this.css, css);
|
|
163
|
+
// create a div
|
|
164
|
+
el = $('<div style="position:absolute;margin-left:auto;margin-right:auto;"></div>');
|
|
165
|
+
this.canvas._elem.append(el);
|
|
166
|
+
// set text
|
|
167
|
+
this.escapeHtml ? el.text(t) : el.html(t);
|
|
168
|
+
// style it
|
|
169
|
+
// remove styles we don't want overridden.
|
|
170
|
+
delete css.position;
|
|
171
|
+
delete css.marginRight;
|
|
172
|
+
delete css.marginLeft;
|
|
173
|
+
if (!css.background && !css.backgroundColor && !css.backgroundImage){
|
|
174
|
+
css.background = colorGenerator.next();
|
|
175
|
+
}
|
|
176
|
+
el.css(css);
|
|
177
|
+
w = el.outerWidth();
|
|
178
|
+
h = el.outerHeight();
|
|
179
|
+
left = gd[0] - w/2 + 'px';
|
|
180
|
+
top = gd[1] - h/2 + 'px';
|
|
181
|
+
el.css({left:left, top:top});
|
|
182
|
+
el = null;
|
|
183
|
+
}
|
|
184
|
+
};
|
|
185
|
+
|
|
186
|
+
$.jqplot.BlockCanvas = function() {
|
|
187
|
+
$.jqplot.ElemContainer.call(this);
|
|
188
|
+
this._ctx;
|
|
189
|
+
};
|
|
190
|
+
|
|
191
|
+
$.jqplot.BlockCanvas.prototype = new $.jqplot.ElemContainer();
|
|
192
|
+
$.jqplot.BlockCanvas.prototype.constructor = $.jqplot.BlockCanvas;
|
|
193
|
+
|
|
194
|
+
$.jqplot.BlockCanvas.prototype.createElement = function(offsets, clss, plotDimensions) {
|
|
195
|
+
this._offsets = offsets;
|
|
196
|
+
var klass = 'jqplot-blockCanvas';
|
|
197
|
+
if (clss != undefined) {
|
|
198
|
+
klass = clss;
|
|
199
|
+
}
|
|
200
|
+
var elem;
|
|
201
|
+
// if this canvas already has a dom element, don't make a new one.
|
|
202
|
+
if (this._elem) {
|
|
203
|
+
elem = this._elem.get(0);
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
elem = document.createElement('div');
|
|
207
|
+
}
|
|
208
|
+
// if new plotDimensions supplied, use them.
|
|
209
|
+
if (plotDimensions != undefined) {
|
|
210
|
+
this._plotDimensions = plotDimensions;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
var w = this._plotDimensions.width - this._offsets.left - this._offsets.right + 'px';
|
|
214
|
+
var h = this._plotDimensions.height - this._offsets.top - this._offsets.bottom + 'px';
|
|
215
|
+
this._elem = $(elem);
|
|
216
|
+
this._elem.css({ position: 'absolute', width:w, height:h, left: this._offsets.left, top: this._offsets.top });
|
|
217
|
+
|
|
218
|
+
this._elem.addClass(klass);
|
|
219
|
+
return this._elem;
|
|
220
|
+
};
|
|
221
|
+
|
|
222
|
+
$.jqplot.BlockCanvas.prototype.setContext = function() {
|
|
223
|
+
this._ctx = {
|
|
224
|
+
canvas:{
|
|
225
|
+
width:0,
|
|
226
|
+
height:0
|
|
227
|
+
},
|
|
228
|
+
clearRect:function(){return null;}
|
|
229
|
+
};
|
|
230
|
+
return this._ctx;
|
|
231
|
+
};
|
|
232
|
+
|
|
233
|
+
})(jQuery);
|
|
234
|
+
|
|
235
|
+
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/* jqPlot 1.0.8r1250 | (c) 2009-2013 Chris Leonello | jplot.com
|
|
2
|
+
jsDate | (c) 2010-2013 Chris Leonello
|
|
3
|
+
*/(function(a){a.jqplot.BlockRenderer=function(){a.jqplot.LineRenderer.call(this)};a.jqplot.BlockRenderer.prototype=new a.jqplot.LineRenderer();a.jqplot.BlockRenderer.prototype.constructor=a.jqplot.BlockRenderer;a.jqplot.BlockRenderer.prototype.init=function(b){this.css={padding:"2px",border:"1px solid #999",textAlign:"center"};this.escapeHtml=false;this.insertBreaks=true;this.varyBlockColors=false;a.extend(true,this,b);if(this.css.backgroundColor){this.color=this.css.backgroundColor}else{if(this.css.background){this.color=this.css.background}else{if(!this.varyBlockColors){this.css.background=this.color}}}this.canvas=new a.jqplot.BlockCanvas();this.shadowCanvas=new a.jqplot.BlockCanvas();this.canvas._plotDimensions=this._plotDimensions;this.shadowCanvas._plotDimensions=this._plotDimensions;this._type="block";this.moveBlock=function(l,j,i,e){var c=this.canvas._elem.children(":eq("+l+")");this.data[l][0]=j;this.data[l][1]=i;this._plotData[l][0]=j;this._plotData[l][1]=i;this._stackData[l][0]=j;this._stackData[l][1]=i;this.gridData[l][0]=this._xaxis.series_u2p(j);this.gridData[l][1]=this._yaxis.series_u2p(i);var k=c.outerWidth();var f=c.outerHeight();var d=this.gridData[l][0]-k/2+"px";var g=this.gridData[l][1]-f/2+"px";if(e){if(parseInt(e,10)){e=parseInt(e,10)}c.animate({left:d,top:g},e)}else{c.css({left:d,top:g})}c=null}};a.jqplot.BlockRenderer.prototype.draw=function(q,o,r){if(this.plugins.pointLabels){this.plugins.pointLabels.show=false}var f,c,l,o,p,k,n,g,e,m;var b=(r!=undefined)?r:{};var j=new a.jqplot.ColorGenerator(this.seriesColors);this.canvas._elem.empty();for(f=0;f<this.gridData.length;f++){l=this.data[f];o=this.gridData[f];p="";k={};if(typeof l[2]=="string"){p=l[2]}else{if(typeof l[2]=="object"){k=l[2]}}if(typeof l[3]=="object"){k=l[3]}if(this.insertBreaks){p=p.replace(/ /g,"<br />")}k=a.extend(true,{},this.css,k);c=a('<div style="position:absolute;margin-left:auto;margin-right:auto;"></div>');this.canvas._elem.append(c);this.escapeHtml?c.text(p):c.html(p);delete k.position;delete k.marginRight;delete k.marginLeft;if(!k.background&&!k.backgroundColor&&!k.backgroundImage){k.background=j.next()}c.css(k);n=c.outerWidth();g=c.outerHeight();e=o[0]-n/2+"px";m=o[1]-g/2+"px";c.css({left:e,top:m});c=null}};a.jqplot.BlockCanvas=function(){a.jqplot.ElemContainer.call(this);this._ctx};a.jqplot.BlockCanvas.prototype=new a.jqplot.ElemContainer();a.jqplot.BlockCanvas.prototype.constructor=a.jqplot.BlockCanvas;a.jqplot.BlockCanvas.prototype.createElement=function(i,e,c){this._offsets=i;var b="jqplot-blockCanvas";if(e!=undefined){b=e}var g;if(this._elem){g=this._elem.get(0)}else{g=document.createElement("div")}if(c!=undefined){this._plotDimensions=c}var d=this._plotDimensions.width-this._offsets.left-this._offsets.right+"px";var f=this._plotDimensions.height-this._offsets.top-this._offsets.bottom+"px";this._elem=a(g);this._elem.css({position:"absolute",width:d,height:f,left:this._offsets.left,top:this._offsets.top});this._elem.addClass(b);return this._elem};a.jqplot.BlockCanvas.prototype.setContext=function(){this._ctx={canvas:{width:0,height:0},clearRect:function(){return null}};return this._ctx}})(jQuery);
|