Skip to content

Commit e07e8ed

Browse files
Merge pull request #20690 from Snuffleupagus/getPdfFilenameFromUrl-searchParams-findLast
Reduce duplication when parsing `searchParams` in the `getPdfFilenameFromUrl` function
2 parents 6f0d8d5 + 34f2718 commit e07e8ed

1 file changed

Lines changed: 8 additions & 13 deletions

File tree

src/display/display_utils.js

Lines changed: 8 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -395,19 +395,14 @@ function getPdfFilenameFromUrl(url, defaultFilename = "document.pdf") {
395395
}
396396

397397
if (newURL.searchParams.size > 0) {
398-
const values = Array.from(newURL.searchParams.values()).reverse();
399-
for (const value of values) {
400-
if (pdfRegex.test(value)) {
401-
// If any of the search parameters ends with ".pdf", return it.
402-
return decode(value);
403-
}
404-
}
405-
const keys = Array.from(newURL.searchParams.keys()).reverse();
406-
for (const key of keys) {
407-
if (pdfRegex.test(key)) {
408-
// If any of the search parameter keys ends with ".pdf", return it.
409-
return decode(key);
410-
}
398+
const getLast = iterator => [...iterator].findLast(v => pdfRegex.test(v));
399+
400+
// If any of the search parameters ends with ".pdf", return it.
401+
const name =
402+
getLast(newURL.searchParams.values()) ??
403+
getLast(newURL.searchParams.keys());
404+
if (name) {
405+
return decode(name);
411406
}
412407
}
413408

0 commit comments

Comments
 (0)