308 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			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 + ")";
 | 
						|
    }
 | 
						|
} |