@internetarchive/collection-browser 3.4.1 → 3.4.2-alpha-webdev7761.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.github/workflows/ci.yml +27 -27
- package/.github/workflows/gh-pages-main.yml +39 -39
- package/.github/workflows/npm-publish.yml +39 -39
- package/.github/workflows/pr-preview.yml +38 -38
- package/.husky/pre-commit +4 -4
- package/.prettierignore +1 -1
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/src/app-root.js +19 -28
- package/dist/src/app-root.js.map +1 -1
- package/dist/src/collection-browser.d.ts +27 -4
- package/dist/src/collection-browser.js +973 -801
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-row.js +143 -143
- package/dist/src/collection-facets/facet-row.js.map +1 -1
- package/dist/src/collection-facets/more-facets-content.js +148 -159
- package/dist/src/collection-facets/more-facets-content.js.map +1 -1
- package/dist/src/collection-facets/more-facets-pagination.js +6 -10
- package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +16 -21
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +7 -10
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js +3 -2
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +9 -11
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +7 -7
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -1
- package/dist/src/collection-facets/toggle-switch.js +4 -6
- package/dist/src/collection-facets/toggle-switch.js.map +1 -1
- package/dist/src/collection-facets.js +309 -310
- package/dist/src/collection-facets.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source-interface.d.ts +10 -1
- package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source.d.ts +19 -1
- package/dist/src/data-source/collection-browser-data-source.js +71 -65
- package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
- package/dist/src/data-source/collection-browser-query-state.d.ts +1 -2
- package/dist/src/data-source/collection-browser-query-state.js.map +1 -1
- package/dist/src/data-source/models.d.ts +11 -0
- package/dist/src/data-source/models.js.map +1 -1
- package/dist/src/empty-placeholder.js +19 -18
- package/dist/src/empty-placeholder.js.map +1 -1
- package/dist/src/expanded-date-picker.js +6 -10
- package/dist/src/expanded-date-picker.js.map +1 -1
- package/dist/src/language-code-handler/language-code-handler.js +2 -2
- package/dist/src/language-code-handler/language-code-handler.js.map +1 -1
- package/dist/src/manage/manage-bar.js +9 -15
- package/dist/src/manage/manage-bar.js.map +1 -1
- package/dist/src/manage/remove-items-modal-content.js +2 -2
- package/dist/src/manage/remove-items-modal-content.js.map +1 -1
- package/dist/src/models.d.ts +2 -6
- package/dist/src/models.js +44 -54
- package/dist/src/models.js.map +1 -1
- package/dist/src/restoration-state-handler.d.ts +1 -2
- package/dist/src/restoration-state-handler.js +12 -19
- package/dist/src/restoration-state-handler.js.map +1 -1
- package/dist/src/sort-filter-bar/alpha-bar.js +9 -14
- package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
- package/dist/src/sort-filter-bar/sort-filter-bar.js +14 -24
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
- package/dist/src/tiles/base-tile-component.js +1 -2
- package/dist/src/tiles/base-tile-component.js.map +1 -1
- package/dist/src/tiles/grid/account-tile.js +5 -7
- package/dist/src/tiles/grid/account-tile.js.map +1 -1
- package/dist/src/tiles/grid/collection-tile.js +3 -6
- package/dist/src/tiles/grid/collection-tile.js.map +1 -1
- package/dist/src/tiles/grid/item-tile.js +23 -33
- package/dist/src/tiles/grid/item-tile.js.map +1 -1
- package/dist/src/tiles/grid/search-tile.js +1 -2
- package/dist/src/tiles/grid/search-tile.js.map +1 -1
- package/dist/src/tiles/grid/tile-stats.js +2 -3
- package/dist/src/tiles/grid/tile-stats.js.map +1 -1
- package/dist/src/tiles/hover/hover-pane-controller.js +21 -28
- package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
- package/dist/src/tiles/hover/tile-hover-pane.js +3 -4
- package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
- package/dist/src/tiles/image-block.js +5 -8
- package/dist/src/tiles/image-block.js.map +1 -1
- package/dist/src/tiles/item-image.js +12 -19
- package/dist/src/tiles/item-image.js.map +1 -1
- package/dist/src/tiles/list/tile-list-compact.js +17 -25
- package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
- package/dist/src/tiles/list/tile-list.js +34 -55
- package/dist/src/tiles/list/tile-list.js.map +1 -1
- package/dist/src/tiles/overlay/icon-overlay.js +1 -2
- package/dist/src/tiles/overlay/icon-overlay.js.map +1 -1
- package/dist/src/tiles/overlay/text-overlay.js +2 -4
- package/dist/src/tiles/overlay/text-overlay.js.map +1 -1
- package/dist/src/tiles/text-snippet-block.js +2 -4
- package/dist/src/tiles/text-snippet-block.js.map +1 -1
- package/dist/src/tiles/tile-dispatcher.js +22 -30
- package/dist/src/tiles/tile-dispatcher.js.map +1 -1
- package/dist/src/tiles/tile-display-value-provider.js +5 -9
- package/dist/src/tiles/tile-display-value-provider.js.map +1 -1
- package/dist/src/tiles/tile-mediatype-icon.js +12 -19
- package/dist/src/tiles/tile-mediatype-icon.js.map +1 -1
- package/dist/src/utils/collapse-repeated-quotes.js +1 -1
- package/dist/src/utils/collapse-repeated-quotes.js.map +1 -1
- package/dist/src/utils/facet-utils.js +3 -5
- package/dist/src/utils/facet-utils.js.map +1 -1
- package/dist/src/utils/format-count.js +10 -10
- package/dist/src/utils/format-count.js.map +1 -1
- package/dist/src/utils/resolve-mediatype.js +2 -3
- package/dist/src/utils/resolve-mediatype.js.map +1 -1
- package/dist/test/collection-browser.test.js +336 -380
- package/dist/test/collection-browser.test.js.map +1 -1
- package/dist/test/collection-facets/facet-row.test.js +37 -52
- package/dist/test/collection-facets/facet-row.test.js.map +1 -1
- package/dist/test/collection-facets/facets-template.test.js +17 -23
- package/dist/test/collection-facets/facets-template.test.js.map +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +22 -32
- package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.js +16 -22
- package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -1
- package/dist/test/collection-facets/toggle-switch.test.js +22 -19
- package/dist/test/collection-facets/toggle-switch.test.js.map +1 -1
- package/dist/test/collection-facets.test.js +60 -77
- package/dist/test/collection-facets.test.js.map +1 -1
- package/dist/test/empty-placeholder.test.js +11 -17
- package/dist/test/empty-placeholder.test.js.map +1 -1
- package/dist/test/expanded-date-picker.test.js +8 -14
- package/dist/test/expanded-date-picker.test.js.map +1 -1
- package/dist/test/icon-overlay.test.js +7 -6
- package/dist/test/icon-overlay.test.js.map +1 -1
- package/dist/test/image-block.test.js +16 -26
- package/dist/test/image-block.test.js.map +1 -1
- package/dist/test/item-image.test.js +23 -32
- package/dist/test/item-image.test.js.map +1 -1
- package/dist/test/manage/manage-bar.test.js +21 -33
- package/dist/test/manage/manage-bar.test.js.map +1 -1
- package/dist/test/manage/remove-items-modal-content.test.js +10 -15
- package/dist/test/manage/remove-items-modal-content.test.js.map +1 -1
- package/dist/test/mocks/mock-search-service.js +2 -3
- package/dist/test/mocks/mock-search-service.js.map +1 -1
- package/dist/test/restoration-state-handler.test.js +14 -54
- package/dist/test/restoration-state-handler.test.js.map +1 -1
- package/dist/test/review-block.test.js +16 -18
- package/dist/test/review-block.test.js.map +1 -1
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +2 -3
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -1
- package/dist/test/sort-filter-bar/alpha-bar.test.js +18 -24
- package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -1
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +178 -180
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
- package/dist/test/text-overlay.test.js +16 -15
- package/dist/test/text-overlay.test.js.map +1 -1
- package/dist/test/text-snippet-block.test.js +14 -19
- package/dist/test/text-snippet-block.test.js.map +1 -1
- package/dist/test/tile-stats.test.js +73 -34
- package/dist/test/tile-stats.test.js.map +1 -1
- package/dist/test/tiles/grid/account-tile.test.js +25 -25
- package/dist/test/tiles/grid/account-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/collection-tile.test.js +13 -19
- package/dist/test/tiles/grid/collection-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/item-tile.test.js +64 -91
- package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/search-tile.test.js +9 -13
- package/dist/test/tiles/grid/search-tile.test.js.map +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.js +23 -35
- package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -1
- package/dist/test/tiles/hover/tile-hover-pane.test.js +12 -16
- package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.js +34 -48
- package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list.test.js +76 -105
- package/dist/test/tiles/list/tile-list.test.js.map +1 -1
- package/dist/test/tiles/tile-dispatcher.test.js +17 -30
- package/dist/test/tiles/tile-dispatcher.test.js.map +1 -1
- package/dist/test/tiles/tile-mediatype-icon.test.js +12 -24
- package/dist/test/tiles/tile-mediatype-icon.test.js.map +1 -1
- package/eslint.config.mjs +53 -53
- package/index.html +24 -24
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +119 -118
- package/renovate.json +6 -6
- package/src/collection-browser.ts +3071 -2829
- package/src/collection-facets/facet-row.ts +299 -296
- package/src/collection-facets/more-facets-content.ts +642 -642
- package/src/collection-facets.ts +1010 -995
- package/src/data-source/collection-browser-data-source-interface.ts +345 -333
- package/src/data-source/collection-browser-data-source.ts +1441 -1401
- package/src/data-source/collection-browser-query-state.ts +59 -65
- package/src/data-source/models.ts +56 -43
- package/src/models.ts +864 -870
- package/src/restoration-state-handler.ts +546 -544
- package/test/collection-browser.test.ts +2413 -2403
- package/test/restoration-state-handler.test.ts +480 -510
- package/tsconfig.json +25 -20
- package/vite.config.ts +29 -22
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -70,9 +70,8 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
70
70
|
setupEscapeListeners() {
|
|
71
71
|
if (this.modalManager) {
|
|
72
72
|
document.addEventListener('keydown', (e) => {
|
|
73
|
-
var _a;
|
|
74
73
|
if (e.key === 'Escape') {
|
|
75
|
-
|
|
74
|
+
this.modalManager?.closeModal();
|
|
76
75
|
}
|
|
77
76
|
});
|
|
78
77
|
}
|
|
@@ -84,10 +83,9 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
84
83
|
* Whether facet requests are for the search_results page type (either defaulted or explicitly).
|
|
85
84
|
*/
|
|
86
85
|
get isSearchResultsPage() {
|
|
87
|
-
var _a;
|
|
88
86
|
// Default page type is search_results when none is specified, so we check
|
|
89
87
|
// for undefined as well.
|
|
90
|
-
const pageType =
|
|
88
|
+
const pageType = this.pageSpecifierParams?.pageType;
|
|
91
89
|
return pageType === undefined || pageType === 'search_results';
|
|
92
90
|
}
|
|
93
91
|
/**
|
|
@@ -95,10 +93,9 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
95
93
|
* - this.aggregations - hold result of search service and being used for further processing.
|
|
96
94
|
*/
|
|
97
95
|
async updateSpecificFacets() {
|
|
98
|
-
var _a, _b, _c, _d, _e, _f;
|
|
99
96
|
if (!this.facetKey)
|
|
100
97
|
return; // Can't fetch facets if we don't know what type of facets we need!
|
|
101
|
-
const trimmedQuery =
|
|
98
|
+
const trimmedQuery = this.query?.trim();
|
|
102
99
|
if (!trimmedQuery && this.isSearchResultsPage)
|
|
103
100
|
return; // The search page _requires_ a query
|
|
104
101
|
const aggregations = {
|
|
@@ -114,13 +111,13 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
114
111
|
aggregationsSize,
|
|
115
112
|
rows: 0, // todo - do we want server-side pagination with offset/page/limit flag?
|
|
116
113
|
};
|
|
117
|
-
const results = await
|
|
118
|
-
this.aggregations =
|
|
114
|
+
const results = await this.searchService?.search(params, this.searchType);
|
|
115
|
+
this.aggregations = results?.success?.response.aggregations;
|
|
119
116
|
this.facetsLoading = false;
|
|
120
|
-
const collectionTitles =
|
|
117
|
+
const collectionTitles = results?.success?.response?.collectionTitles;
|
|
121
118
|
if (collectionTitles) {
|
|
122
119
|
for (const [id, title] of Object.entries(collectionTitles)) {
|
|
123
|
-
|
|
120
|
+
this.collectionTitles?.set(id, title);
|
|
124
121
|
}
|
|
125
122
|
}
|
|
126
123
|
}
|
|
@@ -128,12 +125,11 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
128
125
|
* Handler for page number changes from the pagination widget.
|
|
129
126
|
*/
|
|
130
127
|
pageNumberClicked(e) {
|
|
131
|
-
|
|
132
|
-
const page = (_a = e === null || e === void 0 ? void 0 : e.detail) === null || _a === void 0 ? void 0 : _a.page;
|
|
128
|
+
const page = e?.detail?.page;
|
|
133
129
|
if (page) {
|
|
134
130
|
this.pageNumber = Number(page);
|
|
135
131
|
}
|
|
136
|
-
|
|
132
|
+
this.analyticsHandler?.sendEvent({
|
|
137
133
|
category: analyticsCategories.default,
|
|
138
134
|
action: analyticsActions.moreFacetsPageChange,
|
|
139
135
|
label: `${this.pageNumber}`,
|
|
@@ -143,7 +139,6 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
143
139
|
* Combines the selected facets with the aggregations to create a single list of facets
|
|
144
140
|
*/
|
|
145
141
|
get mergedFacets() {
|
|
146
|
-
var _a;
|
|
147
142
|
if (!this.facetKey || !this.selectedFacets)
|
|
148
143
|
return undefined;
|
|
149
144
|
const { selectedFacetGroup, aggregationFacetGroup } = this;
|
|
@@ -151,9 +146,9 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
151
146
|
if (!aggregationFacetGroup)
|
|
152
147
|
return undefined;
|
|
153
148
|
// Start with either the selected group if we have one, or the aggregate group otherwise
|
|
154
|
-
const facetGroup = { ...(selectedFacetGroup
|
|
149
|
+
const facetGroup = { ...(selectedFacetGroup ?? aggregationFacetGroup) };
|
|
155
150
|
// Attach the counts to the selected buckets
|
|
156
|
-
const bucketsWithCount =
|
|
151
|
+
const bucketsWithCount = selectedFacetGroup?.buckets.map(bucket => {
|
|
157
152
|
const selectedBucket = aggregationFacetGroup.buckets.find(b => b.key === bucket.key);
|
|
158
153
|
return selectedBucket
|
|
159
154
|
? {
|
|
@@ -161,14 +156,14 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
161
156
|
count: selectedBucket.count,
|
|
162
157
|
}
|
|
163
158
|
: bucket;
|
|
164
|
-
})
|
|
159
|
+
}) ?? [];
|
|
165
160
|
// Sort the buckets by selection state
|
|
166
161
|
// We do this *prior* to considering unapplied selections, because we want the facets
|
|
167
162
|
// to remain in position when they are selected/unselected, rather than re-sort themselves.
|
|
168
163
|
sortBucketsBySelectionState(bucketsWithCount, this.sortedBy);
|
|
169
164
|
// Append any additional buckets that were not selected
|
|
170
165
|
aggregationFacetGroup.buckets.forEach(bucket => {
|
|
171
|
-
const existingBucket = selectedFacetGroup
|
|
166
|
+
const existingBucket = selectedFacetGroup?.buckets.find(b => b.key === bucket.key);
|
|
172
167
|
if (existingBucket)
|
|
173
168
|
return;
|
|
174
169
|
bucketsWithCount.push(bucket);
|
|
@@ -176,7 +171,7 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
176
171
|
// Apply any unapplied selections that appear on this page
|
|
177
172
|
const unappliedBuckets = this.unappliedFacetChanges[this.facetKey];
|
|
178
173
|
for (const [index, bucket] of bucketsWithCount.entries()) {
|
|
179
|
-
const unappliedBucket = unappliedBuckets
|
|
174
|
+
const unappliedBucket = unappliedBuckets?.[bucket.key];
|
|
180
175
|
if (unappliedBucket) {
|
|
181
176
|
bucketsWithCount[index] = { ...unappliedBucket };
|
|
182
177
|
}
|
|
@@ -184,9 +179,8 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
184
179
|
// For TV creator facets, uppercase the display text
|
|
185
180
|
if (this.facetKey === 'creator' && this.isTvSearch) {
|
|
186
181
|
bucketsWithCount.forEach(b => {
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
const channelLabel = (_c = this.tvChannelAliases) === null || _c === void 0 ? void 0 : _c.get(b.displayText);
|
|
182
|
+
b.displayText = (b.displayText ?? b.key)?.toLocaleUpperCase();
|
|
183
|
+
const channelLabel = this.tvChannelAliases?.get(b.displayText);
|
|
190
184
|
if (channelLabel && channelLabel !== b.displayText) {
|
|
191
185
|
b.extraNote = `(${channelLabel})`;
|
|
192
186
|
}
|
|
@@ -211,8 +205,8 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
211
205
|
return {
|
|
212
206
|
displayText,
|
|
213
207
|
key: value,
|
|
214
|
-
count: data
|
|
215
|
-
state: data
|
|
208
|
+
count: data?.count,
|
|
209
|
+
state: data?.state,
|
|
216
210
|
};
|
|
217
211
|
});
|
|
218
212
|
return {
|
|
@@ -236,10 +230,9 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
236
230
|
let sortedBuckets = currentAggregation.getSortedBuckets(this.sortedBy);
|
|
237
231
|
if (this.facetKey === 'collection') {
|
|
238
232
|
// we are not showing fav- collections or certain deemphasized collections in facets
|
|
239
|
-
sortedBuckets = sortedBuckets
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
return (!suppressedCollections[bucketKey] && !(bucketKey === null || bucketKey === void 0 ? void 0 : bucketKey.startsWith('fav-')));
|
|
233
|
+
sortedBuckets = sortedBuckets?.filter(bucket => {
|
|
234
|
+
const bucketKey = bucket?.key?.toString();
|
|
235
|
+
return (!suppressedCollections[bucketKey] && !bucketKey?.startsWith('fav-'));
|
|
243
236
|
});
|
|
244
237
|
}
|
|
245
238
|
// Construct the array of facet buckets from the aggregation buckets
|
|
@@ -274,66 +267,65 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
274
267
|
};
|
|
275
268
|
}
|
|
276
269
|
get moreFacetsTemplate() {
|
|
277
|
-
return html `
|
|
278
|
-
<facets-template
|
|
279
|
-
.facetGroup=${this.facetGroupForCurrentPage}
|
|
280
|
-
.selectedFacets=${this.selectedFacets}
|
|
281
|
-
.collectionTitles=${this.collectionTitles}
|
|
270
|
+
return html `
|
|
271
|
+
<facets-template
|
|
272
|
+
.facetGroup=${this.facetGroupForCurrentPage}
|
|
273
|
+
.selectedFacets=${this.selectedFacets}
|
|
274
|
+
.collectionTitles=${this.collectionTitles}
|
|
282
275
|
@facetClick=${(e) => {
|
|
283
276
|
if (this.facetKey) {
|
|
284
277
|
this.unappliedFacetChanges = updateSelectedFacetBucket(this.unappliedFacetChanges, this.facetKey, e.detail.bucket);
|
|
285
278
|
}
|
|
286
|
-
}}
|
|
287
|
-
></facets-template>
|
|
279
|
+
}}
|
|
280
|
+
></facets-template>
|
|
288
281
|
`;
|
|
289
282
|
}
|
|
290
283
|
get loaderTemplate() {
|
|
291
|
-
return html `
|
|
292
|
-
<ia-status-indicator
|
|
293
|
-
class="facets-loader"
|
|
294
|
-
mode="loading"
|
|
295
|
-
></ia-status-indicator>
|
|
284
|
+
return html `
|
|
285
|
+
<ia-status-indicator
|
|
286
|
+
class="facets-loader"
|
|
287
|
+
mode="loading"
|
|
288
|
+
></ia-status-indicator>
|
|
296
289
|
`;
|
|
297
290
|
}
|
|
298
291
|
/**
|
|
299
292
|
* How many pages of facets to show in the modal pagination widget
|
|
300
293
|
*/
|
|
301
294
|
get paginationSize() {
|
|
302
|
-
var _a;
|
|
303
295
|
if (!this.aggregations || !this.facetKey)
|
|
304
296
|
return 0;
|
|
305
297
|
// Calculate the appropriate number of pages to show in the modal pagination widget
|
|
306
|
-
const length =
|
|
298
|
+
const length = this.aggregations[this.facetKey]?.buckets.length;
|
|
307
299
|
return Math.ceil(length / this.facetsPerPage);
|
|
308
300
|
}
|
|
309
301
|
// render pagination if more then 1 page
|
|
310
302
|
get facetsPaginationTemplate() {
|
|
311
303
|
return this.paginationSize > 1
|
|
312
|
-
? html `<more-facets-pagination
|
|
313
|
-
.size=${this.paginationSize}
|
|
314
|
-
.currentPage=${1}
|
|
315
|
-
@pageNumberClicked=${this.pageNumberClicked}
|
|
304
|
+
? html `<more-facets-pagination
|
|
305
|
+
.size=${this.paginationSize}
|
|
306
|
+
.currentPage=${1}
|
|
307
|
+
@pageNumberClicked=${this.pageNumberClicked}
|
|
316
308
|
></more-facets-pagination>`
|
|
317
309
|
: nothing;
|
|
318
310
|
}
|
|
319
311
|
get footerTemplate() {
|
|
320
312
|
if (this.paginationSize > 0) {
|
|
321
|
-
return html `${this.facetsPaginationTemplate}
|
|
322
|
-
<div class="footer">
|
|
323
|
-
<button
|
|
324
|
-
class="btn btn-cancel"
|
|
325
|
-
type="button"
|
|
326
|
-
@click=${this.cancelClick}
|
|
327
|
-
>
|
|
328
|
-
Cancel
|
|
329
|
-
</button>
|
|
330
|
-
<button
|
|
331
|
-
class="btn btn-submit"
|
|
332
|
-
type="button"
|
|
333
|
-
@click=${this.applySearchFacetsClicked}
|
|
334
|
-
>
|
|
335
|
-
Apply filters
|
|
336
|
-
</button>
|
|
313
|
+
return html `${this.facetsPaginationTemplate}
|
|
314
|
+
<div class="footer">
|
|
315
|
+
<button
|
|
316
|
+
class="btn btn-cancel"
|
|
317
|
+
type="button"
|
|
318
|
+
@click=${this.cancelClick}
|
|
319
|
+
>
|
|
320
|
+
Cancel
|
|
321
|
+
</button>
|
|
322
|
+
<button
|
|
323
|
+
class="btn btn-submit"
|
|
324
|
+
type="button"
|
|
325
|
+
@click=${this.applySearchFacetsClicked}
|
|
326
|
+
>
|
|
327
|
+
Apply filters
|
|
328
|
+
</button>
|
|
337
329
|
</div> `;
|
|
338
330
|
}
|
|
339
331
|
return nothing;
|
|
@@ -343,44 +335,42 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
343
335
|
this.dispatchEvent(new CustomEvent('sortedFacets', { detail: this.sortedBy }));
|
|
344
336
|
}
|
|
345
337
|
get modalHeaderTemplate() {
|
|
346
|
-
|
|
347
|
-
const facetSort = (_a = this.sortedBy) !== null && _a !== void 0 ? _a : defaultFacetSort[this.facetKey];
|
|
338
|
+
const facetSort = this.sortedBy ?? defaultFacetSort[this.facetKey];
|
|
348
339
|
const defaultSwitchSide = facetSort === AggregationSortType.COUNT ? 'left' : 'right';
|
|
349
|
-
return html `<span class="sr-only">${msg('More facets for:')}</span>
|
|
350
|
-
<span class="title">
|
|
351
|
-
${
|
|
352
|
-
|
|
353
|
-
<label class="sort-label">${msg('Sort by:')}</label>
|
|
340
|
+
return html `<span class="sr-only">${msg('More facets for:')}</span>
|
|
341
|
+
<span class="title">
|
|
342
|
+
${this.facetGroup?.title}
|
|
343
|
+
|
|
344
|
+
<label class="sort-label">${msg('Sort by:')}</label>
|
|
354
345
|
${this.facetKey
|
|
355
|
-
? html `<toggle-switch
|
|
356
|
-
class="sort-toggle"
|
|
357
|
-
leftValue=${AggregationSortType.COUNT}
|
|
358
|
-
leftLabel="Count"
|
|
359
|
-
rightValue=${valueFacetSort[this.facetKey]}
|
|
360
|
-
.rightLabel=${
|
|
361
|
-
side=${defaultSwitchSide}
|
|
346
|
+
? html `<toggle-switch
|
|
347
|
+
class="sort-toggle"
|
|
348
|
+
leftValue=${AggregationSortType.COUNT}
|
|
349
|
+
leftLabel="Count"
|
|
350
|
+
rightValue=${valueFacetSort[this.facetKey]}
|
|
351
|
+
.rightLabel=${this.facetGroup?.title}
|
|
352
|
+
side=${defaultSwitchSide}
|
|
362
353
|
@change=${(e) => {
|
|
363
354
|
this.sortFacetAggregation(Number(e.detail));
|
|
364
|
-
}}
|
|
355
|
+
}}
|
|
365
356
|
></toggle-switch>`
|
|
366
|
-
: nothing}
|
|
357
|
+
: nothing}
|
|
367
358
|
</span>`;
|
|
368
359
|
}
|
|
369
360
|
render() {
|
|
370
|
-
return html `
|
|
361
|
+
return html `
|
|
371
362
|
${this.facetsLoading
|
|
372
363
|
? this.loaderTemplate
|
|
373
|
-
: html `
|
|
374
|
-
<section id="more-facets">
|
|
375
|
-
<div class="header-content">${this.modalHeaderTemplate}</div>
|
|
376
|
-
<div class="facets-content">${this.moreFacetsTemplate}</div>
|
|
377
|
-
${this.footerTemplate}
|
|
378
|
-
</section>
|
|
379
|
-
`}
|
|
364
|
+
: html `
|
|
365
|
+
<section id="more-facets">
|
|
366
|
+
<div class="header-content">${this.modalHeaderTemplate}</div>
|
|
367
|
+
<div class="facets-content">${this.moreFacetsTemplate}</div>
|
|
368
|
+
${this.footerTemplate}
|
|
369
|
+
</section>
|
|
370
|
+
`}
|
|
380
371
|
`;
|
|
381
372
|
}
|
|
382
373
|
applySearchFacetsClicked() {
|
|
383
|
-
var _a, _b;
|
|
384
374
|
const mergedSelections = mergeSelectedFacets(this.selectedFacets, this.unappliedFacetChanges);
|
|
385
375
|
const event = new CustomEvent('facetsChanged', {
|
|
386
376
|
detail: mergedSelections,
|
|
@@ -390,19 +380,18 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
390
380
|
this.dispatchEvent(event);
|
|
391
381
|
// Reset the unapplied changes back to default, now that they have been applied
|
|
392
382
|
this.unappliedFacetChanges = getDefaultSelectedFacets();
|
|
393
|
-
|
|
394
|
-
|
|
383
|
+
this.modalManager?.closeModal();
|
|
384
|
+
this.analyticsHandler?.sendEvent({
|
|
395
385
|
category: analyticsCategories.default,
|
|
396
386
|
action: `${analyticsActions.applyMoreFacetsModal}`,
|
|
397
387
|
label: `${this.facetKey}`,
|
|
398
388
|
});
|
|
399
389
|
}
|
|
400
390
|
cancelClick() {
|
|
401
|
-
var _a, _b;
|
|
402
391
|
// Reset the unapplied changes back to default
|
|
403
392
|
this.unappliedFacetChanges = getDefaultSelectedFacets();
|
|
404
|
-
|
|
405
|
-
|
|
393
|
+
this.modalManager?.closeModal();
|
|
394
|
+
this.analyticsHandler?.sendEvent({
|
|
406
395
|
category: analyticsCategories.default,
|
|
407
396
|
action: analyticsActions.closeMoreFacetsModal,
|
|
408
397
|
label: `${this.facetKey}`,
|
|
@@ -412,73 +401,73 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
412
401
|
const modalSubmitButton = css `var(--primaryButtonBGColor, #194880)`;
|
|
413
402
|
return [
|
|
414
403
|
srOnlyStyle,
|
|
415
|
-
css `
|
|
416
|
-
section#more-facets {
|
|
417
|
-
overflow: auto;
|
|
418
|
-
padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */
|
|
419
|
-
--facetsColumnCount: 3;
|
|
420
|
-
}
|
|
421
|
-
.header-content .title {
|
|
422
|
-
display: block;
|
|
423
|
-
text-align: left;
|
|
424
|
-
font-size: 1.8rem;
|
|
425
|
-
padding: 0 10px;
|
|
426
|
-
font-weight: bold;
|
|
427
|
-
}
|
|
428
|
-
|
|
429
|
-
.sort-label {
|
|
430
|
-
margin-left: 20px;
|
|
431
|
-
font-size: 1.3rem;
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
.sort-toggle {
|
|
435
|
-
font-weight: normal;
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
.facets-content {
|
|
439
|
-
font-size: 1.2rem;
|
|
440
|
-
max-height: 300px;
|
|
441
|
-
overflow: auto;
|
|
442
|
-
padding: 10px;
|
|
443
|
-
}
|
|
444
|
-
.facets-loader {
|
|
445
|
-
--icon-width: 70px;
|
|
446
|
-
margin-bottom: 20px;
|
|
447
|
-
display: block;
|
|
448
|
-
margin-left: auto;
|
|
449
|
-
margin-right: auto;
|
|
450
|
-
}
|
|
451
|
-
.btn {
|
|
452
|
-
border: none;
|
|
453
|
-
padding: 10px;
|
|
454
|
-
margin-bottom: 10px;
|
|
455
|
-
width: auto;
|
|
456
|
-
border-radius: 4px;
|
|
457
|
-
cursor: pointer;
|
|
458
|
-
}
|
|
459
|
-
.btn-cancel {
|
|
460
|
-
background-color: #2c2c2c;
|
|
461
|
-
color: white;
|
|
462
|
-
}
|
|
463
|
-
.btn-submit {
|
|
464
|
-
background-color: ${modalSubmitButton};
|
|
465
|
-
color: white;
|
|
466
|
-
}
|
|
467
|
-
.footer {
|
|
468
|
-
text-align: center;
|
|
469
|
-
margin-top: 10px;
|
|
470
|
-
}
|
|
471
|
-
|
|
472
|
-
@media (max-width: 560px) {
|
|
473
|
-
section#more-facets {
|
|
474
|
-
max-height: 450px;
|
|
475
|
-
--facetsColumnCount: 1;
|
|
476
|
-
}
|
|
477
|
-
.facets-content {
|
|
478
|
-
overflow-y: auto;
|
|
479
|
-
height: 300px;
|
|
480
|
-
}
|
|
481
|
-
}
|
|
404
|
+
css `
|
|
405
|
+
section#more-facets {
|
|
406
|
+
overflow: auto;
|
|
407
|
+
padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */
|
|
408
|
+
--facetsColumnCount: 3;
|
|
409
|
+
}
|
|
410
|
+
.header-content .title {
|
|
411
|
+
display: block;
|
|
412
|
+
text-align: left;
|
|
413
|
+
font-size: 1.8rem;
|
|
414
|
+
padding: 0 10px;
|
|
415
|
+
font-weight: bold;
|
|
416
|
+
}
|
|
417
|
+
|
|
418
|
+
.sort-label {
|
|
419
|
+
margin-left: 20px;
|
|
420
|
+
font-size: 1.3rem;
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
.sort-toggle {
|
|
424
|
+
font-weight: normal;
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
.facets-content {
|
|
428
|
+
font-size: 1.2rem;
|
|
429
|
+
max-height: 300px;
|
|
430
|
+
overflow: auto;
|
|
431
|
+
padding: 10px;
|
|
432
|
+
}
|
|
433
|
+
.facets-loader {
|
|
434
|
+
--icon-width: 70px;
|
|
435
|
+
margin-bottom: 20px;
|
|
436
|
+
display: block;
|
|
437
|
+
margin-left: auto;
|
|
438
|
+
margin-right: auto;
|
|
439
|
+
}
|
|
440
|
+
.btn {
|
|
441
|
+
border: none;
|
|
442
|
+
padding: 10px;
|
|
443
|
+
margin-bottom: 10px;
|
|
444
|
+
width: auto;
|
|
445
|
+
border-radius: 4px;
|
|
446
|
+
cursor: pointer;
|
|
447
|
+
}
|
|
448
|
+
.btn-cancel {
|
|
449
|
+
background-color: #2c2c2c;
|
|
450
|
+
color: white;
|
|
451
|
+
}
|
|
452
|
+
.btn-submit {
|
|
453
|
+
background-color: ${modalSubmitButton};
|
|
454
|
+
color: white;
|
|
455
|
+
}
|
|
456
|
+
.footer {
|
|
457
|
+
text-align: center;
|
|
458
|
+
margin-top: 10px;
|
|
459
|
+
}
|
|
460
|
+
|
|
461
|
+
@media (max-width: 560px) {
|
|
462
|
+
section#more-facets {
|
|
463
|
+
max-height: 450px;
|
|
464
|
+
--facetsColumnCount: 1;
|
|
465
|
+
}
|
|
466
|
+
.facets-content {
|
|
467
|
+
overflow-y: auto;
|
|
468
|
+
height: 300px;
|
|
469
|
+
}
|
|
470
|
+
}
|
|
482
471
|
`,
|
|
483
472
|
];
|
|
484
473
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"more-facets-content.js","sourceRoot":"","sources":["../../../src/collection-facets/more-facets-content.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n LitElement,\n nothing,\n PropertyValues,\n TemplateResult,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport {\n Aggregation,\n Bucket,\n SearchServiceInterface,\n SearchParams,\n SearchType,\n AggregationSortType,\n FilterMap,\n PageType,\n} from '@internetarchive/search-service';\nimport type { ModalManagerInterface } from '@internetarchive/modal-manager';\nimport type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';\nimport { msg } from '@lit/localize';\nimport {\n SelectedFacets,\n FacetGroup,\n FacetBucket,\n FacetOption,\n facetTitles,\n suppressedCollections,\n valueFacetSort,\n defaultFacetSort,\n getDefaultSelectedFacets,\n FacetEventDetails,\n} from '../models';\nimport type {\n CollectionTitles,\n PageSpecifierParams,\n TVChannelAliases,\n} from '../data-source/models';\nimport '@internetarchive/elements/ia-status-indicator/ia-status-indicator';\nimport './more-facets-pagination';\nimport './facets-template';\nimport {\n analyticsActions,\n analyticsCategories,\n} from '../utils/analytics-events';\nimport './toggle-switch';\nimport { srOnlyStyle } from '../styles/sr-only';\nimport {\n mergeSelectedFacets,\n sortBucketsBySelectionState,\n updateSelectedFacetBucket,\n} from '../utils/facet-utils';\nimport {\n MORE_FACETS__DEFAULT_PAGE_SIZE,\n MORE_FACETS__MAX_AGGREGATIONS,\n} from './models';\n\n@customElement('more-facets-content')\nexport class MoreFacetsContent extends LitElement {\n @property({ type: String }) facetKey?: FacetOption;\n\n @property({ type: String }) query?: string;\n\n @property({ type: Array }) identifiers?: string[];\n\n @property({ type: Object }) filterMap?: FilterMap;\n\n @property({ type: Number }) searchType?: SearchType;\n\n @property({ type: Object }) pageSpecifierParams?: PageSpecifierParams;\n\n @property({ type: Object })\n collectionTitles?: CollectionTitles;\n\n @property({ type: Object })\n tvChannelAliases?: TVChannelAliases;\n\n /**\n * Maximum number of facets to show per page within the modal.\n */\n @property({ type: Number }) facetsPerPage = MORE_FACETS__DEFAULT_PAGE_SIZE;\n\n /**\n * Whether we are waiting for facet data to load.\n * We begin with this set to true so that we show an initial loading indicator.\n */\n @property({ type: Boolean }) facetsLoading = true;\n\n /**\n * The set of pre-existing facet selections (including both selected & negated facets).\n */\n @property({ type: Object }) selectedFacets?: SelectedFacets;\n\n @property({ type: Number }) sortedBy: AggregationSortType =\n AggregationSortType.COUNT;\n\n @property({ type: Boolean }) isTvSearch = false;\n\n @property({ type: Object }) modalManager?: ModalManagerInterface;\n\n @property({ type: Object }) searchService?: SearchServiceInterface;\n\n @property({ type: Object, attribute: false })\n analyticsHandler?: AnalyticsManagerInterface;\n\n /**\n * The full set of aggregations received from the search service\n */\n @state() private aggregations?: Record<string, Aggregation>;\n\n /**\n * A FacetGroup storing the full set of facet buckets to be shown on the dialog.\n */\n @state() private facetGroup?: FacetGroup;\n\n /**\n * An object holding any changes the patron has made to their facet selections\n * within the modal dialog but which they have not yet applied. These are\n * eventually merged into the existing `selectedFacets` when the patron applies\n * their changes, or discarded if they cancel/close the dialog.\n */\n @state() private unappliedFacetChanges: SelectedFacets =\n getDefaultSelectedFacets();\n\n /**\n * Which page of facets we are showing.\n */\n @state() private pageNumber = 1;\n\n willUpdate(changed: PropertyValues): void {\n if (\n changed.has('aggregations') ||\n changed.has('facetsPerPage') ||\n changed.has('sortedBy') ||\n changed.has('selectedFacets') ||\n changed.has('unappliedFacetChanges')\n ) {\n // Convert the merged selected facets & aggregations into a facet group, and\n // store it for reuse across pages.\n this.facetGroup = this.mergedFacets;\n }\n }\n\n updated(changed: PropertyValues): void {\n // If any of the search properties change, it triggers a facet fetch\n if (\n changed.has('facetKey') ||\n changed.has('query') ||\n changed.has('searchType') ||\n changed.has('filterMap')\n ) {\n this.facetsLoading = true;\n this.pageNumber = 1;\n this.sortedBy = defaultFacetSort[this.facetKey as FacetOption];\n\n this.updateSpecificFacets();\n }\n }\n\n firstUpdated(): void {\n this.setupEscapeListeners();\n }\n\n /**\n * Close more facets modal on Escape click\n */\n private setupEscapeListeners() {\n if (this.modalManager) {\n document.addEventListener('keydown', (e: KeyboardEvent) => {\n if (e.key === 'Escape') {\n this.modalManager?.closeModal();\n }\n });\n } else {\n document.removeEventListener('keydown', () => {});\n }\n }\n\n /**\n * Whether facet requests are for the search_results page type (either defaulted or explicitly).\n */\n private get isSearchResultsPage(): boolean {\n // Default page type is search_results when none is specified, so we check\n // for undefined as well.\n const pageType: PageType | undefined = this.pageSpecifierParams?.pageType;\n return pageType === undefined || pageType === 'search_results';\n }\n\n /**\n * Get specific facets data from search-service API based of currently query params\n * - this.aggregations - hold result of search service and being used for further processing.\n */\n async updateSpecificFacets(): Promise<void> {\n if (!this.facetKey) return; // Can't fetch facets if we don't know what type of facets we need!\n\n const trimmedQuery = this.query?.trim();\n if (!trimmedQuery && this.isSearchResultsPage) return; // The search page _requires_ a query\n\n const aggregations = {\n simpleParams: [this.facetKey],\n };\n const aggregationsSize = MORE_FACETS__MAX_AGGREGATIONS; // Only request the 10K highest-count facets\n\n const params: SearchParams = {\n ...this.pageSpecifierParams,\n query: trimmedQuery || '',\n identifiers: this.identifiers,\n filters: this.filterMap,\n aggregations,\n aggregationsSize,\n rows: 0, // todo - do we want server-side pagination with offset/page/limit flag?\n };\n\n const results = await this.searchService?.search(params, this.searchType);\n this.aggregations = results?.success?.response.aggregations;\n this.facetsLoading = false;\n\n const collectionTitles = results?.success?.response?.collectionTitles;\n if (collectionTitles) {\n for (const [id, title] of Object.entries(collectionTitles)) {\n this.collectionTitles?.set(id, title);\n }\n }\n }\n\n /**\n * Handler for page number changes from the pagination widget.\n */\n private pageNumberClicked(e: CustomEvent<{ page: number }>) {\n const page = e?.detail?.page;\n if (page) {\n this.pageNumber = Number(page);\n }\n\n this.analyticsHandler?.sendEvent({\n category: analyticsCategories.default,\n action: analyticsActions.moreFacetsPageChange,\n label: `${this.pageNumber}`,\n });\n }\n\n /**\n * Combines the selected facets with the aggregations to create a single list of facets\n */\n private get mergedFacets(): FacetGroup | undefined {\n if (!this.facetKey || !this.selectedFacets) return undefined;\n\n const { selectedFacetGroup, aggregationFacetGroup } = this;\n\n // If we don't have any aggregations, then there is nothing to show yet\n if (!aggregationFacetGroup) return undefined;\n\n // Start with either the selected group if we have one, or the aggregate group otherwise\n const facetGroup = { ...(selectedFacetGroup ?? aggregationFacetGroup) };\n\n // Attach the counts to the selected buckets\n const bucketsWithCount =\n selectedFacetGroup?.buckets.map(bucket => {\n const selectedBucket = aggregationFacetGroup.buckets.find(\n b => b.key === bucket.key,\n );\n return selectedBucket\n ? {\n ...bucket,\n count: selectedBucket.count,\n }\n : bucket;\n }) ?? [];\n\n // Sort the buckets by selection state\n // We do this *prior* to considering unapplied selections, because we want the facets\n // to remain in position when they are selected/unselected, rather than re-sort themselves.\n sortBucketsBySelectionState(bucketsWithCount, this.sortedBy);\n\n // Append any additional buckets that were not selected\n aggregationFacetGroup.buckets.forEach(bucket => {\n const existingBucket = selectedFacetGroup?.buckets.find(\n b => b.key === bucket.key,\n );\n if (existingBucket) return;\n bucketsWithCount.push(bucket);\n });\n\n // Apply any unapplied selections that appear on this page\n const unappliedBuckets = this.unappliedFacetChanges[this.facetKey];\n for (const [index, bucket] of bucketsWithCount.entries()) {\n const unappliedBucket = unappliedBuckets?.[bucket.key];\n if (unappliedBucket) {\n bucketsWithCount[index] = { ...unappliedBucket };\n }\n }\n\n // For TV creator facets, uppercase the display text\n if (this.facetKey === 'creator' && this.isTvSearch) {\n bucketsWithCount.forEach(b => {\n b.displayText = (b.displayText ?? b.key)?.toLocaleUpperCase();\n\n const channelLabel = this.tvChannelAliases?.get(b.displayText);\n if (channelLabel && channelLabel !== b.displayText) {\n b.extraNote = `(${channelLabel})`;\n }\n });\n }\n\n facetGroup.buckets = bucketsWithCount;\n return facetGroup;\n }\n\n /**\n * Converts the selected facets for the current facet key to a `FacetGroup`,\n * which is easier to work with.\n */\n private get selectedFacetGroup(): FacetGroup | undefined {\n if (!this.selectedFacets || !this.facetKey) return undefined;\n\n const selectedFacetsForKey = this.selectedFacets[this.facetKey];\n if (!selectedFacetsForKey) return undefined;\n\n const facetGroupTitle = facetTitles[this.facetKey];\n\n const buckets: FacetBucket[] = Object.entries(selectedFacetsForKey).map(\n ([value, data]) => {\n const displayText: string = value;\n return {\n displayText,\n key: value,\n count: data?.count,\n state: data?.state,\n };\n },\n );\n\n return {\n title: facetGroupTitle,\n key: this.facetKey,\n buckets,\n };\n }\n\n /**\n * Converts the raw `aggregations` for the current facet key to a `FacetGroup`,\n * which is easier to work with.\n */\n private get aggregationFacetGroup(): FacetGroup | undefined {\n if (!this.aggregations || !this.facetKey) return undefined;\n\n const currentAggregation = this.aggregations[this.facetKey];\n if (!currentAggregation) return undefined;\n\n const facetGroupTitle = facetTitles[this.facetKey];\n\n // Order the facets according to the current sort option\n let sortedBuckets = currentAggregation.getSortedBuckets(\n this.sortedBy,\n ) as Bucket[];\n\n if (this.facetKey === 'collection') {\n // we are not showing fav- collections or certain deemphasized collections in facets\n sortedBuckets = sortedBuckets?.filter(bucket => {\n const bucketKey = bucket?.key?.toString();\n return (\n !suppressedCollections[bucketKey] && !bucketKey?.startsWith('fav-')\n );\n });\n }\n\n // Construct the array of facet buckets from the aggregation buckets\n const facetBuckets: FacetBucket[] = sortedBuckets.map(bucket => {\n const bucketKeyStr = `${bucket.key}`;\n return {\n displayText: `${bucketKeyStr}`,\n key: `${bucketKeyStr}`,\n count: bucket.doc_count,\n state: 'none',\n };\n });\n\n return {\n title: facetGroupTitle,\n key: this.facetKey,\n buckets: facetBuckets,\n };\n }\n\n /**\n * Returns a FacetGroup representing only the current page of facet buckets to show.\n */\n private get facetGroupForCurrentPage(): FacetGroup | undefined {\n const { facetGroup } = this;\n if (!facetGroup) return undefined;\n\n // Slice out only the current page of facet buckets\n const firstBucketIndexOnPage = (this.pageNumber - 1) * this.facetsPerPage;\n const truncatedBuckets = facetGroup.buckets.slice(\n firstBucketIndexOnPage,\n firstBucketIndexOnPage + this.facetsPerPage,\n );\n\n return {\n ...facetGroup,\n buckets: truncatedBuckets,\n };\n }\n\n private get moreFacetsTemplate(): TemplateResult {\n return html`\n <facets-template\n .facetGroup=${this.facetGroupForCurrentPage}\n .selectedFacets=${this.selectedFacets}\n .collectionTitles=${this.collectionTitles}\n @facetClick=${(e: CustomEvent<FacetEventDetails>) => {\n if (this.facetKey) {\n this.unappliedFacetChanges = updateSelectedFacetBucket(\n this.unappliedFacetChanges,\n this.facetKey,\n e.detail.bucket,\n );\n }\n }}\n ></facets-template>\n `;\n }\n\n private get loaderTemplate(): TemplateResult {\n return html`\n <ia-status-indicator\n class=\"facets-loader\"\n mode=\"loading\"\n ></ia-status-indicator>\n `;\n }\n\n /**\n * How many pages of facets to show in the modal pagination widget\n */\n private get paginationSize(): number {\n if (!this.aggregations || !this.facetKey) return 0;\n\n // Calculate the appropriate number of pages to show in the modal pagination widget\n const length = this.aggregations[this.facetKey]?.buckets.length;\n return Math.ceil(length / this.facetsPerPage);\n }\n\n // render pagination if more then 1 page\n private get facetsPaginationTemplate() {\n return this.paginationSize > 1\n ? html`<more-facets-pagination\n .size=${this.paginationSize}\n .currentPage=${1}\n @pageNumberClicked=${this.pageNumberClicked}\n ></more-facets-pagination>`\n : nothing;\n }\n\n private get footerTemplate() {\n if (this.paginationSize > 0) {\n return html`${this.facetsPaginationTemplate}\n <div class=\"footer\">\n <button\n class=\"btn btn-cancel\"\n type=\"button\"\n @click=${this.cancelClick}\n >\n Cancel\n </button>\n <button\n class=\"btn btn-submit\"\n type=\"button\"\n @click=${this.applySearchFacetsClicked}\n >\n Apply filters\n </button>\n </div> `;\n }\n\n return nothing;\n }\n\n private sortFacetAggregation(facetSortType: AggregationSortType) {\n this.sortedBy = facetSortType;\n this.dispatchEvent(\n new CustomEvent('sortedFacets', { detail: this.sortedBy }),\n );\n }\n\n private get modalHeaderTemplate(): TemplateResult {\n const facetSort =\n this.sortedBy ?? defaultFacetSort[this.facetKey as FacetOption];\n const defaultSwitchSide =\n facetSort === AggregationSortType.COUNT ? 'left' : 'right';\n\n return html`<span class=\"sr-only\">${msg('More facets for:')}</span>\n <span class=\"title\">\n ${this.facetGroup?.title}\n\n <label class=\"sort-label\">${msg('Sort by:')}</label>\n ${this.facetKey\n ? html`<toggle-switch\n class=\"sort-toggle\"\n leftValue=${AggregationSortType.COUNT}\n leftLabel=\"Count\"\n rightValue=${valueFacetSort[this.facetKey]}\n .rightLabel=${this.facetGroup?.title}\n side=${defaultSwitchSide}\n @change=${(e: CustomEvent<string>) => {\n this.sortFacetAggregation(\n Number(e.detail) as AggregationSortType,\n );\n }}\n ></toggle-switch>`\n : nothing}\n </span>`;\n }\n\n render() {\n return html`\n ${this.facetsLoading\n ? this.loaderTemplate\n : html`\n <section id=\"more-facets\">\n <div class=\"header-content\">${this.modalHeaderTemplate}</div>\n <div class=\"facets-content\">${this.moreFacetsTemplate}</div>\n ${this.footerTemplate}\n </section>\n `}\n `;\n }\n\n private applySearchFacetsClicked() {\n const mergedSelections = mergeSelectedFacets(\n this.selectedFacets,\n this.unappliedFacetChanges,\n );\n\n const event = new CustomEvent<SelectedFacets>('facetsChanged', {\n detail: mergedSelections,\n bubbles: true,\n composed: true,\n });\n this.dispatchEvent(event);\n\n // Reset the unapplied changes back to default, now that they have been applied\n this.unappliedFacetChanges = getDefaultSelectedFacets();\n\n this.modalManager?.closeModal();\n this.analyticsHandler?.sendEvent({\n category: analyticsCategories.default,\n action: `${analyticsActions.applyMoreFacetsModal}`,\n label: `${this.facetKey}`,\n });\n }\n\n private cancelClick() {\n // Reset the unapplied changes back to default\n this.unappliedFacetChanges = getDefaultSelectedFacets();\n\n this.modalManager?.closeModal();\n this.analyticsHandler?.sendEvent({\n category: analyticsCategories.default,\n action: analyticsActions.closeMoreFacetsModal,\n label: `${this.facetKey}`,\n });\n }\n\n static get styles(): CSSResultGroup {\n const modalSubmitButton = css`var(--primaryButtonBGColor, #194880)`;\n\n return [\n srOnlyStyle,\n css`\n section#more-facets {\n overflow: auto;\n padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */\n --facetsColumnCount: 3;\n }\n .header-content .title {\n display: block;\n text-align: left;\n font-size: 1.8rem;\n padding: 0 10px;\n font-weight: bold;\n }\n\n .sort-label {\n margin-left: 20px;\n font-size: 1.3rem;\n }\n\n .sort-toggle {\n font-weight: normal;\n }\n\n .facets-content {\n font-size: 1.2rem;\n max-height: 300px;\n overflow: auto;\n padding: 10px;\n }\n .facets-loader {\n --icon-width: 70px;\n margin-bottom: 20px;\n display: block;\n margin-left: auto;\n margin-right: auto;\n }\n .btn {\n border: none;\n padding: 10px;\n margin-bottom: 10px;\n width: auto;\n border-radius: 4px;\n cursor: pointer;\n }\n .btn-cancel {\n background-color: #2c2c2c;\n color: white;\n }\n .btn-submit {\n background-color: ${modalSubmitButton};\n color: white;\n }\n .footer {\n text-align: center;\n margin-top: 10px;\n }\n\n @media (max-width: 560px) {\n section#more-facets {\n max-height: 450px;\n --facetsColumnCount: 1;\n }\n .facets-content {\n overflow-y: auto;\n height: 300px;\n }\n }\n `,\n ];\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"more-facets-content.js","sourceRoot":"","sources":["../../../src/collection-facets/more-facets-content.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n css,\r\n CSSResultGroup,\r\n html,\r\n LitElement,\r\n nothing,\r\n PropertyValues,\r\n TemplateResult,\r\n} from 'lit';\r\nimport { customElement, property, state } from 'lit/decorators.js';\r\nimport {\r\n Aggregation,\r\n Bucket,\r\n SearchServiceInterface,\r\n SearchParams,\r\n SearchType,\r\n AggregationSortType,\r\n FilterMap,\r\n PageType,\r\n} from '@internetarchive/search-service';\r\nimport type { ModalManagerInterface } from '@internetarchive/modal-manager';\r\nimport type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';\r\nimport { msg } from '@lit/localize';\r\nimport {\r\n SelectedFacets,\r\n FacetGroup,\r\n FacetBucket,\r\n FacetOption,\r\n facetTitles,\r\n suppressedCollections,\r\n valueFacetSort,\r\n defaultFacetSort,\r\n getDefaultSelectedFacets,\r\n FacetEventDetails,\r\n} from '../models';\r\nimport type {\r\n CollectionTitles,\r\n PageSpecifierParams,\r\n TVChannelAliases,\r\n} from '../data-source/models';\r\nimport '@internetarchive/elements/ia-status-indicator/ia-status-indicator';\r\nimport './more-facets-pagination';\r\nimport './facets-template';\r\nimport {\r\n analyticsActions,\r\n analyticsCategories,\r\n} from '../utils/analytics-events';\r\nimport './toggle-switch';\r\nimport { srOnlyStyle } from '../styles/sr-only';\r\nimport {\r\n mergeSelectedFacets,\r\n sortBucketsBySelectionState,\r\n updateSelectedFacetBucket,\r\n} from '../utils/facet-utils';\r\nimport {\r\n MORE_FACETS__DEFAULT_PAGE_SIZE,\r\n MORE_FACETS__MAX_AGGREGATIONS,\r\n} from './models';\r\n\r\n@customElement('more-facets-content')\r\nexport class MoreFacetsContent extends LitElement {\r\n @property({ type: String }) facetKey?: FacetOption;\r\n\r\n @property({ type: String }) query?: string;\r\n\r\n @property({ type: Array }) identifiers?: string[];\r\n\r\n @property({ type: Object }) filterMap?: FilterMap;\r\n\r\n @property({ type: Number }) searchType?: SearchType;\r\n\r\n @property({ type: Object }) pageSpecifierParams?: PageSpecifierParams;\r\n\r\n @property({ type: Object })\r\n collectionTitles?: CollectionTitles;\r\n\r\n @property({ type: Object })\r\n tvChannelAliases?: TVChannelAliases;\r\n\r\n /**\r\n * Maximum number of facets to show per page within the modal.\r\n */\r\n @property({ type: Number }) facetsPerPage = MORE_FACETS__DEFAULT_PAGE_SIZE;\r\n\r\n /**\r\n * Whether we are waiting for facet data to load.\r\n * We begin with this set to true so that we show an initial loading indicator.\r\n */\r\n @property({ type: Boolean }) facetsLoading = true;\r\n\r\n /**\r\n * The set of pre-existing facet selections (including both selected & negated facets).\r\n */\r\n @property({ type: Object }) selectedFacets?: SelectedFacets;\r\n\r\n @property({ type: Number }) sortedBy: AggregationSortType =\r\n AggregationSortType.COUNT;\r\n\r\n @property({ type: Boolean }) isTvSearch = false;\r\n\r\n @property({ type: Object }) modalManager?: ModalManagerInterface;\r\n\r\n @property({ type: Object }) searchService?: SearchServiceInterface;\r\n\r\n @property({ type: Object, attribute: false })\r\n analyticsHandler?: AnalyticsManagerInterface;\r\n\r\n /**\r\n * The full set of aggregations received from the search service\r\n */\r\n @state() private aggregations?: Record<string, Aggregation>;\r\n\r\n /**\r\n * A FacetGroup storing the full set of facet buckets to be shown on the dialog.\r\n */\r\n @state() private facetGroup?: FacetGroup;\r\n\r\n /**\r\n * An object holding any changes the patron has made to their facet selections\r\n * within the modal dialog but which they have not yet applied. These are\r\n * eventually merged into the existing `selectedFacets` when the patron applies\r\n * their changes, or discarded if they cancel/close the dialog.\r\n */\r\n @state() private unappliedFacetChanges: SelectedFacets =\r\n getDefaultSelectedFacets();\r\n\r\n /**\r\n * Which page of facets we are showing.\r\n */\r\n @state() private pageNumber = 1;\r\n\r\n willUpdate(changed: PropertyValues): void {\r\n if (\r\n changed.has('aggregations') ||\r\n changed.has('facetsPerPage') ||\r\n changed.has('sortedBy') ||\r\n changed.has('selectedFacets') ||\r\n changed.has('unappliedFacetChanges')\r\n ) {\r\n // Convert the merged selected facets & aggregations into a facet group, and\r\n // store it for reuse across pages.\r\n this.facetGroup = this.mergedFacets;\r\n }\r\n }\r\n\r\n updated(changed: PropertyValues): void {\r\n // If any of the search properties change, it triggers a facet fetch\r\n if (\r\n changed.has('facetKey') ||\r\n changed.has('query') ||\r\n changed.has('searchType') ||\r\n changed.has('filterMap')\r\n ) {\r\n this.facetsLoading = true;\r\n this.pageNumber = 1;\r\n this.sortedBy = defaultFacetSort[this.facetKey as FacetOption];\r\n\r\n this.updateSpecificFacets();\r\n }\r\n }\r\n\r\n firstUpdated(): void {\r\n this.setupEscapeListeners();\r\n }\r\n\r\n /**\r\n * Close more facets modal on Escape click\r\n */\r\n private setupEscapeListeners() {\r\n if (this.modalManager) {\r\n document.addEventListener('keydown', (e: KeyboardEvent) => {\r\n if (e.key === 'Escape') {\r\n this.modalManager?.closeModal();\r\n }\r\n });\r\n } else {\r\n document.removeEventListener('keydown', () => {});\r\n }\r\n }\r\n\r\n /**\r\n * Whether facet requests are for the search_results page type (either defaulted or explicitly).\r\n */\r\n private get isSearchResultsPage(): boolean {\r\n // Default page type is search_results when none is specified, so we check\r\n // for undefined as well.\r\n const pageType: PageType | undefined = this.pageSpecifierParams?.pageType;\r\n return pageType === undefined || pageType === 'search_results';\r\n }\r\n\r\n /**\r\n * Get specific facets data from search-service API based of currently query params\r\n * - this.aggregations - hold result of search service and being used for further processing.\r\n */\r\n async updateSpecificFacets(): Promise<void> {\r\n if (!this.facetKey) return; // Can't fetch facets if we don't know what type of facets we need!\r\n\r\n const trimmedQuery = this.query?.trim();\r\n if (!trimmedQuery && this.isSearchResultsPage) return; // The search page _requires_ a query\r\n\r\n const aggregations = {\r\n simpleParams: [this.facetKey],\r\n };\r\n const aggregationsSize = MORE_FACETS__MAX_AGGREGATIONS; // Only request the 10K highest-count facets\r\n\r\n const params: SearchParams = {\r\n ...this.pageSpecifierParams,\r\n query: trimmedQuery || '',\r\n identifiers: this.identifiers,\r\n filters: this.filterMap,\r\n aggregations,\r\n aggregationsSize,\r\n rows: 0, // todo - do we want server-side pagination with offset/page/limit flag?\r\n };\r\n\r\n const results = await this.searchService?.search(params, this.searchType);\r\n this.aggregations = results?.success?.response.aggregations;\r\n this.facetsLoading = false;\r\n\r\n const collectionTitles = results?.success?.response?.collectionTitles;\r\n if (collectionTitles) {\r\n for (const [id, title] of Object.entries(collectionTitles)) {\r\n this.collectionTitles?.set(id, title);\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Handler for page number changes from the pagination widget.\r\n */\r\n private pageNumberClicked(e: CustomEvent<{ page: number }>) {\r\n const page = e?.detail?.page;\r\n if (page) {\r\n this.pageNumber = Number(page);\r\n }\r\n\r\n this.analyticsHandler?.sendEvent({\r\n category: analyticsCategories.default,\r\n action: analyticsActions.moreFacetsPageChange,\r\n label: `${this.pageNumber}`,\r\n });\r\n }\r\n\r\n /**\r\n * Combines the selected facets with the aggregations to create a single list of facets\r\n */\r\n private get mergedFacets(): FacetGroup | undefined {\r\n if (!this.facetKey || !this.selectedFacets) return undefined;\r\n\r\n const { selectedFacetGroup, aggregationFacetGroup } = this;\r\n\r\n // If we don't have any aggregations, then there is nothing to show yet\r\n if (!aggregationFacetGroup) return undefined;\r\n\r\n // Start with either the selected group if we have one, or the aggregate group otherwise\r\n const facetGroup = { ...(selectedFacetGroup ?? aggregationFacetGroup) };\r\n\r\n // Attach the counts to the selected buckets\r\n const bucketsWithCount =\r\n selectedFacetGroup?.buckets.map(bucket => {\r\n const selectedBucket = aggregationFacetGroup.buckets.find(\r\n b => b.key === bucket.key,\r\n );\r\n return selectedBucket\r\n ? {\r\n ...bucket,\r\n count: selectedBucket.count,\r\n }\r\n : bucket;\r\n }) ?? [];\r\n\r\n // Sort the buckets by selection state\r\n // We do this *prior* to considering unapplied selections, because we want the facets\r\n // to remain in position when they are selected/unselected, rather than re-sort themselves.\r\n sortBucketsBySelectionState(bucketsWithCount, this.sortedBy);\r\n\r\n // Append any additional buckets that were not selected\r\n aggregationFacetGroup.buckets.forEach(bucket => {\r\n const existingBucket = selectedFacetGroup?.buckets.find(\r\n b => b.key === bucket.key,\r\n );\r\n if (existingBucket) return;\r\n bucketsWithCount.push(bucket);\r\n });\r\n\r\n // Apply any unapplied selections that appear on this page\r\n const unappliedBuckets = this.unappliedFacetChanges[this.facetKey];\r\n for (const [index, bucket] of bucketsWithCount.entries()) {\r\n const unappliedBucket = unappliedBuckets?.[bucket.key];\r\n if (unappliedBucket) {\r\n bucketsWithCount[index] = { ...unappliedBucket };\r\n }\r\n }\r\n\r\n // For TV creator facets, uppercase the display text\r\n if (this.facetKey === 'creator' && this.isTvSearch) {\r\n bucketsWithCount.forEach(b => {\r\n b.displayText = (b.displayText ?? b.key)?.toLocaleUpperCase();\r\n\r\n const channelLabel = this.tvChannelAliases?.get(b.displayText);\r\n if (channelLabel && channelLabel !== b.displayText) {\r\n b.extraNote = `(${channelLabel})`;\r\n }\r\n });\r\n }\r\n\r\n facetGroup.buckets = bucketsWithCount;\r\n return facetGroup;\r\n }\r\n\r\n /**\r\n * Converts the selected facets for the current facet key to a `FacetGroup`,\r\n * which is easier to work with.\r\n */\r\n private get selectedFacetGroup(): FacetGroup | undefined {\r\n if (!this.selectedFacets || !this.facetKey) return undefined;\r\n\r\n const selectedFacetsForKey = this.selectedFacets[this.facetKey];\r\n if (!selectedFacetsForKey) return undefined;\r\n\r\n const facetGroupTitle = facetTitles[this.facetKey];\r\n\r\n const buckets: FacetBucket[] = Object.entries(selectedFacetsForKey).map(\r\n ([value, data]) => {\r\n const displayText: string = value;\r\n return {\r\n displayText,\r\n key: value,\r\n count: data?.count,\r\n state: data?.state,\r\n };\r\n },\r\n );\r\n\r\n return {\r\n title: facetGroupTitle,\r\n key: this.facetKey,\r\n buckets,\r\n };\r\n }\r\n\r\n /**\r\n * Converts the raw `aggregations` for the current facet key to a `FacetGroup`,\r\n * which is easier to work with.\r\n */\r\n private get aggregationFacetGroup(): FacetGroup | undefined {\r\n if (!this.aggregations || !this.facetKey) return undefined;\r\n\r\n const currentAggregation = this.aggregations[this.facetKey];\r\n if (!currentAggregation) return undefined;\r\n\r\n const facetGroupTitle = facetTitles[this.facetKey];\r\n\r\n // Order the facets according to the current sort option\r\n let sortedBuckets = currentAggregation.getSortedBuckets(\r\n this.sortedBy,\r\n ) as Bucket[];\r\n\r\n if (this.facetKey === 'collection') {\r\n // we are not showing fav- collections or certain deemphasized collections in facets\r\n sortedBuckets = sortedBuckets?.filter(bucket => {\r\n const bucketKey = bucket?.key?.toString();\r\n return (\r\n !suppressedCollections[bucketKey] && !bucketKey?.startsWith('fav-')\r\n );\r\n });\r\n }\r\n\r\n // Construct the array of facet buckets from the aggregation buckets\r\n const facetBuckets: FacetBucket[] = sortedBuckets.map(bucket => {\r\n const bucketKeyStr = `${bucket.key}`;\r\n return {\r\n displayText: `${bucketKeyStr}`,\r\n key: `${bucketKeyStr}`,\r\n count: bucket.doc_count,\r\n state: 'none',\r\n };\r\n });\r\n\r\n return {\r\n title: facetGroupTitle,\r\n key: this.facetKey,\r\n buckets: facetBuckets,\r\n };\r\n }\r\n\r\n /**\r\n * Returns a FacetGroup representing only the current page of facet buckets to show.\r\n */\r\n private get facetGroupForCurrentPage(): FacetGroup | undefined {\r\n const { facetGroup } = this;\r\n if (!facetGroup) return undefined;\r\n\r\n // Slice out only the current page of facet buckets\r\n const firstBucketIndexOnPage = (this.pageNumber - 1) * this.facetsPerPage;\r\n const truncatedBuckets = facetGroup.buckets.slice(\r\n firstBucketIndexOnPage,\r\n firstBucketIndexOnPage + this.facetsPerPage,\r\n );\r\n\r\n return {\r\n ...facetGroup,\r\n buckets: truncatedBuckets,\r\n };\r\n }\r\n\r\n private get moreFacetsTemplate(): TemplateResult {\r\n return html`\r\n <facets-template\r\n .facetGroup=${this.facetGroupForCurrentPage}\r\n .selectedFacets=${this.selectedFacets}\r\n .collectionTitles=${this.collectionTitles}\r\n @facetClick=${(e: CustomEvent<FacetEventDetails>) => {\r\n if (this.facetKey) {\r\n this.unappliedFacetChanges = updateSelectedFacetBucket(\r\n this.unappliedFacetChanges,\r\n this.facetKey,\r\n e.detail.bucket,\r\n );\r\n }\r\n }}\r\n ></facets-template>\r\n `;\r\n }\r\n\r\n private get loaderTemplate(): TemplateResult {\r\n return html`\r\n <ia-status-indicator\r\n class=\"facets-loader\"\r\n mode=\"loading\"\r\n ></ia-status-indicator>\r\n `;\r\n }\r\n\r\n /**\r\n * How many pages of facets to show in the modal pagination widget\r\n */\r\n private get paginationSize(): number {\r\n if (!this.aggregations || !this.facetKey) return 0;\r\n\r\n // Calculate the appropriate number of pages to show in the modal pagination widget\r\n const length = this.aggregations[this.facetKey]?.buckets.length;\r\n return Math.ceil(length / this.facetsPerPage);\r\n }\r\n\r\n // render pagination if more then 1 page\r\n private get facetsPaginationTemplate() {\r\n return this.paginationSize > 1\r\n ? html`<more-facets-pagination\r\n .size=${this.paginationSize}\r\n .currentPage=${1}\r\n @pageNumberClicked=${this.pageNumberClicked}\r\n ></more-facets-pagination>`\r\n : nothing;\r\n }\r\n\r\n private get footerTemplate() {\r\n if (this.paginationSize > 0) {\r\n return html`${this.facetsPaginationTemplate}\r\n <div class=\"footer\">\r\n <button\r\n class=\"btn btn-cancel\"\r\n type=\"button\"\r\n @click=${this.cancelClick}\r\n >\r\n Cancel\r\n </button>\r\n <button\r\n class=\"btn btn-submit\"\r\n type=\"button\"\r\n @click=${this.applySearchFacetsClicked}\r\n >\r\n Apply filters\r\n </button>\r\n </div> `;\r\n }\r\n\r\n return nothing;\r\n }\r\n\r\n private sortFacetAggregation(facetSortType: AggregationSortType) {\r\n this.sortedBy = facetSortType;\r\n this.dispatchEvent(\r\n new CustomEvent('sortedFacets', { detail: this.sortedBy }),\r\n );\r\n }\r\n\r\n private get modalHeaderTemplate(): TemplateResult {\r\n const facetSort =\r\n this.sortedBy ?? defaultFacetSort[this.facetKey as FacetOption];\r\n const defaultSwitchSide =\r\n facetSort === AggregationSortType.COUNT ? 'left' : 'right';\r\n\r\n return html`<span class=\"sr-only\">${msg('More facets for:')}</span>\r\n <span class=\"title\">\r\n ${this.facetGroup?.title}\r\n\r\n <label class=\"sort-label\">${msg('Sort by:')}</label>\r\n ${this.facetKey\r\n ? html`<toggle-switch\r\n class=\"sort-toggle\"\r\n leftValue=${AggregationSortType.COUNT}\r\n leftLabel=\"Count\"\r\n rightValue=${valueFacetSort[this.facetKey]}\r\n .rightLabel=${this.facetGroup?.title}\r\n side=${defaultSwitchSide}\r\n @change=${(e: CustomEvent<string>) => {\r\n this.sortFacetAggregation(\r\n Number(e.detail) as AggregationSortType,\r\n );\r\n }}\r\n ></toggle-switch>`\r\n : nothing}\r\n </span>`;\r\n }\r\n\r\n render() {\r\n return html`\r\n ${this.facetsLoading\r\n ? this.loaderTemplate\r\n : html`\r\n <section id=\"more-facets\">\r\n <div class=\"header-content\">${this.modalHeaderTemplate}</div>\r\n <div class=\"facets-content\">${this.moreFacetsTemplate}</div>\r\n ${this.footerTemplate}\r\n </section>\r\n `}\r\n `;\r\n }\r\n\r\n private applySearchFacetsClicked() {\r\n const mergedSelections = mergeSelectedFacets(\r\n this.selectedFacets,\r\n this.unappliedFacetChanges,\r\n );\r\n\r\n const event = new CustomEvent<SelectedFacets>('facetsChanged', {\r\n detail: mergedSelections,\r\n bubbles: true,\r\n composed: true,\r\n });\r\n this.dispatchEvent(event);\r\n\r\n // Reset the unapplied changes back to default, now that they have been applied\r\n this.unappliedFacetChanges = getDefaultSelectedFacets();\r\n\r\n this.modalManager?.closeModal();\r\n this.analyticsHandler?.sendEvent({\r\n category: analyticsCategories.default,\r\n action: `${analyticsActions.applyMoreFacetsModal}`,\r\n label: `${this.facetKey}`,\r\n });\r\n }\r\n\r\n private cancelClick() {\r\n // Reset the unapplied changes back to default\r\n this.unappliedFacetChanges = getDefaultSelectedFacets();\r\n\r\n this.modalManager?.closeModal();\r\n this.analyticsHandler?.sendEvent({\r\n category: analyticsCategories.default,\r\n action: analyticsActions.closeMoreFacetsModal,\r\n label: `${this.facetKey}`,\r\n });\r\n }\r\n\r\n static get styles(): CSSResultGroup {\r\n const modalSubmitButton = css`var(--primaryButtonBGColor, #194880)`;\r\n\r\n return [\r\n srOnlyStyle,\r\n css`\r\n section#more-facets {\r\n overflow: auto;\r\n padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */\r\n --facetsColumnCount: 3;\r\n }\r\n .header-content .title {\r\n display: block;\r\n text-align: left;\r\n font-size: 1.8rem;\r\n padding: 0 10px;\r\n font-weight: bold;\r\n }\r\n\r\n .sort-label {\r\n margin-left: 20px;\r\n font-size: 1.3rem;\r\n }\r\n\r\n .sort-toggle {\r\n font-weight: normal;\r\n }\r\n\r\n .facets-content {\r\n font-size: 1.2rem;\r\n max-height: 300px;\r\n overflow: auto;\r\n padding: 10px;\r\n }\r\n .facets-loader {\r\n --icon-width: 70px;\r\n margin-bottom: 20px;\r\n display: block;\r\n margin-left: auto;\r\n margin-right: auto;\r\n }\r\n .btn {\r\n border: none;\r\n padding: 10px;\r\n margin-bottom: 10px;\r\n width: auto;\r\n border-radius: 4px;\r\n cursor: pointer;\r\n }\r\n .btn-cancel {\r\n background-color: #2c2c2c;\r\n color: white;\r\n }\r\n .btn-submit {\r\n background-color: ${modalSubmitButton};\r\n color: white;\r\n }\r\n .footer {\r\n text-align: center;\r\n margin-top: 10px;\r\n }\r\n\r\n @media (max-width: 560px) {\r\n section#more-facets {\r\n max-height: 450px;\r\n --facetsColumnCount: 1;\r\n }\r\n .facets-content {\r\n overflow-y: auto;\r\n height: 300px;\r\n }\r\n }\r\n `,\r\n ];\r\n }\r\n}\r\n"]}
|