@internetarchive/collection-browser 3.1.0 → 3.1.1-alpha-webdev6778.2
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/dist/src/app-root.js +606 -606
- package/dist/src/app-root.js.map +1 -1
- package/dist/src/collection-browser.d.ts +9 -0
- package/dist/src/collection-browser.js +7 -0
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-row.js +140 -140
- package/dist/src/collection-facets/facet-row.js.map +1 -1
- package/dist/src/collection-facets/models.js.map +1 -1
- package/dist/src/collection-facets/more-facets-content.d.ts +1 -0
- package/dist/src/collection-facets/more-facets-content.js +122 -118
- package/dist/src/collection-facets/more-facets-content.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +75 -75
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +54 -54
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
- package/dist/src/collection-facets.d.ts +1 -0
- package/dist/src/collection-facets.js +269 -265
- package/dist/src/collection-facets.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source.js +27 -13
- 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 -0
- package/dist/src/data-source/collection-browser-query-state.js.map +1 -1
- package/dist/src/data-source/models.d.ts +1 -1
- package/dist/src/data-source/models.js.map +1 -1
- package/dist/src/expanded-date-picker.js +52 -52
- package/dist/src/expanded-date-picker.js.map +1 -1
- package/dist/src/manage/manage-bar.js +77 -77
- package/dist/src/manage/manage-bar.js.map +1 -1
- package/dist/src/models.js.map +1 -1
- package/dist/src/sort-filter-bar/sort-filter-bar.js +376 -376
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
- package/dist/src/tiles/grid/collection-tile.js +77 -77
- package/dist/src/tiles/grid/collection-tile.js.map +1 -1
- package/dist/src/tiles/grid/item-tile.js +139 -139
- package/dist/src/tiles/grid/item-tile.js.map +1 -1
- package/dist/src/tiles/grid/search-tile.js +42 -42
- package/dist/src/tiles/grid/search-tile.js.map +1 -1
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +119 -119
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -1
- package/dist/src/tiles/list/tile-list.js +297 -297
- package/dist/src/tiles/list/tile-list.js.map +1 -1
- package/dist/src/tiles/tile-dispatcher.js +200 -200
- package/dist/src/tiles/tile-dispatcher.js.map +1 -1
- package/dist/src/utils/analytics-events.js.map +1 -1
- package/dist/test/collection-facets/facet-row.test.js +23 -23
- package/dist/test/collection-facets/facet-row.test.js.map +1 -1
- package/dist/test/collection-facets.test.js +20 -20
- package/dist/test/collection-facets.test.js.map +1 -1
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +37 -37
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list.test.js +113 -113
- package/dist/test/tiles/list/tile-list.test.js.map +1 -1
- package/package.json +2 -2
- package/src/app-root.ts +1140 -1140
- package/src/collection-browser.ts +14 -0
- package/src/collection-facets/facet-row.ts +296 -296
- package/src/collection-facets/models.ts +10 -10
- package/src/collection-facets/more-facets-content.ts +639 -636
- package/src/collection-facets/smart-facets/smart-facet-bar.ts +437 -437
- package/src/collection-facets/smart-facets/smart-facet-dropdown.ts +185 -185
- package/src/collection-facets.ts +995 -992
- package/src/data-source/collection-browser-data-source-interface.ts +333 -333
- package/src/data-source/collection-browser-data-source.ts +21 -11
- package/src/data-source/collection-browser-query-state.ts +1 -0
- package/src/data-source/models.ts +1 -1
- package/src/expanded-date-picker.ts +191 -191
- package/src/manage/manage-bar.ts +247 -247
- package/src/models.ts +870 -870
- package/src/sort-filter-bar/sort-filter-bar.ts +1283 -1283
- package/src/tiles/grid/collection-tile.ts +162 -162
- package/src/tiles/grid/item-tile.ts +339 -339
- package/src/tiles/grid/search-tile.ts +90 -90
- package/src/tiles/grid/styles/tile-grid-shared-styles.ts +130 -130
- package/src/tiles/list/tile-list.ts +696 -696
- package/src/tiles/tile-dispatcher.ts +486 -486
- package/src/utils/analytics-events.ts +29 -29
- package/test/collection-facets/facet-row.test.ts +375 -375
- package/test/collection-facets.test.ts +928 -928
- package/test/sort-filter-bar/sort-filter-bar.test.ts +885 -885
- package/test/tiles/list/tile-list.test.ts +497 -497
|
@@ -108,6 +108,7 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
108
108
|
const params = {
|
|
109
109
|
...this.pageSpecifierParams,
|
|
110
110
|
query: trimmedQuery || '',
|
|
111
|
+
identifiers: this.identifiers,
|
|
111
112
|
filters: this.filterMap,
|
|
112
113
|
aggregations,
|
|
113
114
|
aggregationsSize,
|
|
@@ -273,22 +274,22 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
273
274
|
};
|
|
274
275
|
}
|
|
275
276
|
get moreFacetsTemplate() {
|
|
276
|
-
return html `
|
|
277
|
-
<facets-template
|
|
278
|
-
.facetGroup=${this.facetGroupForCurrentPage}
|
|
279
|
-
.selectedFacets=${this.selectedFacets}
|
|
280
|
-
.collectionTitles=${this.collectionTitles}
|
|
277
|
+
return html `
|
|
278
|
+
<facets-template
|
|
279
|
+
.facetGroup=${this.facetGroupForCurrentPage}
|
|
280
|
+
.selectedFacets=${this.selectedFacets}
|
|
281
|
+
.collectionTitles=${this.collectionTitles}
|
|
281
282
|
@facetClick=${(e) => {
|
|
282
283
|
if (this.facetKey) {
|
|
283
284
|
this.unappliedFacetChanges = updateSelectedFacetBucket(this.unappliedFacetChanges, this.facetKey, e.detail.bucket);
|
|
284
285
|
}
|
|
285
|
-
}}
|
|
286
|
-
></facets-template>
|
|
286
|
+
}}
|
|
287
|
+
></facets-template>
|
|
287
288
|
`;
|
|
288
289
|
}
|
|
289
290
|
get loaderTemplate() {
|
|
290
|
-
return html `<div class="facets-loader">
|
|
291
|
-
<ia-activity-indicator .mode=${'processing'}></ia-activity-indicator>
|
|
291
|
+
return html `<div class="facets-loader">
|
|
292
|
+
<ia-activity-indicator .mode=${'processing'}></ia-activity-indicator>
|
|
292
293
|
</div> `;
|
|
293
294
|
}
|
|
294
295
|
/**
|
|
@@ -305,31 +306,31 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
305
306
|
// render pagination if more then 1 page
|
|
306
307
|
get facetsPaginationTemplate() {
|
|
307
308
|
return this.paginationSize > 1
|
|
308
|
-
? html `<more-facets-pagination
|
|
309
|
-
.size=${this.paginationSize}
|
|
310
|
-
.currentPage=${1}
|
|
311
|
-
@pageNumberClicked=${this.pageNumberClicked}
|
|
309
|
+
? html `<more-facets-pagination
|
|
310
|
+
.size=${this.paginationSize}
|
|
311
|
+
.currentPage=${1}
|
|
312
|
+
@pageNumberClicked=${this.pageNumberClicked}
|
|
312
313
|
></more-facets-pagination>`
|
|
313
314
|
: nothing;
|
|
314
315
|
}
|
|
315
316
|
get footerTemplate() {
|
|
316
317
|
if (this.paginationSize > 0) {
|
|
317
|
-
return html `${this.facetsPaginationTemplate}
|
|
318
|
-
<div class="footer">
|
|
319
|
-
<button
|
|
320
|
-
class="btn btn-cancel"
|
|
321
|
-
type="button"
|
|
322
|
-
@click=${this.cancelClick}
|
|
323
|
-
>
|
|
324
|
-
Cancel
|
|
325
|
-
</button>
|
|
326
|
-
<button
|
|
327
|
-
class="btn btn-submit"
|
|
328
|
-
type="button"
|
|
329
|
-
@click=${this.applySearchFacetsClicked}
|
|
330
|
-
>
|
|
331
|
-
Apply filters
|
|
332
|
-
</button>
|
|
318
|
+
return html `${this.facetsPaginationTemplate}
|
|
319
|
+
<div class="footer">
|
|
320
|
+
<button
|
|
321
|
+
class="btn btn-cancel"
|
|
322
|
+
type="button"
|
|
323
|
+
@click=${this.cancelClick}
|
|
324
|
+
>
|
|
325
|
+
Cancel
|
|
326
|
+
</button>
|
|
327
|
+
<button
|
|
328
|
+
class="btn btn-submit"
|
|
329
|
+
type="button"
|
|
330
|
+
@click=${this.applySearchFacetsClicked}
|
|
331
|
+
>
|
|
332
|
+
Apply filters
|
|
333
|
+
</button>
|
|
333
334
|
</div> `;
|
|
334
335
|
}
|
|
335
336
|
return nothing;
|
|
@@ -342,37 +343,37 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
342
343
|
var _a, _b, _c;
|
|
343
344
|
const facetSort = (_a = this.sortedBy) !== null && _a !== void 0 ? _a : defaultFacetSort[this.facetKey];
|
|
344
345
|
const defaultSwitchSide = facetSort === AggregationSortType.COUNT ? 'left' : 'right';
|
|
345
|
-
return html `<span class="sr-only">${msg('More facets for:')}</span>
|
|
346
|
-
<span class="title">
|
|
347
|
-
${(_b = this.facetGroup) === null || _b === void 0 ? void 0 : _b.title}
|
|
348
|
-
|
|
349
|
-
<label class="sort-label">${msg('Sort by:')}</label>
|
|
346
|
+
return html `<span class="sr-only">${msg('More facets for:')}</span>
|
|
347
|
+
<span class="title">
|
|
348
|
+
${(_b = this.facetGroup) === null || _b === void 0 ? void 0 : _b.title}
|
|
349
|
+
|
|
350
|
+
<label class="sort-label">${msg('Sort by:')}</label>
|
|
350
351
|
${this.facetKey
|
|
351
|
-
? html `<toggle-switch
|
|
352
|
-
class="sort-toggle"
|
|
353
|
-
leftValue=${AggregationSortType.COUNT}
|
|
354
|
-
leftLabel="Count"
|
|
355
|
-
rightValue=${valueFacetSort[this.facetKey]}
|
|
356
|
-
.rightLabel=${(_c = this.facetGroup) === null || _c === void 0 ? void 0 : _c.title}
|
|
357
|
-
side=${defaultSwitchSide}
|
|
352
|
+
? html `<toggle-switch
|
|
353
|
+
class="sort-toggle"
|
|
354
|
+
leftValue=${AggregationSortType.COUNT}
|
|
355
|
+
leftLabel="Count"
|
|
356
|
+
rightValue=${valueFacetSort[this.facetKey]}
|
|
357
|
+
.rightLabel=${(_c = this.facetGroup) === null || _c === void 0 ? void 0 : _c.title}
|
|
358
|
+
side=${defaultSwitchSide}
|
|
358
359
|
@change=${(e) => {
|
|
359
360
|
this.sortFacetAggregation(Number(e.detail));
|
|
360
|
-
}}
|
|
361
|
+
}}
|
|
361
362
|
></toggle-switch>`
|
|
362
|
-
: nothing}
|
|
363
|
+
: nothing}
|
|
363
364
|
</span>`;
|
|
364
365
|
}
|
|
365
366
|
render() {
|
|
366
|
-
return html `
|
|
367
|
+
return html `
|
|
367
368
|
${this.facetsLoading
|
|
368
369
|
? this.loaderTemplate
|
|
369
|
-
: html `
|
|
370
|
-
<section id="more-facets">
|
|
371
|
-
<div class="header-content">${this.modalHeaderTemplate}</div>
|
|
372
|
-
<div class="facets-content">${this.moreFacetsTemplate}</div>
|
|
373
|
-
${this.footerTemplate}
|
|
374
|
-
</section>
|
|
375
|
-
`}
|
|
370
|
+
: html `
|
|
371
|
+
<section id="more-facets">
|
|
372
|
+
<div class="header-content">${this.modalHeaderTemplate}</div>
|
|
373
|
+
<div class="facets-content">${this.moreFacetsTemplate}</div>
|
|
374
|
+
${this.footerTemplate}
|
|
375
|
+
</section>
|
|
376
|
+
`}
|
|
376
377
|
`;
|
|
377
378
|
}
|
|
378
379
|
applySearchFacetsClicked() {
|
|
@@ -408,73 +409,73 @@ let MoreFacetsContent = class MoreFacetsContent extends LitElement {
|
|
|
408
409
|
const modalSubmitButton = css `var(--primaryButtonBGColor, #194880)`;
|
|
409
410
|
return [
|
|
410
411
|
srOnlyStyle,
|
|
411
|
-
css `
|
|
412
|
-
section#more-facets {
|
|
413
|
-
overflow: auto;
|
|
414
|
-
padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */
|
|
415
|
-
--facetsColumnCount: 3;
|
|
416
|
-
}
|
|
417
|
-
.header-content .title {
|
|
418
|
-
display: block;
|
|
419
|
-
text-align: left;
|
|
420
|
-
font-size: 1.8rem;
|
|
421
|
-
padding: 0 10px;
|
|
422
|
-
font-weight: bold;
|
|
423
|
-
}
|
|
424
|
-
|
|
425
|
-
.sort-label {
|
|
426
|
-
margin-left: 20px;
|
|
427
|
-
font-size: 1.3rem;
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
.sort-toggle {
|
|
431
|
-
font-weight: normal;
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
.facets-content {
|
|
435
|
-
font-size: 1.2rem;
|
|
436
|
-
max-height: 300px;
|
|
437
|
-
overflow: auto;
|
|
438
|
-
padding: 10px;
|
|
439
|
-
}
|
|
440
|
-
.facets-loader {
|
|
441
|
-
margin-bottom: 20px;
|
|
442
|
-
width: 70px;
|
|
443
|
-
display: block;
|
|
444
|
-
margin-left: auto;
|
|
445
|
-
margin-right: auto;
|
|
446
|
-
}
|
|
447
|
-
.btn {
|
|
448
|
-
border: none;
|
|
449
|
-
padding: 10px;
|
|
450
|
-
margin-bottom: 10px;
|
|
451
|
-
width: auto;
|
|
452
|
-
border-radius: 4px;
|
|
453
|
-
cursor: pointer;
|
|
454
|
-
}
|
|
455
|
-
.btn-cancel {
|
|
456
|
-
background-color: #2c2c2c;
|
|
457
|
-
color: white;
|
|
458
|
-
}
|
|
459
|
-
.btn-submit {
|
|
460
|
-
background-color: ${modalSubmitButton};
|
|
461
|
-
color: white;
|
|
462
|
-
}
|
|
463
|
-
.footer {
|
|
464
|
-
text-align: center;
|
|
465
|
-
margin-top: 10px;
|
|
466
|
-
}
|
|
467
|
-
|
|
468
|
-
@media (max-width: 560px) {
|
|
469
|
-
section#more-facets {
|
|
470
|
-
max-height: 450px;
|
|
471
|
-
--facetsColumnCount: 1;
|
|
472
|
-
}
|
|
473
|
-
.facets-content {
|
|
474
|
-
overflow-y: auto;
|
|
475
|
-
height: 300px;
|
|
476
|
-
}
|
|
477
|
-
}
|
|
412
|
+
css `
|
|
413
|
+
section#more-facets {
|
|
414
|
+
overflow: auto;
|
|
415
|
+
padding: 10px; /* leaves room for scroll bar to appear without overlaying on content */
|
|
416
|
+
--facetsColumnCount: 3;
|
|
417
|
+
}
|
|
418
|
+
.header-content .title {
|
|
419
|
+
display: block;
|
|
420
|
+
text-align: left;
|
|
421
|
+
font-size: 1.8rem;
|
|
422
|
+
padding: 0 10px;
|
|
423
|
+
font-weight: bold;
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
.sort-label {
|
|
427
|
+
margin-left: 20px;
|
|
428
|
+
font-size: 1.3rem;
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
.sort-toggle {
|
|
432
|
+
font-weight: normal;
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
.facets-content {
|
|
436
|
+
font-size: 1.2rem;
|
|
437
|
+
max-height: 300px;
|
|
438
|
+
overflow: auto;
|
|
439
|
+
padding: 10px;
|
|
440
|
+
}
|
|
441
|
+
.facets-loader {
|
|
442
|
+
margin-bottom: 20px;
|
|
443
|
+
width: 70px;
|
|
444
|
+
display: block;
|
|
445
|
+
margin-left: auto;
|
|
446
|
+
margin-right: auto;
|
|
447
|
+
}
|
|
448
|
+
.btn {
|
|
449
|
+
border: none;
|
|
450
|
+
padding: 10px;
|
|
451
|
+
margin-bottom: 10px;
|
|
452
|
+
width: auto;
|
|
453
|
+
border-radius: 4px;
|
|
454
|
+
cursor: pointer;
|
|
455
|
+
}
|
|
456
|
+
.btn-cancel {
|
|
457
|
+
background-color: #2c2c2c;
|
|
458
|
+
color: white;
|
|
459
|
+
}
|
|
460
|
+
.btn-submit {
|
|
461
|
+
background-color: ${modalSubmitButton};
|
|
462
|
+
color: white;
|
|
463
|
+
}
|
|
464
|
+
.footer {
|
|
465
|
+
text-align: center;
|
|
466
|
+
margin-top: 10px;
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
@media (max-width: 560px) {
|
|
470
|
+
section#more-facets {
|
|
471
|
+
max-height: 450px;
|
|
472
|
+
--facetsColumnCount: 1;
|
|
473
|
+
}
|
|
474
|
+
.facets-content {
|
|
475
|
+
overflow-y: auto;
|
|
476
|
+
height: 300px;
|
|
477
|
+
}
|
|
478
|
+
}
|
|
478
479
|
`,
|
|
479
480
|
];
|
|
480
481
|
}
|
|
@@ -485,6 +486,9 @@ __decorate([
|
|
|
485
486
|
__decorate([
|
|
486
487
|
property({ type: String })
|
|
487
488
|
], MoreFacetsContent.prototype, "query", void 0);
|
|
489
|
+
__decorate([
|
|
490
|
+
property({ type: Array })
|
|
491
|
+
], MoreFacetsContent.prototype, "identifiers", void 0);
|
|
488
492
|
__decorate([
|
|
489
493
|
property({ type: Object })
|
|
490
494
|
], MoreFacetsContent.prototype, "filterMap", void 0);
|
|
@@ -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/ia-activity-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: 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 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`<div class=\"facets-loader\">\n <ia-activity-indicator .mode=${'processing'}></ia-activity-indicator>\n </div> `;\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 margin-bottom: 20px;\n width: 70px;\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/ia-activity-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`<div class=\"facets-loader\">\r\n <ia-activity-indicator .mode=${'processing'}></ia-activity-indicator>\r\n </div> `;\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 margin-bottom: 20px;\r\n width: 70px;\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"]}
|
|
@@ -33,14 +33,14 @@ let SmartFacetBar = class SmartFacetBar extends LitElement {
|
|
|
33
33
|
if (!this.query)
|
|
34
34
|
return nothing;
|
|
35
35
|
const shouldShowLabel = !!this.label && this.smartFacets.length > 0;
|
|
36
|
-
return html `
|
|
37
|
-
<div id="smart-facets-container">
|
|
38
|
-
${this.filtersToggleTemplate}
|
|
36
|
+
return html `
|
|
37
|
+
<div id="smart-facets-container">
|
|
38
|
+
${this.filtersToggleTemplate}
|
|
39
39
|
${shouldShowLabel
|
|
40
40
|
? html `<p id="filters-label">${this.label}</p>`
|
|
41
|
-
: nothing}
|
|
42
|
-
${repeat(this.smartFacets, f => `${f[0].label}|${f[0].facets[0].facetType}|${f[0].facets[0].bucketKey}`, facet => this.makeSmartFacet(facet))}
|
|
43
|
-
</div>
|
|
41
|
+
: nothing}
|
|
42
|
+
${repeat(this.smartFacets, f => `${f[0].label}|${f[0].facets[0].facetType}|${f[0].facets[0].bucketKey}`, facet => this.makeSmartFacet(facet))}
|
|
43
|
+
</div>
|
|
44
44
|
`;
|
|
45
45
|
}
|
|
46
46
|
willUpdate(changed) {
|
|
@@ -99,38 +99,38 @@ let SmartFacetBar = class SmartFacetBar extends LitElement {
|
|
|
99
99
|
}
|
|
100
100
|
smartFacetButton(facet) {
|
|
101
101
|
var _a;
|
|
102
|
-
return html `
|
|
103
|
-
<smart-facet-button
|
|
104
|
-
.facetInfo=${facet}
|
|
105
|
-
.labelPrefix=${fieldPrefixes[facet.facets[0].facetType]}
|
|
106
|
-
.selected=${(_a = facet.selected) !== null && _a !== void 0 ? _a : false}
|
|
107
|
-
@facetClick=${this.facetClicked}
|
|
108
|
-
></smart-facet-button>
|
|
102
|
+
return html `
|
|
103
|
+
<smart-facet-button
|
|
104
|
+
.facetInfo=${facet}
|
|
105
|
+
.labelPrefix=${fieldPrefixes[facet.facets[0].facetType]}
|
|
106
|
+
.selected=${(_a = facet.selected) !== null && _a !== void 0 ? _a : false}
|
|
107
|
+
@facetClick=${this.facetClicked}
|
|
108
|
+
></smart-facet-button>
|
|
109
109
|
`;
|
|
110
110
|
}
|
|
111
111
|
smartFacetDropdown(facets) {
|
|
112
|
-
return html `
|
|
113
|
-
<smart-facet-dropdown
|
|
114
|
-
.facetInfo=${facets}
|
|
115
|
-
.labelPrefix=${fieldPrefixes[facets[0].facets[0].facetType]}
|
|
116
|
-
.activeFacetRef=${facets[0].facets[0]}
|
|
117
|
-
@facetClick=${this.dropdownOptionClicked}
|
|
118
|
-
@dropdownClick=${this.dropdownClicked}
|
|
119
|
-
></smart-facet-dropdown>
|
|
112
|
+
return html `
|
|
113
|
+
<smart-facet-dropdown
|
|
114
|
+
.facetInfo=${facets}
|
|
115
|
+
.labelPrefix=${fieldPrefixes[facets[0].facets[0].facetType]}
|
|
116
|
+
.activeFacetRef=${facets[0].facets[0]}
|
|
117
|
+
@facetClick=${this.dropdownOptionClicked}
|
|
118
|
+
@dropdownClick=${this.dropdownClicked}
|
|
119
|
+
></smart-facet-dropdown>
|
|
120
120
|
`;
|
|
121
121
|
}
|
|
122
122
|
get filtersToggleTemplate() {
|
|
123
123
|
if (!this.filterToggleShown)
|
|
124
124
|
return nothing;
|
|
125
|
-
return html `
|
|
126
|
-
<button
|
|
127
|
-
id="filters-toggle"
|
|
128
|
-
class=${this.filterToggleActive ? 'active' : ''}
|
|
129
|
-
title="${this.filterToggleActive ? 'Hide' : 'Show'} filters pane"
|
|
130
|
-
@click=${this.filterToggleClicked}
|
|
131
|
-
>
|
|
132
|
-
${filterIcon}
|
|
133
|
-
</button>
|
|
125
|
+
return html `
|
|
126
|
+
<button
|
|
127
|
+
id="filters-toggle"
|
|
128
|
+
class=${this.filterToggleActive ? 'active' : ''}
|
|
129
|
+
title="${this.filterToggleActive ? 'Hide' : 'Show'} filters pane"
|
|
130
|
+
@click=${this.filterToggleClicked}
|
|
131
|
+
>
|
|
132
|
+
${filterIcon}
|
|
133
|
+
</button>
|
|
134
134
|
`;
|
|
135
135
|
}
|
|
136
136
|
get facetsToDisplay() {
|
|
@@ -298,51 +298,51 @@ let SmartFacetBar = class SmartFacetBar extends LitElement {
|
|
|
298
298
|
// STYLES
|
|
299
299
|
//
|
|
300
300
|
static get styles() {
|
|
301
|
-
return css `
|
|
302
|
-
#smart-facets-container {
|
|
303
|
-
display: flex;
|
|
304
|
-
align-items: center;
|
|
305
|
-
gap: 5px 10px;
|
|
306
|
-
padding: 10px 0;
|
|
307
|
-
white-space: nowrap;
|
|
308
|
-
overflow: scroll hidden;
|
|
309
|
-
scrollbar-width: none;
|
|
310
|
-
}
|
|
311
|
-
|
|
312
|
-
#filters-toggle {
|
|
313
|
-
margin: 0;
|
|
314
|
-
border: 0;
|
|
315
|
-
padding: 5px 8px;
|
|
316
|
-
border-radius: 5px;
|
|
317
|
-
background: white;
|
|
318
|
-
color: #2c2c2c;
|
|
319
|
-
border: 1px solid #194880;
|
|
320
|
-
font-size: 1.4rem;
|
|
321
|
-
font-family: inherit;
|
|
322
|
-
text-decoration: none;
|
|
323
|
-
cursor: pointer;
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
#filters-toggle.active {
|
|
327
|
-
background: #194880;
|
|
328
|
-
color: white;
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
#filters-toggle > svg {
|
|
332
|
-
width: 12px;
|
|
333
|
-
filter: invert(0.16667);
|
|
334
|
-
vertical-align: -1px;
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
#filters-toggle.active > svg {
|
|
338
|
-
filter: invert(1);
|
|
339
|
-
}
|
|
340
|
-
|
|
341
|
-
#filters-label {
|
|
342
|
-
font-size: 1.4rem;
|
|
343
|
-
font-weight: var(--smartFacetLabelFontWeight, normal);
|
|
344
|
-
margin: 0 -5px 0 0;
|
|
345
|
-
}
|
|
301
|
+
return css `
|
|
302
|
+
#smart-facets-container {
|
|
303
|
+
display: flex;
|
|
304
|
+
align-items: center;
|
|
305
|
+
gap: 5px 10px;
|
|
306
|
+
padding: 10px 0;
|
|
307
|
+
white-space: nowrap;
|
|
308
|
+
overflow: scroll hidden;
|
|
309
|
+
scrollbar-width: none;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
#filters-toggle {
|
|
313
|
+
margin: 0;
|
|
314
|
+
border: 0;
|
|
315
|
+
padding: 5px 8px;
|
|
316
|
+
border-radius: 5px;
|
|
317
|
+
background: white;
|
|
318
|
+
color: #2c2c2c;
|
|
319
|
+
border: 1px solid #194880;
|
|
320
|
+
font-size: 1.4rem;
|
|
321
|
+
font-family: inherit;
|
|
322
|
+
text-decoration: none;
|
|
323
|
+
cursor: pointer;
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
#filters-toggle.active {
|
|
327
|
+
background: #194880;
|
|
328
|
+
color: white;
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
#filters-toggle > svg {
|
|
332
|
+
width: 12px;
|
|
333
|
+
filter: invert(0.16667);
|
|
334
|
+
vertical-align: -1px;
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
#filters-toggle.active > svg {
|
|
338
|
+
filter: invert(1);
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
#filters-label {
|
|
342
|
+
font-size: 1.4rem;
|
|
343
|
+
font-weight: var(--smartFacetLabelFontWeight, normal);
|
|
344
|
+
margin: 0 -5px 0 0;
|
|
345
|
+
}
|
|
346
346
|
`;
|
|
347
347
|
}
|
|
348
348
|
};
|