rgraph-rails 1.0.4 → 1.0.5
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 +8 -8
- data/.travis.yml +1 -0
- data/README.md +2 -2
- data/lib/rgraph-rails/version.rb +1 -1
- data/vendor/assets/images/bullet.png +0 -0
- data/vendor/assets/images/facebook-large.png +0 -0
- data/vendor/assets/images/google-plus-large.png +0 -0
- data/vendor/assets/images/logo.png +0 -0
- data/vendor/assets/images/rgraph.jpg +0 -0
- data/vendor/assets/javascripts/RGraph.bar.js +533 -242
- data/vendor/assets/javascripts/RGraph.bipolar.js +152 -169
- data/vendor/assets/javascripts/RGraph.common.annotate.js +2 -2
- data/vendor/assets/javascripts/RGraph.common.context.js +2 -2
- data/vendor/assets/javascripts/RGraph.common.core.js +688 -373
- data/vendor/assets/javascripts/RGraph.common.csv.js +2 -2
- data/vendor/assets/javascripts/RGraph.common.deprecated.js +2 -2
- data/vendor/assets/javascripts/RGraph.common.dynamic.js +188 -193
- data/vendor/assets/javascripts/RGraph.common.effects.js +62 -38
- data/vendor/assets/javascripts/RGraph.common.key.js +35 -15
- data/vendor/assets/javascripts/RGraph.common.resizing.js +38 -21
- data/vendor/assets/javascripts/RGraph.common.sheets.js +2 -2
- data/vendor/assets/javascripts/RGraph.common.tooltips.js +48 -40
- data/vendor/assets/javascripts/RGraph.common.zoom.js +2 -2
- data/vendor/assets/javascripts/RGraph.drawing.background.js +33 -49
- data/vendor/assets/javascripts/RGraph.drawing.circle.js +27 -30
- data/vendor/assets/javascripts/RGraph.drawing.image.js +23 -26
- data/vendor/assets/javascripts/RGraph.drawing.marker1.js +47 -40
- data/vendor/assets/javascripts/RGraph.drawing.marker2.js +38 -42
- data/vendor/assets/javascripts/RGraph.drawing.marker3.js +24 -28
- data/vendor/assets/javascripts/RGraph.drawing.poly.js +25 -39
- data/vendor/assets/javascripts/RGraph.drawing.rect.js +27 -32
- data/vendor/assets/javascripts/RGraph.drawing.text.js +53 -58
- data/vendor/assets/javascripts/RGraph.drawing.xaxis.js +24 -29
- data/vendor/assets/javascripts/RGraph.drawing.yaxis.js +45 -51
- data/vendor/assets/javascripts/RGraph.fuel.js +11 -9
- data/vendor/assets/javascripts/RGraph.funnel.js +40 -43
- data/vendor/assets/javascripts/RGraph.gantt.js +34 -34
- data/vendor/assets/javascripts/RGraph.gauge.js +64 -55
- data/vendor/assets/javascripts/RGraph.hbar.js +194 -137
- data/vendor/assets/javascripts/RGraph.hprogress.js +261 -167
- data/vendor/assets/javascripts/RGraph.line.js +520 -512
- data/vendor/assets/javascripts/RGraph.meter.js +11 -10
- data/vendor/assets/javascripts/RGraph.modaldialog.js +11 -2
- data/vendor/assets/javascripts/RGraph.odo.js +11 -9
- data/vendor/assets/javascripts/RGraph.pie.js +385 -100
- data/vendor/assets/javascripts/RGraph.radar.js +36 -29
- data/vendor/assets/javascripts/RGraph.rose.js +58 -41
- data/vendor/assets/javascripts/RGraph.rscatter.js +40 -36
- data/vendor/assets/javascripts/RGraph.scatter.js +441 -499
- data/vendor/assets/javascripts/RGraph.semicircularprogress.js +1015 -0
- data/vendor/assets/javascripts/RGraph.thermometer.js +37 -37
- data/vendor/assets/javascripts/RGraph.vprogress.js +285 -157
- data/vendor/assets/javascripts/RGraph.waterfall.js +62 -62
- data/vendor/assets/stylesheets/website.css +30 -16
- metadata +3 -2
@@ -1,4 +1,4 @@
|
|
1
|
-
// version: 2016-
|
1
|
+
// version: 2016-06-04
|
2
2
|
/**
|
3
3
|
* o--------------------------------------------------------------------------------o
|
4
4
|
* | This file is part of the RGraph package - you can learn more at: |
|
@@ -7,7 +7,7 @@
|
|
7
7
|
* | |
|
8
8
|
* | RGraph is dual licensed under the Open Source GPL (General Public License) |
|
9
9
|
* | v2.0 license and a commercial license which means that you're not bound by |
|
10
|
-
* | the terms of the GPL. The commercial license starts at just
|
10
|
+
* | the terms of the GPL. The commercial license starts at just 99 GBP and |
|
11
11
|
* | you can read about it here: |
|
12
12
|
* | |
|
13
13
|
* | http://www.rgraph.net/license |
|
@@ -64,11 +64,6 @@
|
|
64
64
|
|
65
65
|
|
66
66
|
|
67
|
-
/**
|
68
|
-
* Compatibility with older browsers
|
69
|
-
*/
|
70
|
-
//RGraph.OldBrowserCompat(this.context);
|
71
|
-
|
72
67
|
|
73
68
|
this.max = 0;
|
74
69
|
this.stackedOrGrouped = false;
|
@@ -126,16 +121,32 @@
|
|
126
121
|
'chart.title.valign': null,
|
127
122
|
'chart.text.size': 12,
|
128
123
|
'chart.text.color': 'black',
|
129
|
-
'chart.text.font': 'Arial',
|
124
|
+
'chart.text.font': 'Segoe UI, Arial, Verdana, sans-serif',
|
125
|
+
'chart.text.accessible': true,
|
126
|
+
'chart.text.accessible.overflow': 'visible',
|
127
|
+
'chart.text.accessible.pointerevents': false,
|
130
128
|
'chart.colors': ['Gradient(white:red)', 'Gradient(white:blue)', 'Gradient(white:green)', 'Gradient(white:pink)', 'Gradient(white:yellow)', 'Gradient(white:cyan)', 'Gradient(white:navy)', 'Gradient(white:gray)', 'Gradient(white:black)'],
|
131
129
|
'chart.colors.sequential': false,
|
132
130
|
'chart.xlabels.specific': null,
|
133
131
|
'chart.labels': [],
|
134
132
|
'chart.labels.bold': false,
|
135
133
|
'chart.labels.color': null,
|
134
|
+
|
136
135
|
'chart.labels.above': false,
|
137
136
|
'chart.labels.above.decimals': 0,
|
138
137
|
'chart.labels.above.specific': null,
|
138
|
+
'chart.labels.above.color': null,
|
139
|
+
'chart.labels.above.units.pre': '',
|
140
|
+
'chart.labels.above.units.post': '',
|
141
|
+
'chart.labels.above.font': null,
|
142
|
+
'chart.labels.above.size': null,
|
143
|
+
'chart.labels.above.bold': false,
|
144
|
+
'chart.labels.above.italic': false,
|
145
|
+
|
146
|
+
'chart.labels.offsetx': 0,
|
147
|
+
'chart.labels.offsety': 0,
|
148
|
+
'chart.xlabels.offsetx': 0,
|
149
|
+
'chart.xlabels.offsety': 0,
|
139
150
|
'chart.xlabels': true,
|
140
151
|
'chart.xlabels.count': 5,
|
141
152
|
'chart.contextmenu': null,
|
@@ -182,6 +193,7 @@
|
|
182
193
|
'chart.tooltips.highlight': true,
|
183
194
|
'chart.highlight.fill': 'rgba(255,255,255,0.7)',
|
184
195
|
'chart.highlight.stroke': 'rgba(0,0,0,0)',
|
196
|
+
'chart.highlight.style': null,
|
185
197
|
'chart.annotatable': false,
|
186
198
|
'chart.annotate.color': 'black',
|
187
199
|
'chart.zoom.factor': 1.5,
|
@@ -200,7 +212,7 @@
|
|
200
212
|
'chart.scale.point': '.',
|
201
213
|
'chart.scale.thousand': ',',
|
202
214
|
'chart.scale.decimals': null,
|
203
|
-
'chart.scale.zerostart':
|
215
|
+
'chart.scale.zerostart': true,
|
204
216
|
'chart.noredraw': false,
|
205
217
|
'chart.events.click': null,
|
206
218
|
'chart.events.mousemove': null,
|
@@ -218,7 +230,8 @@
|
|
218
230
|
'chart.variant.threed.xaxis': true,
|
219
231
|
'chart.variant.threed.yaxis': true,
|
220
232
|
'chart.yaxispos': 'left',
|
221
|
-
'chart.variant': 'hbar'
|
233
|
+
'chart.variant': 'hbar',
|
234
|
+
'chart.clearto': 'rgba(0,0,0,0)'
|
222
235
|
}
|
223
236
|
|
224
237
|
// Check for support
|
@@ -227,9 +240,21 @@
|
|
227
240
|
return;
|
228
241
|
}
|
229
242
|
|
243
|
+
// This loop is used to check for stacked or grouped charts and now
|
244
|
+
// also to convert strings to numbers
|
230
245
|
for (i=0,len=this.data.length; i<len; ++i) {
|
231
|
-
if (typeof this.data[i] == 'object') {
|
246
|
+
if (typeof this.data[i] == 'object' && !RGraph.isNull(this.data[i])) {
|
247
|
+
|
232
248
|
this.stackedOrGrouped = true;
|
249
|
+
|
250
|
+
for (var j=0,len2=this.data[i].length; j<len2; ++j) {
|
251
|
+
if (typeof this.data[i][j] === 'string') {
|
252
|
+
this.data[i][j] = parseFloat(this.data[i][j]);
|
253
|
+
}
|
254
|
+
}
|
255
|
+
|
256
|
+
} else if (typeof this.data[i] == 'string') {
|
257
|
+
this.data[i] = parseFloat(this.data[i]) || 0;
|
233
258
|
}
|
234
259
|
}
|
235
260
|
|
@@ -268,7 +293,6 @@
|
|
268
293
|
ca = this.canvas,
|
269
294
|
co = ca.getContext('2d'),
|
270
295
|
prop = this.properties,
|
271
|
-
pa = RG.Path,
|
272
296
|
pa2 = RG.path2,
|
273
297
|
win = window,
|
274
298
|
doc = document,
|
@@ -319,10 +343,9 @@
|
|
319
343
|
|
320
344
|
|
321
345
|
// Convert uppercase letters to dot+lower case letter
|
322
|
-
name
|
323
|
-
|
324
|
-
|
325
|
-
});
|
346
|
+
while(name.match(/([A-Z])/)) {
|
347
|
+
name = name.replace(/([A-Z])/, '.' + RegExp.$1.toLowerCase());
|
348
|
+
}
|
326
349
|
|
327
350
|
if (name == 'chart.labels.abovebar') {
|
328
351
|
name = 'chart.labels.above';
|
@@ -385,8 +408,14 @@
|
|
385
408
|
//
|
386
409
|
// If the chart is 3d then angle it it
|
387
410
|
//
|
411
|
+
|
388
412
|
if (prop['chart.variant'] === '3d') {
|
389
|
-
|
413
|
+
|
414
|
+
if (prop['chart.text.accessible']) {
|
415
|
+
// Nada
|
416
|
+
} else {
|
417
|
+
co.setTransform(1,prop['chart.variant.threed.angle'],0,1,0.5,0.5);
|
418
|
+
}
|
390
419
|
|
391
420
|
// Enlarge the gutter if its 25
|
392
421
|
if (prop['chart.gutter.bottom'] === 25) {
|
@@ -720,7 +749,9 @@
|
|
720
749
|
var units_pre = prop['chart.units.pre'],
|
721
750
|
units_post = prop['chart.units.post'],
|
722
751
|
text_size = prop['chart.text.size'],
|
723
|
-
font = prop['chart.text.font']
|
752
|
+
font = prop['chart.text.font'],
|
753
|
+
offsetx = prop['chart.xlabels.offsetx'],
|
754
|
+
offsety = prop['chart.xlabels.offsety']
|
724
755
|
|
725
756
|
|
726
757
|
|
@@ -742,7 +773,7 @@
|
|
742
773
|
* Specific X labels
|
743
774
|
*/
|
744
775
|
if (RG.isArray(prop['chart.xlabels.specific'])) {
|
745
|
-
|
776
|
+
|
746
777
|
if (prop['chart.yaxispos'] == 'center') {
|
747
778
|
|
748
779
|
var halfGraphWidth = this.graphwidth / 2;
|
@@ -750,27 +781,31 @@
|
|
750
781
|
var interval = (this.graphwidth / 2) / (labels.length - 1);
|
751
782
|
|
752
783
|
co.fillStyle = prop['chart.text.color'];
|
753
|
-
|
784
|
+
|
754
785
|
for (var i=0; i<labels.length; i+=1) {
|
755
|
-
RG.
|
756
|
-
|
757
|
-
|
758
|
-
|
759
|
-
|
760
|
-
|
761
|
-
|
762
|
-
|
786
|
+
RG.text2(this, {
|
787
|
+
'font':font,
|
788
|
+
'size':text_size,
|
789
|
+
'x':this.gutterLeft + halfGraphWidth + (interval * i) + offsetx,
|
790
|
+
'y':ca.height - this.gutterBottom + offsetx,
|
791
|
+
'text':labels[i],
|
792
|
+
'valign':'top',
|
793
|
+
'halign':'center',
|
794
|
+
'tag': 'scale'
|
795
|
+
});
|
763
796
|
}
|
764
797
|
|
765
798
|
for (var i=(labels.length - 1); i>0; i-=1) {
|
766
|
-
RG.Text2(this, {
|
767
|
-
|
768
|
-
|
769
|
-
|
770
|
-
|
771
|
-
|
772
|
-
|
773
|
-
|
799
|
+
RG.Text2(this, {
|
800
|
+
'font':font,
|
801
|
+
'size':text_size,
|
802
|
+
'x':this.gutterLeft + (interval * (labels.length - i - 1)) + offsetx,
|
803
|
+
'y':ca.height - this.gutterBottom + offsety,
|
804
|
+
'text':labels[i],
|
805
|
+
'valign':'top',
|
806
|
+
'halign':'center',
|
807
|
+
'tag': 'scale'
|
808
|
+
});
|
774
809
|
}
|
775
810
|
|
776
811
|
} else if (prop['chart.yaxispos'] == 'right') {
|
@@ -781,14 +816,16 @@
|
|
781
816
|
co.fillStyle = prop['chart.text.color'];
|
782
817
|
|
783
818
|
for (var i=0; i<labels.length; i+=1) {
|
784
|
-
RG.
|
785
|
-
|
786
|
-
|
787
|
-
|
788
|
-
|
789
|
-
|
790
|
-
|
791
|
-
|
819
|
+
RG.text2(this, {
|
820
|
+
'font':font,
|
821
|
+
'size':text_size,
|
822
|
+
'x':this.gutterLeft + (interval * i) + offsetx,
|
823
|
+
'y':ca.height - this.gutterBottom + offsety,
|
824
|
+
'text':labels[labels.length - i - 1],
|
825
|
+
'valign':'top',
|
826
|
+
'halign':'center',
|
827
|
+
'tag': 'scale'
|
828
|
+
});
|
792
829
|
}
|
793
830
|
|
794
831
|
} else {
|
@@ -799,14 +836,16 @@
|
|
799
836
|
co.fillStyle = prop['chart.text.color'];
|
800
837
|
|
801
838
|
for (var i=0; i<labels.length; i+=1) {
|
802
|
-
RG.Text2(this, {
|
803
|
-
|
804
|
-
|
805
|
-
|
806
|
-
|
807
|
-
|
808
|
-
|
809
|
-
|
839
|
+
RG.Text2(this, {
|
840
|
+
'font':font,
|
841
|
+
'size':text_size,
|
842
|
+
'x':this.gutterLeft + (interval * i) + offsetx,
|
843
|
+
'y':ca.height - this.gutterBottom + offsety,
|
844
|
+
'text':labels[i],
|
845
|
+
'valign':'top',
|
846
|
+
'halign':'center',
|
847
|
+
'tag': 'scale'
|
848
|
+
});
|
810
849
|
}
|
811
850
|
}
|
812
851
|
|
@@ -827,8 +866,8 @@
|
|
827
866
|
RG.text2(this, {
|
828
867
|
'font':font,
|
829
868
|
'size':text_size,
|
830
|
-
'x':this.gutterLeft + (this.graphwidth / 2) - ((this.graphwidth / 2) * ((i+1)/this.scale2.labels.length)),
|
831
|
-
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap,
|
869
|
+
'x':this.gutterLeft + (this.graphwidth / 2) - ((this.graphwidth / 2) * ((i+1)/this.scale2.labels.length)) + offsetx,
|
870
|
+
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap + offsety,
|
832
871
|
'text':'-' + this.scale2.labels[i],
|
833
872
|
'valign':'center',
|
834
873
|
'halign':'center',
|
@@ -840,8 +879,8 @@
|
|
840
879
|
RG.text2(this, {
|
841
880
|
'font':font,
|
842
881
|
'size':text_size,
|
843
|
-
'x':this.gutterLeft + ((this.graphwidth / 2) * ((i+1)/this.scale2.labels.length)) + (this.graphwidth / 2),
|
844
|
-
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap,
|
882
|
+
'x':this.gutterLeft + ((this.graphwidth / 2) * ((i+1)/this.scale2.labels.length)) + (this.graphwidth / 2) + offsetx,
|
883
|
+
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap + offsety,
|
845
884
|
'text':this.scale2.labels[i],
|
846
885
|
'valign':'center',
|
847
886
|
'halign':'center',
|
@@ -856,8 +895,8 @@
|
|
856
895
|
RG.Text2(this, {
|
857
896
|
'font':font,
|
858
897
|
'size':text_size,
|
859
|
-
'x':this.gutterLeft + (i * (this.graphwidth / len)),
|
860
|
-
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap,
|
898
|
+
'x':this.gutterLeft + (i * (this.graphwidth / len)) + offsetx,
|
899
|
+
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap + offsety,
|
861
900
|
'text':'-' + this.scale2.labels[len - 1 - i],
|
862
901
|
'valign':'center',
|
863
902
|
'halign':'center',
|
@@ -871,8 +910,8 @@
|
|
871
910
|
RG.Text2(this, {
|
872
911
|
'font':font,
|
873
912
|
'size':text_size,
|
874
|
-
'x':this.gutterLeft + (this.graphwidth * ((i+1)/len)),
|
875
|
-
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap,
|
913
|
+
'x':this.gutterLeft + (this.graphwidth * ((i+1)/len)) + offsetx,
|
914
|
+
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap + offsety,
|
876
915
|
'text':this.scale2.labels[i],
|
877
916
|
'valign':'center',
|
878
917
|
'halign':'center',
|
@@ -898,8 +937,8 @@
|
|
898
937
|
RG.text2(this, {
|
899
938
|
'font':font,
|
900
939
|
'size':text_size,
|
901
|
-
'x':x,
|
902
|
-
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap,
|
940
|
+
'x':x + offsetx,
|
941
|
+
'y':this.gutterTop + this.halfTextHeight + this.graphheight + gap + offsety,
|
903
942
|
'text':RG.numberFormat(this, prop['chart.xmin'].toFixed(prop['chart.scale.decimals']), units_pre, units_post),
|
904
943
|
'valign':'center',
|
905
944
|
'halign':'center',
|
@@ -926,7 +965,9 @@
|
|
926
965
|
var xOffset = prop['chart.variant'] === '3d' && prop['chart.yaxispos'] === 'right' ? 15 : 5,
|
927
966
|
font = prop['chart.text.font'],
|
928
967
|
color = prop['chart.labels.color'] || prop['chart.text.color'],
|
929
|
-
bold = prop['chart.labels.bold']
|
968
|
+
bold = prop['chart.labels.bold'],
|
969
|
+
offsetx = prop['chart.labels.offsetx'],
|
970
|
+
offsety = prop['chart.labels.offsety']
|
930
971
|
|
931
972
|
|
932
973
|
// Draw the X axis labels
|
@@ -957,8 +998,8 @@
|
|
957
998
|
'font': font,
|
958
999
|
'size': prop['chart.text.size'],
|
959
1000
|
'bold': bold,
|
960
|
-
'x': x,
|
961
|
-
'y': y,
|
1001
|
+
'x': x + offsetx,
|
1002
|
+
'y': y + offsety,
|
962
1003
|
'text': String(prop['chart.labels'][i++]),
|
963
1004
|
'halign': halign,
|
964
1005
|
'valign': 'center',
|
@@ -1675,15 +1716,18 @@
|
|
1675
1716
|
co.strokeStyle = prop['chart.strokestyle'];
|
1676
1717
|
|
1677
1718
|
for (var i=0; i<coords.length; ++i) {
|
1678
|
-
|
1719
|
+
|
1679
1720
|
if (prop['chart.shadow']) {
|
1680
|
-
|
1681
|
-
|
1682
|
-
|
1683
|
-
|
1684
|
-
|
1685
|
-
|
1686
|
-
|
1721
|
+
|
1722
|
+
pa2(co, 'b lw % r % % % % s % f %',
|
1723
|
+
prop['chart.linewidth'],
|
1724
|
+
coords[i][0],
|
1725
|
+
coords[i][1],
|
1726
|
+
coords[i][2],
|
1727
|
+
coords[i][3],
|
1728
|
+
prop['chart.strokestyle'],
|
1729
|
+
coords[i][4]
|
1730
|
+
);
|
1687
1731
|
}
|
1688
1732
|
|
1689
1733
|
/**
|
@@ -1692,20 +1736,20 @@
|
|
1692
1736
|
var halign = 'left';
|
1693
1737
|
if (prop['chart.labels.above'] && coords[i][6]) {
|
1694
1738
|
|
1695
|
-
co.
|
1696
|
-
|
1739
|
+
var border = (coords[i][0] + coords[i][2] + 7 + co.measureText(prop['chart.labels.above.units.pre'] + this.coords[i][5] + prop['chart.labels.above.units.post']).width) > ca.width ? true : false,
|
1740
|
+
text = RG.numberFormat(this, (this.coords[i][5]).toFixed(prop['chart.labels.above.decimals']), prop['chart.labels.above.units.pre'], prop['chart.labels.above.units.post']);
|
1741
|
+
|
1697
1742
|
RG.noShadow(this);
|
1698
|
-
|
1699
|
-
var border = (coords[i][0] + coords[i][2] + 7 + co.measureText(prop['chart.units.pre'] + this.coords[i][5] + prop['chart.units.post']).width) > ca.width ? true : false;
|
1700
1743
|
|
1701
1744
|
/**
|
1702
1745
|
* Default to the value - then check for specific labels
|
1703
1746
|
*/
|
1704
|
-
|
1705
|
-
|
1747
|
+
|
1748
|
+
|
1749
|
+
if (typeof prop['chart.labels.above.specific'] === 'object' && prop['chart.labels.above.specific'] && prop['chart.labels.above.specific'][i]) {
|
1706
1750
|
text = prop['chart.labels.above.specific'][i];
|
1707
1751
|
}
|
1708
|
-
|
1752
|
+
|
1709
1753
|
var x = coords[i][0] + coords[i][2] + 5;
|
1710
1754
|
var y = coords[i][1] + (coords[i][3] / 2);
|
1711
1755
|
|
@@ -1718,14 +1762,17 @@
|
|
1718
1762
|
}
|
1719
1763
|
|
1720
1764
|
RG.text2(this, {
|
1721
|
-
'font': font,
|
1722
|
-
'size': size,
|
1723
|
-
|
1724
|
-
|
1725
|
-
|
1726
|
-
|
1727
|
-
'
|
1728
|
-
|
1765
|
+
font: typeof prop['chart.labels.above.font'] === 'string' ? prop['chart.labels.above.font'] : font,
|
1766
|
+
size: typeof prop['chart.labels.above.size'] === 'number' ? prop['chart.labels.above.size'] : size,
|
1767
|
+
color: typeof prop['chart.labels.above.color'] ==='string' ? prop['chart.labels.above.color'] : color,
|
1768
|
+
x: x,
|
1769
|
+
y: y,
|
1770
|
+
bold: prop['chart.labels.above.bold'],
|
1771
|
+
italic: prop['chart.labels.above.italic'],
|
1772
|
+
text: text,
|
1773
|
+
valign: 'center',
|
1774
|
+
halign: halign,
|
1775
|
+
tag: 'labels.above'
|
1729
1776
|
});
|
1730
1777
|
}
|
1731
1778
|
}
|
@@ -1762,7 +1809,7 @@
|
|
1762
1809
|
|
1763
1810
|
// Recreate the path/rectangle so that it can be tested
|
1764
1811
|
// ** DO NOT STROKE OR FILL IT **
|
1765
|
-
|
1812
|
+
pa2(co,['b','r',left,top,width,height]);
|
1766
1813
|
|
1767
1814
|
if (co.isPointInPath(mouseX, mouseY)) {
|
1768
1815
|
|
@@ -1841,8 +1888,11 @@
|
|
1841
1888
|
this.highlight =
|
1842
1889
|
this.Highlight = function (shape)
|
1843
1890
|
{
|
1844
|
-
|
1845
|
-
|
1891
|
+
if (typeof prop['chart.highlight.style'] === 'function') {
|
1892
|
+
(prop['chart.highlight.style'])(shape);
|
1893
|
+
} else {
|
1894
|
+
RG.Highlight.Rect(this, shape);
|
1895
|
+
}
|
1846
1896
|
};
|
1847
1897
|
|
1848
1898
|
|
@@ -1912,35 +1962,24 @@
|
|
1912
1962
|
|
1913
1963
|
// Set the top position
|
1914
1964
|
tooltip.style.left = 0;
|
1915
|
-
tooltip.style.top =
|
1965
|
+
tooltip.style.top = window.event.pageY - height - 5 + 'px';
|
1916
1966
|
|
1917
1967
|
// By default any overflow is hidden
|
1918
1968
|
tooltip.style.overflow = '';
|
1919
|
-
|
1920
|
-
// The arrow
|
1921
|
-
var img = new Image();
|
1922
|
-
img.src = '';
|
1923
|
-
img.style.position = 'absolute';
|
1924
|
-
img.id = '__rgraph_tooltip_pointer__';
|
1925
|
-
img.style.top = (tooltip.offsetHeight - 2) + 'px';
|
1926
|
-
tooltip.appendChild(img);
|
1927
1969
|
|
1928
1970
|
// Reposition the tooltip if at the edges:
|
1929
1971
|
|
1930
1972
|
// LEFT edge
|
1931
|
-
if (
|
1932
|
-
tooltip.style.left =
|
1933
|
-
img.style.left = ((width * 0.1) - 8.5) + 'px';
|
1973
|
+
if (canvasXY[0] + mouseXY[0] - (width / 2) < 0) {
|
1974
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width * 0.1) + 'px';
|
1934
1975
|
|
1935
1976
|
// RIGHT edge
|
1936
|
-
} else if (
|
1937
|
-
tooltip.style.left = canvasXY[0] +
|
1938
|
-
img.style.left = ((width * 0.9) - 8.5) + 'px';
|
1977
|
+
} else if (canvasXY[0] + mouseXY[0] + (width / 2) > doc.body.offsetWidth) {
|
1978
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width * 0.9) + 'px';
|
1939
1979
|
|
1940
1980
|
// Default positioning - CENTERED
|
1941
1981
|
} else {
|
1942
|
-
tooltip.style.left =
|
1943
|
-
img.style.left = ((width * 0.5) - 8.5) + 'px';
|
1982
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width / 2) + 'px';
|
1944
1983
|
}
|
1945
1984
|
};
|
1946
1985
|
|
@@ -2142,11 +2181,14 @@
|
|
2142
2181
|
*/
|
2143
2182
|
this.grow = function ()
|
2144
2183
|
{
|
2145
|
-
var obj
|
2146
|
-
opt
|
2147
|
-
frames
|
2148
|
-
frame
|
2149
|
-
callback
|
2184
|
+
var obj = this,
|
2185
|
+
opt = arguments[0] || {},
|
2186
|
+
frames = opt.frames || 30,
|
2187
|
+
frame = 0,
|
2188
|
+
callback = arguments[1] || function () {},
|
2189
|
+
labelsAbove = prop['chart.labels.above'];
|
2190
|
+
|
2191
|
+
this.set('labelsAbove', false);
|
2150
2192
|
|
2151
2193
|
|
2152
2194
|
// Save the data
|
@@ -2197,6 +2239,12 @@
|
|
2197
2239
|
frame += 1;
|
2198
2240
|
RG.Effects.updateCanvas(iterator);
|
2199
2241
|
} else {
|
2242
|
+
|
2243
|
+
if (labelsAbove) {
|
2244
|
+
obj.set('labelsAbove', true);
|
2245
|
+
RG.redraw();
|
2246
|
+
}
|
2247
|
+
|
2200
2248
|
callback(obj);
|
2201
2249
|
}
|
2202
2250
|
}
|
@@ -2227,7 +2275,10 @@
|
|
2227
2275
|
var framesperbar = opt.frames / 3,
|
2228
2276
|
frame = -1,
|
2229
2277
|
callback = arguments[1] || function () {},
|
2230
|
-
original = RG.arrayClone(obj.data)
|
2278
|
+
original = RG.arrayClone(obj.data),
|
2279
|
+
labelsAbove = prop['chart.labels.above'];
|
2280
|
+
|
2281
|
+
this.set('labelsAbove', false);
|
2231
2282
|
|
2232
2283
|
for (var i=0,len=obj.data.length; i<len; i+=1) {
|
2233
2284
|
opt.startFrames[i] = ((opt.frames / 2) / (obj.data.length - 1)) * i;
|
@@ -2254,39 +2305,45 @@
|
|
2254
2305
|
++frame;
|
2255
2306
|
|
2256
2307
|
for (var i=0,len=obj.data.length; i<len; i+=1) {
|
2257
|
-
|
2258
|
-
|
2308
|
+
if (frame > opt.startFrames[i]) {
|
2309
|
+
if (typeof obj.data[i] === 'number') {
|
2310
|
+
|
2311
|
+
obj.data[i] = ma.min(
|
2312
|
+
ma.abs(original[i]),
|
2313
|
+
ma.abs(original[i] * ( (opt.counters[i]++) / framesperbar))
|
2314
|
+
);
|
2315
|
+
|
2316
|
+
// Make the number negative if the original was
|
2317
|
+
if (original[i] < 0) {
|
2318
|
+
obj.data[i] *= -1;
|
2319
|
+
}
|
2320
|
+
} else if (!RG.isNull(obj.data[i])) {
|
2321
|
+
for (var j=0,len2=obj.data[i].length; j<len2; j+=1) {
|
2259
2322
|
|
2260
|
-
obj.data[i] = ma.min(
|
2261
|
-
ma.abs(original[i]),
|
2262
|
-
ma.abs(original[i] * ( (opt.counters[i]++) / framesperbar))
|
2323
|
+
obj.data[i][j] = ma.min(
|
2324
|
+
ma.abs(original[i][j]),
|
2325
|
+
ma.abs(original[i][j] * ( (opt.counters[i][j]++) / framesperbar))
|
2263
2326
|
);
|
2264
|
-
|
2265
|
-
// Make the number negative if the original was
|
2266
|
-
if (original[i] < 0) {
|
2267
|
-
obj.data[i] *= -1;
|
2268
|
-
}
|
2269
|
-
} else if (!RG.isNull(obj.data[i])) {
|
2270
|
-
for (var j=0,len2=obj.data[i].length; j<len2; j+=1) {
|
2271
|
-
|
2272
|
-
obj.data[i][j] = ma.min(
|
2273
|
-
ma.abs(original[i][j]),
|
2274
|
-
ma.abs(original[i][j] * ( (opt.counters[i][j]++) / framesperbar))
|
2275
|
-
);
|
2276
2327
|
|
2277
|
-
|
2278
|
-
|
2279
|
-
|
2280
|
-
}
|
2328
|
+
// Make the number negative if the original was
|
2329
|
+
if (original[i][j] < 0) {
|
2330
|
+
obj.data[i][j] *= -1;
|
2281
2331
|
}
|
2282
2332
|
}
|
2283
|
-
} else {
|
2284
|
-
obj.data[i] = typeof obj.data[i] === 'object' && obj.data[i] ? RG.arrayPad([], obj.data[i].length, 0) : (RG.isNull(obj.data[i]) ? null : 0);
|
2285
2333
|
}
|
2334
|
+
} else {
|
2335
|
+
obj.data[i] = typeof obj.data[i] === 'object' && obj.data[i] ? RG.arrayPad([], obj.data[i].length, 0) : (RG.isNull(obj.data[i]) ? null : 0);
|
2336
|
+
}
|
2286
2337
|
}
|
2287
2338
|
|
2288
2339
|
|
2289
2340
|
if (frame >= opt.frames) {
|
2341
|
+
|
2342
|
+
if (labelsAbove) {
|
2343
|
+
obj.set('labelsAbove', true);
|
2344
|
+
RG.redrawCanvas(obj.canvas);
|
2345
|
+
}
|
2346
|
+
|
2290
2347
|
callback(obj);
|
2291
2348
|
} else {
|
2292
2349
|
RG.redrawCanvas(obj.canvas);
|