@internetarchive/collection-browser 1.14.9-alpha.2 → 1.14.9-alpha10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.husky/pre-commit +4 -4
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +9 -9
- package/dist/index.js +9 -9
- package/dist/src/app-root.d.ts +73 -72
- package/dist/src/app-root.js +501 -429
- package/dist/src/app-root.js.map +1 -1
- package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-left.js +2 -2
- package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
- package/dist/src/assets/img/icons/arrow-right.js +2 -2
- package/dist/src/assets/img/icons/chevron.d.ts +2 -2
- package/dist/src/assets/img/icons/chevron.js +2 -2
- package/dist/src/assets/img/icons/contract.d.ts +2 -2
- package/dist/src/assets/img/icons/contract.js +2 -2
- package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
- package/dist/src/assets/img/icons/empty-query.js +2 -2
- package/dist/src/assets/img/icons/expand.d.ts +2 -2
- package/dist/src/assets/img/icons/expand.js +2 -2
- package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
- package/dist/src/assets/img/icons/eye-closed.js +2 -2
- package/dist/src/assets/img/icons/eye.d.ts +2 -2
- package/dist/src/assets/img/icons/eye.js +2 -2
- package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
- package/dist/src/assets/img/icons/favorite-filled.js +2 -2
- package/dist/src/assets/img/icons/login-required.d.ts +1 -1
- package/dist/src/assets/img/icons/login-required.js +2 -2
- package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/account.js +2 -2
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
- package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/data.js +2 -2
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/film.js +2 -2
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/images.js +2 -2
- package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/search.js +2 -2
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/software.js +2 -2
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/video.js +2 -2
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/web.js +2 -2
- package/dist/src/assets/img/icons/null-result.d.ts +2 -2
- package/dist/src/assets/img/icons/null-result.js +2 -2
- package/dist/src/assets/img/icons/restricted.d.ts +1 -1
- package/dist/src/assets/img/icons/restricted.js +2 -2
- package/dist/src/assets/img/icons/reviews.d.ts +1 -1
- package/dist/src/assets/img/icons/reviews.js +2 -2
- package/dist/src/assets/img/icons/upload.d.ts +1 -1
- package/dist/src/assets/img/icons/upload.js +2 -2
- package/dist/src/assets/img/icons/views.d.ts +1 -1
- package/dist/src/assets/img/icons/views.js +2 -2
- package/dist/src/circular-activity-indicator.d.ts +5 -5
- package/dist/src/circular-activity-indicator.js +17 -17
- package/dist/src/collection-browser.d.ts +533 -533
- package/dist/src/collection-browser.js +1894 -1893
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-row.d.ts +30 -0
- package/dist/src/collection-facets/facet-row.js +245 -0
- package/dist/src/collection-facets/facet-row.js.map +1 -0
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
- package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
- package/dist/src/collection-facets/facets-template.d.ts +17 -20
- package/dist/src/collection-facets/facets-template.js +122 -264
- package/dist/src/collection-facets/facets-template.js.map +1 -1
- package/dist/src/collection-facets/more-facets-content.d.ts +77 -77
- package/dist/src/collection-facets/more-facets-content.js +359 -359
- package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
- package/dist/src/collection-facets/more-facets-pagination.js +196 -196
- package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
- package/dist/src/collection-facets/toggle-switch.js +94 -94
- package/dist/src/collection-facets.d.ts +104 -104
- package/dist/src/collection-facets.js +506 -506
- package/dist/src/empty-placeholder.d.ts +23 -23
- package/dist/src/empty-placeholder.js +74 -74
- package/dist/src/expanded-date-picker.d.ts +43 -43
- package/dist/src/expanded-date-picker.js +109 -109
- package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
- package/dist/src/language-code-handler/language-code-handler.js +26 -26
- package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
- package/dist/src/language-code-handler/language-code-mapping.js +562 -562
- package/dist/src/manage/manage-bar.d.ts +26 -26
- package/dist/src/manage/manage-bar.js +53 -53
- package/dist/src/mediatype/mediatype-config.d.ts +3 -3
- package/dist/src/mediatype/mediatype-config.js +91 -91
- package/dist/src/models.d.ts +180 -164
- package/dist/src/models.js +269 -269
- package/dist/src/models.js.map +1 -1
- package/dist/src/restoration-state-handler.d.ts +70 -70
- package/dist/src/restoration-state-handler.js +355 -355
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
- package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
- package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/compact.js +2 -2
- package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/list.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
- package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/tile.js +2 -2
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +208 -208
- package/dist/src/sort-filter-bar/sort-filter-bar.js +637 -637
- package/dist/src/styles/item-image-styles.d.ts +8 -8
- package/dist/src/styles/item-image-styles.js +9 -9
- package/dist/src/styles/sr-only.d.ts +1 -1
- package/dist/src/styles/sr-only.js +2 -2
- package/dist/src/tiles/base-tile-component.d.ts +19 -19
- package/dist/src/tiles/base-tile-component.js +63 -63
- package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
- package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
- package/dist/src/tiles/grid/account-tile.d.ts +18 -18
- package/dist/src/tiles/grid/account-tile.js +72 -72
- package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
- package/dist/src/tiles/grid/collection-tile.js +80 -80
- package/dist/src/tiles/grid/item-tile.d.ts +27 -27
- package/dist/src/tiles/grid/item-tile.js +134 -134
- package/dist/src/tiles/grid/search-tile.d.ts +10 -10
- package/dist/src/tiles/grid/search-tile.js +51 -51
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
- package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
- package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
- package/dist/src/tiles/grid/tile-stats.js +48 -48
- package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
- package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
- package/dist/src/tiles/hover/tile-hover-pane.d.ts +15 -15
- package/dist/src/tiles/hover/tile-hover-pane.js +38 -38
- package/dist/src/tiles/image-block.d.ts +17 -17
- package/dist/src/tiles/image-block.js +73 -73
- package/dist/src/tiles/item-image.d.ts +36 -36
- package/dist/src/tiles/item-image.js +127 -127
- package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
- package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
- package/dist/src/tiles/list/tile-list-compact.d.ts +15 -15
- package/dist/src/tiles/list/tile-list-compact.js +114 -114
- package/dist/src/tiles/list/tile-list.d.ts +46 -46
- package/dist/src/tiles/list/tile-list.js +302 -302
- package/dist/src/tiles/mediatype-icon.d.ts +9 -9
- package/dist/src/tiles/mediatype-icon.js +47 -47
- package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
- package/dist/src/tiles/overlay/icon-overlay.js +40 -40
- package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
- package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
- package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
- package/dist/src/tiles/overlay/text-overlay.js +42 -42
- package/dist/src/tiles/text-snippet-block.d.ts +27 -27
- package/dist/src/tiles/text-snippet-block.js +73 -73
- package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
- package/dist/src/tiles/tile-dispatcher.js +231 -231
- package/dist/src/tiles/tile-display-value-provider.d.ts +43 -43
- package/dist/src/tiles/tile-display-value-provider.js +80 -80
- package/dist/src/utils/analytics-events.d.ts +25 -25
- package/dist/src/utils/analytics-events.js +27 -27
- package/dist/src/utils/array-equals.d.ts +4 -4
- package/dist/src/utils/array-equals.js +10 -10
- package/dist/src/utils/format-count.d.ts +7 -7
- package/dist/src/utils/format-count.js +76 -76
- package/dist/src/utils/format-date.d.ts +2 -2
- package/dist/src/utils/format-date.js +25 -25
- package/dist/src/utils/format-unit-size.d.ts +2 -2
- package/dist/src/utils/format-unit-size.js +33 -33
- package/dist/src/utils/local-date-from-utc.d.ts +9 -9
- package/dist/src/utils/local-date-from-utc.js +15 -15
- package/dist/src/utils/sha1.d.ts +2 -2
- package/dist/src/utils/sha1.js +8 -8
- package/dist/test/collection-browser.test.d.ts +1 -1
- package/dist/test/collection-browser.test.js +1130 -1098
- package/dist/test/collection-browser.test.js.map +1 -1
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -0
- package/dist/test/collection-facets/facet-row.test.js +235 -0
- package/dist/test/collection-facets/facet-row.test.js.map +1 -0
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +110 -141
- package/dist/test/collection-facets/facets-template.test.js.map +1 -1
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +133 -133
- package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
- package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
- package/dist/test/collection-facets/toggle-switch.test.js +73 -73
- package/dist/test/collection-facets.test.d.ts +2 -2
- package/dist/test/collection-facets.test.js +651 -682
- package/dist/test/collection-facets.test.js.map +1 -1
- package/dist/test/empty-placeholder.test.d.ts +1 -1
- package/dist/test/empty-placeholder.test.js +63 -63
- package/dist/test/expanded-date-picker.test.d.ts +1 -1
- package/dist/test/expanded-date-picker.test.js +95 -95
- package/dist/test/icon-overlay.test.d.ts +1 -1
- package/dist/test/icon-overlay.test.js +24 -24
- package/dist/test/image-block.test.d.ts +1 -1
- package/dist/test/image-block.test.js +48 -48
- package/dist/test/item-image.test.d.ts +1 -1
- package/dist/test/item-image.test.js +86 -86
- package/dist/test/manage/manage-bar.test.d.ts +1 -1
- package/dist/test/manage/manage-bar.test.js +72 -72
- package/dist/test/mediatype-config.test.d.ts +1 -1
- package/dist/test/mediatype-config.test.js +16 -16
- package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
- package/dist/test/mocks/mock-analytics-handler.js +15 -15
- package/dist/test/mocks/mock-collection-name-cache.d.ts +9 -9
- package/dist/test/mocks/mock-collection-name-cache.js +17 -17
- package/dist/test/mocks/mock-search-responses.d.ts +21 -21
- package/dist/test/mocks/mock-search-responses.js +709 -709
- package/dist/test/mocks/mock-search-service.d.ts +15 -15
- package/dist/test/mocks/mock-search-service.js +50 -50
- package/dist/test/restoration-state-handler.test.d.ts +1 -1
- package/dist/test/restoration-state-handler.test.js +270 -270
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
- package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
- package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js +378 -378
- package/dist/test/text-overlay.test.d.ts +1 -1
- package/dist/test/text-overlay.test.js +48 -48
- package/dist/test/text-snippet-block.test.d.ts +1 -1
- package/dist/test/text-snippet-block.test.js +57 -57
- package/dist/test/tile-stats.test.d.ts +1 -1
- package/dist/test/tile-stats.test.js +33 -33
- package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/account-tile.test.js +76 -76
- package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/collection-tile.test.js +73 -73
- package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/item-tile.test.js +254 -254
- package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/search-tile.test.js +51 -51
- package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.js +258 -258
- package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
- package/dist/test/tiles/hover/tile-hover-pane.test.js +13 -13
- package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
- package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list.test.js +242 -242
- package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
- package/dist/test/tiles/tile-dispatcher.test.js +94 -94
- package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
- package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
- package/dist/test/utils/array-equals.test.d.ts +1 -1
- package/dist/test/utils/array-equals.test.js +26 -26
- package/dist/test/utils/format-count.test.d.ts +1 -1
- package/dist/test/utils/format-count.test.js +23 -23
- package/dist/test/utils/format-date.test.d.ts +1 -1
- package/dist/test/utils/format-date.test.js +17 -17
- package/dist/test/utils/format-unit-size.test.d.ts +1 -1
- package/dist/test/utils/format-unit-size.test.js +17 -17
- package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
- package/dist/test/utils/local-date-from-utc.test.js +26 -26
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +2 -2
- package/renovate.json +6 -6
- package/src/app-root.ts +159 -82
- package/src/collection-browser.ts +25 -22
- package/src/collection-facets/facet-row.ts +274 -0
- package/src/collection-facets/facets-template.ts +49 -196
- package/src/models.ts +18 -2
- package/test/collection-browser.test.ts +36 -4
- package/test/collection-facets/facet-row.test.ts +328 -0
- package/test/collection-facets/facets-template.test.ts +72 -110
- package/test/collection-facets.test.ts +69 -101
- package/tsconfig.json +21 -21
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
- package/dist/src/selected-facets.d.ts +0 -67
- package/dist/src/selected-facets.js +0 -149
- package/dist/src/selected-facets.js.map +0 -1
- package/src/selected-facets.ts +0 -216
|
@@ -1,186 +1,107 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { css, html, LitElement } from 'lit';
|
|
3
|
-
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
-
import { repeat } from 'lit/directives/repeat.js';
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
*/
|
|
91
|
-
facetsBucket = [
|
|
92
|
-
...facetsBucket
|
|
93
|
-
.filter(x => x.state === 'selected')
|
|
94
|
-
.sort((a, b) => (a.count < b.count ? 1 : -1)),
|
|
95
|
-
...facetsBucket
|
|
96
|
-
.filter(x => x.state === 'hidden')
|
|
97
|
-
.sort((a, b) => (a.count < b.count ? 1 : -1)),
|
|
98
|
-
...facetsBucket.filter(x => x.state === 'none'),
|
|
99
|
-
];
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { css, html, LitElement, nothing, } from 'lit';
|
|
3
|
+
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
+
import { repeat } from 'lit/directives/repeat.js';
|
|
5
|
+
import { getDefaultSelectedFacets, } from '../models';
|
|
6
|
+
import { FacetRow } from './facet-row';
|
|
7
|
+
let FacetsTemplate = class FacetsTemplate extends LitElement {
|
|
8
|
+
facetClicked(e) {
|
|
9
|
+
const { bucket, negative } = e.detail;
|
|
10
|
+
if (bucket.state === 'none') {
|
|
11
|
+
this.facetUnchecked(bucket);
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
this.facetChecked(bucket, negative);
|
|
15
|
+
}
|
|
16
|
+
this.dispatchFacetClickEvent(e.detail);
|
|
17
|
+
}
|
|
18
|
+
facetChecked(bucket, negative) {
|
|
19
|
+
const { facetGroup, selectedFacets } = this;
|
|
20
|
+
if (!facetGroup)
|
|
21
|
+
return;
|
|
22
|
+
let newFacets;
|
|
23
|
+
if (selectedFacets) {
|
|
24
|
+
newFacets = {
|
|
25
|
+
...selectedFacets,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
newFacets = getDefaultSelectedFacets();
|
|
30
|
+
}
|
|
31
|
+
newFacets[facetGroup.key][bucket.key] = {
|
|
32
|
+
...bucket,
|
|
33
|
+
state: FacetRow.getFacetState(true, negative),
|
|
34
|
+
};
|
|
35
|
+
this.selectedFacets = newFacets;
|
|
36
|
+
this.dispatchSelectedFacetsChanged();
|
|
37
|
+
}
|
|
38
|
+
facetUnchecked(bucket) {
|
|
39
|
+
const { facetGroup, selectedFacets } = this;
|
|
40
|
+
if (!facetGroup)
|
|
41
|
+
return;
|
|
42
|
+
let newFacets;
|
|
43
|
+
if (selectedFacets) {
|
|
44
|
+
newFacets = {
|
|
45
|
+
...selectedFacets,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
newFacets = getDefaultSelectedFacets();
|
|
50
|
+
}
|
|
51
|
+
delete newFacets[facetGroup.key][bucket.key];
|
|
52
|
+
this.selectedFacets = newFacets;
|
|
53
|
+
this.dispatchSelectedFacetsChanged();
|
|
54
|
+
}
|
|
55
|
+
dispatchFacetClickEvent(detail) {
|
|
56
|
+
const event = new CustomEvent('facetClick', {
|
|
57
|
+
detail,
|
|
58
|
+
composed: true,
|
|
59
|
+
});
|
|
60
|
+
this.dispatchEvent(event);
|
|
61
|
+
}
|
|
62
|
+
dispatchSelectedFacetsChanged() {
|
|
63
|
+
const event = new CustomEvent('selectedFacetsChanged', {
|
|
64
|
+
detail: this.selectedFacets,
|
|
65
|
+
bubbles: true,
|
|
66
|
+
composed: true,
|
|
67
|
+
});
|
|
68
|
+
this.dispatchEvent(event);
|
|
69
|
+
}
|
|
70
|
+
get facetsTemplate() {
|
|
71
|
+
const { facetGroup } = this;
|
|
72
|
+
if (!facetGroup)
|
|
73
|
+
return nothing;
|
|
74
|
+
let facetBuckets = facetGroup.buckets;
|
|
75
|
+
/**
|
|
76
|
+
* sorting FacetBucket before render page / modal
|
|
77
|
+
* - first, selected items should be at top having sorted
|
|
78
|
+
* - second, suppressed/hidden items should be after selected having sorted
|
|
79
|
+
* - and then no-selected / not suppressed items should render having sorted
|
|
80
|
+
*/
|
|
81
|
+
facetBuckets = [
|
|
82
|
+
...facetBuckets
|
|
83
|
+
.filter(x => x.state === 'selected')
|
|
84
|
+
.sort((a, b) => (a.count < b.count ? 1 : -1)),
|
|
85
|
+
...facetBuckets
|
|
86
|
+
.filter(x => x.state === 'hidden')
|
|
87
|
+
.sort((a, b) => (a.count < b.count ? 1 : -1)),
|
|
88
|
+
...facetBuckets.filter(x => x.state === 'none'),
|
|
89
|
+
];
|
|
100
90
|
return html `
|
|
101
91
|
<div class="facets-on-${this.renderOn}">
|
|
102
|
-
${repeat(
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
// a static value to use
|
|
109
|
-
const bucketTextDisplay = facetGroup.key !== 'collection'
|
|
110
|
-
? html `${(_a = bucket.displayText) !== null && _a !== void 0 ? _a : bucket.key}`
|
|
111
|
-
: html `<a href="${this.collectionPagePath}${bucket.key}">
|
|
112
|
-
<async-collection-name
|
|
113
|
-
.collectionNameCache=${this.collectionNameCache}
|
|
114
|
-
.identifier=${bucket.key}
|
|
115
|
-
placeholder="-"
|
|
116
|
-
></async-collection-name>
|
|
117
|
-
</a> `;
|
|
118
|
-
const facetHidden = bucket.state === 'hidden';
|
|
119
|
-
const facetSelected = bucket.state === 'selected';
|
|
120
|
-
const titleText = `${facetGroup.key}: ${(_b = bucket.displayText) !== null && _b !== void 0 ? _b : bucket.key}`;
|
|
121
|
-
const onlyShowText = facetSelected
|
|
122
|
-
? `Show all ${facetGroup.key}s`
|
|
123
|
-
: `Only show ${titleText}`;
|
|
124
|
-
const hideText = `Hide ${titleText}`;
|
|
125
|
-
const unhideText = `Unhide ${titleText}`;
|
|
126
|
-
const showHideText = facetHidden ? unhideText : hideText;
|
|
127
|
-
const ariaLabel = `${titleText}, ${bucket.count} results`;
|
|
128
|
-
return html `
|
|
129
|
-
<div class="facet-row">
|
|
130
|
-
<div class="facet-checkbox">
|
|
131
|
-
<input
|
|
132
|
-
type="checkbox"
|
|
133
|
-
.name=${facetGroup.key}
|
|
134
|
-
.value=${bucket.key}
|
|
135
|
-
@click=${(e) => {
|
|
136
|
-
this.facetClicked(e, bucket.count, false);
|
|
137
|
-
}}
|
|
138
|
-
.checked=${facetSelected}
|
|
139
|
-
class="select-facet-checkbox"
|
|
140
|
-
title=${onlyShowText}
|
|
141
|
-
id=${showOnlyCheckboxId}
|
|
142
|
-
/>
|
|
143
|
-
<input
|
|
144
|
-
type="checkbox"
|
|
145
|
-
id=${negativeCheckboxId}
|
|
146
|
-
.name=${facetGroup.key}
|
|
147
|
-
.value=${bucket.key}
|
|
148
|
-
@click=${(e) => {
|
|
149
|
-
this.facetClicked(e, bucket.count, true);
|
|
150
|
-
}}
|
|
151
|
-
.checked=${facetHidden}
|
|
152
|
-
class="hide-facet-checkbox"
|
|
153
|
-
/>
|
|
154
|
-
<label
|
|
155
|
-
for=${negativeCheckboxId}
|
|
156
|
-
class="hide-facet-icon${facetHidden ? ' active' : ''}"
|
|
157
|
-
title=${showHideText}
|
|
158
|
-
>
|
|
159
|
-
<span class="eye">${eyeIcon}</span>
|
|
160
|
-
<span class="eye-closed">${eyeClosedIcon}</span>
|
|
161
|
-
</label>
|
|
162
|
-
</div>
|
|
163
|
-
<label
|
|
164
|
-
for=${showOnlyCheckboxId}
|
|
165
|
-
class="facet-info-display"
|
|
166
|
-
title=${onlyShowText}
|
|
167
|
-
aria-label=${ariaLabel}
|
|
168
|
-
>
|
|
169
|
-
<div class="facet-title">${bucketTextDisplay}</div>
|
|
170
|
-
<div class="facet-count">
|
|
171
|
-
${bucket.count.toLocaleString()}
|
|
172
|
-
</div>
|
|
173
|
-
</label>
|
|
174
|
-
</div>
|
|
175
|
-
`;
|
|
176
|
-
})}
|
|
92
|
+
${repeat(facetBuckets, bucket => `${facetGroup.key}:${bucket.key}`, bucket => html `<facet-row
|
|
93
|
+
.facetType=${facetGroup.key}
|
|
94
|
+
.bucket=${bucket}
|
|
95
|
+
.collectionNameCache=${this.collectionNameCache}
|
|
96
|
+
@facetClick=${this.facetClicked}
|
|
97
|
+
></facet-row>`)}
|
|
177
98
|
</div>
|
|
178
|
-
`;
|
|
179
|
-
}
|
|
180
|
-
render() {
|
|
181
|
-
return html `${this.
|
|
182
|
-
}
|
|
183
|
-
static get styles() {
|
|
99
|
+
`;
|
|
100
|
+
}
|
|
101
|
+
render() {
|
|
102
|
+
return html `${this.facetsTemplate}`;
|
|
103
|
+
}
|
|
104
|
+
static get styles() {
|
|
184
105
|
return css `
|
|
185
106
|
@media (max-width: 560px) {
|
|
186
107
|
.facets-on-modal {
|
|
@@ -191,9 +112,7 @@ let FacetsTemplate = class FacetsTemplate extends LitElement {
|
|
|
191
112
|
column-gap: 15px;
|
|
192
113
|
column-count: 3;
|
|
193
114
|
}
|
|
194
|
-
|
|
195
|
-
display: contents;
|
|
196
|
-
}
|
|
115
|
+
|
|
197
116
|
ul.facet-list {
|
|
198
117
|
list-style: none;
|
|
199
118
|
margin: 0;
|
|
@@ -203,19 +122,7 @@ let FacetsTemplate = class FacetsTemplate extends LitElement {
|
|
|
203
122
|
margin-bottom: 0.2rem;
|
|
204
123
|
display: grid;
|
|
205
124
|
}
|
|
206
|
-
|
|
207
|
-
margin: 0 5px 0 0;
|
|
208
|
-
display: flex;
|
|
209
|
-
height: 15px;
|
|
210
|
-
}
|
|
211
|
-
.facet-checkbox input:first-child {
|
|
212
|
-
margin-right: 5px;
|
|
213
|
-
}
|
|
214
|
-
.facet-checkbox input {
|
|
215
|
-
height: 15px;
|
|
216
|
-
width: 15px;
|
|
217
|
-
margin: 0;
|
|
218
|
-
}
|
|
125
|
+
|
|
219
126
|
.facet-row {
|
|
220
127
|
display: flex;
|
|
221
128
|
font-weight: 500;
|
|
@@ -226,52 +133,6 @@ let FacetsTemplate = class FacetsTemplate extends LitElement {
|
|
|
226
133
|
border-bottom: var(--facet-row-border-bottom, 1px solid transparent);
|
|
227
134
|
overflow: hidden;
|
|
228
135
|
}
|
|
229
|
-
.facet-info-display {
|
|
230
|
-
display: flex;
|
|
231
|
-
flex: 1 1 0%;
|
|
232
|
-
cursor: pointer;
|
|
233
|
-
flex-wrap: wrap;
|
|
234
|
-
}
|
|
235
|
-
.facet-title {
|
|
236
|
-
word-break: break-word;
|
|
237
|
-
display: inline-block;
|
|
238
|
-
flex: 1 1 0%;
|
|
239
|
-
}
|
|
240
|
-
.facet-count {
|
|
241
|
-
text-align: right;
|
|
242
|
-
}
|
|
243
|
-
.select-facet-checkbox {
|
|
244
|
-
cursor: pointer;
|
|
245
|
-
display: inline-block;
|
|
246
|
-
}
|
|
247
|
-
.hide-facet-checkbox {
|
|
248
|
-
display: none;
|
|
249
|
-
}
|
|
250
|
-
.hide-facet-icon {
|
|
251
|
-
width: 15px;
|
|
252
|
-
height: 15px;
|
|
253
|
-
cursor: pointer;
|
|
254
|
-
opacity: 0.3;
|
|
255
|
-
display: inline-block;
|
|
256
|
-
}
|
|
257
|
-
.hide-facet-icon:hover,
|
|
258
|
-
.active {
|
|
259
|
-
opacity: 1;
|
|
260
|
-
}
|
|
261
|
-
.hide-facet-icon:hover .eye,
|
|
262
|
-
.hide-facet-icon .eye-closed {
|
|
263
|
-
display: none;
|
|
264
|
-
}
|
|
265
|
-
.hide-facet-icon:hover .eye-closed,
|
|
266
|
-
.hide-facet-icon.active .eye-closed {
|
|
267
|
-
display: inline;
|
|
268
|
-
}
|
|
269
|
-
.hide-facet-icon.active .eye {
|
|
270
|
-
display: none;
|
|
271
|
-
}
|
|
272
|
-
.sorting-icon {
|
|
273
|
-
cursor: pointer;
|
|
274
|
-
}
|
|
275
136
|
|
|
276
137
|
a:link,
|
|
277
138
|
a:visited {
|
|
@@ -281,26 +142,23 @@ let FacetsTemplate = class FacetsTemplate extends LitElement {
|
|
|
281
142
|
a:hover {
|
|
282
143
|
text-decoration: underline;
|
|
283
144
|
}
|
|
284
|
-
`;
|
|
285
|
-
}
|
|
286
|
-
};
|
|
287
|
-
__decorate([
|
|
288
|
-
property({ type: Object })
|
|
289
|
-
], FacetsTemplate.prototype, "facetGroup", void 0);
|
|
290
|
-
__decorate([
|
|
291
|
-
property({ type: Object })
|
|
292
|
-
], FacetsTemplate.prototype, "selectedFacets", void 0);
|
|
293
|
-
__decorate([
|
|
294
|
-
property({ type: String })
|
|
295
|
-
], FacetsTemplate.prototype, "renderOn", void 0);
|
|
296
|
-
__decorate([
|
|
297
|
-
property({ type:
|
|
298
|
-
], FacetsTemplate.prototype, "
|
|
299
|
-
__decorate([
|
|
300
|
-
|
|
301
|
-
], FacetsTemplate
|
|
302
|
-
FacetsTemplate
|
|
303
|
-
customElement('facets-template')
|
|
304
|
-
], FacetsTemplate);
|
|
305
|
-
export { FacetsTemplate };
|
|
145
|
+
`;
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
__decorate([
|
|
149
|
+
property({ type: Object })
|
|
150
|
+
], FacetsTemplate.prototype, "facetGroup", void 0);
|
|
151
|
+
__decorate([
|
|
152
|
+
property({ type: Object })
|
|
153
|
+
], FacetsTemplate.prototype, "selectedFacets", void 0);
|
|
154
|
+
__decorate([
|
|
155
|
+
property({ type: String })
|
|
156
|
+
], FacetsTemplate.prototype, "renderOn", void 0);
|
|
157
|
+
__decorate([
|
|
158
|
+
property({ type: Object })
|
|
159
|
+
], FacetsTemplate.prototype, "collectionNameCache", void 0);
|
|
160
|
+
FacetsTemplate = __decorate([
|
|
161
|
+
customElement('facets-template')
|
|
162
|
+
], FacetsTemplate);
|
|
163
|
+
export { FacetsTemplate };
|
|
306
164
|
//# sourceMappingURL=facets-template.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"facets-template.js","sourceRoot":"","sources":["../../../src/collection-facets/facets-template.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement, TemplateResult, CSSResultGroup } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';\nimport eyeIcon from '../assets/img/icons/eye';\nimport eyeClosedIcon from '../assets/img/icons/eye-closed';\nimport {\n FacetGroup,\n FacetOption,\n FacetBucket,\n SelectedFacets,\n getDefaultSelectedFacets,\n FacetEventDetails,\n FacetState,\n} from '../models';\n\n@customElement('facets-template')\nexport class FacetsTemplate extends LitElement {\n @property({ type: Object }) facetGroup?: FacetGroup;\n\n @property({ type: Object }) selectedFacets?: SelectedFacets;\n\n @property({ type: String }) renderOn?: string;\n\n @property({ type: String }) collectionPagePath: string = '/details/';\n\n @property({ type: Object })\n collectionNameCache?: CollectionNameCacheInterface;\n\n private facetClicked(e: Event, count: number, negative: boolean) {\n const target = e.target as HTMLInputElement;\n const { checked, name, value } = target;\n if (checked) {\n this.facetChecked(name as FacetOption, value, count, negative);\n } else {\n this.facetUnchecked(name as FacetOption, value);\n }\n\n this.dispatchFacetClickEvent(\n name as FacetOption,\n this.getFacetState(checked, negative),\n negative\n );\n }\n\n private facetChecked(\n key: FacetOption,\n value: string,\n count: number,\n negative: boolean\n ) {\n const { selectedFacets } = this;\n let newFacets: SelectedFacets;\n if (selectedFacets) {\n newFacets = {\n ...selectedFacets,\n };\n } else {\n newFacets = getDefaultSelectedFacets();\n }\n newFacets[key][value] = {\n state: this.getFacetState(true, negative),\n count,\n } as FacetBucket;\n\n this.selectedFacets = newFacets;\n this.dispatchSelectedFacetsChanged();\n }\n\n private facetUnchecked(key: FacetOption, value: string) {\n const { selectedFacets } = this;\n let newFacets: SelectedFacets;\n if (selectedFacets) {\n newFacets = {\n ...selectedFacets,\n };\n } else {\n newFacets = getDefaultSelectedFacets();\n }\n delete newFacets[key][value];\n\n this.selectedFacets = newFacets;\n this.dispatchSelectedFacetsChanged();\n }\n\n /** Returns the composed facet state corresponding to a positive or negative facet's checked state */\n private getFacetState(checked: boolean, negative: boolean): FacetState {\n let state: FacetState;\n if (checked) {\n state = negative ? 'hidden' : 'selected';\n } else {\n state = 'none';\n }\n return state;\n }\n\n private dispatchFacetClickEvent(\n key: FacetOption,\n state: FacetState,\n negative: boolean\n ) {\n const event = new CustomEvent<FacetEventDetails>('facetClick', {\n detail: { key, state, negative },\n composed: true,\n });\n this.dispatchEvent(event);\n }\n\n private dispatchSelectedFacetsChanged() {\n const event = new CustomEvent<SelectedFacets>('selectedFacetsChanged', {\n detail: this.selectedFacets,\n bubbles: true,\n composed: true,\n });\n this.dispatchEvent(event);\n }\n\n private getFacetsTemplate(facetGroup: FacetGroup): TemplateResult {\n let facetsBucket = facetGroup?.buckets as FacetBucket[];\n\n /**\n * sorting FacetBucket before render page / modal\n * - first, selected items should be at top having sorted\n * - second, suppressed/hidden items should be after selected having sorted\n * - and then no-selected / not suppressed items should render having sorted\n */\n facetsBucket = [\n ...facetsBucket\n .filter(x => x.state === 'selected')\n .sort((a, b) => (a.count < b.count ? 1 : -1)),\n ...facetsBucket\n .filter(x => x.state === 'hidden')\n .sort((a, b) => (a.count < b.count ? 1 : -1)),\n ...facetsBucket.filter(x => x.state === 'none'),\n ];\n\n return html`\n <div class=\"facets-on-${this.renderOn}\">\n ${repeat(\n facetsBucket,\n bucket => `${facetGroup.key}:${bucket.key}`,\n bucket => {\n const showOnlyCheckboxId = `${facetGroup.key}:${bucket.key}-show-only`;\n const negativeCheckboxId = `${facetGroup.key}:${bucket.key}-negative`;\n // for collections, we need to asynchronously load the collection name\n // so we use the `async-collection-name` widget and for the rest, we have\n // a static value to use\n const bucketTextDisplay =\n facetGroup.key !== 'collection'\n ? html`${bucket.displayText ?? bucket.key}`\n : html`<a href=\"${this.collectionPagePath}${bucket.key}\">\n <async-collection-name\n .collectionNameCache=${this.collectionNameCache}\n .identifier=${bucket.key}\n placeholder=\"-\"\n ></async-collection-name>\n </a> `;\n const facetHidden = bucket.state === 'hidden';\n const facetSelected = bucket.state === 'selected';\n const titleText = `${facetGroup.key}: ${\n bucket.displayText ?? bucket.key\n }`;\n const onlyShowText = facetSelected\n ? `Show all ${facetGroup.key}s`\n : `Only show ${titleText}`;\n const hideText = `Hide ${titleText}`;\n const unhideText = `Unhide ${titleText}`;\n const showHideText = facetHidden ? unhideText : hideText;\n const ariaLabel = `${titleText}, ${bucket.count} results`;\n return html`\n <div class=\"facet-row\">\n <div class=\"facet-checkbox\">\n <input\n type=\"checkbox\"\n .name=${facetGroup.key}\n .value=${bucket.key}\n @click=${(e: Event) => {\n this.facetClicked(e, bucket.count, false);\n }}\n .checked=${facetSelected}\n class=\"select-facet-checkbox\"\n title=${onlyShowText}\n id=${showOnlyCheckboxId}\n />\n <input\n type=\"checkbox\"\n id=${negativeCheckboxId}\n .name=${facetGroup.key}\n .value=${bucket.key}\n @click=${(e: Event) => {\n this.facetClicked(e, bucket.count, true);\n }}\n .checked=${facetHidden}\n class=\"hide-facet-checkbox\"\n />\n <label\n for=${negativeCheckboxId}\n class=\"hide-facet-icon${facetHidden ? ' active' : ''}\"\n title=${showHideText}\n >\n <span class=\"eye\">${eyeIcon}</span>\n <span class=\"eye-closed\">${eyeClosedIcon}</span>\n </label>\n </div>\n <label\n for=${showOnlyCheckboxId}\n class=\"facet-info-display\"\n title=${onlyShowText}\n aria-label=${ariaLabel}\n >\n <div class=\"facet-title\">${bucketTextDisplay}</div>\n <div class=\"facet-count\">\n ${bucket.count.toLocaleString()}\n </div>\n </label>\n </div>\n `;\n }\n )}\n </div>\n `;\n }\n\n render() {\n return html`${this.getFacetsTemplate(this.facetGroup as FacetGroup)}`;\n }\n\n static get styles(): CSSResultGroup {\n return css`\n @media (max-width: 560px) {\n .facets-on-modal {\n column-count: 1 !important;\n }\n }\n .facets-on-modal {\n column-gap: 15px;\n column-count: 3;\n }\n async-collection-name {\n display: contents;\n }\n ul.facet-list {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n ul.facet-list li {\n margin-bottom: 0.2rem;\n display: grid;\n }\n .facet-checkbox {\n margin: 0 5px 0 0;\n display: flex;\n height: 15px;\n }\n .facet-checkbox input:first-child {\n margin-right: 5px;\n }\n .facet-checkbox input {\n height: 15px;\n width: 15px;\n margin: 0;\n }\n .facet-row {\n display: flex;\n font-weight: 500;\n font-size: 1.2rem;\n margin: 2.5px auto;\n height: auto;\n border-top: var(--facet-row-border-top, 1px solid transparent);\n border-bottom: var(--facet-row-border-bottom, 1px solid transparent);\n overflow: hidden;\n }\n .facet-info-display {\n display: flex;\n flex: 1 1 0%;\n cursor: pointer;\n flex-wrap: wrap;\n }\n .facet-title {\n word-break: break-word;\n display: inline-block;\n flex: 1 1 0%;\n }\n .facet-count {\n text-align: right;\n }\n .select-facet-checkbox {\n cursor: pointer;\n display: inline-block;\n }\n .hide-facet-checkbox {\n display: none;\n }\n .hide-facet-icon {\n width: 15px;\n height: 15px;\n cursor: pointer;\n opacity: 0.3;\n display: inline-block;\n }\n .hide-facet-icon:hover,\n .active {\n opacity: 1;\n }\n .hide-facet-icon:hover .eye,\n .hide-facet-icon .eye-closed {\n display: none;\n }\n .hide-facet-icon:hover .eye-closed,\n .hide-facet-icon.active .eye-closed {\n display: inline;\n }\n .hide-facet-icon.active .eye {\n display: none;\n }\n .sorting-icon {\n cursor: pointer;\n }\n\n a:link,\n a:visited {\n text-decoration: none;\n color: var(--ia-theme-link-color, #4b64ff);\n }\n a:hover {\n text-decoration: underline;\n }\n `;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"facets-template.js","sourceRoot":"","sources":["../../../src/collection-facets/facets-template.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n css,\n html,\n LitElement,\n TemplateResult,\n CSSResultGroup,\n nothing,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';\nimport {\n FacetGroup,\n FacetBucket,\n SelectedFacets,\n getDefaultSelectedFacets,\n FacetEventDetails,\n} from '../models';\nimport { FacetRow } from './facet-row';\n\n@customElement('facets-template')\nexport class FacetsTemplate extends LitElement {\n @property({ type: Object }) facetGroup?: FacetGroup;\n\n @property({ type: Object }) selectedFacets?: SelectedFacets;\n\n @property({ type: String }) renderOn?: string;\n\n @property({ type: Object })\n collectionNameCache?: CollectionNameCacheInterface;\n\n private facetClicked(e: CustomEvent<FacetEventDetails>) {\n const { bucket, negative } = e.detail;\n if (bucket.state === 'none') {\n this.facetUnchecked(bucket);\n } else {\n this.facetChecked(bucket, negative);\n }\n\n this.dispatchFacetClickEvent(e.detail);\n }\n\n private facetChecked(bucket: FacetBucket, negative: boolean) {\n const { facetGroup, selectedFacets } = this;\n if (!facetGroup) return;\n\n let newFacets: SelectedFacets;\n if (selectedFacets) {\n newFacets = {\n ...selectedFacets,\n };\n } else {\n newFacets = getDefaultSelectedFacets();\n }\n newFacets[facetGroup.key][bucket.key] = {\n ...bucket,\n state: FacetRow.getFacetState(true, negative),\n };\n\n this.selectedFacets = newFacets;\n this.dispatchSelectedFacetsChanged();\n }\n\n private facetUnchecked(bucket: FacetBucket) {\n const { facetGroup, selectedFacets } = this;\n if (!facetGroup) return;\n\n let newFacets: SelectedFacets;\n if (selectedFacets) {\n newFacets = {\n ...selectedFacets,\n };\n } else {\n newFacets = getDefaultSelectedFacets();\n }\n delete newFacets[facetGroup.key][bucket.key];\n\n this.selectedFacets = newFacets;\n this.dispatchSelectedFacetsChanged();\n }\n\n private dispatchFacetClickEvent(detail: FacetEventDetails) {\n const event = new CustomEvent<FacetEventDetails>('facetClick', {\n detail,\n composed: true,\n });\n this.dispatchEvent(event);\n }\n\n private dispatchSelectedFacetsChanged() {\n const event = new CustomEvent<SelectedFacets>('selectedFacetsChanged', {\n detail: this.selectedFacets,\n bubbles: true,\n composed: true,\n });\n this.dispatchEvent(event);\n }\n\n private get facetsTemplate(): TemplateResult | typeof nothing {\n const { facetGroup } = this;\n if (!facetGroup) return nothing;\n\n let facetBuckets = facetGroup.buckets as FacetBucket[];\n\n /**\n * sorting FacetBucket before render page / modal\n * - first, selected items should be at top having sorted\n * - second, suppressed/hidden items should be after selected having sorted\n * - and then no-selected / not suppressed items should render having sorted\n */\n facetBuckets = [\n ...facetBuckets\n .filter(x => x.state === 'selected')\n .sort((a, b) => (a.count < b.count ? 1 : -1)),\n ...facetBuckets\n .filter(x => x.state === 'hidden')\n .sort((a, b) => (a.count < b.count ? 1 : -1)),\n ...facetBuckets.filter(x => x.state === 'none'),\n ];\n\n return html`\n <div class=\"facets-on-${this.renderOn}\">\n ${repeat(\n facetBuckets,\n bucket => `${facetGroup.key}:${bucket.key}`,\n bucket => html`<facet-row\n .facetType=${facetGroup.key}\n .bucket=${bucket}\n .collectionNameCache=${this.collectionNameCache}\n @facetClick=${this.facetClicked}\n ></facet-row>`\n )}\n </div>\n `;\n }\n\n render() {\n return html`${this.facetsTemplate}`;\n }\n\n static get styles(): CSSResultGroup {\n return css`\n @media (max-width: 560px) {\n .facets-on-modal {\n column-count: 1 !important;\n }\n }\n .facets-on-modal {\n column-gap: 15px;\n column-count: 3;\n }\n\n ul.facet-list {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n ul.facet-list li {\n margin-bottom: 0.2rem;\n display: grid;\n }\n\n .facet-row {\n display: flex;\n font-weight: 500;\n font-size: 1.2rem;\n margin: 2.5px auto;\n height: auto;\n border-top: var(--facet-row-border-top, 1px solid transparent);\n border-bottom: var(--facet-row-border-bottom, 1px solid transparent);\n overflow: hidden;\n }\n\n a:link,\n a:visited {\n text-decoration: none;\n color: var(--ia-theme-link-color, #4b64ff);\n }\n a:hover {\n text-decoration: underline;\n }\n `;\n }\n}\n"]}
|
|
@@ -1,77 +1,77 @@
|
|
|
1
|
-
import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
|
-
import { Aggregation, SearchServiceInterface, SearchType, AggregationSortType, FilterMap } from '@internetarchive/search-service';
|
|
3
|
-
import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
|
|
4
|
-
import type { ModalManagerInterface } from '@internetarchive/modal-manager';
|
|
5
|
-
import type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
|
|
6
|
-
import { SelectedFacets, FacetGroup, FacetOption } from '../models';
|
|
7
|
-
import '@internetarchive/ia-activity-indicator/ia-activity-indicator';
|
|
8
|
-
import './more-facets-pagination';
|
|
9
|
-
import './facets-template';
|
|
10
|
-
import './toggle-switch';
|
|
11
|
-
export declare class MoreFacetsContent extends LitElement {
|
|
12
|
-
facetKey?: FacetOption;
|
|
13
|
-
facetAggregationKey?: FacetOption;
|
|
14
|
-
query?: string;
|
|
15
|
-
filterMap?: FilterMap;
|
|
16
|
-
modalManager?: ModalManagerInterface;
|
|
17
|
-
searchService?: SearchServiceInterface;
|
|
18
|
-
searchType?: SearchType;
|
|
19
|
-
withinCollection?: string;
|
|
20
|
-
collectionNameCache?: CollectionNameCacheInterface;
|
|
21
|
-
selectedFacets?: SelectedFacets;
|
|
22
|
-
sortedBy: AggregationSortType;
|
|
23
|
-
analyticsHandler?: AnalyticsManagerInterface;
|
|
24
|
-
aggregations?: Record<string, Aggregation>;
|
|
25
|
-
facetGroup?: FacetGroup[];
|
|
26
|
-
facetGroupTitle?: String;
|
|
27
|
-
pageNumber: number;
|
|
28
|
-
/**
|
|
29
|
-
* Facets are loading on popup
|
|
30
|
-
*/
|
|
31
|
-
facetsLoading: boolean;
|
|
32
|
-
paginationSize: number;
|
|
33
|
-
facetsType: string;
|
|
34
|
-
private facetsPerPage;
|
|
35
|
-
updated(changed: PropertyValues): void;
|
|
36
|
-
firstUpdated(): void;
|
|
37
|
-
/**
|
|
38
|
-
* Close more facets modal on Escape click
|
|
39
|
-
*/
|
|
40
|
-
private setupEscapeListeners;
|
|
41
|
-
/**
|
|
42
|
-
* Get specific facets data from search-service API based of currently query params
|
|
43
|
-
* - this.aggregations - hold result of search service and being used for further processing.
|
|
44
|
-
*/
|
|
45
|
-
updateSpecificFacets(): Promise<void>;
|
|
46
|
-
private pageNumberClicked;
|
|
47
|
-
/**
|
|
48
|
-
* Combines the selected facets with the aggregations to create a single list of facets
|
|
49
|
-
*/
|
|
50
|
-
private get mergedFacets();
|
|
51
|
-
/**
|
|
52
|
-
* Converts the selected facets to a `FacetGroup` array,
|
|
53
|
-
* which is easier to work with
|
|
54
|
-
*/
|
|
55
|
-
private get selectedFacetGroups();
|
|
56
|
-
/**
|
|
57
|
-
* Converts the raw `aggregations` to `FacetGroups`, which are easier to use
|
|
58
|
-
*/
|
|
59
|
-
private get aggregationFacetGroups();
|
|
60
|
-
/**
|
|
61
|
-
* for collections, we need to asynchronously load the collection name
|
|
62
|
-
* so we use the `async-collection-name` widget and for the rest, we have a static value to use
|
|
63
|
-
*
|
|
64
|
-
* @param castedBuckets
|
|
65
|
-
*/
|
|
66
|
-
private preloadCollectionNames;
|
|
67
|
-
private get getMoreFacetsTemplate();
|
|
68
|
-
private get loaderTemplate();
|
|
69
|
-
private get facetsPaginationTemplate();
|
|
70
|
-
private get footerTemplate();
|
|
71
|
-
private sortFacetAggregation;
|
|
72
|
-
private get getModalHeaderTemplate();
|
|
73
|
-
render(): TemplateResult<1>;
|
|
74
|
-
private applySearchFacetsClicked;
|
|
75
|
-
private cancelClick;
|
|
76
|
-
static get styles(): CSSResultGroup;
|
|
77
|
-
}
|
|
1
|
+
import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
|
+
import { Aggregation, SearchServiceInterface, SearchType, AggregationSortType, FilterMap } from '@internetarchive/search-service';
|
|
3
|
+
import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
|
|
4
|
+
import type { ModalManagerInterface } from '@internetarchive/modal-manager';
|
|
5
|
+
import type { AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
|
|
6
|
+
import { SelectedFacets, FacetGroup, FacetOption } from '../models';
|
|
7
|
+
import '@internetarchive/ia-activity-indicator/ia-activity-indicator';
|
|
8
|
+
import './more-facets-pagination';
|
|
9
|
+
import './facets-template';
|
|
10
|
+
import './toggle-switch';
|
|
11
|
+
export declare class MoreFacetsContent extends LitElement {
|
|
12
|
+
facetKey?: FacetOption;
|
|
13
|
+
facetAggregationKey?: FacetOption;
|
|
14
|
+
query?: string;
|
|
15
|
+
filterMap?: FilterMap;
|
|
16
|
+
modalManager?: ModalManagerInterface;
|
|
17
|
+
searchService?: SearchServiceInterface;
|
|
18
|
+
searchType?: SearchType;
|
|
19
|
+
withinCollection?: string;
|
|
20
|
+
collectionNameCache?: CollectionNameCacheInterface;
|
|
21
|
+
selectedFacets?: SelectedFacets;
|
|
22
|
+
sortedBy: AggregationSortType;
|
|
23
|
+
analyticsHandler?: AnalyticsManagerInterface;
|
|
24
|
+
aggregations?: Record<string, Aggregation>;
|
|
25
|
+
facetGroup?: FacetGroup[];
|
|
26
|
+
facetGroupTitle?: String;
|
|
27
|
+
pageNumber: number;
|
|
28
|
+
/**
|
|
29
|
+
* Facets are loading on popup
|
|
30
|
+
*/
|
|
31
|
+
facetsLoading: boolean;
|
|
32
|
+
paginationSize: number;
|
|
33
|
+
facetsType: string;
|
|
34
|
+
private facetsPerPage;
|
|
35
|
+
updated(changed: PropertyValues): void;
|
|
36
|
+
firstUpdated(): void;
|
|
37
|
+
/**
|
|
38
|
+
* Close more facets modal on Escape click
|
|
39
|
+
*/
|
|
40
|
+
private setupEscapeListeners;
|
|
41
|
+
/**
|
|
42
|
+
* Get specific facets data from search-service API based of currently query params
|
|
43
|
+
* - this.aggregations - hold result of search service and being used for further processing.
|
|
44
|
+
*/
|
|
45
|
+
updateSpecificFacets(): Promise<void>;
|
|
46
|
+
private pageNumberClicked;
|
|
47
|
+
/**
|
|
48
|
+
* Combines the selected facets with the aggregations to create a single list of facets
|
|
49
|
+
*/
|
|
50
|
+
private get mergedFacets();
|
|
51
|
+
/**
|
|
52
|
+
* Converts the selected facets to a `FacetGroup` array,
|
|
53
|
+
* which is easier to work with
|
|
54
|
+
*/
|
|
55
|
+
private get selectedFacetGroups();
|
|
56
|
+
/**
|
|
57
|
+
* Converts the raw `aggregations` to `FacetGroups`, which are easier to use
|
|
58
|
+
*/
|
|
59
|
+
private get aggregationFacetGroups();
|
|
60
|
+
/**
|
|
61
|
+
* for collections, we need to asynchronously load the collection name
|
|
62
|
+
* so we use the `async-collection-name` widget and for the rest, we have a static value to use
|
|
63
|
+
*
|
|
64
|
+
* @param castedBuckets
|
|
65
|
+
*/
|
|
66
|
+
private preloadCollectionNames;
|
|
67
|
+
private get getMoreFacetsTemplate();
|
|
68
|
+
private get loaderTemplate();
|
|
69
|
+
private get facetsPaginationTemplate();
|
|
70
|
+
private get footerTemplate();
|
|
71
|
+
private sortFacetAggregation;
|
|
72
|
+
private get getModalHeaderTemplate();
|
|
73
|
+
render(): TemplateResult<1>;
|
|
74
|
+
private applySearchFacetsClicked;
|
|
75
|
+
private cancelClick;
|
|
76
|
+
static get styles(): CSSResultGroup;
|
|
77
|
+
}
|