@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.
Files changed (279) 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 +280 -279
  68. package/dist/src/collection-browser.js +1178 -1156
  69. package/dist/src/collection-browser.js.map +1 -1
  70. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  71. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  72. package/dist/src/collection-facets/facets-template.d.ts +16 -16
  73. package/dist/src/collection-facets/facets-template.js +125 -125
  74. package/dist/src/collection-facets/more-facets-content.d.ts +76 -75
  75. package/dist/src/collection-facets/more-facets-content.js +354 -377
  76. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  77. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  78. package/dist/src/collection-facets/more-facets-pagination.js +197 -195
  79. package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
  80. package/dist/src/collection-facets/toggle-switch.d.ts +41 -0
  81. package/dist/src/collection-facets/toggle-switch.js +184 -0
  82. package/dist/src/collection-facets/toggle-switch.js.map +1 -0
  83. package/dist/src/collection-facets.d.ts +81 -81
  84. package/dist/src/collection-facets.js +376 -385
  85. package/dist/src/collection-facets.js.map +1 -1
  86. package/dist/src/empty-placeholder.d.ts +13 -11
  87. package/dist/src/empty-placeholder.js +80 -44
  88. package/dist/src/empty-placeholder.js.map +1 -1
  89. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  90. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  91. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  92. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  93. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  94. package/dist/src/mediatype/mediatype-config.js +85 -85
  95. package/dist/src/models.d.ts +119 -115
  96. package/dist/src/models.js +136 -125
  97. package/dist/src/models.js.map +1 -1
  98. package/dist/src/restoration-state-handler.d.ts +45 -45
  99. package/dist/src/restoration-state-handler.js +230 -230
  100. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  101. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +25 -26
  102. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js.map +1 -1
  103. package/dist/src/sort-filter-bar/alpha-bar.d.ts +20 -20
  104. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  105. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  106. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  107. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  108. package/dist/src/sort-filter-bar/img/list.js +3 -3
  109. package/dist/src/sort-filter-bar/img/list.js.map +1 -1
  110. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -0
  111. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +15 -0
  112. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js.map +1 -0
  113. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -0
  114. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +17 -0
  115. package/dist/src/sort-filter-bar/img/sort-toggle-down.js.map +1 -0
  116. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -0
  117. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +17 -0
  118. package/dist/src/sort-filter-bar/img/sort-toggle-up.js.map +1 -0
  119. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  120. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  121. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  122. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  123. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +189 -108
  124. package/dist/src/sort-filter-bar/sort-filter-bar.js +708 -614
  125. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  126. package/dist/src/styles/item-image-styles.d.ts +8 -8
  127. package/dist/src/styles/item-image-styles.js +9 -9
  128. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  129. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  130. package/dist/src/tiles/grid/account-tile.d.ts +20 -20
  131. package/dist/src/tiles/grid/account-tile.js +64 -64
  132. package/dist/src/tiles/grid/collection-tile.d.ts +17 -17
  133. package/dist/src/tiles/grid/collection-tile.js +71 -71
  134. package/dist/src/tiles/grid/item-tile.d.ts +32 -32
  135. package/dist/src/tiles/grid/item-tile.js +130 -126
  136. package/dist/src/tiles/grid/item-tile.js.map +1 -1
  137. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  138. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +7 -7
  139. package/dist/src/tiles/grid/tile-stats.d.ts +11 -10
  140. package/dist/src/tiles/grid/tile-stats.js +44 -40
  141. package/dist/src/tiles/grid/tile-stats.js.map +1 -1
  142. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  143. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  144. package/dist/src/tiles/hover/tile-hover-pane.d.ts +15 -15
  145. package/dist/src/tiles/hover/tile-hover-pane.js +38 -38
  146. package/dist/src/tiles/image-block.d.ts +17 -17
  147. package/dist/src/tiles/image-block.js +72 -72
  148. package/dist/src/tiles/item-image.d.ts +35 -35
  149. package/dist/src/tiles/item-image.js +117 -117
  150. package/dist/src/tiles/list/account-label.d.ts +1 -1
  151. package/dist/src/tiles/list/account-label.js +6 -6
  152. package/dist/src/tiles/list/date-label.d.ts +1 -1
  153. package/dist/src/tiles/list/date-label.js +12 -12
  154. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
  155. package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
  156. package/dist/src/tiles/list/tile-list-compact.d.ts +22 -21
  157. package/dist/src/tiles/list/tile-list-compact.js +114 -101
  158. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  159. package/dist/src/tiles/list/tile-list.d.ts +55 -55
  160. package/dist/src/tiles/list/tile-list.js +304 -301
  161. package/dist/src/tiles/list/tile-list.js.map +1 -1
  162. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  163. package/dist/src/tiles/mediatype-icon.js +47 -47
  164. package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
  165. package/dist/src/tiles/overlay/icon-overlay.js +40 -40
  166. package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
  167. package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
  168. package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
  169. package/dist/src/tiles/overlay/text-overlay.js +42 -42
  170. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  171. package/dist/src/tiles/text-snippet-block.js +73 -73
  172. package/dist/src/tiles/tile-dispatcher.d.ts +58 -58
  173. package/dist/src/tiles/tile-dispatcher.js +194 -194
  174. package/dist/src/utils/analytics-events.d.ts +22 -22
  175. package/dist/src/utils/analytics-events.js +24 -24
  176. package/dist/src/utils/format-count.d.ts +7 -7
  177. package/dist/src/utils/format-count.js +76 -76
  178. package/dist/src/utils/format-date.d.ts +2 -2
  179. package/dist/src/utils/format-date.js +23 -23
  180. package/dist/src/utils/format-unit-size.d.ts +2 -2
  181. package/dist/src/utils/format-unit-size.js +33 -33
  182. package/dist/test/collection-browser.test.d.ts +1 -1
  183. package/dist/test/collection-browser.test.js +584 -584
  184. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  185. package/dist/test/collection-facets/facets-template.test.js +62 -62
  186. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  187. package/dist/test/collection-facets/more-facets-content.test.js +114 -114
  188. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  189. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  190. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -0
  191. package/dist/test/collection-facets/toggle-switch.test.js +87 -0
  192. package/dist/test/collection-facets/toggle-switch.test.js.map +1 -0
  193. package/dist/test/collection-facets.test.d.ts +2 -2
  194. package/dist/test/collection-facets.test.js +460 -460
  195. package/dist/test/empty-placeholder.test.d.ts +1 -1
  196. package/dist/test/empty-placeholder.test.js +33 -33
  197. package/dist/test/icon-overlay.test.d.ts +1 -1
  198. package/dist/test/icon-overlay.test.js +24 -24
  199. package/dist/test/image-block.test.d.ts +1 -1
  200. package/dist/test/image-block.test.js +48 -48
  201. package/dist/test/item-image.test.d.ts +1 -1
  202. package/dist/test/item-image.test.js +84 -84
  203. package/dist/test/mediatype-config.test.d.ts +1 -1
  204. package/dist/test/mediatype-config.test.js +16 -16
  205. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  206. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  207. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -7
  208. package/dist/test/mocks/mock-collection-name-cache.js +13 -13
  209. package/dist/test/mocks/mock-search-responses.d.ts +12 -12
  210. package/dist/test/mocks/mock-search-responses.js +341 -341
  211. package/dist/test/mocks/mock-search-service.d.ts +13 -13
  212. package/dist/test/mocks/mock-search-service.js +40 -40
  213. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  214. package/dist/test/restoration-state-handler.test.js +125 -125
  215. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  216. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  217. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  218. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  219. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  220. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +372 -199
  221. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
  222. package/dist/test/text-overlay.test.d.ts +1 -1
  223. package/dist/test/text-overlay.test.js +48 -48
  224. package/dist/test/text-snippet-block.test.d.ts +1 -1
  225. package/dist/test/text-snippet-block.test.js +57 -57
  226. package/dist/test/tile-stats.test.d.ts +1 -1
  227. package/dist/test/tile-stats.test.js +33 -33
  228. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  229. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  230. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  231. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  232. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  233. package/dist/test/tiles/grid/item-tile.test.js +158 -158
  234. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  235. package/dist/test/tiles/hover/hover-pane-controller.test.js +257 -257
  236. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  237. package/dist/test/tiles/hover/tile-hover-pane.test.js +13 -13
  238. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  239. package/dist/test/tiles/list/tile-list-compact.test.js +104 -92
  240. package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
  241. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  242. package/dist/test/tiles/list/tile-list.test.js +175 -163
  243. package/dist/test/tiles/list/tile-list.test.js.map +1 -1
  244. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  245. package/dist/test/tiles/tile-dispatcher.test.js +67 -67
  246. package/dist/test/utils/format-count.test.d.ts +1 -1
  247. package/dist/test/utils/format-count.test.js +23 -23
  248. package/dist/test/utils/format-date.test.d.ts +1 -1
  249. package/dist/test/utils/format-date.test.js +17 -17
  250. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  251. package/dist/test/utils/format-unit-size.test.js +17 -17
  252. package/local.archive.org.cert +86 -86
  253. package/local.archive.org.key +27 -27
  254. package/package.json +4 -3
  255. package/renovate.json +6 -6
  256. package/src/collection-browser.ts +28 -1
  257. package/src/collection-facets/more-facets-content.ts +25 -48
  258. package/src/collection-facets/more-facets-pagination.ts +5 -3
  259. package/src/collection-facets/toggle-switch.ts +184 -0
  260. package/src/collection-facets.ts +1 -10
  261. package/src/empty-placeholder.ts +53 -7
  262. package/src/models.ts +23 -8
  263. package/src/sort-filter-bar/alpha-bar-tooltip.ts +1 -2
  264. package/src/sort-filter-bar/img/list.ts +1 -1
  265. package/src/sort-filter-bar/img/sort-toggle-disabled.ts +15 -0
  266. package/src/sort-filter-bar/img/sort-toggle-down.ts +17 -0
  267. package/src/sort-filter-bar/img/sort-toggle-up.ts +17 -0
  268. package/src/sort-filter-bar/sort-filter-bar.ts +433 -303
  269. package/src/tiles/grid/item-tile.ts +6 -1
  270. package/src/tiles/grid/tile-stats.ts +3 -1
  271. package/src/tiles/list/tile-list-compact.ts +15 -2
  272. package/src/tiles/list/tile-list.ts +3 -0
  273. package/test/collection-facets/toggle-switch.test.ts +154 -0
  274. package/test/sort-filter-bar/sort-filter-bar.test.ts +377 -101
  275. package/test/tiles/list/tile-list-compact.test.ts +14 -0
  276. package/test/tiles/list/tile-list.test.ts +14 -0
  277. package/tsconfig.json +21 -21
  278. package/web-dev-server.config.mjs +30 -30
  279. package/web-test-runner.config.mjs +41 -41
