@internetarchive/collection-browser 3.3.2 → 3.3.4-alpha-webdev7761.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.github/workflows/ci.yml +27 -27
- package/.github/workflows/gh-pages-main.yml +39 -39
- package/.github/workflows/npm-publish.yml +39 -39
- package/.github/workflows/pr-preview.yml +38 -38
- package/.husky/pre-commit +4 -4
- package/.prettierignore +1 -1
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +16 -0
- package/dist/index.js.map +1 -0
- package/dist/src/app-root.d.ts +105 -0
- package/dist/src/app-root.js +1076 -0
- package/dist/src/app-root.js.map +1 -0
- package/dist/src/assets/img/icons/arrow-left.d.ts +2 -0
- package/dist/src/assets/img/icons/arrow-left.js +10 -0
- package/dist/src/assets/img/icons/arrow-left.js.map +1 -0
- package/dist/src/assets/img/icons/arrow-right.d.ts +2 -0
- package/dist/src/assets/img/icons/arrow-right.js +10 -0
- package/dist/src/assets/img/icons/arrow-right.js.map +1 -0
- package/dist/src/assets/img/icons/chevron.d.ts +2 -0
- package/dist/src/assets/img/icons/chevron.js +4 -0
- package/dist/src/assets/img/icons/chevron.js.map +1 -0
- package/dist/src/assets/img/icons/close-circle-dark.d.ts +2 -0
- package/dist/src/assets/img/icons/close-circle-dark.js +5 -0
- package/dist/src/assets/img/icons/close-circle-dark.js.map +1 -0
- package/dist/src/assets/img/icons/contract.d.ts +2 -0
- package/dist/src/assets/img/icons/contract.js +9 -0
- package/dist/src/assets/img/icons/contract.js.map +1 -0
- package/dist/src/assets/img/icons/empty-query.d.ts +2 -0
- package/dist/src/assets/img/icons/empty-query.js +5 -0
- package/dist/src/assets/img/icons/empty-query.js.map +1 -0
- package/dist/src/assets/img/icons/expand.d.ts +2 -0
- package/dist/src/assets/img/icons/expand.js +9 -0
- package/dist/src/assets/img/icons/expand.js.map +1 -0
- package/dist/src/assets/img/icons/eye-closed.d.ts +2 -0
- package/dist/src/assets/img/icons/eye-closed.js +5 -0
- package/dist/src/assets/img/icons/eye-closed.js.map +1 -0
- package/dist/src/assets/img/icons/eye.d.ts +2 -0
- package/dist/src/assets/img/icons/eye.js +5 -0
- package/dist/src/assets/img/icons/eye.js.map +1 -0
- package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -0
- package/dist/src/assets/img/icons/favorite-filled.js +10 -0
- package/dist/src/assets/img/icons/favorite-filled.js.map +1 -0
- package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -0
- package/dist/src/assets/img/icons/favorite-unfilled.js +9 -0
- package/dist/src/assets/img/icons/favorite-unfilled.js.map +1 -0
- package/dist/src/assets/img/icons/filter.d.ts +2 -0
- package/dist/src/assets/img/icons/filter.js +10 -0
- package/dist/src/assets/img/icons/filter.js.map +1 -0
- package/dist/src/assets/img/icons/login-required.d.ts +1 -0
- package/dist/src/assets/img/icons/login-required.js +18 -0
- package/dist/src/assets/img/icons/login-required.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/account.js +14 -0
- package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/audio.js +14 -0
- package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/collection.js +12 -0
- package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/data.js +15 -0
- package/dist/src/assets/img/icons/mediatype/data.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/etree.js +14 -0
- package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/film.js +14 -0
- package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/images.js +13 -0
- package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/radio.js +15 -0
- package/dist/src/assets/img/icons/mediatype/radio.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/search.js +14 -0
- package/dist/src/assets/img/icons/mediatype/search.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/software.js +13 -0
- package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/texts.js +13 -0
- package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-commercial.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-commercial.js +12 -0
- package/dist/src/assets/img/icons/mediatype/tv-commercial.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-fact-check.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-fact-check.js +12 -0
- package/dist/src/assets/img/icons/mediatype/tv-fact-check.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-quote.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/tv-quote.js +12 -0
- package/dist/src/assets/img/icons/mediatype/tv-quote.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/tv.js +14 -0
- package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/video.js +14 -0
- package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/web.js +13 -0
- package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
- package/dist/src/assets/img/icons/null-result.d.ts +2 -0
- package/dist/src/assets/img/icons/null-result.js +5 -0
- package/dist/src/assets/img/icons/null-result.js.map +1 -0
- package/dist/src/assets/img/icons/quote.d.ts +1 -0
- package/dist/src/assets/img/icons/quote.js +7 -0
- package/dist/src/assets/img/icons/quote.js.map +1 -0
- package/dist/src/assets/img/icons/restricted.d.ts +1 -0
- package/dist/src/assets/img/icons/restricted.js +13 -0
- package/dist/src/assets/img/icons/restricted.js.map +1 -0
- package/dist/src/assets/img/icons/reviews.d.ts +1 -0
- package/dist/src/assets/img/icons/reviews.js +11 -0
- package/dist/src/assets/img/icons/reviews.js.map +1 -0
- package/dist/src/assets/img/icons/upload.d.ts +1 -0
- package/dist/src/assets/img/icons/upload.js +12 -0
- package/dist/src/assets/img/icons/upload.js.map +1 -0
- package/dist/src/assets/img/icons/views.d.ts +1 -0
- package/dist/src/assets/img/icons/views.js +11 -0
- package/dist/src/assets/img/icons/views.js.map +1 -0
- package/dist/src/circular-activity-indicator.d.ts +5 -0
- package/dist/src/circular-activity-indicator.js +66 -0
- package/dist/src/circular-activity-indicator.js.map +1 -0
- package/dist/src/collection-browser.d.ts +692 -0
- package/dist/src/collection-browser.js +2669 -0
- package/dist/src/collection-browser.js.map +1 -0
- package/dist/src/collection-facets/facet-row.d.ts +30 -0
- package/dist/src/collection-facets/facet-row.js +266 -0
- package/dist/src/collection-facets/facet-row.js.map +1 -0
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -0
- package/dist/src/collection-facets/facet-tombstone-row.js +43 -0
- package/dist/src/collection-facets/facet-tombstone-row.js.map +1 -0
- package/dist/src/collection-facets/facets-template.d.ts +13 -0
- package/dist/src/collection-facets/facets-template.js +68 -0
- package/dist/src/collection-facets/facets-template.js.map +1 -0
- package/dist/src/collection-facets/models.d.ts +9 -0
- package/dist/src/collection-facets/models.js +10 -0
- package/dist/src/collection-facets/models.js.map +1 -0
- package/dist/src/collection-facets/more-facets-content.d.ts +109 -0
- package/dist/src/collection-facets/more-facets-content.js +547 -0
- package/dist/src/collection-facets/more-facets-content.js.map +1 -0
- package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -0
- package/dist/src/collection-facets/more-facets-pagination.js +264 -0
- package/dist/src/collection-facets/more-facets-pagination.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -0
- package/dist/src/collection-facets/smart-facets/dedupe.js +35 -0
- package/dist/src/collection-facets/smart-facets/dedupe.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.d.ts +5 -0
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.js +24 -0
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/index.d.ts +3 -0
- package/dist/src/collection-facets/smart-facets/heuristics/index.js +4 -0
- package/dist/src/collection-facets/smart-facets/heuristics/index.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.d.ts +4 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js +14 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.d.ts +6 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.js +68 -0
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.d.ts +9 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.js +69 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.d.ts +21 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +76 -0
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/models.d.ts +30 -0
- package/dist/src/collection-facets/smart-facets/models.js +2 -0
- package/dist/src/collection-facets/smart-facets/models.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +54 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +383 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js +133 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +28 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +172 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +13 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.js.map +1 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +18 -0
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -0
- package/dist/src/collection-facets/toggle-switch.d.ts +41 -0
- package/dist/src/collection-facets/toggle-switch.js +174 -0
- package/dist/src/collection-facets/toggle-switch.js.map +1 -0
- package/dist/src/collection-facets.d.ts +113 -0
- package/dist/src/collection-facets.js +884 -0
- package/dist/src/collection-facets.js.map +1 -0
- package/dist/src/data-source/collection-browser-data-source-interface.d.ts +270 -0
- package/dist/src/data-source/collection-browser-data-source-interface.js +2 -0
- package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -0
- package/dist/src/data-source/collection-browser-data-source.d.ts +418 -0
- package/dist/src/data-source/collection-browser-data-source.js +1121 -0
- package/dist/src/data-source/collection-browser-data-source.js.map +1 -0
- package/dist/src/data-source/collection-browser-query-state.d.ts +48 -0
- package/dist/src/data-source/collection-browser-query-state.js +2 -0
- package/dist/src/data-source/collection-browser-query-state.js.map +1 -0
- package/dist/src/data-source/models.d.ts +43 -0
- package/dist/src/data-source/models.js +9 -0
- package/dist/src/data-source/models.js.map +1 -0
- package/dist/src/empty-placeholder.d.ts +23 -0
- package/dist/src/empty-placeholder.js +165 -0
- package/dist/src/empty-placeholder.js.map +1 -0
- package/dist/src/expanded-date-picker.d.ts +50 -0
- package/dist/src/expanded-date-picker.js +182 -0
- package/dist/src/expanded-date-picker.js.map +1 -0
- package/dist/src/language-code-handler/language-code-handler.d.ts +37 -0
- package/dist/src/language-code-handler/language-code-handler.js +27 -0
- package/dist/src/language-code-handler/language-code-handler.js.map +1 -0
- package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -0
- package/dist/src/language-code-handler/language-code-mapping.js +563 -0
- package/dist/src/language-code-handler/language-code-mapping.js.map +1 -0
- package/dist/src/manage/manage-bar.d.ts +58 -0
- package/dist/src/manage/manage-bar.js +237 -0
- package/dist/src/manage/manage-bar.js.map +1 -0
- package/dist/src/manage/remove-items-modal-content.d.ts +9 -0
- package/dist/src/manage/remove-items-modal-content.js +104 -0
- package/dist/src/manage/remove-items-modal-content.js.map +1 -0
- package/dist/src/mediatype/mediatype-config.d.ts +11 -0
- package/dist/src/mediatype/mediatype-config.js +116 -0
- package/dist/src/mediatype/mediatype-config.js.map +1 -0
- package/dist/src/models.d.ts +298 -0
- package/dist/src/models.js +507 -0
- package/dist/src/models.js.map +1 -0
- package/dist/src/restoration-state-handler.d.ts +74 -0
- package/dist/src/restoration-state-handler.js +397 -0
- package/dist/src/restoration-state-handler.js.map +1 -0
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -0
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +60 -0
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js.map +1 -0
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -0
- package/dist/src/sort-filter-bar/alpha-bar.js +241 -0
- package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
- package/dist/src/sort-filter-bar/img/compact.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/compact.js +5 -0
- package/dist/src/sort-filter-bar/img/compact.js.map +1 -0
- package/dist/src/sort-filter-bar/img/list.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/list.js +5 -0
- package/dist/src/sort-filter-bar/img/list.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +15 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js +17 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js +17 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-triangle.js +5 -0
- package/dist/src/sort-filter-bar/img/sort-triangle.js.map +1 -0
- package/dist/src/sort-filter-bar/img/tile.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/tile.js +5 -0
- package/dist/src/sort-filter-bar/img/tile.js.map +1 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +278 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.js +1161 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
- package/dist/src/styles/ia-button.d.ts +2 -0
- package/dist/src/styles/ia-button.js +134 -0
- package/dist/src/styles/ia-button.js.map +1 -0
- package/dist/src/styles/item-image-styles.d.ts +8 -0
- package/dist/src/styles/item-image-styles.js +123 -0
- package/dist/src/styles/item-image-styles.js.map +1 -0
- package/dist/src/styles/sr-only.d.ts +1 -0
- package/dist/src/styles/sr-only.js +18 -0
- package/dist/src/styles/sr-only.js.map +1 -0
- package/dist/src/tiles/base-tile-component.d.ts +27 -0
- package/dist/src/tiles/base-tile-component.js +82 -0
- package/dist/src/tiles/base-tile-component.js.map +1 -0
- package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -0
- package/dist/src/tiles/collection-browser-loading-tile.js +29 -0
- package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -0
- package/dist/src/tiles/grid/account-tile.d.ts +18 -0
- package/dist/src/tiles/grid/account-tile.js +111 -0
- package/dist/src/tiles/grid/account-tile.js.map +1 -0
- package/dist/src/tiles/grid/collection-tile.d.ts +15 -0
- package/dist/src/tiles/grid/collection-tile.js +160 -0
- package/dist/src/tiles/grid/collection-tile.js.map +1 -0
- package/dist/src/tiles/grid/item-tile.d.ts +41 -0
- package/dist/src/tiles/grid/item-tile.js +321 -0
- package/dist/src/tiles/grid/item-tile.js.map +1 -0
- package/dist/src/tiles/grid/search-tile.d.ts +10 -0
- package/dist/src/tiles/grid/search-tile.js +95 -0
- package/dist/src/tiles/grid/search-tile.js.map +1 -0
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -0
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +128 -0
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -0
- package/dist/src/tiles/grid/tile-stats.d.ts +58 -0
- package/dist/src/tiles/grid/tile-stats.js +204 -0
- package/dist/src/tiles/grid/tile-stats.js.map +1 -0
- package/dist/src/tiles/hover/hover-pane-controller.d.ts +228 -0
- package/dist/src/tiles/hover/hover-pane-controller.js +446 -0
- package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -0
- package/dist/src/tiles/hover/tile-hover-pane.d.ts +20 -0
- package/dist/src/tiles/hover/tile-hover-pane.js +185 -0
- package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -0
- package/dist/src/tiles/image-block.d.ts +19 -0
- package/dist/src/tiles/image-block.js +175 -0
- package/dist/src/tiles/image-block.js.map +1 -0
- package/dist/src/tiles/item-image.d.ts +40 -0
- package/dist/src/tiles/item-image.js +191 -0
- package/dist/src/tiles/item-image.js.map +1 -0
- package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -0
- package/dist/src/tiles/list/tile-list-compact-header.js +85 -0
- package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -0
- package/dist/src/tiles/list/tile-list-compact.d.ts +19 -0
- package/dist/src/tiles/list/tile-list-compact.js +223 -0
- package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
- package/dist/src/tiles/list/tile-list.d.ts +54 -0
- package/dist/src/tiles/list/tile-list.js +621 -0
- package/dist/src/tiles/list/tile-list.js.map +1 -0
- package/dist/src/tiles/models.d.ts +1 -0
- package/dist/src/tiles/models.js +2 -0
- package/dist/src/tiles/models.js.map +1 -0
- package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -0
- package/dist/src/tiles/overlay/icon-overlay.js +55 -0
- package/dist/src/tiles/overlay/icon-overlay.js.map +1 -0
- package/dist/src/tiles/overlay/text-overlay.d.ts +9 -0
- package/dist/src/tiles/overlay/text-overlay.js +74 -0
- package/dist/src/tiles/overlay/text-overlay.js.map +1 -0
- package/dist/src/tiles/review-block.d.ts +12 -0
- package/dist/src/tiles/review-block.js +134 -0
- package/dist/src/tiles/review-block.js.map +1 -0
- package/dist/src/tiles/text-snippet-block.d.ts +27 -0
- package/dist/src/tiles/text-snippet-block.js +132 -0
- package/dist/src/tiles/text-snippet-block.js.map +1 -0
- package/dist/src/tiles/tile-dispatcher.d.ts +71 -0
- package/dist/src/tiles/tile-dispatcher.js +472 -0
- package/dist/src/tiles/tile-dispatcher.js.map +1 -0
- package/dist/src/tiles/tile-display-value-provider.d.ts +47 -0
- package/dist/src/tiles/tile-display-value-provider.js +95 -0
- package/dist/src/tiles/tile-display-value-provider.js.map +1 -0
- package/dist/src/tiles/tile-mediatype-icon.d.ts +27 -0
- package/dist/src/tiles/tile-mediatype-icon.js +130 -0
- package/dist/src/tiles/tile-mediatype-icon.js.map +1 -0
- package/dist/src/utils/analytics-events.d.ts +28 -0
- package/dist/src/utils/analytics-events.js +31 -0
- package/dist/src/utils/analytics-events.js.map +1 -0
- package/dist/src/utils/array-equals.d.ts +4 -0
- package/dist/src/utils/array-equals.js +11 -0
- package/dist/src/utils/array-equals.js.map +1 -0
- package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -0
- package/dist/src/utils/collapse-repeated-quotes.js +14 -0
- package/dist/src/utils/collapse-repeated-quotes.js.map +1 -0
- package/dist/src/utils/facet-utils.d.ts +83 -0
- package/dist/src/utils/facet-utils.js +152 -0
- package/dist/src/utils/facet-utils.js.map +1 -0
- package/dist/src/utils/format-count.d.ts +7 -0
- package/dist/src/utils/format-count.js +76 -0
- package/dist/src/utils/format-count.js.map +1 -0
- package/dist/src/utils/format-date.d.ts +16 -0
- package/dist/src/utils/format-date.js +33 -0
- package/dist/src/utils/format-date.js.map +1 -0
- package/dist/src/utils/format-unit-size.d.ts +2 -0
- package/dist/src/utils/format-unit-size.js +34 -0
- package/dist/src/utils/format-unit-size.js.map +1 -0
- package/dist/src/utils/local-date-from-utc.d.ts +9 -0
- package/dist/src/utils/local-date-from-utc.js +16 -0
- package/dist/src/utils/local-date-from-utc.js.map +1 -0
- package/dist/src/utils/log.d.ts +7 -0
- package/dist/src/utils/log.js +14 -0
- package/dist/src/utils/log.js.map +1 -0
- package/dist/src/utils/resolve-mediatype.d.ts +8 -0
- package/dist/src/utils/resolve-mediatype.js +24 -0
- package/dist/src/utils/resolve-mediatype.js.map +1 -0
- package/dist/src/utils/sha1.d.ts +2 -0
- package/dist/src/utils/sha1.js +9 -0
- package/dist/src/utils/sha1.js.map +1 -0
- package/dist/test/collection-browser.test.d.ts +1 -0
- package/dist/test/collection-browser.test.js +1721 -0
- package/dist/test/collection-browser.test.js.map +1 -0
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -0
- package/dist/test/collection-facets/facet-row.test.js +274 -0
- package/dist/test/collection-facets/facet-row.test.js.map +1 -0
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -0
- package/dist/test/collection-facets/facets-template.test.js +101 -0
- package/dist/test/collection-facets/facets-template.test.js.map +1 -0
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -0
- package/dist/test/collection-facets/more-facets-content.test.js +169 -0
- package/dist/test/collection-facets/more-facets-content.test.js.map +1 -0
- package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -0
- package/dist/test/collection-facets/more-facets-pagination.test.js +132 -0
- package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -0
- package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -0
- package/dist/test/collection-facets/toggle-switch.test.js +96 -0
- package/dist/test/collection-facets/toggle-switch.test.js.map +1 -0
- package/dist/test/collection-facets.test.d.ts +2 -0
- package/dist/test/collection-facets.test.js +745 -0
- package/dist/test/collection-facets.test.js.map +1 -0
- package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -0
- package/dist/test/data-source/collection-browser-data-source.test.js +102 -0
- package/dist/test/data-source/collection-browser-data-source.test.js.map +1 -0
- package/dist/test/empty-placeholder.test.d.ts +1 -0
- package/dist/test/empty-placeholder.test.js +63 -0
- package/dist/test/empty-placeholder.test.js.map +1 -0
- package/dist/test/expanded-date-picker.test.d.ts +1 -0
- package/dist/test/expanded-date-picker.test.js +130 -0
- package/dist/test/expanded-date-picker.test.js.map +1 -0
- package/dist/test/icon-overlay.test.d.ts +1 -0
- package/dist/test/icon-overlay.test.js +30 -0
- package/dist/test/icon-overlay.test.js.map +1 -0
- package/dist/test/image-block.test.d.ts +1 -0
- package/dist/test/image-block.test.js +218 -0
- package/dist/test/image-block.test.js.map +1 -0
- package/dist/test/item-image.test.d.ts +1 -0
- package/dist/test/item-image.test.js +196 -0
- package/dist/test/item-image.test.js.map +1 -0
- package/dist/test/manage/manage-bar.test.d.ts +2 -0
- package/dist/test/manage/manage-bar.test.js +106 -0
- package/dist/test/manage/manage-bar.test.js.map +1 -0
- package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -0
- package/dist/test/manage/remove-items-modal-content.test.js +65 -0
- package/dist/test/manage/remove-items-modal-content.test.js.map +1 -0
- package/dist/test/mediatype-config.test.d.ts +1 -0
- package/dist/test/mediatype-config.test.js +11 -0
- package/dist/test/mediatype-config.test.js.map +1 -0
- package/dist/test/mocks/mock-analytics-handler.d.ts +10 -0
- package/dist/test/mocks/mock-analytics-handler.js +16 -0
- package/dist/test/mocks/mock-analytics-handler.js.map +1 -0
- package/dist/test/mocks/mock-search-responses.d.ts +31 -0
- package/dist/test/mocks/mock-search-responses.js +1241 -0
- package/dist/test/mocks/mock-search-responses.js.map +1 -0
- package/dist/test/mocks/mock-search-service.d.ts +16 -0
- package/dist/test/mocks/mock-search-service.js +65 -0
- package/dist/test/mocks/mock-search-service.js.map +1 -0
- package/dist/test/restoration-state-handler.test.d.ts +1 -0
- package/dist/test/restoration-state-handler.test.js +343 -0
- package/dist/test/restoration-state-handler.test.js.map +1 -0
- package/dist/test/review-block.test.d.ts +1 -0
- package/dist/test/review-block.test.js +48 -0
- package/dist/test/review-block.test.js.map +1 -0
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -0
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +13 -0
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -0
- package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -0
- package/dist/test/sort-filter-bar/alpha-bar.test.js +74 -0
- package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -0
- package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -0
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +609 -0
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -0
- package/dist/test/text-overlay.test.d.ts +1 -0
- package/dist/test/text-overlay.test.js +42 -0
- package/dist/test/text-overlay.test.js.map +1 -0
- package/dist/test/text-snippet-block.test.d.ts +1 -0
- package/dist/test/text-snippet-block.test.js +63 -0
- package/dist/test/text-snippet-block.test.js.map +1 -0
- package/dist/test/tile-stats.test.d.ts +1 -0
- package/dist/test/tile-stats.test.js +128 -0
- package/dist/test/tile-stats.test.js.map +1 -0
- package/dist/test/tiles/grid/account-tile.test.d.ts +1 -0
- package/dist/test/tiles/grid/account-tile.test.js +96 -0
- package/dist/test/tiles/grid/account-tile.test.js.map +1 -0
- package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -0
- package/dist/test/tiles/grid/collection-tile.test.js +96 -0
- package/dist/test/tiles/grid/collection-tile.test.js.map +1 -0
- package/dist/test/tiles/grid/item-tile.test.d.ts +1 -0
- package/dist/test/tiles/grid/item-tile.test.js +427 -0
- package/dist/test/tiles/grid/item-tile.test.js.map +1 -0
- package/dist/test/tiles/grid/search-tile.test.d.ts +1 -0
- package/dist/test/tiles/grid/search-tile.test.js +66 -0
- package/dist/test/tiles/grid/search-tile.test.js.map +1 -0
- package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -0
- package/dist/test/tiles/hover/hover-pane-controller.test.js +329 -0
- package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -0
- package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -0
- package/dist/test/tiles/hover/tile-hover-pane.test.js +57 -0
- package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -0
- package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -0
- package/dist/test/tiles/list/tile-list-compact.test.js +251 -0
- package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -0
- package/dist/test/tiles/list/tile-list.test.d.ts +1 -0
- package/dist/test/tiles/list/tile-list.test.js +469 -0
- package/dist/test/tiles/list/tile-list.test.js.map +1 -0
- package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -0
- package/dist/test/tiles/tile-dispatcher.test.js +231 -0
- package/dist/test/tiles/tile-dispatcher.test.js.map +1 -0
- package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -0
- package/dist/test/tiles/tile-display-value-provider.test.js +142 -0
- package/dist/test/tiles/tile-display-value-provider.test.js.map +1 -0
- package/dist/test/tiles/tile-mediatype-icon.test.d.ts +1 -0
- package/dist/test/tiles/tile-mediatype-icon.test.js +145 -0
- package/dist/test/tiles/tile-mediatype-icon.test.js.map +1 -0
- package/dist/test/utils/array-equals.test.d.ts +1 -0
- package/dist/test/utils/array-equals.test.js +27 -0
- package/dist/test/utils/array-equals.test.js.map +1 -0
- package/dist/test/utils/format-count.test.d.ts +1 -0
- package/dist/test/utils/format-count.test.js +24 -0
- package/dist/test/utils/format-count.test.js.map +1 -0
- package/dist/test/utils/format-date.test.d.ts +1 -0
- package/dist/test/utils/format-date.test.js +61 -0
- package/dist/test/utils/format-date.test.js.map +1 -0
- package/dist/test/utils/format-unit-size.test.d.ts +1 -0
- package/dist/test/utils/format-unit-size.test.js +18 -0
- package/dist/test/utils/format-unit-size.test.js.map +1 -0
- package/dist/test/utils/local-date-from-utc.test.d.ts +1 -0
- package/dist/test/utils/local-date-from-utc.test.js +27 -0
- package/dist/test/utils/local-date-from-utc.test.js.map +1 -0
- package/eslint.config.mjs +53 -53
- package/index.html +24 -24
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +118 -117
- package/renovate.json +6 -6
- package/src/collection-browser.ts +2954 -2829
- package/src/collection-facets/facet-row.ts +299 -296
- package/src/collection-facets/models.ts +10 -10
- package/src/collection-facets/more-facets-content.ts +639 -639
- package/src/collection-facets.ts +1005 -995
- package/src/data-source/collection-browser-data-source-interface.ts +345 -333
- package/src/data-source/collection-browser-data-source.ts +1441 -1401
- package/src/data-source/collection-browser-query-state.ts +59 -65
- package/src/data-source/models.ts +56 -43
- package/src/manage/manage-bar.ts +247 -247
- package/src/models.ts +866 -870
- package/src/restoration-state-handler.ts +542 -544
- package/src/tiles/base-tile-component.ts +65 -65
- package/src/tiles/grid/account-tile.ts +113 -113
- package/src/tiles/grid/collection-tile.ts +163 -163
- package/src/tiles/grid/item-tile.ts +340 -340
- package/src/tiles/grid/search-tile.ts +90 -90
- package/src/tiles/grid/styles/tile-grid-shared-styles.ts +130 -130
- package/src/tiles/hover/hover-pane-controller.ts +613 -517
- package/src/tiles/hover/tile-hover-pane.ts +184 -180
- package/src/tiles/list/tile-list-compact.ts +239 -239
- package/src/tiles/list/tile-list.ts +700 -700
- package/src/tiles/tile-dispatcher.ts +517 -490
- package/src/utils/format-date.ts +62 -62
- package/test/collection-browser.test.ts +2413 -2403
- package/test/collection-facets/facet-row.test.ts +375 -375
- package/test/collection-facets.test.ts +928 -928
- package/test/restoration-state-handler.test.ts +480 -510
- package/test/tiles/grid/item-tile.test.ts +520 -520
- package/test/tiles/hover/hover-pane-controller.test.ts +418 -353
- package/test/tiles/list/tile-list-compact.test.ts +282 -282
- package/test/tiles/list/tile-list.test.ts +552 -552
- package/test/tiles/tile-dispatcher.test.ts +283 -187
- package/test/utils/format-date.test.ts +89 -89
- package/tsconfig.json +20 -20
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { SearchType, SortDirection } from '@internetarchive/search-service';
|
|
2
|
+
import { CollectionBrowserContext, CollectionDisplayMode, SelectedFacets, SortField } from './models';
|
|
3
|
+
export interface RestorationState {
|
|
4
|
+
displayMode?: CollectionDisplayMode;
|
|
5
|
+
searchType?: SearchType;
|
|
6
|
+
selectedSort?: SortField;
|
|
7
|
+
sortDirection?: SortDirection;
|
|
8
|
+
selectedFacets: SelectedFacets;
|
|
9
|
+
baseQuery?: string;
|
|
10
|
+
currentPage?: number;
|
|
11
|
+
titleQuery?: string;
|
|
12
|
+
creatorQuery?: string;
|
|
13
|
+
minSelectedDate?: string;
|
|
14
|
+
maxSelectedDate?: string;
|
|
15
|
+
selectedTitleFilter?: string;
|
|
16
|
+
selectedCreatorFilter?: string;
|
|
17
|
+
}
|
|
18
|
+
export interface RestorationStatePersistOptions {
|
|
19
|
+
forceReplace?: boolean;
|
|
20
|
+
persistMetadataSearchType?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export interface RestorationStateHandlerInterface {
|
|
23
|
+
persistState(state: RestorationState, options?: RestorationStatePersistOptions): void;
|
|
24
|
+
getRestorationState(): RestorationState;
|
|
25
|
+
}
|
|
26
|
+
export declare class RestorationStateHandler implements RestorationStateHandlerInterface {
|
|
27
|
+
private context;
|
|
28
|
+
private cookieDomain;
|
|
29
|
+
private cookieExpiration;
|
|
30
|
+
private cookiePath;
|
|
31
|
+
constructor(options: {
|
|
32
|
+
context: CollectionBrowserContext;
|
|
33
|
+
});
|
|
34
|
+
persistState(state: RestorationState, options?: RestorationStatePersistOptions): void;
|
|
35
|
+
getRestorationState(): RestorationState;
|
|
36
|
+
private persistViewStateToCookies;
|
|
37
|
+
private loadTileViewStateFromCookies;
|
|
38
|
+
private persistQueryStateToUrl;
|
|
39
|
+
private loadQueryStateFromUrl;
|
|
40
|
+
/**
|
|
41
|
+
* Converts a URL sort param into a field/direction pair, if possible.
|
|
42
|
+
* Either or both may be undefined if the param is not in a recognized format.
|
|
43
|
+
*/
|
|
44
|
+
private getSortFieldAndDirection;
|
|
45
|
+
/** Returns the `-` prefix for `desc` sort, or the empty string otherwise. */
|
|
46
|
+
private sortDirectionPrefix;
|
|
47
|
+
/** Remove optional opening and closing quotes from a string */
|
|
48
|
+
private stripQuotes;
|
|
49
|
+
/**
|
|
50
|
+
* Returns whether the two given URLSearchParams objects have
|
|
51
|
+
* identical values for all of the given param keys. If either
|
|
52
|
+
* object contains more than one value for a given key, then
|
|
53
|
+
* all of the values for that key must match (disregarding order).
|
|
54
|
+
*/
|
|
55
|
+
private paramsMatch;
|
|
56
|
+
/**
|
|
57
|
+
* Deletes any params from the given URLSearchParams object that are recognized
|
|
58
|
+
* when loading state from the URL.
|
|
59
|
+
*/
|
|
60
|
+
private removeRecognizedParams;
|
|
61
|
+
/**
|
|
62
|
+
* Returns whether the given URLSearchParams object contains a param that is
|
|
63
|
+
* only recognized as a holdover from legacy search, and should not be
|
|
64
|
+
* persisted to the URL.
|
|
65
|
+
*/
|
|
66
|
+
private hasLegacyParam;
|
|
67
|
+
/**
|
|
68
|
+
* Sets the facet state for the given field & value to the given state,
|
|
69
|
+
* creating any previously-undefined buckets as needed.
|
|
70
|
+
*/
|
|
71
|
+
private setSelectedFacetState;
|
|
72
|
+
/** Returns a default bucket with the given key, count of 0, and state 'none'. */
|
|
73
|
+
private getDefaultBucket;
|
|
74
|
+
}
|
|
@@ -0,0 +1,397 @@
|
|
|
1
|
+
import { SearchType } from '@internetarchive/search-service';
|
|
2
|
+
import { getCookie, setCookie } from 'typescript-cookie';
|
|
3
|
+
import { SortField, getDefaultSelectedFacets, sortOptionFromAPIString, SORT_OPTIONS, tvClipURLParamsToFilters, } from './models';
|
|
4
|
+
import { arrayEquals } from './utils/array-equals';
|
|
5
|
+
export class RestorationStateHandler {
|
|
6
|
+
constructor(options) {
|
|
7
|
+
this.cookieDomain = '.archive.org';
|
|
8
|
+
this.cookieExpiration = 30;
|
|
9
|
+
this.cookiePath = '/';
|
|
10
|
+
this.context = options.context;
|
|
11
|
+
}
|
|
12
|
+
persistState(state, options = {}) {
|
|
13
|
+
if (state.displayMode)
|
|
14
|
+
this.persistViewStateToCookies(state.displayMode);
|
|
15
|
+
this.persistQueryStateToUrl(state, options);
|
|
16
|
+
}
|
|
17
|
+
getRestorationState() {
|
|
18
|
+
const restorationState = this.loadQueryStateFromUrl();
|
|
19
|
+
const displayMode = this.loadTileViewStateFromCookies();
|
|
20
|
+
restorationState.displayMode = displayMode;
|
|
21
|
+
return restorationState;
|
|
22
|
+
}
|
|
23
|
+
persistViewStateToCookies(displayMode) {
|
|
24
|
+
const gridState = displayMode === 'grid' ? 'tiles' : 'lists';
|
|
25
|
+
setCookie(`view-${this.context}`, gridState, {
|
|
26
|
+
domain: this.cookieDomain,
|
|
27
|
+
expires: this.cookieExpiration,
|
|
28
|
+
path: this.cookiePath,
|
|
29
|
+
});
|
|
30
|
+
const detailsState = displayMode === 'list-detail' ? 'showdetails' : '';
|
|
31
|
+
setCookie(`showdetails-${this.context}`, detailsState, {
|
|
32
|
+
domain: this.cookieDomain,
|
|
33
|
+
expires: this.cookieExpiration,
|
|
34
|
+
path: this.cookiePath,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
loadTileViewStateFromCookies() {
|
|
38
|
+
const viewState = getCookie(`view-${this.context}`);
|
|
39
|
+
const detailsState = getCookie(`showdetails-${this.context}`);
|
|
40
|
+
if (viewState === 'tiles' || viewState === undefined)
|
|
41
|
+
return 'grid';
|
|
42
|
+
if (detailsState === 'showdetails')
|
|
43
|
+
return 'list-detail';
|
|
44
|
+
return 'list-compact';
|
|
45
|
+
}
|
|
46
|
+
persistQueryStateToUrl(state, options = {}) {
|
|
47
|
+
var _a, _b, _c, _d, _e;
|
|
48
|
+
const url = new URL(window.location.href);
|
|
49
|
+
const oldParams = new URLSearchParams(url.searchParams);
|
|
50
|
+
const newParams = this.removeRecognizedParams(url.searchParams);
|
|
51
|
+
let replaceEmptySin = false;
|
|
52
|
+
if (state.baseQuery) {
|
|
53
|
+
newParams.set('query', state.baseQuery);
|
|
54
|
+
}
|
|
55
|
+
switch (state.searchType) {
|
|
56
|
+
case SearchType.FULLTEXT:
|
|
57
|
+
newParams.set('sin', 'TXT');
|
|
58
|
+
break;
|
|
59
|
+
case SearchType.RADIO:
|
|
60
|
+
newParams.set('sin', 'RADIO');
|
|
61
|
+
break;
|
|
62
|
+
case SearchType.TV:
|
|
63
|
+
newParams.set('sin', 'TV');
|
|
64
|
+
break;
|
|
65
|
+
case SearchType.METADATA:
|
|
66
|
+
// Only write the param for metadata when it isn't already the default.
|
|
67
|
+
// Currently this is only the case within TV collections.
|
|
68
|
+
if (options.persistMetadataSearchType || oldParams.get('sin') === 'MD')
|
|
69
|
+
newParams.set('sin', 'MD');
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
if (oldParams.get('sin') === '') {
|
|
73
|
+
// Treat empty sin the same as no sin at all
|
|
74
|
+
oldParams.delete('sin');
|
|
75
|
+
replaceEmptySin = true;
|
|
76
|
+
}
|
|
77
|
+
if (state.currentPage) {
|
|
78
|
+
if (state.currentPage > 1) {
|
|
79
|
+
newParams.set('page', state.currentPage.toString());
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
newParams.delete('page');
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (state.selectedSort) {
|
|
86
|
+
const sortOption = SORT_OPTIONS[state.selectedSort];
|
|
87
|
+
let prefix = this.sortDirectionPrefix(state.sortDirection);
|
|
88
|
+
if (sortOption.field === SortField.unrecognized) {
|
|
89
|
+
// For unrecognized sorts, use the existing param, possibly updating its direction
|
|
90
|
+
const oldSortParam = (_a = oldParams.get('sort')) !== null && _a !== void 0 ? _a : '';
|
|
91
|
+
const { field, direction } = this.getSortFieldAndDirection(oldSortParam);
|
|
92
|
+
// Use the state-specified direction if available, or extract one from the param if not
|
|
93
|
+
if (!state.sortDirection)
|
|
94
|
+
prefix = this.sortDirectionPrefix(direction);
|
|
95
|
+
if (field) {
|
|
96
|
+
newParams.set('sort', `${prefix}${field}`);
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
newParams.set('sort', oldSortParam);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
else if (sortOption.shownInURL) {
|
|
103
|
+
// Otherwise, use the canonical API form of the sort option
|
|
104
|
+
const canonicalApiSort = sortOption.urlNames[0];
|
|
105
|
+
newParams.set('sort', `${prefix}${canonicalApiSort}`);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
if (state.selectedFacets) {
|
|
109
|
+
for (const [facetName, facetValues] of Object.entries(state.selectedFacets)) {
|
|
110
|
+
const facetEntries = Object.entries(facetValues);
|
|
111
|
+
if (facetEntries.length === 0)
|
|
112
|
+
continue;
|
|
113
|
+
for (const [key, data] of facetEntries) {
|
|
114
|
+
const notValue = data.state === 'hidden';
|
|
115
|
+
const paramValue = `${facetName}:"${key}"`;
|
|
116
|
+
if (notValue) {
|
|
117
|
+
newParams.append('not[]', paramValue);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
newParams.append('and[]', paramValue);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const dateField = ((_b = state.minSelectedDate) === null || _b === void 0 ? void 0 : _b.includes('-')) ||
|
|
126
|
+
((_c = state.maxSelectedDate) === null || _c === void 0 ? void 0 : _c.includes('-'))
|
|
127
|
+
? 'date'
|
|
128
|
+
: 'year';
|
|
129
|
+
if (state.minSelectedDate && state.maxSelectedDate) {
|
|
130
|
+
newParams.append('and[]', `${dateField}:[${state.minSelectedDate} TO ${state.maxSelectedDate}]`);
|
|
131
|
+
}
|
|
132
|
+
if (state.titleQuery) {
|
|
133
|
+
newParams.append('and[]', state.titleQuery);
|
|
134
|
+
}
|
|
135
|
+
if (state.creatorQuery) {
|
|
136
|
+
newParams.append('and[]', state.creatorQuery);
|
|
137
|
+
}
|
|
138
|
+
// Ensure we aren't pushing consecutive identical states to the history stack.
|
|
139
|
+
// - If the state has changed, we push a new history entry.
|
|
140
|
+
// - If only the page number has changed, we replace the current history entry.
|
|
141
|
+
// - If the state hasn't changed, then do nothing.
|
|
142
|
+
let historyMethod = options.forceReplace
|
|
143
|
+
? 'replaceState'
|
|
144
|
+
: 'pushState';
|
|
145
|
+
const nonQueryParamsMatch = this.paramsMatch(oldParams, newParams, [
|
|
146
|
+
'sin',
|
|
147
|
+
'sort',
|
|
148
|
+
'and[]',
|
|
149
|
+
'not[]',
|
|
150
|
+
'only_commercials',
|
|
151
|
+
'only_factchecks',
|
|
152
|
+
'only_quotes',
|
|
153
|
+
]);
|
|
154
|
+
if (nonQueryParamsMatch &&
|
|
155
|
+
this.paramsMatch(oldParams, newParams, ['query'])) {
|
|
156
|
+
if (replaceEmptySin) {
|
|
157
|
+
// Get rid of any empty sin param
|
|
158
|
+
newParams.delete('sin');
|
|
159
|
+
}
|
|
160
|
+
else if (this.paramsMatch(oldParams, newParams, ['page'])) {
|
|
161
|
+
// For page number, we want to replace the page state when it changes,
|
|
162
|
+
// not push a new history entry. If it hasn't changed, then we're done.
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
historyMethod = 'replaceState';
|
|
166
|
+
}
|
|
167
|
+
else if (nonQueryParamsMatch && this.hasLegacyParam(oldParams)) {
|
|
168
|
+
// Similarly, if the only non-matching param was a legacy query param, then
|
|
169
|
+
// we just want to overwrite it.
|
|
170
|
+
historyMethod = 'replaceState';
|
|
171
|
+
}
|
|
172
|
+
(_e = (_d = window.history)[historyMethod]) === null || _e === void 0 ? void 0 : _e.call(_d, {
|
|
173
|
+
query: state.baseQuery,
|
|
174
|
+
searchType: state.searchType,
|
|
175
|
+
page: state.currentPage,
|
|
176
|
+
sort: { field: state.selectedSort, direction: state.sortDirection },
|
|
177
|
+
minDate: state.minSelectedDate,
|
|
178
|
+
maxDate: state.maxSelectedDate,
|
|
179
|
+
facets: state.selectedFacets,
|
|
180
|
+
}, '', url);
|
|
181
|
+
}
|
|
182
|
+
loadQueryStateFromUrl() {
|
|
183
|
+
var _a;
|
|
184
|
+
const url = new URL(window.location.href);
|
|
185
|
+
const searchInside = url.searchParams.get('sin');
|
|
186
|
+
const pageNumber = url.searchParams.get('page');
|
|
187
|
+
const searchQuery = url.searchParams.get('query');
|
|
188
|
+
const sortQuery = url.searchParams.get('sort');
|
|
189
|
+
const facetAnds = url.searchParams.getAll('and[]');
|
|
190
|
+
const facetNots = url.searchParams.getAll('not[]');
|
|
191
|
+
// We also need to check for the presence of params like 'and[0]', 'not[1]', etc.
|
|
192
|
+
// since Facebook automatically converts URLs with [] into those forms.
|
|
193
|
+
for (const [key, val] of url.searchParams.entries()) {
|
|
194
|
+
if (/and\[\d+\]/.test(key)) {
|
|
195
|
+
facetAnds.push(val);
|
|
196
|
+
}
|
|
197
|
+
else if (/not\[\d+\]/.test(key)) {
|
|
198
|
+
facetNots.push(val);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
// Legacy search allowed `q` and `search` params for the query, so in the interest
|
|
202
|
+
// of backwards-compatibility with old bookmarks, we recognize those here too.
|
|
203
|
+
// (However, they still get upgraded to a `query` param when we persist our state
|
|
204
|
+
// to the URL).
|
|
205
|
+
const legacySearchQuery = (_a = url.searchParams.get('q')) !== null && _a !== void 0 ? _a : url.searchParams.get('search');
|
|
206
|
+
const restorationState = {
|
|
207
|
+
selectedFacets: getDefaultSelectedFacets(),
|
|
208
|
+
};
|
|
209
|
+
if (searchQuery) {
|
|
210
|
+
restorationState.baseQuery = searchQuery;
|
|
211
|
+
}
|
|
212
|
+
else if (legacySearchQuery) {
|
|
213
|
+
restorationState.baseQuery = legacySearchQuery;
|
|
214
|
+
}
|
|
215
|
+
switch (searchInside) {
|
|
216
|
+
case 'TXT':
|
|
217
|
+
restorationState.searchType = SearchType.FULLTEXT;
|
|
218
|
+
break;
|
|
219
|
+
case 'RADIO':
|
|
220
|
+
restorationState.searchType = SearchType.RADIO;
|
|
221
|
+
break;
|
|
222
|
+
case 'TV':
|
|
223
|
+
restorationState.searchType = SearchType.TV;
|
|
224
|
+
break;
|
|
225
|
+
case 'MD':
|
|
226
|
+
restorationState.searchType = SearchType.METADATA;
|
|
227
|
+
break;
|
|
228
|
+
default:
|
|
229
|
+
restorationState.searchType = SearchType.DEFAULT;
|
|
230
|
+
break;
|
|
231
|
+
}
|
|
232
|
+
if (pageNumber) {
|
|
233
|
+
const parsed = parseInt(pageNumber, 10);
|
|
234
|
+
restorationState.currentPage = parsed;
|
|
235
|
+
}
|
|
236
|
+
else {
|
|
237
|
+
restorationState.currentPage = 1;
|
|
238
|
+
}
|
|
239
|
+
if (sortQuery) {
|
|
240
|
+
const { field, direction } = this.getSortFieldAndDirection(sortQuery);
|
|
241
|
+
const sortOption = sortOptionFromAPIString(field);
|
|
242
|
+
restorationState.selectedSort = sortOption.field;
|
|
243
|
+
if (['asc', 'desc'].includes(direction)) {
|
|
244
|
+
restorationState.sortDirection = direction;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
if (facetAnds) {
|
|
248
|
+
facetAnds.forEach(and => {
|
|
249
|
+
// eslint-disable-next-line prefer-const
|
|
250
|
+
let [field, value] = and.split(':');
|
|
251
|
+
// Legacy search allowed and[] fields like 'creatorSorter', 'languageSorter', etc.
|
|
252
|
+
// which we want to normalize to 'creator', 'language', etc. if redirected here.
|
|
253
|
+
field = field.replace(/Sorter$/, '');
|
|
254
|
+
// Legacy search also allowed a form of negative faceting like `and[]=-collection:foo`
|
|
255
|
+
// which we want to normalize to a not[] param instead
|
|
256
|
+
if (field.startsWith('-')) {
|
|
257
|
+
facetNots.push(and.slice(1));
|
|
258
|
+
return;
|
|
259
|
+
}
|
|
260
|
+
switch (field) {
|
|
261
|
+
case 'date':
|
|
262
|
+
case 'year': {
|
|
263
|
+
const [minDate, maxDate] = value.split(' TO ');
|
|
264
|
+
// we have two potential ways of filtering by date:
|
|
265
|
+
// the range with "date TO date" or the single date with "date"
|
|
266
|
+
// this is checking for the range case and if we don't have those, fall
|
|
267
|
+
// back to the single date case
|
|
268
|
+
if (minDate && maxDate) {
|
|
269
|
+
restorationState.minSelectedDate = minDate.substring(1, minDate.length);
|
|
270
|
+
restorationState.maxSelectedDate = maxDate.substring(0, maxDate.length - 1);
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
|
|
274
|
+
}
|
|
275
|
+
break;
|
|
276
|
+
}
|
|
277
|
+
case 'firstTitle':
|
|
278
|
+
restorationState.selectedTitleFilter = value;
|
|
279
|
+
break;
|
|
280
|
+
case 'firstCreator':
|
|
281
|
+
restorationState.selectedCreatorFilter = value;
|
|
282
|
+
break;
|
|
283
|
+
default:
|
|
284
|
+
this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
|
|
285
|
+
}
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
if (facetNots) {
|
|
289
|
+
facetNots.forEach(not => {
|
|
290
|
+
const [field, value] = not.split(':');
|
|
291
|
+
this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'hidden');
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
// TV clip special filters (carryovers from legacy page)
|
|
295
|
+
for (const [paramKey, facetKey] of Object.entries(tvClipURLParamsToFilters)) {
|
|
296
|
+
if (url.searchParams.get(paramKey)) {
|
|
297
|
+
this.setSelectedFacetState(restorationState.selectedFacets, 'clip_type', facetKey, 'selected');
|
|
298
|
+
break;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
return restorationState;
|
|
302
|
+
}
|
|
303
|
+
/**
|
|
304
|
+
* Converts a URL sort param into a field/direction pair, if possible.
|
|
305
|
+
* Either or both may be undefined if the param is not in a recognized format.
|
|
306
|
+
*/
|
|
307
|
+
getSortFieldAndDirection(sortParam) {
|
|
308
|
+
// check for two different sort formats: `date desc` and `-date`
|
|
309
|
+
const hasSpace = sortParam.indexOf(' ') > -1;
|
|
310
|
+
let field;
|
|
311
|
+
let direction;
|
|
312
|
+
if (hasSpace) {
|
|
313
|
+
[field, direction] = sortParam.split(' ');
|
|
314
|
+
}
|
|
315
|
+
else {
|
|
316
|
+
field = sortParam.startsWith('-') ? sortParam.slice(1) : sortParam;
|
|
317
|
+
direction = sortParam.startsWith('-') ? 'desc' : 'asc';
|
|
318
|
+
}
|
|
319
|
+
return { field, direction };
|
|
320
|
+
}
|
|
321
|
+
/** Returns the `-` prefix for `desc` sort, or the empty string otherwise. */
|
|
322
|
+
sortDirectionPrefix(sortDirection) {
|
|
323
|
+
return sortDirection === 'desc' ? '-' : '';
|
|
324
|
+
}
|
|
325
|
+
/** Remove optional opening and closing quotes from a string */
|
|
326
|
+
stripQuotes(value) {
|
|
327
|
+
if (value.startsWith('"') && value.endsWith('"')) {
|
|
328
|
+
return value.substring(1, value.length - 1);
|
|
329
|
+
}
|
|
330
|
+
return value;
|
|
331
|
+
}
|
|
332
|
+
/**
|
|
333
|
+
* Returns whether the two given URLSearchParams objects have
|
|
334
|
+
* identical values for all of the given param keys. If either
|
|
335
|
+
* object contains more than one value for a given key, then
|
|
336
|
+
* all of the values for that key must match (disregarding order).
|
|
337
|
+
*/
|
|
338
|
+
paramsMatch(searchParams1, searchParams2, keys) {
|
|
339
|
+
return keys.every(key => arrayEquals(searchParams1.getAll(key).sort(), searchParams2.getAll(key).sort()));
|
|
340
|
+
}
|
|
341
|
+
/**
|
|
342
|
+
* Deletes any params from the given URLSearchParams object that are recognized
|
|
343
|
+
* when loading state from the URL.
|
|
344
|
+
*/
|
|
345
|
+
removeRecognizedParams(searchParams) {
|
|
346
|
+
// Remove all of our standard params
|
|
347
|
+
searchParams.delete('query');
|
|
348
|
+
searchParams.delete('sin');
|
|
349
|
+
searchParams.delete('page');
|
|
350
|
+
searchParams.delete('sort');
|
|
351
|
+
searchParams.delete('and[]');
|
|
352
|
+
searchParams.delete('not[]');
|
|
353
|
+
// Remove any and/not facet params that contain numbers in their square brackets
|
|
354
|
+
for (const key of searchParams.keys()) {
|
|
355
|
+
if (/(and|not)\[\d+\]/.test(key)) {
|
|
356
|
+
searchParams.delete(key);
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
// Also remove some legacy params that should have been upgraded to the ones above
|
|
360
|
+
searchParams.delete('q');
|
|
361
|
+
searchParams.delete('search');
|
|
362
|
+
searchParams.delete('only_commercials');
|
|
363
|
+
searchParams.delete('only_factchecks');
|
|
364
|
+
searchParams.delete('only_quotes');
|
|
365
|
+
return searchParams;
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Returns whether the given URLSearchParams object contains a param that is
|
|
369
|
+
* only recognized as a holdover from legacy search, and should not be
|
|
370
|
+
* persisted to the URL.
|
|
371
|
+
*/
|
|
372
|
+
hasLegacyParam(searchParams) {
|
|
373
|
+
return searchParams.has('q') || searchParams.has('search');
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Sets the facet state for the given field & value to the given state,
|
|
377
|
+
* creating any previously-undefined buckets as needed.
|
|
378
|
+
*/
|
|
379
|
+
setSelectedFacetState(selectedFacets, field, value, state) {
|
|
380
|
+
var _a;
|
|
381
|
+
const facet = selectedFacets[field];
|
|
382
|
+
if (!facet)
|
|
383
|
+
return; // Unrecognized facet group, ignore it.
|
|
384
|
+
const unQuotedValue = this.stripQuotes(value);
|
|
385
|
+
(_a = facet[unQuotedValue]) !== null && _a !== void 0 ? _a : (facet[unQuotedValue] = this.getDefaultBucket(value));
|
|
386
|
+
facet[unQuotedValue].state = state;
|
|
387
|
+
}
|
|
388
|
+
/** Returns a default bucket with the given key, count of 0, and state 'none'. */
|
|
389
|
+
getDefaultBucket(key) {
|
|
390
|
+
return {
|
|
391
|
+
key,
|
|
392
|
+
count: 0,
|
|
393
|
+
state: 'none',
|
|
394
|
+
};
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
//# sourceMappingURL=restoration-state-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"restoration-state-handler.js","sourceRoot":"","sources":["../../src/restoration-state-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import { SearchType, SortDirection } from '@internetarchive/search-service';\r\nimport { getCookie, setCookie } from 'typescript-cookie';\r\nimport {\r\n FacetOption,\r\n CollectionBrowserContext,\r\n CollectionDisplayMode,\r\n SelectedFacets,\r\n SortField,\r\n FacetBucket,\r\n FacetState,\r\n getDefaultSelectedFacets,\r\n sortOptionFromAPIString,\r\n SORT_OPTIONS,\r\n tvClipURLParamsToFilters,\r\n} from './models';\r\nimport { arrayEquals } from './utils/array-equals';\r\n\r\nexport interface RestorationState {\r\n displayMode?: CollectionDisplayMode;\r\n searchType?: SearchType;\r\n selectedSort?: SortField;\r\n sortDirection?: SortDirection;\r\n selectedFacets: SelectedFacets;\r\n baseQuery?: string;\r\n currentPage?: number;\r\n titleQuery?: string;\r\n creatorQuery?: string;\r\n minSelectedDate?: string;\r\n maxSelectedDate?: string;\r\n selectedTitleFilter?: string;\r\n selectedCreatorFilter?: string;\r\n}\r\n\r\nexport interface RestorationStatePersistOptions {\r\n forceReplace?: boolean;\r\n persistMetadataSearchType?: boolean;\r\n}\r\n\r\nexport interface RestorationStateHandlerInterface {\r\n persistState(\r\n state: RestorationState,\r\n options?: RestorationStatePersistOptions,\r\n ): void;\r\n getRestorationState(): RestorationState;\r\n}\r\n\r\nexport class RestorationStateHandler\r\n implements RestorationStateHandlerInterface\r\n{\r\n private context: CollectionBrowserContext;\r\n\r\n private cookieDomain = '.archive.org';\r\n\r\n private cookieExpiration = 30;\r\n\r\n private cookiePath = '/';\r\n\r\n constructor(options: { context: CollectionBrowserContext }) {\r\n this.context = options.context;\r\n }\r\n\r\n persistState(\r\n state: RestorationState,\r\n options: RestorationStatePersistOptions = {},\r\n ): void {\r\n if (state.displayMode) this.persistViewStateToCookies(state.displayMode);\r\n this.persistQueryStateToUrl(state, options);\r\n }\r\n\r\n getRestorationState(): RestorationState {\r\n const restorationState = this.loadQueryStateFromUrl();\r\n const displayMode = this.loadTileViewStateFromCookies();\r\n restorationState.displayMode = displayMode;\r\n return restorationState;\r\n }\r\n\r\n private persistViewStateToCookies(displayMode: CollectionDisplayMode) {\r\n const gridState = displayMode === 'grid' ? 'tiles' : 'lists';\r\n setCookie(`view-${this.context}`, gridState, {\r\n domain: this.cookieDomain,\r\n expires: this.cookieExpiration,\r\n path: this.cookiePath,\r\n });\r\n const detailsState = displayMode === 'list-detail' ? 'showdetails' : '';\r\n setCookie(`showdetails-${this.context}`, detailsState, {\r\n domain: this.cookieDomain,\r\n expires: this.cookieExpiration,\r\n path: this.cookiePath,\r\n });\r\n }\r\n\r\n private loadTileViewStateFromCookies(): CollectionDisplayMode {\r\n const viewState = getCookie(`view-${this.context}`);\r\n const detailsState = getCookie(`showdetails-${this.context}`);\r\n if (viewState === 'tiles' || viewState === undefined) return 'grid';\r\n if (detailsState === 'showdetails') return 'list-detail';\r\n return 'list-compact';\r\n }\r\n\r\n private persistQueryStateToUrl(\r\n state: RestorationState,\r\n options: RestorationStatePersistOptions = {},\r\n ) {\r\n const url = new URL(window.location.href);\r\n const oldParams = new URLSearchParams(url.searchParams);\r\n const newParams = this.removeRecognizedParams(url.searchParams);\r\n\r\n let replaceEmptySin = false;\r\n\r\n if (state.baseQuery) {\r\n newParams.set('query', state.baseQuery);\r\n }\r\n\r\n switch (state.searchType) {\r\n case SearchType.FULLTEXT:\r\n newParams.set('sin', 'TXT');\r\n break;\r\n case SearchType.RADIO:\r\n newParams.set('sin', 'RADIO');\r\n break;\r\n case SearchType.TV:\r\n newParams.set('sin', 'TV');\r\n break;\r\n case SearchType.METADATA:\r\n // Only write the param for metadata when it isn't already the default.\r\n // Currently this is only the case within TV collections.\r\n if (options.persistMetadataSearchType || oldParams.get('sin') === 'MD')\r\n newParams.set('sin', 'MD');\r\n break;\r\n }\r\n\r\n if (oldParams.get('sin') === '') {\r\n // Treat empty sin the same as no sin at all\r\n oldParams.delete('sin');\r\n replaceEmptySin = true;\r\n }\r\n\r\n if (state.currentPage) {\r\n if (state.currentPage > 1) {\r\n newParams.set('page', state.currentPage.toString());\r\n } else {\r\n newParams.delete('page');\r\n }\r\n }\r\n\r\n if (state.selectedSort) {\r\n const sortOption = SORT_OPTIONS[state.selectedSort];\r\n let prefix = this.sortDirectionPrefix(state.sortDirection);\r\n\r\n if (sortOption.field === SortField.unrecognized) {\r\n // For unrecognized sorts, use the existing param, possibly updating its direction\r\n const oldSortParam = oldParams.get('sort') ?? '';\r\n const { field, direction } =\r\n this.getSortFieldAndDirection(oldSortParam);\r\n\r\n // Use the state-specified direction if available, or extract one from the param if not\r\n if (!state.sortDirection) prefix = this.sortDirectionPrefix(direction);\r\n\r\n if (field) {\r\n newParams.set('sort', `${prefix}${field}`);\r\n } else {\r\n newParams.set('sort', oldSortParam);\r\n }\r\n } else if (sortOption.shownInURL) {\r\n // Otherwise, use the canonical API form of the sort option\r\n const canonicalApiSort = sortOption.urlNames[0];\r\n newParams.set('sort', `${prefix}${canonicalApiSort}`);\r\n }\r\n }\r\n\r\n if (state.selectedFacets) {\r\n for (const [facetName, facetValues] of Object.entries(\r\n state.selectedFacets,\r\n )) {\r\n const facetEntries = Object.entries(facetValues);\r\n if (facetEntries.length === 0) continue;\r\n for (const [key, data] of facetEntries) {\r\n const notValue = data.state === 'hidden';\r\n const paramValue = `${facetName}:\"${key}\"`;\r\n if (notValue) {\r\n newParams.append('not[]', paramValue);\r\n } else {\r\n newParams.append('and[]', paramValue);\r\n }\r\n }\r\n }\r\n }\r\n\r\n const dateField =\r\n state.minSelectedDate?.includes('-') ||\r\n state.maxSelectedDate?.includes('-')\r\n ? 'date'\r\n : 'year';\r\n\r\n if (state.minSelectedDate && state.maxSelectedDate) {\r\n newParams.append(\r\n 'and[]',\r\n `${dateField}:[${state.minSelectedDate} TO ${state.maxSelectedDate}]`,\r\n );\r\n }\r\n\r\n if (state.titleQuery) {\r\n newParams.append('and[]', state.titleQuery);\r\n }\r\n\r\n if (state.creatorQuery) {\r\n newParams.append('and[]', state.creatorQuery);\r\n }\r\n\r\n // Ensure we aren't pushing consecutive identical states to the history stack.\r\n // - If the state has changed, we push a new history entry.\r\n // - If only the page number has changed, we replace the current history entry.\r\n // - If the state hasn't changed, then do nothing.\r\n let historyMethod: 'pushState' | 'replaceState' = options.forceReplace\r\n ? 'replaceState'\r\n : 'pushState';\r\n const nonQueryParamsMatch = this.paramsMatch(oldParams, newParams, [\r\n 'sin',\r\n 'sort',\r\n 'and[]',\r\n 'not[]',\r\n 'only_commercials',\r\n 'only_factchecks',\r\n 'only_quotes',\r\n ]);\r\n\r\n if (\r\n nonQueryParamsMatch &&\r\n this.paramsMatch(oldParams, newParams, ['query'])\r\n ) {\r\n if (replaceEmptySin) {\r\n // Get rid of any empty sin param\r\n newParams.delete('sin');\r\n } else if (this.paramsMatch(oldParams, newParams, ['page'])) {\r\n // For page number, we want to replace the page state when it changes,\r\n // not push a new history entry. If it hasn't changed, then we're done.\r\n return;\r\n }\r\n historyMethod = 'replaceState';\r\n } else if (nonQueryParamsMatch && this.hasLegacyParam(oldParams)) {\r\n // Similarly, if the only non-matching param was a legacy query param, then\r\n // we just want to overwrite it.\r\n historyMethod = 'replaceState';\r\n }\r\n\r\n window.history[historyMethod]?.(\r\n {\r\n query: state.baseQuery,\r\n searchType: state.searchType,\r\n page: state.currentPage,\r\n sort: { field: state.selectedSort, direction: state.sortDirection },\r\n minDate: state.minSelectedDate,\r\n maxDate: state.maxSelectedDate,\r\n facets: state.selectedFacets,\r\n },\r\n '',\r\n url,\r\n );\r\n }\r\n\r\n private loadQueryStateFromUrl(): RestorationState {\r\n const url = new URL(window.location.href);\r\n const searchInside = url.searchParams.get('sin');\r\n const pageNumber = url.searchParams.get('page');\r\n const searchQuery = url.searchParams.get('query');\r\n const sortQuery = url.searchParams.get('sort');\r\n const facetAnds = url.searchParams.getAll('and[]');\r\n const facetNots = url.searchParams.getAll('not[]');\r\n\r\n // We also need to check for the presence of params like 'and[0]', 'not[1]', etc.\r\n // since Facebook automatically converts URLs with [] into those forms.\r\n for (const [key, val] of url.searchParams.entries()) {\r\n if (/and\\[\\d+\\]/.test(key)) {\r\n facetAnds.push(val);\r\n } else if (/not\\[\\d+\\]/.test(key)) {\r\n facetNots.push(val);\r\n }\r\n }\r\n\r\n // Legacy search allowed `q` and `search` params for the query, so in the interest\r\n // of backwards-compatibility with old bookmarks, we recognize those here too.\r\n // (However, they still get upgraded to a `query` param when we persist our state\r\n // to the URL).\r\n const legacySearchQuery =\r\n url.searchParams.get('q') ?? url.searchParams.get('search');\r\n\r\n const restorationState: RestorationState = {\r\n selectedFacets: getDefaultSelectedFacets(),\r\n };\r\n\r\n if (searchQuery) {\r\n restorationState.baseQuery = searchQuery;\r\n } else if (legacySearchQuery) {\r\n restorationState.baseQuery = legacySearchQuery;\r\n }\r\n\r\n switch (searchInside) {\r\n case 'TXT':\r\n restorationState.searchType = SearchType.FULLTEXT;\r\n break;\r\n case 'RADIO':\r\n restorationState.searchType = SearchType.RADIO;\r\n break;\r\n case 'TV':\r\n restorationState.searchType = SearchType.TV;\r\n break;\r\n case 'MD':\r\n restorationState.searchType = SearchType.METADATA;\r\n break;\r\n default:\r\n restorationState.searchType = SearchType.DEFAULT;\r\n break;\r\n }\r\n\r\n if (pageNumber) {\r\n const parsed = parseInt(pageNumber, 10);\r\n restorationState.currentPage = parsed;\r\n } else {\r\n restorationState.currentPage = 1;\r\n }\r\n\r\n if (sortQuery) {\r\n const { field, direction } = this.getSortFieldAndDirection(sortQuery);\r\n\r\n const sortOption = sortOptionFromAPIString(field);\r\n restorationState.selectedSort = sortOption.field;\r\n\r\n if (['asc', 'desc'].includes(direction)) {\r\n restorationState.sortDirection = direction as SortDirection;\r\n }\r\n }\r\n\r\n if (facetAnds) {\r\n facetAnds.forEach(and => {\r\n // eslint-disable-next-line prefer-const\r\n let [field, value] = and.split(':');\r\n\r\n // Legacy search allowed and[] fields like 'creatorSorter', 'languageSorter', etc.\r\n // which we want to normalize to 'creator', 'language', etc. if redirected here.\r\n field = field.replace(/Sorter$/, '');\r\n\r\n // Legacy search also allowed a form of negative faceting like `and[]=-collection:foo`\r\n // which we want to normalize to a not[] param instead\r\n if (field.startsWith('-')) {\r\n facetNots.push(and.slice(1));\r\n return;\r\n }\r\n\r\n switch (field) {\r\n case 'date':\r\n case 'year': {\r\n const [minDate, maxDate] = value.split(' TO ');\r\n // we have two potential ways of filtering by date:\r\n // the range with \"date TO date\" or the single date with \"date\"\r\n // this is checking for the range case and if we don't have those, fall\r\n // back to the single date case\r\n if (minDate && maxDate) {\r\n restorationState.minSelectedDate = minDate.substring(\r\n 1,\r\n minDate.length,\r\n );\r\n restorationState.maxSelectedDate = maxDate.substring(\r\n 0,\r\n maxDate.length - 1,\r\n );\r\n } else {\r\n this.setSelectedFacetState(\r\n restorationState.selectedFacets,\r\n field as FacetOption,\r\n value,\r\n 'selected',\r\n );\r\n }\r\n break;\r\n }\r\n case 'firstTitle':\r\n restorationState.selectedTitleFilter = value;\r\n break;\r\n case 'firstCreator':\r\n restorationState.selectedCreatorFilter = value;\r\n break;\r\n default:\r\n this.setSelectedFacetState(\r\n restorationState.selectedFacets,\r\n field as FacetOption,\r\n value,\r\n 'selected',\r\n );\r\n }\r\n });\r\n }\r\n\r\n if (facetNots) {\r\n facetNots.forEach(not => {\r\n const [field, value] = not.split(':');\r\n this.setSelectedFacetState(\r\n restorationState.selectedFacets,\r\n field as FacetOption,\r\n value,\r\n 'hidden',\r\n );\r\n });\r\n }\r\n\r\n // TV clip special filters (carryovers from legacy page)\r\n for (const [paramKey, facetKey] of Object.entries(\r\n tvClipURLParamsToFilters,\r\n )) {\r\n if (url.searchParams.get(paramKey)) {\r\n this.setSelectedFacetState(\r\n restorationState.selectedFacets,\r\n 'clip_type',\r\n facetKey,\r\n 'selected',\r\n );\r\n break;\r\n }\r\n }\r\n\r\n return restorationState;\r\n }\r\n\r\n /**\r\n * Converts a URL sort param into a field/direction pair, if possible.\r\n * Either or both may be undefined if the param is not in a recognized format.\r\n */\r\n private getSortFieldAndDirection(sortParam: string) {\r\n // check for two different sort formats: `date desc` and `-date`\r\n const hasSpace = sortParam.indexOf(' ') > -1;\r\n let field;\r\n let direction;\r\n if (hasSpace) {\r\n [field, direction] = sortParam.split(' ');\r\n } else {\r\n field = sortParam.startsWith('-') ? sortParam.slice(1) : sortParam;\r\n direction = sortParam.startsWith('-') ? 'desc' : 'asc';\r\n }\r\n\r\n return { field, direction };\r\n }\r\n\r\n /** Returns the `-` prefix for `desc` sort, or the empty string otherwise. */\r\n private sortDirectionPrefix(sortDirection?: string) {\r\n return sortDirection === 'desc' ? '-' : '';\r\n }\r\n\r\n /** Remove optional opening and closing quotes from a string */\r\n private stripQuotes(value: string): string {\r\n if (value.startsWith('\"') && value.endsWith('\"')) {\r\n return value.substring(1, value.length - 1);\r\n }\r\n\r\n return value;\r\n }\r\n\r\n /**\r\n * Returns whether the two given URLSearchParams objects have\r\n * identical values for all of the given param keys. If either\r\n * object contains more than one value for a given key, then\r\n * all of the values for that key must match (disregarding order).\r\n */\r\n private paramsMatch(\r\n searchParams1: URLSearchParams,\r\n searchParams2: URLSearchParams,\r\n keys: string[],\r\n ): boolean {\r\n return keys.every(key =>\r\n arrayEquals(\r\n searchParams1.getAll(key).sort(),\r\n searchParams2.getAll(key).sort(),\r\n ),\r\n );\r\n }\r\n\r\n /**\r\n * Deletes any params from the given URLSearchParams object that are recognized\r\n * when loading state from the URL.\r\n */\r\n private removeRecognizedParams(\r\n searchParams: URLSearchParams,\r\n ): URLSearchParams {\r\n // Remove all of our standard params\r\n searchParams.delete('query');\r\n searchParams.delete('sin');\r\n searchParams.delete('page');\r\n searchParams.delete('sort');\r\n searchParams.delete('and[]');\r\n searchParams.delete('not[]');\r\n\r\n // Remove any and/not facet params that contain numbers in their square brackets\r\n for (const key of searchParams.keys()) {\r\n if (/(and|not)\\[\\d+\\]/.test(key)) {\r\n searchParams.delete(key);\r\n }\r\n }\r\n\r\n // Also remove some legacy params that should have been upgraded to the ones above\r\n searchParams.delete('q');\r\n searchParams.delete('search');\r\n searchParams.delete('only_commercials');\r\n searchParams.delete('only_factchecks');\r\n searchParams.delete('only_quotes');\r\n\r\n return searchParams;\r\n }\r\n\r\n /**\r\n * Returns whether the given URLSearchParams object contains a param that is\r\n * only recognized as a holdover from legacy search, and should not be\r\n * persisted to the URL.\r\n */\r\n private hasLegacyParam(searchParams: URLSearchParams): boolean {\r\n return searchParams.has('q') || searchParams.has('search');\r\n }\r\n\r\n /**\r\n * Sets the facet state for the given field & value to the given state,\r\n * creating any previously-undefined buckets as needed.\r\n */\r\n private setSelectedFacetState(\r\n selectedFacets: SelectedFacets,\r\n field: FacetOption,\r\n value: string,\r\n state: FacetState,\r\n ): void {\r\n const facet = selectedFacets[field];\r\n if (!facet) return; // Unrecognized facet group, ignore it.\r\n\r\n const unQuotedValue = this.stripQuotes(value);\r\n facet[unQuotedValue] ??= this.getDefaultBucket(value);\r\n facet[unQuotedValue].state = state;\r\n }\r\n\r\n /** Returns a default bucket with the given key, count of 0, and state 'none'. */\r\n private getDefaultBucket(key: string): FacetBucket {\r\n return {\r\n key,\r\n count: 0,\r\n state: 'none',\r\n };\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { LitElement, html, css } from 'lit';
|
|
3
|
+
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
+
let AlphaBarTooltip = class AlphaBarTooltip extends LitElement {
|
|
5
|
+
constructor() {
|
|
6
|
+
super(...arguments);
|
|
7
|
+
this.numResults = 0;
|
|
8
|
+
}
|
|
9
|
+
render() {
|
|
10
|
+
return html `
|
|
11
|
+
<div id="tooltip-container" role="tooltip">
|
|
12
|
+
<div id="arrow"></div>
|
|
13
|
+
<div id="tooltip-text">
|
|
14
|
+
${this.numResults} ${this.numResults === 1 ? 'result' : 'results'}
|
|
15
|
+
</div>
|
|
16
|
+
</div>
|
|
17
|
+
`;
|
|
18
|
+
}
|
|
19
|
+
static get styles() {
|
|
20
|
+
const arrowSize = css `var(--tooltipArrowSize, 5px)`;
|
|
21
|
+
const arrowOffset = css `var(--tooltipArrowOffset, 0px)`;
|
|
22
|
+
return css `
|
|
23
|
+
#tooltip-container {
|
|
24
|
+
width: max-content;
|
|
25
|
+
max-width: 200px;
|
|
26
|
+
pointer-events: none;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
#arrow {
|
|
30
|
+
position: relative;
|
|
31
|
+
left: calc(50% + ${arrowOffset});
|
|
32
|
+
top: 0;
|
|
33
|
+
width: 0;
|
|
34
|
+
height: 0;
|
|
35
|
+
margin-top: calc(-1 * ${arrowSize});
|
|
36
|
+
margin-left: calc(-1 * ${arrowSize});
|
|
37
|
+
border: ${arrowSize} solid transparent;
|
|
38
|
+
border-bottom-color: black;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
#tooltip-text {
|
|
42
|
+
padding: 3px 8px;
|
|
43
|
+
border-radius: 4px;
|
|
44
|
+
background-color: #000;
|
|
45
|
+
color: white;
|
|
46
|
+
font-size: 1.2rem;
|
|
47
|
+
text-align: center;
|
|
48
|
+
text-decoration: none;
|
|
49
|
+
}
|
|
50
|
+
`;
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
__decorate([
|
|
54
|
+
property({ type: Number })
|
|
55
|
+
], AlphaBarTooltip.prototype, "numResults", void 0);
|
|
56
|
+
AlphaBarTooltip = __decorate([
|
|
57
|
+
customElement('alpha-bar-tooltip')
|
|
58
|
+
], AlphaBarTooltip);
|
|
59
|
+
export { AlphaBarTooltip };
|
|
60
|
+
//# sourceMappingURL=alpha-bar-tooltip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alpha-bar-tooltip.js","sourceRoot":"","sources":["../../../src/sort-filter-bar/alpha-bar-tooltip.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAkB,MAAM,KAAK,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAGrD,IAAM,eAAe,GAArB,MAAM,eAAgB,SAAQ,UAAU;IAAxC;;QACuB,eAAU,GAAW,CAAC,CAAC;IA+CrD,CAAC;IA7CC,MAAM;QACJ,OAAO,IAAI,CAAA;;;;YAIH,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;KAGtE,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,MAAM,SAAS,GAAG,GAAG,CAAA,8BAA8B,CAAC;QACpD,MAAM,WAAW,GAAG,GAAG,CAAA,gCAAgC,CAAC;QAExD,OAAO,GAAG,CAAA;;;;;;;;;2BASa,WAAW;;;;gCAIN,SAAS;iCACR,SAAS;kBACxB,SAAS;;;;;;;;;;;;;KAatB,CAAC;IACJ,CAAC;CACF,CAAA;AA/C6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAAwB;AADxC,eAAe;IAD3B,aAAa,CAAC,mBAAmB,CAAC;GACtB,eAAe,CAgD3B","sourcesContent":["import { LitElement, html, css, CSSResultGroup } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('alpha-bar-tooltip')\nexport class AlphaBarTooltip extends LitElement {\n @property({ type: Number }) numResults: number = 0;\n\n render() {\n return html`\n <div id=\"tooltip-container\" role=\"tooltip\">\n <div id=\"arrow\"></div>\n <div id=\"tooltip-text\">\n ${this.numResults} ${this.numResults === 1 ? 'result' : 'results'}\n </div>\n </div>\n `;\n }\n\n static get styles(): CSSResultGroup {\n const arrowSize = css`var(--tooltipArrowSize, 5px)`;\n const arrowOffset = css`var(--tooltipArrowOffset, 0px)`;\n\n return css`\n #tooltip-container {\n width: max-content;\n max-width: 200px;\n pointer-events: none;\n }\n\n #arrow {\n position: relative;\n left: calc(50% + ${arrowOffset});\n top: 0;\n width: 0;\n height: 0;\n margin-top: calc(-1 * ${arrowSize});\n margin-left: calc(-1 * ${arrowSize});\n border: ${arrowSize} solid transparent;\n border-bottom-color: black;\n }\n\n #tooltip-text {\n padding: 3px 8px;\n border-radius: 4px;\n background-color: #000;\n color: white;\n font-size: 1.2rem;\n text-align: center;\n text-decoration: none;\n }\n `;\n }\n}\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { LitElement, TemplateResult } from 'lit';
|
|
2
|
+
import type { PrefixFilterCounts } from '../models';
|
|
3
|
+
import './alpha-bar-tooltip';
|
|
4
|
+
export declare class AlphaBar extends LitElement {
|
|
5
|
+
selectedLetter: string | null;
|
|
6
|
+
letterCounts?: PrefixFilterCounts;
|
|
7
|
+
ariaLandmarkLabel?: string;
|
|
8
|
+
private tooltipShown;
|
|
9
|
+
private hoveredLetter?;
|
|
10
|
+
private tooltip?;
|
|
11
|
+
private readonly alphabet;
|
|
12
|
+
private get selectedUppercaseLetter();
|
|
13
|
+
render(): TemplateResult<1>;
|
|
14
|
+
private letterButtonTemplate;
|
|
15
|
+
private tooltipTemplate;
|
|
16
|
+
private letterClicked;
|
|
17
|
+
private handleMouseMove;
|
|
18
|
+
private handleMouseLeave;
|
|
19
|
+
private positionTooltip;
|
|
20
|
+
static styles: import("lit").CSSResult;
|
|
21
|
+
}
|