mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-08 04:13:41 -05:00
* 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
83 lines
1.6 KiB
JavaScript
83 lines
1.6 KiB
JavaScript
(function(window) {
|
|
"use strict";
|
|
|
|
window.NotifyModules['update-status'] = function() {
|
|
|
|
const getRenderer = $component => response => $component.html(
|
|
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';
|
|
|
|
this.$component = $(component);
|
|
this.$textbox = $('#' + this.$component.data('target'));
|
|
|
|
this.$component
|
|
.attr('id', id);
|
|
|
|
this.$textbox
|
|
.attr(
|
|
'aria-describedby',
|
|
(
|
|
this.$textbox.attr('aria-describedby') || ''
|
|
) + (
|
|
this.$textbox.attr('aria-describedby') ? ' ' : ''
|
|
) + id
|
|
)
|
|
.on('input', throttle(this.update, 150))
|
|
.trigger('input');
|
|
|
|
};
|
|
|
|
this.update = () => {
|
|
|
|
$.ajax(
|
|
this.$component.data('updates-url'),
|
|
{
|
|
'method': 'post',
|
|
'data': this.$textbox.parents('form').serialize()
|
|
}
|
|
).done(
|
|
getRenderer(this.$component)
|
|
).fail(
|
|
() => {}
|
|
);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
})(window);
|