mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-05-21 09:01:34 -04:00
62 lines
1.7 KiB
JavaScript
62 lines
1.7 KiB
JavaScript
function announceUploadStatusFromElement() {
|
|
const srRegion = document.getElementById('upload-status-live');
|
|
const success = document.getElementById('upload-success');
|
|
const error = document.getElementById('upload-error');
|
|
|
|
if (!srRegion) return;
|
|
|
|
const message = error?.textContent || success?.textContent;
|
|
|
|
if (message) {
|
|
srRegion.textContent = '';
|
|
setTimeout(() => {
|
|
srRegion.textContent = message;
|
|
console.log(message);
|
|
}, 50);
|
|
}
|
|
}
|
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
|
announceUploadStatusFromElement();
|
|
});
|
|
|
|
(function(Modules) {
|
|
"use strict";
|
|
|
|
Modules.FileUpload = function() {
|
|
|
|
this.submit = () => this.$form.trigger('submit');
|
|
|
|
this.showCancelButton = () => {
|
|
$('.file-upload-button', this.$form).replaceWith(`
|
|
<button class='usa-button uploading-button' aria-disabled="true" tabindex="0">
|
|
Uploading<span class="dot-anim" aria-hidden="true"></span>
|
|
</button>
|
|
`);
|
|
};
|
|
|
|
this.start = function(component) {
|
|
this.$form = $(component);
|
|
|
|
// Handle "Upload your file" button click — CSP-safe version
|
|
this.$form.on('click', '[data-module="upload-trigger"]', function () {
|
|
const inputId = $(this).data('file-input-id');
|
|
const fileInput = document.getElementById(inputId);
|
|
if (fileInput) fileInput.click();
|
|
});
|
|
|
|
// Clear the form if the user navigates back to the page
|
|
$(window).on("pageshow", () => this.$form[0].reset());
|
|
|
|
// Watch for file input changes
|
|
this.$form.on('change', '.file-upload-field', () => {
|
|
this.submit();
|
|
this.showCancelButton();
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
})(window.GOVUK.Modules);
|