mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 19:03:30 -05:00
67 lines
1.8 KiB
JavaScript
67 lines
1.8 KiB
JavaScript
(function (window) {
|
|
|
|
function initializeChartAndSocket() {
|
|
var ctx = document.getElementById('myChart');
|
|
if (!ctx) {
|
|
return;
|
|
}
|
|
|
|
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
|
|
}
|
|
}
|
|
}
|
|
});
|
|
|
|
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);
|
|
});
|
|
}
|
|
}
|
|
|
|
document.addEventListener('DOMContentLoaded', initializeChartAndSocket);
|
|
|
|
})(window);
|