@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
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
import { accountIcon } from '../assets/img/icons/mediatype/account';
|
|
2
|
-
import { audioIcon } from '../assets/img/icons/mediatype/audio';
|
|
3
|
-
import { collectionIcon } from '../assets/img/icons/mediatype/collection';
|
|
4
|
-
import { dataIcon } from '../assets/img/icons/mediatype/data';
|
|
5
|
-
import { etreeIcon } from '../assets/img/icons/mediatype/etree';
|
|
6
|
-
import { imagesIcon } from '../assets/img/icons/mediatype/images';
|
|
7
|
-
import { filmIcon } from '../assets/img/icons/mediatype/film';
|
|
8
|
-
import { radioIcon } from '../assets/img/icons/mediatype/radio';
|
|
9
|
-
import { softwareIcon } from '../assets/img/icons/mediatype/software';
|
|
10
|
-
import { textsIcon } from '../assets/img/icons/mediatype/texts';
|
|
11
|
-
import { tvIcon } from '../assets/img/icons/mediatype/tv';
|
|
12
|
-
import { videoIcon } from '../assets/img/icons/mediatype/video';
|
|
13
|
-
import { webIcon } from '../assets/img/icons/mediatype/web';
|
|
14
|
-
import { searchIcon } from '../assets/img/icons/mediatype/search';
|
|
15
|
-
export const mediatypeConfig = {
|
|
16
|
-
account: {
|
|
17
|
-
color: '#000000',
|
|
18
|
-
icon: accountIcon,
|
|
19
|
-
text: 'Account',
|
|
20
|
-
},
|
|
21
|
-
audio: {
|
|
22
|
-
color: '#00adef',
|
|
23
|
-
icon: audioIcon,
|
|
24
|
-
text: 'Audio',
|
|
25
|
-
},
|
|
26
|
-
collection: {
|
|
27
|
-
color: '#4666ff',
|
|
28
|
-
icon: collectionIcon,
|
|
29
|
-
text: 'Collection',
|
|
30
|
-
},
|
|
31
|
-
data: {
|
|
32
|
-
color: '#333333',
|
|
33
|
-
icon: dataIcon,
|
|
34
|
-
text: 'Data',
|
|
35
|
-
},
|
|
36
|
-
etree: {
|
|
37
|
-
color: '#00adef',
|
|
38
|
-
icon: etreeIcon,
|
|
39
|
-
text: 'E-tree',
|
|
40
|
-
},
|
|
41
|
-
film: {
|
|
42
|
-
color: '#bf1b2c',
|
|
43
|
-
icon: filmIcon,
|
|
44
|
-
text: 'Film',
|
|
45
|
-
},
|
|
46
|
-
image: {
|
|
47
|
-
color: '#aa99c9',
|
|
48
|
-
icon: imagesIcon,
|
|
49
|
-
text: 'Image',
|
|
50
|
-
},
|
|
51
|
-
movies: {
|
|
52
|
-
color: '#f1644b',
|
|
53
|
-
icon: filmIcon,
|
|
54
|
-
text: 'Movie',
|
|
55
|
-
},
|
|
56
|
-
radio: {
|
|
57
|
-
color: '#8fdaef',
|
|
58
|
-
icon: radioIcon,
|
|
59
|
-
text: 'Radio',
|
|
60
|
-
},
|
|
61
|
-
software: {
|
|
62
|
-
color: '#9ecc4f',
|
|
63
|
-
icon: softwareIcon,
|
|
64
|
-
text: 'Software',
|
|
65
|
-
},
|
|
66
|
-
texts: {
|
|
67
|
-
color: '#faab3c',
|
|
68
|
-
icon: textsIcon,
|
|
69
|
-
text: 'Text',
|
|
70
|
-
},
|
|
71
|
-
tv: {
|
|
72
|
-
color: '#f1644b',
|
|
73
|
-
icon: tvIcon,
|
|
74
|
-
text: 'TV',
|
|
75
|
-
},
|
|
76
|
-
video: {
|
|
77
|
-
color: '#f1644b',
|
|
78
|
-
icon: videoIcon,
|
|
79
|
-
text: 'Video',
|
|
80
|
-
},
|
|
81
|
-
web: {
|
|
82
|
-
color: '#ffcd27',
|
|
83
|
-
icon: webIcon,
|
|
84
|
-
text: 'Web',
|
|
85
|
-
},
|
|
86
|
-
search: {
|
|
87
|
-
color: '#000000',
|
|
88
|
-
icon: searchIcon,
|
|
89
|
-
text: 'Search',
|
|
90
|
-
},
|
|
91
|
-
};
|
|
1
|
+
import { accountIcon } from '../assets/img/icons/mediatype/account';
|
|
2
|
+
import { audioIcon } from '../assets/img/icons/mediatype/audio';
|
|
3
|
+
import { collectionIcon } from '../assets/img/icons/mediatype/collection';
|
|
4
|
+
import { dataIcon } from '../assets/img/icons/mediatype/data';
|
|
5
|
+
import { etreeIcon } from '../assets/img/icons/mediatype/etree';
|
|
6
|
+
import { imagesIcon } from '../assets/img/icons/mediatype/images';
|
|
7
|
+
import { filmIcon } from '../assets/img/icons/mediatype/film';
|
|
8
|
+
import { radioIcon } from '../assets/img/icons/mediatype/radio';
|
|
9
|
+
import { softwareIcon } from '../assets/img/icons/mediatype/software';
|
|
10
|
+
import { textsIcon } from '../assets/img/icons/mediatype/texts';
|
|
11
|
+
import { tvIcon } from '../assets/img/icons/mediatype/tv';
|
|
12
|
+
import { videoIcon } from '../assets/img/icons/mediatype/video';
|
|
13
|
+
import { webIcon } from '../assets/img/icons/mediatype/web';
|
|
14
|
+
import { searchIcon } from '../assets/img/icons/mediatype/search';
|
|
15
|
+
export const mediatypeConfig = {
|
|
16
|
+
account: {
|
|
17
|
+
color: '#000000',
|
|
18
|
+
icon: accountIcon,
|
|
19
|
+
text: 'Account',
|
|
20
|
+
},
|
|
21
|
+
audio: {
|
|
22
|
+
color: '#00adef',
|
|
23
|
+
icon: audioIcon,
|
|
24
|
+
text: 'Audio',
|
|
25
|
+
},
|
|
26
|
+
collection: {
|
|
27
|
+
color: '#4666ff',
|
|
28
|
+
icon: collectionIcon,
|
|
29
|
+
text: 'Collection',
|
|
30
|
+
},
|
|
31
|
+
data: {
|
|
32
|
+
color: '#333333',
|
|
33
|
+
icon: dataIcon,
|
|
34
|
+
text: 'Data',
|
|
35
|
+
},
|
|
36
|
+
etree: {
|
|
37
|
+
color: '#00adef',
|
|
38
|
+
icon: etreeIcon,
|
|
39
|
+
text: 'E-tree',
|
|
40
|
+
},
|
|
41
|
+
film: {
|
|
42
|
+
color: '#bf1b2c',
|
|
43
|
+
icon: filmIcon,
|
|
44
|
+
text: 'Film',
|
|
45
|
+
},
|
|
46
|
+
image: {
|
|
47
|
+
color: '#aa99c9',
|
|
48
|
+
icon: imagesIcon,
|
|
49
|
+
text: 'Image',
|
|
50
|
+
},
|
|
51
|
+
movies: {
|
|
52
|
+
color: '#f1644b',
|
|
53
|
+
icon: filmIcon,
|
|
54
|
+
text: 'Movie',
|
|
55
|
+
},
|
|
56
|
+
radio: {
|
|
57
|
+
color: '#8fdaef',
|
|
58
|
+
icon: radioIcon,
|
|
59
|
+
text: 'Radio',
|
|
60
|
+
},
|
|
61
|
+
software: {
|
|
62
|
+
color: '#9ecc4f',
|
|
63
|
+
icon: softwareIcon,
|
|
64
|
+
text: 'Software',
|
|
65
|
+
},
|
|
66
|
+
texts: {
|
|
67
|
+
color: '#faab3c',
|
|
68
|
+
icon: textsIcon,
|
|
69
|
+
text: 'Text',
|
|
70
|
+
},
|
|
71
|
+
tv: {
|
|
72
|
+
color: '#f1644b',
|
|
73
|
+
icon: tvIcon,
|
|
74
|
+
text: 'TV',
|
|
75
|
+
},
|
|
76
|
+
video: {
|
|
77
|
+
color: '#f1644b',
|
|
78
|
+
icon: videoIcon,
|
|
79
|
+
text: 'Video',
|
|
80
|
+
},
|
|
81
|
+
web: {
|
|
82
|
+
color: '#ffcd27',
|
|
83
|
+
icon: webIcon,
|
|
84
|
+
text: 'Web',
|
|
85
|
+
},
|
|
86
|
+
search: {
|
|
87
|
+
color: '#000000',
|
|
88
|
+
icon: searchIcon,
|
|
89
|
+
text: 'Search',
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
92
|
//# sourceMappingURL=mediatype-config.js.map
|
package/dist/src/models.d.ts
CHANGED
|
@@ -1,228 +1,228 @@
|
|
|
1
|
-
import type { TemplateResult } from 'lit';
|
|
2
|
-
import type { MediaType } from '@internetarchive/field-parsers';
|
|
3
|
-
import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
|
|
4
|
-
/**
|
|
5
|
-
* Different types of tile overlays, corresponding to the above flags.
|
|
6
|
-
*/
|
|
7
|
-
export declare type TileOverlayType = 'login-required' | 'content-warning';
|
|
8
|
-
export declare const TILE_OVERLAY_TEXT: Record<TileOverlayType, string>;
|
|
9
|
-
export declare const TILE_OVERLAY_ICONS: Record<TileOverlayType, TemplateResult>;
|
|
10
|
-
/**
|
|
11
|
-
* Class for converting & storing raw search results in the correct format for UI tiles.
|
|
12
|
-
*/
|
|
13
|
-
export declare class TileModel {
|
|
14
|
-
averageRating?: number;
|
|
15
|
-
captureDates?: Date[];
|
|
16
|
-
checked: boolean;
|
|
17
|
-
collectionIdentifier?: string;
|
|
18
|
-
collectionName?: string;
|
|
19
|
-
collectionFilesCount: number;
|
|
20
|
-
collections: string[];
|
|
21
|
-
collectionSize: number;
|
|
22
|
-
commentCount: number;
|
|
23
|
-
creator?: string;
|
|
24
|
-
creators: string[];
|
|
25
|
-
dateStr?: string;
|
|
26
|
-
dateAdded?: Date;
|
|
27
|
-
dateArchived?: Date;
|
|
28
|
-
datePublished?: Date;
|
|
29
|
-
dateReviewed?: Date;
|
|
30
|
-
description?: string;
|
|
31
|
-
favCount: number;
|
|
32
|
-
href?: string;
|
|
33
|
-
identifier?: string;
|
|
34
|
-
issue?: string;
|
|
35
|
-
itemCount: number;
|
|
36
|
-
mediatype: MediaType;
|
|
37
|
-
review?: Review;
|
|
38
|
-
source?: string;
|
|
39
|
-
snippets?: string[];
|
|
40
|
-
subjects: string[];
|
|
41
|
-
title: string;
|
|
42
|
-
viewCount?: number;
|
|
43
|
-
volume?: string;
|
|
44
|
-
weeklyViewCount?: number;
|
|
45
|
-
loginRequired: boolean;
|
|
46
|
-
contentWarning: boolean;
|
|
47
|
-
constructor(result: SearchResult);
|
|
48
|
-
/**
|
|
49
|
-
* Copies the contents of this TileModel onto a new instance
|
|
50
|
-
*/
|
|
51
|
-
clone(): TileModel;
|
|
52
|
-
/**
|
|
53
|
-
* Determines the appropriate tile flags for the given search result
|
|
54
|
-
* (login required and/or content warning)
|
|
55
|
-
*/
|
|
56
|
-
private getFlags;
|
|
57
|
-
private static cleanIdentifier;
|
|
58
|
-
}
|
|
59
|
-
export declare type RequestKind = 'full' | 'hits' | 'aggregations';
|
|
60
|
-
export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
|
|
61
|
-
export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
|
|
62
|
-
/**
|
|
63
|
-
* This is mainly used to set the cookies for the collection display mode.
|
|
64
|
-
*
|
|
65
|
-
* It allows the user to set different modes for different contexts (collection page, search page, profile page etc).
|
|
66
|
-
*/
|
|
67
|
-
export declare type CollectionBrowserContext = 'collection' | 'search' | 'profile';
|
|
68
|
-
/**
|
|
69
|
-
* The sort fields shown in the sort filter bar
|
|
70
|
-
*/
|
|
71
|
-
export declare enum SortField {
|
|
72
|
-
'default' = "default",
|
|
73
|
-
'unrecognized' = "unrecognized",
|
|
74
|
-
'relevance' = "relevance",
|
|
75
|
-
'alltimeview' = "alltimeview",
|
|
76
|
-
'weeklyview' = "weeklyview",
|
|
77
|
-
'title' = "title",
|
|
78
|
-
'date' = "date",
|
|
79
|
-
'datearchived' = "datearchived",
|
|
80
|
-
'datereviewed' = "datereviewed",
|
|
81
|
-
'dateadded' = "dateadded",
|
|
82
|
-
'datefavorited' = "datefavorited",
|
|
83
|
-
'creator' = "creator"
|
|
84
|
-
}
|
|
85
|
-
export interface SortOption {
|
|
86
|
-
/**
|
|
87
|
-
* The SortField enum member corresponding to this option.
|
|
88
|
-
*/
|
|
89
|
-
field: SortField;
|
|
90
|
-
/**
|
|
91
|
-
* The default sort direction to apply when this sort option is first selected.
|
|
92
|
-
*/
|
|
93
|
-
defaultSortDirection: SortDirection | null;
|
|
94
|
-
/**
|
|
95
|
-
* Whether this sort option allows its sort direction to be changed from the default.
|
|
96
|
-
*/
|
|
97
|
-
canSetDirection: boolean;
|
|
98
|
-
/**
|
|
99
|
-
* Whether this sort option may appear in the sort bar.
|
|
100
|
-
*/
|
|
101
|
-
shownInSortBar: boolean;
|
|
102
|
-
/**
|
|
103
|
-
* Whether this sort option should be saved to the URL.
|
|
104
|
-
* If false, then no `sort` param will be added to the URL when this sort option
|
|
105
|
-
* is selected.
|
|
106
|
-
*/
|
|
107
|
-
shownInURL: boolean;
|
|
108
|
-
/**
|
|
109
|
-
* Whether this sort option is passed to the search service.
|
|
110
|
-
* If false, then no sort param will be passed to the search service at all when
|
|
111
|
-
* this sort option is selected.
|
|
112
|
-
*/
|
|
113
|
-
handledBySearchService: boolean;
|
|
114
|
-
/**
|
|
115
|
-
* The string identifying this sort field to the search service & backend API.
|
|
116
|
-
*/
|
|
117
|
-
searchServiceKey?: string;
|
|
118
|
-
/**
|
|
119
|
-
* The human-readable name to use for this option in the sort bar (if applicable).
|
|
120
|
-
*/
|
|
121
|
-
displayName: string;
|
|
122
|
-
/**
|
|
123
|
-
* A list of URL param keys that should be mapped to this sort option.
|
|
124
|
-
* E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
|
|
125
|
-
*/
|
|
126
|
-
urlNames: (string | null | undefined)[];
|
|
127
|
-
}
|
|
128
|
-
export declare const SORT_OPTIONS: Record<SortField, SortOption>;
|
|
129
|
-
/**
|
|
130
|
-
* Returns the SortOption corresponding to the given API sort name, or
|
|
131
|
-
* the "unrecognized" SortOption if none matches.
|
|
132
|
-
*/
|
|
133
|
-
export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
|
|
134
|
-
export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
|
|
135
|
-
/** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
|
|
136
|
-
export declare type PrefixFilterType = 'title' | 'creator';
|
|
137
|
-
/** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
|
|
138
|
-
export declare type PrefixFilterCounts = Record<string, number>;
|
|
139
|
-
/**
|
|
140
|
-
* A map from prefix filter types to the corresponding aggregation keys
|
|
141
|
-
* that are needed to fetch the filter counts from the backend.
|
|
142
|
-
*/
|
|
143
|
-
export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
|
|
144
|
-
/**
|
|
145
|
-
* Different facet loading strategies that can be used with collection browser.
|
|
146
|
-
* - `eager`: Facet data is always loaded as soon as a search is performed
|
|
147
|
-
* - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
|
|
148
|
-
* In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
|
|
149
|
-
* - `opt-in-or-login`: Same as `opt-in` for guest users not logged into an account, but same as `eager` for
|
|
150
|
-
* any logged in user.
|
|
151
|
-
* - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
|
|
152
|
-
* In the mobile layout, functions exactly as `lazy-mobile`.
|
|
153
|
-
* - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
|
|
154
|
-
* indicating that they are unavailable.
|
|
155
|
-
*/
|
|
156
|
-
export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in-or-login' | 'opt-in' | 'off';
|
|
157
|
-
/**
|
|
158
|
-
* Union of the facet types that are available in the sidebar.
|
|
159
|
-
*/
|
|
160
|
-
export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
|
|
161
|
-
export declare type SelectedFacetState = 'selected' | 'hidden';
|
|
162
|
-
export declare type FacetState = SelectedFacetState | 'none';
|
|
163
|
-
export interface FacetBucket {
|
|
164
|
-
displayText?: string;
|
|
165
|
-
key: string;
|
|
166
|
-
count: number;
|
|
167
|
-
state: FacetState;
|
|
168
|
-
}
|
|
169
|
-
export interface FacetGroup {
|
|
170
|
-
title: string;
|
|
171
|
-
key: FacetOption;
|
|
172
|
-
buckets: FacetBucket[];
|
|
173
|
-
}
|
|
174
|
-
/**
|
|
175
|
-
* Information about a user interaction event on a facet.
|
|
176
|
-
*/
|
|
177
|
-
export declare type FacetEventDetails = {
|
|
178
|
-
/**
|
|
179
|
-
* The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
|
|
180
|
-
*/
|
|
181
|
-
facetType: FacetOption;
|
|
182
|
-
/**
|
|
183
|
-
* The bucket corresponding to the facet that was interacted with, including the
|
|
184
|
-
* updated state of the facet after the interaction.
|
|
185
|
-
*/
|
|
186
|
-
bucket: FacetBucket;
|
|
187
|
-
/**
|
|
188
|
-
* Whether the interaction occurred on a negative facet.
|
|
189
|
-
*/
|
|
190
|
-
negative: boolean;
|
|
191
|
-
};
|
|
192
|
-
export declare type FacetValue = string;
|
|
193
|
-
export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
|
|
194
|
-
export declare const getDefaultSelectedFacets: () => SelectedFacets;
|
|
195
|
-
export declare const facetDisplayOrder: FacetOption[];
|
|
196
|
-
export declare const facetTitles: Record<FacetOption, string>;
|
|
197
|
-
/**
|
|
198
|
-
* The default sort type to use for each facet type
|
|
199
|
-
*/
|
|
200
|
-
export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
|
|
201
|
-
/**
|
|
202
|
-
* The sort type corresponding to facet bucket values, for each facet type
|
|
203
|
-
* (i.e., the opposite of "sort by count" for that type).
|
|
204
|
-
*/
|
|
205
|
-
export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
|
|
206
|
-
export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
|
|
207
|
-
/**
|
|
208
|
-
* Maps valid lending keys to whether they should be visible in the facet sidebar
|
|
209
|
-
*/
|
|
210
|
-
export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
|
|
211
|
-
/**
|
|
212
|
-
* Maps valid, visible lending keys to their facet sidebar display text
|
|
213
|
-
*/
|
|
214
|
-
export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
|
|
215
|
-
/**
|
|
216
|
-
* A record of which admin-only collections should be suppressed from being displayed
|
|
217
|
-
* as facets or in an item's list of collections.
|
|
218
|
-
*/
|
|
219
|
-
export declare const suppressedCollections: Record<string, boolean>;
|
|
220
|
-
/**
|
|
221
|
-
* A record of manageable item
|
|
222
|
-
*/
|
|
223
|
-
export interface ManageableItem {
|
|
224
|
-
identifier: string;
|
|
225
|
-
title?: string;
|
|
226
|
-
dateStr?: string;
|
|
227
|
-
date?: string;
|
|
228
|
-
}
|
|
1
|
+
import type { TemplateResult } from 'lit';
|
|
2
|
+
import type { MediaType } from '@internetarchive/field-parsers';
|
|
3
|
+
import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
|
|
4
|
+
/**
|
|
5
|
+
* Different types of tile overlays, corresponding to the above flags.
|
|
6
|
+
*/
|
|
7
|
+
export declare type TileOverlayType = 'login-required' | 'content-warning';
|
|
8
|
+
export declare const TILE_OVERLAY_TEXT: Record<TileOverlayType, string>;
|
|
9
|
+
export declare const TILE_OVERLAY_ICONS: Record<TileOverlayType, TemplateResult>;
|
|
10
|
+
/**
|
|
11
|
+
* Class for converting & storing raw search results in the correct format for UI tiles.
|
|
12
|
+
*/
|
|
13
|
+
export declare class TileModel {
|
|
14
|
+
averageRating?: number;
|
|
15
|
+
captureDates?: Date[];
|
|
16
|
+
checked: boolean;
|
|
17
|
+
collectionIdentifier?: string;
|
|
18
|
+
collectionName?: string;
|
|
19
|
+
collectionFilesCount: number;
|
|
20
|
+
collections: string[];
|
|
21
|
+
collectionSize: number;
|
|
22
|
+
commentCount: number;
|
|
23
|
+
creator?: string;
|
|
24
|
+
creators: string[];
|
|
25
|
+
dateStr?: string;
|
|
26
|
+
dateAdded?: Date;
|
|
27
|
+
dateArchived?: Date;
|
|
28
|
+
datePublished?: Date;
|
|
29
|
+
dateReviewed?: Date;
|
|
30
|
+
description?: string;
|
|
31
|
+
favCount: number;
|
|
32
|
+
href?: string;
|
|
33
|
+
identifier?: string;
|
|
34
|
+
issue?: string;
|
|
35
|
+
itemCount: number;
|
|
36
|
+
mediatype: MediaType;
|
|
37
|
+
review?: Review;
|
|
38
|
+
source?: string;
|
|
39
|
+
snippets?: string[];
|
|
40
|
+
subjects: string[];
|
|
41
|
+
title: string;
|
|
42
|
+
viewCount?: number;
|
|
43
|
+
volume?: string;
|
|
44
|
+
weeklyViewCount?: number;
|
|
45
|
+
loginRequired: boolean;
|
|
46
|
+
contentWarning: boolean;
|
|
47
|
+
constructor(result: SearchResult);
|
|
48
|
+
/**
|
|
49
|
+
* Copies the contents of this TileModel onto a new instance
|
|
50
|
+
*/
|
|
51
|
+
clone(): TileModel;
|
|
52
|
+
/**
|
|
53
|
+
* Determines the appropriate tile flags for the given search result
|
|
54
|
+
* (login required and/or content warning)
|
|
55
|
+
*/
|
|
56
|
+
private getFlags;
|
|
57
|
+
private static cleanIdentifier;
|
|
58
|
+
}
|
|
59
|
+
export declare type RequestKind = 'full' | 'hits' | 'aggregations';
|
|
60
|
+
export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
|
|
61
|
+
export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
|
|
62
|
+
/**
|
|
63
|
+
* This is mainly used to set the cookies for the collection display mode.
|
|
64
|
+
*
|
|
65
|
+
* It allows the user to set different modes for different contexts (collection page, search page, profile page etc).
|
|
66
|
+
*/
|
|
67
|
+
export declare type CollectionBrowserContext = 'collection' | 'search' | 'profile';
|
|
68
|
+
/**
|
|
69
|
+
* The sort fields shown in the sort filter bar
|
|
70
|
+
*/
|
|
71
|
+
export declare enum SortField {
|
|
72
|
+
'default' = "default",
|
|
73
|
+
'unrecognized' = "unrecognized",
|
|
74
|
+
'relevance' = "relevance",
|
|
75
|
+
'alltimeview' = "alltimeview",
|
|
76
|
+
'weeklyview' = "weeklyview",
|
|
77
|
+
'title' = "title",
|
|
78
|
+
'date' = "date",
|
|
79
|
+
'datearchived' = "datearchived",
|
|
80
|
+
'datereviewed' = "datereviewed",
|
|
81
|
+
'dateadded' = "dateadded",
|
|
82
|
+
'datefavorited' = "datefavorited",
|
|
83
|
+
'creator' = "creator"
|
|
84
|
+
}
|
|
85
|
+
export interface SortOption {
|
|
86
|
+
/**
|
|
87
|
+
* The SortField enum member corresponding to this option.
|
|
88
|
+
*/
|
|
89
|
+
field: SortField;
|
|
90
|
+
/**
|
|
91
|
+
* The default sort direction to apply when this sort option is first selected.
|
|
92
|
+
*/
|
|
93
|
+
defaultSortDirection: SortDirection | null;
|
|
94
|
+
/**
|
|
95
|
+
* Whether this sort option allows its sort direction to be changed from the default.
|
|
96
|
+
*/
|
|
97
|
+
canSetDirection: boolean;
|
|
98
|
+
/**
|
|
99
|
+
* Whether this sort option may appear in the sort bar.
|
|
100
|
+
*/
|
|
101
|
+
shownInSortBar: boolean;
|
|
102
|
+
/**
|
|
103
|
+
* Whether this sort option should be saved to the URL.
|
|
104
|
+
* If false, then no `sort` param will be added to the URL when this sort option
|
|
105
|
+
* is selected.
|
|
106
|
+
*/
|
|
107
|
+
shownInURL: boolean;
|
|
108
|
+
/**
|
|
109
|
+
* Whether this sort option is passed to the search service.
|
|
110
|
+
* If false, then no sort param will be passed to the search service at all when
|
|
111
|
+
* this sort option is selected.
|
|
112
|
+
*/
|
|
113
|
+
handledBySearchService: boolean;
|
|
114
|
+
/**
|
|
115
|
+
* The string identifying this sort field to the search service & backend API.
|
|
116
|
+
*/
|
|
117
|
+
searchServiceKey?: string;
|
|
118
|
+
/**
|
|
119
|
+
* The human-readable name to use for this option in the sort bar (if applicable).
|
|
120
|
+
*/
|
|
121
|
+
displayName: string;
|
|
122
|
+
/**
|
|
123
|
+
* A list of URL param keys that should be mapped to this sort option.
|
|
124
|
+
* E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
|
|
125
|
+
*/
|
|
126
|
+
urlNames: (string | null | undefined)[];
|
|
127
|
+
}
|
|
128
|
+
export declare const SORT_OPTIONS: Record<SortField, SortOption>;
|
|
129
|
+
/**
|
|
130
|
+
* Returns the SortOption corresponding to the given API sort name, or
|
|
131
|
+
* the "unrecognized" SortOption if none matches.
|
|
132
|
+
*/
|
|
133
|
+
export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
|
|
134
|
+
export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
|
|
135
|
+
/** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
|
|
136
|
+
export declare type PrefixFilterType = 'title' | 'creator';
|
|
137
|
+
/** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
|
|
138
|
+
export declare type PrefixFilterCounts = Record<string, number>;
|
|
139
|
+
/**
|
|
140
|
+
* A map from prefix filter types to the corresponding aggregation keys
|
|
141
|
+
* that are needed to fetch the filter counts from the backend.
|
|
142
|
+
*/
|
|
143
|
+
export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
|
|
144
|
+
/**
|
|
145
|
+
* Different facet loading strategies that can be used with collection browser.
|
|
146
|
+
* - `eager`: Facet data is always loaded as soon as a search is performed
|
|
147
|
+
* - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
|
|
148
|
+
* In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
|
|
149
|
+
* - `opt-in-or-login`: Same as `opt-in` for guest users not logged into an account, but same as `eager` for
|
|
150
|
+
* any logged in user.
|
|
151
|
+
* - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
|
|
152
|
+
* In the mobile layout, functions exactly as `lazy-mobile`.
|
|
153
|
+
* - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
|
|
154
|
+
* indicating that they are unavailable.
|
|
155
|
+
*/
|
|
156
|
+
export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in-or-login' | 'opt-in' | 'off';
|
|
157
|
+
/**
|
|
158
|
+
* Union of the facet types that are available in the sidebar.
|
|
159
|
+
*/
|
|
160
|
+
export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
|
|
161
|
+
export declare type SelectedFacetState = 'selected' | 'hidden';
|
|
162
|
+
export declare type FacetState = SelectedFacetState | 'none';
|
|
163
|
+
export interface FacetBucket {
|
|
164
|
+
displayText?: string;
|
|
165
|
+
key: string;
|
|
166
|
+
count: number;
|
|
167
|
+
state: FacetState;
|
|
168
|
+
}
|
|
169
|
+
export interface FacetGroup {
|
|
170
|
+
title: string;
|
|
171
|
+
key: FacetOption;
|
|
172
|
+
buckets: FacetBucket[];
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Information about a user interaction event on a facet.
|
|
176
|
+
*/
|
|
177
|
+
export declare type FacetEventDetails = {
|
|
178
|
+
/**
|
|
179
|
+
* The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
|
|
180
|
+
*/
|
|
181
|
+
facetType: FacetOption;
|
|
182
|
+
/**
|
|
183
|
+
* The bucket corresponding to the facet that was interacted with, including the
|
|
184
|
+
* updated state of the facet after the interaction.
|
|
185
|
+
*/
|
|
186
|
+
bucket: FacetBucket;
|
|
187
|
+
/**
|
|
188
|
+
* Whether the interaction occurred on a negative facet.
|
|
189
|
+
*/
|
|
190
|
+
negative: boolean;
|
|
191
|
+
};
|
|
192
|
+
export declare type FacetValue = string;
|
|
193
|
+
export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
|
|
194
|
+
export declare const getDefaultSelectedFacets: () => SelectedFacets;
|
|
195
|
+
export declare const facetDisplayOrder: FacetOption[];
|
|
196
|
+
export declare const facetTitles: Record<FacetOption, string>;
|
|
197
|
+
/**
|
|
198
|
+
* The default sort type to use for each facet type
|
|
199
|
+
*/
|
|
200
|
+
export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
|
|
201
|
+
/**
|
|
202
|
+
* The sort type corresponding to facet bucket values, for each facet type
|
|
203
|
+
* (i.e., the opposite of "sort by count" for that type).
|
|
204
|
+
*/
|
|
205
|
+
export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
|
|
206
|
+
export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
|
|
207
|
+
/**
|
|
208
|
+
* Maps valid lending keys to whether they should be visible in the facet sidebar
|
|
209
|
+
*/
|
|
210
|
+
export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
|
|
211
|
+
/**
|
|
212
|
+
* Maps valid, visible lending keys to their facet sidebar display text
|
|
213
|
+
*/
|
|
214
|
+
export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
|
|
215
|
+
/**
|
|
216
|
+
* A record of which admin-only collections should be suppressed from being displayed
|
|
217
|
+
* as facets or in an item's list of collections.
|
|
218
|
+
*/
|
|
219
|
+
export declare const suppressedCollections: Record<string, boolean>;
|
|
220
|
+
/**
|
|
221
|
+
* A record of manageable item
|
|
222
|
+
*/
|
|
223
|
+
export interface ManageableItem {
|
|
224
|
+
identifier: string;
|
|
225
|
+
title?: string;
|
|
226
|
+
dateStr?: string;
|
|
227
|
+
date?: string;
|
|
228
|
+
}
|