mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-04-16 15:21:39 -04:00
144 lines
5.1 KiB
JavaScript
144 lines
5.1 KiB
JavaScript
(function (window) {
|
|
var canvas = document.getElementById('totalMessageChart');
|
|
var ctx = canvas.getContext('2d');
|
|
// Set explicit dimensions for the canvas
|
|
canvas.width = canvas.parentElement.clientWidth;
|
|
canvas.height = 100;
|
|
|
|
var chartContainer = document.getElementById('chartContainer');
|
|
var chartTitle = document.getElementById('chartTitle').textContent;
|
|
var sms_sent = parseInt(chartContainer.getAttribute('data-sms-sent'));
|
|
var sms_remaining_messages = parseInt(chartContainer.getAttribute('data-sms-allowance-remaining'));
|
|
var totalMessages = sms_sent + sms_remaining_messages;
|
|
|
|
// Set a minimum value for "Messages Sent" based on a percentage of the remaining messages
|
|
var minSentPercentage = 0.01; // Minimum width as a percentage of total messages (1% in this case)
|
|
var minSentValue = totalMessages * minSentPercentage;
|
|
var displaySent = Math.max(sms_sent, minSentValue);
|
|
var displayRemaining = totalMessages - displaySent;
|
|
|
|
var myChart = new Chart(ctx, {
|
|
type: 'bar',
|
|
data: {
|
|
labels: [''],
|
|
datasets: [{
|
|
label: 'Messages Sent',
|
|
data: [displaySent],
|
|
backgroundColor: '#0076d6',
|
|
actualValue: sms_sent // Store the actual value for tooltips
|
|
},
|
|
{
|
|
label: 'Remaining',
|
|
data: [displayRemaining],
|
|
backgroundColor: '#fa9441',
|
|
actualValue: sms_remaining_messages // Store the actual value for tooltips
|
|
}]
|
|
},
|
|
options: {
|
|
indexAxis: 'y',
|
|
scales: {
|
|
x: {
|
|
beginAtZero: true,
|
|
stacked: true,
|
|
max: totalMessages,
|
|
grid: {
|
|
display: false,
|
|
},
|
|
border: {
|
|
display: false,
|
|
},
|
|
ticks: {
|
|
display: false // Hide x-axis ticks
|
|
}
|
|
},
|
|
y: {
|
|
stacked: true,
|
|
grid: {
|
|
display: false,
|
|
},
|
|
border: {
|
|
display: false,
|
|
},
|
|
ticks: {
|
|
display: false // Hide y-axis ticks
|
|
}
|
|
}
|
|
},
|
|
plugins: {
|
|
legend: {
|
|
display: false
|
|
},
|
|
tooltip: {
|
|
callbacks: {
|
|
label: function(tooltipItem) {
|
|
var dataset = tooltipItem.dataset;
|
|
return dataset.label + ': ' + dataset.actualValue.toLocaleString();
|
|
}
|
|
}
|
|
},
|
|
title: {
|
|
display: false // Hide the Chart.js title and use custom title
|
|
}
|
|
},
|
|
responsive: true,
|
|
layout: {
|
|
padding: {
|
|
left: 0, // Adjust left padding to remove extra space
|
|
top: 0,
|
|
bottom: 0,
|
|
right: 0
|
|
}
|
|
}
|
|
}
|
|
});
|
|
|
|
// Update the message below the chart
|
|
document.getElementById('message').innerText = `${sms_sent.toLocaleString()} sent / ${sms_remaining_messages.toLocaleString()} remaining`;
|
|
|
|
// Create and populate the accessible table
|
|
var tableContainer = document.getElementById('totalMessageTable');
|
|
var table = document.createElement('table');
|
|
table.className = 'usa-sr-only';
|
|
|
|
var caption = document.createElement('caption');
|
|
caption.textContent = chartTitle;
|
|
table.appendChild(caption);
|
|
|
|
var thead = document.createElement('thead');
|
|
var theadRow = document.createElement('tr');
|
|
var thLabel = document.createElement('th');
|
|
thLabel.textContent = 'Label';
|
|
var thValue = document.createElement('th');
|
|
thValue.textContent = 'Value';
|
|
theadRow.appendChild(thLabel);
|
|
theadRow.appendChild(thValue);
|
|
thead.appendChild(theadRow);
|
|
table.appendChild(thead);
|
|
|
|
var tbody = document.createElement('tbody');
|
|
var tableData = [
|
|
{ label: 'Messages Sent', value: sms_sent.toLocaleString() },
|
|
{ label: 'Remaining', value: sms_remaining_messages.toLocaleString() }
|
|
];
|
|
|
|
tableData.forEach(function(rowData) {
|
|
var row = document.createElement('tr');
|
|
var cellLabel = document.createElement('td');
|
|
var cellValue = document.createElement('td');
|
|
cellLabel.textContent = rowData.label;
|
|
cellValue.textContent = rowData.value;
|
|
row.appendChild(cellLabel);
|
|
row.appendChild(cellValue);
|
|
tbody.appendChild(row);
|
|
});
|
|
|
|
table.appendChild(tbody);
|
|
tableContainer.appendChild(table);
|
|
|
|
// Ensure the chart resizes correctly on window resize
|
|
window.addEventListener('resize', function() {
|
|
canvas.width = canvas.parentElement.clientWidth;
|
|
myChart.resize();
|
|
});
|
|
})(window);
|