sunrise-votes 0.1.1 → 0.1.2
Sign up to get free protection for your applications and to get access to all the features.
- data/README.rdoc +2 -4
- data/Rakefile +0 -22
- data/app/controllers/manage/ballot_box/votes_controller.rb +4 -0
- data/app/views/manage/ballot_box/votes/show.html.erb +211 -81
- data/lib/generators/sunrise/votes/install_generator.rb +1 -1
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/highcharts.js +170 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/highcharts.src.js +11428 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/modules/exporting.js +22 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/modules/exporting.src.js +711 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/themes/dark-blue.js +263 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/themes/dark-green.js +263 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/themes/gray.js +262 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/themes/grid.js +96 -0
- data/lib/generators/sunrise/votes/templates/javascripts/highcharts/themes/skies.js +89 -0
- data/lib/sunrise/votes/version.rb +1 -1
- metadata +33 -79
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/excanvas.min.js +0 -35
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/jquery.jqplot.css +0 -226
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/jquery.jqplot.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.BezierCurveRenderer.js +0 -312
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.BezierCurveRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.barRenderer.js +0 -702
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.barRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.blockRenderer.js +0 -234
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.blockRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.bubbleRenderer.js +0 -748
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.bubbleRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasAxisLabelRenderer.js +0 -199
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasAxisLabelRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasAxisTickRenderer.js +0 -238
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasAxisTickRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasOverlay.js +0 -614
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasOverlay.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasTextRenderer.js +0 -420
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.canvasTextRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.categoryAxisRenderer.js +0 -634
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.categoryAxisRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.ciParser.js +0 -115
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.ciParser.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.cursor.js +0 -1002
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.cursor.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.dateAxisRenderer.js +0 -439
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.dateAxisRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.donutRenderer.js +0 -904
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.donutRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.dragable.js +0 -218
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.dragable.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.enhancedLegendRenderer.js +0 -199
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.enhancedLegendRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.funnelRenderer.js +0 -932
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.funnelRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.highlighter.js +0 -406
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.highlighter.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.json2.js +0 -475
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.json2.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.logAxisRenderer.js +0 -446
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.logAxisRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.mekkoAxisRenderer.js +0 -607
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.mekkoAxisRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.mekkoRenderer.js +0 -432
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.mekkoRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.meterGaugeRenderer.js +0 -1142
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.meterGaugeRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.ohlcRenderer.js +0 -372
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.ohlcRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.pieRenderer.js +0 -797
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.pieRenderer.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.pointLabels.js +0 -337
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.pointLabels.min.js +0 -30
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.trendline.js +0 -220
- data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.trendline.min.js +0 -30
data/lib/generators/sunrise/votes/templates/javascripts/ballot_box/plugins/jqplot.cursor.min.js
DELETED
@@ -1,30 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* jqPlot
|
3
|
-
* Pure JavaScript plotting plugin using jQuery
|
4
|
-
*
|
5
|
-
* Version: 1.0.0b1_r746
|
6
|
-
*
|
7
|
-
* Copyright (c) 2009-2011 Chris Leonello
|
8
|
-
* jqPlot is currently available for use in all personal or commercial projects
|
9
|
-
* under both the MIT (http://www.opensource.org/licenses/mit-license.php) and GPL
|
10
|
-
* version 2.0 (http://www.gnu.org/licenses/gpl-2.0.html) licenses. This means that you can
|
11
|
-
* choose the license that best suits your project and use it accordingly.
|
12
|
-
*
|
13
|
-
* Although not required, the author would appreciate an email letting him
|
14
|
-
* know of any substantial use of jqPlot. You can reach the author at:
|
15
|
-
* chris at jqplot dot com or see http://www.jqplot.com/info.php .
|
16
|
-
*
|
17
|
-
* If you are feeling kind and generous, consider supporting the project by
|
18
|
-
* making a donation at: http://www.jqplot.com/donate.php .
|
19
|
-
*
|
20
|
-
* sprintf functions contained in jqplot.sprintf.js by Ash Searle:
|
21
|
-
*
|
22
|
-
* version 2007.04.27
|
23
|
-
* author Ash Searle
|
24
|
-
* http://hexmen.com/blog/2007/03/printf-sprintf/
|
25
|
-
* http://hexmen.com/js/sprintf.js
|
26
|
-
* The author (Ash Searle) has placed this code in the public domain:
|
27
|
-
* "This code is unrestricted: you are free to use it however you like."
|
28
|
-
*
|
29
|
-
*/
|
30
|
-
(function(j){j.jqplot.Cursor=function(q){this.style="crosshair";this.previousCursor="auto";this.show=j.jqplot.config.enablePlugins;this.showTooltip=true;this.followMouse=false;this.tooltipLocation="se";this.tooltipOffset=6;this.showTooltipGridPosition=false;this.showTooltipUnitPosition=true;this.showTooltipDataPosition=false;this.tooltipFormatString="%.4P, %.4P";this.useAxesFormatters=true;this.tooltipAxisGroups=[];this.zoom=false;this.zoomProxy=false;this.zoomTarget=false;this.looseZoom=false;this.clickReset=false;this.dblClickReset=true;this.showVerticalLine=false;this.showHorizontalLine=false;this.constrainZoomTo="none";this.shapeRenderer=new j.jqplot.ShapeRenderer();this._zoom={start:[],end:[],started:false,zooming:false,isZoomed:false,axes:{start:{},end:{}},gridpos:{},datapos:{}};this._tooltipElem;this.zoomCanvas;this.cursorCanvas;this.intersectionThreshold=2;this.showCursorLegend=false;this.cursorLegendFormatString=j.jqplot.Cursor.cursorLegendFormatString;this._oldHandlers={onselectstart:null,ondrag:null,onmousedown:null};this.constrainOutsideZoom=true;this.showTooltipOutsideZoom=false;this.onGrid=false;j.extend(true,this,q)};j.jqplot.Cursor.cursorLegendFormatString="%s x:%s, y:%s";j.jqplot.Cursor.init=function(t,s,r){var q=r||{};this.plugins.cursor=new j.jqplot.Cursor(q.cursor);var u=this.plugins.cursor;if(u.show){j.jqplot.eventListenerHooks.push(["jqplotMouseEnter",b]);j.jqplot.eventListenerHooks.push(["jqplotMouseLeave",f]);j.jqplot.eventListenerHooks.push(["jqplotMouseMove",i]);if(u.showCursorLegend){r.legend=r.legend||{};r.legend.renderer=j.jqplot.CursorLegendRenderer;r.legend.formatString=this.plugins.cursor.cursorLegendFormatString;r.legend.show=true}if(u.zoom){j.jqplot.eventListenerHooks.push(["jqplotMouseDown",a]);if(u.clickReset){j.jqplot.eventListenerHooks.push(["jqplotClick",k])}if(u.dblClickReset){j.jqplot.eventListenerHooks.push(["jqplotDblClick",c])}}this.resetZoom=function(){var x=this.axes;if(!u.zoomProxy){for(var w in x){x[w].reset()}this.redraw()}else{var v=this.plugins.cursor.zoomCanvas._ctx;v.clearRect(0,0,v.canvas.width,v.canvas.height);v=null}this.plugins.cursor._zoom.isZoomed=false;this.target.trigger("jqplotResetZoom",[this,this.plugins.cursor])};if(u.showTooltipDataPosition){u.showTooltipUnitPosition=false;u.showTooltipGridPosition=false;if(q.cursor.tooltipFormatString==undefined){u.tooltipFormatString=j.jqplot.Cursor.cursorLegendFormatString}}}};j.jqplot.Cursor.postDraw=function(){var w=this.plugins.cursor;w.zoomCanvas=new j.jqplot.GenericCanvas();this.eventCanvas._elem.before(w.zoomCanvas.createElement(this._gridPadding,"jqplot-zoom-canvas",this._plotDimensions));w.zoomCanvas.setContext();w._tooltipElem=j('<div class="jqplot-cursor-tooltip" style="position:absolute;display:none"></div>');w.zoomCanvas._elem.before(w._tooltipElem);if(w.showVerticalLine||w.showHorizontalLine){w.cursorCanvas=new j.jqplot.GenericCanvas();this.eventCanvas._elem.before(w.cursorCanvas.createElement(this._gridPadding,"jqplot-cursor-canvas",this._plotDimensions));w.cursorCanvas.setContext()}if(w.showTooltipUnitPosition){if(w.tooltipAxisGroups.length===0){var t=this.series;var u;var q=[];for(var r=0;r<t.length;r++){u=t[r];var v=u.xaxis+","+u.yaxis;if(j.inArray(v,q)==-1){q.push(v)}}for(var r=0;r<q.length;r++){w.tooltipAxisGroups.push(q[r].split(","))}}}};j.jqplot.Cursor.zoomProxy=function(v,r){var q=v.plugins.cursor;var u=r.plugins.cursor;q.zoomTarget=true;q.zoom=true;q.style="auto";q.dblClickReset=false;u.zoom=true;u.zoomProxy=true;r.target.bind("jqplotZoom",t);r.target.bind("jqplotResetZoom",s);function t(x,w,z,y,A){q.doZoom(w,z,v,A)}function s(w,x,y){v.resetZoom()}};j.jqplot.Cursor.prototype.resetZoom=function(u,v){var t=u.axes;var s=v._zoom.axes;if(!u.plugins.cursor.zoomProxy&&v._zoom.isZoomed){for(var r in t){t[r]._ticks=[];t[r].min=s[r].min;t[r].max=s[r].max;t[r].numberTicks=s[r].numberTicks;t[r].tickInterval=s[r].tickInterval;t[r].daTickInterval=s[r].daTickInterval}u.redraw();v._zoom.isZoomed=false}else{var q=v.zoomCanvas._ctx;q.clearRect(0,0,q.canvas.width,q.canvas.height);q=null}u.target.trigger("jqplotResetZoom",[u,v])};j.jqplot.Cursor.resetZoom=function(q){q.resetZoom()};j.jqplot.Cursor.prototype.doZoom=function(F,s,B,t){var G=t;var E=B.axes;var q=G._zoom.axes;var v=q.start;var r=q.end;var A,D,y,C;var z=B.plugins.cursor.zoomCanvas._ctx;if((G.constrainZoomTo=="none"&&Math.abs(F.x-G._zoom.start[0])>6&&Math.abs(F.y-G._zoom.start[1])>6)||(G.constrainZoomTo=="x"&&Math.abs(F.x-G._zoom.start[0])>6)||(G.constrainZoomTo=="y"&&Math.abs(F.y-G._zoom.start[1])>6)){if(!B.plugins.cursor.zoomProxy){for(var x in s){if(G._zoom.axes[x]==undefined){G._zoom.axes[x]={};G._zoom.axes[x].numberTicks=E[x].numberTicks;G._zoom.axes[x].tickInterval=E[x].tickInterval;G._zoom.axes[x].daTickInterval=E[x].daTickInterval;G._zoom.axes[x].min=E[x].min;G._zoom.axes[x].max=E[x].max}if((G.constrainZoomTo=="none")||(G.constrainZoomTo=="x"&&x.charAt(0)=="x")||(G.constrainZoomTo=="y"&&x.charAt(0)=="y")){y=s[x];if(y!=null){var u,w;if(y>v[x]){u=v[x];w=y}else{C=v[x]-y;u=y;w=v[x]}if(this.looseZoom&&(E[x].renderer.constructor===j.jqplot.LinearAxisRenderer||E[x].renderer.constructor===j.jqplot.DateAxisRenderer)){var H=j.jqplot.LinearTickGenerator(u,w);E[x].min=H[0];E[x].max=H[1];E[x].numberTicks=H[2];E[x].tickInterval=H[4];E[x].daTickInterval=[H[4]/1000,"seconds"]}else{E[x].min=u;E[x].max=w;E[x].tickInterval=null;E[x].daTickInterval=null}E[x]._ticks=[]}}}z.clearRect(0,0,z.canvas.width,z.canvas.height);B.redraw();G._zoom.isZoomed=true;z=null}B.target.trigger("jqplotZoom",[F,s,B,t])}};j.jqplot.preInitHooks.push(j.jqplot.Cursor.init);j.jqplot.postDrawHooks.push(j.jqplot.Cursor.postDraw);function e(E,r,B){var G=B.plugins.cursor;var w="";var K=false;if(G.showTooltipGridPosition){w=E.x+", "+E.y;K=true}if(G.showTooltipUnitPosition){var D;for(var C=0;C<G.tooltipAxisGroups.length;C++){D=G.tooltipAxisGroups[C];if(K){w+="<br />"}if(G.useAxesFormatters){var A=B.axes[D[0]]._ticks[0].formatter;var q=B.axes[D[1]]._ticks[0].formatter;var H=B.axes[D[0]]._ticks[0].formatString;var v=B.axes[D[1]]._ticks[0].formatString;w+=A(H,r[D[0]])+", "+q(v,r[D[1]])}else{w+=j.jqplot.sprintf(G.tooltipFormatString,r[D[0]],r[D[1]])}K=true}}if(G.showTooltipDataPosition){var u=B.series;var J=d(B,E.x,E.y);var K=false;for(var C=0;C<u.length;C++){if(u[C].show){var y=u[C].index;var t=u[C].label.toString();var F=j.inArray(y,J.indices);var z=undefined;var x=undefined;if(F!=-1){var I=J.data[F].data;if(G.useAxesFormatters){var A=u[C]._xaxis._ticks[0].formatter;var q=u[C]._yaxis._ticks[0].formatter;var H=u[C]._xaxis._ticks[0].formatString;var v=u[C]._yaxis._ticks[0].formatString;z=A(H,I[0]);x=q(v,I[1])}else{z=I[0];x=I[1]}if(K){w+="<br />"}w+=j.jqplot.sprintf(G.tooltipFormatString,t,z,x);K=true}}}}G._tooltipElem.html(w)}function g(C,A){var E=A.plugins.cursor;var z=E.cursorCanvas._ctx;z.clearRect(0,0,z.canvas.width,z.canvas.height);if(E.showVerticalLine){E.shapeRenderer.draw(z,[[C.x,0],[C.x,z.canvas.height]])}if(E.showHorizontalLine){E.shapeRenderer.draw(z,[[0,C.y],[z.canvas.width,C.y]])}var G=d(A,C.x,C.y);if(E.showCursorLegend){var r=j(A.targetId+" td.jqplot-cursor-legend-label");for(var B=0;B<r.length;B++){var v=j(r[B]).data("seriesIndex");var t=A.series[v];var s=t.label.toString();var D=j.inArray(v,G.indices);var x=undefined;var w=undefined;if(D!=-1){var H=G.data[D].data;if(E.useAxesFormatters){var y=t._xaxis._ticks[0].formatter;var q=t._yaxis._ticks[0].formatter;var F=t._xaxis._ticks[0].formatString;var u=t._yaxis._ticks[0].formatString;x=y(F,H[0]);w=q(u,H[1])}else{x=H[0];w=H[1]}}if(A.legend.escapeHtml){j(r[B]).text(j.jqplot.sprintf(E.cursorLegendFormatString,s,x,w))}else{j(r[B]).html(j.jqplot.sprintf(E.cursorLegendFormatString,s,x,w))}}}z=null}function d(A,F,E){var B={indices:[],data:[]};var G,w,u,C,v,q,t;var z;var D=A.plugins.cursor;for(var w=0;w<A.series.length;w++){G=A.series[w];q=G.renderer;if(G.show){z=D.intersectionThreshold;if(G.showMarker){z+=G.markerRenderer.size/2}for(var v=0;v<G.gridData.length;v++){t=G.gridData[v];if(D.showVerticalLine){if(Math.abs(F-t[0])<=z){B.indices.push(w);B.data.push({seriesIndex:w,pointIndex:v,gridData:t,data:G.data[v]})}}}}}return B}function n(r,t){var v=t.plugins.cursor;var s=v._tooltipElem;switch(v.tooltipLocation){case"nw":var q=r.x+t._gridPadding.left-s.outerWidth(true)-v.tooltipOffset;var u=r.y+t._gridPadding.top-v.tooltipOffset-s.outerHeight(true);break;case"n":var q=r.x+t._gridPadding.left-s.outerWidth(true)/2;var u=r.y+t._gridPadding.top-v.tooltipOffset-s.outerHeight(true);break;case"ne":var q=r.x+t._gridPadding.left+v.tooltipOffset;var u=r.y+t._gridPadding.top-v.tooltipOffset-s.outerHeight(true);break;case"e":var q=r.x+t._gridPadding.left+v.tooltipOffset;var u=r.y+t._gridPadding.top-s.outerHeight(true)/2;break;case"se":var q=r.x+t._gridPadding.left+v.tooltipOffset;var u=r.y+t._gridPadding.top+v.tooltipOffset;break;case"s":var q=r.x+t._gridPadding.left-s.outerWidth(true)/2;var u=r.y+t._gridPadding.top+v.tooltipOffset;break;case"sw":var q=r.x+t._gridPadding.left-s.outerWidth(true)-v.tooltipOffset;var u=r.y+t._gridPadding.top+v.tooltipOffset;break;case"w":var q=r.x+t._gridPadding.left-s.outerWidth(true)-v.tooltipOffset;var u=r.y+t._gridPadding.top-s.outerHeight(true)/2;break;default:var q=r.x+t._gridPadding.left+v.tooltipOffset;var u=r.y+t._gridPadding.top+v.tooltipOffset;break}s.css("left",q);s.css("top",u);s=null}function m(u){var s=u._gridPadding;var v=u.plugins.cursor;var t=v._tooltipElem;switch(v.tooltipLocation){case"nw":var r=s.left+v.tooltipOffset;var q=s.top+v.tooltipOffset;t.css("left",r);t.css("top",q);break;case"n":var r=(s.left+(u._plotDimensions.width-s.right))/2-t.outerWidth(true)/2;var q=s.top+v.tooltipOffset;t.css("left",r);t.css("top",q);break;case"ne":var r=s.right+v.tooltipOffset;var q=s.top+v.tooltipOffset;t.css({right:r,top:q});break;case"e":var r=s.right+v.tooltipOffset;var q=(s.top+(u._plotDimensions.height-s.bottom))/2-t.outerHeight(true)/2;t.css({right:r,top:q});break;case"se":var r=s.right+v.tooltipOffset;var q=s.bottom+v.tooltipOffset;t.css({right:r,bottom:q});break;case"s":var r=(s.left+(u._plotDimensions.width-s.right))/2-t.outerWidth(true)/2;var q=s.bottom+v.tooltipOffset;t.css({left:r,bottom:q});break;case"sw":var r=s.left+v.tooltipOffset;var q=s.bottom+v.tooltipOffset;t.css({left:r,bottom:q});break;case"w":var r=s.left+v.tooltipOffset;var q=(s.top+(u._plotDimensions.height-s.bottom))/2-t.outerHeight(true)/2;t.css({left:r,top:q});break;default:var r=s.right-v.tooltipOffset;var q=s.bottom+v.tooltipOffset;t.css({right:r,bottom:q});break}t=null}function k(r,q,v,u,t){r.preventDefault();r.stopImmediatePropagation();var w=t.plugins.cursor;if(w.clickReset){w.resetZoom(t,w)}var s=window.getSelection;if(document.selection&&document.selection.empty){document.selection.empty()}else{if(s&&!s().isCollapsed){s().collapse()}}return false}function c(r,q,v,u,t){r.preventDefault();r.stopImmediatePropagation();var w=t.plugins.cursor;if(w.dblClickReset){w.resetZoom(t,w)}var s=window.getSelection;if(document.selection&&document.selection.empty){document.selection.empty()}else{if(s&&!s().isCollapsed){s().collapse()}}return false}function f(w,t,q,z,u){var v=u.plugins.cursor;v.onGrid=false;if(v.show){j(w.target).css("cursor",v.previousCursor);if(v.showTooltip&&!(v._zoom.zooming&&v.showTooltipOutsideZoom&&!v.constrainOutsideZoom)){v._tooltipElem.hide()}if(v.zoom){v._zoom.gridpos=t;v._zoom.datapos=q}if(v.showVerticalLine||v.showHorizontalLine){var B=v.cursorCanvas._ctx;B.clearRect(0,0,B.canvas.width,B.canvas.height);B=null}if(v.showCursorLegend){var A=j(u.targetId+" td.jqplot-cursor-legend-label");for(var s=0;s<A.length;s++){var y=j(A[s]).data("seriesIndex");var r=u.series[y];var x=r.label.toString();if(u.legend.escapeHtml){j(A[s]).text(j.jqplot.sprintf(v.cursorLegendFormatString,x,undefined,undefined))}else{j(A[s]).html(j.jqplot.sprintf(v.cursorLegendFormatString,x,undefined,undefined))}}}}}function b(r,q,u,t,s){var v=s.plugins.cursor;v.onGrid=true;if(v.show){v.previousCursor=r.target.style.cursor;r.target.style.cursor=v.style;if(v.showTooltip){e(q,u,s);if(v.followMouse){n(q,s)}else{m(s)}v._tooltipElem.show()}if(v.showVerticalLine||v.showHorizontalLine){g(q,s)}}}function i(s,r,v,u,t){var w=t.plugins.cursor;var q=w.zoomCanvas._ctx;if(w.show){if(w.showTooltip){e(r,v,t);if(w.followMouse){n(r,t)}}if(w.showVerticalLine||w.showHorizontalLine){g(r,t)}}q=null}function o(y){var x=y.data.plot;var t=x.eventCanvas._elem.offset();var w={x:y.pageX-t.left,y:y.pageY-t.top};var u={xaxis:null,yaxis:null,x2axis:null,y2axis:null,y3axis:null,y4axis:null,y5axis:null,y6axis:null,y7axis:null,y8axis:null,y9axis:null};var v=["xaxis","yaxis","x2axis","y2axis","y3axis","y4axis","y5axis","y6axis","y7axis","y8axis","y9axis"];var q=x.axes;var r,s;for(r=11;r>0;r--){s=v[r-1];if(q[s].show){u[s]=q[s].series_p2u(w[s.charAt(0)])}}return{offsets:t,gridPos:w,dataPos:u}}function h(z){var x=z.data.plot;var y=x.plugins.cursor;if(y.show&&y.zoom&&y._zoom.started&&!y.zoomTarget){var B=y.zoomCanvas._ctx;var v=o(z);var w=v.gridPos;var t=v.dataPos;y._zoom.gridpos=w;y._zoom.datapos=t;y._zoom.zooming=true;var u=w.x;var s=w.y;var A=B.canvas.height;var q=B.canvas.width;if(y.showTooltip&&!y.onGrid&&y.showTooltipOutsideZoom){e(w,t,x);if(y.followMouse){n(w,x)}}if(y.constrainZoomTo=="x"){y._zoom.end=[u,A]}else{if(y.constrainZoomTo=="y"){y._zoom.end=[q,s]}else{y._zoom.end=[u,s]}}var r=window.getSelection;if(document.selection&&document.selection.empty){document.selection.empty()}else{if(r&&!r().isCollapsed){r().collapse()}}l.call(y);B=null}}function a(w,s,r,x,t){var v=t.plugins.cursor;j(document).one("mouseup.jqplot_cursor",{plot:t},p);var u=t.axes;if(document.onselectstart!=undefined){v._oldHandlers.onselectstart=document.onselectstart;document.onselectstart=function(){return false}}if(document.ondrag!=undefined){v._oldHandlers.ondrag=document.ondrag;document.ondrag=function(){return false}}if(document.onmousedown!=undefined){v._oldHandlers.onmousedown=document.onmousedown;document.onmousedown=function(){return false}}if(v.zoom){if(!v.zoomProxy){var y=v.zoomCanvas._ctx;y.clearRect(0,0,y.canvas.width,y.canvas.height);y=null}if(v.constrainZoomTo=="x"){v._zoom.start=[s.x,0]}else{if(v.constrainZoomTo=="y"){v._zoom.start=[0,s.y]}else{v._zoom.start=[s.x,s.y]}}v._zoom.started=true;for(var q in r){v._zoom.axes.start[q]=r[q]}j(document).bind("mousemove.jqplotCursor",{plot:t},h)}}function p(y){var v=y.data.plot;var x=v.plugins.cursor;if(x.zoom&&x._zoom.zooming&&!x.zoomTarget){var u=x._zoom.gridpos.x;var r=x._zoom.gridpos.y;var t=x._zoom.datapos;var z=x.zoomCanvas._ctx.canvas.height;var q=x.zoomCanvas._ctx.canvas.width;var w=v.axes;if(x.constrainOutsideZoom&&!x.onGrid){if(u<0){u=0}else{if(u>q){u=q}}if(r<0){r=0}else{if(r>z){r=z}}for(var s in t){if(t[s]){if(s.charAt(0)=="x"){t[s]=w[s].series_p2u(u)}else{t[s]=w[s].series_p2u(r)}}}}if(x.constrainZoomTo=="x"){r=z}else{if(x.constrainZoomTo=="y"){u=q}}x._zoom.end=[u,r];x._zoom.gridpos={x:u,y:r};x.doZoom(x._zoom.gridpos,t,v,x)}x._zoom.started=false;x._zoom.zooming=false;j(document).unbind("mousemove.jqplotCursor",h);if(document.onselectstart!=undefined&&x._oldHandlers.onselectstart!=null){document.onselectstart=x._oldHandlers.onselectstart;x._oldHandlers.onselectstart=null}if(document.ondrag!=undefined&&x._oldHandlers.ondrag!=null){document.ondrag=x._oldHandlers.ondrag;x._oldHandlers.ondrag=null}if(document.onmousedown!=undefined&&x._oldHandlers.onmousedown!=null){document.onmousedown=x._oldHandlers.onmousedown;x._oldHandlers.onmousedown=null}}function l(){var y=this._zoom.start;var u=this._zoom.end;var s=this.zoomCanvas._ctx;var r,v,x,q;if(u[0]>y[0]){r=y[0];q=u[0]-y[0]}else{r=u[0];q=y[0]-u[0]}if(u[1]>y[1]){v=y[1];x=u[1]-y[1]}else{v=u[1];x=y[1]-u[1]}s.fillStyle="rgba(0,0,0,0.2)";s.strokeStyle="#999999";s.lineWidth=1;s.clearRect(0,0,s.canvas.width,s.canvas.height);s.fillRect(0,0,s.canvas.width,s.canvas.height);s.clearRect(r,v,q,x);s.strokeRect(r,v,q,x);s=null}j.jqplot.CursorLegendRenderer=function(q){j.jqplot.TableLegendRenderer.call(this,q);this.formatString="%s"};j.jqplot.CursorLegendRenderer.prototype=new j.jqplot.TableLegendRenderer();j.jqplot.CursorLegendRenderer.prototype.constructor=j.jqplot.CursorLegendRenderer;j.jqplot.CursorLegendRenderer.prototype.draw=function(){if(this.show){var v=this._series,z;this._elem=j('<table class="jqplot-legend jqplot-cursor-legend" style="position:absolute"></table>');var q=false;for(var w=0;w<v.length;w++){z=v[w];if(z.show&&z.showLabel){var u=j.jqplot.sprintf(this.formatString,z.label.toString());if(u){var r=z.color;if(z._stack&&!z.fill){r=""}y.call(this,u,r,q,w);q=true}for(var t=0;t<j.jqplot.addLegendRowHooks.length;t++){var x=j.jqplot.addLegendRowHooks[t].call(this,z);if(x){y.call(this,x.label,x.color,q);q=true}}}}v=z=null;delete v;delete z}function y(C,B,E,s){var A=(E)?this.rowSpacing:"0";var D=j('<tr class="jqplot-legend jqplot-cursor-legend"></tr>').appendTo(this._elem);D.data("seriesIndex",s);j('<td class="jqplot-legend jqplot-cursor-legend-swatch" style="padding-top:'+A+';"><div style="border:1px solid #cccccc;padding:0.2em;"><div class="jqplot-cursor-legend-swatch" style="background-color:'+B+';"></div></div></td>').appendTo(D);var F=j('<td class="jqplot-legend jqplot-cursor-legend-label" style="vertical-align:middle;padding-top:'+A+';"></td>');F.appendTo(D);F.data("seriesIndex",s);if(this.escapeHtml){F.text(C)}else{F.html(C)}D=null;F=null}return this._elem}})(jQuery);
|
@@ -1,439 +0,0 @@
|
|
1
|
-
/**
|
2
|
-
* jqPlot
|
3
|
-
* Pure JavaScript plotting plugin using jQuery
|
4
|
-
*
|
5
|
-
* Version: 1.0.0b1_r746
|
6
|
-
*
|
7
|
-
* Copyright (c) 2009-2011 Chris Leonello
|
8
|
-
* jqPlot is currently available for use in all personal or commercial projects
|
9
|
-
* under both the MIT (http://www.opensource.org/licenses/mit-license.php) and GPL
|
10
|
-
* version 2.0 (http://www.gnu.org/licenses/gpl-2.0.html) licenses. This means that you can
|
11
|
-
* choose the license that best suits your project and use it accordingly.
|
12
|
-
*
|
13
|
-
* Although not required, the author would appreciate an email letting him
|
14
|
-
* know of any substantial use of jqPlot. You can reach the author at:
|
15
|
-
* chris at jqplot dot com or see http://www.jqplot.com/info.php .
|
16
|
-
*
|
17
|
-
* If you are feeling kind and generous, consider supporting the project by
|
18
|
-
* making a donation at: http://www.jqplot.com/donate.php .
|
19
|
-
*
|
20
|
-
* sprintf functions contained in jqplot.sprintf.js by Ash Searle:
|
21
|
-
*
|
22
|
-
* version 2007.04.27
|
23
|
-
* author Ash Searle
|
24
|
-
* http://hexmen.com/blog/2007/03/printf-sprintf/
|
25
|
-
* http://hexmen.com/js/sprintf.js
|
26
|
-
* The author (Ash Searle) has placed this code in the public domain:
|
27
|
-
* "This code is unrestricted: you are free to use it however you like."
|
28
|
-
*
|
29
|
-
*/
|
30
|
-
(function($) {
|
31
|
-
/**
|
32
|
-
* Class: $.jqplot.DateAxisRenderer
|
33
|
-
* A plugin for a jqPlot to render an axis as a series of date values.
|
34
|
-
* This renderer has no options beyond those supplied by the <Axis> class.
|
35
|
-
* It supplies it's own tick formatter, so the tickOptions.formatter option
|
36
|
-
* should not be overridden.
|
37
|
-
*
|
38
|
-
* Thanks to Ken Synder for his enhanced Date instance methods which are
|
39
|
-
* included with this code <http://kendsnyder.com/sandbox/date/>.
|
40
|
-
*
|
41
|
-
* To use this renderer, include the plugin in your source
|
42
|
-
* > <script type="text/javascript" language="javascript" src="plugins/jqplot.dateAxisRenderer.js"></script>
|
43
|
-
*
|
44
|
-
* and supply the appropriate options to your plot
|
45
|
-
*
|
46
|
-
* > {axes:{xaxis:{renderer:$.jqplot.DateAxisRenderer}}}
|
47
|
-
*
|
48
|
-
* Dates can be passed into the axis in almost any recognizable value and
|
49
|
-
* will be parsed. They will be rendered on the axis in the format
|
50
|
-
* specified by tickOptions.formatString. e.g. tickOptions.formatString = '%Y-%m-%d'.
|
51
|
-
*
|
52
|
-
* Accecptable format codes
|
53
|
-
* are:
|
54
|
-
*
|
55
|
-
* > Code Result Description
|
56
|
-
* > == Years ==
|
57
|
-
* > %Y 2008 Four-digit year
|
58
|
-
* > %y 08 Two-digit year
|
59
|
-
* > == Months ==
|
60
|
-
* > %m 09 Two-digit month
|
61
|
-
* > %#m 9 One or two-digit month
|
62
|
-
* > %B September Full month name
|
63
|
-
* > %b Sep Abbreviated month name
|
64
|
-
* > == Days ==
|
65
|
-
* > %d 05 Two-digit day of month
|
66
|
-
* > %#d 5 One or two-digit day of month
|
67
|
-
* > %e 5 One or two-digit day of month
|
68
|
-
* > %A Sunday Full name of the day of the week
|
69
|
-
* > %a Sun Abbreviated name of the day of the week
|
70
|
-
* > %w 0 Number of the day of the week (0 = Sunday, 6 = Saturday)
|
71
|
-
* > %o th The ordinal suffix string following the day of the month
|
72
|
-
* > == Hours ==
|
73
|
-
* > %H 23 Hours in 24-hour format (two digits)
|
74
|
-
* > %#H 3 Hours in 24-hour integer format (one or two digits)
|
75
|
-
* > %I 11 Hours in 12-hour format (two digits)
|
76
|
-
* > %#I 3 Hours in 12-hour integer format (one or two digits)
|
77
|
-
* > %p PM AM or PM
|
78
|
-
* > == Minutes ==
|
79
|
-
* > %M 09 Minutes (two digits)
|
80
|
-
* > %#M 9 Minutes (one or two digits)
|
81
|
-
* > == Seconds ==
|
82
|
-
* > %S 02 Seconds (two digits)
|
83
|
-
* > %#S 2 Seconds (one or two digits)
|
84
|
-
* > %s 1206567625723 Unix timestamp (Seconds past 1970-01-01 00:00:00)
|
85
|
-
* > == Milliseconds ==
|
86
|
-
* > %N 008 Milliseconds (three digits)
|
87
|
-
* > %#N 8 Milliseconds (one to three digits)
|
88
|
-
* > == Timezone ==
|
89
|
-
* > %O 360 difference in minutes between local time and GMT
|
90
|
-
* > %Z Mountain Standard Time Name of timezone as reported by browser
|
91
|
-
* > %G -06:00 Hours and minutes between GMT
|
92
|
-
* > == Shortcuts ==
|
93
|
-
* > %F 2008-03-26 %Y-%m-%d
|
94
|
-
* > %T 05:06:30 %H:%M:%S
|
95
|
-
* > %X 05:06:30 %H:%M:%S
|
96
|
-
* > %x 03/26/08 %m/%d/%y
|
97
|
-
* > %D 03/26/08 %m/%d/%y
|
98
|
-
* > %#c Wed Mar 26 15:31:00 2008 %a %b %e %H:%M:%S %Y
|
99
|
-
* > %v 3-Sep-2008 %e-%b-%Y
|
100
|
-
* > %R 15:31 %H:%M
|
101
|
-
* > %r 3:31:00 PM %I:%M:%S %p
|
102
|
-
* > == Characters ==
|
103
|
-
* > %n \n Newline
|
104
|
-
* > %t \t Tab
|
105
|
-
* > %% % Percent Symbol
|
106
|
-
*/
|
107
|
-
$.jqplot.DateAxisRenderer = function() {
|
108
|
-
$.jqplot.LinearAxisRenderer.call(this);
|
109
|
-
this.date = new $.jsDate();
|
110
|
-
};
|
111
|
-
|
112
|
-
$.jqplot.DateAxisRenderer.prototype = new $.jqplot.LinearAxisRenderer();
|
113
|
-
$.jqplot.DateAxisRenderer.prototype.constructor = $.jqplot.DateAxisRenderer;
|
114
|
-
|
115
|
-
$.jqplot.DateTickFormatter = function(format, val) {
|
116
|
-
if (!format) {
|
117
|
-
format = '%Y/%m/%d';
|
118
|
-
}
|
119
|
-
return $.jsDate.strftime(val, format);
|
120
|
-
};
|
121
|
-
|
122
|
-
$.jqplot.DateAxisRenderer.prototype.init = function(options){
|
123
|
-
// prop: tickRenderer
|
124
|
-
// A class of a rendering engine for creating the ticks labels displayed on the plot,
|
125
|
-
// See <$.jqplot.AxisTickRenderer>.
|
126
|
-
// this.tickRenderer = $.jqplot.AxisTickRenderer;
|
127
|
-
// this.labelRenderer = $.jqplot.AxisLabelRenderer;
|
128
|
-
this.tickOptions.formatter = $.jqplot.DateTickFormatter;
|
129
|
-
this.daTickInterval = null;
|
130
|
-
this._daTickInterval = null;
|
131
|
-
|
132
|
-
$.extend(true, this, options);
|
133
|
-
|
134
|
-
var db = this._dataBounds,
|
135
|
-
stats,
|
136
|
-
sum,
|
137
|
-
s,
|
138
|
-
d,
|
139
|
-
pd,
|
140
|
-
sd,
|
141
|
-
intv;
|
142
|
-
|
143
|
-
// Go through all the series attached to this axis and find
|
144
|
-
// the min/max bounds for this axis.
|
145
|
-
for (var i=0; i<this._series.length; i++) {
|
146
|
-
stats = {intervals:[], frequencies:{}, sortedIntervals:[], min:null, max:null, mean:null};
|
147
|
-
sum = 0;
|
148
|
-
s = this._series[i];
|
149
|
-
d = s.data;
|
150
|
-
pd = s._plotData;
|
151
|
-
sd = s._stackData;
|
152
|
-
intv = 0;
|
153
|
-
|
154
|
-
for (var j=0; j<d.length; j++) {
|
155
|
-
if (this.name == 'xaxis' || this.name == 'x2axis') {
|
156
|
-
d[j][0] = new $.jsDate(d[j][0]).getTime();
|
157
|
-
pd[j][0] = new $.jsDate(d[j][0]).getTime();
|
158
|
-
sd[j][0] = new $.jsDate(d[j][0]).getTime();
|
159
|
-
if ((d[j][0] != null && d[j][0] < db.min) || db.min == null) {
|
160
|
-
db.min = d[j][0];
|
161
|
-
}
|
162
|
-
if ((d[j][0] != null && d[j][0] > db.max) || db.max == null) {
|
163
|
-
db.max = d[j][0];
|
164
|
-
}
|
165
|
-
if (j>0) {
|
166
|
-
intv = Math.abs(d[j][0] - d[j-1][0]);
|
167
|
-
stats.intervals.push(intv);
|
168
|
-
if (stats.frequencies.hasOwnProperty(intv)) {
|
169
|
-
stats.frequencies[intv] += 1;
|
170
|
-
}
|
171
|
-
else {
|
172
|
-
stats.frequencies[intv] = 1;
|
173
|
-
}
|
174
|
-
}
|
175
|
-
sum += intv;
|
176
|
-
|
177
|
-
}
|
178
|
-
else {
|
179
|
-
d[j][1] = new $.jsDate(d[j][1]).getTime();
|
180
|
-
pd[j][1] = new $.jsDate(d[j][1]).getTime();
|
181
|
-
sd[j][1] = new $.jsDate(d[j][1]).getTime();
|
182
|
-
if ((d[j][1] != null && d[j][1] < db.min) || db.min == null) {
|
183
|
-
db.min = d[j][1];
|
184
|
-
}
|
185
|
-
if ((d[j][1] != null && d[j][1] > db.max) || db.max == null) {
|
186
|
-
db.max = d[j][1];
|
187
|
-
}
|
188
|
-
if (j>0) {
|
189
|
-
intv = Math.abs(d[j][1] - d[j-1][1]);
|
190
|
-
stats.intervals.push(intv);
|
191
|
-
if (stats.frequencies.hasOwnProperty(intv)) {
|
192
|
-
stats.frequencies[intv] += 1;
|
193
|
-
}
|
194
|
-
else {
|
195
|
-
stats.frequencies[intv] = 1;
|
196
|
-
}
|
197
|
-
}
|
198
|
-
}
|
199
|
-
sum += intv;
|
200
|
-
}
|
201
|
-
|
202
|
-
var tempf = 0,
|
203
|
-
tempn=0;
|
204
|
-
for (var n in stats.frequencies) {
|
205
|
-
stats.sortedIntervals.push({interval:n, frequency:stats.frequencies[n]});
|
206
|
-
}
|
207
|
-
stats.sortedIntervals.sort(function(a, b){
|
208
|
-
return b.frequency - a.frequency;
|
209
|
-
});
|
210
|
-
|
211
|
-
stats.min = $.jqplot.arrayMin(stats.intervals);
|
212
|
-
stats.max = $.jqplot.arrayMax(stats.intervals);
|
213
|
-
stats.mean = sum/d.length;
|
214
|
-
this._intervalStats.push(stats);
|
215
|
-
stats = sum = s = d = pd = sd = null;
|
216
|
-
}
|
217
|
-
db = null;
|
218
|
-
|
219
|
-
};
|
220
|
-
|
221
|
-
// called with scope of an axis
|
222
|
-
$.jqplot.DateAxisRenderer.prototype.reset = function() {
|
223
|
-
this.min = this._min;
|
224
|
-
this.max = this._max;
|
225
|
-
this.tickInterval = this._tickInterval;
|
226
|
-
this.numberTicks = this._numberTicks;
|
227
|
-
this.daTickInterval = this._daTickInterval;
|
228
|
-
// this._ticks = this.__ticks;
|
229
|
-
};
|
230
|
-
|
231
|
-
$.jqplot.DateAxisRenderer.prototype.createTicks = function() {
|
232
|
-
// we're are operating on an axis here
|
233
|
-
var ticks = this._ticks;
|
234
|
-
var userTicks = this.ticks;
|
235
|
-
var name = this.name;
|
236
|
-
// databounds were set on axis initialization.
|
237
|
-
var db = this._dataBounds;
|
238
|
-
var iv = this._intervalStats;
|
239
|
-
var dim, interval;
|
240
|
-
var min, max;
|
241
|
-
var pos1, pos2;
|
242
|
-
var tt, i;
|
243
|
-
|
244
|
-
// if we already have ticks, use them.
|
245
|
-
// ticks must be in order of increasing value.
|
246
|
-
|
247
|
-
min = ((this.min != null) ? new $.jsDate(this.min).getTime() : db.min);
|
248
|
-
max = ((this.max != null) ? new $.jsDate(this.max).getTime() : db.max);
|
249
|
-
|
250
|
-
var range = max - min;
|
251
|
-
|
252
|
-
if (userTicks.length) {
|
253
|
-
// ticks could be 1D or 2D array of [val, val, ,,,] or [[val, label], [val, label], ...] or mixed
|
254
|
-
for (i=0; i<userTicks.length; i++){
|
255
|
-
var ut = userTicks[i];
|
256
|
-
var t = new this.tickRenderer(this.tickOptions);
|
257
|
-
if (ut.constructor == Array) {
|
258
|
-
t.value = new $.jsDate(ut[0]).getTime();
|
259
|
-
t.label = ut[1];
|
260
|
-
if (!this.showTicks) {
|
261
|
-
t.showLabel = false;
|
262
|
-
t.showMark = false;
|
263
|
-
}
|
264
|
-
else if (!this.showTickMarks) {
|
265
|
-
t.showMark = false;
|
266
|
-
}
|
267
|
-
t.setTick(t.value, this.name);
|
268
|
-
this._ticks.push(t);
|
269
|
-
}
|
270
|
-
|
271
|
-
else {
|
272
|
-
t.value = new $.jsDate(ut).getTime();
|
273
|
-
if (!this.showTicks) {
|
274
|
-
t.showLabel = false;
|
275
|
-
t.showMark = false;
|
276
|
-
}
|
277
|
-
else if (!this.showTickMarks) {
|
278
|
-
t.showMark = false;
|
279
|
-
}
|
280
|
-
t.setTick(t.value, this.name);
|
281
|
-
this._ticks.push(t);
|
282
|
-
}
|
283
|
-
}
|
284
|
-
this.numberTicks = userTicks.length;
|
285
|
-
this.min = this._ticks[0].value;
|
286
|
-
this.max = this._ticks[this.numberTicks-1].value;
|
287
|
-
this.daTickInterval = [(this.max - this.min) / (this.numberTicks - 1)/1000, 'seconds'];
|
288
|
-
}
|
289
|
-
|
290
|
-
////////
|
291
|
-
// We don't have any ticks yet, let's make some!
|
292
|
-
// Doing complete autoscaling, no user options specified
|
293
|
-
////////
|
294
|
-
|
295
|
-
else if (this.tickInterval == null && this.min == null && this.max == null && this.numberTicks == null) {
|
296
|
-
var ret = $.jqplot.LinearTickGenerator(min, max);
|
297
|
-
// calculate a padded max and min, points should be less than these
|
298
|
-
// so that they aren't too close to the edges of the plot.
|
299
|
-
// User can adjust how much padding is allowed with pad, padMin and PadMax options.
|
300
|
-
var tumin = min + range*(this.padMin - 1);
|
301
|
-
var tumax = max - range*(this.padMax - 1);
|
302
|
-
|
303
|
-
if (min <=tumin || max >= tumax) {
|
304
|
-
tumin = min - range*(this.padMin - 1);
|
305
|
-
tumax = max + range*(this.padMax - 1);
|
306
|
-
ret = $.jqplot.LinearTickGenerator(tumin, tumax);
|
307
|
-
}
|
308
|
-
|
309
|
-
this.min = ret[0];
|
310
|
-
this.max = ret[1];
|
311
|
-
this.numberTicks = ret[2];
|
312
|
-
this.tickInterval = ret[4];
|
313
|
-
this.daTickInterval = [this.tickInterval/1000, 'seconds'];
|
314
|
-
|
315
|
-
for (var i=0; i<this.numberTicks; i++){
|
316
|
-
var min = new $.jsDate(this.min);
|
317
|
-
tt = min.add(i*this.daTickInterval[0], this.daTickInterval[1]).getTime();
|
318
|
-
var t = new this.tickRenderer(this.tickOptions);
|
319
|
-
// var t = new $.jqplot.AxisTickRenderer(this.tickOptions);
|
320
|
-
if (!this.showTicks) {
|
321
|
-
t.showLabel = false;
|
322
|
-
t.showMark = false;
|
323
|
-
}
|
324
|
-
else if (!this.showTickMarks) {
|
325
|
-
t.showMark = false;
|
326
|
-
}
|
327
|
-
t.setTick(tt, this.name);
|
328
|
-
this._ticks.push(t);
|
329
|
-
}
|
330
|
-
}
|
331
|
-
|
332
|
-
////////
|
333
|
-
// Some option(s) specified, work around that.
|
334
|
-
////////
|
335
|
-
|
336
|
-
else {
|
337
|
-
if (name == 'xaxis' || name == 'x2axis') {
|
338
|
-
dim = this._plotDimensions.width;
|
339
|
-
}
|
340
|
-
else {
|
341
|
-
dim = this._plotDimensions.height;
|
342
|
-
}
|
343
|
-
|
344
|
-
// if min, max and number of ticks specified, user can't specify interval.
|
345
|
-
if (this.min != null && this.max != null && this.numberTicks != null) {
|
346
|
-
this.tickInterval = null;
|
347
|
-
}
|
348
|
-
|
349
|
-
// if user specified a tick interval, convert to usable.
|
350
|
-
if (this.tickInterval != null)
|
351
|
-
{
|
352
|
-
// if interval is a number or can be converted to one, use it.
|
353
|
-
// Assume it is in SECONDS!!!
|
354
|
-
if (Number(this.tickInterval)) {
|
355
|
-
this.daTickInterval = [Number(this.tickInterval), 'seconds'];
|
356
|
-
}
|
357
|
-
// else, parse out something we can build from.
|
358
|
-
else if (typeof this.tickInterval == "string") {
|
359
|
-
var parts = this.tickInterval.split(' ');
|
360
|
-
if (parts.length == 1) {
|
361
|
-
this.daTickInterval = [1, parts[0]];
|
362
|
-
}
|
363
|
-
else if (parts.length == 2) {
|
364
|
-
this.daTickInterval = [parts[0], parts[1]];
|
365
|
-
}
|
366
|
-
}
|
367
|
-
}
|
368
|
-
|
369
|
-
// if min and max are same, space them out a bit
|
370
|
-
if (min == max) {
|
371
|
-
var adj = 24*60*60*500; // 1/2 day
|
372
|
-
min -= adj;
|
373
|
-
max += adj;
|
374
|
-
}
|
375
|
-
|
376
|
-
range = max - min;
|
377
|
-
|
378
|
-
var optNumTicks = 2 + parseInt(Math.max(0, dim-100)/100, 10);
|
379
|
-
|
380
|
-
|
381
|
-
// Here try to set ticks based on data spacing.
|
382
|
-
// if (this.min == null && this.max == null && this.numberTicks == null && this.tickInterval == null) {
|
383
|
-
// //
|
384
|
-
// }
|
385
|
-
|
386
|
-
|
387
|
-
var rmin, rmax;
|
388
|
-
|
389
|
-
rmin = (this.min != null) ? new $.jsDate(this.min).getTime() : min - range/2*(this.padMin - 1);
|
390
|
-
rmax = (this.max != null) ? new $.jsDate(this.max).getTime() : max + range/2*(this.padMax - 1);
|
391
|
-
this.min = rmin;
|
392
|
-
this.max = rmax;
|
393
|
-
range = this.max - this.min;
|
394
|
-
|
395
|
-
if (this.numberTicks == null){
|
396
|
-
// if tickInterval is specified by user, we will ignore computed maximum.
|
397
|
-
// max will be equal or greater to fit even # of ticks.
|
398
|
-
if (this.daTickInterval != null) {
|
399
|
-
var nc = new $.jsDate(this.max).diff(this.min, this.daTickInterval[1], true);
|
400
|
-
this.numberTicks = Math.ceil(nc/this.daTickInterval[0]) +1;
|
401
|
-
// this.max = new $.jsDate(this.min).add(this.numberTicks-1, this.daTickInterval[1]).getTime();
|
402
|
-
this.max = new $.jsDate(this.min).add((this.numberTicks-1) * this.daTickInterval[0], this.daTickInterval[1]).getTime();
|
403
|
-
}
|
404
|
-
else if (dim > 200) {
|
405
|
-
this.numberTicks = parseInt(3+(dim-200)/100, 10);
|
406
|
-
}
|
407
|
-
else {
|
408
|
-
this.numberTicks = 2;
|
409
|
-
}
|
410
|
-
}
|
411
|
-
|
412
|
-
if (this.daTickInterval == null) {
|
413
|
-
this.daTickInterval = [range / (this.numberTicks-1)/1000, 'seconds'];
|
414
|
-
}
|
415
|
-
for (var i=0; i<this.numberTicks; i++){
|
416
|
-
var min = new $.jsDate(this.min);
|
417
|
-
tt = min.add(i*this.daTickInterval[0], this.daTickInterval[1]).getTime();
|
418
|
-
var t = new this.tickRenderer(this.tickOptions);
|
419
|
-
// var t = new $.jqplot.AxisTickRenderer(this.tickOptions);
|
420
|
-
if (!this.showTicks) {
|
421
|
-
t.showLabel = false;
|
422
|
-
t.showMark = false;
|
423
|
-
}
|
424
|
-
else if (!this.showTickMarks) {
|
425
|
-
t.showMark = false;
|
426
|
-
}
|
427
|
-
t.setTick(tt, this.name);
|
428
|
-
this._ticks.push(t);
|
429
|
-
}
|
430
|
-
}
|
431
|
-
|
432
|
-
|
433
|
-
if (this._daTickInterval == null) {
|
434
|
-
this._daTickInterval = this.daTickInterval;
|
435
|
-
}
|
436
|
-
};
|
437
|
-
|
438
|
-
})(jQuery);
|
439
|
-
|