dikplhd/public/assets/js/pages/chartjs-area.js

308 lines
11 KiB
JavaScript

/**
* Theme: Attex - Responsive Tailwind CSS 3 Admin Dashboard
* Author: Coderthemes
* Module/App: Chartjs Area
*/
class ChartjsArea {
constructor() {
this.body = document.getElementsByTagName('body')[0]
this.charts = [];
this.defaultColors = ["#3e60d5", "#47ad77", "#fa5c7c", "#ffbc00"];
Chart.defaults.font.family = '-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif';
Chart.defaults.color = "#8391a2";
Chart.defaults.scale.grid.color = "#8391a2";
}
initboundariesExample() {
var chartElement = document.getElementById('boundaries-example');
var dataColors = chartElement.getAttribute('data-colors');
var colors = dataColors ? dataColors.split(",") : this.defaultColors;
var ctx = chartElement.getContext('2d');
var chart = new Chart(ctx, {
type: 'line', data: {
labels: ['Jan', 'Feb', 'March', 'April', 'May', 'June'], datasets: [{
label: 'Fully Rounded',
data: [12.5, -19.4, 14.3, -15.0, 10.8, -10.5],
borderColor: colors[0],
backgroundColor: hexToRGB(colors[0], .3),
fill: false
},]
}, options: {
responsive: true, maintainAspectRatio: false,
plugins: {
legend: {
display: false,
position: 'top',
},
}, scales: {
x: {
grid: {
display: false
}
}, y: {
grid: {
display: false
}
},
}
},
});
this.charts.push(chart);
}
initdatasetExample() {
var chartElement = document.getElementById('dataset-example');
var dataColors = chartElement.getAttribute('data-colors');
var colors = dataColors ? dataColors.split(",") : this.defaultColors
var ctx = chartElement.getContext('2d');
var chart = new Chart(ctx, {
type: 'line', data: {
labels: ['Jan', 'Feb', 'March', 'April', 'May', 'June'], datasets: [{
label: 'D0',
data: [10, 20, 15, 35, 38, 24],
borderColor: colors[0],
hidden: true,
backgroundColor: hexToRGB(colors[0], 0.3),
}, {
label: 'D1',
data: [12, 18, 18, 33, 41, 20],
borderColor: colors[1],
fill: '-1',
backgroundColor: hexToRGB(colors[1], 0.3),
}, {
label: 'D2',
data: [5, 25, 20, 25, 28, 14],
borderColor: colors[2],
fill: 1,
backgroundColor: hexToRGB(colors[2], 0.3),
}, {
label: 'D3',
data: [12, 45, 15, 35, 38, 24],
borderColor: colors[3],
fill: '-1',
backgroundColor: hexToRGB(colors[3], 0.3),
}, {
label: 'D4',
data: [24, 38, 35, 15, 20, 10],
borderColor: colors[4],
fill: 8,
backgroundColor: hexToRGB(colors[4], 0.3),
}]
}, options: {
responsive: true, maintainAspectRatio: false,
plugins: {
filler: {
propagate: false
},
}, interaction: {
intersect: false,
}, scales: {
x: {
grid: {
display: false
}
}, y: {
stacked: true, grid: {
display: false
}
},
}
},
});
this.charts.push(chart)
}
initdrawTimeExample() {
var chartElement = document.getElementById('draw-time-example');
var dataColors = chartElement.getAttribute('data-colors');
var colors = dataColors ? dataColors.split(",") : this.defaultColors
var ctx = chartElement.getContext('2d');
var chart = new Chart(ctx, {
type: 'line', data: {
labels: ['Jan', 'Feb', 'March', 'April', 'May', 'June'], datasets: [{
label: 'Fully Rounded',
data: [10, 20, 15, 35, 38, 24],
borderColor: colors[0],
backgroundColor: colors[0],
fill: true
}, {
label: 'Small Radius',
data: [24, 38, 35, 15, 20, 10],
backgroundColor: hexToRGB(colors[1], 0.3),
borderColor: colors[1],
borderWidth: 1,
}]
}, options: {
responsive: true, maintainAspectRatio: false, plugins: {
legend: {
display: false,
}, filler: {
propagate: false,
},
}, pointBackgroundColor: '#fff', radius: 5, interaction: {
intersect: false,
}, scales: {
x: {
grid: {
display: false
}
}, y: {
grid: {
display: false
}
},
}
},
});
this.charts.push(chart)
}
initstackedExample() {
var chartElement = document.getElementById('stacked-example');
var dataColors = chartElement.getAttribute('data-colors');
var colors = dataColors ? dataColors.split(",") : this.defaultColors
var ctx = chartElement.getContext('2d');
var chart = new Chart(ctx, {
type: 'line', data: {
labels: ['Jan', 'Feb', 'March', 'April', 'May', 'June'], datasets: [{
label: 'D0',
data: [10, 20, 15, 35, 38, 24],
borderColor: colors[0],
fill: true,
backgroundColor: colors[0],
}, {
label: 'D1',
data: [12, 18, 18, 33, 41, 20],
borderColor: colors[1],
fill: true,
backgroundColor: colors[1],
}, {
label: 'D2',
data: [5, 25, 20, 25, 28, 14],
borderColor: colors[2],
fill: true,
backgroundColor: colors[2],
}, {
label: 'D3',
data: [12, 45, 15, 35, 38, 24],
borderColor: colors[3],
fill: true,
backgroundColor: colors[3],
}, {
label: 'D4',
data: [24, 38, 35, 15, 20, 10],
borderColor: colors[4],
fill: true,
backgroundColor: colors[4],
}]
}, options: {
responsive: true, maintainAspectRatio: false, plugins: {
legend: {
display: false,
},
}, interaction: {
mode: 'nearest', axis: 'x', intersect: false
}, scales: {
x: {
title: {
display: true, text: 'Month'
},
grid: {
display: false
}
}, y: {
stacked: true, title: {
display: true, text: 'Value'
}, grid: {
display: false
}
},
}
},
});
this.charts.push(chart)
}
initradarExample() {
var chartElement = document.getElementById('radar-example');
var dataColors = chartElement.getAttribute('data-colors');
var colors = dataColors ? dataColors.split(",") : this.defaultColors
var ctx = chartElement.getContext('2d');
var chart = new Chart(ctx, {
type: 'radar', data: {
labels: ['Jan', 'Feb', 'March', 'April', 'May', 'June'], datasets: [{
label: 'D0',
data: [10, 20, 15, 35, 38, 24],
borderColor: colors[0],
fill: '-1',
backgroundColor: hexToRGB(colors[0], 0.3),
}, {
label: 'D1',
data: [12, 18, 18, 33, 41, 20],
borderColor: colors[1],
fill: false,
backgroundColor: hexToRGB(colors[1], 0.3),
}, {
label: 'D2',
data: [5, 25, 20, 25, 28, 14],
borderColor: colors[2],
fill: '-1',
backgroundColor: hexToRGB(colors[2], 0.3),
}, {
label: 'D3',
data: [12, 45, 15, 35, 38, 24],
borderColor: colors[3],
fill: '-1',
backgroundColor: hexToRGB(colors[3], 0.3),
},]
}, options: {
responsive: true, maintainAspectRatio: false, plugins: {
legend: {
display: false,
}, filler: {
propagate: false
},
},
},
});
this.charts.push(chart)
}
init() {
this.initboundariesExample();
this.initdatasetExample();
this.initdrawTimeExample();
this.initstackedExample();
this.initradarExample();
}
}
new ChartjsArea().init();
/* utility function */
function hexToRGB(hex, alpha) {
var r = parseInt(hex.slice(1, 3), 16), g = parseInt(hex.slice(3, 5), 16), b = parseInt(hex.slice(5, 7), 16);
if (alpha) {
return "rgba(" + r + ", " + g + ", " + b + ", " + alpha + ")";
} else {
return "rgb(" + r + ", " + g + ", " + b + ")";
}
}