@@ -1,13 +1,13 @@
1
- import type { Result } from '@internetarchive/result-type';
2
- import type { SearchParams, SearchResponse, SearchServiceInterface, SearchServiceError, SearchType } from '@internetarchive/search-service';
3
- export declare class MockSearchService implements SearchServiceInterface {
4
- searchParams?: SearchParams;
5
- searchType?: SearchType;
6
- asyncResponse: boolean;
7
- resultsSpy: Function;
8
- constructor({ asyncResponse, resultsSpy }?: {
9
- asyncResponse?: boolean | undefined;
10
- resultsSpy?: (() => void) | undefined;
11
- });
12
- search(params: SearchParams, searchType: SearchType): Promise<Result<SearchResponse, SearchServiceError>>;
13
- }
1
+ import type { Result } from '@internetarchive/result-type';
2
+ import type { SearchParams, SearchResponse, SearchServiceInterface, SearchServiceError, SearchType } from '@internetarchive/search-service';
3
+ export declare class MockSearchService implements SearchServiceInterface {
4
+ searchParams?: SearchParams;
5
+ searchType?: SearchType;
6
+ asyncResponse: boolean;
7
+ resultsSpy: Function;
8
+ constructor({ asyncResponse, resultsSpy }?: {
9
+ asyncResponse?: boolean | undefined;
10
+ resultsSpy?: (() => void) | undefined;
11
+ });
12
+ search(params: SearchParams, searchType: SearchType): Promise<Result<SearchResponse, SearchServiceError>>;
13
+ }
@@ -1,41 +1,41 @@
1
- import { mockSuccessSingleResult, mockSuccessMultipleResults, getMockSuccessSingleResultWithSort, mockSuccessLoggedInResult, mockSuccessNoPreviewResult, mockSuccessLoggedInAndNoPreviewResult, mockSuccessWithYearHistogramAggs, mockSuccessMultiLineDescription, mockSuccessFirstTitleResult, mockSuccessFirstCreatorResult, } from './mock-search-responses';
2
- export class MockSearchService {
3
- constructor({ asyncResponse = false, resultsSpy = () => { } } = {}) {
4
- this.asyncResponse = asyncResponse;
5
- this.resultsSpy = resultsSpy;
6
- }
7
- async search(params, searchType) {
8
- var _a;
9
- this.searchParams = params;
10
- this.searchType = searchType;
11
- if (this.asyncResponse) {
12
- // Add an artificial 1-tick delay
13
- await new Promise(res => {
14
- setTimeout(res, 0);
15
- });
16
- }
17
- switch ((_a = this.searchParams) === null || _a === void 0 ? void 0 : _a.query) {
18
- case 'single-result':
19
- return mockSuccessSingleResult;
20
- case 'years':
21
- return mockSuccessWithYearHistogramAggs;
22
- case 'multi-line-description':
23
- return mockSuccessMultiLineDescription;
24
- case 'loggedin':
25
- return mockSuccessLoggedInResult;
26
- case 'no-preview':
27
- return mockSuccessNoPreviewResult;
28
- case 'loggedin-no-preview':
29
- return mockSuccessLoggedInAndNoPreviewResult;
30
- case 'first-title':
31
- return mockSuccessFirstTitleResult;
32
- case 'first-creator':
33
- return mockSuccessFirstCreatorResult;
34
- case 'with-sort':
35
- return getMockSuccessSingleResultWithSort(this.resultsSpy);
36
- default:
37
- return mockSuccessMultipleResults;
38
- }
39
- }
40
- }
1
+ import { mockSuccessSingleResult, mockSuccessMultipleResults, getMockSuccessSingleResultWithSort, mockSuccessLoggedInResult, mockSuccessNoPreviewResult, mockSuccessLoggedInAndNoPreviewResult, mockSuccessWithYearHistogramAggs, mockSuccessMultiLineDescription, mockSuccessFirstTitleResult, mockSuccessFirstCreatorResult, } from './mock-search-responses';
2
+ export class MockSearchService {
3
+ constructor({ asyncResponse = false, resultsSpy = () => { } } = {}) {
4
+ this.asyncResponse = asyncResponse;
5
+ this.resultsSpy = resultsSpy;
6
+ }
7
+ async search(params, searchType) {
8
+ var _a;
9
+ this.searchParams = params;
10
+ this.searchType = searchType;
11
+ if (this.asyncResponse) {
12
+ // Add an artificial 1-tick delay
13
+ await new Promise(res => {
14
+ setTimeout(res, 0);
15
+ });
16
+ }
17
+ switch ((_a = this.searchParams) === null || _a === void 0 ? void 0 : _a.query) {
18
+ case 'single-result':
19
+ return mockSuccessSingleResult;
20
+ case 'years':
21
+ return mockSuccessWithYearHistogramAggs;
22
+ case 'multi-line-description':
23
+ return mockSuccessMultiLineDescription;
24
+ case 'loggedin':
25
+ return mockSuccessLoggedInResult;
26
+ case 'no-preview':
27
+ return mockSuccessNoPreviewResult;
28
+ case 'loggedin-no-preview':
29
+ return mockSuccessLoggedInAndNoPreviewResult;
30
+ case 'first-title':
31
+ return mockSuccessFirstTitleResult;
32
+ case 'first-creator':
33
+ return mockSuccessFirstCreatorResult;
34
+ case 'with-sort':
35
+ return getMockSuccessSingleResultWithSort(this.resultsSpy);
36
+ default:
37
+ return mockSuccessMultipleResults;
38
+ }
39
+ }
40
+ }
41
41
  //# sourceMappingURL=mock-search-service.js.map
