Skip to content

Commit

Permalink
test: Preserve filters when reloading the review page (#4911)
Browse files Browse the repository at this point in the history
Related to work on PR #4767
  • Loading branch information
joeyparrish committed Jan 30, 2023
1 parent acbfca1 commit c6b4078
Showing 1 changed file with 51 additions and 13 deletions.
64 changes: 51 additions & 13 deletions test/test/assets/screenshots/review.html
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,17 @@ <h2 id="instructions">
window.addEventListener('focus', focusHandler);


applyFilters();
// Consume URL hash parameters that indicate filters.
// Ignore the '#' in location.hash with substr(1).
for (const param of location.hash.substr(1).split('&')) {
const [key, value] = param.split('=');
try {
allOptions[key][value].checked = true;
} catch (error) {} // ignore errors
}

// Apply the initial filters.
initializeFilters();


function appendOption(parentElement, key, value, onChange) {
Expand Down Expand Up @@ -310,30 +320,52 @@ <h2 id="instructions">
}

function applyFilters() {
// A collection of URL hash parameters to indicate the selected filters.
const params = [];

// If no platform is selected, show all platforms.
let allPlatforms = true;
for (const platformInput of Object.values(allOptions['platform'])) {
if (platformInput.checked) allPlatforms = false;
for (const platformKey in allOptions['platform']) {
const platformInput = allOptions['platform'][platformKey];
if (platformInput.checked) {
allPlatforms = false;
params.push(`platform=${platformKey}`);
}
}

// If no suite is selected, show all suites.
let allSuites = true;
for (const suiteInput of Object.values(allOptions['suite'])) {
if (suiteInput.checked) allSuites = false;
for (const suiteKey in allOptions['suite']) {
const suiteInput = allOptions['suite'][suiteKey];
if (suiteInput.checked) {
allSuites = false;
params.push(`suite=${suiteKey}`);
}
}

// If no test is selected, show all tests.
let allPrefixes = true;
for (const prefixInput of Object.values(allOptions['prefix'])) {
if (prefixInput.checked) allPrefixes = false;
for (const prefixKey in allOptions['prefix']) {
const prefixInput = allOptions['prefix'][prefixKey];
if (prefixInput.checked) {
allPrefixes = false;
params.push(`prefix=${prefixKey}`);
}
}

// If no test is selected, show all tests.
let allTests = true;
for (const testInput of Object.values(allOptions['test'])) {
if (testInput.checked) allTests = false;
for (const testKey in allOptions['test']) {
const testInput = allOptions['test'][testKey];
if (testInput.checked) {
allTests = false;
params.push(`test=${testKey}`);
}
}

// Set the location hash so that we keep the same filters on reload.
location.hash = params.join('&');

for (const container of allScreenshots) {
const platform = container.dataset.platform;
const suite = container.dataset.suite;
Expand Down Expand Up @@ -367,16 +399,18 @@ <h2 id="instructions">
}
}

function applySuiteFilters() {
function applySuiteFilters(resetTests = true) {
// If no suite is selected, show the test options for all suites.
let allSuites = true;
for (const suiteInput of Object.values(allOptions['suite'])) {
if (suiteInput.checked) allSuites = false;
}

// Reset all test options.
for (const testInput of Object.values(allOptions['test'])) {
testInput.checked = false;
if (resetTests) {
// Reset all test options.
for (const testInput of Object.values(allOptions['test'])) {
testInput.checked = false;
}
}

// Show test options matching the suites.
Expand All @@ -390,6 +424,10 @@ <h2 id="instructions">
applyFilters();
}

function initializeFilters() {
applySuiteFilters(/* resetTests= */ false);
}

</script>
</body>
</html>

0 comments on commit c6b4078

Please sign in to comment.