@internetarchive/collection-browser 2.7.12 → 2.7.13-alpha2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +29 -29
- package/.github/workflows/ci.yml +3 -3
- package/.github/workflows/gh-pages-main.yml +2 -2
- package/.github/workflows/pr-preview.yml +2 -2
- package/.husky/pre-commit +4 -4
- package/.prettierignore +1 -0
- package/LICENSE +661 -661
- package/README.md +83 -83
- package/dist/index.d.ts +13 -13
- package/dist/index.js +11 -13
- package/dist/index.js.map +1 -1
- package/dist/src/app-root.d.ts +109 -107
- package/dist/src/app-root.js +541 -531
- 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/favorite-unfilled.d.ts +1 -1
- package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
- package/dist/src/assets/img/icons/filter.d.ts +2 -2
- package/dist/src/assets/img/icons/filter.js +2 -2
- package/dist/src/assets/img/icons/login-required.d.ts +1 -1
- package/dist/src/assets/img/icons/login-required.js +2 -2
- package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/account.js +2 -2
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
- package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/data.js +2 -2
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/film.js +2 -2
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/images.js +2 -2
- package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
- package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/search.js +2 -2
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/software.js +2 -2
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/video.js +2 -2
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
- package/dist/src/assets/img/icons/mediatype/web.js +2 -2
- package/dist/src/assets/img/icons/null-result.d.ts +2 -2
- package/dist/src/assets/img/icons/null-result.js +2 -2
- package/dist/src/assets/img/icons/restricted.d.ts +1 -1
- package/dist/src/assets/img/icons/restricted.js +2 -2
- package/dist/src/assets/img/icons/reviews.d.ts +1 -1
- package/dist/src/assets/img/icons/reviews.js +2 -2
- package/dist/src/assets/img/icons/upload.d.ts +1 -1
- package/dist/src/assets/img/icons/upload.js +2 -2
- package/dist/src/assets/img/icons/views.d.ts +1 -1
- package/dist/src/assets/img/icons/views.js +2 -2
- package/dist/src/circular-activity-indicator.d.ts +5 -5
- package/dist/src/circular-activity-indicator.js +17 -17
- package/dist/src/circular-activity-indicator.js.map +1 -1
- package/dist/src/collection-browser.d.ts +607 -606
- package/dist/src/collection-browser.js +1683 -1677
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-row.d.ts +30 -30
- package/dist/src/collection-facets/facet-row.js +118 -118
- package/dist/src/collection-facets/facet-row.js.map +1 -1
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
- package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
- package/dist/src/collection-facets/facet-tombstone-row.js.map +1 -1
- package/dist/src/collection-facets/facets-template.d.ts +13 -13
- package/dist/src/collection-facets/facets-template.js +49 -49
- package/dist/src/collection-facets/facets-template.js.map +1 -1
- package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
- package/dist/src/collection-facets/more-facets-content.js +406 -408
- package/dist/src/collection-facets/more-facets-content.js.map +1 -1
- package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
- package/dist/src/collection-facets/more-facets-pagination.js +197 -196
- package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -10
- package/dist/src/collection-facets/smart-facets/dedupe.js +33 -33
- package/dist/src/collection-facets/smart-facets/dedupe.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.js +23 -23
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js +44 -44
- package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js +172 -172
- package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/models.d.ts +26 -26
- package/dist/src/collection-facets/smart-facets/models.js +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +31 -31
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +237 -240
- package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -11
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js +86 -86
- package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +16 -16
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +100 -100
- package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -2
- package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +12 -12
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -5
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +15 -15
- package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -1
- 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/toggle-switch.js.map +1 -1
- package/dist/src/collection-facets.d.ts +103 -103
- package/dist/src/collection-facets.js +521 -522
- package/dist/src/collection-facets.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source-interface.d.ts +245 -245
- package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
- package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -1
- package/dist/src/data-source/collection-browser-data-source.d.ts +377 -377
- package/dist/src/data-source/collection-browser-data-source.js +1003 -1001
- package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
- package/dist/src/data-source/collection-browser-query-state.d.ts +44 -44
- package/dist/src/data-source/collection-browser-query-state.js +1 -1
- package/dist/src/data-source/models.d.ts +28 -28
- package/dist/src/data-source/models.js +8 -8
- package/dist/src/empty-placeholder.d.ts +23 -23
- package/dist/src/empty-placeholder.js +87 -88
- package/dist/src/empty-placeholder.js.map +1 -1
- package/dist/src/expanded-date-picker.d.ts +43 -43
- package/dist/src/expanded-date-picker.js +109 -109
- package/dist/src/expanded-date-picker.js.map +1 -1
- 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-handler.js.map +1 -1
- 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/language-code-handler/language-code-mapping.js.map +1 -1
- package/dist/src/manage/manage-bar.d.ts +58 -58
- package/dist/src/manage/manage-bar.js +175 -175
- package/dist/src/manage/manage-bar.js.map +1 -1
- package/dist/src/manage/remove-items-modal-content.d.ts +9 -9
- package/dist/src/manage/remove-items-modal-content.js +34 -34
- package/dist/src/manage/remove-items-modal-content.js.map +1 -1
- package/dist/src/mediatype/mediatype-config.d.ts +3 -3
- package/dist/src/mediatype/mediatype-config.js +92 -91
- package/dist/src/mediatype/mediatype-config.js.map +1 -1
- package/dist/src/models.d.ts +228 -228
- package/dist/src/models.js +401 -401
- 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 +362 -363
- package/dist/src/restoration-state-handler.js.map +1 -1
- 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-tooltip.js.map +1 -1
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
- package/dist/src/sort-filter-bar/alpha-bar.js +136 -136
- package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
- package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/compact.js +2 -2
- package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/list.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
- package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
- package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
- package/dist/src/sort-filter-bar/img/tile.js +2 -2
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
- package/dist/src/sort-filter-bar/sort-filter-bar.js +696 -697
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
- package/dist/src/styles/ia-button.d.ts +2 -2
- package/dist/src/styles/ia-button.js +17 -17
- package/dist/src/styles/item-image-styles.d.ts +8 -8
- package/dist/src/styles/item-image-styles.js +9 -9
- package/dist/src/styles/sr-only.d.ts +1 -1
- package/dist/src/styles/sr-only.js +2 -2
- package/dist/src/tiles/base-tile-component.d.ts +19 -19
- package/dist/src/tiles/base-tile-component.js +64 -64
- package/dist/src/tiles/base-tile-component.js.map +1 -1
- 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/collection-browser-loading-tile.js.map +1 -1
- 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/account-tile.js.map +1 -1
- 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/collection-tile.js.map +1 -1
- package/dist/src/tiles/grid/item-tile.d.ts +34 -34
- package/dist/src/tiles/grid/item-tile.js +159 -160
- package/dist/src/tiles/grid/item-tile.js.map +1 -1
- 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/search-tile.js.map +1 -1
- 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 +54 -54
- package/dist/src/tiles/grid/tile-stats.js.map +1 -1
- 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/hover-pane-controller.js.map +1 -1
- package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
- package/dist/src/tiles/hover/tile-hover-pane.js +72 -70
- package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
- package/dist/src/tiles/image-block.d.ts +18 -18
- package/dist/src/tiles/image-block.js +89 -89
- package/dist/src/tiles/image-block.js.map +1 -1
- package/dist/src/tiles/item-image.d.ts +39 -39
- package/dist/src/tiles/item-image.js +154 -154
- package/dist/src/tiles/item-image.js.map +1 -1
- 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-header.js.map +1 -1
- package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
- package/dist/src/tiles/list/tile-list-compact.js +122 -122
- package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
- package/dist/src/tiles/list/tile-list.d.ts +54 -54
- package/dist/src/tiles/list/tile-list.js +324 -326
- package/dist/src/tiles/list/tile-list.js.map +1 -1
- package/dist/src/tiles/mediatype-icon.d.ts +9 -9
- package/dist/src/tiles/mediatype-icon.js +47 -47
- package/dist/src/tiles/mediatype-icon.js.map +1 -1
- package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
- package/dist/src/tiles/overlay/icon-overlay.js +25 -25
- package/dist/src/tiles/overlay/icon-overlay.js.map +1 -1
- package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
- package/dist/src/tiles/overlay/text-overlay.js +31 -31
- package/dist/src/tiles/overlay/text-overlay.js.map +1 -1
- package/dist/src/tiles/review-block.d.ts +12 -12
- package/dist/src/tiles/review-block.js +56 -56
- package/dist/src/tiles/review-block.js.map +1 -1
- 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/text-snippet-block.js.map +1 -1
- package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
- package/dist/src/tiles/tile-dispatcher.js +230 -230
- package/dist/src/tiles/tile-dispatcher.js.map +1 -1
- package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
- package/dist/src/tiles/tile-display-value-provider.js +94 -94
- package/dist/src/tiles/tile-display-value-provider.js.map +1 -1
- package/dist/src/utils/analytics-events.d.ts +28 -28
- package/dist/src/utils/analytics-events.js +30 -30
- package/dist/src/utils/array-equals.d.ts +4 -4
- package/dist/src/utils/array-equals.js +10 -10
- package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
- package/dist/src/utils/collapse-repeated-quotes.js +13 -13
- package/dist/src/utils/facet-utils.d.ts +83 -83
- package/dist/src/utils/facet-utils.js +145 -145
- package/dist/src/utils/facet-utils.js.map +1 -1
- package/dist/src/utils/format-count.d.ts +7 -7
- package/dist/src/utils/format-count.js +75 -76
- package/dist/src/utils/format-count.js.map +1 -1
- package/dist/src/utils/format-date.d.ts +2 -2
- package/dist/src/utils/format-date.js +27 -27
- package/dist/src/utils/format-date.js.map +1 -1
- 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/format-unit-size.js.map +1 -1
- package/dist/src/utils/local-date-from-utc.d.ts +9 -9
- package/dist/src/utils/local-date-from-utc.js +15 -15
- package/dist/src/utils/log.d.ts +7 -7
- package/dist/src/utils/log.js +13 -15
- package/dist/src/utils/log.js.map +1 -1
- package/dist/src/utils/resolve-mediatype.d.ts +8 -8
- package/dist/src/utils/resolve-mediatype.js +23 -23
- package/dist/src/utils/resolve-mediatype.js.map +1 -1
- 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 +1309 -1308
- package/dist/test/collection-browser.test.js.map +1 -1
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
- package/dist/test/collection-facets/facet-row.test.js +230 -227
- package/dist/test/collection-facets/facet-row.test.js.map +1 -1
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +91 -91
- package/dist/test/collection-facets/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 +140 -141
- package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-pagination.test.js +116 -117
- package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -1
- package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
- package/dist/test/collection-facets/toggle-switch.test.js +82 -73
- package/dist/test/collection-facets/toggle-switch.test.js.map +1 -1
- package/dist/test/collection-facets.test.d.ts +2 -2
- package/dist/test/collection-facets.test.js +692 -692
- package/dist/test/collection-facets.test.js.map +1 -1
- package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
- package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
- package/dist/test/data-source/collection-browser-data-source.test.js.map +1 -1
- package/dist/test/empty-placeholder.test.d.ts +1 -1
- package/dist/test/empty-placeholder.test.js +62 -63
- package/dist/test/empty-placeholder.test.js.map +1 -1
- package/dist/test/expanded-date-picker.test.d.ts +1 -1
- package/dist/test/expanded-date-picker.test.js +97 -96
- package/dist/test/expanded-date-picker.test.js.map +1 -1
- package/dist/test/icon-overlay.test.d.ts +1 -1
- package/dist/test/icon-overlay.test.js +23 -24
- package/dist/test/icon-overlay.test.js.map +1 -1
- package/dist/test/image-block.test.d.ts +1 -1
- package/dist/test/image-block.test.js +106 -107
- package/dist/test/image-block.test.js.map +1 -1
- package/dist/test/item-image.test.d.ts +1 -1
- package/dist/test/item-image.test.js +84 -85
- package/dist/test/item-image.test.js.map +1 -1
- package/dist/test/manage/manage-bar.test.d.ts +2 -2
- package/dist/test/manage/manage-bar.test.js +100 -101
- package/dist/test/manage/manage-bar.test.js.map +1 -1
- package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -1
- package/dist/test/manage/remove-items-modal-content.test.js +44 -45
- package/dist/test/manage/remove-items-modal-content.test.js.map +1 -1
- package/dist/test/mediatype-config.test.d.ts +1 -1
- package/dist/test/mediatype-config.test.js +16 -16
- package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
- package/dist/test/mocks/mock-analytics-handler.js +15 -15
- package/dist/test/mocks/mock-search-responses.d.ts +25 -25
- package/dist/test/mocks/mock-search-responses.js +942 -942
- package/dist/test/mocks/mock-search-responses.js.map +1 -1
- package/dist/test/mocks/mock-search-service.d.ts +15 -15
- package/dist/test/mocks/mock-search-service.js +54 -54
- package/dist/test/mocks/mock-search-service.js.map +1 -1
- package/dist/test/restoration-state-handler.test.d.ts +1 -1
- package/dist/test/restoration-state-handler.test.js +270 -270
- package/dist/test/restoration-state-handler.test.js.map +1 -1
- package/dist/test/review-block.test.d.ts +1 -1
- package/dist/test/review-block.test.js +43 -44
- package/dist/test/review-block.test.js.map +1 -1
- 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-tooltip.test.js.map +1 -1
- 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/alpha-bar.test.js.map +1 -1
- 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 +425 -426
- package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
- package/dist/test/text-overlay.test.d.ts +1 -1
- package/dist/test/text-overlay.test.js +37 -38
- package/dist/test/text-overlay.test.js.map +1 -1
- package/dist/test/text-snippet-block.test.d.ts +1 -1
- package/dist/test/text-snippet-block.test.js +56 -57
- package/dist/test/text-snippet-block.test.js.map +1 -1
- package/dist/test/tile-stats.test.d.ts +1 -1
- package/dist/test/tile-stats.test.js +98 -99
- package/dist/test/tile-stats.test.js.map +1 -1
- package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/account-tile.test.js +75 -76
- package/dist/test/tiles/grid/account-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/collection-tile.test.js +72 -73
- package/dist/test/tiles/grid/collection-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/item-tile.test.js +311 -312
- package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
- package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
- package/dist/test/tiles/grid/search-tile.test.js +50 -51
- package/dist/test/tiles/grid/search-tile.test.js.map +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
- package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -1
- package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
- package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
- package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list-compact.test.js +142 -143
- package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
- package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
- package/dist/test/tiles/list/tile-list.test.js +296 -297
- package/dist/test/tiles/list/tile-list.test.js.map +1 -1
- package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
- package/dist/test/tiles/tile-dispatcher.test.js +100 -100
- package/dist/test/tiles/tile-dispatcher.test.js.map +1 -1
- 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-count.test.js.map +1 -1
- package/dist/test/utils/format-date.test.d.ts +1 -1
- package/dist/test/utils/format-date.test.js +30 -30
- package/dist/test/utils/format-date.test.js.map +1 -1
- 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/dist/test/utils/local-date-from-utc.test.js.map +1 -1
- package/eslint.config.mjs +53 -0
- package/index.html +0 -3
- package/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +41 -39
- package/renovate.json +6 -6
- package/src/app-root.ts +33 -23
- package/src/collection-browser.ts +44 -42
- package/src/collection-facets/facets-template.ts +7 -6
- package/src/collection-facets/more-facets-content.ts +11 -13
- package/src/collection-facets/more-facets-pagination.ts +3 -2
- package/src/collection-facets/smart-facets/dedupe.ts +2 -2
- package/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.ts +1 -1
- package/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.ts +6 -6
- package/src/collection-facets/smart-facets/smart-facet-bar.ts +6 -8
- package/src/collection-facets/smart-facets/smart-facet-button.ts +5 -3
- package/src/collection-facets/smart-facets/smart-facet-dropdown.ts +4 -4
- package/src/collection-facets/smart-facets/smart-facet-heuristics.ts +1 -1
- package/src/collection-facets/toggle-switch.ts +2 -2
- package/src/collection-facets.ts +18 -19
- package/src/data-source/collection-browser-data-source-interface.ts +5 -1
- package/src/data-source/collection-browser-data-source.ts +42 -35
- package/src/empty-placeholder.ts +19 -16
- package/src/expanded-date-picker.ts +1 -1
- package/src/language-code-handler/language-code-handler.ts +1 -1
- package/src/manage/manage-bar.ts +23 -20
- package/src/manage/remove-items-modal-content.ts +2 -2
- package/src/mediatype/mediatype-config.ts +1 -0
- package/src/models.ts +3 -3
- package/src/restoration-state-handler.ts +14 -15
- package/src/sort-filter-bar/alpha-bar.ts +16 -17
- package/src/sort-filter-bar/sort-filter-bar.ts +14 -15
- package/src/tiles/grid/account-tile.ts +1 -1
- package/src/tiles/grid/collection-tile.ts +1 -1
- package/src/tiles/grid/item-tile.ts +9 -9
- package/src/tiles/grid/tile-stats.ts +4 -4
- package/src/tiles/hover/hover-pane-controller.ts +1 -1
- package/src/tiles/hover/tile-hover-pane.ts +4 -2
- package/src/tiles/item-image.ts +1 -1
- package/src/tiles/list/tile-list-compact.ts +2 -2
- package/src/tiles/list/tile-list.ts +22 -24
- package/src/tiles/tile-dispatcher.ts +5 -5
- package/src/tiles/tile-display-value-provider.ts +4 -4
- package/src/utils/facet-utils.ts +6 -6
- package/src/utils/format-count.ts +2 -3
- package/src/utils/format-date.ts +1 -1
- package/src/utils/format-unit-size.ts +1 -1
- package/src/utils/log.ts +1 -3
- package/test/collection-browser.test.ts +125 -124
- package/test/collection-facets/facet-row.test.ts +31 -28
- package/test/collection-facets/facets-template.test.ts +9 -9
- package/test/collection-facets/more-facets-content.test.ts +14 -15
- package/test/collection-facets/more-facets-pagination.test.ts +18 -19
- package/test/collection-facets/toggle-switch.test.ts +28 -18
- package/test/collection-facets.test.ts +46 -39
- package/test/data-source/collection-browser-data-source.test.ts +2 -2
- package/test/empty-placeholder.test.ts +6 -7
- package/test/expanded-date-picker.test.ts +25 -20
- package/test/icon-overlay.test.ts +0 -1
- package/test/image-block.test.ts +6 -7
- package/test/item-image.test.ts +0 -1
- package/test/manage/manage-bar.test.ts +19 -16
- package/test/manage/remove-items-modal-content.test.ts +4 -5
- package/test/mocks/mock-search-responses.ts +2 -1
- package/test/mocks/mock-search-service.ts +1 -1
- package/test/restoration-state-handler.test.ts +12 -12
- package/test/review-block.test.ts +1 -2
- package/test/sort-filter-bar/alpha-bar-tooltip.test.ts +1 -1
- package/test/sort-filter-bar/alpha-bar.test.ts +5 -5
- package/test/sort-filter-bar/sort-filter-bar.test.ts +38 -39
- package/test/text-overlay.test.ts +0 -1
- package/test/text-snippet-block.test.ts +5 -6
- package/test/tile-stats.test.ts +26 -35
- package/test/tiles/grid/account-tile.test.ts +2 -3
- package/test/tiles/grid/collection-tile.test.ts +3 -4
- package/test/tiles/grid/item-tile.test.ts +13 -14
- package/test/tiles/grid/search-tile.test.ts +1 -2
- package/test/tiles/hover/hover-pane-controller.test.ts +15 -15
- package/test/tiles/hover/tile-hover-pane.test.ts +5 -5
- package/test/tiles/list/tile-list-compact.test.ts +1 -2
- package/test/tiles/list/tile-list.test.ts +10 -11
- package/test/tiles/tile-dispatcher.test.ts +5 -5
- package/test/utils/format-count.test.ts +1 -1
- package/test/utils/format-date.test.ts +1 -1
- package/test/utils/local-date-from-utc.test.ts +1 -1
- package/tsconfig.json +0 -1
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { css, html, LitElement, nothing, } from 'lit';
|
|
3
|
-
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
-
import { msg } from '@lit/localize';
|
|
5
|
-
import { favoriteFilledIcon } from '../assets/img/icons/favorite-filled';
|
|
6
|
-
import { favoriteUnfilledIcon } from '../assets/img/icons/favorite-unfilled';
|
|
7
|
-
import { srOnlyStyle } from '../styles/sr-only';
|
|
8
|
-
let ReviewBlock = class ReviewBlock extends LitElement {
|
|
9
|
-
constructor() {
|
|
10
|
-
super(...arguments);
|
|
11
|
-
this.title = '';
|
|
12
|
-
this.body = '';
|
|
13
|
-
this.starRating = 0;
|
|
14
|
-
this.viewSize = 'desktop';
|
|
15
|
-
}
|
|
16
|
-
render() {
|
|
17
|
-
if (!this.title && !this.body && !this.starRating)
|
|
18
|
-
return nothing;
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { css, html, LitElement, nothing, } from 'lit';
|
|
3
|
+
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
+
import { msg } from '@lit/localize';
|
|
5
|
+
import { favoriteFilledIcon } from '../assets/img/icons/favorite-filled';
|
|
6
|
+
import { favoriteUnfilledIcon } from '../assets/img/icons/favorite-unfilled';
|
|
7
|
+
import { srOnlyStyle } from '../styles/sr-only';
|
|
8
|
+
let ReviewBlock = class ReviewBlock extends LitElement {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.title = '';
|
|
12
|
+
this.body = '';
|
|
13
|
+
this.starRating = 0;
|
|
14
|
+
this.viewSize = 'desktop';
|
|
15
|
+
}
|
|
16
|
+
render() {
|
|
17
|
+
if (!this.title && !this.body && !this.starRating)
|
|
18
|
+
return nothing;
|
|
19
19
|
return html `
|
|
20
20
|
<div class="review-container">
|
|
21
21
|
<div class="snippet-view ${this.viewSize}">
|
|
@@ -24,34 +24,34 @@ let ReviewBlock = class ReviewBlock extends LitElement {
|
|
|
24
24
|
<p class="review-body">${this.body}</p>
|
|
25
25
|
</div>
|
|
26
26
|
</div>
|
|
27
|
-
`;
|
|
28
|
-
}
|
|
29
|
-
get starsTemplate() {
|
|
30
|
-
if (this.starRating <= 0)
|
|
31
|
-
return nothing;
|
|
32
|
-
const numFilledStars = Math.min(5, this.starRating);
|
|
33
|
-
const numUnfilledStars = Math.min(5, 5 - this.starRating);
|
|
27
|
+
`;
|
|
28
|
+
}
|
|
29
|
+
get starsTemplate() {
|
|
30
|
+
if (this.starRating <= 0)
|
|
31
|
+
return nothing;
|
|
32
|
+
const numFilledStars = Math.min(5, this.starRating);
|
|
33
|
+
const numUnfilledStars = Math.min(5, 5 - this.starRating);
|
|
34
34
|
return html `
|
|
35
35
|
<div class="star-rating">
|
|
36
36
|
<span class="sr-only">${this.starRating} ${msg('out of 5 stars')}</span>
|
|
37
37
|
${Array(numFilledStars).fill(this.filledStarTemplate)}
|
|
38
38
|
${Array(numUnfilledStars).fill(this.unfilledStarTemplate)}
|
|
39
39
|
</div>
|
|
40
|
-
`;
|
|
41
|
-
}
|
|
42
|
-
get filledStarTemplate() {
|
|
43
|
-
return html `<span aria-hidden="true">${favoriteFilledIcon}</span>`;
|
|
44
|
-
}
|
|
45
|
-
get unfilledStarTemplate() {
|
|
40
|
+
`;
|
|
41
|
+
}
|
|
42
|
+
get filledStarTemplate() {
|
|
43
|
+
return html `<span aria-hidden="true">${favoriteFilledIcon}</span>`;
|
|
44
|
+
}
|
|
45
|
+
get unfilledStarTemplate() {
|
|
46
46
|
return html `
|
|
47
47
|
<span class="unfilled-star" aria-hidden="true">
|
|
48
48
|
${favoriteUnfilledIcon}
|
|
49
49
|
</span>
|
|
50
|
-
`;
|
|
51
|
-
}
|
|
52
|
-
static get styles() {
|
|
53
|
-
return [
|
|
54
|
-
srOnlyStyle,
|
|
50
|
+
`;
|
|
51
|
+
}
|
|
52
|
+
static get styles() {
|
|
53
|
+
return [
|
|
54
|
+
srOnlyStyle,
|
|
55
55
|
css `
|
|
56
56
|
.review-container {
|
|
57
57
|
display: flex;
|
|
@@ -111,24 +111,24 @@ let ReviewBlock = class ReviewBlock extends LitElement {
|
|
|
111
111
|
margin: 0;
|
|
112
112
|
padding-left: 5px;
|
|
113
113
|
}
|
|
114
|
-
`,
|
|
115
|
-
];
|
|
116
|
-
}
|
|
117
|
-
};
|
|
118
|
-
__decorate([
|
|
119
|
-
property({ type: String })
|
|
120
|
-
], ReviewBlock.prototype, "title", void 0);
|
|
121
|
-
__decorate([
|
|
122
|
-
property({ type: String })
|
|
123
|
-
], ReviewBlock.prototype, "body", void 0);
|
|
124
|
-
__decorate([
|
|
125
|
-
property({ type: Number })
|
|
126
|
-
], ReviewBlock.prototype, "starRating", void 0);
|
|
127
|
-
__decorate([
|
|
128
|
-
property({ type: String })
|
|
129
|
-
], ReviewBlock.prototype, "viewSize", void 0);
|
|
130
|
-
ReviewBlock = __decorate([
|
|
131
|
-
customElement('review-block')
|
|
132
|
-
], ReviewBlock);
|
|
133
|
-
export { ReviewBlock };
|
|
114
|
+
`,
|
|
115
|
+
];
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
__decorate([
|
|
119
|
+
property({ type: String })
|
|
120
|
+
], ReviewBlock.prototype, "title", void 0);
|
|
121
|
+
__decorate([
|
|
122
|
+
property({ type: String })
|
|
123
|
+
], ReviewBlock.prototype, "body", void 0);
|
|
124
|
+
__decorate([
|
|
125
|
+
property({ type: Number })
|
|
126
|
+
], ReviewBlock.prototype, "starRating", void 0);
|
|
127
|
+
__decorate([
|
|
128
|
+
property({ type: String })
|
|
129
|
+
], ReviewBlock.prototype, "viewSize", void 0);
|
|
130
|
+
ReviewBlock = __decorate([
|
|
131
|
+
customElement('review-block')
|
|
132
|
+
], ReviewBlock);
|
|
133
|
+
export { ReviewBlock };
|
|
134
134
|
//# sourceMappingURL=review-block.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"review-block.js","sourceRoot":"","sources":["../../../src/tiles/review-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"review-block.js","sourceRoot":"","sources":["../../../src/tiles/review-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGzC,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,UAAU;IAApC;;QACuB,UAAK,GAAG,EAAE,CAAC;QAEX,SAAI,GAAG,EAAE,CAAC;QAEV,eAAU,GAAG,CAAC,CAAC;QAEf,aAAQ,GAAG,SAAS,CAAC;IA2GnD,CAAC;IAzGC,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,OAAO,CAAC;QAElE,OAAO,IAAI,CAAA;;mCAEoB,IAAI,CAAC,QAAQ;YACpC,IAAI,CAAC,aAAa;oCACM,IAAI,CAAC,KAAK;mCACX,IAAI,CAAC,IAAI;;;KAGvC,CAAC;IACJ,CAAC;IAED,IAAY,aAAa;QACvB,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC;YAAE,OAAO,OAAO,CAAC;QAEzC,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,gBAAgB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;QAC1D,OAAO,IAAI,CAAA;;gCAEiB,IAAI,CAAC,UAAU,IAAI,GAAG,CAAC,gBAAgB,CAAC;UAC9D,KAAK,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC;UACnD,KAAK,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC;;KAE5D,CAAC;IACJ,CAAC;IAED,IAAY,kBAAkB;QAC5B,OAAO,IAAI,CAAA,4BAA4B,kBAAkB,SAAS,CAAC;IACrE,CAAC;IAED,IAAY,oBAAoB;QAC9B,OAAO,IAAI,CAAA;;UAEL,oBAAoB;;KAEzB,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO;YACL,WAAW;YACX,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2DF;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AAjH6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;0CAAY;AAEX;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;yCAAW;AAEV;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+CAAgB;AAEf;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAsB;AAPtC,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAkHvB","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n LitElement,\n nothing,\n TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { msg } from '@lit/localize';\nimport { favoriteFilledIcon } from '../assets/img/icons/favorite-filled';\nimport { favoriteUnfilledIcon } from '../assets/img/icons/favorite-unfilled';\nimport { srOnlyStyle } from '../styles/sr-only';\n\n@customElement('review-block')\nexport class ReviewBlock extends LitElement {\n @property({ type: String }) title = '';\n\n @property({ type: String }) body = '';\n\n @property({ type: Number }) starRating = 0;\n\n @property({ type: String }) viewSize = 'desktop';\n\n render() {\n if (!this.title && !this.body && !this.starRating) return nothing;\n\n return html`\n <div class=\"review-container\">\n <div class=\"snippet-view ${this.viewSize}\">\n ${this.starsTemplate}\n <p class=\"review-title\">${this.title}</p>\n <p class=\"review-body\">${this.body}</p>\n </div>\n </div>\n `;\n }\n\n private get starsTemplate(): TemplateResult | typeof nothing {\n if (this.starRating <= 0) return nothing;\n\n const numFilledStars = Math.min(5, this.starRating);\n const numUnfilledStars = Math.min(5, 5 - this.starRating);\n return html`\n <div class=\"star-rating\">\n <span class=\"sr-only\">${this.starRating} ${msg('out of 5 stars')}</span>\n ${Array(numFilledStars).fill(this.filledStarTemplate)}\n ${Array(numUnfilledStars).fill(this.unfilledStarTemplate)}\n </div>\n `;\n }\n\n private get filledStarTemplate(): TemplateResult {\n return html`<span aria-hidden=\"true\">${favoriteFilledIcon}</span>`;\n }\n\n private get unfilledStarTemplate(): TemplateResult {\n return html`\n <span class=\"unfilled-star\" aria-hidden=\"true\">\n ${favoriteUnfilledIcon}\n </span>\n `;\n }\n\n static get styles(): CSSResultGroup {\n return [\n srOnlyStyle,\n css`\n .review-container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n width: calc(100% - 10px);\n border: 1px solid #ccc;\n margin-top: var(--containerTopMargin, 10px);\n margin-left: var(--containerLeftMargin, 0px);\n padding: 5px;\n box-sizing: border-box;\n }\n\n .review-title,\n .review-body {\n display: -webkit-box;\n font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;\n overflow: hidden;\n overflow-wrap: break-word;\n word-break: break-word;\n -webkit-line-clamp: var(--maxLines, 3);\n -webkit-box-orient: vertical;\n margin: 0;\n }\n\n .review-title {\n font-size: 1.4rem;\n line-height: 2rem;\n max-height: 6rem;\n }\n\n .review-title > a[href] {\n color: inherit;\n text-decoration: none;\n }\n\n .review-title > a[href]:hover {\n text-decoration: underline;\n }\n\n .review-body {\n font-size: 1rem;\n line-height: 1.4rem;\n max-height: 4.2rem;\n }\n\n .star-rating svg {\n width: 10px;\n height: 10px;\n }\n\n .unfilled-star {\n fill: #ccc;\n }\n\n .list {\n margin: 0;\n padding-left: 5px;\n }\n `,\n ];\n }\n}\n"]}
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import { CSSResultGroup, LitElement, TemplateResult } from 'lit';
|
|
2
|
-
export declare class TextSnippetBlock extends LitElement {
|
|
3
|
-
snippets?: string[];
|
|
4
|
-
viewSize: string;
|
|
5
|
-
render(): TemplateResult<1>;
|
|
6
|
-
/**
|
|
7
|
-
* An array of HTML templates derived from the snippets, with ellipses inserted
|
|
8
|
-
* at the beginning, end, and between each pair of snippets.
|
|
9
|
-
*/
|
|
10
|
-
private get ellipsisJoinedSnippets();
|
|
11
|
-
/**
|
|
12
|
-
* Returns an array of HTML span templates containing this item's snippets with all of
|
|
13
|
-
* their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
|
|
14
|
-
*
|
|
15
|
-
* This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
|
|
16
|
-
* in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
|
|
17
|
-
*
|
|
18
|
-
* Note on `<em>` vs. `<mark>`:
|
|
19
|
-
* The old search page snippets had search keywords demarcated with `<em>` tags.
|
|
20
|
-
* The `<mark>` tag is semantically more accurate for this use case than `<em>`,
|
|
21
|
-
* but screen-reader behavior may be different. `<em>` will likely be read in a
|
|
22
|
-
* different tone, while `<mark>` is often read no differently than ordinary text
|
|
23
|
-
* in many screen-readers (though there are ways to work around this if needed).
|
|
24
|
-
*/
|
|
25
|
-
private get snippetTemplates();
|
|
26
|
-
static get styles(): CSSResultGroup;
|
|
27
|
-
}
|
|
1
|
+
import { CSSResultGroup, LitElement, TemplateResult } from 'lit';
|
|
2
|
+
export declare class TextSnippetBlock extends LitElement {
|
|
3
|
+
snippets?: string[];
|
|
4
|
+
viewSize: string;
|
|
5
|
+
render(): TemplateResult<1>;
|
|
6
|
+
/**
|
|
7
|
+
* An array of HTML templates derived from the snippets, with ellipses inserted
|
|
8
|
+
* at the beginning, end, and between each pair of snippets.
|
|
9
|
+
*/
|
|
10
|
+
private get ellipsisJoinedSnippets();
|
|
11
|
+
/**
|
|
12
|
+
* Returns an array of HTML span templates containing this item's snippets with all of
|
|
13
|
+
* their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
|
|
14
|
+
*
|
|
15
|
+
* This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
|
|
16
|
+
* in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
|
|
17
|
+
*
|
|
18
|
+
* Note on `<em>` vs. `<mark>`:
|
|
19
|
+
* The old search page snippets had search keywords demarcated with `<em>` tags.
|
|
20
|
+
* The `<mark>` tag is semantically more accurate for this use case than `<em>`,
|
|
21
|
+
* but screen-reader behavior may be different. `<em>` will likely be read in a
|
|
22
|
+
* different tone, while `<mark>` is often read no differently than ordinary text
|
|
23
|
+
* in many screen-readers (though there are ways to work around this if needed).
|
|
24
|
+
*/
|
|
25
|
+
private get snippetTemplates();
|
|
26
|
+
static get styles(): CSSResultGroup;
|
|
27
|
+
}
|
|
@@ -1,74 +1,74 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { css, html, LitElement, nothing, } from 'lit';
|
|
3
|
-
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
-
import { join } from 'lit/directives/join.js';
|
|
5
|
-
let TextSnippetBlock = class TextSnippetBlock extends LitElement {
|
|
6
|
-
constructor() {
|
|
7
|
-
super(...arguments);
|
|
8
|
-
this.snippets = [];
|
|
9
|
-
this.viewSize = 'desktop';
|
|
10
|
-
}
|
|
11
|
-
render() {
|
|
12
|
-
var _a;
|
|
13
|
-
if (!((_a = this.snippets) === null || _a === void 0 ? void 0 : _a.length))
|
|
14
|
-
return html `${nothing}`;
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { css, html, LitElement, nothing, } from 'lit';
|
|
3
|
+
import { customElement, property } from 'lit/decorators.js';
|
|
4
|
+
import { join } from 'lit/directives/join.js';
|
|
5
|
+
let TextSnippetBlock = class TextSnippetBlock extends LitElement {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this.snippets = [];
|
|
9
|
+
this.viewSize = 'desktop';
|
|
10
|
+
}
|
|
11
|
+
render() {
|
|
12
|
+
var _a;
|
|
13
|
+
if (!((_a = this.snippets) === null || _a === void 0 ? void 0 : _a.length))
|
|
14
|
+
return html `${nothing}`;
|
|
15
15
|
return html `
|
|
16
16
|
<div class="container">
|
|
17
17
|
<div class="snippet-view ${this.viewSize}">
|
|
18
18
|
${this.ellipsisJoinedSnippets}
|
|
19
19
|
</div>
|
|
20
20
|
</div>
|
|
21
|
-
`;
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* An array of HTML templates derived from the snippets, with ellipses inserted
|
|
25
|
-
* at the beginning, end, and between each pair of snippets.
|
|
26
|
-
*/
|
|
27
|
-
get ellipsisJoinedSnippets() {
|
|
21
|
+
`;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* An array of HTML templates derived from the snippets, with ellipses inserted
|
|
25
|
+
* at the beginning, end, and between each pair of snippets.
|
|
26
|
+
*/
|
|
27
|
+
get ellipsisJoinedSnippets() {
|
|
28
28
|
return html `
|
|
29
29
|
… ${join(this.snippetTemplates, html ` … `)} …
|
|
30
|
-
`;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Returns an array of HTML span templates containing this item's snippets with all of
|
|
34
|
-
* their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
|
|
35
|
-
*
|
|
36
|
-
* This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
|
|
37
|
-
* in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
|
|
38
|
-
*
|
|
39
|
-
* Note on `<em>` vs. `<mark>`:
|
|
40
|
-
* The old search page snippets had search keywords demarcated with `<em>` tags.
|
|
41
|
-
* The `<mark>` tag is semantically more accurate for this use case than `<em>`,
|
|
42
|
-
* but screen-reader behavior may be different. `<em>` will likely be read in a
|
|
43
|
-
* different tone, while `<mark>` is often read no differently than ordinary text
|
|
44
|
-
* in many screen-readers (though there are ways to work around this if needed).
|
|
45
|
-
*/
|
|
46
|
-
get snippetTemplates() {
|
|
47
|
-
var _a;
|
|
48
|
-
return (_a = this.snippets) === null || _a === void 0 ? void 0 : _a.map(s => {
|
|
49
|
-
const matches = s.matchAll(/{{{(.+?)}}}/gs);
|
|
50
|
-
const templates = [];
|
|
51
|
-
// Convert each match into an HTML template that includes:
|
|
52
|
-
// - Everything from the end of the previous match (or the beginning of the
|
|
53
|
-
// string) up to the current match, as raw text.
|
|
54
|
-
// - The current match (excluding the curly braces) wrapped in a `<mark>` tag.
|
|
55
|
-
let index = 0;
|
|
56
|
-
for (const match of matches) {
|
|
57
|
-
if (match.index != null) {
|
|
30
|
+
`;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Returns an array of HTML span templates containing this item's snippets with all of
|
|
34
|
+
* their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
|
|
35
|
+
*
|
|
36
|
+
* This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
|
|
37
|
+
* in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
|
|
38
|
+
*
|
|
39
|
+
* Note on `<em>` vs. `<mark>`:
|
|
40
|
+
* The old search page snippets had search keywords demarcated with `<em>` tags.
|
|
41
|
+
* The `<mark>` tag is semantically more accurate for this use case than `<em>`,
|
|
42
|
+
* but screen-reader behavior may be different. `<em>` will likely be read in a
|
|
43
|
+
* different tone, while `<mark>` is often read no differently than ordinary text
|
|
44
|
+
* in many screen-readers (though there are ways to work around this if needed).
|
|
45
|
+
*/
|
|
46
|
+
get snippetTemplates() {
|
|
47
|
+
var _a;
|
|
48
|
+
return (_a = this.snippets) === null || _a === void 0 ? void 0 : _a.map(s => {
|
|
49
|
+
const matches = s.matchAll(/{{{(.+?)}}}/gs);
|
|
50
|
+
const templates = [];
|
|
51
|
+
// Convert each match into an HTML template that includes:
|
|
52
|
+
// - Everything from the end of the previous match (or the beginning of the
|
|
53
|
+
// string) up to the current match, as raw text.
|
|
54
|
+
// - The current match (excluding the curly braces) wrapped in a `<mark>` tag.
|
|
55
|
+
let index = 0;
|
|
56
|
+
for (const match of matches) {
|
|
57
|
+
if (match.index != null) {
|
|
58
58
|
templates.push(html `
|
|
59
59
|
${s.slice(index, match.index)}
|
|
60
60
|
<mark>${match[1]}</mark>
|
|
61
|
-
`);
|
|
62
|
-
index = match.index + match[0].length;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
// Include any text from the last match to the end
|
|
66
|
-
templates.push(html `${s.slice(index)}`);
|
|
67
|
-
// Squash everything into a single span template
|
|
68
|
-
return html `<span>${templates}</span>`;
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
static get styles() {
|
|
61
|
+
`);
|
|
62
|
+
index = match.index + match[0].length;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
// Include any text from the last match to the end
|
|
66
|
+
templates.push(html `${s.slice(index)}`);
|
|
67
|
+
// Squash everything into a single span template
|
|
68
|
+
return html `<span>${templates}</span>`;
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
static get styles() {
|
|
72
72
|
return css `
|
|
73
73
|
.container {
|
|
74
74
|
display: flex;
|
|
@@ -116,17 +116,17 @@ let TextSnippetBlock = class TextSnippetBlock extends LitElement {
|
|
|
116
116
|
background-color: #0000ff33;
|
|
117
117
|
color: inherit;
|
|
118
118
|
}
|
|
119
|
-
`;
|
|
120
|
-
}
|
|
121
|
-
};
|
|
122
|
-
__decorate([
|
|
123
|
-
property({ type: Array })
|
|
124
|
-
], TextSnippetBlock.prototype, "snippets", void 0);
|
|
125
|
-
__decorate([
|
|
126
|
-
property({ type: String })
|
|
127
|
-
], TextSnippetBlock.prototype, "viewSize", void 0);
|
|
128
|
-
TextSnippetBlock = __decorate([
|
|
129
|
-
customElement('text-snippet-block')
|
|
130
|
-
], TextSnippetBlock);
|
|
131
|
-
export { TextSnippetBlock };
|
|
119
|
+
`;
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
__decorate([
|
|
123
|
+
property({ type: Array })
|
|
124
|
+
], TextSnippetBlock.prototype, "snippets", void 0);
|
|
125
|
+
__decorate([
|
|
126
|
+
property({ type: String })
|
|
127
|
+
], TextSnippetBlock.prototype, "viewSize", void 0);
|
|
128
|
+
TextSnippetBlock = __decorate([
|
|
129
|
+
customElement('text-snippet-block')
|
|
130
|
+
], TextSnippetBlock);
|
|
131
|
+
export { TextSnippetBlock };
|
|
132
132
|
//# sourceMappingURL=text-snippet-block.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"text-snippet-block.js","sourceRoot":"","sources":["../../../src/tiles/text-snippet-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"text-snippet-block.js","sourceRoot":"","sources":["../../../src/tiles/text-snippet-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAGvC,IAAM,gBAAgB,GAAtB,MAAM,gBAAiB,SAAQ,UAAU;IAAzC;;QACsB,aAAQ,GAAc,EAAE,CAAC;QAExB,aAAQ,GAAW,SAAS,CAAC;IAoH3D,CAAC;IAlHC,MAAM;;QACJ,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,MAAM,CAAA;YAAE,OAAO,IAAI,CAAA,GAAG,OAAO,EAAE,CAAC;QAEpD,OAAO,IAAI,CAAA;;mCAEoB,IAAI,CAAC,QAAQ;YACpC,IAAI,CAAC,sBAAsB;;;KAGlC,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,IAAY,sBAAsB;QAChC,OAAO,IAAI,CAAA;iBACE,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAA,YAAY,CAAC;KACzD,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,IAAY,gBAAgB;;QAC1B,OAAO,MAAA,IAAI,CAAC,QAAQ,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE;YAC5B,MAAM,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;YAC5C,MAAM,SAAS,GAAqB,EAAE,CAAC;YAEvC,0DAA0D;YAC1D,4EAA4E;YAC5E,qDAAqD;YACrD,+EAA+E;YAC/E,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;gBAC5B,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,EAAE,CAAC;oBACxB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA;cACf,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC;oBACrB,KAAK,CAAC,CAAC,CAAC;WACjB,CAAC,CAAC;oBACH,KAAK,GAAG,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;gBACxC,CAAC;YACH,CAAC;YAED,kDAAkD;YAClD,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAExC,gDAAgD;YAChD,OAAO,IAAI,CAAA,SAAS,SAAS,SAAS,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA+CT,CAAC;IACJ,CAAC;CACF,CAAA;AAtH4B;IAA1B,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;kDAA0B;AAExB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAA8B;AAH9C,gBAAgB;IAD5B,aAAa,CAAC,oBAAoB,CAAC;GACvB,gBAAgB,CAuH5B","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n LitElement,\n nothing,\n TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { join } from 'lit/directives/join.js';\n\n@customElement('text-snippet-block')\nexport class TextSnippetBlock extends LitElement {\n @property({ type: Array }) snippets?: string[] = [];\n\n @property({ type: String }) viewSize: string = 'desktop';\n\n render() {\n if (!this.snippets?.length) return html`${nothing}`;\n\n return html`\n <div class=\"container\">\n <div class=\"snippet-view ${this.viewSize}\">\n ${this.ellipsisJoinedSnippets}\n </div>\n </div>\n `;\n }\n\n /**\n * An array of HTML templates derived from the snippets, with ellipses inserted\n * at the beginning, end, and between each pair of snippets.\n */\n private get ellipsisJoinedSnippets(): TemplateResult {\n return html`\n … ${join(this.snippetTemplates, html` … `)} …\n `;\n }\n\n /**\n * Returns an array of HTML span templates containing this item's snippets with all of\n * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.\n *\n * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags\n * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.\n *\n * Note on `<em>` vs. `<mark>`:\n * The old search page snippets had search keywords demarcated with `<em>` tags.\n * The `<mark>` tag is semantically more accurate for this use case than `<em>`,\n * but screen-reader behavior may be different. `<em>` will likely be read in a\n * different tone, while `<mark>` is often read no differently than ordinary text\n * in many screen-readers (though there are ways to work around this if needed).\n */\n private get snippetTemplates(): TemplateResult[] | undefined {\n return this.snippets?.map(s => {\n const matches = s.matchAll(/{{{(.+?)}}}/gs);\n const templates: TemplateResult[] = [];\n\n // Convert each match into an HTML template that includes:\n // - Everything from the end of the previous match (or the beginning of the\n // string) up to the current match, as raw text.\n // - The current match (excluding the curly braces) wrapped in a `<mark>` tag.\n let index = 0;\n for (const match of matches) {\n if (match.index != null) {\n templates.push(html`\n ${s.slice(index, match.index)}\n <mark>${match[1]}</mark>\n `);\n index = match.index + match[0].length;\n }\n }\n\n // Include any text from the last match to the end\n templates.push(html`${s.slice(index)}`);\n\n // Squash everything into a single span template\n return html`<span>${templates}</span>`;\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n .container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n width: calc(100% - 10px);\n border-left: 5px solid #194880;\n margin-top: var(--containerTopMargin, 10px);\n margin-left: var(--containerLeftMargin, 0px);\n border-radius: 3px;\n box-sizing: border-box;\n }\n\n .snippet-view {\n display: -webkit-box;\n font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;\n font-size: 14px;\n overflow: hidden;\n overflow-wrap: break-word;\n -webkit-line-clamp: var(--maxLines, 3);\n -webkit-box-orient: vertical;\n margin-left: 5px;\n }\n\n .grid {\n font-size: 1.2rem;\n line-height: 1.5rem;\n }\n\n .list {\n margin: 0;\n padding-left: 15px;\n font-size: 1.4rem;\n line-height: 2rem;\n\n /*\n * Safari doesn't always respect the line-clamping rules,\n * so we add this to ensure these fields still get truncated.\n */\n max-height: 6rem;\n }\n\n mark {\n /* blue, 20% transparency */\n background-color: #0000ff33;\n color: inherit;\n }\n `;\n }\n}\n"]}
|
|
@@ -1,64 +1,64 @@
|
|
|
1
|
-
import { PropertyValues } from 'lit';
|
|
2
|
-
import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
|
|
3
|
-
import type { TileDisplayMode } from '../models';
|
|
4
|
-
import type { CollectionTitles } from '../data-source/models';
|
|
5
|
-
import './grid/collection-tile';
|
|
6
|
-
import './grid/item-tile';
|
|
7
|
-
import './grid/account-tile';
|
|
8
|
-
import './grid/search-tile';
|
|
9
|
-
import './hover/tile-hover-pane';
|
|
10
|
-
import './list/tile-list';
|
|
11
|
-
import './list/tile-list-compact';
|
|
12
|
-
import './list/tile-list-compact-header';
|
|
13
|
-
import type { TileHoverPane } from './hover/tile-hover-pane';
|
|
14
|
-
import { BaseTileComponent } from './base-tile-component';
|
|
15
|
-
import { HoverPaneProperties, HoverPaneProviderInterface } from './hover/hover-pane-controller';
|
|
16
|
-
export declare class TileDispatcher extends BaseTileComponent implements SharedResizeObserverResizeHandlerInterface, HoverPaneProviderInterface {
|
|
17
|
-
tileDisplayMode?: TileDisplayMode;
|
|
18
|
-
isManageView: boolean;
|
|
19
|
-
resizeObserver?: SharedResizeObserverInterface;
|
|
20
|
-
collectionTitles?: CollectionTitles;
|
|
21
|
-
/** Whether this tile should include a hover pane at all (for applicable tile modes) */
|
|
22
|
-
enableHoverPane: boolean;
|
|
23
|
-
manageCheckTitle: string;
|
|
24
|
-
private hoverPaneController?;
|
|
25
|
-
private container;
|
|
26
|
-
private hoverPane?;
|
|
27
|
-
/** Maps each display mode to whether hover panes should appear in that mode */
|
|
28
|
-
private static readonly HOVER_PANE_DISPLAY_MODES;
|
|
29
|
-
render(): import("lit
|
|
30
|
-
protected firstUpdated(): void;
|
|
31
|
-
private get headerTemplate();
|
|
32
|
-
private get tileTemplate();
|
|
33
|
-
private get linkTileTemplate();
|
|
34
|
-
private get linkTileHref();
|
|
35
|
-
private get manageCheckTemplate();
|
|
36
|
-
/**
|
|
37
|
-
* Whether hover pane behavior should be prepared for this tile
|
|
38
|
-
* (e.g., whether mouse listeners should be attached, etc.)
|
|
39
|
-
*/
|
|
40
|
-
private get shouldPrepareHoverPane();
|
|
41
|
-
private get isHoverEnabled();
|
|
42
|
-
/** @inheritdoc */
|
|
43
|
-
getHoverPane(): TileHoverPane | undefined;
|
|
44
|
-
/** @inheritdoc */
|
|
45
|
-
getHoverPaneProps(): HoverPaneProperties;
|
|
46
|
-
handleResize(entry: ResizeObserverEntry): void;
|
|
47
|
-
disconnectedCallback(): void;
|
|
48
|
-
private stopResizeObservation;
|
|
49
|
-
private startResizeObservation;
|
|
50
|
-
updated(props: PropertyValues): void;
|
|
51
|
-
/**
|
|
52
|
-
* Handler for when the tile link is left-clicked. Emits the `resultSelected` event.
|
|
53
|
-
* In manage view, it also checks/unchecks the tile.
|
|
54
|
-
*/
|
|
55
|
-
private handleLinkClicked;
|
|
56
|
-
/**
|
|
57
|
-
* Handler for when the tile link is right-clicked.
|
|
58
|
-
* In manage view, it opens the item in a new tab. Otherwise, does nothing.
|
|
59
|
-
*/
|
|
60
|
-
private handleLinkContextMenu;
|
|
61
|
-
private tileInfoButtonPressed;
|
|
62
|
-
private get tile();
|
|
63
|
-
static get styles(): import("lit").CSSResult;
|
|
64
|
-
}
|
|
1
|
+
import { PropertyValues } from 'lit';
|
|
2
|
+
import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
|
|
3
|
+
import type { TileDisplayMode } from '../models';
|
|
4
|
+
import type { CollectionTitles } from '../data-source/models';
|
|
5
|
+
import './grid/collection-tile';
|
|
6
|
+
import './grid/item-tile';
|
|
7
|
+
import './grid/account-tile';
|
|
8
|
+
import './grid/search-tile';
|
|
9
|
+
import './hover/tile-hover-pane';
|
|
10
|
+
import './list/tile-list';
|
|
11
|
+
import './list/tile-list-compact';
|
|
12
|
+
import './list/tile-list-compact-header';
|
|
13
|
+
import type { TileHoverPane } from './hover/tile-hover-pane';
|
|
14
|
+
import { BaseTileComponent } from './base-tile-component';
|
|
15
|
+
import { HoverPaneProperties, HoverPaneProviderInterface } from './hover/hover-pane-controller';
|
|
16
|
+
export declare class TileDispatcher extends BaseTileComponent implements SharedResizeObserverResizeHandlerInterface, HoverPaneProviderInterface {
|
|
17
|
+
tileDisplayMode?: TileDisplayMode;
|
|
18
|
+
isManageView: boolean;
|
|
19
|
+
resizeObserver?: SharedResizeObserverInterface;
|
|
20
|
+
collectionTitles?: CollectionTitles;
|
|
21
|
+
/** Whether this tile should include a hover pane at all (for applicable tile modes) */
|
|
22
|
+
enableHoverPane: boolean;
|
|
23
|
+
manageCheckTitle: string;
|
|
24
|
+
private hoverPaneController?;
|
|
25
|
+
private container;
|
|
26
|
+
private hoverPane?;
|
|
27
|
+
/** Maps each display mode to whether hover panes should appear in that mode */
|
|
28
|
+
private static readonly HOVER_PANE_DISPLAY_MODES;
|
|
29
|
+
render(): import("lit").TemplateResult<1>;
|
|
30
|
+
protected firstUpdated(): void;
|
|
31
|
+
private get headerTemplate();
|
|
32
|
+
private get tileTemplate();
|
|
33
|
+
private get linkTileTemplate();
|
|
34
|
+
private get linkTileHref();
|
|
35
|
+
private get manageCheckTemplate();
|
|
36
|
+
/**
|
|
37
|
+
* Whether hover pane behavior should be prepared for this tile
|
|
38
|
+
* (e.g., whether mouse listeners should be attached, etc.)
|
|
39
|
+
*/
|
|
40
|
+
private get shouldPrepareHoverPane();
|
|
41
|
+
private get isHoverEnabled();
|
|
42
|
+
/** @inheritdoc */
|
|
43
|
+
getHoverPane(): TileHoverPane | undefined;
|
|
44
|
+
/** @inheritdoc */
|
|
45
|
+
getHoverPaneProps(): HoverPaneProperties;
|
|
46
|
+
handleResize(entry: ResizeObserverEntry): void;
|
|
47
|
+
disconnectedCallback(): void;
|
|
48
|
+
private stopResizeObservation;
|
|
49
|
+
private startResizeObservation;
|
|
50
|
+
updated(props: PropertyValues): void;
|
|
51
|
+
/**
|
|
52
|
+
* Handler for when the tile link is left-clicked. Emits the `resultSelected` event.
|
|
53
|
+
* In manage view, it also checks/unchecks the tile.
|
|
54
|
+
*/
|
|
55
|
+
private handleLinkClicked;
|
|
56
|
+
/**
|
|
57
|
+
* Handler for when the tile link is right-clicked.
|
|
58
|
+
* In manage view, it opens the item in a new tab. Otherwise, does nothing.
|
|
59
|
+
*/
|
|
60
|
+
private handleLinkContextMenu;
|
|
61
|
+
private tileInfoButtonPressed;
|
|
62
|
+
private get tile();
|
|
63
|
+
static get styles(): import("lit").CSSResult;
|
|
64
|
+
}
|