xxxxxxxxxx
1
<div class="container my-5">
2
<div class="row">
3
<div class="col-md-12 mb-4">
4
<canvas id="canvas"></canvas>
5
</div>
6
<div class="col-md-12 d-flex justify-content-center">
7
<button class="btn btn-primary btn-sm" id="randomizeData">Randomize Data</button>
8
</div>
9
</div>
10
</div>
1
1
xxxxxxxxxx
1
// Chart customizer
2
window.chartColors = {
3
red: 'rgb(255, 99, 132)',
4
orange: 'rgb(255, 159, 64)',
5
yellow: 'rgb(255, 205, 86)',
6
green: 'rgb(75, 192, 192)',
7
blue: 'rgb(54, 162, 235)',
8
purple: 'rgb(153, 102, 255)',
9
grey: 'rgb(201, 203, 207)'
10
};
11
12
(function(global) {
13
var MONTHS = [
14
'January',
15
'February',
16
'March',
17
'April',
18
'May',
19
'June',
20
'July',
21
'August',
22
'September',
23
'October',
24
'November',
25
'December'
26
];
27
28
var COLORS = [
29
'#4dc9f6',
30
'#f67019',
31
'#f53794',
32
'#537bc4',
33
'#acc236',
34
'#166a8f',
35
'#00a950',
36
'#58595b',
37
'#8549ba'
38
];
39
40
var Samples = global.Samples || (global.Samples = {});
41
var Color = global.Color;
42
43
Samples.utils = {
44
// Adapted from http://indiegamr.com/generate-repeatable-random-numbers-in-js/
45
srand: function(seed) {
46
this._seed = seed;
47
},
48
49
rand: function(min, max) {
50
var seed = this._seed;
51
min = min === undefined ? 0 : min;
52
max = max === undefined ? 1 : max;
53
this._seed = (seed * 9301 + 49297) % 233280;
54
return min + (this._seed / 233280) * (max - min);
55
},
56
57
numbers: function(config) {
58
var cfg = config || {};
59
var min = cfg.min || 0;
60
var max = cfg.max || 1;
61
var from = cfg.from || [];
62
var count = cfg.count || 8;
63
var decimals = cfg.decimals || 8;
64
var continuity = cfg.continuity || 1;
65
var dfactor = Math.pow(10, decimals) || 0;
66
var data = [];
67
var i, value;
68
69
for (i = 0; i < count; ++i) {
70
value = (from[i] || 0) + this.rand(min, max);
71
if (this.rand() <= continuity) {
72
data.push(Math.round(dfactor * value) / dfactor);
73
} else {
74
data.push(null);
75
}
76
}
77
78
return data;
79
},
80
81
labels: function(config) {
82
var cfg = config || {};
83
var min = cfg.min || 0;
84
var max = cfg.max || 100;
85
var count = cfg.count || 8;
86
var step = (max - min) / count;
87
var decimals = cfg.decimals || 8;
88
var dfactor = Math.pow(10, decimals) || 0;
89
var prefix = cfg.prefix || '';
90
var values = [];
91
var i;
92
93
for (i = min; i < max; i += step) {
94
values.push(prefix + Math.round(dfactor * i) / dfactor);
95
}
96
97
return values;
98
},
99
100
months: function(config) {
101
var cfg = config || {};
102
var count = cfg.count || 12;
103
var section = cfg.section;
104
var values = [];
105
var i, value;
106
107
for (i = 0; i < count; ++i) {
108
value = MONTHS[Math.ceil(i) % 12];
109
values.push(value.substring(0, section));
110
}
111
112
return values;
113
},
114
115
color: function(index) {
116
return COLORS[index % COLORS.length];
117
},
118
119
transparentize: function(color, opacity) {
120
var alpha = opacity === undefined ? 0.5 : 1 - opacity;
121
return Color(color).alpha(alpha).rgbString();
122
}
123
};
124
125
// DEPRECATED
126
window.randomScalingFactor = function() {
127
return Math.round(Samples.utils.rand(-100, 100));
128
};
129
130
// INITIALIZATION
131
132
Samples.utils.srand(Date.now());
133
134
// Google Analytics
135
/* eslint-disable */
136
if (document.location.hostname.match(/^(www\.)?chartjs\.org$/)) {
137
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
138
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
139
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
140
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
141
ga('create', 'UA-28909194-3', 'auto');
142
ga('send', 'pageview');
143
}
144
/* eslint-enable */
145
146
}(this));
147
148
// Bar chart
149
var barChartData = {
150
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
151
datasets: [{
152
label: 'Dataset 1',
153
backgroundColor: window.chartColors.red,
154
stack: 'Stack 0',
155
data: [
156
randomScalingFactor(),
157
randomScalingFactor(),
158
randomScalingFactor(),
159
randomScalingFactor(),
160
randomScalingFactor(),
161
randomScalingFactor(),
162
randomScalingFactor()
163
]
164
}, {
165
label: 'Dataset 2',
166
backgroundColor: window.chartColors.blue,
167
stack: 'Stack 0',
168
data: [
169
randomScalingFactor(),
170
randomScalingFactor(),
171
randomScalingFactor(),
172
randomScalingFactor(),
173
randomScalingFactor(),
174
randomScalingFactor(),
175
randomScalingFactor()
176
]
177
}, {
178
label: 'Dataset 3',
179
backgroundColor: window.chartColors.green,
180
stack: 'Stack 1',
181
data: [
182
randomScalingFactor(),
183
randomScalingFactor(),
184
randomScalingFactor(),
185
randomScalingFactor(),
186
randomScalingFactor(),
187
randomScalingFactor(),
188
randomScalingFactor()
189
]
190
}]
191
192
};
193
window.onload = function() {
194
var ctx = document.getElementById('canvas').getContext('2d');
195
window.myBar = new Chart(ctx, {
196
type: 'bar',
197
data: barChartData,
198
options: {
199
title: {
200
display: true,
201
text: 'Bootstrap bar chart stacked groups'
202
},
203
tooltips: {
204
mode: 'index',
205
intersect: false
206
},
207
responsive: true,
208
scales: {
209
xAxes: [{
210
stacked: true,
211
}],
212
yAxes: [{
213
stacked: true
214
}]
215
}
216
}
217
});
218
};
219
220
document.getElementById('randomizeData').addEventListener('click', function() {
221
barChartData.datasets.forEach(function(dataset) {
222
dataset.data = dataset.data.map(function() {
223
return randomScalingFactor();
224
});
225
});
226
window.myBar.update();
227
});
Console errors: 0