@internetarchive/collection-browser 0.4.10 → 0.4.11

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.
Files changed (229) hide show
  1. package/.editorconfig +29 -29
  2. package/.github/workflows/ci.yml +26 -26
  3. package/.github/workflows/gh-pages-main.yml +39 -39
  4. package/.github/workflows/npm-publish.yml +39 -39
  5. package/.github/workflows/pr-preview.yml +38 -38
  6. package/.husky/pre-commit +4 -4
  7. package/LICENSE +661 -661
  8. package/README.md +83 -83
  9. package/dist/index.d.ts +9 -9
  10. package/dist/index.js +9 -9
  11. package/dist/src/app-root.d.ts +50 -50
  12. package/dist/src/app-root.js +278 -278
  13. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  14. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  15. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  16. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  17. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  18. package/dist/src/assets/img/icons/chevron.js +2 -2
  19. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  20. package/dist/src/assets/img/icons/empty-query.js +2 -2
  21. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  22. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  23. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  24. package/dist/src/assets/img/icons/eye.js +2 -2
  25. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  26. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  27. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  28. package/dist/src/assets/img/icons/login-required.js +2 -2
  29. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  30. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  31. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  32. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  33. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  34. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  35. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  36. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  37. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  38. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  39. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  40. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  41. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  42. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  43. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  44. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  45. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  46. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  47. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  48. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  49. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  50. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  51. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  52. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  53. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  54. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  55. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  56. package/dist/src/assets/img/icons/null-result.js +2 -2
  57. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  58. package/dist/src/assets/img/icons/restricted.js +2 -2
  59. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  60. package/dist/src/assets/img/icons/reviews.js +2 -2
  61. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  62. package/dist/src/assets/img/icons/upload.js +2 -2
  63. package/dist/src/assets/img/icons/views.d.ts +1 -1
  64. package/dist/src/assets/img/icons/views.js +2 -2
  65. package/dist/src/circular-activity-indicator.d.ts +5 -5
  66. package/dist/src/circular-activity-indicator.js +17 -17
  67. package/dist/src/collection-browser.d.ts +279 -279
  68. package/dist/src/collection-browser.js +1156 -1156
  69. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  70. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  71. package/dist/src/collection-facets/facets-template.d.ts +16 -16
  72. package/dist/src/collection-facets/facets-template.js +125 -125
  73. package/dist/src/collection-facets/more-facets-content.d.ts +75 -75
  74. package/dist/src/collection-facets/more-facets-content.js +340 -340
  75. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  76. package/dist/src/collection-facets/more-facets-pagination.js +192 -192
  77. package/dist/src/collection-facets.d.ts +81 -81
  78. package/dist/src/collection-facets.js +375 -375
  79. package/dist/src/empty-placeholder.d.ts +11 -11
  80. package/dist/src/empty-placeholder.js +42 -42
  81. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  82. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  83. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  84. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  85. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  86. package/dist/src/mediatype/mediatype-config.js +85 -85
  87. package/dist/src/models.d.ts +115 -115
  88. package/dist/src/models.js +125 -125
  89. package/dist/src/restoration-state-handler.d.ts +45 -45
  90. package/dist/src/restoration-state-handler.js +230 -230
  91. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  92. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  93. package/dist/src/sort-filter-bar/alpha-bar.d.ts +20 -20
  94. package/dist/src/sort-filter-bar/alpha-bar.js +136 -128
  95. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
  96. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  97. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  98. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  99. package/dist/src/sort-filter-bar/img/list.js +2 -2
  100. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  101. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  102. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  103. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  104. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +108 -108
  105. package/dist/src/sort-filter-bar/sort-filter-bar.js +438 -438
  106. package/dist/src/styles/item-image-styles.d.ts +8 -8
  107. package/dist/src/styles/item-image-styles.js +9 -9
  108. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  109. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  110. package/dist/src/tiles/grid/account-tile.d.ts +20 -20
  111. package/dist/src/tiles/grid/account-tile.js +64 -64
  112. package/dist/src/tiles/grid/collection-tile.d.ts +17 -17
  113. package/dist/src/tiles/grid/collection-tile.js +71 -71
  114. package/dist/src/tiles/grid/item-tile.d.ts +32 -32
  115. package/dist/src/tiles/grid/item-tile.js +122 -122
  116. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  117. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +7 -7
  118. package/dist/src/tiles/grid/tile-stats.d.ts +10 -10
  119. package/dist/src/tiles/grid/tile-stats.js +40 -40
  120. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  121. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  122. package/dist/src/tiles/hover/tile-hover-pane.d.ts +15 -15
  123. package/dist/src/tiles/hover/tile-hover-pane.js +38 -38
  124. package/dist/src/tiles/image-block.d.ts +17 -17
  125. package/dist/src/tiles/image-block.js +72 -72
  126. package/dist/src/tiles/item-image.d.ts +35 -35
  127. package/dist/src/tiles/item-image.js +117 -117
  128. package/dist/src/tiles/list/account-label.d.ts +1 -1
  129. package/dist/src/tiles/list/account-label.js +6 -6
  130. package/dist/src/tiles/list/date-label.d.ts +1 -1
  131. package/dist/src/tiles/list/date-label.js +12 -12
  132. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
  133. package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
  134. package/dist/src/tiles/list/tile-list-compact.d.ts +21 -21
  135. package/dist/src/tiles/list/tile-list-compact.js +99 -99
  136. package/dist/src/tiles/list/tile-list.d.ts +55 -55
  137. package/dist/src/tiles/list/tile-list.js +301 -301
  138. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  139. package/dist/src/tiles/mediatype-icon.js +47 -47
  140. package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
  141. package/dist/src/tiles/overlay/icon-overlay.js +40 -40
  142. package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
  143. package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
  144. package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
  145. package/dist/src/tiles/overlay/text-overlay.js +42 -42
  146. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  147. package/dist/src/tiles/text-snippet-block.js +73 -73
  148. package/dist/src/tiles/tile-dispatcher.d.ts +58 -58
  149. package/dist/src/tiles/tile-dispatcher.js +194 -194
  150. package/dist/src/utils/analytics-events.d.ts +22 -22
  151. package/dist/src/utils/analytics-events.js +24 -24
  152. package/dist/src/utils/format-count.d.ts +7 -7
  153. package/dist/src/utils/format-count.js +76 -76
  154. package/dist/src/utils/format-date.d.ts +2 -2
  155. package/dist/src/utils/format-date.js +23 -23
  156. package/dist/src/utils/format-unit-size.d.ts +2 -2
  157. package/dist/src/utils/format-unit-size.js +33 -33
  158. package/dist/test/collection-browser.test.d.ts +1 -1
  159. package/dist/test/collection-browser.test.js +584 -584
  160. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  161. package/dist/test/collection-facets/facets-template.test.js +62 -62
  162. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  163. package/dist/test/collection-facets/more-facets-content.test.js +114 -114
  164. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  165. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  166. package/dist/test/collection-facets.test.d.ts +2 -2
  167. package/dist/test/collection-facets.test.js +460 -460
  168. package/dist/test/empty-placeholder.test.d.ts +1 -1
  169. package/dist/test/empty-placeholder.test.js +33 -33
  170. package/dist/test/icon-overlay.test.d.ts +1 -1
  171. package/dist/test/icon-overlay.test.js +24 -24
  172. package/dist/test/image-block.test.d.ts +1 -1
  173. package/dist/test/image-block.test.js +48 -48
  174. package/dist/test/item-image.test.d.ts +1 -1
  175. package/dist/test/item-image.test.js +84 -84
  176. package/dist/test/mediatype-config.test.d.ts +1 -1
  177. package/dist/test/mediatype-config.test.js +16 -16
  178. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  179. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  180. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -7
  181. package/dist/test/mocks/mock-collection-name-cache.js +13 -13
  182. package/dist/test/mocks/mock-search-responses.d.ts +12 -12
  183. package/dist/test/mocks/mock-search-responses.js +341 -341
  184. package/dist/test/mocks/mock-search-service.d.ts +13 -13
  185. package/dist/test/mocks/mock-search-service.js +40 -40
  186. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  187. package/dist/test/restoration-state-handler.test.js +125 -125
  188. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  189. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  190. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  191. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  192. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  193. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +197 -197
  194. package/dist/test/text-overlay.test.d.ts +1 -1
  195. package/dist/test/text-overlay.test.js +48 -48
  196. package/dist/test/text-snippet-block.test.d.ts +1 -1
  197. package/dist/test/text-snippet-block.test.js +57 -57
  198. package/dist/test/tile-stats.test.d.ts +1 -1
  199. package/dist/test/tile-stats.test.js +33 -33
  200. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  201. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  202. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  203. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  204. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  205. package/dist/test/tiles/grid/item-tile.test.js +158 -158
  206. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  207. package/dist/test/tiles/hover/hover-pane-controller.test.js +257 -257
  208. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  209. package/dist/test/tiles/hover/tile-hover-pane.test.js +13 -13
  210. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  211. package/dist/test/tiles/list/tile-list-compact.test.js +92 -92
  212. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  213. package/dist/test/tiles/list/tile-list.test.js +163 -163
  214. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  215. package/dist/test/tiles/tile-dispatcher.test.js +67 -67
  216. package/dist/test/utils/format-count.test.d.ts +1 -1
  217. package/dist/test/utils/format-count.test.js +23 -23
  218. package/dist/test/utils/format-date.test.d.ts +1 -1
  219. package/dist/test/utils/format-date.test.js +17 -17
  220. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  221. package/dist/test/utils/format-unit-size.test.js +17 -17
  222. package/local.archive.org.cert +86 -86
  223. package/local.archive.org.key +27 -27
  224. package/package.json +1 -1
  225. package/renovate.json +6 -6
  226. package/src/sort-filter-bar/alpha-bar.ts +8 -0
  227. package/tsconfig.json +21 -21
  228. package/web-dev-server.config.mjs +30 -30
  229. package/web-test-runner.config.mjs +41 -41
