-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/staging' into feat/submit/mailTo
- Loading branch information
Showing
15 changed files
with
2,153 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,43 @@ | ||
const hideElementsWithJsHidden = () => { | ||
/* globals MutationObserver, document */ | ||
|
||
/** | ||
* Initiates checks for elements with the class 'js-hidden' and updates their display and visibility styles accordingly. | ||
* | ||
* When an element gains the 'js-hidden' class, its display and visibility styles are set to 'none' and 'hidden', respectively. | ||
* When an element loses the 'js-hidden' class, its display and visibility styles are reset to their default values. | ||
* | ||
* This function also hides any elements that already have the 'js-hidden' class when it is called. | ||
*/ | ||
const initiateJsHiddenChecks = () => { | ||
const observer = new MutationObserver((mutations) => { | ||
mutations.forEach((mutation) => { | ||
if (mutation.type === 'attributes' && mutation.attributeName === 'class') { | ||
const target = mutation.target | ||
const classList = target.classList | ||
if (classList.contains('js-hidden')) { | ||
// Class js-hidden was added | ||
target.style.display = 'none' | ||
target.style.visibility = 'hidden' | ||
} else { | ||
// Class js-hidden was removed | ||
target.style.display = '' | ||
target.style.visibility = '' | ||
} | ||
} | ||
}) | ||
}) | ||
|
||
observer.observe(document.body, { | ||
attributes: true, | ||
attributeFilter: ['class'], | ||
subtree: true | ||
}) | ||
|
||
document.querySelectorAll('.js-hidden').forEach((el, i) => { | ||
console.log(el) | ||
console.log('Hiding element', el) | ||
el.style.display = 'none' | ||
el.style.visibility = 'none' | ||
}) | ||
} | ||
|
||
export default hideElementsWithJsHidden | ||
export default initiateJsHiddenChecks |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
/** | ||
* This file is taken from https://github.com/alphagov/collections/blob/main/app/assets/javascripts/modules/list-filter.js | ||
*/ | ||
|
||
/* eslint-disable no-var */ | ||
//= require govuk_publishing_components/vendor/polyfills/closest | ||
|
||
const keyPauseTime = 20 | ||
|
||
window.GOVUK = window.GOVUK || {} | ||
window.GOVUK.Modules = window.GOVUK.Modules || {}; | ||
|
||
(function (Modules) { | ||
function ListFilter ($module) { | ||
this.$module = $module | ||
this.filterTimeout = null | ||
this.form = this.$module.querySelector('[data-filter="form"]') | ||
this.searchResults = this.$module.querySelector('#search_results') | ||
} | ||
|
||
ListFilter.prototype.init = function () { | ||
this.$module.filterList = this.filterList.bind(this) | ||
// Form should only appear if the JS is working | ||
this.form.classList.add('filter-list__form--active') | ||
this.results = document.createElement('div') | ||
this.results.classList.add('filter-list__results', 'govuk-heading-m', 'js-search-results') | ||
this.results.setAttribute('aria-live', 'polite') | ||
this.results.innerHTML = this.countInitialItems() + ' results found' | ||
this.searchResults.insertBefore(this.results, this.searchResults.firstChild) | ||
|
||
// We don't want the form to submit/refresh the page on enter key | ||
this.form.onsubmit = function () { return false } | ||
|
||
this.form.addEventListener('keyup', function (e) { | ||
var searchTerm = e.target.value | ||
clearTimeout(this.filterTimeout) | ||
this.filterTimeout = setTimeout(function () { | ||
this.$module.filterList(searchTerm) | ||
}.bind(this), keyPauseTime) | ||
}.bind(this)) | ||
} | ||
|
||
ListFilter.prototype.filterList = function (searchTerm) { | ||
var itemsToFilter = this.$module.querySelectorAll('[data-filter="item"]') | ||
var blocksToFilter = this.$module.querySelectorAll('[data-filter="block"]') | ||
for (var i = 0; i <= itemsToFilter.length - 1; i++) { | ||
var currentItem = itemsToFilter[i] | ||
if (!this.matchSearchTerm(currentItem, searchTerm)) { | ||
currentItem.classList.add('js-hidden') | ||
} | ||
} | ||
this.updateItemCount(blocksToFilter) | ||
} | ||
|
||
ListFilter.prototype.matchSearchTerm = function (item, term) { | ||
var normaliseWhitespace = function (string) { | ||
return string | ||
.trim() // Removes spaces at beginning and end of string. | ||
.replace(/\r?\n|\r/g, ' ') // Replaces line breaks with one space. | ||
.replace(/\s+/g, ' ') // Squashes multiple spaces to one space. | ||
} | ||
|
||
var searchTerms = item.getAttribute('data-filter-terms') || '' | ||
var normalisedTerms = normaliseWhitespace(searchTerms) | ||
|
||
item.classList.remove('js-hidden') | ||
|
||
var searchTermRegexp = new RegExp(term.trim().replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), 'i') | ||
return searchTermRegexp.exec(normalisedTerms) !== null | ||
} | ||
|
||
ListFilter.prototype.countInitialItems = function () { | ||
return this.$module.querySelectorAll('[data-filter="item"]').length | ||
} | ||
|
||
ListFilter.prototype.updateItemCount = function (blocksToFilter) { | ||
var totalMatchingItems = 0 | ||
|
||
for (var i = 0; i < blocksToFilter.length; i++) { | ||
var block = blocksToFilter[i].closest('[data-filter="block"]') | ||
block.classList.remove('js-hidden') | ||
|
||
var matchingItems = block.querySelectorAll('[data-filter="item"]') | ||
var matchingItemCount = 0 | ||
|
||
var innerBlocks = block.querySelectorAll('[data-filter="inner-block"]') | ||
for (var r = 0; r < innerBlocks.length; r++) { | ||
innerBlocks[r].classList.add('js-hidden') | ||
} | ||
|
||
for (var j = 0; j < matchingItems.length; j++) { | ||
if (!matchingItems[j].classList.contains('js-hidden')) { | ||
matchingItemCount++ | ||
|
||
if (matchingItems[j].closest('[data-filter="inner-block"]') !== null) { matchingItems[j].closest('[data-filter="inner-block"]').classList.remove('js-hidden') } | ||
} | ||
} | ||
|
||
var itemCount = block.querySelectorAll('[data-item-count="true"]') | ||
var accessibleItemCount = block.querySelectorAll('.js-accessible-item-count') | ||
|
||
if (matchingItemCount === 0) { | ||
block.classList.toggle('js-hidden') | ||
} | ||
|
||
if (matchingItemCount > 0) { | ||
for (var l = 0; l < itemCount.length; l++) { | ||
itemCount[l].textContent = matchingItemCount | ||
} | ||
|
||
for (var k = 0; k < accessibleItemCount.length; k++) { | ||
accessibleItemCount[k].textContent = matchingItemCount | ||
} | ||
} | ||
|
||
totalMatchingItems += matchingItemCount | ||
} | ||
|
||
var text = ' results found' | ||
if (totalMatchingItems === 1) { | ||
text = ' result found' | ||
} | ||
this.results.innerHTML = totalMatchingItems + text | ||
} | ||
|
||
Modules.ListFilter = ListFilter | ||
})(window.GOVUK.Modules) |
Oops, something went wrong.