@internetarchive/collection-browser 2.3.0 → 2.4.0-e2e-test-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.husky/pre-commit +4 -4
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +12 -12
- package/dist/index.js +12 -12
- package/dist/src/app-root.d.ts +91 -91
- package/dist/src/app-root.js +487 -487
- 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/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 +466 -466
- package/dist/src/collection-browser.js +1476 -1476
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-row.d.ts +30 -30
- package/dist/src/collection-facets/facet-row.js +116 -114
- package/dist/src/collection-facets/facet-row.js.map +1 -1
- 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 +17 -17
- package/dist/src/collection-facets/facets-template.js +118 -115
- package/dist/src/collection-facets/facets-template.js.map +1 -1
- package/dist/src/collection-facets/more-facets-content.d.ts +74 -74
- package/dist/src/collection-facets/more-facets-content.js +360 -360
- 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/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 -512
- package/dist/src/collection-facets.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
- package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
- package/dist/src/data-source/collection-browser-data-source.d.ts +378 -378
- package/dist/src/data-source/collection-browser-data-source.js +985 -985
- package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
- 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 +87 -79
- package/dist/src/empty-placeholder.js.map +1 -1
- 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 +30 -30
- package/dist/src/manage/manage-bar.js +61 -61
- 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 +209 -209
- package/dist/src/models.js +381 -381
- package/dist/src/restoration-state-handler.d.ts +70 -70
- package/dist/src/restoration-state-handler.js +357 -357
- 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 +222 -222
- package/dist/src/sort-filter-bar/sort-filter-bar.js +699 -696
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
- package/dist/src/styles/ia-button.d.ts +2 -2
- package/dist/src/styles/ia-button.js +16 -16
- 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 +63 -63
- 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 +30 -30
- package/dist/src/tiles/grid/item-tile.js +149 -149
- 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 +354 -352
- package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
- package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -15
- package/dist/src/tiles/hover/tile-hover-pane.js +127 -47
- package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
- package/dist/src/tiles/image-block.d.ts +17 -17
- package/dist/src/tiles/image-block.js +74 -74
- package/dist/src/tiles/image-block.js.map +1 -1
- 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 +15 -15
- package/dist/src/tiles/list/tile-list-compact.js +114 -114
- package/dist/src/tiles/list/tile-list.d.ts +50 -50
- package/dist/src/tiles/list/tile-list.js +315 -315
- 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 +10 -10
- package/dist/src/tiles/overlay/icon-overlay.js +40 -40
- package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
- package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
- package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
- package/dist/src/tiles/overlay/text-overlay.js +42 -42
- 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 +229 -229
- 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/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 +25 -25
- 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 +1293 -1293
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
- package/dist/test/collection-facets/facet-row.test.js +203 -203
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +105 -105
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +139 -139
- 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 +652 -652
- 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 +48 -48
- 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 +1 -1
- package/dist/test/manage/manage-bar.test.js +81 -81
- 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 +24 -24
- package/dist/test/mocks/mock-search-responses.js +860 -860
- package/dist/test/mocks/mock-search-service.d.ts +15 -15
- package/dist/test/mocks/mock-search-service.js +53 -53
- 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 +48 -48
- 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 -13
- package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
- 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 +17 -17
- 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/collection-browser.ts +1 -1
- package/src/collection-facets/facet-row.ts +2 -0
- package/src/collection-facets/facets-template.ts +4 -1
- package/src/collection-facets.ts +12 -2
- package/src/empty-placeholder.ts +13 -5
- package/src/sort-filter-bar/sort-filter-bar.ts +3 -0
- package/src/tiles/hover/hover-pane-controller.ts +2 -0
- package/src/tiles/hover/tile-hover-pane.ts +100 -11
- package/src/tiles/image-block.ts +1 -1
- package/test/tiles/hover/tile-hover-pane.test.ts +61 -0
- package/tsconfig.json +21 -21
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -1,43 +1,43 @@
|
|
|
1
|
-
import type { CollectionExtraInfo, PageElementName, SearchServiceInterface, SearchType, SortDirection, SortParam } from '@internetarchive/search-service';
|
|
2
|
-
import type { FacetLoadStrategy, SelectedFacets, SortField } from '../models';
|
|
3
|
-
import type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';
|
|
4
|
-
/**
|
|
5
|
-
* Properties of collection browser that affect the overall search query
|
|
6
|
-
*/
|
|
7
|
-
export interface CollectionBrowserQueryState {
|
|
8
|
-
baseQuery?: string;
|
|
9
|
-
withinCollection?: string;
|
|
10
|
-
withinProfile?: string;
|
|
11
|
-
profileElement?: PageElementName;
|
|
12
|
-
searchType: SearchType;
|
|
13
|
-
selectedFacets?: SelectedFacets;
|
|
14
|
-
minSelectedDate?: string;
|
|
15
|
-
maxSelectedDate?: string;
|
|
16
|
-
selectedTitleFilter: string | null;
|
|
17
|
-
selectedCreatorFilter: string | null;
|
|
18
|
-
selectedSort?: SortField;
|
|
19
|
-
sortDirection: SortDirection | null;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Interface representing search-related state and operations required by the
|
|
23
|
-
* data source on its host component.
|
|
24
|
-
*/
|
|
25
|
-
export interface CollectionBrowserSearchInterface extends CollectionBrowserQueryState {
|
|
26
|
-
searchService?: SearchServiceInterface;
|
|
27
|
-
readonly sortParam: SortParam | null;
|
|
28
|
-
readonly defaultSortParam: SortParam | null;
|
|
29
|
-
readonly facetLoadStrategy: FacetLoadStrategy;
|
|
30
|
-
readonly initialPageNumber: number;
|
|
31
|
-
readonly currentVisiblePageNumbers: number[];
|
|
32
|
-
readonly clearResultsOnEmptyQuery?: boolean;
|
|
33
|
-
readonly dataSource?: CollectionBrowserDataSourceInterface;
|
|
34
|
-
getSessionId(): Promise<string>;
|
|
35
|
-
setSearchResultsLoading(loading: boolean): void;
|
|
36
|
-
setFacetsLoading(loading: boolean): void;
|
|
37
|
-
setTotalResultCount(count: number): void;
|
|
38
|
-
setTileCount(count: number): void;
|
|
39
|
-
applyDefaultCollectionSort(collectionInfo?: CollectionExtraInfo): void;
|
|
40
|
-
emitEmptyResults(): void;
|
|
41
|
-
emitQueryStateChanged(): void;
|
|
42
|
-
refreshVisibleResults(): void;
|
|
43
|
-
}
|
|
1
|
+
import type { CollectionExtraInfo, PageElementName, SearchServiceInterface, SearchType, SortDirection, SortParam } from '@internetarchive/search-service';
|
|
2
|
+
import type { FacetLoadStrategy, SelectedFacets, SortField } from '../models';
|
|
3
|
+
import type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';
|
|
4
|
+
/**
|
|
5
|
+
* Properties of collection browser that affect the overall search query
|
|
6
|
+
*/
|
|
7
|
+
export interface CollectionBrowserQueryState {
|
|
8
|
+
baseQuery?: string;
|
|
9
|
+
withinCollection?: string;
|
|
10
|
+
withinProfile?: string;
|
|
11
|
+
profileElement?: PageElementName;
|
|
12
|
+
searchType: SearchType;
|
|
13
|
+
selectedFacets?: SelectedFacets;
|
|
14
|
+
minSelectedDate?: string;
|
|
15
|
+
maxSelectedDate?: string;
|
|
16
|
+
selectedTitleFilter: string | null;
|
|
17
|
+
selectedCreatorFilter: string | null;
|
|
18
|
+
selectedSort?: SortField;
|
|
19
|
+
sortDirection: SortDirection | null;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Interface representing search-related state and operations required by the
|
|
23
|
+
* data source on its host component.
|
|
24
|
+
*/
|
|
25
|
+
export interface CollectionBrowserSearchInterface extends CollectionBrowserQueryState {
|
|
26
|
+
searchService?: SearchServiceInterface;
|
|
27
|
+
readonly sortParam: SortParam | null;
|
|
28
|
+
readonly defaultSortParam: SortParam | null;
|
|
29
|
+
readonly facetLoadStrategy: FacetLoadStrategy;
|
|
30
|
+
readonly initialPageNumber: number;
|
|
31
|
+
readonly currentVisiblePageNumbers: number[];
|
|
32
|
+
readonly clearResultsOnEmptyQuery?: boolean;
|
|
33
|
+
readonly dataSource?: CollectionBrowserDataSourceInterface;
|
|
34
|
+
getSessionId(): Promise<string>;
|
|
35
|
+
setSearchResultsLoading(loading: boolean): void;
|
|
36
|
+
setFacetsLoading(loading: boolean): void;
|
|
37
|
+
setTotalResultCount(count: number): void;
|
|
38
|
+
setTileCount(count: number): void;
|
|
39
|
+
applyDefaultCollectionSort(collectionInfo?: CollectionExtraInfo): void;
|
|
40
|
+
emitEmptyResults(): void;
|
|
41
|
+
emitQueryStateChanged(): void;
|
|
42
|
+
refreshVisibleResults(): void;
|
|
43
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=collection-browser-query-state.js.map
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import type { PageElementName, PageType } from '@internetarchive/search-service';
|
|
2
|
-
/**
|
|
3
|
-
* A Map from collection identifiers to their corresponding collection titles.
|
|
4
|
-
*/
|
|
5
|
-
export declare type CollectionTitles = Map<string, string>;
|
|
6
|
-
/**
|
|
7
|
-
* The subset of search service params that uniquely specify the type of results
|
|
8
|
-
* that are sought by an instance of collection browser.
|
|
9
|
-
*/
|
|
10
|
-
export declare type PageSpecifierParams = {
|
|
11
|
-
/**
|
|
12
|
-
* What high-level type of page is being fetched for (search results, collection, or profile)
|
|
13
|
-
*/
|
|
14
|
-
pageType: PageType;
|
|
15
|
-
/**
|
|
16
|
-
* The target identifier for collection or profile pages (e.g., "prelinger", "@brewster", ...)
|
|
17
|
-
*/
|
|
18
|
-
pageTarget: string;
|
|
19
|
-
/**
|
|
20
|
-
* Which specific elements of a profile page to fetch. Corresponds to individual tab data
|
|
21
|
-
* (e.g., "uploads", "reviews", ...)
|
|
22
|
-
*/
|
|
23
|
-
pageElements?: PageElementName[];
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* List of profile page elements that do not currently allow faceting
|
|
27
|
-
*/
|
|
28
|
-
export declare const FACETLESS_PAGE_ELEMENTS: PageElementName[];
|
|
1
|
+
import type { PageElementName, PageType } from '@internetarchive/search-service';
|
|
2
|
+
/**
|
|
3
|
+
* A Map from collection identifiers to their corresponding collection titles.
|
|
4
|
+
*/
|
|
5
|
+
export declare type CollectionTitles = Map<string, string>;
|
|
6
|
+
/**
|
|
7
|
+
* The subset of search service params that uniquely specify the type of results
|
|
8
|
+
* that are sought by an instance of collection browser.
|
|
9
|
+
*/
|
|
10
|
+
export declare type PageSpecifierParams = {
|
|
11
|
+
/**
|
|
12
|
+
* What high-level type of page is being fetched for (search results, collection, or profile)
|
|
13
|
+
*/
|
|
14
|
+
pageType: PageType;
|
|
15
|
+
/**
|
|
16
|
+
* The target identifier for collection or profile pages (e.g., "prelinger", "@brewster", ...)
|
|
17
|
+
*/
|
|
18
|
+
pageTarget: string;
|
|
19
|
+
/**
|
|
20
|
+
* Which specific elements of a profile page to fetch. Corresponds to individual tab data
|
|
21
|
+
* (e.g., "uploads", "reviews", ...)
|
|
22
|
+
*/
|
|
23
|
+
pageElements?: PageElementName[];
|
|
24
|
+
};
|
|
25
|
+
/**
|
|
26
|
+
* List of profile page elements that do not currently allow faceting
|
|
27
|
+
*/
|
|
28
|
+
export declare const FACETLESS_PAGE_ELEMENTS: PageElementName[];
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* List of profile page elements that do not currently allow faceting
|
|
3
|
-
*/
|
|
4
|
-
export const FACETLESS_PAGE_ELEMENTS = [
|
|
5
|
-
'forum_posts',
|
|
6
|
-
'lending',
|
|
7
|
-
'web_archives',
|
|
8
|
-
];
|
|
1
|
+
/**
|
|
2
|
+
* List of profile page elements that do not currently allow faceting
|
|
3
|
+
*/
|
|
4
|
+
export const FACETLESS_PAGE_ELEMENTS = [
|
|
5
|
+
'forum_posts',
|
|
6
|
+
'lending',
|
|
7
|
+
'web_archives',
|
|
8
|
+
];
|
|
9
9
|
//# sourceMappingURL=models.js.map
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
import { LitElement, CSSResultGroup, nothing, TemplateResult } from 'lit';
|
|
2
|
-
export declare type PlaceholderType = 'empty-query' | 'empty-collection' | 'no-results' | 'query-error' | 'collection-error' | null;
|
|
3
|
-
export declare class EmptyPlaceholder extends LitElement {
|
|
4
|
-
private static readonly MESSAGE_EMPTY_QUERY;
|
|
5
|
-
private static readonly MESSAGE_NO_SEARCH_RESULTS;
|
|
6
|
-
private static readonly MESSAGE_NO_COLLECTION_RESULTS;
|
|
7
|
-
private static readonly MESSAGE_NO_VIEWABLE_MEMBERS;
|
|
8
|
-
private static readonly MESSAGE_QUERY_ERROR;
|
|
9
|
-
private static readonly MESSAGE_COLLECTION_ERROR;
|
|
10
|
-
private static readonly QUERY_ERROR_DETAILS_MESSAGE;
|
|
11
|
-
placeholderType: PlaceholderType;
|
|
12
|
-
isMobileView?: false;
|
|
13
|
-
isCollection?: false;
|
|
14
|
-
detailMessage?: string;
|
|
15
|
-
render(): TemplateResult<1> | typeof nothing;
|
|
16
|
-
private get placeholderTemplate();
|
|
17
|
-
private get emptyQueryTemplate();
|
|
18
|
-
private get emptyCollectionTemplate();
|
|
19
|
-
private get noResultsTemplate();
|
|
20
|
-
private get queryErrorTemplate();
|
|
21
|
-
private get collectionErrorTemplate();
|
|
22
|
-
static get styles(): CSSResultGroup;
|
|
23
|
-
}
|
|
1
|
+
import { LitElement, CSSResultGroup, nothing, TemplateResult } from 'lit';
|
|
2
|
+
export declare type PlaceholderType = 'empty-query' | 'empty-collection' | 'no-results' | 'query-error' | 'collection-error' | null;
|
|
3
|
+
export declare class EmptyPlaceholder extends LitElement {
|
|
4
|
+
private static readonly MESSAGE_EMPTY_QUERY;
|
|
5
|
+
private static readonly MESSAGE_NO_SEARCH_RESULTS;
|
|
6
|
+
private static readonly MESSAGE_NO_COLLECTION_RESULTS;
|
|
7
|
+
private static readonly MESSAGE_NO_VIEWABLE_MEMBERS;
|
|
8
|
+
private static readonly MESSAGE_QUERY_ERROR;
|
|
9
|
+
private static readonly MESSAGE_COLLECTION_ERROR;
|
|
10
|
+
private static readonly QUERY_ERROR_DETAILS_MESSAGE;
|
|
11
|
+
placeholderType: PlaceholderType;
|
|
12
|
+
isMobileView?: false;
|
|
13
|
+
isCollection?: false;
|
|
14
|
+
detailMessage?: string;
|
|
15
|
+
render(): TemplateResult<1> | typeof nothing;
|
|
16
|
+
private get placeholderTemplate();
|
|
17
|
+
private get emptyQueryTemplate();
|
|
18
|
+
private get emptyCollectionTemplate();
|
|
19
|
+
private get noResultsTemplate();
|
|
20
|
+
private get queryErrorTemplate();
|
|
21
|
+
private get collectionErrorTemplate();
|
|
22
|
+
static get styles(): CSSResultGroup;
|
|
23
|
+
}
|
|
@@ -1,78 +1,86 @@
|
|
|
1
|
-
var EmptyPlaceholder_1;
|
|
2
|
-
import { __decorate } from "tslib";
|
|
3
|
-
import { css, html, LitElement, nothing, } from 'lit';
|
|
4
|
-
import { customElement, property } from 'lit/decorators.js';
|
|
5
|
-
import { choose } from 'lit/directives/choose.js';
|
|
6
|
-
import { msg } from '@lit/localize';
|
|
7
|
-
import emptyQueryIcon from './assets/img/icons/empty-query';
|
|
8
|
-
import nullResultIcon from './assets/img/icons/null-result';
|
|
9
|
-
let EmptyPlaceholder = EmptyPlaceholder_1 = class EmptyPlaceholder extends LitElement {
|
|
10
|
-
constructor() {
|
|
11
|
-
super(...arguments);
|
|
12
|
-
this.placeholderType = null;
|
|
13
|
-
this.detailMessage = '';
|
|
14
|
-
}
|
|
15
|
-
render() {
|
|
16
|
-
return this.placeholderType ? html `${this.placeholderTemplate}` : nothing;
|
|
17
|
-
}
|
|
18
|
-
get placeholderTemplate() {
|
|
1
|
+
var EmptyPlaceholder_1;
|
|
2
|
+
import { __decorate } from "tslib";
|
|
3
|
+
import { css, html, LitElement, nothing, } from 'lit';
|
|
4
|
+
import { customElement, property } from 'lit/decorators.js';
|
|
5
|
+
import { choose } from 'lit/directives/choose.js';
|
|
6
|
+
import { msg } from '@lit/localize';
|
|
7
|
+
import emptyQueryIcon from './assets/img/icons/empty-query';
|
|
8
|
+
import nullResultIcon from './assets/img/icons/null-result';
|
|
9
|
+
let EmptyPlaceholder = EmptyPlaceholder_1 = class EmptyPlaceholder extends LitElement {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.placeholderType = null;
|
|
13
|
+
this.detailMessage = '';
|
|
14
|
+
}
|
|
15
|
+
render() {
|
|
16
|
+
return this.placeholderType ? html `${this.placeholderTemplate}` : nothing;
|
|
17
|
+
}
|
|
18
|
+
get placeholderTemplate() {
|
|
19
19
|
return html `
|
|
20
20
|
<div
|
|
21
|
-
class="placeholder ${this.placeholderType} ${this.isMobileView
|
|
22
|
-
? 'mobile'
|
|
21
|
+
class="placeholder ${this.placeholderType} ${this.isMobileView
|
|
22
|
+
? 'mobile'
|
|
23
23
|
: 'desktop'}"
|
|
24
24
|
>
|
|
25
|
-
${choose(this.placeholderType, [
|
|
26
|
-
['empty-query', () => this.emptyQueryTemplate],
|
|
27
|
-
['empty-collection', () => this.emptyCollectionTemplate],
|
|
28
|
-
['no-results', () => this.noResultsTemplate],
|
|
29
|
-
['query-error', () => this.queryErrorTemplate],
|
|
30
|
-
['collection-error', () => this.collectionErrorTemplate],
|
|
25
|
+
${choose(this.placeholderType, [
|
|
26
|
+
['empty-query', () => this.emptyQueryTemplate],
|
|
27
|
+
['empty-collection', () => this.emptyCollectionTemplate],
|
|
28
|
+
['no-results', () => this.noResultsTemplate],
|
|
29
|
+
['query-error', () => this.queryErrorTemplate],
|
|
30
|
+
['collection-error', () => this.collectionErrorTemplate],
|
|
31
31
|
])}
|
|
32
32
|
</div>
|
|
33
|
-
`;
|
|
34
|
-
}
|
|
35
|
-
get emptyQueryTemplate() {
|
|
33
|
+
`;
|
|
34
|
+
}
|
|
35
|
+
get emptyQueryTemplate() {
|
|
36
36
|
return html `
|
|
37
|
-
<h2 class="title"
|
|
37
|
+
<h2 class="title" data-testid="empty-query-text-msg">
|
|
38
|
+
${EmptyPlaceholder_1.MESSAGE_EMPTY_QUERY}
|
|
39
|
+
</h2>
|
|
38
40
|
<div>${emptyQueryIcon}</div>
|
|
39
|
-
`;
|
|
40
|
-
}
|
|
41
|
-
get emptyCollectionTemplate() {
|
|
41
|
+
`;
|
|
42
|
+
}
|
|
43
|
+
get emptyCollectionTemplate() {
|
|
42
44
|
return html `
|
|
43
|
-
<h2 class="title"
|
|
45
|
+
<h2 class="title" data-testid="empty-collection-text-msg">
|
|
46
|
+
${EmptyPlaceholder_1.MESSAGE_NO_VIEWABLE_MEMBERS}
|
|
47
|
+
</h2>
|
|
44
48
|
<div>${nullResultIcon}</div>
|
|
45
|
-
`;
|
|
46
|
-
}
|
|
47
|
-
get noResultsTemplate() {
|
|
49
|
+
`;
|
|
50
|
+
}
|
|
51
|
+
get noResultsTemplate() {
|
|
48
52
|
return html `
|
|
49
|
-
<h2 class="title">
|
|
50
|
-
${this.isCollection
|
|
51
|
-
? EmptyPlaceholder_1.MESSAGE_NO_COLLECTION_RESULTS
|
|
53
|
+
<h2 class="title" data-testid="empty-results-text-msg">
|
|
54
|
+
${this.isCollection
|
|
55
|
+
? EmptyPlaceholder_1.MESSAGE_NO_COLLECTION_RESULTS
|
|
52
56
|
: EmptyPlaceholder_1.MESSAGE_NO_SEARCH_RESULTS}
|
|
53
57
|
</h2>
|
|
54
58
|
<div>${nullResultIcon}</div>
|
|
55
|
-
`;
|
|
56
|
-
}
|
|
57
|
-
get queryErrorTemplate() {
|
|
59
|
+
`;
|
|
60
|
+
}
|
|
61
|
+
get queryErrorTemplate() {
|
|
58
62
|
return html `
|
|
59
|
-
<h2 class="title"
|
|
63
|
+
<h2 class="title" data-testid="error-query-text-msg">
|
|
64
|
+
${EmptyPlaceholder_1.MESSAGE_QUERY_ERROR}
|
|
65
|
+
</h2>
|
|
60
66
|
<div>${nullResultIcon}</div>
|
|
61
67
|
<p class="error-details">
|
|
62
68
|
${EmptyPlaceholder_1.QUERY_ERROR_DETAILS_MESSAGE} ${this.detailMessage}
|
|
63
69
|
</p>
|
|
64
|
-
`;
|
|
65
|
-
}
|
|
66
|
-
get collectionErrorTemplate() {
|
|
70
|
+
`;
|
|
71
|
+
}
|
|
72
|
+
get collectionErrorTemplate() {
|
|
67
73
|
return html `
|
|
68
|
-
<h2 class="title"
|
|
74
|
+
<h2 class="title" data-testid="error-collection-text-msg">
|
|
75
|
+
${EmptyPlaceholder_1.MESSAGE_COLLECTION_ERROR}
|
|
76
|
+
</h2>
|
|
69
77
|
<div>${nullResultIcon}</div>
|
|
70
78
|
<p class="error-details">
|
|
71
79
|
${EmptyPlaceholder_1.QUERY_ERROR_DETAILS_MESSAGE} ${this.detailMessage}
|
|
72
80
|
</p>
|
|
73
|
-
`;
|
|
74
|
-
}
|
|
75
|
-
static get styles() {
|
|
81
|
+
`;
|
|
82
|
+
}
|
|
83
|
+
static get styles() {
|
|
76
84
|
return css `
|
|
77
85
|
:host {
|
|
78
86
|
text-align: center;
|
|
@@ -113,41 +121,41 @@ let EmptyPlaceholder = EmptyPlaceholder_1 = class EmptyPlaceholder extends LitEl
|
|
|
113
121
|
font-size: 1.2rem;
|
|
114
122
|
word-break: break-word;
|
|
115
123
|
}
|
|
116
|
-
`;
|
|
117
|
-
}
|
|
118
|
-
};
|
|
119
|
-
EmptyPlaceholder.MESSAGE_EMPTY_QUERY = msg('To begin searching, enter a search term in the box above and hit "Go".');
|
|
120
|
-
EmptyPlaceholder.MESSAGE_NO_SEARCH_RESULTS = msg('Your search did not match any items in the Archive. ' +
|
|
121
|
-
'Try different keywords or a more general search.');
|
|
122
|
-
EmptyPlaceholder.MESSAGE_NO_COLLECTION_RESULTS = msg('Your search did not match any items in this collection. ' +
|
|
123
|
-
'Try different keywords or a more general search.');
|
|
124
|
-
EmptyPlaceholder.MESSAGE_NO_VIEWABLE_MEMBERS = msg('This collection contains no viewable items.');
|
|
124
|
+
`;
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
EmptyPlaceholder.MESSAGE_EMPTY_QUERY = msg('To begin searching, enter a search term in the box above and hit "Go".');
|
|
128
|
+
EmptyPlaceholder.MESSAGE_NO_SEARCH_RESULTS = msg('Your search did not match any items in the Archive. ' +
|
|
129
|
+
'Try different keywords or a more general search.');
|
|
130
|
+
EmptyPlaceholder.MESSAGE_NO_COLLECTION_RESULTS = msg('Your search did not match any items in this collection. ' +
|
|
131
|
+
'Try different keywords or a more general search.');
|
|
132
|
+
EmptyPlaceholder.MESSAGE_NO_VIEWABLE_MEMBERS = msg('This collection contains no viewable items.');
|
|
125
133
|
EmptyPlaceholder.MESSAGE_QUERY_ERROR = msg(html `The search engine
|
|
126
134
|
encountered an error, which might be related to your search query.
|
|
127
135
|
<a
|
|
128
136
|
href="https://help.archive.org/help/search-building-powerful-complex-queries/"
|
|
129
137
|
>
|
|
130
138
|
Tips for constructing search queries.
|
|
131
|
-
</a> `);
|
|
139
|
+
</a> `);
|
|
132
140
|
EmptyPlaceholder.MESSAGE_COLLECTION_ERROR = msg(html `The search engine
|
|
133
141
|
encountered an error while loading this collection. If the problem persists,
|
|
134
142
|
please let us know at
|
|
135
|
-
<a href="mailto:info@archive.org">info@archive.org</a>.`);
|
|
136
|
-
EmptyPlaceholder.QUERY_ERROR_DETAILS_MESSAGE = msg('Error details:');
|
|
137
|
-
__decorate([
|
|
138
|
-
property({ type: String })
|
|
139
|
-
], EmptyPlaceholder.prototype, "placeholderType", void 0);
|
|
140
|
-
__decorate([
|
|
141
|
-
property({ type: Boolean })
|
|
142
|
-
], EmptyPlaceholder.prototype, "isMobileView", void 0);
|
|
143
|
-
__decorate([
|
|
144
|
-
property({ type: Boolean })
|
|
145
|
-
], EmptyPlaceholder.prototype, "isCollection", void 0);
|
|
146
|
-
__decorate([
|
|
147
|
-
property({ type: String })
|
|
148
|
-
], EmptyPlaceholder.prototype, "detailMessage", void 0);
|
|
149
|
-
EmptyPlaceholder = EmptyPlaceholder_1 = __decorate([
|
|
150
|
-
customElement('empty-placeholder')
|
|
151
|
-
], EmptyPlaceholder);
|
|
152
|
-
export { EmptyPlaceholder };
|
|
143
|
+
<a href="mailto:info@archive.org">info@archive.org</a>.`);
|
|
144
|
+
EmptyPlaceholder.QUERY_ERROR_DETAILS_MESSAGE = msg('Error details:');
|
|
145
|
+
__decorate([
|
|
146
|
+
property({ type: String })
|
|
147
|
+
], EmptyPlaceholder.prototype, "placeholderType", void 0);
|
|
148
|
+
__decorate([
|
|
149
|
+
property({ type: Boolean })
|
|
150
|
+
], EmptyPlaceholder.prototype, "isMobileView", void 0);
|
|
151
|
+
__decorate([
|
|
152
|
+
property({ type: Boolean })
|
|
153
|
+
], EmptyPlaceholder.prototype, "isCollection", void 0);
|
|
154
|
+
__decorate([
|
|
155
|
+
property({ type: String })
|
|
156
|
+
], EmptyPlaceholder.prototype, "detailMessage", void 0);
|
|
157
|
+
EmptyPlaceholder = EmptyPlaceholder_1 = __decorate([
|
|
158
|
+
customElement('empty-placeholder')
|
|
159
|
+
], EmptyPlaceholder);
|
|
160
|
+
export { EmptyPlaceholder };
|
|
153
161
|
//# sourceMappingURL=empty-placeholder.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"empty-placeholder.js","sourceRoot":"","sources":["../../src/empty-placeholder.ts"],"names":[],"mappings":";;AAAA,OAAO,EACL,GAAG,EACH,IAAI,EACJ,UAAU,EAEV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAEpC,OAAO,cAAc,MAAM,gCAAgC,CAAC;AAC5D,OAAO,cAAc,MAAM,gCAAgC,CAAC;AAU5D,IAAa,gBAAgB,wBAA7B,MAAa,gBAAiB,SAAQ,UAAU;IAAhD;;QAkC8B,oBAAe,GAAoB,IAAI,CAAC;QAMxC,kBAAa,GAAY,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"empty-placeholder.js","sourceRoot":"","sources":["../../src/empty-placeholder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n css,\n html,\n LitElement,\n CSSResultGroup,\n nothing,\n TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { choose } from 'lit/directives/choose.js';\nimport { msg } from '@lit/localize';\n\nimport emptyQueryIcon from './assets/img/icons/empty-query';\nimport nullResultIcon from './assets/img/icons/null-result';\n\nexport type PlaceholderType =\n | 'empty-query'\n | 'empty-collection'\n | 'no-results'\n | 'query-error'\n | 'collection-error'\n | null;\n@customElement('empty-placeholder')\nexport class EmptyPlaceholder extends LitElement {\n private static readonly MESSAGE_EMPTY_QUERY = msg(\n 'To begin searching, enter a search term in the box above and hit \"Go\".'\n );\n\n private static readonly MESSAGE_NO_SEARCH_RESULTS = msg(\n 'Your search did not match any items in the Archive. ' +\n 'Try different keywords or a more general search.'\n );\n\n private static readonly MESSAGE_NO_COLLECTION_RESULTS = msg(\n 'Your search did not match any items in this collection. ' +\n 'Try different keywords or a more general search.'\n );\n\n private static readonly MESSAGE_NO_VIEWABLE_MEMBERS = msg(\n 'This collection contains no viewable items.'\n );\n\n private static readonly MESSAGE_QUERY_ERROR = msg(html`The search engine\n encountered an error, which might be related to your search query.\n <a\n href=\"https://help.archive.org/help/search-building-powerful-complex-queries/\"\n >\n Tips for constructing search queries.\n </a> `);\n\n private static readonly MESSAGE_COLLECTION_ERROR = msg(html`The search engine\n encountered an error while loading this collection. If the problem persists,\n please let us know at\n <a href=\"mailto:info@archive.org\">info@archive.org</a>.`);\n\n private static readonly QUERY_ERROR_DETAILS_MESSAGE = msg('Error details:');\n\n @property({ type: String }) placeholderType: PlaceholderType = null;\n\n @property({ type: Boolean }) isMobileView?: false;\n\n @property({ type: Boolean }) isCollection?: false;\n\n @property({ type: String }) detailMessage?: string = '';\n\n render() {\n return this.placeholderType ? html`${this.placeholderTemplate}` : nothing;\n }\n\n private get placeholderTemplate(): TemplateResult {\n return html`\n <div\n class=\"placeholder ${this.placeholderType} ${this.isMobileView\n ? 'mobile'\n : 'desktop'}\"\n >\n ${choose(this.placeholderType, [\n ['empty-query', () => this.emptyQueryTemplate],\n ['empty-collection', () => this.emptyCollectionTemplate],\n ['no-results', () => this.noResultsTemplate],\n ['query-error', () => this.queryErrorTemplate],\n ['collection-error', () => this.collectionErrorTemplate],\n ])}\n </div>\n `;\n }\n\n private get emptyQueryTemplate(): TemplateResult {\n return html`\n <h2 class=\"title\" data-testid=\"empty-query-text-msg\">\n ${EmptyPlaceholder.MESSAGE_EMPTY_QUERY}\n </h2>\n <div>${emptyQueryIcon}</div>\n `;\n }\n\n private get emptyCollectionTemplate(): TemplateResult {\n return html`\n <h2 class=\"title\" data-testid=\"empty-collection-text-msg\">\n ${EmptyPlaceholder.MESSAGE_NO_VIEWABLE_MEMBERS}\n </h2>\n <div>${nullResultIcon}</div>\n `;\n }\n\n private get noResultsTemplate(): TemplateResult {\n return html`\n <h2 class=\"title\" data-testid=\"empty-results-text-msg\">\n ${this.isCollection\n ? EmptyPlaceholder.MESSAGE_NO_COLLECTION_RESULTS\n : EmptyPlaceholder.MESSAGE_NO_SEARCH_RESULTS}\n </h2>\n <div>${nullResultIcon}</div>\n `;\n }\n\n private get queryErrorTemplate(): TemplateResult {\n return html`\n <h2 class=\"title\" data-testid=\"error-query-text-msg\">\n ${EmptyPlaceholder.MESSAGE_QUERY_ERROR}\n </h2>\n <div>${nullResultIcon}</div>\n <p class=\"error-details\">\n ${EmptyPlaceholder.QUERY_ERROR_DETAILS_MESSAGE} ${this.detailMessage}\n </p>\n `;\n }\n\n private get collectionErrorTemplate(): TemplateResult {\n return html`\n <h2 class=\"title\" data-testid=\"error-collection-text-msg\">\n ${EmptyPlaceholder.MESSAGE_COLLECTION_ERROR}\n </h2>\n <div>${nullResultIcon}</div>\n <p class=\"error-details\">\n ${EmptyPlaceholder.QUERY_ERROR_DETAILS_MESSAGE} ${this.detailMessage}\n </p>\n `;\n }\n\n static get styles(): CSSResultGroup {\n return css`\n :host {\n text-align: center;\n width: 100%;\n }\n\n a {\n text-decoration: none;\n }\n a:link {\n color: var(--ia-theme-link-color, #4b64ff);\n }\n a:hover {\n text-decoration: underline;\n }\n\n .placeholder {\n display: block;\n }\n\n .desktop svg {\n max-height: 40rem;\n }\n .desktop .title,\n .desktop .error-details {\n margin: 4rem 0;\n }\n\n .mobile svg {\n max-height: 20rem;\n }\n .mobile .title,\n .mobile .error-details {\n margin: 2rem 0.5;\n }\n\n .error-details {\n font-size: 1.2rem;\n word-break: break-word;\n }\n `;\n }\n}\n"]}
|
|
@@ -1,43 +1,43 @@
|
|
|
1
|
-
import { LitElement, CSSResultGroup, TemplateResult } from 'lit';
|
|
2
|
-
import type { ModalManagerInterface } from '@internetarchive/modal-manager';
|
|
3
|
-
import type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
|
|
4
|
-
export declare class ExpandedDatePicker extends LitElement {
|
|
5
|
-
minDate?: string;
|
|
6
|
-
maxDate?: string;
|
|
7
|
-
minSelectedDate?: string;
|
|
8
|
-
maxSelectedDate?: string;
|
|
9
|
-
buckets?: number[];
|
|
10
|
-
modalManager?: ModalManagerInterface;
|
|
11
|
-
analyticsHandler?: AnalyticsManagerInterface;
|
|
12
|
-
render(): TemplateResult;
|
|
13
|
-
connectedCallback(): void;
|
|
14
|
-
disconnectedCallback(): void;
|
|
15
|
-
/**
|
|
16
|
-
* Add an event listener to close the date picker modal when the Esc key is pressed
|
|
17
|
-
*/
|
|
18
|
-
private setupEscapeListener;
|
|
19
|
-
/**
|
|
20
|
-
* Remove the Esc key listener that was previously added
|
|
21
|
-
*/
|
|
22
|
-
private removeEscapeListener;
|
|
23
|
-
/**
|
|
24
|
-
* Closes the modal dialog if the given event is pressing the Esc key.
|
|
25
|
-
* Arrow function to ensure `this` remains bound to the current component.
|
|
26
|
-
*/
|
|
27
|
-
private boundEscapeListener;
|
|
28
|
-
/**
|
|
29
|
-
* When the histogram is updated, keep track of the newly selected date range.
|
|
30
|
-
* We don't commit to the new range until the apply button is clicked.
|
|
31
|
-
*/
|
|
32
|
-
private histogramDateRangeUpdated;
|
|
33
|
-
/**
|
|
34
|
-
* When the Apply button is clicked, emit the current date range and close the modal.
|
|
35
|
-
*/
|
|
36
|
-
private applyBtnClicked;
|
|
37
|
-
/**
|
|
38
|
-
* Closes the modal associated with this component (if it exists) and dispatches a
|
|
39
|
-
* modalClosed event.
|
|
40
|
-
*/
|
|
41
|
-
private closeModal;
|
|
42
|
-
static get styles(): CSSResultGroup;
|
|
43
|
-
}
|
|
1
|
+
import { LitElement, CSSResultGroup, TemplateResult } from 'lit';
|
|
2
|
+
import type { ModalManagerInterface } from '@internetarchive/modal-manager';
|
|
3
|
+
import type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
|
|
4
|
+
export declare class ExpandedDatePicker extends LitElement {
|
|
5
|
+
minDate?: string;
|
|
6
|
+
maxDate?: string;
|
|
7
|
+
minSelectedDate?: string;
|
|
8
|
+
maxSelectedDate?: string;
|
|
9
|
+
buckets?: number[];
|
|
10
|
+
modalManager?: ModalManagerInterface;
|
|
11
|
+
analyticsHandler?: AnalyticsManagerInterface;
|
|
12
|
+
render(): TemplateResult;
|
|
13
|
+
connectedCallback(): void;
|
|
14
|
+
disconnectedCallback(): void;
|
|
15
|
+
/**
|
|
16
|
+
* Add an event listener to close the date picker modal when the Esc key is pressed
|
|
17
|
+
*/
|
|
18
|
+
private setupEscapeListener;
|
|
19
|
+
/**
|
|
20
|
+
* Remove the Esc key listener that was previously added
|
|
21
|
+
*/
|
|
22
|
+
private removeEscapeListener;
|
|
23
|
+
/**
|
|
24
|
+
* Closes the modal dialog if the given event is pressing the Esc key.
|
|
25
|
+
* Arrow function to ensure `this` remains bound to the current component.
|
|
26
|
+
*/
|
|
27
|
+
private boundEscapeListener;
|
|
28
|
+
/**
|
|
29
|
+
* When the histogram is updated, keep track of the newly selected date range.
|
|
30
|
+
* We don't commit to the new range until the apply button is clicked.
|
|
31
|
+
*/
|
|
32
|
+
private histogramDateRangeUpdated;
|
|
33
|
+
/**
|
|
34
|
+
* When the Apply button is clicked, emit the current date range and close the modal.
|
|
35
|
+
*/
|
|
36
|
+
private applyBtnClicked;
|
|
37
|
+
/**
|
|
38
|
+
* Closes the modal associated with this component (if it exists) and dispatches a
|
|
39
|
+
* modalClosed event.
|
|
40
|
+
*/
|
|
41
|
+
private closeModal;
|
|
42
|
+
static get styles(): CSSResultGroup;
|
|
43
|
+
}
|