@internetarchive/collection-browser 1.14.12 → 1.14.13
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 +83 -83
- package/dist/src/app-root.js +412 -412
- 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 +534 -534
- package/dist/src/collection-browser.js +1897 -1897
- package/dist/src/collection-facets/facet-row.d.ts +30 -30
- package/dist/src/collection-facets/facet-row.js +115 -115
- 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 -17
- package/dist/src/collection-facets/facets-template.js +114 -114
- 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 -180
- package/dist/src/models.js +269 -269
- package/dist/src/restoration-state-handler.d.ts +70 -70
- package/dist/src/restoration-state-handler.js +355 -355
- package/dist/src/selected-facets.d.ts +67 -0
- package/dist/src/selected-facets.js +149 -0
- package/dist/src/selected-facets.js.map +1 -0
- 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 +210 -210
- package/dist/src/sort-filter-bar/sort-filter-bar.js +644 -644
- 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 +1137 -1137
- package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
- package/dist/test/collection-facets/facet-row.test.js +206 -206
- package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
- package/dist/test/collection-facets/facets-template.test.js +105 -105
- 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 -651
- 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 +386 -386
- 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 +4 -4
- package/renovate.json +6 -6
- package/src/selected-facets.ts +216 -0
- package/tsconfig.json +21 -21
- package/web-dev-server.config.mjs +30 -30
- package/web-test-runner.config.mjs +41 -41
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
import { aTimeout, expect, fixture } from '@open-wc/testing';
|
|
2
|
-
import { html } from 'lit';
|
|
3
|
-
import sinon from 'sinon';
|
|
4
|
-
import '../../src/tiles/tile-dispatcher';
|
|
5
|
-
import { TileHoverPane } from '../../src/tiles/hover/tile-hover-pane';
|
|
6
|
-
describe('Tile Dispatcher', () => {
|
|
7
|
-
it('should render item-tile for grid mode by default', async () => {
|
|
8
|
-
var _a;
|
|
1
|
+
import { aTimeout, expect, fixture } from '@open-wc/testing';
|
|
2
|
+
import { html } from 'lit';
|
|
3
|
+
import sinon from 'sinon';
|
|
4
|
+
import '../../src/tiles/tile-dispatcher';
|
|
5
|
+
import { TileHoverPane } from '../../src/tiles/hover/tile-hover-pane';
|
|
6
|
+
describe('Tile Dispatcher', () => {
|
|
7
|
+
it('should render item-tile for grid mode by default', async () => {
|
|
8
|
+
var _a;
|
|
9
9
|
const el = await fixture(html `
|
|
10
10
|
<tile-dispatcher
|
|
11
11
|
.tileDisplayMode=${'grid'}
|
|
12
12
|
.model=${{ mediatype: 'texts' }}
|
|
13
13
|
>
|
|
14
14
|
</tile-dispatcher>
|
|
15
|
-
`);
|
|
16
|
-
const itemTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('item-tile');
|
|
17
|
-
expect(itemTile).to.exist;
|
|
18
|
-
});
|
|
19
|
-
it('should render collection-tile for grid mode and collection mediatype', async () => {
|
|
20
|
-
var _a;
|
|
15
|
+
`);
|
|
16
|
+
const itemTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('item-tile');
|
|
17
|
+
expect(itemTile).to.exist;
|
|
18
|
+
});
|
|
19
|
+
it('should render collection-tile for grid mode and collection mediatype', async () => {
|
|
20
|
+
var _a;
|
|
21
21
|
const el = await fixture(html `
|
|
22
22
|
<tile-dispatcher
|
|
23
23
|
.tileDisplayMode=${'grid'}
|
|
24
24
|
.model=${{ mediatype: 'collection' }}
|
|
25
25
|
>
|
|
26
26
|
</tile-dispatcher>
|
|
27
|
-
`);
|
|
28
|
-
const collectionTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('collection-tile');
|
|
29
|
-
expect(collectionTile).to.exist;
|
|
30
|
-
});
|
|
31
|
-
it('should render account-tile for grid mode and account mediatype', async () => {
|
|
32
|
-
var _a;
|
|
27
|
+
`);
|
|
28
|
+
const collectionTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('collection-tile');
|
|
29
|
+
expect(collectionTile).to.exist;
|
|
30
|
+
});
|
|
31
|
+
it('should render account-tile for grid mode and account mediatype', async () => {
|
|
32
|
+
var _a;
|
|
33
33
|
const el = await fixture(html `
|
|
34
34
|
<tile-dispatcher
|
|
35
35
|
.tileDisplayMode=${'grid'}
|
|
36
36
|
.model=${{ mediatype: 'account' }}
|
|
37
37
|
>
|
|
38
38
|
</tile-dispatcher>
|
|
39
|
-
`);
|
|
40
|
-
const accountTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('account-tile');
|
|
41
|
-
expect(accountTile).to.exist;
|
|
42
|
-
});
|
|
43
|
-
it('should render tile-list for extended list mode', async () => {
|
|
44
|
-
var _a;
|
|
39
|
+
`);
|
|
40
|
+
const accountTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('account-tile');
|
|
41
|
+
expect(accountTile).to.exist;
|
|
42
|
+
});
|
|
43
|
+
it('should render tile-list for extended list mode', async () => {
|
|
44
|
+
var _a;
|
|
45
45
|
const el = await fixture(html `
|
|
46
46
|
<tile-dispatcher .tileDisplayMode=${'list-detail'} .model=${{}}>
|
|
47
47
|
</tile-dispatcher>
|
|
48
|
-
`);
|
|
49
|
-
const listTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('tile-list');
|
|
50
|
-
expect(listTile).to.exist;
|
|
51
|
-
});
|
|
52
|
-
it('should render tile-list-compact for compact list mode', async () => {
|
|
53
|
-
var _a;
|
|
48
|
+
`);
|
|
49
|
+
const listTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('tile-list');
|
|
50
|
+
expect(listTile).to.exist;
|
|
51
|
+
});
|
|
52
|
+
it('should render tile-list-compact for compact list mode', async () => {
|
|
53
|
+
var _a;
|
|
54
54
|
const el = await fixture(html `
|
|
55
55
|
<tile-dispatcher .tileDisplayMode=${'list-compact'} .model=${{}}>
|
|
56
56
|
</tile-dispatcher>
|
|
57
|
-
`);
|
|
58
|
-
const compactListTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('tile-list-compact');
|
|
59
|
-
expect(compactListTile).to.exist;
|
|
60
|
-
});
|
|
61
|
-
it('should open item in new tab when right-clicked in manage mode', async () => {
|
|
62
|
-
var _a;
|
|
63
|
-
const oldWindowOpen = window.open;
|
|
64
|
-
const spy = sinon.spy();
|
|
65
|
-
window.open = spy;
|
|
57
|
+
`);
|
|
58
|
+
const compactListTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('tile-list-compact');
|
|
59
|
+
expect(compactListTile).to.exist;
|
|
60
|
+
});
|
|
61
|
+
it('should open item in new tab when right-clicked in manage mode', async () => {
|
|
62
|
+
var _a;
|
|
63
|
+
const oldWindowOpen = window.open;
|
|
64
|
+
const spy = sinon.spy();
|
|
65
|
+
window.open = spy;
|
|
66
66
|
const el = await fixture(html `
|
|
67
67
|
<tile-dispatcher
|
|
68
68
|
isManageView
|
|
@@ -70,51 +70,51 @@ describe('Tile Dispatcher', () => {
|
|
|
70
70
|
.baseNavigationUrl=${''}
|
|
71
71
|
>
|
|
72
72
|
</tile-dispatcher>
|
|
73
|
-
`);
|
|
74
|
-
const tileLink = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('a[href]');
|
|
75
|
-
expect(tileLink).to.exist;
|
|
76
|
-
tileLink.dispatchEvent(new Event('contextmenu'));
|
|
77
|
-
await el.updateComplete;
|
|
78
|
-
expect(spy.callCount).to.equal(1);
|
|
79
|
-
expect(spy.args[0][0]).to.equal('/foo');
|
|
80
|
-
expect(spy.args[0][1]).to.equal('_blank');
|
|
81
|
-
window.open = oldWindowOpen;
|
|
82
|
-
});
|
|
83
|
-
it('should toggle model checked state when manage check clicked', async () => {
|
|
84
|
-
var _a, _b, _c;
|
|
73
|
+
`);
|
|
74
|
+
const tileLink = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('a[href]');
|
|
75
|
+
expect(tileLink).to.exist;
|
|
76
|
+
tileLink.dispatchEvent(new Event('contextmenu'));
|
|
77
|
+
await el.updateComplete;
|
|
78
|
+
expect(spy.callCount).to.equal(1);
|
|
79
|
+
expect(spy.args[0][0]).to.equal('/foo');
|
|
80
|
+
expect(spy.args[0][1]).to.equal('_blank');
|
|
81
|
+
window.open = oldWindowOpen;
|
|
82
|
+
});
|
|
83
|
+
it('should toggle model checked state when manage check clicked', async () => {
|
|
84
|
+
var _a, _b, _c;
|
|
85
85
|
const el = await fixture(html `
|
|
86
86
|
<tile-dispatcher
|
|
87
87
|
isManageView
|
|
88
88
|
.model=${{ identifier: 'foo', href: '/foo' }}
|
|
89
89
|
.tileDisplayMode=${'grid'}
|
|
90
90
|
></tile-dispatcher>
|
|
91
|
-
`);
|
|
92
|
-
const manageCheck = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.manage-check > input[type="checkbox"]');
|
|
93
|
-
manageCheck.click();
|
|
94
|
-
await el.updateComplete;
|
|
95
|
-
expect((_b = el.model) === null || _b === void 0 ? void 0 : _b.checked).to.be.true;
|
|
96
|
-
manageCheck.click();
|
|
97
|
-
await el.updateComplete;
|
|
98
|
-
expect((_c = el.model) === null || _c === void 0 ? void 0 : _c.checked).to.be.false;
|
|
99
|
-
});
|
|
100
|
-
it('should return hover pane props', async () => {
|
|
91
|
+
`);
|
|
92
|
+
const manageCheck = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.manage-check > input[type="checkbox"]');
|
|
93
|
+
manageCheck.click();
|
|
94
|
+
await el.updateComplete;
|
|
95
|
+
expect((_b = el.model) === null || _b === void 0 ? void 0 : _b.checked).to.be.true;
|
|
96
|
+
manageCheck.click();
|
|
97
|
+
await el.updateComplete;
|
|
98
|
+
expect((_c = el.model) === null || _c === void 0 ? void 0 : _c.checked).to.be.false;
|
|
99
|
+
});
|
|
100
|
+
it('should return hover pane props', async () => {
|
|
101
101
|
const el = await fixture(html `
|
|
102
102
|
<tile-dispatcher .model=${{ identifier: 'foo' }}> </tile-dispatcher>
|
|
103
|
-
`);
|
|
104
|
-
expect(el.getHoverPaneProps()).to.satisfy((props) => { var _a; return ((_a = props === null || props === void 0 ? void 0 : props.model) === null || _a === void 0 ? void 0 : _a.identifier) === 'foo'; });
|
|
105
|
-
});
|
|
106
|
-
describe('Hover pane info button behavior', () => {
|
|
107
|
-
let oldMatchMedia;
|
|
108
|
-
before(() => {
|
|
109
|
-
oldMatchMedia = window.matchMedia;
|
|
110
|
-
// Pretend that there is no hover-capable input device
|
|
111
|
-
window.matchMedia = () => ({ matches: false });
|
|
112
|
-
});
|
|
113
|
-
after(() => {
|
|
114
|
-
window.matchMedia = oldMatchMedia;
|
|
115
|
-
});
|
|
116
|
-
it('should toggle hover pane when tile info button is pressed', async () => {
|
|
117
|
-
var _a, _b;
|
|
103
|
+
`);
|
|
104
|
+
expect(el.getHoverPaneProps()).to.satisfy((props) => { var _a; return ((_a = props === null || props === void 0 ? void 0 : props.model) === null || _a === void 0 ? void 0 : _a.identifier) === 'foo'; });
|
|
105
|
+
});
|
|
106
|
+
describe('Hover pane info button behavior', () => {
|
|
107
|
+
let oldMatchMedia;
|
|
108
|
+
before(() => {
|
|
109
|
+
oldMatchMedia = window.matchMedia;
|
|
110
|
+
// Pretend that there is no hover-capable input device
|
|
111
|
+
window.matchMedia = () => ({ matches: false });
|
|
112
|
+
});
|
|
113
|
+
after(() => {
|
|
114
|
+
window.matchMedia = oldMatchMedia;
|
|
115
|
+
});
|
|
116
|
+
it('should toggle hover pane when tile info button is pressed', async () => {
|
|
117
|
+
var _a, _b;
|
|
118
118
|
const el = await fixture(html `
|
|
119
119
|
<tile-dispatcher
|
|
120
120
|
.tileDisplayMode=${'grid'}
|
|
@@ -122,20 +122,20 @@ describe('Tile Dispatcher', () => {
|
|
|
122
122
|
.enableHoverPane=${true}
|
|
123
123
|
>
|
|
124
124
|
</tile-dispatcher>
|
|
125
|
-
`);
|
|
126
|
-
const itemTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('item-tile');
|
|
127
|
-
expect(itemTile).to.exist;
|
|
128
|
-
const infoButton = (_b = itemTile.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.info-button');
|
|
129
|
-
expect(infoButton).to.exist;
|
|
130
|
-
infoButton.click();
|
|
131
|
-
await aTimeout(500);
|
|
132
|
-
await el.updateComplete;
|
|
133
|
-
expect(el.getHoverPane()).to.be.instanceOf(TileHoverPane);
|
|
134
|
-
infoButton.click();
|
|
135
|
-
await aTimeout(500);
|
|
136
|
-
await el.updateComplete;
|
|
137
|
-
expect(el.getHoverPane()).not.to.exist;
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
});
|
|
125
|
+
`);
|
|
126
|
+
const itemTile = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('item-tile');
|
|
127
|
+
expect(itemTile).to.exist;
|
|
128
|
+
const infoButton = (_b = itemTile.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.info-button');
|
|
129
|
+
expect(infoButton).to.exist;
|
|
130
|
+
infoButton.click();
|
|
131
|
+
await aTimeout(500);
|
|
132
|
+
await el.updateComplete;
|
|
133
|
+
expect(el.getHoverPane()).to.be.instanceOf(TileHoverPane);
|
|
134
|
+
infoButton.click();
|
|
135
|
+
await aTimeout(500);
|
|
136
|
+
await el.updateComplete;
|
|
137
|
+
expect(el.getHoverPane()).not.to.exist;
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
141
|
//# sourceMappingURL=tile-dispatcher.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
@@ -1,142 +1,142 @@
|
|
|
1
|
-
import { expect } from '@open-wc/testing';
|
|
2
|
-
import { nothing } from 'lit';
|
|
3
|
-
import { TileDisplayValueProvider } from '../../src/tiles/tile-display-value-provider';
|
|
4
|
-
describe('Tile Display Value Provider', () => {
|
|
5
|
-
describe('basic construction', () => {
|
|
6
|
-
it('constructs w/ no options', () => {
|
|
7
|
-
const provider = new TileDisplayValueProvider();
|
|
8
|
-
expect(provider).to.exist;
|
|
9
|
-
});
|
|
10
|
-
it('constructs w/ options', () => {
|
|
11
|
-
const provider = new TileDisplayValueProvider({
|
|
12
|
-
model: {},
|
|
13
|
-
baseNavigationUrl: 'foo',
|
|
14
|
-
collectionPagePath: 'bar',
|
|
15
|
-
sortParam: { field: 'baz', direction: 'asc' },
|
|
16
|
-
creatorFilter: 'X',
|
|
17
|
-
});
|
|
18
|
-
expect(provider).to.exist;
|
|
19
|
-
});
|
|
20
|
-
});
|
|
21
|
-
describe('firstCreatorMatchingFilter', () => {
|
|
22
|
-
it('provides undefined creator when no model set', () => {
|
|
23
|
-
const provider = new TileDisplayValueProvider();
|
|
24
|
-
expect(provider.firstCreatorMatchingFilter).to.be.undefined;
|
|
25
|
-
});
|
|
26
|
-
it('provides creator from model with no filter', () => {
|
|
27
|
-
const provider = new TileDisplayValueProvider({
|
|
28
|
-
model: { creator: 'foo', creators: ['foo', 'bar', 'baz'] },
|
|
29
|
-
});
|
|
30
|
-
expect(provider.firstCreatorMatchingFilter).to.equal('foo');
|
|
31
|
-
});
|
|
32
|
-
it('provides first creator matching filter when present', () => {
|
|
33
|
-
const provider = new TileDisplayValueProvider({
|
|
34
|
-
model: { creator: 'foo', creators: ['foo', 'bar', 'baz'] },
|
|
35
|
-
creatorFilter: 'B',
|
|
36
|
-
});
|
|
37
|
-
expect(provider.firstCreatorMatchingFilter).to.equal('bar');
|
|
38
|
-
});
|
|
39
|
-
it('matches letters with diacritics', () => {
|
|
40
|
-
const provider = new TileDisplayValueProvider({
|
|
41
|
-
model: {
|
|
42
|
-
creator: 'foo',
|
|
43
|
-
creators: ['foo', 'émile', 'ernest'],
|
|
44
|
-
},
|
|
45
|
-
creatorFilter: 'E',
|
|
46
|
-
});
|
|
47
|
-
expect(provider.firstCreatorMatchingFilter).to.equal('émile');
|
|
48
|
-
});
|
|
49
|
-
it('ignores non-alphabetical characters when matching', () => {
|
|
50
|
-
const provider = new TileDisplayValueProvider({
|
|
51
|
-
model: {
|
|
52
|
-
creator: 'foo',
|
|
53
|
-
creators: ['foo', '"(bar)"', 'baz'],
|
|
54
|
-
},
|
|
55
|
-
creatorFilter: 'B',
|
|
56
|
-
});
|
|
57
|
-
expect(provider.firstCreatorMatchingFilter).to.equal('"(bar)"');
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
describe('accountLabel', () => {
|
|
61
|
-
it('provides empty account label when no model', () => {
|
|
62
|
-
const provider = new TileDisplayValueProvider();
|
|
63
|
-
expect(provider.accountLabel).to.equal('');
|
|
64
|
-
});
|
|
65
|
-
it('provides empty account label when no date added', () => {
|
|
66
|
-
const provider = new TileDisplayValueProvider({ model: {} });
|
|
67
|
-
expect(provider.accountLabel).to.equal('');
|
|
68
|
-
});
|
|
69
|
-
it('provides Archivist label from date added', () => {
|
|
70
|
-
const provider = new TileDisplayValueProvider({
|
|
71
|
-
model: { dateAdded: new Date(2010, 1, 2) },
|
|
72
|
-
});
|
|
73
|
-
expect(provider.accountLabel).to.equal('Archivist since 2010');
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
describe('dateLabel', () => {
|
|
77
|
-
it('provides empty date label when no sort param', () => {
|
|
78
|
-
const provider = new TileDisplayValueProvider();
|
|
79
|
-
expect(provider.dateLabel).to.equal('');
|
|
80
|
-
});
|
|
81
|
-
it('provides empty date label when sorting by non-date', () => {
|
|
82
|
-
const provider = new TileDisplayValueProvider({
|
|
83
|
-
sortParam: { field: 'downloads', direction: 'desc' },
|
|
84
|
-
});
|
|
85
|
-
expect(provider.dateLabel).to.equal('');
|
|
86
|
-
});
|
|
87
|
-
it('provides correct date label for publicdate', () => {
|
|
88
|
-
const provider = new TileDisplayValueProvider({
|
|
89
|
-
sortParam: { field: 'publicdate', direction: 'asc' },
|
|
90
|
-
});
|
|
91
|
-
expect(provider.dateLabel).to.equal('Archived');
|
|
92
|
-
});
|
|
93
|
-
it('provides correct date label for reviewdate', () => {
|
|
94
|
-
const provider = new TileDisplayValueProvider({
|
|
95
|
-
sortParam: { field: 'reviewdate', direction: 'asc' },
|
|
96
|
-
});
|
|
97
|
-
expect(provider.dateLabel).to.equal('Reviewed');
|
|
98
|
-
});
|
|
99
|
-
it('provides correct date label for addeddate', () => {
|
|
100
|
-
const provider = new TileDisplayValueProvider({
|
|
101
|
-
sortParam: { field: 'addeddate', direction: 'asc' },
|
|
102
|
-
});
|
|
103
|
-
expect(provider.dateLabel).to.equal('Added');
|
|
104
|
-
});
|
|
105
|
-
it('provides correct date label for published date', () => {
|
|
106
|
-
const provider = new TileDisplayValueProvider({
|
|
107
|
-
sortParam: { field: 'date', direction: 'asc' },
|
|
108
|
-
});
|
|
109
|
-
expect(provider.dateLabel).to.equal('Published');
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
describe('itemPageUrl', () => {
|
|
113
|
-
it('provides nothing when no base url set', () => {
|
|
114
|
-
const provider = new TileDisplayValueProvider();
|
|
115
|
-
expect(provider.itemPageUrl('foo')).to.equal(nothing);
|
|
116
|
-
});
|
|
117
|
-
it('provides nothing when identifier is empty', () => {
|
|
118
|
-
const provider = new TileDisplayValueProvider({
|
|
119
|
-
baseNavigationUrl: 'foo',
|
|
120
|
-
});
|
|
121
|
-
expect(provider.itemPageUrl('')).to.equal(nothing);
|
|
122
|
-
});
|
|
123
|
-
it('builds correct url from base and identifier', () => {
|
|
124
|
-
const provider = new TileDisplayValueProvider({
|
|
125
|
-
baseNavigationUrl: 'base',
|
|
126
|
-
});
|
|
127
|
-
expect(provider.itemPageUrl('foo')).to.equal('base/details/foo');
|
|
128
|
-
});
|
|
129
|
-
it('allows base url to be empty', () => {
|
|
130
|
-
const provider = new TileDisplayValueProvider({ baseNavigationUrl: '' });
|
|
131
|
-
expect(provider.itemPageUrl('foo')).to.equal('/details/foo');
|
|
132
|
-
});
|
|
133
|
-
it('uses provided collection base path for collections', () => {
|
|
134
|
-
const provider = new TileDisplayValueProvider({
|
|
135
|
-
baseNavigationUrl: 'base',
|
|
136
|
-
collectionPagePath: '/collection/',
|
|
137
|
-
});
|
|
138
|
-
expect(provider.itemPageUrl('foo', true)).to.equal('base/collection/foo');
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
});
|
|
1
|
+
import { expect } from '@open-wc/testing';
|
|
2
|
+
import { nothing } from 'lit';
|
|
3
|
+
import { TileDisplayValueProvider } from '../../src/tiles/tile-display-value-provider';
|
|
4
|
+
describe('Tile Display Value Provider', () => {
|
|
5
|
+
describe('basic construction', () => {
|
|
6
|
+
it('constructs w/ no options', () => {
|
|
7
|
+
const provider = new TileDisplayValueProvider();
|
|
8
|
+
expect(provider).to.exist;
|
|
9
|
+
});
|
|
10
|
+
it('constructs w/ options', () => {
|
|
11
|
+
const provider = new TileDisplayValueProvider({
|
|
12
|
+
model: {},
|
|
13
|
+
baseNavigationUrl: 'foo',
|
|
14
|
+
collectionPagePath: 'bar',
|
|
15
|
+
sortParam: { field: 'baz', direction: 'asc' },
|
|
16
|
+
creatorFilter: 'X',
|
|
17
|
+
});
|
|
18
|
+
expect(provider).to.exist;
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
describe('firstCreatorMatchingFilter', () => {
|
|
22
|
+
it('provides undefined creator when no model set', () => {
|
|
23
|
+
const provider = new TileDisplayValueProvider();
|
|
24
|
+
expect(provider.firstCreatorMatchingFilter).to.be.undefined;
|
|
25
|
+
});
|
|
26
|
+
it('provides creator from model with no filter', () => {
|
|
27
|
+
const provider = new TileDisplayValueProvider({
|
|
28
|
+
model: { creator: 'foo', creators: ['foo', 'bar', 'baz'] },
|
|
29
|
+
});
|
|
30
|
+
expect(provider.firstCreatorMatchingFilter).to.equal('foo');
|
|
31
|
+
});
|
|
32
|
+
it('provides first creator matching filter when present', () => {
|
|
33
|
+
const provider = new TileDisplayValueProvider({
|
|
34
|
+
model: { creator: 'foo', creators: ['foo', 'bar', 'baz'] },
|
|
35
|
+
creatorFilter: 'B',
|
|
36
|
+
});
|
|
37
|
+
expect(provider.firstCreatorMatchingFilter).to.equal('bar');
|
|
38
|
+
});
|
|
39
|
+
it('matches letters with diacritics', () => {
|
|
40
|
+
const provider = new TileDisplayValueProvider({
|
|
41
|
+
model: {
|
|
42
|
+
creator: 'foo',
|
|
43
|
+
creators: ['foo', 'émile', 'ernest'],
|
|
44
|
+
},
|
|
45
|
+
creatorFilter: 'E',
|
|
46
|
+
});
|
|
47
|
+
expect(provider.firstCreatorMatchingFilter).to.equal('émile');
|
|
48
|
+
});
|
|
49
|
+
it('ignores non-alphabetical characters when matching', () => {
|
|
50
|
+
const provider = new TileDisplayValueProvider({
|
|
51
|
+
model: {
|
|
52
|
+
creator: 'foo',
|
|
53
|
+
creators: ['foo', '"(bar)"', 'baz'],
|
|
54
|
+
},
|
|
55
|
+
creatorFilter: 'B',
|
|
56
|
+
});
|
|
57
|
+
expect(provider.firstCreatorMatchingFilter).to.equal('"(bar)"');
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('accountLabel', () => {
|
|
61
|
+
it('provides empty account label when no model', () => {
|
|
62
|
+
const provider = new TileDisplayValueProvider();
|
|
63
|
+
expect(provider.accountLabel).to.equal('');
|
|
64
|
+
});
|
|
65
|
+
it('provides empty account label when no date added', () => {
|
|
66
|
+
const provider = new TileDisplayValueProvider({ model: {} });
|
|
67
|
+
expect(provider.accountLabel).to.equal('');
|
|
68
|
+
});
|
|
69
|
+
it('provides Archivist label from date added', () => {
|
|
70
|
+
const provider = new TileDisplayValueProvider({
|
|
71
|
+
model: { dateAdded: new Date(2010, 1, 2) },
|
|
72
|
+
});
|
|
73
|
+
expect(provider.accountLabel).to.equal('Archivist since 2010');
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
describe('dateLabel', () => {
|
|
77
|
+
it('provides empty date label when no sort param', () => {
|
|
78
|
+
const provider = new TileDisplayValueProvider();
|
|
79
|
+
expect(provider.dateLabel).to.equal('');
|
|
80
|
+
});
|
|
81
|
+
it('provides empty date label when sorting by non-date', () => {
|
|
82
|
+
const provider = new TileDisplayValueProvider({
|
|
83
|
+
sortParam: { field: 'downloads', direction: 'desc' },
|
|
84
|
+
});
|
|
85
|
+
expect(provider.dateLabel).to.equal('');
|
|
86
|
+
});
|
|
87
|
+
it('provides correct date label for publicdate', () => {
|
|
88
|
+
const provider = new TileDisplayValueProvider({
|
|
89
|
+
sortParam: { field: 'publicdate', direction: 'asc' },
|
|
90
|
+
});
|
|
91
|
+
expect(provider.dateLabel).to.equal('Archived');
|
|
92
|
+
});
|
|
93
|
+
it('provides correct date label for reviewdate', () => {
|
|
94
|
+
const provider = new TileDisplayValueProvider({
|
|
95
|
+
sortParam: { field: 'reviewdate', direction: 'asc' },
|
|
96
|
+
});
|
|
97
|
+
expect(provider.dateLabel).to.equal('Reviewed');
|
|
98
|
+
});
|
|
99
|
+
it('provides correct date label for addeddate', () => {
|
|
100
|
+
const provider = new TileDisplayValueProvider({
|
|
101
|
+
sortParam: { field: 'addeddate', direction: 'asc' },
|
|
102
|
+
});
|
|
103
|
+
expect(provider.dateLabel).to.equal('Added');
|
|
104
|
+
});
|
|
105
|
+
it('provides correct date label for published date', () => {
|
|
106
|
+
const provider = new TileDisplayValueProvider({
|
|
107
|
+
sortParam: { field: 'date', direction: 'asc' },
|
|
108
|
+
});
|
|
109
|
+
expect(provider.dateLabel).to.equal('Published');
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
describe('itemPageUrl', () => {
|
|
113
|
+
it('provides nothing when no base url set', () => {
|
|
114
|
+
const provider = new TileDisplayValueProvider();
|
|
115
|
+
expect(provider.itemPageUrl('foo')).to.equal(nothing);
|
|
116
|
+
});
|
|
117
|
+
it('provides nothing when identifier is empty', () => {
|
|
118
|
+
const provider = new TileDisplayValueProvider({
|
|
119
|
+
baseNavigationUrl: 'foo',
|
|
120
|
+
});
|
|
121
|
+
expect(provider.itemPageUrl('')).to.equal(nothing);
|
|
122
|
+
});
|
|
123
|
+
it('builds correct url from base and identifier', () => {
|
|
124
|
+
const provider = new TileDisplayValueProvider({
|
|
125
|
+
baseNavigationUrl: 'base',
|
|
126
|
+
});
|
|
127
|
+
expect(provider.itemPageUrl('foo')).to.equal('base/details/foo');
|
|
128
|
+
});
|
|
129
|
+
it('allows base url to be empty', () => {
|
|
130
|
+
const provider = new TileDisplayValueProvider({ baseNavigationUrl: '' });
|
|
131
|
+
expect(provider.itemPageUrl('foo')).to.equal('/details/foo');
|
|
132
|
+
});
|
|
133
|
+
it('uses provided collection base path for collections', () => {
|
|
134
|
+
const provider = new TileDisplayValueProvider({
|
|
135
|
+
baseNavigationUrl: 'base',
|
|
136
|
+
collectionPagePath: '/collection/',
|
|
137
|
+
});
|
|
138
|
+
expect(provider.itemPageUrl('foo', true)).to.equal('base/collection/foo');
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
142
|
//# sourceMappingURL=tile-display-value-provider.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
import { expect } from '@open-wc/testing';
|
|
2
|
-
import { arrayEquals } from '../../src/utils/array-equals';
|
|
3
|
-
describe('arrayEquals', () => {
|
|
4
|
-
it('returns true for empty args', () => {
|
|
5
|
-
expect(arrayEquals([], [])).to.be.true;
|
|
6
|
-
});
|
|
7
|
-
it('returns true for identical array objects', () => {
|
|
8
|
-
const arr = ['foo', 'bar'];
|
|
9
|
-
expect(arrayEquals(arr, arr)).to.be.true;
|
|
10
|
-
});
|
|
11
|
-
it('returns true for arrays with identical contents', () => {
|
|
12
|
-
const arr1 = ['foo', 'bar'];
|
|
13
|
-
const arr2 = ['foo', 'bar'];
|
|
14
|
-
expect(arrayEquals(arr1, arr2)).to.be.true;
|
|
15
|
-
});
|
|
16
|
-
it('returns false for arrays of unequal length', () => {
|
|
17
|
-
const arr1 = [1, 2, 3];
|
|
18
|
-
const arr2 = [1, 2, 3, 4];
|
|
19
|
-
expect(arrayEquals(arr1, arr2)).to.be.false;
|
|
20
|
-
});
|
|
21
|
-
it('returns false for unequal arrays of same length', () => {
|
|
22
|
-
const arr1 = ['foo', 'bar'];
|
|
23
|
-
const arr2 = ['foo', 'qux'];
|
|
24
|
-
expect(arrayEquals(arr1, arr2)).to.be.false;
|
|
25
|
-
});
|
|
26
|
-
});
|
|
1
|
+
import { expect } from '@open-wc/testing';
|
|
2
|
+
import { arrayEquals } from '../../src/utils/array-equals';
|
|
3
|
+
describe('arrayEquals', () => {
|
|
4
|
+
it('returns true for empty args', () => {
|
|
5
|
+
expect(arrayEquals([], [])).to.be.true;
|
|
6
|
+
});
|
|
7
|
+
it('returns true for identical array objects', () => {
|
|
8
|
+
const arr = ['foo', 'bar'];
|
|
9
|
+
expect(arrayEquals(arr, arr)).to.be.true;
|
|
10
|
+
});
|
|
11
|
+
it('returns true for arrays with identical contents', () => {
|
|
12
|
+
const arr1 = ['foo', 'bar'];
|
|
13
|
+
const arr2 = ['foo', 'bar'];
|
|
14
|
+
expect(arrayEquals(arr1, arr2)).to.be.true;
|
|
15
|
+
});
|
|
16
|
+
it('returns false for arrays of unequal length', () => {
|
|
17
|
+
const arr1 = [1, 2, 3];
|
|
18
|
+
const arr2 = [1, 2, 3, 4];
|
|
19
|
+
expect(arrayEquals(arr1, arr2)).to.be.false;
|
|
20
|
+
});
|
|
21
|
+
it('returns false for unequal arrays of same length', () => {
|
|
22
|
+
const arr1 = ['foo', 'bar'];
|
|
23
|
+
const arr2 = ['foo', 'qux'];
|
|
24
|
+
expect(arrayEquals(arr1, arr2)).to.be.false;
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
27
|
//# sourceMappingURL=array-equals.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { expect } from '@open-wc/testing';
|
|
2
|
-
import { formatCount } from '../../src/utils/format-count';
|
|
3
|
-
const testCount = 805342;
|
|
4
|
-
describe('formatCount', () => {
|
|
5
|
-
it('returns blank when undefined number', () => {
|
|
6
|
-
expect(formatCount(undefined)).to.equal('');
|
|
7
|
-
});
|
|
8
|
-
it('returns blank when negative number', () => {
|
|
9
|
-
expect(formatCount(testCount * -1)).to.equal('');
|
|
10
|
-
});
|
|
11
|
-
it('returns long number when no NumberFormat', () => {
|
|
12
|
-
expect(formatCount(testCount)).to.equal('805,342');
|
|
13
|
-
});
|
|
14
|
-
it('returns short number when short NumberFormat', () => {
|
|
15
|
-
expect(formatCount(testCount, 'short')).to.equal('805K');
|
|
16
|
-
});
|
|
17
|
-
it('returns decimal when value of significant digits < 10', () => {
|
|
18
|
-
expect(formatCount(testCount * 10, 'short', 'long')).to.equal('8.1 million');
|
|
19
|
-
});
|
|
20
|
-
it('returns locale formatted number', () => {
|
|
21
|
-
expect(formatCount(testCount, 'long', 'long', 'de-DE')).to.equal('805.342');
|
|
22
|
-
});
|
|
23
|
-
});
|
|
1
|
+
import { expect } from '@open-wc/testing';
|
|
2
|
+
import { formatCount } from '../../src/utils/format-count';
|
|
3
|
+
const testCount = 805342;
|
|
4
|
+
describe('formatCount', () => {
|
|
5
|
+
it('returns blank when undefined number', () => {
|
|
6
|
+
expect(formatCount(undefined)).to.equal('');
|
|
7
|
+
});
|
|
8
|
+
it('returns blank when negative number', () => {
|
|
9
|
+
expect(formatCount(testCount * -1)).to.equal('');
|
|
10
|
+
});
|
|
11
|
+
it('returns long number when no NumberFormat', () => {
|
|
12
|
+
expect(formatCount(testCount)).to.equal('805,342');
|
|
13
|
+
});
|
|
14
|
+
it('returns short number when short NumberFormat', () => {
|
|
15
|
+
expect(formatCount(testCount, 'short')).to.equal('805K');
|
|
16
|
+
});
|
|
17
|
+
it('returns decimal when value of significant digits < 10', () => {
|
|
18
|
+
expect(formatCount(testCount * 10, 'short', 'long')).to.equal('8.1 million');
|
|
19
|
+
});
|
|
20
|
+
it('returns locale formatted number', () => {
|
|
21
|
+
expect(formatCount(testCount, 'long', 'long', 'de-DE')).to.equal('805.342');
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
24
|
//# sourceMappingURL=format-count.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|