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

82 lines
1.9 KiB
JavaScript
Raw Normal View History

(function(window) {
"use strict";
Removed all govuk css (#2814) * Removed all govuk css * Updated reference files * Removing govuk js * Fixed casing for modules, removed unused page * Got more reference images * Updated template page * Removed govuk padding util * Updated hint to uswds hint * More govuk cleanup * Commiting backstopjs ref files * Fixed all unit tests that broke due to brittleness around govuk styling * Added new ref images * Final removal of govuk * Officially removed all govuk references * Updated reference file * Updated link to button * UI modernization * Cleanup * removed govuk escaping tests since they are no longer needed * Fix CodeQL security issue in escapeElementName function - Escape backslashes first before other special characters - Prevents potential double-escaping vulnerability - Addresses CodeQL alert about improper string escaping * Found more govuk removal. Fixed unit tests * Add missing pipeline check to pre-commit * updated test * Updated e2e test * More update to e2e test * Fixed another e2e test * Simple PR comments addressed * More updates * Updated backstop ref files * Refactored folder selection for non-admins * Updated redundant line * Updated tests to include correct mocks * Added more ref files * Addressing carlos comments * Addressing Carlo comments, cleanup of window initing * More cleanup and addressing carlo comments * Fixing a11 scan * Fixed a few issues with javascript * Fixed for pr * Fixing e2e tests * Tweaking e2e test * Added more ref files and cleaned up urls.js * Fixed bug with creating new template * Removed brittle test - addressed code ql comment * e2e race condition fix * More e2e test fixes * Updated e2e tests to not wait for text sent * Updated test to not wait for button click response * Made tear down more resilent if staging is down * reverted e2e test to what was working before main merge * Updated backstopRef images * Updated gulp to include job-polling differently
2025-10-06 09:38:54 -04:00
window.NotifyModules['update-status'] = function() {
2025-10-21 11:06:08 -04:00
const getRenderer = component => response => {
component.innerHTML = response.html;
};
const throttle = (func, limit) => {
let throttleOn = false;
let callsHaveBeenThrottled = false;
let timeout;
return function() {
const args = arguments;
const context = this;
if (throttleOn) {
callsHaveBeenThrottled = true;
} else {
func.apply(context, args);
throttleOn = true;
}
clearTimeout(timeout);
timeout = setTimeout(() => {
throttleOn = false;
if (callsHaveBeenThrottled) func.apply(context, args);
callsHaveBeenThrottled = false;
}, limit);
};
};
this.start = component => {
let id = 'update-status';
2025-10-21 11:06:08 -04:00
this.component = component;
this.textbox = document.getElementById(this.component.dataset.target);
this.component.setAttribute('id', id);
2025-10-21 11:06:08 -04:00
const currentAriaDescribedBy = this.textbox.getAttribute('aria-describedby') || '';
const newAriaDescribedBy = currentAriaDescribedBy + (currentAriaDescribedBy ? ' ' : '') + id;
this.textbox.setAttribute('aria-describedby', newAriaDescribedBy);
2025-10-21 11:06:08 -04:00
this.textbox.addEventListener('input', throttle(this.update, 150));
this.textbox.dispatchEvent(new Event('input'));
};
this.update = () => {
2025-10-21 11:06:08 -04:00
const form = this.textbox.closest('form');
const formData = new FormData(form);
fetch(this.component.dataset.updatesUrl, {
method: 'POST',
body: formData,
credentials: 'same-origin'
})
.then(response => {
if (!response.ok) {
throw new Error('HTTP error');
}
return response.json();
})
.then(getRenderer(this.component))
.catch(() => {});
};
};
})(window);