mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-09 04:43:54 -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
100 lines
2.3 KiB
JavaScript
100 lines
2.3 KiB
JavaScript
(function(window) {
|
|
"use strict";
|
|
|
|
var Modules = window.NotifyModules;
|
|
let state;
|
|
let normalize = (string) => string.toLowerCase().replace(/ /g,'');
|
|
let resultsSummary = (num) => {
|
|
if (num === 0) {
|
|
return "no results";
|
|
} else {
|
|
return num + (num === 1 ? " result" : " results");
|
|
}
|
|
};
|
|
|
|
let filter = ($searchBox, $searchLabel, $liveRegion, $targets) => () => {
|
|
|
|
let query = normalize($searchBox.val());
|
|
let results = 0;
|
|
let $noResultsMessage = $('.js-live-search-no-results');
|
|
|
|
$targets.each(function() {
|
|
|
|
let content = $('.live-search-relevant', this).text() || $(this).text();
|
|
|
|
if ($(this).has(':checked').length) {
|
|
$(this).show();
|
|
results++;
|
|
return;
|
|
}
|
|
|
|
if (query == '') {
|
|
$(this).removeClass('js-hidden');
|
|
results++;
|
|
return;
|
|
}
|
|
|
|
let isMatch = normalize(content).includes(normalize(query));
|
|
|
|
if (isMatch) {
|
|
$(this).removeClass('js-hidden');
|
|
results++;
|
|
} else {
|
|
$(this).addClass('js-hidden');
|
|
}
|
|
});
|
|
|
|
if (query !== '' && results === 0) {
|
|
$noResultsMessage.removeClass('js-hidden');
|
|
} else {
|
|
$noResultsMessage.addClass('js-hidden');
|
|
}
|
|
|
|
if (state === 'loaded') {
|
|
if (query !== '') {
|
|
$searchBox.attr('aria-label', $searchLabel.text().trim() + ', ' + resultsSummary(results));
|
|
}
|
|
state = 'active';
|
|
} else {
|
|
$searchBox.removeAttr('aria-label');
|
|
$liveRegion.text(resultsSummary(results));
|
|
}
|
|
|
|
// make sticky JS recalculate its cache of the element's position
|
|
// because live search can change the height document
|
|
if (window.NotifyModules && 'stickAtBottomWhenScrolling' in window.NotifyModules) {
|
|
window.NotifyModules.stickAtBottomWhenScrolling.recalculate();
|
|
}
|
|
|
|
};
|
|
|
|
|
|
Modules['live-search'] = function() {
|
|
|
|
this.start = function(component) {
|
|
|
|
let $component = $(component);
|
|
|
|
let $searchBox = $('input', $component);
|
|
let $searchLabel = $('label', $component);
|
|
let $liveRegion = $('.live-search__status', $component);
|
|
|
|
let filterFunc = filter(
|
|
$searchBox,
|
|
$searchLabel,
|
|
$liveRegion,
|
|
$($component.data('targets'))
|
|
);
|
|
|
|
state = 'loaded';
|
|
|
|
$searchBox.on('keyup input', filterFunc);
|
|
|
|
filterFunc();
|
|
|
|
};
|
|
|
|
};
|
|
|
|
})(window);
|