@@ -1 +1 @@
1
- export {};
1
+ export {};
@@ -1,126 +1,126 @@
1
- import { SearchType } from '@internetarchive/search-service';
2
- import { expect } from '@open-wc/testing';
3
- import { RestorationStateHandler } from '../src/restoration-state-handler';
4
- describe('Restoration state handler', () => {
5
- it('should restore query from URL', async () => {
6
- const handler = new RestorationStateHandler({ context: 'search' });
7
- const url = new URL(window.location.href);
8
- url.search = '?query=boop';
9
- window.history.replaceState({ path: url.href }, '', url.href);
10
- const restorationState = handler.getRestorationState();
11
- expect(restorationState.baseQuery).to.equal('boop');
12
- });
13
- it('should restore full text search type from URL', async () => {
14
- const handler = new RestorationStateHandler({ context: 'search' });
15
- const url = new URL(window.location.href);
16
- url.search = '?sin=TXT';
17
- window.history.replaceState({ path: url.href }, '', url.href);
18
- const restorationState = handler.getRestorationState();
19
- expect(restorationState.searchType).to.equal(SearchType.FULLTEXT);
20
- });
21
- it('should restore page number from URL', async () => {
22
- const handler = new RestorationStateHandler({ context: 'search' });
23
- const url = new URL(window.location.href);
24
- url.search = '?page=42';
25
- window.history.replaceState({ path: url.href }, '', url.href);
26
- const restorationState = handler.getRestorationState();
27
- expect(restorationState.currentPage).to.equal(42);
28
- });
29
- it('should restore selected year facets from URL', async () => {
30
- const handler = new RestorationStateHandler({ context: 'search' });
31
- const url = new URL(window.location.href);
32
- url.search = '?and[]=year:"2018"';
33
- window.history.replaceState({ path: url.href }, '', url.href);
34
- const restorationState = handler.getRestorationState();
35
- expect(restorationState.selectedFacets.year['2018'].state).to.equal('selected');
36
- });
37
- it('should restore selected date range facets from URL', async () => {
38
- const handler = new RestorationStateHandler({ context: 'search' });
39
- const url = new URL(window.location.href);
40
- url.search = '?and[]=year:"2018+TO+2021"';
41
- window.history.replaceState({ path: url.href }, '', url.href);
42
- const restorationState = handler.getRestorationState();
43
- expect(restorationState.minSelectedDate).to.equal('2018');
44
- expect(restorationState.maxSelectedDate).to.equal('2021');
45
- });
46
- it('should restore creator filter from URL', async () => {
47
- const handler = new RestorationStateHandler({ context: 'search' });
48
- const url = new URL(window.location.href);
49
- url.search = '?and[]=firstCreator:F';
50
- window.history.replaceState({ path: url.href }, '', url.href);
51
- const restorationState = handler.getRestorationState();
52
- expect(restorationState.selectedCreatorFilter).to.equal('F');
53
- });
54
- it('should restore title filter from URL', async () => {
55
- const handler = new RestorationStateHandler({ context: 'search' });
56
- const url = new URL(window.location.href);
57
- url.search = '?and[]=firstTitle:F';
58
- window.history.replaceState({ path: url.href }, '', url.href);
59
- const restorationState = handler.getRestorationState();
60
- expect(restorationState.selectedTitleFilter).to.equal('F');
61
- });
62
- it('should restore other selected facets from URL', async () => {
63
- const handler = new RestorationStateHandler({ context: 'search' });
64
- const url = new URL(window.location.href);
65
- url.search = '?and[]=subject:"foo"';
66
- window.history.replaceState({ path: url.href }, '', url.href);
67
- const restorationState = handler.getRestorationState();
68
- expect(restorationState.selectedFacets.subject.foo.state).to.equal('selected');
69
- });
70
- it('should restore negative facets from URL', async () => {
71
- const handler = new RestorationStateHandler({ context: 'search' });
72
- const url = new URL(window.location.href);
73
- url.search = '?not[]=year:2018';
74
- window.history.replaceState({ path: url.href }, '', url.href);
75
- const restorationState = handler.getRestorationState();
76
- expect(restorationState.selectedFacets.year['2018'].state).to.equal('hidden');
77
- });
78
- it('should restore multiple selected/negative facets from URL', async () => {
79
- const handler = new RestorationStateHandler({ context: 'search' });
80
- const url = new URL(window.location.href);
81
- url.search =
82
- '?and[]=collection:"foo"&and[]=collection:"bar"&not[]=collection:"baz"&not[]=collection:"boop"';
83
- window.history.replaceState({ path: url.href }, '', url.href);
84
- const restorationState = handler.getRestorationState();
85
- expect(restorationState.selectedFacets.collection.foo.state).to.equal('selected');
86
- expect(restorationState.selectedFacets.collection.bar.state).to.equal('selected');
87
- expect(restorationState.selectedFacets.collection.baz.state).to.equal('hidden');
88
- expect(restorationState.selectedFacets.collection.boop.state).to.equal('hidden');
89
- });
90
- it('negative facets take precedence if both present in URL', async () => {
91
- const handler = new RestorationStateHandler({ context: 'search' });
92
- const url = new URL(window.location.href);
93
- url.search = '?and[]=collection:"foo"&not[]=collection:"foo"';
94
- window.history.replaceState({ path: url.href }, '', url.href);
95
- const restorationState = handler.getRestorationState();
96
- expect(restorationState.selectedFacets.collection.foo.state).to.equal('hidden');
97
- });
98
- it('should restore sort from URL (space format)', async () => {
99
- const handler = new RestorationStateHandler({ context: 'search' });
100
- const url = new URL(window.location.href);
101
- url.search = '?sort=date+desc';
102
- window.history.replaceState({ path: url.href }, '', url.href);
103
- const restorationState = handler.getRestorationState();
104
- expect(restorationState.selectedSort).to.equal('date');
105
- expect(restorationState.sortDirection).to.equal('desc');
106
- });
107
- it('should restore sort from URL (prefix format, desc)', async () => {
108
- const handler = new RestorationStateHandler({ context: 'search' });
109
- const url = new URL(window.location.href);
110
- url.search = '?sort=-date';
111
- window.history.replaceState({ path: url.href }, '', url.href);
112
- const restorationState = handler.getRestorationState();
113
- expect(restorationState.selectedSort).to.equal('date');
114
- expect(restorationState.sortDirection).to.equal('desc');
115
- });
116
- it('should restore sort from URL (prefix format, asc)', async () => {
117
- const handler = new RestorationStateHandler({ context: 'search' });
118
- const url = new URL(window.location.href);
119
- url.search = '?sort=date';
120
- window.history.replaceState({ path: url.href }, '', url.href);
121
- const restorationState = handler.getRestorationState();
122
- expect(restorationState.selectedSort).to.equal('date');
123
- expect(restorationState.sortDirection).to.equal('asc');
124
- });
125
- });
1
+ import { SearchType } from '@internetarchive/search-service';
2
+ import { expect } from '@open-wc/testing';
3
+ import { RestorationStateHandler } from '../src/restoration-state-handler';
4
+ describe('Restoration state handler', () => {
5
+ it('should restore query from URL', async () => {
6
+ const handler = new RestorationStateHandler({ context: 'search' });
7
+ const url = new URL(window.location.href);
8
+ url.search = '?query=boop';
9
+ window.history.replaceState({ path: url.href }, '', url.href);
10
+ const restorationState = handler.getRestorationState();
11
+ expect(restorationState.baseQuery).to.equal('boop');
12
+ });
13
+ it('should restore full text search type from URL', async () => {
14
+ const handler = new RestorationStateHandler({ context: 'search' });
15
+ const url = new URL(window.location.href);
16
+ url.search = '?sin=TXT';
17
+ window.history.replaceState({ path: url.href }, '', url.href);
18
+ const restorationState = handler.getRestorationState();
19
+ expect(restorationState.searchType).to.equal(SearchType.FULLTEXT);
20
+ });
21
+ it('should restore page number from URL', async () => {
22
+ const handler = new RestorationStateHandler({ context: 'search' });
23
+ const url = new URL(window.location.href);
24
+ url.search = '?page=42';
25
+ window.history.replaceState({ path: url.href }, '', url.href);
26
+ const restorationState = handler.getRestorationState();
27
+ expect(restorationState.currentPage).to.equal(42);
28
+ });
29
+ it('should restore selected year facets from URL', async () => {
30
+ const handler = new RestorationStateHandler({ context: 'search' });
31
+ const url = new URL(window.location.href);
32
+ url.search = '?and[]=year:"2018"';
33
+ window.history.replaceState({ path: url.href }, '', url.href);
34
+ const restorationState = handler.getRestorationState();
35
+ expect(restorationState.selectedFacets.year['2018'].state).to.equal('selected');
36
+ });
37
+ it('should restore selected date range facets from URL', async () => {
38
+ const handler = new RestorationStateHandler({ context: 'search' });
39
+ const url = new URL(window.location.href);
40
+ url.search = '?and[]=year:"2018+TO+2021"';
41
+ window.history.replaceState({ path: url.href }, '', url.href);
42
+ const restorationState = handler.getRestorationState();
43
+ expect(restorationState.minSelectedDate).to.equal('2018');
44
+ expect(restorationState.maxSelectedDate).to.equal('2021');
45
+ });
46
+ it('should restore creator filter from URL', async () => {
47
+ const handler = new RestorationStateHandler({ context: 'search' });
48
+ const url = new URL(window.location.href);
49
+ url.search = '?and[]=firstCreator:F';
50
+ window.history.replaceState({ path: url.href }, '', url.href);
51
+ const restorationState = handler.getRestorationState();
52
+ expect(restorationState.selectedCreatorFilter).to.equal('F');
53
+ });
54
+ it('should restore title filter from URL', async () => {
55
+ const handler = new RestorationStateHandler({ context: 'search' });
56
+ const url = new URL(window.location.href);
57
+ url.search = '?and[]=firstTitle:F';
58
+ window.history.replaceState({ path: url.href }, '', url.href);
59
+ const restorationState = handler.getRestorationState();
60
+ expect(restorationState.selectedTitleFilter).to.equal('F');
61
+ });
62
+ it('should restore other selected facets from URL', async () => {
63
+ const handler = new RestorationStateHandler({ context: 'search' });
64
+ const url = new URL(window.location.href);
65
+ url.search = '?and[]=subject:"foo"';
66
+ window.history.replaceState({ path: url.href }, '', url.href);
67
+ const restorationState = handler.getRestorationState();
68
+ expect(restorationState.selectedFacets.subject.foo.state).to.equal('selected');
69
+ });
70
+ it('should restore negative facets from URL', async () => {
71
+ const handler = new RestorationStateHandler({ context: 'search' });
72
+ const url = new URL(window.location.href);
73
+ url.search = '?not[]=year:2018';
74
+ window.history.replaceState({ path: url.href }, '', url.href);
75
+ const restorationState = handler.getRestorationState();
76
+ expect(restorationState.selectedFacets.year['2018'].state).to.equal('hidden');
77
+ });
78
+ it('should restore multiple selected/negative facets from URL', async () => {
79
+ const handler = new RestorationStateHandler({ context: 'search' });
80
+ const url = new URL(window.location.href);
81
+ url.search =
82
+ '?and[]=collection:"foo"&and[]=collection:"bar"&not[]=collection:"baz"&not[]=collection:"boop"';
83
+ window.history.replaceState({ path: url.href }, '', url.href);
84
+ const restorationState = handler.getRestorationState();
85
+ expect(restorationState.selectedFacets.collection.foo.state).to.equal('selected');
86
+ expect(restorationState.selectedFacets.collection.bar.state).to.equal('selected');
87
+ expect(restorationState.selectedFacets.collection.baz.state).to.equal('hidden');
88
+ expect(restorationState.selectedFacets.collection.boop.state).to.equal('hidden');
89
+ });
90
+ it('negative facets take precedence if both present in URL', async () => {
91
+ const handler = new RestorationStateHandler({ context: 'search' });
92
+ const url = new URL(window.location.href);
93
+ url.search = '?and[]=collection:"foo"&not[]=collection:"foo"';
94
+ window.history.replaceState({ path: url.href }, '', url.href);
95
+ const restorationState = handler.getRestorationState();
96
+ expect(restorationState.selectedFacets.collection.foo.state).to.equal('hidden');
97
+ });
98
+ it('should restore sort from URL (space format)', async () => {
99
+ const handler = new RestorationStateHandler({ context: 'search' });
100
+ const url = new URL(window.location.href);
101
+ url.search = '?sort=date+desc';
102
+ window.history.replaceState({ path: url.href }, '', url.href);
103
+ const restorationState = handler.getRestorationState();
104
+ expect(restorationState.selectedSort).to.equal('date');
105
+ expect(restorationState.sortDirection).to.equal('desc');
106
+ });
107
+ it('should restore sort from URL (prefix format, desc)', async () => {
108
+ const handler = new RestorationStateHandler({ context: 'search' });
109
+ const url = new URL(window.location.href);
110
+ url.search = '?sort=-date';
111
+ window.history.replaceState({ path: url.href }, '', url.href);
112
+ const restorationState = handler.getRestorationState();
113
+ expect(restorationState.selectedSort).to.equal('date');
114
+ expect(restorationState.sortDirection).to.equal('desc');
115
+ });
116
+ it('should restore sort from URL (prefix format, asc)', async () => {
117
+ const handler = new RestorationStateHandler({ context: 'search' });
118
+ const url = new URL(window.location.href);
119
+ url.search = '?sort=date';
120
+ window.history.replaceState({ path: url.href }, '', url.href);
121
+ const restorationState = handler.getRestorationState();
122
+ expect(restorationState.selectedSort).to.equal('date');
123
+ expect(restorationState.sortDirection).to.equal('asc');
124
+ });
125
+ });
126
126
  //# sourceMappingURL=restoration-state-handler.test.js.map
