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 is just
|
10
|
+
* | the terms of the GPL. The commercial license is just 99 GBP and you can |
|
11
11
|
* | read about it here: |
|
12
12
|
* | http://www.rgraph.net/license |
|
13
13
|
* o--------------------------------------------------------------------------------o
|
@@ -89,7 +89,7 @@
|
|
89
89
|
'chart.gutter.bottom': 25,
|
90
90
|
'chart.numticks': 10,
|
91
91
|
'chart.numticks.inner': 50,
|
92
|
-
'chart.background.color': '#eee',
|
92
|
+
'chart.background.color': 'Gradient(#ccc:#eee:#efefef)',
|
93
93
|
'chart.shadow': false,
|
94
94
|
'chart.shadow.color': 'rgba(0,0,0,0.5)',
|
95
95
|
'chart.shadow.blur': 3,
|
@@ -105,7 +105,10 @@
|
|
105
105
|
'chart.title.valign': null,
|
106
106
|
'chart.text.size': 12,
|
107
107
|
'chart.text.color': 'black',
|
108
|
-
'chart.text.font': 'Arial',
|
108
|
+
'chart.text.font': 'Segoe UI, Arial, Verdana, sans-serif',
|
109
|
+
'chart.text.accessible': true,
|
110
|
+
'chart.text.accessible.overflow': 'visible',
|
111
|
+
'chart.text.accessible.pointerevents': false,
|
109
112
|
'chart.contextmenu': null,
|
110
113
|
'chart.units.pre': '',
|
111
114
|
'chart.units.post': '',
|
@@ -134,6 +137,8 @@
|
|
134
137
|
'chart.resize.handle.background':null,
|
135
138
|
'chart.labels.specific': null,
|
136
139
|
'chart.labels.count': 10,
|
140
|
+
'chart.labels.offsetx': 0,
|
141
|
+
'chart.labels.offsety': 0,
|
137
142
|
'chart.adjustable': false,
|
138
143
|
'chart.scale.decimals': 0,
|
139
144
|
'chart.scale.point': '.',
|
@@ -163,7 +168,8 @@
|
|
163
168
|
'chart.labels.position': 'bottom',
|
164
169
|
'chart.events.mousemove': null,
|
165
170
|
'chart.events.click': null,
|
166
|
-
'chart.border.inner': true
|
171
|
+
'chart.border.inner': true,
|
172
|
+
'chart.clearto': 'rgba(0,0,0,0)'
|
167
173
|
}
|
168
174
|
|
169
175
|
|
@@ -200,7 +206,6 @@
|
|
200
206
|
ca = this.canvas,
|
201
207
|
co = ca.getContext('2d'),
|
202
208
|
prop = this.properties,
|
203
|
-
pa = RG.Path,
|
204
209
|
pa2 = RG.path2,
|
205
210
|
win = window,
|
206
211
|
doc = document,
|
@@ -253,10 +258,9 @@
|
|
253
258
|
|
254
259
|
|
255
260
|
// Convert uppercase letters to dot+lower case letter
|
256
|
-
name
|
257
|
-
|
258
|
-
|
259
|
-
});
|
261
|
+
while(name.match(/([A-Z])/)) {
|
262
|
+
name = name.replace(/([A-Z])/, '.' + RegExp.$1.toLowerCase());
|
263
|
+
}
|
260
264
|
|
261
265
|
|
262
266
|
/**
|
@@ -354,7 +358,7 @@
|
|
354
358
|
this.coords = [];
|
355
359
|
this.coordsText = [];
|
356
360
|
|
357
|
-
this.
|
361
|
+
this.drawbar();
|
358
362
|
this.DrawTickMarks();
|
359
363
|
this.DrawLabels();
|
360
364
|
this.DrawTitle();
|
@@ -448,13 +452,13 @@
|
|
448
452
|
'max':this.max,
|
449
453
|
'min':this.min,
|
450
454
|
'strict':true,
|
451
|
-
'scale.thousand':prop['chart.scale.thousand'],
|
452
|
-
'scale.point':prop['chart.scale.point'],
|
453
|
-
'scale.decimals':prop['chart.scale.decimals'],
|
454
|
-
'ylabels.count':prop['chart.labels.count'],
|
455
|
-
'scale.round':prop['chart.scale.round'],
|
456
|
-
'units.pre':
|
457
|
-
'units.post':
|
455
|
+
'scale.thousand': prop['chart.scale.thousand'],
|
456
|
+
'scale.point': prop['chart.scale.point'],
|
457
|
+
'scale.decimals': prop['chart.scale.decimals'],
|
458
|
+
'ylabels.count': prop['chart.labels.count'],
|
459
|
+
'scale.round': prop['chart.scale.round'],
|
460
|
+
'units.pre': prop['chart.units.pre'],
|
461
|
+
'units.post': prop['chart.units.post']
|
458
462
|
});
|
459
463
|
|
460
464
|
// Set a shadow if requested
|
@@ -462,12 +466,6 @@
|
|
462
466
|
RG.SetShadow(this, prop['chart.shadow.color'], prop['chart.shadow.offsetx'], prop['chart.shadow.offsety'], prop['chart.shadow.blur']);
|
463
467
|
}
|
464
468
|
|
465
|
-
// Draw the shadow for MSIE
|
466
|
-
if (RG.ISOLD && prop['chart.shadow']) {
|
467
|
-
co.fillStyle = prop['chart.shadow.color'];
|
468
|
-
co.fillRect(this.gutterLeft + prop['chart.shadow.offsetx'], this.gutterTop + prop['chart.shadow.offsety'], this.width, this.height);
|
469
|
-
}
|
470
|
-
|
471
469
|
// Draw the outline
|
472
470
|
co.fillStyle = prop['chart.background.color'];
|
473
471
|
co.strokeStyle = prop['chart.strokestyle.outer'];
|
@@ -475,7 +473,7 @@
|
|
475
473
|
co.fillRect(this.gutterLeft, this.gutterTop, this.width, this.height);
|
476
474
|
|
477
475
|
// Turn off any shadow
|
478
|
-
RG.
|
476
|
+
RG.noShadow(this);
|
479
477
|
|
480
478
|
co.fillStyle = prop['chart.colors'][0];
|
481
479
|
co.strokeStyle = prop['chart.strokestyle.outer'];
|
@@ -483,7 +481,7 @@
|
|
483
481
|
var margin = prop['chart.margin'];
|
484
482
|
|
485
483
|
// Draw the actual bar itself
|
486
|
-
var barWidth =
|
484
|
+
var barWidth = ma.min(this.width, ((RG.array_sum(this.value) - this.min) / (this.max - this.min) ) * this.width);
|
487
485
|
|
488
486
|
if (prop['chart.tickmarks.inner']) {
|
489
487
|
|
@@ -506,45 +504,71 @@
|
|
506
504
|
/**
|
507
505
|
* This bit draws the actual progress bar
|
508
506
|
*/
|
509
|
-
if (typeof
|
510
|
-
|
511
|
-
co.strokeStyle = prop['chart.strokestyle.inner'];
|
512
|
-
co.fillStyle = prop['chart.colors'][0];
|
513
|
-
|
507
|
+
if (typeof this.value === 'number') {
|
508
|
+
|
514
509
|
if (prop['chart.border.inner']) {
|
515
|
-
|
510
|
+
this.drawCurvedBar({
|
511
|
+
x: this.gutterLeft,
|
512
|
+
y: this.gutterTop + margin,
|
513
|
+
width: barWidth,
|
514
|
+
height: this.height - margin - margin,
|
515
|
+
stroke: prop['chart.strokestyle.inner']
|
516
|
+
});
|
516
517
|
}
|
517
|
-
|
518
|
+
|
519
|
+
this.drawCurvedBar({
|
520
|
+
x: this.gutterLeft,
|
521
|
+
y: this.gutterTop + margin,
|
522
|
+
width: barWidth,
|
523
|
+
height: this.height - margin - margin,
|
524
|
+
fill: prop['chart.colors'][0]
|
525
|
+
});
|
518
526
|
|
519
527
|
// Store the coords
|
520
|
-
this.coords.push([
|
521
|
-
|
522
|
-
|
523
|
-
|
524
|
-
|
525
|
-
|
528
|
+
this.coords.push([
|
529
|
+
this.gutterLeft,
|
530
|
+
this.gutterTop + margin,
|
531
|
+
barWidth,
|
532
|
+
this.height - margin - margin
|
533
|
+
]);
|
526
534
|
|
535
|
+
} else if (typeof this.value === 'object') {
|
536
|
+
|
527
537
|
co.beginPath();
|
528
|
-
co.strokeStyle = prop['chart.strokestyle.inner'];
|
529
538
|
|
530
539
|
var startPoint = this.gutterLeft;
|
531
540
|
|
532
|
-
for (var i=0
|
541
|
+
for (var i=0,len=this.value.length; i<len; ++i) {
|
533
542
|
|
534
|
-
var segmentLength = (this.value[i] / RG.
|
535
|
-
co.fillStyle = prop['chart.colors'][i];
|
543
|
+
var segmentLength = (this.value[i] / RG.arraySum(this.value)) * barWidth;
|
536
544
|
|
537
545
|
if (prop['chart.border.inner']) {
|
538
|
-
|
546
|
+
this.drawCurvedBar({
|
547
|
+
x: startPoint,
|
548
|
+
y: this.gutterTop + margin,
|
549
|
+
width: segmentLength,
|
550
|
+
height: this.height - margin - margin,
|
551
|
+
fill: prop['chart.colors'][i],
|
552
|
+
stroke: prop['chart.strokestyle.inner']
|
553
|
+
});
|
539
554
|
}
|
540
|
-
|
555
|
+
|
556
|
+
this.drawCurvedBar({
|
557
|
+
x: startPoint,
|
558
|
+
y: this.gutterTop + margin,
|
559
|
+
width: segmentLength,
|
560
|
+
height: this.height - margin - margin,
|
561
|
+
fill: prop['chart.colors'][i]
|
562
|
+
});
|
541
563
|
|
542
564
|
|
543
565
|
// Store the coords
|
544
|
-
this.coords.push([
|
545
|
-
|
546
|
-
|
547
|
-
|
566
|
+
this.coords.push([
|
567
|
+
startPoint,
|
568
|
+
this.gutterTop + margin,
|
569
|
+
segmentLength,
|
570
|
+
this.height - margin - margin
|
571
|
+
]);
|
548
572
|
|
549
573
|
startPoint += segmentLength;
|
550
574
|
}
|
@@ -586,17 +610,18 @@
|
|
586
610
|
*/
|
587
611
|
if (prop['chart.label.inner']) {
|
588
612
|
co.fillStyle = 'black';
|
589
|
-
RG.Text2(this, {
|
590
|
-
|
591
|
-
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
|
598
|
-
|
599
|
-
|
613
|
+
RG.Text2(this, {
|
614
|
+
'font':prop['chart.text.font'],
|
615
|
+
'size':prop['chart.text.size'] + 2,
|
616
|
+
'x':this.gutterLeft + barWidth + 5,
|
617
|
+
'y':this.gutterTop + (this.height / 2),
|
618
|
+
'text': String(prop['chart.units.pre'] + this.value + prop['chart.units.post']),
|
619
|
+
'valign':'bottom',
|
620
|
+
'halign':'left',
|
621
|
+
'bounding':true,
|
622
|
+
'boundingFill':'white',
|
623
|
+
'tag': 'label.inner'
|
624
|
+
});
|
600
625
|
}
|
601
626
|
};
|
602
627
|
|
@@ -653,10 +678,12 @@
|
|
653
678
|
|
654
679
|
co.fillStyle = prop['chart.text.color'];
|
655
680
|
|
656
|
-
var xPoints = []
|
657
|
-
|
658
|
-
|
659
|
-
|
681
|
+
var xPoints = [],
|
682
|
+
yPoints = [],
|
683
|
+
font = prop['chart.text.font'],
|
684
|
+
size = prop['chart.text.size'],
|
685
|
+
offsetx = prop['chart.labels.offsetx'],
|
686
|
+
offsety = prop['chart.labels.offsety'];
|
660
687
|
|
661
688
|
for (i=0,len=this.scale2.labels.length; i<len; i++) {
|
662
689
|
|
@@ -671,38 +698,41 @@
|
|
671
698
|
var valign = 'top';
|
672
699
|
}
|
673
700
|
|
674
|
-
RG.
|
675
|
-
|
676
|
-
|
677
|
-
|
678
|
-
|
679
|
-
|
680
|
-
|
681
|
-
|
682
|
-
|
701
|
+
RG.text2(this, {
|
702
|
+
'font':font,
|
703
|
+
'size':size,
|
704
|
+
'x':x + offsetx,
|
705
|
+
'y':y + offsety,
|
706
|
+
'text': this.scale2.labels[i],
|
707
|
+
'valign':valign,
|
708
|
+
'halign':'center',
|
709
|
+
'tag': 'scale'
|
710
|
+
});
|
683
711
|
}
|
684
712
|
|
685
713
|
if (prop['chart.tickmarks.zerostart']) {
|
686
714
|
if (prop['chart.labels.position'] == 'top') {
|
687
|
-
RG.
|
688
|
-
|
689
|
-
|
690
|
-
|
691
|
-
|
692
|
-
|
693
|
-
|
694
|
-
|
695
|
-
|
715
|
+
RG.text2(this, {
|
716
|
+
'font':font,
|
717
|
+
'size':size,
|
718
|
+
'x':this.gutterLeft + offsetx,
|
719
|
+
'y':this.gutterTop - 6 + offsety,
|
720
|
+
'text': prop['chart.units.pre'] + Number(this.min).toFixed(prop['chart.scale.decimals']) + prop['chart.units.post'],
|
721
|
+
'valign':'bottom',
|
722
|
+
'halign':'center',
|
723
|
+
'tag': 'scale'
|
724
|
+
});
|
696
725
|
} else {
|
697
|
-
RG.
|
698
|
-
|
699
|
-
|
700
|
-
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
|
705
|
-
|
726
|
+
RG.text2(this, {
|
727
|
+
'font':font,
|
728
|
+
'size':size,
|
729
|
+
'x':this.gutterLeft + offsetx,
|
730
|
+
'y':ca.height - this.gutterBottom + 5 + offsety,
|
731
|
+
'text': prop['chart.units.pre'] + Number(this.min).toFixed(prop['chart.scale.decimals']) + prop['chart.units.post'],
|
732
|
+
'valign':'top',
|
733
|
+
'halign':'center',
|
734
|
+
'tag': 'scale'
|
735
|
+
});
|
706
736
|
}
|
707
737
|
}
|
708
738
|
};
|
@@ -718,27 +748,34 @@
|
|
718
748
|
this.getShape =
|
719
749
|
this.getBar = function (e)
|
720
750
|
{
|
721
|
-
var
|
722
|
-
|
723
|
-
|
724
|
-
|
725
|
-
|
726
|
-
|
727
|
-
|
728
|
-
|
729
|
-
|
730
|
-
|
731
|
-
|
732
|
-
|
733
|
-
|
734
|
-
|
751
|
+
var mouseXY = RG.getMouseXY(e),
|
752
|
+
mouseX = mouseXY[0],
|
753
|
+
mouseY = mouseXY[1];
|
754
|
+
|
755
|
+
for (var i=0,len=this.coords.length; i<len; i++) {
|
756
|
+
|
757
|
+
var x = this.coords[i][0],
|
758
|
+
y = this.coords[i][1],
|
759
|
+
w = this.coords[i][2],
|
760
|
+
h = this.coords[i][3],
|
761
|
+
idx = i;
|
762
|
+
|
763
|
+
co.beginPath();
|
764
|
+
this.drawCurvedBar({
|
765
|
+
x: x,
|
766
|
+
y: y,
|
767
|
+
height: h,
|
768
|
+
width: w
|
769
|
+
});
|
770
|
+
|
771
|
+
if (co.isPointInPath(mouseX, mouseY)) {
|
735
772
|
|
736
773
|
var tooltip = RG.parseTooltipText(prop['chart.tooltips'], idx);
|
737
774
|
|
738
775
|
return {
|
739
|
-
|
740
|
-
|
741
|
-
|
776
|
+
0: this, 1: x, 2: y, 3: w, 4: h, 5: idx,
|
777
|
+
'object':this, 'x':x, 'y':y, 'width': w, 'height': h, 'index': idx, 'tooltip': tooltip
|
778
|
+
}
|
742
779
|
}
|
743
780
|
}
|
744
781
|
};
|
@@ -781,8 +818,21 @@
|
|
781
818
|
this.highlight =
|
782
819
|
this.Highlight = function (shape)
|
783
820
|
{
|
784
|
-
|
785
|
-
|
821
|
+
var last = shape.index === this.coords.length - 1;
|
822
|
+
|
823
|
+
if (typeof prop['chart.highlight.style'] === 'function') {
|
824
|
+
(prop['chart.highlight.style'])(shape);
|
825
|
+
} else {
|
826
|
+
|
827
|
+
this.drawCurvedBar({
|
828
|
+
x: shape.x,
|
829
|
+
y: shape.y,
|
830
|
+
width: shape.width,
|
831
|
+
height: shape.height,
|
832
|
+
stroke: prop['chart.highlight.stroke'],
|
833
|
+
fill: prop['chart.highlight.fill']
|
834
|
+
});
|
835
|
+
}
|
786
836
|
};
|
787
837
|
|
788
838
|
|
@@ -853,23 +903,26 @@
|
|
853
903
|
|
854
904
|
if (labels) {
|
855
905
|
|
856
|
-
var font
|
857
|
-
|
858
|
-
|
859
|
-
|
906
|
+
var font = prop['chart.text.font'],
|
907
|
+
size = prop['chart.text.size'],
|
908
|
+
valign = (prop['chart.labels.position'] == 'top' ? 'bottom' : 'top'),
|
909
|
+
step = this.width / (labels.length - 1),
|
910
|
+
offsetx = prop['chart.labels.offsetx'],
|
911
|
+
offsety = prop['chart.labels.offsety']
|
860
912
|
|
861
913
|
co.beginPath();
|
862
914
|
co.fillStyle = prop['chart.text.color'];
|
863
915
|
for (var i=0; i<labels.length; ++i) {
|
864
|
-
RG.Text2(this, {
|
865
|
-
|
866
|
-
|
867
|
-
|
868
|
-
|
869
|
-
|
870
|
-
|
871
|
-
|
872
|
-
|
916
|
+
RG.Text2(this, {
|
917
|
+
font:font,
|
918
|
+
size:size,
|
919
|
+
x: this.gutterLeft + (step * i) + offsetx,
|
920
|
+
y: prop['chart.labels.position'] == 'top' ? this.gutterTop - 7 + offsety: ca.height - this.gutterBottom + 7 + offsety,
|
921
|
+
text: labels[i],
|
922
|
+
valign:valign,
|
923
|
+
halign:'center',
|
924
|
+
tag: 'labels.specific'
|
925
|
+
});
|
873
926
|
}
|
874
927
|
co.fill();
|
875
928
|
}
|
@@ -897,38 +950,28 @@
|
|
897
950
|
var gutterTop = this.gutterTop;
|
898
951
|
var width = tooltip.offsetWidth;
|
899
952
|
var height = tooltip.offsetHeight;
|
953
|
+
var mouseXY = RG.getMouseXY(window.event);
|
900
954
|
|
901
955
|
// Set the top position
|
902
956
|
tooltip.style.left = 0;
|
903
|
-
tooltip.style.top =
|
957
|
+
tooltip.style.top = window.event.pageY - height - 5 + 'px';
|
904
958
|
|
905
959
|
// By default any overflow is hidden
|
906
960
|
tooltip.style.overflow = '';
|
907
|
-
|
908
|
-
// The arrow
|
909
|
-
var img = new Image();
|
910
|
-
img.src = '';
|
911
|
-
img.style.position = 'absolute';
|
912
|
-
img.id = '__rgraph_tooltip_pointer__';
|
913
|
-
img.style.top = (tooltip.offsetHeight - 2) + 'px';
|
914
|
-
tooltip.appendChild(img);
|
915
961
|
|
916
962
|
// Reposition the tooltip if at the edges:
|
917
963
|
|
918
964
|
// LEFT edge
|
919
|
-
if (
|
920
|
-
tooltip.style.left =
|
921
|
-
img.style.left = ((width * 0.1) - 8.5) + 'px';
|
965
|
+
if (canvasXY[0] + mouseXY[0] - (width / 2) < 0) {
|
966
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width * 0.1) + 'px';
|
922
967
|
|
923
968
|
// RIGHT edge
|
924
|
-
} else if (
|
925
|
-
tooltip.style.left = canvasXY[0] +
|
926
|
-
img.style.left = ((width * 0.9) - 8.5) + 'px';
|
969
|
+
} else if (canvasXY[0] + mouseXY[0] + (width / 2) > doc.body.offsetWidth) {
|
970
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width * 0.9) + 'px';
|
927
971
|
|
928
972
|
// Default positioning - CENTERED
|
929
973
|
} else {
|
930
|
-
tooltip.style.left =
|
931
|
-
img.style.left = ((width * 0.5) - 8.5) + 'px';
|
974
|
+
tooltip.style.left = canvasXY[0] + mouseXY[0] - (width / 2) + 'px';
|
932
975
|
}
|
933
976
|
};
|
934
977
|
|
@@ -1075,23 +1118,45 @@
|
|
1075
1118
|
co.save();
|
1076
1119
|
// Draw a path to clip to
|
1077
1120
|
co.beginPath();
|
1078
|
-
|
1079
|
-
|
1080
|
-
|
1081
|
-
|
1082
|
-
|
1083
|
-
|
1084
|
-
|
1085
|
-
|
1086
|
-
|
1087
|
-
|
1121
|
+
co.rect(
|
1122
|
+
this.coords[0][0],
|
1123
|
+
this.coords[0][1],
|
1124
|
+
len,
|
1125
|
+
this.coords[0][3]
|
1126
|
+
);
|
1127
|
+
co.clip();
|
1128
|
+
|
1129
|
+
co.save();
|
1130
|
+
// Draw a path to clip to
|
1131
|
+
co.beginPath();
|
1132
|
+
this.drawCurvedBar({
|
1133
|
+
x: this.coords[0][0],
|
1134
|
+
y: this.coords[0][1],
|
1135
|
+
width: len,
|
1136
|
+
height: this.coords[0][3]
|
1137
|
+
});
|
1138
|
+
co.clip();
|
1088
1139
|
|
1089
|
-
|
1140
|
+
// Now draw the rect with a shadow
|
1141
|
+
co.beginPath();
|
1142
|
+
|
1143
|
+
co.shadowColor = 'black';
|
1144
|
+
co.shadowOffsetX = 0;
|
1145
|
+
co.shadowOffsetY = 0;
|
1146
|
+
co.shadowBlur = 15;
|
1147
|
+
|
1148
|
+
co.lineWidth = 2;
|
1149
|
+
|
1150
|
+
this.drawCurvedBar({
|
1151
|
+
x: this.coords[0][0] - 51,
|
1152
|
+
y: this.coords[0][1] - 1,
|
1153
|
+
width: len + 52,
|
1154
|
+
height: this.coords[0][3] + 2
|
1155
|
+
});
|
1090
1156
|
|
1091
|
-
co.
|
1092
|
-
|
1093
|
-
co.
|
1094
|
-
|
1157
|
+
co.stroke();
|
1158
|
+
|
1159
|
+
co.restore();
|
1095
1160
|
co.restore();
|
1096
1161
|
};
|
1097
1162
|
|
@@ -1123,18 +1188,19 @@
|
|
1123
1188
|
}
|
1124
1189
|
|
1125
1190
|
|
1126
|
-
RG.Text2(this, {
|
1127
|
-
|
1128
|
-
|
1129
|
-
|
1130
|
-
|
1131
|
-
|
1132
|
-
|
1133
|
-
|
1134
|
-
|
1135
|
-
|
1136
|
-
|
1137
|
-
|
1191
|
+
RG.Text2(this, {
|
1192
|
+
'font':font,
|
1193
|
+
'size':size,
|
1194
|
+
'x': typeof(prop['chart.title.x']) == 'number' ? prop['chart.title.x'] : x,
|
1195
|
+
'y': typeof(prop['chart.title.y']) == 'number' ? prop['chart.title.y'] : y,
|
1196
|
+
'text': text,
|
1197
|
+
'valign': prop['chart.title.valign'] ? prop['chart.title.valign'] : valign,
|
1198
|
+
'halign': prop['chart.title.halign'] ? prop['chart.title.halign'] : 'center',
|
1199
|
+
'bold':prop['chart.title.bold'],
|
1200
|
+
'bounding': prop['chart.title.background'] ? true : false,
|
1201
|
+
'boundingFill': prop['chart.title.background'],
|
1202
|
+
'tag': 'title'
|
1203
|
+
});
|
1138
1204
|
}
|
1139
1205
|
};
|
1140
1206
|
|
@@ -1188,6 +1254,34 @@
|
|
1188
1254
|
|
1189
1255
|
|
1190
1256
|
|
1257
|
+
/**
|
1258
|
+
* Draws a bar with a curved end.
|
1259
|
+
*
|
1260
|
+
* DOESN'T DRAW A CURVED BAR ANY MORE - JUST A REGULAR SQUARE ENDED BAR
|
1261
|
+
*
|
1262
|
+
* @param object opt The coords and colours
|
1263
|
+
*/
|
1264
|
+
this.drawCurvedBar = function (opt)
|
1265
|
+
{
|
1266
|
+
pa2(co, 'b r % % % %',
|
1267
|
+
opt.x, opt.y,
|
1268
|
+
opt.width, opt.height
|
1269
|
+
);
|
1270
|
+
|
1271
|
+
if (opt.stroke) {
|
1272
|
+
co.strokeStyle = opt.stroke;
|
1273
|
+
co.stroke();
|
1274
|
+
}
|
1275
|
+
|
1276
|
+
if (opt.fill) {
|
1277
|
+
co.fillStyle = opt.fill;
|
1278
|
+
co.fill();
|
1279
|
+
}
|
1280
|
+
}
|
1281
|
+
|
1282
|
+
|
1283
|
+
|
1284
|
+
|
1191
1285
|
/**
|
1192
1286
|
* This function runs once only
|
1193
1287
|
* (put at the end of the file (before any effects))
|