Files
notifications-admin/app/assets/javascripts/sampleChartDashboard.js

67 lines
1.8 KiB
JavaScript
Raw Normal View History

2024-05-15 11:39:03 -07:00
(function (window) {
2024-06-06 01:10:09 -07:00
function initializeChartAndSocket() {
var ctx = document.getElementById('myChart');
if (!ctx) {
return;
}
2024-06-06 01:10:09 -07:00
var myBarChart = new Chart(ctx.getContext('2d'), {
type: 'bar',
data: {
labels: [],
datasets: [
{
label: 'Delivered',
data: [],
backgroundColor: '#0076d6',
stack: 'Stack 0'
},
]
},
options: {
scales: {
y: {
beginAtZero: true
}
}
2024-05-15 11:39:03 -07:00
}
2024-06-06 01:10:09 -07:00
});
var socket = io();
var serviceId = ctx.getAttribute('data-service-id');
socket.on('connect', function() {
socket.emit('fetch_daily_stats', serviceId);
});
socket.on('daily_stats_update', function(data) {
var labels = [];
var deliveredData = [];
for (var date in data) {
labels.push(date);
deliveredData.push(data[date].sms.delivered);
}
myBarChart.data.labels = labels;
myBarChart.data.datasets[0].data = deliveredData;
myBarChart.update();
});
socket.on('error', function(data) {
console.log('Error:', data);
});
var sevenDaysButton = document.getElementById('sevenDaysButton');
if (sevenDaysButton) {
sevenDaysButton.addEventListener('click', function() {
socket.emit('fetch_daily_stats', serviceId);
});
2024-05-15 11:39:03 -07:00
}
2024-06-06 01:10:09 -07:00
}
document.addEventListener('DOMContentLoaded', initializeChartAndSocket);
2024-05-15 11:39:03 -07:00
})(window);