@@ -1 +1 @@
1
- import '../src/empty-placeholder';
1
+ import '../src/empty-placeholder';
@@ -1,34 +1,34 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import '../src/empty-placeholder';
5
- describe('Empty Placeholder', () => {
6
- it('should render with empty-query placeholder', async () => {
7
- var _a, _b, _c;
8
- const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
9
- el.placeholderType = 'empty-query';
10
- await el.updateComplete;
11
- expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.empty-query')).to.exist;
12
- expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.null-result')).to.not.exist;
13
- expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('infinite-scroller')).to.not.exist;
14
- });
15
- it('should render with null-result placeholder', async () => {
16
- var _a, _b, _c;
17
- const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
18
- el.placeholderType = 'null-result';
19
- await el.updateComplete;
20
- expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.null-result')).to.exist;
21
- expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.empty-query')).to.not.exist;
22
- expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('collection-facets')).to.not.exist;
23
- });
24
- it('should not render any empty placeholder', async () => {
25
- var _a, _b, _c;
26
- const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
27
- el.placeholderType = null;
28
- await el.updateComplete;
29
- expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.empty-query')).to.not.exist;
30
- expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.null-result')).to.not.exist;
31
- expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('collection-facets')).to.not.exist;
32
- });
33
- });
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import '../src/empty-placeholder';
5
+ describe('Empty Placeholder', () => {
6
+ it('should render with empty-query placeholder', async () => {
7
+ var _a, _b, _c;
8
+ const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
9
+ el.placeholderType = 'empty-query';
10
+ await el.updateComplete;
11
+ expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.empty-query')).to.exist;
12
+ expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.null-result')).to.not.exist;
13
+ expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('infinite-scroller')).to.not.exist;
14
+ });
15
+ it('should render with null-result placeholder', async () => {
16
+ var _a, _b, _c;
17
+ const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
18
+ el.placeholderType = 'null-result';
19
+ await el.updateComplete;
20
+ expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.null-result')).to.exist;
21
+ expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.empty-query')).to.not.exist;
22
+ expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('collection-facets')).to.not.exist;
23
+ });
24
+ it('should not render any empty placeholder', async () => {
25
+ var _a, _b, _c;
26
+ const el = await fixture(html `<empty-placeholder></empty-placeholder>`);
27
+ el.placeholderType = null;
28
+ await el.updateComplete;
29
+ expect((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.empty-query')).to.not.exist;
30
+ expect((_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.null-result')).to.not.exist;
31
+ expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('collection-facets')).to.not.exist;
32
+ });
33
+ });
34
34
  //# sourceMappingURL=empty-placeholder.test.js.map
@@ -1 +1 @@
1
- import '../src/tiles/overlay/icon-overlay';
1
+ import '../src/tiles/overlay/icon-overlay';
@@ -1,31 +1,31 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import '../src/tiles/overlay/icon-overlay';
5
- describe('Icon Overlay component', () => {
6
- it('should render component if loggedIn required', async () => {
7
- var _a, _b, _c;
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import '../src/tiles/overlay/icon-overlay';
5
+ describe('Icon Overlay component', () => {
6
+ it('should render component if loggedIn required', async () => {
7
+ var _a, _b, _c;
8
8
  const el = await fixture(html `
9
9
  <icon-overlay .loggedIn=${false} .loginRequired=${true}> </icon-overlay>
10
- `);
11
- const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
12
- expect(svgTitle).to.equal('Log in to view this item');
13
- });
14
- it('should render component if content warning', async () => {
15
- var _a, _b, _c;
10
+ `);
11
+ const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
12
+ expect(svgTitle).to.equal('Log in to view this item');
13
+ });
14
+ it('should render component if content warning', async () => {
15
+ var _a, _b, _c;
16
16
  const el = await fixture(html `
17
17
  <icon-overlay .loggedIn=${false} .loginRequired=${false}> </icon-overlay>
18
- `);
19
- const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
20
- expect(svgTitle).to.equal('Content may be inappropriate');
21
- });
22
- it('should render component if content warning', async () => {
23
- var _a, _b, _c;
18
+ `);
19
+ const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
20
+ expect(svgTitle).to.equal('Content may be inappropriate');
21
+ });
22
+ it('should render component if content warning', async () => {
23
+ var _a, _b, _c;
24
24
  const el = await fixture(html `
25
25
  <icon-overlay .loggedIn=${true} .loginRequired=${true}> </icon-overlay>
26
- `);
27
- const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
28
- expect(svgTitle).to.equal('Content may be inappropriate');
29
- });
30
- });
26
+ `);
27
+ const svgTitle = (_c = (_b = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('svg')) === null || _b === void 0 ? void 0 : _b.querySelector('title')) === null || _c === void 0 ? void 0 : _c.textContent;
28
+ expect(svgTitle).to.equal('Content may be inappropriate');
29
+ });
30
+ });
31
31
  //# sourceMappingURL=icon-overlay.test.js.map
@@ -1 +1 @@
1
- import '../src/tiles/image-block';
1
+ import '../src/tiles/image-block';
@@ -1,16 +1,16 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import '../src/tiles/image-block';
5
- describe('Image block component', () => {
6
- it('should render component grid display mode', async () => {
7
- var _a, _b, _c;
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import '../src/tiles/image-block';
5
+ describe('Image block component', () => {
6
+ it('should render component grid display mode', async () => {
7
+ var _a, _b, _c;
8
8
  const el = await fixture(html `
9
9
  <image-block
10
- .model=${{
11
- loggedInRequired: true,
12
- contentWarning: true,
13
- identifier: 'goody',
10
+ .model=${{
11
+ loggedInRequired: true,
12
+ contentWarning: true,
13
+ identifier: 'goody',
14
14
  }}
15
15
  .baseImageUrl=${'https://archive.org'}
16
16
  .isCompactTile=${false}
@@ -19,22 +19,22 @@ describe('Image block component', () => {
19
19
  .loggedIn=${false}
20
20
  >
21
21
  </image-block>
22
- `);
23
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.grid');
24
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
25
- const textOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('text-overlay');
26
- expect(viewSize).to.exist;
27
- expect(itemImage).to.exist;
28
- expect(textOverlay).to.exist;
29
- });
30
- it('should render component list display mode', async () => {
31
- var _a, _b, _c;
22
+ `);
23
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.grid');
24
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
25
+ const textOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('text-overlay');
26
+ expect(viewSize).to.exist;
27
+ expect(itemImage).to.exist;
28
+ expect(textOverlay).to.exist;
29
+ });
30
+ it('should render component list display mode', async () => {
31
+ var _a, _b, _c;
32
32
  const el = await fixture(html `
33
33
  <image-block
34
- .model=${{
35
- loggedInRequired: true,
36
- contentWarning: true,
37
- identifier: 'goody',
34
+ .model=${{
35
+ loggedInRequired: true,
36
+ contentWarning: true,
37
+ identifier: 'goody',
38
38
  }}
39
39
  .baseImageUrl=${'https://archive.org'}
40
40
  .isCompactTile=${false}
@@ -43,22 +43,22 @@ describe('Image block component', () => {
43
43
  .loggedIn=${false}
44
44
  >
45
45
  </image-block>
46
- `);
47
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list.desktop');
48
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
49
- const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
50
- expect(viewSize).to.exist;
51
- expect(itemImage).to.exist;
52
- expect(iconOverlay).to.exist;
53
- });
54
- it('should render component compact display mode', async () => {
55
- var _a, _b, _c;
46
+ `);
47
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list.desktop');
48
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
49
+ const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
50
+ expect(viewSize).to.exist;
51
+ expect(itemImage).to.exist;
52
+ expect(iconOverlay).to.exist;
53
+ });
54
+ it('should render component compact display mode', async () => {
55
+ var _a, _b, _c;
56
56
  const el = await fixture(html `
57
57
  <image-block
58
- .model=${{
59
- loggedInRequired: true,
60
- contentWarning: true,
61
- identifier: 'goody',
58
+ .model=${{
59
+ loggedInRequired: true,
60
+ contentWarning: true,
61
+ identifier: 'goody',
62
62
  }}
63
63
  .baseImageUrl=${'https://archive.org'}
64
64
  .isCompactTile=${true}
@@ -67,13 +67,13 @@ describe('Image block component', () => {
67
67
  .loggedIn=${false}
68
68
  >
69
69
  </image-block>
70
- `);
71
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list-compact.desktop');
72
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
73
- const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
74
- expect(viewSize).to.exist;
75
- expect(itemImage).to.exist;
76
- expect(iconOverlay).to.exist;
77
- });
78
- });
70
+ `);
71
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list-compact.desktop');
72
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
73
+ const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
74
+ expect(viewSize).to.exist;
75
+ expect(itemImage).to.exist;
76
+ expect(iconOverlay).to.exist;
77
+ });
78
+ });
79
79
  //# sourceMappingURL=image-block.test.js.map
@@ -1 +1 @@
1
- import '../src/tiles/item-image';
1
+ import '../src/tiles/item-image';
@@ -1,43 +1,43 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import '../src/tiles/item-image';
5
- const baseImageUrl = 'https://archive.org';
6
- const testBookModel = {
7
- collections: [],
8
- commentCount: 0,
9
- creators: [],
10
- favCount: 0,
11
- identifier: '18730130BloomfieldRecordCompleteIssue',
12
- itemCount: 0,
13
- mediatype: 'texts',
14
- subjects: [],
15
- title: 'Sample Waveform',
16
- viewCount: 0,
17
- loginRequired: false,
18
- contentWarning: false,
19
- collectionFilesCount: 0,
20
- collectionSize: 0,
21
- };
22
- const testAudioModel = {
23
- collections: [],
24
- commentCount: 0,
25
- creators: [],
26
- favCount: 0,
27
- identifier: 'dwd2015-01-24',
28
- itemCount: 0,
29
- mediatype: 'audio',
30
- subjects: [],
31
- title: 'Sample Waveform',
32
- viewCount: 0,
33
- loginRequired: false,
34
- contentWarning: false,
35
- collectionFilesCount: 0,
36
- collectionSize: 0,
37
- };
38
- describe('ItemImage component', () => {
39
- it('should render initial component', async () => {
40
- var _a, _b;
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import '../src/tiles/item-image';
5
+ const baseImageUrl = 'https://archive.org';
6
+ const testBookModel = {
7
+ collections: [],
8
+ commentCount: 0,
9
+ creators: [],
10
+ favCount: 0,
11
+ identifier: '18730130BloomfieldRecordCompleteIssue',
12
+ itemCount: 0,
13
+ mediatype: 'texts',
14
+ subjects: [],
15
+ title: 'Sample Waveform',
16
+ viewCount: 0,
17
+ loginRequired: false,
18
+ contentWarning: false,
19
+ collectionFilesCount: 0,
20
+ collectionSize: 0,
21
+ };
22
+ const testAudioModel = {
23
+ collections: [],
24
+ commentCount: 0,
25
+ creators: [],
26
+ favCount: 0,
27
+ identifier: 'dwd2015-01-24',
28
+ itemCount: 0,
29
+ mediatype: 'audio',
30
+ subjects: [],
31
+ title: 'Sample Waveform',
32
+ viewCount: 0,
33
+ loginRequired: false,
34
+ contentWarning: false,
35
+ collectionFilesCount: 0,
36
+ collectionSize: 0,
37
+ };
38
+ describe('ItemImage component', () => {
39
+ it('should render initial component', async () => {
40
+ var _a, _b;
41
41
  const el = await fixture(html `
42
42
  <item-image
43
43
  .isListTile=${false}
@@ -46,14 +46,14 @@ describe('ItemImage component', () => {
46
46
  .baseImageUrl=${baseImageUrl}
47
47
  >
48
48
  </item-image>
49
- `);
50
- const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
51
- const imgClassName = (_b = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img')) === null || _b === void 0 ? void 0 : _b.className;
52
- expect(dropShadow).to.exist;
53
- expect(imgClassName).to.eql(' contain ');
54
- });
55
- it('should render component if mediatype is waveform', async () => {
56
- var _a;
49
+ `);
50
+ const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
51
+ const imgClassName = (_b = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img')) === null || _b === void 0 ? void 0 : _b.className;
52
+ expect(dropShadow).to.exist;
53
+ expect(imgClassName).to.eql(' contain ');
54
+ });
55
+ it('should render component if mediatype is waveform', async () => {
56
+ var _a;
57
57
  const el = await fixture(html `
58
58
  <item-image
59
59
  .isListTile=${false}
@@ -62,19 +62,19 @@ describe('ItemImage component', () => {
62
62
  .baseImageUrl=${baseImageUrl}
63
63
  >
64
64
  </item-image>
65
- `);
66
- const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
67
- const image = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img');
68
- expect(dropShadow).to.exist;
69
- expect(image).to.exist;
70
- // simulate image onLoad event check if image className is waveform
71
- setTimeout(() => {
72
- const imgClassName = image === null || image === void 0 ? void 0 : image.className;
73
- expect(imgClassName).to.eql(' waveform ');
74
- }, 1000);
75
- });
76
- it('should not fetch image with undefined base url', async () => {
77
- var _a;
65
+ `);
66
+ const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
67
+ const image = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img');
68
+ expect(dropShadow).to.exist;
69
+ expect(image).to.exist;
70
+ // simulate image onLoad event check if image className is waveform
71
+ setTimeout(() => {
72
+ const imgClassName = image === null || image === void 0 ? void 0 : image.className;
73
+ expect(imgClassName).to.eql(' waveform ');
74
+ }, 1000);
75
+ });
76
+ it('should not fetch image with undefined base url', async () => {
77
+ var _a;
78
78
  const el = await fixture(html `
79
79
  <item-image
80
80
  .isListTile=${false}
@@ -82,14 +82,14 @@ describe('ItemImage component', () => {
82
82
  .model=${testBookModel}
83
83
  >
84
84
  </item-image>
85
- `);
86
- // Doesn't set the image src if base url is undefined
87
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
88
- expect(img).to.exist;
89
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
90
- });
91
- it('should not fetch image with undefined model', async () => {
92
- var _a;
85
+ `);
86
+ // Doesn't set the image src if base url is undefined
87
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
88
+ expect(img).to.exist;
89
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
90
+ });
91
+ it('should not fetch image with undefined model', async () => {
92
+ var _a;
93
93
  const el = await fixture(html `
94
94
  <item-image
95
95
  .isListTile=${false}
@@ -97,14 +97,14 @@ describe('ItemImage component', () => {
97
97
  .baseImageUrl=${baseImageUrl}
98
98
  >
99
99
  </item-image>
100
- `);
101
- // Doesn't set the image src if model is not present
102
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
103
- expect(img).to.exist;
104
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
105
- });
106
- it('should not fetch image with undefined identifier', async () => {
107
- var _a;
100
+ `);
101
+ // Doesn't set the image src if model is not present
102
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
103
+ expect(img).to.exist;
104
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
105
+ });
106
+ it('should not fetch image with undefined identifier', async () => {
107
+ var _a;
108
108
  const el = await fixture(html `
109
109
  <item-image
110
110
  .isListTile=${false}
@@ -113,11 +113,11 @@ describe('ItemImage component', () => {
113
113
  .baseImageUrl=${baseImageUrl}
114
114
  >
115
115
  </item-image>
116
- `);
117
- // Doesn't set the image src if identifier is not present
118
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
119
- expect(img).to.exist;
120
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
121
- });
122
- });
116
+ `);
117
+ // Doesn't set the image src if identifier is not present
118
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
119
+ expect(img).to.exist;
120
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
121
+ });
122
+ });
123
123
  //# sourceMappingURL=item-image.test.js.map
@@ -1 +1 @@
1
- export {};
1
+ export {};
@@ -1,17 +1,17 @@
1
- import { expect } from '@open-wc/testing';
2
- import { mediatypeConfig } from '../src/mediatype/mediatype-config';
3
- describe('mediatypeConfig', () => {
4
- it('returns undefined', () => {
5
- expect(mediatypeConfig['']).to.equal(undefined);
6
- expect(mediatypeConfig.test).to.equal(undefined);
7
- expect(mediatypeConfig.media).to.equal(undefined);
8
- expect(mediatypeConfig.testing).to.equal(undefined);
9
- });
10
- it('returns audio', () => {
11
- expect(mediatypeConfig.audio).to.exist;
12
- expect(mediatypeConfig.audio.color).to.exist;
13
- expect(mediatypeConfig.audio.icon).to.exist;
14
- expect(mediatypeConfig.audio.text).to.exist;
15
- });
16
- });
1
+ import { expect } from '@open-wc/testing';
2
+ import { mediatypeConfig } from '../src/mediatype/mediatype-config';
3
+ describe('mediatypeConfig', () => {
4
+ it('returns undefined', () => {
5
+ expect(mediatypeConfig['']).to.equal(undefined);
6
+ expect(mediatypeConfig.test).to.equal(undefined);
7
+ expect(mediatypeConfig.media).to.equal(undefined);
8
+ expect(mediatypeConfig.testing).to.equal(undefined);
9
+ });
10
+ it('returns audio', () => {
11
+ expect(mediatypeConfig.audio).to.exist;
12
+ expect(mediatypeConfig.audio.color).to.exist;
13
+ expect(mediatypeConfig.audio.icon).to.exist;
14
+ expect(mediatypeConfig.audio.text).to.exist;
15
+ });
16
+ });
17
17
  //# sourceMappingURL=mediatype-config.test.js.map
@@ -1,10 +1,10 @@
1
- import type { AnalyticsEvent, AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
2
- export declare class MockAnalyticsHandler implements AnalyticsManagerInterface {
3
- callCategory?: string;
4
- callAction?: string;
5
- callLabel?: string;
6
- callEventConfiguration?: object;
7
- sendPing(): void;
8
- sendEvent(options: AnalyticsEvent): void;
9
- sendEventNoSampling(options: AnalyticsEvent): void;
10
- }
1
+ import type { AnalyticsEvent, AnalyticsManagerInterface } from '@internetarchive/analytics-manager';
2
+ export declare class MockAnalyticsHandler implements AnalyticsManagerInterface {
3
+ callCategory?: string;
4
+ callAction?: string;
5
+ callLabel?: string;
6
+ callEventConfiguration?: object;
7
+ sendPing(): void;
8
+ sendEvent(options: AnalyticsEvent): void;
9
+ sendEventNoSampling(options: AnalyticsEvent): void;
10
+ }
@@ -1,16 +1,16 @@
1
- export class MockAnalyticsHandler {
2
- sendPing() { }
3
- sendEvent(options) {
4
- this.callCategory = options.category;
5
- this.callAction = options.action;
6
- this.callLabel = options.label;
7
- this.callEventConfiguration = options.eventConfiguration;
8
- }
9
- sendEventNoSampling(options) {
10
- this.callCategory = options.category;
11
- this.callAction = options.action;
12
- this.callLabel = options.label;
13
- this.callEventConfiguration = options.eventConfiguration;
14
- }
15
- }
1
+ export class MockAnalyticsHandler {
2
+ sendPing() { }
3
+ sendEvent(options) {
4
+ this.callCategory = options.category;
5
+ this.callAction = options.action;
6
+ this.callLabel = options.label;
7
+ this.callEventConfiguration = options.eventConfiguration;
8
+ }
9
+ sendEventNoSampling(options) {
10
+ this.callCategory = options.category;
11
+ this.callAction = options.action;
12
+ this.callLabel = options.label;
13
+ this.callEventConfiguration = options.eventConfiguration;
14
+ }
15
+ }
16
16
  //# sourceMappingURL=mock-analytics-handler.js.map
@@ -1,7 +1,7 @@
1
- import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
2
- export declare class MockCollectionNameCache implements CollectionNameCacheInterface {
3
- collectionNamesRequested: string[];
4
- preloadIdentifiersRequested: string[];
5
- collectionNameFor(identifier: string): Promise<string | null>;
6
- preloadIdentifiers(identifiers: string[]): Promise<void>;
7
- }
1
+ import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
2
+ export declare class MockCollectionNameCache implements CollectionNameCacheInterface {
3
+ collectionNamesRequested: string[];
4
+ preloadIdentifiersRequested: string[];
5
+ collectionNameFor(identifier: string): Promise<string | null>;
6
+ preloadIdentifiers(identifiers: string[]): Promise<void>;
7
+ }
@@ -1,14 +1,14 @@
1
- export class MockCollectionNameCache {
2
- constructor() {
3
- this.collectionNamesRequested = [];
4
- this.preloadIdentifiersRequested = [];
5
- }
6
- async collectionNameFor(identifier) {
7
- this.collectionNamesRequested.push(identifier);
8
- return `${identifier}-name`;
9
- }
10
- async preloadIdentifiers(identifiers) {
11
- this.preloadIdentifiersRequested = identifiers;
12
- }
13
- }
1
+ export class MockCollectionNameCache {
2
+ constructor() {
3
+ this.collectionNamesRequested = [];
4
+ this.preloadIdentifiersRequested = [];
5
+ }
6
+ async collectionNameFor(identifier) {
7
+ this.collectionNamesRequested.push(identifier);
8
+ return `${identifier}-name`;
9
+ }
10
+ async preloadIdentifiers(identifiers) {
11
+ this.preloadIdentifiersRequested = identifiers;
12
+ }
13
+ }
14
14
  //# sourceMappingURL=mock-collection-name-cache.js.map
@@ -1,12 +1,12 @@
1
- import type { Result } from '@internetarchive/result-type';
2
- import { SearchResponse, SearchServiceError } from '@internetarchive/search-service';
3
- export declare const mockSuccessSingleResult: Result<SearchResponse, SearchServiceError>;
4
- export declare const mockSuccessWithYearHistogramAggs: Result<SearchResponse, SearchServiceError>;
5
- export declare const mockSuccessLoggedInResult: Result<SearchResponse, SearchServiceError>;
6
- export declare const mockSuccessNoPreviewResult: Result<SearchResponse, SearchServiceError>;
7
- export declare const mockSuccessLoggedInAndNoPreviewResult: Result<SearchResponse, SearchServiceError>;
8
- export declare const mockSuccessFirstTitleResult: Result<SearchResponse, SearchServiceError>;
9
- export declare const mockSuccessFirstCreatorResult: Result<SearchResponse, SearchServiceError>;
10
- export declare const getMockSuccessSingleResultWithSort: (resultsSpy: Function) => Result<SearchResponse, SearchServiceError>;
11
- export declare const mockSuccessMultipleResults: Result<SearchResponse, SearchServiceError>;
12
- export declare const mockSuccessMultiLineDescription: Result<SearchResponse, SearchServiceError>;
1
+ import type { Result } from '@internetarchive/result-type';
2
+ import { SearchResponse, SearchServiceError } from '@internetarchive/search-service';
3
+ export declare const mockSuccessSingleResult: Result<SearchResponse, SearchServiceError>;
4
+ export declare const mockSuccessWithYearHistogramAggs: Result<SearchResponse, SearchServiceError>;
5
+ export declare const mockSuccessLoggedInResult: Result<SearchResponse, SearchServiceError>;
6
+ export declare const mockSuccessNoPreviewResult: Result<SearchResponse, SearchServiceError>;
7
+ export declare const mockSuccessLoggedInAndNoPreviewResult: Result<SearchResponse, SearchServiceError>;
8
+ export declare const mockSuccessFirstTitleResult: Result<SearchResponse, SearchServiceError>;
9
+ export declare const mockSuccessFirstCreatorResult: Result<SearchResponse, SearchServiceError>;
10
+ export declare const getMockSuccessSingleResultWithSort: (resultsSpy: Function) => Result<SearchResponse, SearchServiceError>;
11
+ export declare const mockSuccessMultipleResults: Result<SearchResponse, SearchServiceError>;
12
+ export declare const mockSuccessMultiLineDescription: Result<SearchResponse, SearchServiceError>;