@@ -1 +1 @@
1
- import '../../src/sort-filter-bar/alpha-bar-tooltip';
1
+ import '../../src/sort-filter-bar/alpha-bar-tooltip';
@@ -1,13 +1,13 @@
1
- import { expect, fixture } from '@open-wc/testing';
2
- import { html } from 'lit';
3
- import '../../src/sort-filter-bar/alpha-bar-tooltip';
4
- describe('Alphabet Filter Bar Tooltips', () => {
5
- it('renders component', async () => {
6
- var _a, _b;
7
- const el = await fixture(html `<alpha-bar-tooltip .numResults=${42}></alpha-bar-tooltip>`);
8
- // Should render the number of results
9
- const tooltipText = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#tooltip-text');
10
- expect((_b = tooltipText === null || tooltipText === void 0 ? void 0 : tooltipText.textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('42 results');
11
- });
12
- });
1
+ import { expect, fixture } from '@open-wc/testing';
2
+ import { html } from 'lit';
3
+ import '../../src/sort-filter-bar/alpha-bar-tooltip';
4
+ describe('Alphabet Filter Bar Tooltips', () => {
5
+ it('renders component', async () => {
6
+ var _a, _b;
7
+ const el = await fixture(html `<alpha-bar-tooltip .numResults=${42}></alpha-bar-tooltip>`);
8
+ // Should render the number of results
9
+ const tooltipText = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('#tooltip-text');
10
+ expect((_b = tooltipText === null || tooltipText === void 0 ? void 0 : tooltipText.textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('42 results');
11
+ });
12
+ });
13
13
  //# sourceMappingURL=alpha-bar-tooltip.test.js.map
@@ -1 +1 @@
1
- import '../../src/sort-filter-bar/alpha-bar';
1
+ import '../../src/sort-filter-bar/alpha-bar';
@@ -1,74 +1,74 @@
1
- import { aTimeout, expect, fixture } from '@open-wc/testing';
2
- import { html } from 'lit';
3
- import '../../src/sort-filter-bar/alpha-bar';
4
- describe('Alphabetical Filter Bar', () => {
5
- it('renders component', async () => {
6
- var _a;
7
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
8
- // Should have all the letters
9
- const letters = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li');
10
- expect(letters === null || letters === void 0 ? void 0 : letters.length).to.equal(26);
11
- });
12
- it('renders letters with items as links', async () => {
13
- var _a, _b, _c;
14
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
15
- el.letterCounts = { U: 10, X: 10 };
16
- await el.updateComplete;
17
- // Should have exactly two letter links
18
- const letterLinks = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li > a[href]');
19
- expect(letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.length).to.equal(2);
20
- expect((_b = letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.item(0).textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('U');
21
- expect((_c = letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.item(1).textContent) === null || _c === void 0 ? void 0 : _c.trim()).to.equal('X');
22
- });
23
- it('renders letters without items as uninteractive text', async () => {
24
- var _a, _b, _c;
25
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
26
- el.letterCounts = { U: 10, X: 10 };
27
- await el.updateComplete;
28
- // All but the two letters above should just be inert spans, not links
29
- const letterNonLinks = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li > span');
30
- expect(letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.length).to.equal(24);
31
- expect((_b = letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.item(0).textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('A');
32
- expect((_c = letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.item(23).textContent) === null || _c === void 0 ? void 0 : _c.trim()).to.equal('Z');
33
- });
34
- it('renders the selected letter with the "selected" class', async () => {
35
- var _a, _b;
36
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
37
- el.selectedLetter = 'B';
38
- await el.updateComplete;
39
- const selectedLetter = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('li.selected');
40
- expect(selectedLetter).to.exist;
41
- expect((_b = selectedLetter === null || selectedLetter === void 0 ? void 0 : selectedLetter.textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('B');
42
- });
43
- it('renders a tooltip when hovered and removes it when un-hovered', async () => {
44
- var _a, _b, _c;
45
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
46
- const firstLetter = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('li');
47
- expect(firstLetter).to.exist;
48
- firstLetter.dispatchEvent(new MouseEvent('mousemove'));
49
- await el.updateComplete;
50
- const tooltip = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('alpha-bar-tooltip');
51
- expect(tooltip).to.exist;
52
- // Should be positioned after next tick
53
- await aTimeout(0);
54
- expect(tooltip.style.left).to.exist;
55
- firstLetter.dispatchEvent(new MouseEvent('mouseleave'));
56
- await el.updateComplete;
57
- expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('alpha-bar-tooltip')).not.to.exist;
58
- });
59
- it('positions tooltip correctly when it would overflow viewport', async () => {
60
- var _a, _b;
61
- const el = await fixture(html `<alpha-bar></alpha-bar>`);
62
- const letters = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li');
63
- const lastLetter = letters === null || letters === void 0 ? void 0 : letters.item(letters.length - 1);
64
- expect(lastLetter).to.exist;
65
- lastLetter.dispatchEvent(new MouseEvent('mousemove'));
66
- await el.updateComplete;
67
- const tooltip = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('alpha-bar-tooltip');
68
- expect(tooltip).to.exist;
69
- // Should be positioned after next tick, but not off-screen
70
- await aTimeout(0);
71
- expect(tooltip.getBoundingClientRect().right).to.be.lessThan(window.innerWidth);
72
- });
73
- });
1
+ import { aTimeout, expect, fixture } from '@open-wc/testing';
2
+ import { html } from 'lit';
3
+ import '../../src/sort-filter-bar/alpha-bar';
4
+ describe('Alphabetical Filter Bar', () => {
5
+ it('renders component', async () => {
6
+ var _a;
7
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
8
+ // Should have all the letters
9
+ const letters = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li');
10
+ expect(letters === null || letters === void 0 ? void 0 : letters.length).to.equal(26);
11
+ });
12
+ it('renders letters with items as links', async () => {
13
+ var _a, _b, _c;
14
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
15
+ el.letterCounts = { U: 10, X: 10 };
16
+ await el.updateComplete;
17
+ // Should have exactly two letter links
18
+ const letterLinks = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li > a[href]');
19
+ expect(letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.length).to.equal(2);
20
+ expect((_b = letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.item(0).textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('U');
21
+ expect((_c = letterLinks === null || letterLinks === void 0 ? void 0 : letterLinks.item(1).textContent) === null || _c === void 0 ? void 0 : _c.trim()).to.equal('X');
22
+ });
23
+ it('renders letters without items as uninteractive text', async () => {
24
+ var _a, _b, _c;
25
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
26
+ el.letterCounts = { U: 10, X: 10 };
27
+ await el.updateComplete;
28
+ // All but the two letters above should just be inert spans, not links
29
+ const letterNonLinks = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li > span');
30
+ expect(letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.length).to.equal(24);
31
+ expect((_b = letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.item(0).textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('A');
32
+ expect((_c = letterNonLinks === null || letterNonLinks === void 0 ? void 0 : letterNonLinks.item(23).textContent) === null || _c === void 0 ? void 0 : _c.trim()).to.equal('Z');
33
+ });
34
+ it('renders the selected letter with the "selected" class', async () => {
35
+ var _a, _b;
36
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
37
+ el.selectedLetter = 'B';
38
+ await el.updateComplete;
39
+ const selectedLetter = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('li.selected');
40
+ expect(selectedLetter).to.exist;
41
+ expect((_b = selectedLetter === null || selectedLetter === void 0 ? void 0 : selectedLetter.textContent) === null || _b === void 0 ? void 0 : _b.trim()).to.equal('B');
42
+ });
43
+ it('renders a tooltip when hovered and removes it when un-hovered', async () => {
44
+ var _a, _b, _c;
45
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
46
+ const firstLetter = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('li');
47
+ expect(firstLetter).to.exist;
48
+ firstLetter.dispatchEvent(new MouseEvent('mousemove'));
49
+ await el.updateComplete;
50
+ const tooltip = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('alpha-bar-tooltip');
51
+ expect(tooltip).to.exist;
52
+ // Should be positioned after next tick
53
+ await aTimeout(0);
54
+ expect(tooltip.style.left).to.exist;
55
+ firstLetter.dispatchEvent(new MouseEvent('mouseleave'));
56
+ await el.updateComplete;
57
+ expect((_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('alpha-bar-tooltip')).not.to.exist;
58
+ });
59
+ it('positions tooltip correctly when it would overflow viewport', async () => {
60
+ var _a, _b;
61
+ const el = await fixture(html `<alpha-bar></alpha-bar>`);
62
+ const letters = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('li');
63
+ const lastLetter = letters === null || letters === void 0 ? void 0 : letters.item(letters.length - 1);
64
+ expect(lastLetter).to.exist;
65
+ lastLetter.dispatchEvent(new MouseEvent('mousemove'));
66
+ await el.updateComplete;
67
+ const tooltip = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('alpha-bar-tooltip');
68
+ expect(tooltip).to.exist;
69
+ // Should be positioned after next tick, but not off-screen
70
+ await aTimeout(0);
71
+ expect(tooltip.getBoundingClientRect().right).to.be.lessThan(window.innerWidth);
72
+ });
73
+ });
74
74
  //# sourceMappingURL=alpha-bar.test.js.map
@@ -1 +1 @@
1
- import '../../src/sort-filter-bar/sort-filter-bar';
1
+ import '../../src/sort-filter-bar/sort-filter-bar';