@internetarchive/collection-browser 0.4.11 → 0.4.13-alpha.1
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 +26 -26
- package/.github/workflows/gh-pages-main.yml +39 -39
- package/.github/workflows/npm-publish.yml +39 -39
- package/.github/workflows/pr-preview.yml +38 -38
- package/.husky/pre-commit +4 -4
- package/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 +50 -50
- package/dist/src/app-root.js +278 -278
- 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/empty-query.d.ts +2 -2
- package/dist/src/assets/img/icons/empty-query.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/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 +280 -279
- package/dist/src/collection-browser.js +1178 -1156
- package/dist/src/collection-browser.js.map +1 -1
- package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
- package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
- package/dist/src/collection-facets/facets-template.d.ts +16 -16
- package/dist/src/collection-facets/facets-template.js +125 -125
- package/dist/src/collection-facets/more-facets-content.d.ts +76 -75
- package/dist/src/collection-facets/more-facets-content.js +354 -377
- 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 -195
- package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
- package/dist/src/collection-facets/toggle-switch.d.ts +41 -0
- package/dist/src/collection-facets/toggle-switch.js +184 -0
- package/dist/src/collection-facets/toggle-switch.js.map +1 -0
- package/dist/src/collection-facets.d.ts +81 -81
- package/dist/src/collection-facets.js +376 -385
- package/dist/src/collection-facets.js.map +1 -1
- package/dist/src/empty-placeholder.d.ts +13 -11
- package/dist/src/empty-placeholder.js +80 -44
- package/dist/src/empty-placeholder.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-mapping.d.ts +1 -1
- package/dist/src/language-code-handler/language-code-mapping.js +562 -562
- package/dist/src/mediatype/mediatype-config.d.ts +3 -3
- package/dist/src/mediatype/mediatype-config.js +85 -85
- package/dist/src/models.d.ts +119 -115
- package/dist/src/models.js +136 -125
- package/dist/src/models.js.map +1 -1
- package/dist/src/restoration-state-handler.d.ts +45 -45
- package/dist/src/restoration-state-handler.js +230 -230
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +25 -26
- package/dist/src/sort-filter-bar/alpha-bar-tooltip.js.map +1 -1
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +20 -20
- 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 +3 -3
- package/dist/src/sort-filter-bar/img/list.js.map +1 -1
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +15 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js +17 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-down.js.map +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js +17 -0
- package/dist/src/sort-filter-bar/img/sort-toggle-up.js.map +1 -0
- 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 +189 -108
- package/dist/src/sort-filter-bar/sort-filter-bar.js +708 -614
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
- package/dist/src/styles/item-image-styles.d.ts +8 -8
- package/dist/src/styles/item-image-styles.js +9 -9
- 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 +20 -20
- package/dist/src/tiles/grid/account-tile.js +64 -64
- package/dist/src/tiles/grid/collection-tile.d.ts +17 -17
- package/dist/src/tiles/grid/collection-tile.js +71 -71
- package/dist/src/tiles/grid/item-tile.d.ts +32 -32
- package/dist/src/tiles/grid/item-tile.js +130 -126
- package/dist/src/tiles/grid/item-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 +7 -7
- package/dist/src/tiles/grid/tile-stats.d.ts +11 -10
- package/dist/src/tiles/grid/tile-stats.js +44 -40
- 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/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 +72 -72
- package/dist/src/tiles/item-image.d.ts +35 -35
- package/dist/src/tiles/item-image.js +117 -117
- package/dist/src/tiles/list/account-label.d.ts +1 -1
- package/dist/src/tiles/list/account-label.js +6 -6
- package/dist/src/tiles/list/date-label.d.ts +1 -1
- package/dist/src/tiles/list/date-label.js +12 -12
- package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
- package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
- package/dist/src/tiles/list/tile-list-compact.d.ts +22 -21
- package/dist/src/tiles/list/tile-list-compact.js +114 -101
- package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
- package/dist/src/tiles/list/tile-list.d.ts +55 -55
- package/dist/src/tiles/list/tile-list.js +304 -301
- 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/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 +58 -58
- package/dist/src/tiles/tile-dispatcher.js +194 -194
- package/dist/src/utils/analytics-events.d.ts +22 -22
- package/dist/src/utils/analytics-events.js +24 -24
- 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 +23 -23
- package/dist/src/utils/format-unit-size.d.ts +2 -2
- package/dist/src/utils/format-unit-size.js +33 -33
- package/dist/test/collection-browser.test.d.ts +1 -1
- package/dist/test/collection-browser.test.js +584 -584
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +62 -62
- package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
- package/dist/test/collection-facets/more-facets-content.test.js +114 -114
- 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 -0
- package/dist/test/collection-facets/toggle-switch.test.js +87 -0
- package/dist/test/collection-facets/toggle-switch.test.js.map +1 -0
- package/dist/test/collection-facets.test.d.ts +2 -2
- package/dist/test/collection-facets.test.js +460 -460
- package/dist/test/empty-placeholder.test.d.ts +1 -1
- package/dist/test/empty-placeholder.test.js +33 -33
- 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 +84 -84
- 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 +7 -7
- package/dist/test/mocks/mock-collection-name-cache.js +13 -13
- package/dist/test/mocks/mock-search-responses.d.ts +12 -12
- package/dist/test/mocks/mock-search-responses.js +341 -341
- package/dist/test/mocks/mock-search-service.d.ts +13 -13
- package/dist/test/mocks/mock-search-service.js +40 -40
- package/dist/test/restoration-state-handler.test.d.ts +1 -1
- package/dist/test/restoration-state-handler.test.js +125 -125
- 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 +372 -199
- 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 +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 +158 -158
- package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
- package/dist/test/tiles/hover/hover-pane-controller.test.js +257 -257
- 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 +104 -92
- 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 +175 -163
- 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 +67 -67
- 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/local.archive.org.cert +86 -86
- package/local.archive.org.key +27 -27
- package/package.json +4 -3
- package/renovate.json +6 -6
- package/src/collection-browser.ts +28 -1
- package/src/collection-facets/more-facets-content.ts +25 -48
- package/src/collection-facets/more-facets-pagination.ts +5 -3
- package/src/collection-facets/toggle-switch.ts +184 -0
- package/src/collection-facets.ts +1 -10
- package/src/empty-placeholder.ts +53 -7
- package/src/models.ts +23 -8
- package/src/sort-filter-bar/alpha-bar-tooltip.ts +1 -2
- package/src/sort-filter-bar/img/list.ts +1 -1
- package/src/sort-filter-bar/img/sort-toggle-disabled.ts +15 -0
- package/src/sort-filter-bar/img/sort-toggle-down.ts +17 -0
- package/src/sort-filter-bar/img/sort-toggle-up.ts +17 -0
- package/src/sort-filter-bar/sort-filter-bar.ts +433 -303
- package/src/tiles/grid/item-tile.ts +6 -1
- package/src/tiles/grid/tile-stats.ts +3 -1
- package/src/tiles/list/tile-list-compact.ts +15 -2
- package/src/tiles/list/tile-list.ts +3 -0
- package/test/collection-facets/toggle-switch.test.ts +154 -0
- package/test/sort-filter-bar/sort-filter-bar.test.ts +377 -101
- package/test/tiles/list/tile-list-compact.test.ts +14 -0
- package/test/tiles/list/tile-list.test.ts +14 -0
- package/tsconfig.json +21 -21
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -35,6 +35,10 @@ export class ItemTile extends LitElement {
|
|
|
35
35
|
|
|
36
36
|
render() {
|
|
37
37
|
const itemTitle = this.model?.title;
|
|
38
|
+
const [viewCount, viewLabel] =
|
|
39
|
+
this.sortParam?.field === 'week'
|
|
40
|
+
? [this.model?.weeklyViewCount, 'weekly views']
|
|
41
|
+
: [this.model?.viewCount, 'all-time views'];
|
|
38
42
|
|
|
39
43
|
return html`
|
|
40
44
|
<div class="container">
|
|
@@ -58,7 +62,8 @@ export class ItemTile extends LitElement {
|
|
|
58
62
|
|
|
59
63
|
<tile-stats
|
|
60
64
|
.mediatype=${this.model?.mediatype}
|
|
61
|
-
.viewCount=${
|
|
65
|
+
.viewCount=${viewCount}
|
|
66
|
+
.viewLabel=${viewLabel}
|
|
62
67
|
.favCount=${this.model?.favCount}
|
|
63
68
|
.commentCount=${this.model?.commentCount}
|
|
64
69
|
>
|
|
@@ -16,6 +16,8 @@ export class TileStats extends LitElement {
|
|
|
16
16
|
|
|
17
17
|
@property({ type: Number }) viewCount?: number;
|
|
18
18
|
|
|
19
|
+
@property({ type: String }) viewLabel?: number;
|
|
20
|
+
|
|
19
21
|
@property({ type: Number }) favCount?: number;
|
|
20
22
|
|
|
21
23
|
@property({ type: Number }) commentCount?: number;
|
|
@@ -31,7 +33,7 @@ export class TileStats extends LitElement {
|
|
|
31
33
|
const uploadsOrViewsTitle =
|
|
32
34
|
this.mediatype === 'account'
|
|
33
35
|
? `${this.itemCount} uploads`
|
|
34
|
-
: `${this.viewCount} all-time views`;
|
|
36
|
+
: `${this.viewCount} ${this.viewLabel ?? 'all-time views'}`;
|
|
35
37
|
|
|
36
38
|
return html`
|
|
37
39
|
<div class="item-stats">
|
|
@@ -41,7 +41,9 @@ export class TileListCompact extends LitElement {
|
|
|
41
41
|
.loggedIn=${this.loggedIn}
|
|
42
42
|
>
|
|
43
43
|
</image-block>
|
|
44
|
-
<
|
|
44
|
+
<a href=${this.href} id="title"
|
|
45
|
+
>${DOMPurify.sanitize(this.model?.title ?? '')}</a
|
|
46
|
+
>
|
|
45
47
|
<div id="creator">
|
|
46
48
|
${this.model?.mediatype === 'account'
|
|
47
49
|
? accountLabel(this.model?.dateAdded)
|
|
@@ -60,6 +62,14 @@ export class TileListCompact extends LitElement {
|
|
|
60
62
|
`;
|
|
61
63
|
}
|
|
62
64
|
|
|
65
|
+
private get href(): string {
|
|
66
|
+
// Use the server-specified href if available.
|
|
67
|
+
// Otherwise, construct a details page URL from the item identifier.
|
|
68
|
+
return this.model?.href
|
|
69
|
+
? `${this.baseNavigationUrl}${this.model.href}`
|
|
70
|
+
: `${this.baseNavigationUrl}/details/${this.model?.identifier}`;
|
|
71
|
+
}
|
|
72
|
+
|
|
63
73
|
/*
|
|
64
74
|
* TODO: fix field names to match model in src/collection-browser.ts
|
|
65
75
|
* private get dateSortSelector()
|
|
@@ -145,10 +155,13 @@ export class TileListCompact extends LitElement {
|
|
|
145
155
|
}
|
|
146
156
|
|
|
147
157
|
#title {
|
|
148
|
-
color: #4b64ff;
|
|
149
158
|
text-decoration: none;
|
|
150
159
|
}
|
|
151
160
|
|
|
161
|
+
#title:link {
|
|
162
|
+
color: var(--ia-theme-link-color, #4b64ff);
|
|
163
|
+
}
|
|
164
|
+
|
|
152
165
|
#title,
|
|
153
166
|
#creator {
|
|
154
167
|
text-overflow: ellipsis;
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
import { expect, fixture } from '@open-wc/testing';
|
|
2
|
+
import sinon from 'sinon';
|
|
3
|
+
import { html } from 'lit';
|
|
4
|
+
import type { ToggleSwitch } from '../../src/collection-facets/toggle-switch';
|
|
5
|
+
|
|
6
|
+
import '../../src/collection-facets/toggle-switch';
|
|
7
|
+
|
|
8
|
+
describe('Toggle switch', () => {
|
|
9
|
+
it('renders component', async () => {
|
|
10
|
+
const el = await fixture<ToggleSwitch>(
|
|
11
|
+
html`<toggle-switch></toggle-switch>`
|
|
12
|
+
);
|
|
13
|
+
|
|
14
|
+
expect(el.shadowRoot?.querySelector('#switch-button')).to.exist;
|
|
15
|
+
expect(el.shadowRoot?.querySelector('#knob')).to.exist;
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
it('renders provided L/R values', async () => {
|
|
19
|
+
const el = await fixture<ToggleSwitch>(
|
|
20
|
+
html`<toggle-switch .leftValue=${'L'} .rightValue=${'R'}></toggle-switch>`
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
expect(el.value).to.equal('L');
|
|
24
|
+
expect(el.selectedLabel).to.equal('L');
|
|
25
|
+
|
|
26
|
+
expect(
|
|
27
|
+
el.shadowRoot
|
|
28
|
+
?.querySelector('label[for=switch-left]')
|
|
29
|
+
?.textContent?.trim()
|
|
30
|
+
).to.equal('L');
|
|
31
|
+
expect(
|
|
32
|
+
el.shadowRoot
|
|
33
|
+
?.querySelector('label[for=switch-right]')
|
|
34
|
+
?.textContent?.trim()
|
|
35
|
+
).to.equal('R');
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it('renders provided L/R labels instead of values', async () => {
|
|
39
|
+
const el = await fixture<ToggleSwitch>(
|
|
40
|
+
html`<toggle-switch
|
|
41
|
+
.leftValue=${'L'}
|
|
42
|
+
.leftLabel=${'L-label'}
|
|
43
|
+
.rightValue=${'R'}
|
|
44
|
+
.rightLabel=${'R-label'}
|
|
45
|
+
></toggle-switch>`
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
expect(el.value).to.equal('L');
|
|
49
|
+
expect(el.selectedLabel).to.equal('L-label');
|
|
50
|
+
|
|
51
|
+
expect(
|
|
52
|
+
(el.shadowRoot?.querySelector('#switch-left') as HTMLInputElement)?.value
|
|
53
|
+
).to.equal('L');
|
|
54
|
+
expect(
|
|
55
|
+
(el.shadowRoot?.querySelector('#switch-right') as HTMLInputElement)?.value
|
|
56
|
+
).to.equal('R');
|
|
57
|
+
|
|
58
|
+
expect(
|
|
59
|
+
el.shadowRoot
|
|
60
|
+
?.querySelector('label[for=switch-left]')
|
|
61
|
+
?.textContent?.trim()
|
|
62
|
+
).to.equal('L-label');
|
|
63
|
+
expect(
|
|
64
|
+
el.shadowRoot
|
|
65
|
+
?.querySelector('label[for=switch-right]')
|
|
66
|
+
?.textContent?.trim()
|
|
67
|
+
).to.equal('R-label');
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('sets the initial side', async () => {
|
|
71
|
+
const el = await fixture<ToggleSwitch>(
|
|
72
|
+
html`<toggle-switch
|
|
73
|
+
.leftValue=${'L'}
|
|
74
|
+
.rightValue=${'R'}
|
|
75
|
+
.side=${'right'}
|
|
76
|
+
></toggle-switch>`
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
expect(el.value).to.equal('R');
|
|
80
|
+
expect(el.selectedLabel).to.equal('R');
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it('toggles on click', async () => {
|
|
84
|
+
const el = await fixture<ToggleSwitch>(
|
|
85
|
+
html`<toggle-switch .leftValue=${'L'} .rightValue=${'R'}></toggle-switch>`
|
|
86
|
+
);
|
|
87
|
+
|
|
88
|
+
const button = el.shadowRoot?.querySelector(
|
|
89
|
+
'#switch-button'
|
|
90
|
+
) as HTMLButtonElement;
|
|
91
|
+
|
|
92
|
+
expect(el.value).to.equal('L');
|
|
93
|
+
button.click();
|
|
94
|
+
await el.updateComplete;
|
|
95
|
+
|
|
96
|
+
expect(el.value).to.equal('R');
|
|
97
|
+
button.click();
|
|
98
|
+
await el.updateComplete;
|
|
99
|
+
|
|
100
|
+
expect(el.value).to.equal('L');
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('toggles on radio change', async () => {
|
|
104
|
+
const el = await fixture<ToggleSwitch>(
|
|
105
|
+
html`<toggle-switch .leftValue=${'L'} .rightValue=${'R'}></toggle-switch>`
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
const leftRadio = el.shadowRoot?.querySelector(
|
|
109
|
+
'#switch-left'
|
|
110
|
+
) as HTMLInputElement;
|
|
111
|
+
const rightRadio = el.shadowRoot?.querySelector(
|
|
112
|
+
'#switch-right'
|
|
113
|
+
) as HTMLInputElement;
|
|
114
|
+
|
|
115
|
+
expect(el.value).to.equal('L');
|
|
116
|
+
rightRadio.click();
|
|
117
|
+
await el.updateComplete;
|
|
118
|
+
|
|
119
|
+
expect(el.value).to.equal('R');
|
|
120
|
+
leftRadio.click();
|
|
121
|
+
await el.updateComplete;
|
|
122
|
+
|
|
123
|
+
expect(el.value).to.equal('L');
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
it('emits change event when toggled', async () => {
|
|
127
|
+
const changeSpy = sinon.spy();
|
|
128
|
+
const el = await fixture<ToggleSwitch>(
|
|
129
|
+
html`<toggle-switch
|
|
130
|
+
.leftValue=${'L'}
|
|
131
|
+
.rightValue=${'R'}
|
|
132
|
+
@change=${changeSpy}
|
|
133
|
+
></toggle-switch>`
|
|
134
|
+
);
|
|
135
|
+
|
|
136
|
+
const button = el.shadowRoot?.querySelector(
|
|
137
|
+
'#switch-button'
|
|
138
|
+
) as HTMLButtonElement;
|
|
139
|
+
|
|
140
|
+
button.click();
|
|
141
|
+
await el.updateComplete;
|
|
142
|
+
|
|
143
|
+
expect(changeSpy.callCount).to.equal(1);
|
|
144
|
+
|
|
145
|
+
const leftRadio = el.shadowRoot?.querySelector(
|
|
146
|
+
'#switch-left'
|
|
147
|
+
) as HTMLInputElement;
|
|
148
|
+
|
|
149
|
+
leftRadio.click();
|
|
150
|
+
await el.updateComplete;
|
|
151
|
+
|
|
152
|
+
expect(changeSpy.callCount).to.equal(2);
|
|
153
|
+
});
|
|
154
|
+
});
|