@internetarchive/collection-browser 2.7.12 → 2.7.13
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/.husky/pre-commit +4 -4
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +13 -13
- package/dist/index.js +13 -13
- package/dist/src/app-root.d.ts +107 -107
- package/dist/src/app-root.js +531 -531
- package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-left.js +2 -2
- package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-right.js +2 -2
- package/dist/src/assets/img/icons/chevron.d.ts +2 -2
- package/dist/src/assets/img/icons/chevron.js +2 -2
- package/dist/src/assets/img/icons/contract.d.ts +2 -2
- package/dist/src/assets/img/icons/contract.js +2 -2
- package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
- package/dist/src/assets/img/icons/empty-query.js +2 -2
- package/dist/src/assets/img/icons/expand.d.ts +2 -2
- package/dist/src/assets/img/icons/expand.js +2 -2
- package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
- package/dist/src/assets/img/icons/eye-closed.js +2 -2
- package/dist/src/assets/img/icons/eye.d.ts +2 -2
- package/dist/src/assets/img/icons/eye.js +2 -2
- package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
- package/dist/src/assets/img/icons/favorite-filled.js +2 -2
- package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -1
- package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
- package/dist/src/assets/img/icons/filter.d.ts +2 -2
- package/dist/src/assets/img/icons/filter.js +2 -2
- package/dist/src/assets/img/icons/login-required.d.ts +1 -1
- package/dist/src/assets/img/icons/login-required.js +2 -2
- package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/account.js +2 -2
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
- package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/data.js +2 -2
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/film.js +2 -2
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/images.js +2 -2
- package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/search.js +2 -2
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/software.js +2 -2
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/video.js +2 -2
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/web.js +2 -2
- package/dist/src/assets/img/icons/null-result.d.ts +2 -2
- package/dist/src/assets/img/icons/null-result.js +2 -2
- package/dist/src/assets/img/icons/restricted.d.ts +1 -1
- package/dist/src/assets/img/icons/restricted.js +2 -2
- package/dist/src/assets/img/icons/reviews.d.ts +1 -1
- package/dist/src/assets/img/icons/reviews.js +2 -2
- package/dist/src/assets/img/icons/upload.d.ts +1 -1
- package/dist/src/assets/img/icons/upload.js +2 -2
- package/dist/src/assets/img/icons/views.d.ts +1 -1
- package/dist/src/assets/img/icons/views.js +2 -2
- package/dist/src/circular-activity-indicator.d.ts +5 -5
- package/dist/src/circular-activity-indicator.js +17 -17
- package/dist/src/collection-browser.d.ts +606 -606
- package/dist/src/collection-browser.js +1677 -1677
- package/dist/src/collection-facets/facet-row.d.ts +30 -30
- package/dist/src/collection-facets/facet-row.js +118 -118
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
- package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
- package/dist/src/collection-facets/facets-template.d.ts +13 -13
- package/dist/src/collection-facets/facets-template.js +44 -44
- package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
- package/dist/src/collection-facets/more-facets-content.js +407 -407
- package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
- package/dist/src/collection-facets/more-facets-pagination.js +196 -196
- package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -10
- package/dist/src/collection-facets/smart-facets/dedupe.js +33 -33
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.js +23 -23
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js +44 -44
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js +172 -172
- package/dist/src/collection-facets/smart-facets/models.d.ts +26 -26
- package/dist/src/collection-facets/smart-facets/models.js +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +31 -31
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +240 -240
- package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -11
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js +86 -86
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +16 -16
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +100 -100
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -2
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +12 -12
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +15 -15
- package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
- package/dist/src/collection-facets/toggle-switch.js +94 -94
- package/dist/src/collection-facets.d.ts +103 -103
- package/dist/src/collection-facets.js +522 -522
- package/dist/src/data-source/collection-browser-data-source-interface.d.ts +245 -245
- package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
- package/dist/src/data-source/collection-browser-data-source.d.ts +377 -377
- package/dist/src/data-source/collection-browser-data-source.js +1004 -1001
- package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
- package/dist/src/data-source/collection-browser-query-state.d.ts +44 -44
- package/dist/src/data-source/collection-browser-query-state.js +1 -1
- package/dist/src/data-source/models.d.ts +28 -28
- package/dist/src/data-source/models.js +8 -8
- package/dist/src/empty-placeholder.d.ts +23 -23
- package/dist/src/empty-placeholder.js +79 -79
- package/dist/src/expanded-date-picker.d.ts +43 -43
- package/dist/src/expanded-date-picker.js +109 -109
- package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
- package/dist/src/language-code-handler/language-code-handler.js +26 -26
- package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
- package/dist/src/language-code-handler/language-code-mapping.js +562 -562
- package/dist/src/manage/manage-bar.d.ts +58 -58
- package/dist/src/manage/manage-bar.js +159 -159
- package/dist/src/manage/remove-items-modal-content.d.ts +9 -9
- package/dist/src/manage/remove-items-modal-content.js +34 -34
- package/dist/src/mediatype/mediatype-config.d.ts +3 -3
- package/dist/src/mediatype/mediatype-config.js +91 -91
- package/dist/src/models.d.ts +228 -228
- package/dist/src/models.js +401 -401
- package/dist/src/restoration-state-handler.d.ts +70 -70
- package/dist/src/restoration-state-handler.js +363 -363
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
- package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
- package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/compact.js +2 -2
- package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/list.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
- package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/tile.js +2 -2
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
- package/dist/src/sort-filter-bar/sort-filter-bar.js +697 -697
- package/dist/src/styles/ia-button.d.ts +2 -2
- package/dist/src/styles/ia-button.js +17 -17
- package/dist/src/styles/item-image-styles.d.ts +8 -8
- package/dist/src/styles/item-image-styles.js +9 -9
- package/dist/src/styles/sr-only.d.ts +1 -1
- package/dist/src/styles/sr-only.js +2 -2
- package/dist/src/tiles/base-tile-component.d.ts +19 -19
- package/dist/src/tiles/base-tile-component.js +64 -64
- package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
- package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
- package/dist/src/tiles/grid/account-tile.d.ts +18 -18
- package/dist/src/tiles/grid/account-tile.js +72 -72
- package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
- package/dist/src/tiles/grid/collection-tile.js +80 -80
- package/dist/src/tiles/grid/item-tile.d.ts +34 -34
- package/dist/src/tiles/grid/item-tile.js +158 -158
- package/dist/src/tiles/grid/search-tile.d.ts +10 -10
- package/dist/src/tiles/grid/search-tile.js +51 -51
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
- package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
- package/dist/src/tiles/grid/tile-stats.js +53 -53
- package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
- package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
- package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
- package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
- package/dist/src/tiles/image-block.d.ts +18 -18
- package/dist/src/tiles/image-block.js +89 -89
- package/dist/src/tiles/item-image.d.ts +39 -39
- package/dist/src/tiles/item-image.js +154 -154
- package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
- package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
- package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
- package/dist/src/tiles/list/tile-list-compact.js +122 -122
- package/dist/src/tiles/list/tile-list.d.ts +54 -54
- package/dist/src/tiles/list/tile-list.js +323 -323
- package/dist/src/tiles/mediatype-icon.d.ts +9 -9
- package/dist/src/tiles/mediatype-icon.js +47 -47
- package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
- package/dist/src/tiles/overlay/icon-overlay.js +25 -25
- package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
- package/dist/src/tiles/overlay/text-overlay.js +31 -31
- package/dist/src/tiles/review-block.d.ts +12 -12
- package/dist/src/tiles/review-block.js +56 -56
- package/dist/src/tiles/text-snippet-block.d.ts +27 -27
- package/dist/src/tiles/text-snippet-block.js +73 -73
- package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
- package/dist/src/tiles/tile-dispatcher.js +230 -230
- package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
- package/dist/src/tiles/tile-display-value-provider.js +94 -94
- package/dist/src/utils/analytics-events.d.ts +28 -28
- package/dist/src/utils/analytics-events.js +30 -30
- package/dist/src/utils/array-equals.d.ts +4 -4
- package/dist/src/utils/array-equals.js +10 -10
- package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
- package/dist/src/utils/collapse-repeated-quotes.js +13 -13
- package/dist/src/utils/facet-utils.d.ts +83 -83
- package/dist/src/utils/facet-utils.js +145 -145
- package/dist/src/utils/format-count.d.ts +7 -7
- package/dist/src/utils/format-count.js +76 -76
- package/dist/src/utils/format-date.d.ts +2 -2
- package/dist/src/utils/format-date.js +27 -27
- package/dist/src/utils/format-unit-size.d.ts +2 -2
- package/dist/src/utils/format-unit-size.js +33 -33
- package/dist/src/utils/local-date-from-utc.d.ts +9 -9
- package/dist/src/utils/local-date-from-utc.js +15 -15
- package/dist/src/utils/log.d.ts +7 -7
- package/dist/src/utils/log.js +15 -15
- package/dist/src/utils/resolve-mediatype.d.ts +8 -8
- package/dist/src/utils/resolve-mediatype.js +23 -23
- package/dist/src/utils/sha1.d.ts +2 -2
- package/dist/src/utils/sha1.js +8 -8
- package/dist/test/collection-browser.test.d.ts +1 -1
- package/dist/test/collection-browser.test.js +1308 -1308
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
- package/dist/test/collection-facets/facet-row.test.js +227 -227
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +91 -91
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +141 -141
- package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
- package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
- package/dist/test/collection-facets/toggle-switch.test.js +73 -73
- package/dist/test/collection-facets.test.d.ts +2 -2
- package/dist/test/collection-facets.test.js +690 -690
- package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
- package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
- package/dist/test/empty-placeholder.test.d.ts +1 -1
- package/dist/test/empty-placeholder.test.js +63 -63
- package/dist/test/expanded-date-picker.test.d.ts +1 -1
- package/dist/test/expanded-date-picker.test.js +95 -95
- package/dist/test/icon-overlay.test.d.ts +1 -1
- package/dist/test/icon-overlay.test.js +24 -24
- package/dist/test/image-block.test.d.ts +1 -1
- package/dist/test/image-block.test.js +107 -107
- package/dist/test/item-image.test.d.ts +1 -1
- package/dist/test/item-image.test.js +85 -85
- package/dist/test/manage/manage-bar.test.d.ts +2 -2
- package/dist/test/manage/manage-bar.test.js +100 -100
- package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -1
- package/dist/test/manage/remove-items-modal-content.test.js +45 -45
- package/dist/test/mediatype-config.test.d.ts +1 -1
- package/dist/test/mediatype-config.test.js +16 -16
- package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
- package/dist/test/mocks/mock-analytics-handler.js +15 -15
- package/dist/test/mocks/mock-search-responses.d.ts +25 -25
- package/dist/test/mocks/mock-search-responses.js +942 -942
- package/dist/test/mocks/mock-search-service.d.ts +15 -15
- package/dist/test/mocks/mock-search-service.js +54 -54
- package/dist/test/restoration-state-handler.test.d.ts +1 -1
- package/dist/test/restoration-state-handler.test.js +270 -270
- package/dist/test/review-block.test.d.ts +1 -1
- package/dist/test/review-block.test.js +44 -44
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
- package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
- package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
- package/dist/test/text-overlay.test.d.ts +1 -1
- package/dist/test/text-overlay.test.js +38 -38
- package/dist/test/text-snippet-block.test.d.ts +1 -1
- package/dist/test/text-snippet-block.test.js +57 -57
- package/dist/test/tile-stats.test.d.ts +1 -1
- package/dist/test/tile-stats.test.js +81 -81
- package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/account-tile.test.js +76 -76
- package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/collection-tile.test.js +73 -73
- package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/item-tile.test.js +312 -312
- package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/search-tile.test.js +51 -51
- package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
- package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
- package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
- package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
- package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list.test.js +297 -297
- package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
- package/dist/test/tiles/tile-dispatcher.test.js +100 -100
- package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
- package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
- package/dist/test/utils/array-equals.test.d.ts +1 -1
- package/dist/test/utils/array-equals.test.js +26 -26
- package/dist/test/utils/format-count.test.d.ts +1 -1
- package/dist/test/utils/format-count.test.js +23 -23
- package/dist/test/utils/format-date.test.d.ts +1 -1
- package/dist/test/utils/format-date.test.js +30 -30
- package/dist/test/utils/format-unit-size.test.d.ts +1 -1
- package/dist/test/utils/format-unit-size.test.js +17 -17
- package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
- package/dist/test/utils/local-date-from-utc.test.js +26 -26
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +1 -1
- package/renovate.json +6 -6
- package/src/data-source/collection-browser-data-source.ts +5 -1
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
package/dist/src/models.js
CHANGED
|
@@ -1,402 +1,402 @@
|
|
|
1
|
-
import { msg } from '@lit/localize';
|
|
2
|
-
import { AggregationSortType, } from '@internetarchive/search-service';
|
|
3
|
-
import { collapseRepeatedQuotes } from './utils/collapse-repeated-quotes';
|
|
4
|
-
import { resolveMediatype } from './utils/resolve-mediatype';
|
|
5
|
-
import { loginRequiredIcon } from './assets/img/icons/login-required';
|
|
6
|
-
import { restrictedIcon } from './assets/img/icons/restricted';
|
|
7
|
-
export const TILE_OVERLAY_TEXT = {
|
|
8
|
-
'login-required': msg('Log in to view this item'),
|
|
9
|
-
'content-warning': msg('Content may be inappropriate'),
|
|
10
|
-
};
|
|
11
|
-
export const TILE_OVERLAY_ICONS = {
|
|
12
|
-
'login-required': loginRequiredIcon,
|
|
13
|
-
'content-warning': restrictedIcon,
|
|
14
|
-
};
|
|
15
|
-
/**
|
|
16
|
-
* Class for converting & storing raw search results in the correct format for UI tiles.
|
|
17
|
-
*/
|
|
18
|
-
export class TileModel {
|
|
19
|
-
constructor(result) {
|
|
20
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11;
|
|
21
|
-
const flags = this.getFlags(result);
|
|
22
|
-
this.averageRating = (_a = result.avg_rating) === null || _a === void 0 ? void 0 : _a.value;
|
|
23
|
-
this.captureDates = (_b = result.capture_dates) === null || _b === void 0 ? void 0 : _b.values;
|
|
24
|
-
this.checked = false;
|
|
25
|
-
this.collections = (_d = (_c = result.collection) === null || _c === void 0 ? void 0 : _c.values) !== null && _d !== void 0 ? _d : [];
|
|
26
|
-
this.collectionFilesCount = (_f = (_e = result.collection_files_count) === null || _e === void 0 ? void 0 : _e.value) !== null && _f !== void 0 ? _f : 0;
|
|
27
|
-
this.collectionSize = (_h = (_g = result.collection_size) === null || _g === void 0 ? void 0 : _g.value) !== null && _h !== void 0 ? _h : 0;
|
|
28
|
-
this.commentCount = (_k = (_j = result.num_reviews) === null || _j === void 0 ? void 0 : _j.value) !== null && _k !== void 0 ? _k : 0;
|
|
29
|
-
this.creator = (_l = result.creator) === null || _l === void 0 ? void 0 : _l.value;
|
|
30
|
-
this.creators = (_o = (_m = result.creator) === null || _m === void 0 ? void 0 : _m.values) !== null && _o !== void 0 ? _o : [];
|
|
31
|
-
this.dateAdded = (_p = result.addeddate) === null || _p === void 0 ? void 0 : _p.value;
|
|
32
|
-
this.dateArchived = (_q = result.publicdate) === null || _q === void 0 ? void 0 : _q.value;
|
|
33
|
-
this.datePublished = (_r = result.date) === null || _r === void 0 ? void 0 : _r.value;
|
|
34
|
-
this.dateReviewed = (_s = result.reviewdate) === null || _s === void 0 ? void 0 : _s.value;
|
|
35
|
-
this.description = (_t = result.description) === null || _t === void 0 ? void 0 : _t.values.join('\n');
|
|
36
|
-
this.favCount = (_v = (_u = result.num_favorites) === null || _u === void 0 ? void 0 : _u.value) !== null && _v !== void 0 ? _v : 0;
|
|
37
|
-
this.href = collapseRepeatedQuotes((_x = (_w = result.review) === null || _w === void 0 ? void 0 : _w.__href__) !== null && _x !== void 0 ? _x : (_y = result.__href__) === null || _y === void 0 ? void 0 : _y.value);
|
|
38
|
-
this.identifier = TileModel.cleanIdentifier(result.identifier);
|
|
39
|
-
this.issue = (_z = result.issue) === null || _z === void 0 ? void 0 : _z.value;
|
|
40
|
-
this.itemCount = (_1 = (_0 = result.item_count) === null || _0 === void 0 ? void 0 : _0.value) !== null && _1 !== void 0 ? _1 : 0;
|
|
41
|
-
this.mediatype = resolveMediatype(result);
|
|
42
|
-
this.review = result.review;
|
|
43
|
-
this.snippets = (_3 = (_2 = result.highlight) === null || _2 === void 0 ? void 0 : _2.values) !== null && _3 !== void 0 ? _3 : [];
|
|
44
|
-
this.source = (_4 = result.source) === null || _4 === void 0 ? void 0 : _4.value;
|
|
45
|
-
this.subjects = (_6 = (_5 = result.subject) === null || _5 === void 0 ? void 0 : _5.values) !== null && _6 !== void 0 ? _6 : [];
|
|
46
|
-
this.title = (_8 = (_7 = result.title) === null || _7 === void 0 ? void 0 : _7.value) !== null && _8 !== void 0 ? _8 : '';
|
|
47
|
-
this.volume = (_9 = result.volume) === null || _9 === void 0 ? void 0 : _9.value;
|
|
48
|
-
this.viewCount = (_10 = result.downloads) === null || _10 === void 0 ? void 0 : _10.value;
|
|
49
|
-
this.weeklyViewCount = (_11 = result.week) === null || _11 === void 0 ? void 0 : _11.value;
|
|
50
|
-
this.loginRequired = flags.loginRequired;
|
|
51
|
-
this.contentWarning = flags.contentWarning;
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* Copies the contents of this TileModel onto a new instance
|
|
55
|
-
*/
|
|
56
|
-
clone() {
|
|
57
|
-
const cloned = new TileModel({});
|
|
58
|
-
cloned.averageRating = this.averageRating;
|
|
59
|
-
cloned.captureDates = this.captureDates;
|
|
60
|
-
cloned.checked = this.checked;
|
|
61
|
-
cloned.collections = this.collections;
|
|
62
|
-
cloned.collectionFilesCount = this.collectionFilesCount;
|
|
63
|
-
cloned.collectionSize = this.collectionSize;
|
|
64
|
-
cloned.commentCount = this.commentCount;
|
|
65
|
-
cloned.creator = this.creator;
|
|
66
|
-
cloned.creators = this.creators;
|
|
67
|
-
cloned.dateStr = this.dateStr;
|
|
68
|
-
cloned.dateAdded = this.dateAdded;
|
|
69
|
-
cloned.dateArchived = this.dateArchived;
|
|
70
|
-
cloned.datePublished = this.datePublished;
|
|
71
|
-
cloned.dateReviewed = this.dateReviewed;
|
|
72
|
-
cloned.description = this.description;
|
|
73
|
-
cloned.favCount = this.favCount;
|
|
74
|
-
cloned.href = this.href;
|
|
75
|
-
cloned.identifier = this.identifier;
|
|
76
|
-
cloned.issue = this.issue;
|
|
77
|
-
cloned.itemCount = this.itemCount;
|
|
78
|
-
cloned.mediatype = this.mediatype;
|
|
79
|
-
cloned.snippets = this.snippets;
|
|
80
|
-
cloned.source = this.source;
|
|
81
|
-
cloned.subjects = this.subjects;
|
|
82
|
-
cloned.title = this.title;
|
|
83
|
-
cloned.volume = this.volume;
|
|
84
|
-
cloned.viewCount = this.viewCount;
|
|
85
|
-
cloned.weeklyViewCount = this.weeklyViewCount;
|
|
86
|
-
cloned.loginRequired = this.loginRequired;
|
|
87
|
-
cloned.contentWarning = this.contentWarning;
|
|
88
|
-
return cloned;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Determines the appropriate tile flags for the given search result
|
|
92
|
-
* (login required and/or content warning)
|
|
93
|
-
*/
|
|
94
|
-
getFlags(result) {
|
|
95
|
-
var _a, _b, _c, _d;
|
|
96
|
-
const flags = {
|
|
97
|
-
loginRequired: false,
|
|
98
|
-
contentWarning: false,
|
|
99
|
-
};
|
|
100
|
-
// Check if item and item in "modifying" collection, setting above flags
|
|
101
|
-
if (((_a = result.collection) === null || _a === void 0 ? void 0 : _a.values.length) &&
|
|
102
|
-
((_b = result.mediatype) === null || _b === void 0 ? void 0 : _b.value) !== 'collection') {
|
|
103
|
-
for (const collection of (_d = (_c = result.collection) === null || _c === void 0 ? void 0 : _c.values) !== null && _d !== void 0 ? _d : []) {
|
|
104
|
-
if (collection === 'loggedin') {
|
|
105
|
-
flags.loginRequired = true;
|
|
106
|
-
if (flags.contentWarning)
|
|
107
|
-
break;
|
|
108
|
-
}
|
|
109
|
-
if (collection === 'no-preview') {
|
|
110
|
-
flags.contentWarning = true;
|
|
111
|
-
if (flags.loginRequired)
|
|
112
|
-
break;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
return flags;
|
|
117
|
-
}
|
|
118
|
-
static cleanIdentifier(identifier) {
|
|
119
|
-
var _a;
|
|
120
|
-
// Some identifiers (e.g., from Whisper) represent documents rather than items, and
|
|
121
|
-
// are suffixed with values that need to be stripped. Those values are separated
|
|
122
|
-
// from the item identifier itself with '|'.
|
|
123
|
-
const barIndex = (_a = identifier === null || identifier === void 0 ? void 0 : identifier.indexOf('|')) !== null && _a !== void 0 ? _a : -1;
|
|
124
|
-
const cleaned = barIndex > 0 ? identifier === null || identifier === void 0 ? void 0 : identifier.slice(0, barIndex) : identifier;
|
|
125
|
-
return cleaned;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* The sort fields shown in the sort filter bar
|
|
130
|
-
*/
|
|
131
|
-
export var SortField;
|
|
132
|
-
(function (SortField) {
|
|
133
|
-
SortField["default"] = "default";
|
|
134
|
-
SortField["unrecognized"] = "unrecognized";
|
|
135
|
-
SortField["relevance"] = "relevance";
|
|
136
|
-
SortField["alltimeview"] = "alltimeview";
|
|
137
|
-
SortField["weeklyview"] = "weeklyview";
|
|
138
|
-
SortField["title"] = "title";
|
|
139
|
-
SortField["date"] = "date";
|
|
140
|
-
SortField["datearchived"] = "datearchived";
|
|
141
|
-
SortField["datereviewed"] = "datereviewed";
|
|
142
|
-
SortField["dateadded"] = "dateadded";
|
|
143
|
-
SortField["datefavorited"] = "datefavorited";
|
|
144
|
-
SortField["creator"] = "creator";
|
|
145
|
-
})(SortField || (SortField = {}));
|
|
146
|
-
export const SORT_OPTIONS = {
|
|
147
|
-
// Default sort is the case where the user has not specified a sort option via the sort bar or URL.
|
|
148
|
-
// In these cases, we defer to whatever sort the backend chooses.
|
|
149
|
-
// For the search page, the default is always relevance sort.
|
|
150
|
-
// For collection pages _without a query_, the default is usually weekly views, but this can be
|
|
151
|
-
// overridden by the collection's `sort-by` metadata entry. If a query _is_ specified, then the
|
|
152
|
-
// default is again relevance sort.
|
|
153
|
-
// For fav-* collections only, the default is instead sorting by date favorited.
|
|
154
|
-
[SortField.default]: {
|
|
155
|
-
field: SortField.default,
|
|
156
|
-
defaultSortDirection: null,
|
|
157
|
-
canSetDirection: false,
|
|
158
|
-
shownInSortBar: false,
|
|
159
|
-
shownInURL: false,
|
|
160
|
-
handledBySearchService: false,
|
|
161
|
-
displayName: '',
|
|
162
|
-
urlNames: ['', null, undefined], // Empty or nullish sort params result in default sorting
|
|
163
|
-
},
|
|
164
|
-
// Unrecognized sort is the case where the user has specified a sort in the URL, but it is not
|
|
165
|
-
// one of the options listed in this map. We still want these unrecognized sorts to be applied
|
|
166
|
-
// when searching, but they are not displayed in the sort bar and we do not actively manage
|
|
167
|
-
// their URL param beyond flipping the direction as needed.
|
|
168
|
-
[SortField.unrecognized]: {
|
|
169
|
-
field: SortField.unrecognized,
|
|
170
|
-
defaultSortDirection: null,
|
|
171
|
-
canSetDirection: true,
|
|
172
|
-
shownInSortBar: false,
|
|
173
|
-
shownInURL: false,
|
|
174
|
-
handledBySearchService: true,
|
|
175
|
-
displayName: '',
|
|
176
|
-
urlNames: [],
|
|
177
|
-
},
|
|
178
|
-
// Relevance sort is unique in that it does not produce a URL param when it is set.
|
|
179
|
-
// It is only available when there is a user-specified query that relevancy can be scored against.
|
|
180
|
-
// Therefore, it does not appear as a sort bar option when browsing a collection with no query set.
|
|
181
|
-
[SortField.relevance]: {
|
|
182
|
-
field: SortField.relevance,
|
|
183
|
-
defaultSortDirection: null,
|
|
184
|
-
canSetDirection: false,
|
|
185
|
-
shownInSortBar: true,
|
|
186
|
-
shownInURL: false,
|
|
187
|
-
handledBySearchService: false,
|
|
188
|
-
displayName: 'Relevance',
|
|
189
|
-
urlNames: ['_score'],
|
|
190
|
-
},
|
|
191
|
-
[SortField.alltimeview]: {
|
|
192
|
-
field: SortField.alltimeview,
|
|
193
|
-
defaultSortDirection: 'desc',
|
|
194
|
-
canSetDirection: true,
|
|
195
|
-
shownInSortBar: true,
|
|
196
|
-
shownInURL: true,
|
|
197
|
-
handledBySearchService: true,
|
|
198
|
-
searchServiceKey: 'downloads',
|
|
199
|
-
displayName: 'All-time views',
|
|
200
|
-
urlNames: ['downloads'],
|
|
201
|
-
},
|
|
202
|
-
[SortField.weeklyview]: {
|
|
203
|
-
field: SortField.weeklyview,
|
|
204
|
-
defaultSortDirection: 'desc',
|
|
205
|
-
canSetDirection: true,
|
|
206
|
-
shownInSortBar: true,
|
|
207
|
-
shownInURL: true,
|
|
208
|
-
handledBySearchService: true,
|
|
209
|
-
searchServiceKey: 'week',
|
|
210
|
-
displayName: 'Weekly views',
|
|
211
|
-
urlNames: ['week'],
|
|
212
|
-
},
|
|
213
|
-
[SortField.title]: {
|
|
214
|
-
field: SortField.title,
|
|
215
|
-
defaultSortDirection: 'asc',
|
|
216
|
-
canSetDirection: true,
|
|
217
|
-
shownInSortBar: true,
|
|
218
|
-
shownInURL: true,
|
|
219
|
-
handledBySearchService: true,
|
|
220
|
-
searchServiceKey: 'titleSorter',
|
|
221
|
-
displayName: 'Title',
|
|
222
|
-
urlNames: ['title', 'titleSorter'],
|
|
223
|
-
},
|
|
224
|
-
[SortField.date]: {
|
|
225
|
-
field: SortField.date,
|
|
226
|
-
defaultSortDirection: 'desc',
|
|
227
|
-
canSetDirection: true,
|
|
228
|
-
shownInSortBar: true,
|
|
229
|
-
shownInURL: true,
|
|
230
|
-
handledBySearchService: true,
|
|
231
|
-
searchServiceKey: 'date',
|
|
232
|
-
displayName: 'Date published',
|
|
233
|
-
urlNames: ['date'],
|
|
234
|
-
},
|
|
235
|
-
[SortField.datearchived]: {
|
|
236
|
-
field: SortField.datearchived,
|
|
237
|
-
defaultSortDirection: 'desc',
|
|
238
|
-
canSetDirection: true,
|
|
239
|
-
shownInSortBar: true,
|
|
240
|
-
shownInURL: true,
|
|
241
|
-
handledBySearchService: true,
|
|
242
|
-
searchServiceKey: 'publicdate',
|
|
243
|
-
displayName: 'Date archived',
|
|
244
|
-
urlNames: ['publicdate'],
|
|
245
|
-
},
|
|
246
|
-
[SortField.datereviewed]: {
|
|
247
|
-
field: SortField.datereviewed,
|
|
248
|
-
defaultSortDirection: 'desc',
|
|
249
|
-
canSetDirection: true,
|
|
250
|
-
shownInSortBar: true,
|
|
251
|
-
shownInURL: true,
|
|
252
|
-
handledBySearchService: true,
|
|
253
|
-
searchServiceKey: 'reviewdate',
|
|
254
|
-
displayName: 'Date reviewed',
|
|
255
|
-
urlNames: ['reviewdate'],
|
|
256
|
-
},
|
|
257
|
-
[SortField.dateadded]: {
|
|
258
|
-
field: SortField.dateadded,
|
|
259
|
-
defaultSortDirection: 'desc',
|
|
260
|
-
canSetDirection: true,
|
|
261
|
-
shownInSortBar: true,
|
|
262
|
-
shownInURL: true,
|
|
263
|
-
handledBySearchService: true,
|
|
264
|
-
searchServiceKey: 'addeddate',
|
|
265
|
-
displayName: 'Date added',
|
|
266
|
-
urlNames: ['addeddate'],
|
|
267
|
-
},
|
|
268
|
-
[SortField.datefavorited]: {
|
|
269
|
-
field: SortField.datefavorited,
|
|
270
|
-
defaultSortDirection: 'desc',
|
|
271
|
-
canSetDirection: false,
|
|
272
|
-
shownInSortBar: true,
|
|
273
|
-
shownInURL: false,
|
|
274
|
-
handledBySearchService: false,
|
|
275
|
-
searchServiceKey: 'favoritedate',
|
|
276
|
-
displayName: 'Date favorited',
|
|
277
|
-
urlNames: ['favoritedate'],
|
|
278
|
-
},
|
|
279
|
-
[SortField.creator]: {
|
|
280
|
-
field: SortField.creator,
|
|
281
|
-
defaultSortDirection: 'asc',
|
|
282
|
-
canSetDirection: true,
|
|
283
|
-
shownInSortBar: true,
|
|
284
|
-
shownInURL: true,
|
|
285
|
-
handledBySearchService: true,
|
|
286
|
-
searchServiceKey: 'creatorSorter',
|
|
287
|
-
displayName: 'Creator',
|
|
288
|
-
urlNames: ['creator', 'creatorSorter'],
|
|
289
|
-
},
|
|
290
|
-
};
|
|
291
|
-
/**
|
|
292
|
-
* Returns the SortOption corresponding to the given API sort name, or
|
|
293
|
-
* the "unrecognized" SortOption if none matches.
|
|
294
|
-
*/
|
|
295
|
-
export function sortOptionFromAPIString(sortName) {
|
|
296
|
-
var _a;
|
|
297
|
-
return ((_a = Object.values(SORT_OPTIONS).find(opt => opt.urlNames.some(name => sortName === name))) !== null && _a !== void 0 ? _a : SORT_OPTIONS[SortField.unrecognized]);
|
|
298
|
-
}
|
|
299
|
-
export const defaultProfileElementSorts = {
|
|
300
|
-
uploads: SortField.datearchived,
|
|
301
|
-
reviews: SortField.datereviewed,
|
|
302
|
-
collections: SortField.datearchived,
|
|
303
|
-
web_archives: SortField.datearchived,
|
|
304
|
-
};
|
|
305
|
-
/**
|
|
306
|
-
* A map from prefix filter types to the corresponding aggregation keys
|
|
307
|
-
* that are needed to fetch the filter counts from the backend.
|
|
308
|
-
*/
|
|
309
|
-
export const prefixFilterAggregationKeys = {
|
|
310
|
-
title: 'firstTitle',
|
|
311
|
-
creator: 'firstCreator',
|
|
312
|
-
};
|
|
313
|
-
export const getDefaultSelectedFacets = () => ({
|
|
314
|
-
subject: {},
|
|
315
|
-
lending: {},
|
|
316
|
-
mediatype: {},
|
|
317
|
-
language: {},
|
|
318
|
-
creator: {},
|
|
319
|
-
collection: {},
|
|
320
|
-
year: {},
|
|
321
|
-
});
|
|
322
|
-
export const facetDisplayOrder = [
|
|
323
|
-
'mediatype',
|
|
324
|
-
// 'lending', Commenting this out removes the lending facet from the sidebar for now
|
|
325
|
-
'year',
|
|
326
|
-
'subject',
|
|
327
|
-
'collection',
|
|
328
|
-
'creator',
|
|
329
|
-
'language',
|
|
330
|
-
];
|
|
331
|
-
export const facetTitles = {
|
|
332
|
-
subject: 'Subject',
|
|
333
|
-
lending: 'Availability',
|
|
334
|
-
mediatype: 'Media Type',
|
|
335
|
-
language: 'Language',
|
|
336
|
-
creator: 'Creator',
|
|
337
|
-
collection: 'Collection',
|
|
338
|
-
year: 'Year',
|
|
339
|
-
};
|
|
340
|
-
/**
|
|
341
|
-
* The default sort type to use for each facet type
|
|
342
|
-
*/
|
|
343
|
-
export const defaultFacetSort = {
|
|
344
|
-
subject: AggregationSortType.COUNT,
|
|
345
|
-
lending: AggregationSortType.COUNT,
|
|
346
|
-
mediatype: AggregationSortType.COUNT,
|
|
347
|
-
language: AggregationSortType.COUNT,
|
|
348
|
-
creator: AggregationSortType.COUNT,
|
|
349
|
-
collection: AggregationSortType.COUNT,
|
|
350
|
-
year: AggregationSortType.NUMERIC,
|
|
351
|
-
};
|
|
352
|
-
/**
|
|
353
|
-
* The sort type corresponding to facet bucket values, for each facet type
|
|
354
|
-
* (i.e., the opposite of "sort by count" for that type).
|
|
355
|
-
*/
|
|
356
|
-
export const valueFacetSort = {
|
|
357
|
-
subject: AggregationSortType.ALPHABETICAL,
|
|
358
|
-
lending: AggregationSortType.ALPHABETICAL,
|
|
359
|
-
mediatype: AggregationSortType.ALPHABETICAL,
|
|
360
|
-
language: AggregationSortType.ALPHABETICAL,
|
|
361
|
-
creator: AggregationSortType.ALPHABETICAL,
|
|
362
|
-
collection: AggregationSortType.ALPHABETICAL,
|
|
363
|
-
year: AggregationSortType.NUMERIC,
|
|
364
|
-
};
|
|
365
|
-
/**
|
|
366
|
-
* Maps valid lending keys to whether they should be visible in the facet sidebar
|
|
367
|
-
*/
|
|
368
|
-
export const lendingFacetKeysVisibility = {
|
|
369
|
-
is_lendable: true,
|
|
370
|
-
is_borrowable: false,
|
|
371
|
-
available_to_borrow: true,
|
|
372
|
-
is_browsable: false,
|
|
373
|
-
available_to_browse: false,
|
|
374
|
-
is_readable: true,
|
|
375
|
-
available_to_waitlist: false,
|
|
376
|
-
};
|
|
377
|
-
/**
|
|
378
|
-
* Maps valid, visible lending keys to their facet sidebar display text
|
|
379
|
-
*/
|
|
380
|
-
export const lendingFacetDisplayNames = {
|
|
381
|
-
is_lendable: 'Lending Library',
|
|
382
|
-
available_to_borrow: 'Borrow 14 Days',
|
|
383
|
-
is_readable: 'Always Available',
|
|
384
|
-
};
|
|
385
|
-
/**
|
|
386
|
-
* A record of which admin-only collections should be suppressed from being displayed
|
|
387
|
-
* as facets or in an item's list of collections.
|
|
388
|
-
*/
|
|
389
|
-
export const suppressedCollections = {
|
|
390
|
-
deemphasize: true,
|
|
391
|
-
community: true,
|
|
392
|
-
stream_only: true,
|
|
393
|
-
samples_only: true,
|
|
394
|
-
test_collection: true,
|
|
395
|
-
printdisabled: true,
|
|
396
|
-
'openlibrary-ol': true,
|
|
397
|
-
nationalemergencylibrary: true,
|
|
398
|
-
china: true,
|
|
399
|
-
americana: true,
|
|
400
|
-
toronto: true,
|
|
401
|
-
};
|
|
1
|
+
import { msg } from '@lit/localize';
|
|
2
|
+
import { AggregationSortType, } from '@internetarchive/search-service';
|
|
3
|
+
import { collapseRepeatedQuotes } from './utils/collapse-repeated-quotes';
|
|
4
|
+
import { resolveMediatype } from './utils/resolve-mediatype';
|
|
5
|
+
import { loginRequiredIcon } from './assets/img/icons/login-required';
|
|
6
|
+
import { restrictedIcon } from './assets/img/icons/restricted';
|
|
7
|
+
export const TILE_OVERLAY_TEXT = {
|
|
8
|
+
'login-required': msg('Log in to view this item'),
|
|
9
|
+
'content-warning': msg('Content may be inappropriate'),
|
|
10
|
+
};
|
|
11
|
+
export const TILE_OVERLAY_ICONS = {
|
|
12
|
+
'login-required': loginRequiredIcon,
|
|
13
|
+
'content-warning': restrictedIcon,
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Class for converting & storing raw search results in the correct format for UI tiles.
|
|
17
|
+
*/
|
|
18
|
+
export class TileModel {
|
|
19
|
+
constructor(result) {
|
|
20
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11;
|
|
21
|
+
const flags = this.getFlags(result);
|
|
22
|
+
this.averageRating = (_a = result.avg_rating) === null || _a === void 0 ? void 0 : _a.value;
|
|
23
|
+
this.captureDates = (_b = result.capture_dates) === null || _b === void 0 ? void 0 : _b.values;
|
|
24
|
+
this.checked = false;
|
|
25
|
+
this.collections = (_d = (_c = result.collection) === null || _c === void 0 ? void 0 : _c.values) !== null && _d !== void 0 ? _d : [];
|
|
26
|
+
this.collectionFilesCount = (_f = (_e = result.collection_files_count) === null || _e === void 0 ? void 0 : _e.value) !== null && _f !== void 0 ? _f : 0;
|
|
27
|
+
this.collectionSize = (_h = (_g = result.collection_size) === null || _g === void 0 ? void 0 : _g.value) !== null && _h !== void 0 ? _h : 0;
|
|
28
|
+
this.commentCount = (_k = (_j = result.num_reviews) === null || _j === void 0 ? void 0 : _j.value) !== null && _k !== void 0 ? _k : 0;
|
|
29
|
+
this.creator = (_l = result.creator) === null || _l === void 0 ? void 0 : _l.value;
|
|
30
|
+
this.creators = (_o = (_m = result.creator) === null || _m === void 0 ? void 0 : _m.values) !== null && _o !== void 0 ? _o : [];
|
|
31
|
+
this.dateAdded = (_p = result.addeddate) === null || _p === void 0 ? void 0 : _p.value;
|
|
32
|
+
this.dateArchived = (_q = result.publicdate) === null || _q === void 0 ? void 0 : _q.value;
|
|
33
|
+
this.datePublished = (_r = result.date) === null || _r === void 0 ? void 0 : _r.value;
|
|
34
|
+
this.dateReviewed = (_s = result.reviewdate) === null || _s === void 0 ? void 0 : _s.value;
|
|
35
|
+
this.description = (_t = result.description) === null || _t === void 0 ? void 0 : _t.values.join('\n');
|
|
36
|
+
this.favCount = (_v = (_u = result.num_favorites) === null || _u === void 0 ? void 0 : _u.value) !== null && _v !== void 0 ? _v : 0;
|
|
37
|
+
this.href = collapseRepeatedQuotes((_x = (_w = result.review) === null || _w === void 0 ? void 0 : _w.__href__) !== null && _x !== void 0 ? _x : (_y = result.__href__) === null || _y === void 0 ? void 0 : _y.value);
|
|
38
|
+
this.identifier = TileModel.cleanIdentifier(result.identifier);
|
|
39
|
+
this.issue = (_z = result.issue) === null || _z === void 0 ? void 0 : _z.value;
|
|
40
|
+
this.itemCount = (_1 = (_0 = result.item_count) === null || _0 === void 0 ? void 0 : _0.value) !== null && _1 !== void 0 ? _1 : 0;
|
|
41
|
+
this.mediatype = resolveMediatype(result);
|
|
42
|
+
this.review = result.review;
|
|
43
|
+
this.snippets = (_3 = (_2 = result.highlight) === null || _2 === void 0 ? void 0 : _2.values) !== null && _3 !== void 0 ? _3 : [];
|
|
44
|
+
this.source = (_4 = result.source) === null || _4 === void 0 ? void 0 : _4.value;
|
|
45
|
+
this.subjects = (_6 = (_5 = result.subject) === null || _5 === void 0 ? void 0 : _5.values) !== null && _6 !== void 0 ? _6 : [];
|
|
46
|
+
this.title = (_8 = (_7 = result.title) === null || _7 === void 0 ? void 0 : _7.value) !== null && _8 !== void 0 ? _8 : '';
|
|
47
|
+
this.volume = (_9 = result.volume) === null || _9 === void 0 ? void 0 : _9.value;
|
|
48
|
+
this.viewCount = (_10 = result.downloads) === null || _10 === void 0 ? void 0 : _10.value;
|
|
49
|
+
this.weeklyViewCount = (_11 = result.week) === null || _11 === void 0 ? void 0 : _11.value;
|
|
50
|
+
this.loginRequired = flags.loginRequired;
|
|
51
|
+
this.contentWarning = flags.contentWarning;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Copies the contents of this TileModel onto a new instance
|
|
55
|
+
*/
|
|
56
|
+
clone() {
|
|
57
|
+
const cloned = new TileModel({});
|
|
58
|
+
cloned.averageRating = this.averageRating;
|
|
59
|
+
cloned.captureDates = this.captureDates;
|
|
60
|
+
cloned.checked = this.checked;
|
|
61
|
+
cloned.collections = this.collections;
|
|
62
|
+
cloned.collectionFilesCount = this.collectionFilesCount;
|
|
63
|
+
cloned.collectionSize = this.collectionSize;
|
|
64
|
+
cloned.commentCount = this.commentCount;
|
|
65
|
+
cloned.creator = this.creator;
|
|
66
|
+
cloned.creators = this.creators;
|
|
67
|
+
cloned.dateStr = this.dateStr;
|
|
68
|
+
cloned.dateAdded = this.dateAdded;
|
|
69
|
+
cloned.dateArchived = this.dateArchived;
|
|
70
|
+
cloned.datePublished = this.datePublished;
|
|
71
|
+
cloned.dateReviewed = this.dateReviewed;
|
|
72
|
+
cloned.description = this.description;
|
|
73
|
+
cloned.favCount = this.favCount;
|
|
74
|
+
cloned.href = this.href;
|
|
75
|
+
cloned.identifier = this.identifier;
|
|
76
|
+
cloned.issue = this.issue;
|
|
77
|
+
cloned.itemCount = this.itemCount;
|
|
78
|
+
cloned.mediatype = this.mediatype;
|
|
79
|
+
cloned.snippets = this.snippets;
|
|
80
|
+
cloned.source = this.source;
|
|
81
|
+
cloned.subjects = this.subjects;
|
|
82
|
+
cloned.title = this.title;
|
|
83
|
+
cloned.volume = this.volume;
|
|
84
|
+
cloned.viewCount = this.viewCount;
|
|
85
|
+
cloned.weeklyViewCount = this.weeklyViewCount;
|
|
86
|
+
cloned.loginRequired = this.loginRequired;
|
|
87
|
+
cloned.contentWarning = this.contentWarning;
|
|
88
|
+
return cloned;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Determines the appropriate tile flags for the given search result
|
|
92
|
+
* (login required and/or content warning)
|
|
93
|
+
*/
|
|
94
|
+
getFlags(result) {
|
|
95
|
+
var _a, _b, _c, _d;
|
|
96
|
+
const flags = {
|
|
97
|
+
loginRequired: false,
|
|
98
|
+
contentWarning: false,
|
|
99
|
+
};
|
|
100
|
+
// Check if item and item in "modifying" collection, setting above flags
|
|
101
|
+
if (((_a = result.collection) === null || _a === void 0 ? void 0 : _a.values.length) &&
|
|
102
|
+
((_b = result.mediatype) === null || _b === void 0 ? void 0 : _b.value) !== 'collection') {
|
|
103
|
+
for (const collection of (_d = (_c = result.collection) === null || _c === void 0 ? void 0 : _c.values) !== null && _d !== void 0 ? _d : []) {
|
|
104
|
+
if (collection === 'loggedin') {
|
|
105
|
+
flags.loginRequired = true;
|
|
106
|
+
if (flags.contentWarning)
|
|
107
|
+
break;
|
|
108
|
+
}
|
|
109
|
+
if (collection === 'no-preview') {
|
|
110
|
+
flags.contentWarning = true;
|
|
111
|
+
if (flags.loginRequired)
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
return flags;
|
|
117
|
+
}
|
|
118
|
+
static cleanIdentifier(identifier) {
|
|
119
|
+
var _a;
|
|
120
|
+
// Some identifiers (e.g., from Whisper) represent documents rather than items, and
|
|
121
|
+
// are suffixed with values that need to be stripped. Those values are separated
|
|
122
|
+
// from the item identifier itself with '|'.
|
|
123
|
+
const barIndex = (_a = identifier === null || identifier === void 0 ? void 0 : identifier.indexOf('|')) !== null && _a !== void 0 ? _a : -1;
|
|
124
|
+
const cleaned = barIndex > 0 ? identifier === null || identifier === void 0 ? void 0 : identifier.slice(0, barIndex) : identifier;
|
|
125
|
+
return cleaned;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* The sort fields shown in the sort filter bar
|
|
130
|
+
*/
|
|
131
|
+
export var SortField;
|
|
132
|
+
(function (SortField) {
|
|
133
|
+
SortField["default"] = "default";
|
|
134
|
+
SortField["unrecognized"] = "unrecognized";
|
|
135
|
+
SortField["relevance"] = "relevance";
|
|
136
|
+
SortField["alltimeview"] = "alltimeview";
|
|
137
|
+
SortField["weeklyview"] = "weeklyview";
|
|
138
|
+
SortField["title"] = "title";
|
|
139
|
+
SortField["date"] = "date";
|
|
140
|
+
SortField["datearchived"] = "datearchived";
|
|
141
|
+
SortField["datereviewed"] = "datereviewed";
|
|
142
|
+
SortField["dateadded"] = "dateadded";
|
|
143
|
+
SortField["datefavorited"] = "datefavorited";
|
|
144
|
+
SortField["creator"] = "creator";
|
|
145
|
+
})(SortField || (SortField = {}));
|
|
146
|
+
export const SORT_OPTIONS = {
|
|
147
|
+
// Default sort is the case where the user has not specified a sort option via the sort bar or URL.
|
|
148
|
+
// In these cases, we defer to whatever sort the backend chooses.
|
|
149
|
+
// For the search page, the default is always relevance sort.
|
|
150
|
+
// For collection pages _without a query_, the default is usually weekly views, but this can be
|
|
151
|
+
// overridden by the collection's `sort-by` metadata entry. If a query _is_ specified, then the
|
|
152
|
+
// default is again relevance sort.
|
|
153
|
+
// For fav-* collections only, the default is instead sorting by date favorited.
|
|
154
|
+
[SortField.default]: {
|
|
155
|
+
field: SortField.default,
|
|
156
|
+
defaultSortDirection: null,
|
|
157
|
+
canSetDirection: false,
|
|
158
|
+
shownInSortBar: false,
|
|
159
|
+
shownInURL: false,
|
|
160
|
+
handledBySearchService: false,
|
|
161
|
+
displayName: '',
|
|
162
|
+
urlNames: ['', null, undefined], // Empty or nullish sort params result in default sorting
|
|
163
|
+
},
|
|
164
|
+
// Unrecognized sort is the case where the user has specified a sort in the URL, but it is not
|
|
165
|
+
// one of the options listed in this map. We still want these unrecognized sorts to be applied
|
|
166
|
+
// when searching, but they are not displayed in the sort bar and we do not actively manage
|
|
167
|
+
// their URL param beyond flipping the direction as needed.
|
|
168
|
+
[SortField.unrecognized]: {
|
|
169
|
+
field: SortField.unrecognized,
|
|
170
|
+
defaultSortDirection: null,
|
|
171
|
+
canSetDirection: true,
|
|
172
|
+
shownInSortBar: false,
|
|
173
|
+
shownInURL: false,
|
|
174
|
+
handledBySearchService: true,
|
|
175
|
+
displayName: '',
|
|
176
|
+
urlNames: [],
|
|
177
|
+
},
|
|
178
|
+
// Relevance sort is unique in that it does not produce a URL param when it is set.
|
|
179
|
+
// It is only available when there is a user-specified query that relevancy can be scored against.
|
|
180
|
+
// Therefore, it does not appear as a sort bar option when browsing a collection with no query set.
|
|
181
|
+
[SortField.relevance]: {
|
|
182
|
+
field: SortField.relevance,
|
|
183
|
+
defaultSortDirection: null,
|
|
184
|
+
canSetDirection: false,
|
|
185
|
+
shownInSortBar: true,
|
|
186
|
+
shownInURL: false,
|
|
187
|
+
handledBySearchService: false,
|
|
188
|
+
displayName: 'Relevance',
|
|
189
|
+
urlNames: ['_score'],
|
|
190
|
+
},
|
|
191
|
+
[SortField.alltimeview]: {
|
|
192
|
+
field: SortField.alltimeview,
|
|
193
|
+
defaultSortDirection: 'desc',
|
|
194
|
+
canSetDirection: true,
|
|
195
|
+
shownInSortBar: true,
|
|
196
|
+
shownInURL: true,
|
|
197
|
+
handledBySearchService: true,
|
|
198
|
+
searchServiceKey: 'downloads',
|
|
199
|
+
displayName: 'All-time views',
|
|
200
|
+
urlNames: ['downloads'],
|
|
201
|
+
},
|
|
202
|
+
[SortField.weeklyview]: {
|
|
203
|
+
field: SortField.weeklyview,
|
|
204
|
+
defaultSortDirection: 'desc',
|
|
205
|
+
canSetDirection: true,
|
|
206
|
+
shownInSortBar: true,
|
|
207
|
+
shownInURL: true,
|
|
208
|
+
handledBySearchService: true,
|
|
209
|
+
searchServiceKey: 'week',
|
|
210
|
+
displayName: 'Weekly views',
|
|
211
|
+
urlNames: ['week'],
|
|
212
|
+
},
|
|
213
|
+
[SortField.title]: {
|
|
214
|
+
field: SortField.title,
|
|
215
|
+
defaultSortDirection: 'asc',
|
|
216
|
+
canSetDirection: true,
|
|
217
|
+
shownInSortBar: true,
|
|
218
|
+
shownInURL: true,
|
|
219
|
+
handledBySearchService: true,
|
|
220
|
+
searchServiceKey: 'titleSorter',
|
|
221
|
+
displayName: 'Title',
|
|
222
|
+
urlNames: ['title', 'titleSorter'],
|
|
223
|
+
},
|
|
224
|
+
[SortField.date]: {
|
|
225
|
+
field: SortField.date,
|
|
226
|
+
defaultSortDirection: 'desc',
|
|
227
|
+
canSetDirection: true,
|
|
228
|
+
shownInSortBar: true,
|
|
229
|
+
shownInURL: true,
|
|
230
|
+
handledBySearchService: true,
|
|
231
|
+
searchServiceKey: 'date',
|
|
232
|
+
displayName: 'Date published',
|
|
233
|
+
urlNames: ['date'],
|
|
234
|
+
},
|
|
235
|
+
[SortField.datearchived]: {
|
|
236
|
+
field: SortField.datearchived,
|
|
237
|
+
defaultSortDirection: 'desc',
|
|
238
|
+
canSetDirection: true,
|
|
239
|
+
shownInSortBar: true,
|
|
240
|
+
shownInURL: true,
|
|
241
|
+
handledBySearchService: true,
|
|
242
|
+
searchServiceKey: 'publicdate',
|
|
243
|
+
displayName: 'Date archived',
|
|
244
|
+
urlNames: ['publicdate'],
|
|
245
|
+
},
|
|
246
|
+
[SortField.datereviewed]: {
|
|
247
|
+
field: SortField.datereviewed,
|
|
248
|
+
defaultSortDirection: 'desc',
|
|
249
|
+
canSetDirection: true,
|
|
250
|
+
shownInSortBar: true,
|
|
251
|
+
shownInURL: true,
|
|
252
|
+
handledBySearchService: true,
|
|
253
|
+
searchServiceKey: 'reviewdate',
|
|
254
|
+
displayName: 'Date reviewed',
|
|
255
|
+
urlNames: ['reviewdate'],
|
|
256
|
+
},
|
|
257
|
+
[SortField.dateadded]: {
|
|
258
|
+
field: SortField.dateadded,
|
|
259
|
+
defaultSortDirection: 'desc',
|
|
260
|
+
canSetDirection: true,
|
|
261
|
+
shownInSortBar: true,
|
|
262
|
+
shownInURL: true,
|
|
263
|
+
handledBySearchService: true,
|
|
264
|
+
searchServiceKey: 'addeddate',
|
|
265
|
+
displayName: 'Date added',
|
|
266
|
+
urlNames: ['addeddate'],
|
|
267
|
+
},
|
|
268
|
+
[SortField.datefavorited]: {
|
|
269
|
+
field: SortField.datefavorited,
|
|
270
|
+
defaultSortDirection: 'desc',
|
|
271
|
+
canSetDirection: false,
|
|
272
|
+
shownInSortBar: true,
|
|
273
|
+
shownInURL: false,
|
|
274
|
+
handledBySearchService: false,
|
|
275
|
+
searchServiceKey: 'favoritedate',
|
|
276
|
+
displayName: 'Date favorited',
|
|
277
|
+
urlNames: ['favoritedate'],
|
|
278
|
+
},
|
|
279
|
+
[SortField.creator]: {
|
|
280
|
+
field: SortField.creator,
|
|
281
|
+
defaultSortDirection: 'asc',
|
|
282
|
+
canSetDirection: true,
|
|
283
|
+
shownInSortBar: true,
|
|
284
|
+
shownInURL: true,
|
|
285
|
+
handledBySearchService: true,
|
|
286
|
+
searchServiceKey: 'creatorSorter',
|
|
287
|
+
displayName: 'Creator',
|
|
288
|
+
urlNames: ['creator', 'creatorSorter'],
|
|
289
|
+
},
|
|
290
|
+
};
|
|
291
|
+
/**
|
|
292
|
+
* Returns the SortOption corresponding to the given API sort name, or
|
|
293
|
+
* the "unrecognized" SortOption if none matches.
|
|
294
|
+
*/
|
|
295
|
+
export function sortOptionFromAPIString(sortName) {
|
|
296
|
+
var _a;
|
|
297
|
+
return ((_a = Object.values(SORT_OPTIONS).find(opt => opt.urlNames.some(name => sortName === name))) !== null && _a !== void 0 ? _a : SORT_OPTIONS[SortField.unrecognized]);
|
|
298
|
+
}
|
|
299
|
+
export const defaultProfileElementSorts = {
|
|
300
|
+
uploads: SortField.datearchived,
|
|
301
|
+
reviews: SortField.datereviewed,
|
|
302
|
+
collections: SortField.datearchived,
|
|
303
|
+
web_archives: SortField.datearchived,
|
|
304
|
+
};
|
|
305
|
+
/**
|
|
306
|
+
* A map from prefix filter types to the corresponding aggregation keys
|
|
307
|
+
* that are needed to fetch the filter counts from the backend.
|
|
308
|
+
*/
|
|
309
|
+
export const prefixFilterAggregationKeys = {
|
|
310
|
+
title: 'firstTitle',
|
|
311
|
+
creator: 'firstCreator',
|
|
312
|
+
};
|
|
313
|
+
export const getDefaultSelectedFacets = () => ({
|
|
314
|
+
subject: {},
|
|
315
|
+
lending: {},
|
|
316
|
+
mediatype: {},
|
|
317
|
+
language: {},
|
|
318
|
+
creator: {},
|
|
319
|
+
collection: {},
|
|
320
|
+
year: {},
|
|
321
|
+
});
|
|
322
|
+
export const facetDisplayOrder = [
|
|
323
|
+
'mediatype',
|
|
324
|
+
// 'lending', Commenting this out removes the lending facet from the sidebar for now
|
|
325
|
+
'year',
|
|
326
|
+
'subject',
|
|
327
|
+
'collection',
|
|
328
|
+
'creator',
|
|
329
|
+
'language',
|
|
330
|
+
];
|
|
331
|
+
export const facetTitles = {
|
|
332
|
+
subject: 'Subject',
|
|
333
|
+
lending: 'Availability',
|
|
334
|
+
mediatype: 'Media Type',
|
|
335
|
+
language: 'Language',
|
|
336
|
+
creator: 'Creator',
|
|
337
|
+
collection: 'Collection',
|
|
338
|
+
year: 'Year',
|
|
339
|
+
};
|
|
340
|
+
/**
|
|
341
|
+
* The default sort type to use for each facet type
|
|
342
|
+
*/
|
|
343
|
+
export const defaultFacetSort = {
|
|
344
|
+
subject: AggregationSortType.COUNT,
|
|
345
|
+
lending: AggregationSortType.COUNT,
|
|
346
|
+
mediatype: AggregationSortType.COUNT,
|
|
347
|
+
language: AggregationSortType.COUNT,
|
|
348
|
+
creator: AggregationSortType.COUNT,
|
|
349
|
+
collection: AggregationSortType.COUNT,
|
|
350
|
+
year: AggregationSortType.NUMERIC,
|
|
351
|
+
};
|
|
352
|
+
/**
|
|
353
|
+
* The sort type corresponding to facet bucket values, for each facet type
|
|
354
|
+
* (i.e., the opposite of "sort by count" for that type).
|
|
355
|
+
*/
|
|
356
|
+
export const valueFacetSort = {
|
|
357
|
+
subject: AggregationSortType.ALPHABETICAL,
|
|
358
|
+
lending: AggregationSortType.ALPHABETICAL,
|
|
359
|
+
mediatype: AggregationSortType.ALPHABETICAL,
|
|
360
|
+
language: AggregationSortType.ALPHABETICAL,
|
|
361
|
+
creator: AggregationSortType.ALPHABETICAL,
|
|
362
|
+
collection: AggregationSortType.ALPHABETICAL,
|
|
363
|
+
year: AggregationSortType.NUMERIC,
|
|
364
|
+
};
|
|
365
|
+
/**
|
|
366
|
+
* Maps valid lending keys to whether they should be visible in the facet sidebar
|
|
367
|
+
*/
|
|
368
|
+
export const lendingFacetKeysVisibility = {
|
|
369
|
+
is_lendable: true,
|
|
370
|
+
is_borrowable: false,
|
|
371
|
+
available_to_borrow: true,
|
|
372
|
+
is_browsable: false,
|
|
373
|
+
available_to_browse: false,
|
|
374
|
+
is_readable: true,
|
|
375
|
+
available_to_waitlist: false,
|
|
376
|
+
};
|
|
377
|
+
/**
|
|
378
|
+
* Maps valid, visible lending keys to their facet sidebar display text
|
|
379
|
+
*/
|
|
380
|
+
export const lendingFacetDisplayNames = {
|
|
381
|
+
is_lendable: 'Lending Library',
|
|
382
|
+
available_to_borrow: 'Borrow 14 Days',
|
|
383
|
+
is_readable: 'Always Available',
|
|
384
|
+
};
|
|
385
|
+
/**
|
|
386
|
+
* A record of which admin-only collections should be suppressed from being displayed
|
|
387
|
+
* as facets or in an item's list of collections.
|
|
388
|
+
*/
|
|
389
|
+
export const suppressedCollections = {
|
|
390
|
+
deemphasize: true,
|
|
391
|
+
community: true,
|
|
392
|
+
stream_only: true,
|
|
393
|
+
samples_only: true,
|
|
394
|
+
test_collection: true,
|
|
395
|
+
printdisabled: true,
|
|
396
|
+
'openlibrary-ol': true,
|
|
397
|
+
nationalemergencylibrary: true,
|
|
398
|
+
china: true,
|
|
399
|
+
americana: true,
|
|
400
|
+
toronto: true,
|
|
401
|
+
};
|
|
402
402
|
//# sourceMappingURL=models.js.map
|