@internetarchive/collection-browser 2.5.2 → 2.6.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 (308) hide show
  1. package/.editorconfig +29 -29
  2. package/.husky/pre-commit +4 -4
  3. package/LICENSE +661 -661
  4. package/README.md +83 -83
  5. package/dist/index.d.ts +12 -12
  6. package/dist/index.js +12 -12
  7. package/dist/src/app-root.d.ts +91 -91
  8. package/dist/src/app-root.js +487 -487
  9. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  10. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  11. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  12. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  13. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  14. package/dist/src/assets/img/icons/chevron.js +2 -2
  15. package/dist/src/assets/img/icons/contract.d.ts +2 -2
  16. package/dist/src/assets/img/icons/contract.js +2 -2
  17. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  18. package/dist/src/assets/img/icons/empty-query.js +2 -2
  19. package/dist/src/assets/img/icons/expand.d.ts +2 -2
  20. package/dist/src/assets/img/icons/expand.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/favorite-unfilled.d.ts +1 -1
  28. package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
  29. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  30. package/dist/src/assets/img/icons/login-required.js +2 -2
  31. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  32. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  33. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  34. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  35. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  36. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  37. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  38. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  39. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  40. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  41. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  42. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  43. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  44. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  45. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  46. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  47. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
  48. package/dist/src/assets/img/icons/mediatype/search.js +2 -2
  49. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  50. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  51. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  52. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  53. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  54. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  55. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  56. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  57. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  58. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  59. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  60. package/dist/src/assets/img/icons/null-result.js +2 -2
  61. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  62. package/dist/src/assets/img/icons/restricted.js +2 -2
  63. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  64. package/dist/src/assets/img/icons/reviews.js +2 -2
  65. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  66. package/dist/src/assets/img/icons/upload.js +2 -2
  67. package/dist/src/assets/img/icons/views.d.ts +1 -1
  68. package/dist/src/assets/img/icons/views.js +2 -2
  69. package/dist/src/circular-activity-indicator.d.ts +5 -5
  70. package/dist/src/circular-activity-indicator.js +17 -17
  71. package/dist/src/collection-browser.d.ts +564 -564
  72. package/dist/src/collection-browser.js +1579 -1569
  73. package/dist/src/collection-browser.js.map +1 -1
  74. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  75. package/dist/src/collection-facets/facet-row.js +120 -117
  76. package/dist/src/collection-facets/facet-row.js.map +1 -1
  77. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  78. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  79. package/dist/src/collection-facets/facets-template.d.ts +13 -13
  80. package/dist/src/collection-facets/facets-template.js +45 -43
  81. package/dist/src/collection-facets/facets-template.js.map +1 -1
  82. package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
  83. package/dist/src/collection-facets/more-facets-content.js +407 -407
  84. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  85. package/dist/src/collection-facets/more-facets-pagination.js +196 -196
  86. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  87. package/dist/src/collection-facets/toggle-switch.js +94 -94
  88. package/dist/src/collection-facets.d.ts +103 -103
  89. package/dist/src/collection-facets.js +534 -516
  90. package/dist/src/collection-facets.js.map +1 -1
  91. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
  92. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  93. package/dist/src/data-source/collection-browser-data-source.d.ts +378 -378
  94. package/dist/src/data-source/collection-browser-data-source.js +984 -985
  95. package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
  96. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  97. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  98. package/dist/src/data-source/models.d.ts +28 -28
  99. package/dist/src/data-source/models.js +8 -8
  100. package/dist/src/empty-placeholder.d.ts +23 -23
  101. package/dist/src/empty-placeholder.js +92 -79
  102. package/dist/src/empty-placeholder.js.map +1 -1
  103. package/dist/src/expanded-date-picker.d.ts +43 -43
  104. package/dist/src/expanded-date-picker.js +109 -109
  105. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  106. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  107. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  108. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  109. package/dist/src/manage/manage-bar.d.ts +30 -30
  110. package/dist/src/manage/manage-bar.js +61 -61
  111. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  112. package/dist/src/mediatype/mediatype-config.js +91 -91
  113. package/dist/src/models.d.ts +211 -209
  114. package/dist/src/models.js +381 -381
  115. package/dist/src/models.js.map +1 -1
  116. package/dist/src/restoration-state-handler.d.ts +70 -70
  117. package/dist/src/restoration-state-handler.js +357 -357
  118. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  119. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  120. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  121. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  122. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  123. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  124. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  125. package/dist/src/sort-filter-bar/img/list.js +2 -2
  126. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  127. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  128. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  129. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  130. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  131. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  132. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  133. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  134. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  135. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  136. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -222
  137. package/dist/src/sort-filter-bar/sort-filter-bar.js +700 -696
  138. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  139. package/dist/src/styles/ia-button.d.ts +2 -2
  140. package/dist/src/styles/ia-button.js +16 -16
  141. package/dist/src/styles/item-image-styles.d.ts +8 -8
  142. package/dist/src/styles/item-image-styles.js +9 -9
  143. package/dist/src/styles/sr-only.d.ts +1 -1
  144. package/dist/src/styles/sr-only.js +2 -2
  145. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  146. package/dist/src/tiles/base-tile-component.js +63 -63
  147. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  148. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  149. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  150. package/dist/src/tiles/grid/account-tile.js +72 -72
  151. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  152. package/dist/src/tiles/grid/collection-tile.js +80 -80
  153. package/dist/src/tiles/grid/item-tile.d.ts +30 -30
  154. package/dist/src/tiles/grid/item-tile.js +149 -149
  155. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  156. package/dist/src/tiles/grid/search-tile.js +51 -51
  157. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  158. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  159. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  160. package/dist/src/tiles/grid/tile-stats.js +53 -53
  161. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  162. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  163. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
  164. package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
  165. package/dist/src/tiles/image-block.d.ts +17 -17
  166. package/dist/src/tiles/image-block.js +73 -73
  167. package/dist/src/tiles/item-image.d.ts +39 -39
  168. package/dist/src/tiles/item-image.js +154 -154
  169. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  170. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  171. package/dist/src/tiles/list/tile-list-compact.d.ts +15 -15
  172. package/dist/src/tiles/list/tile-list-compact.js +114 -114
  173. package/dist/src/tiles/list/tile-list.d.ts +50 -50
  174. package/dist/src/tiles/list/tile-list.js +315 -315
  175. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  176. package/dist/src/tiles/mediatype-icon.js +47 -47
  177. package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
  178. package/dist/src/tiles/overlay/icon-overlay.js +40 -40
  179. package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
  180. package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
  181. package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
  182. package/dist/src/tiles/overlay/text-overlay.js +42 -42
  183. package/dist/src/tiles/review-block.d.ts +12 -12
  184. package/dist/src/tiles/review-block.js +56 -56
  185. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  186. package/dist/src/tiles/text-snippet-block.js +73 -73
  187. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  188. package/dist/src/tiles/tile-dispatcher.js +229 -229
  189. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  190. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  191. package/dist/src/utils/analytics-events.d.ts +28 -28
  192. package/dist/src/utils/analytics-events.js +30 -30
  193. package/dist/src/utils/array-equals.d.ts +4 -4
  194. package/dist/src/utils/array-equals.js +10 -10
  195. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  196. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  197. package/dist/src/utils/facet-utils.d.ts +83 -83
  198. package/dist/src/utils/facet-utils.js +145 -145
  199. package/dist/src/utils/format-count.d.ts +7 -7
  200. package/dist/src/utils/format-count.js +76 -76
  201. package/dist/src/utils/format-date.d.ts +2 -2
  202. package/dist/src/utils/format-date.js +25 -25
  203. package/dist/src/utils/format-unit-size.d.ts +2 -2
  204. package/dist/src/utils/format-unit-size.js +33 -33
  205. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  206. package/dist/src/utils/local-date-from-utc.js +15 -15
  207. package/dist/src/utils/log.d.ts +7 -7
  208. package/dist/src/utils/log.js +15 -15
  209. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  210. package/dist/src/utils/resolve-mediatype.js +23 -23
  211. package/dist/src/utils/sha1.d.ts +2 -2
  212. package/dist/src/utils/sha1.js +8 -8
  213. package/dist/test/collection-browser.test.d.ts +1 -1
  214. package/dist/test/collection-browser.test.js +1294 -1294
  215. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  216. package/dist/test/collection-facets/facet-row.test.js +227 -227
  217. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  218. package/dist/test/collection-facets/facets-template.test.js +91 -91
  219. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  220. package/dist/test/collection-facets/more-facets-content.test.js +141 -141
  221. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  222. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  223. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  224. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  225. package/dist/test/collection-facets.test.d.ts +2 -2
  226. package/dist/test/collection-facets.test.js +652 -652
  227. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  228. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  229. package/dist/test/empty-placeholder.test.d.ts +1 -1
  230. package/dist/test/empty-placeholder.test.js +63 -63
  231. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  232. package/dist/test/expanded-date-picker.test.js +95 -95
  233. package/dist/test/icon-overlay.test.d.ts +1 -1
  234. package/dist/test/icon-overlay.test.js +24 -24
  235. package/dist/test/image-block.test.d.ts +1 -1
  236. package/dist/test/image-block.test.js +48 -48
  237. package/dist/test/item-image.test.d.ts +1 -1
  238. package/dist/test/item-image.test.js +85 -85
  239. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  240. package/dist/test/manage/manage-bar.test.js +81 -81
  241. package/dist/test/mediatype-config.test.d.ts +1 -1
  242. package/dist/test/mediatype-config.test.js +16 -16
  243. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  244. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  245. package/dist/test/mocks/mock-search-responses.d.ts +25 -25
  246. package/dist/test/mocks/mock-search-responses.js +942 -942
  247. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  248. package/dist/test/mocks/mock-search-service.js +54 -54
  249. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  250. package/dist/test/restoration-state-handler.test.js +270 -270
  251. package/dist/test/review-block.test.d.ts +1 -1
  252. package/dist/test/review-block.test.js +44 -44
  253. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  254. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  255. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  256. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  257. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  258. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  259. package/dist/test/text-overlay.test.d.ts +1 -1
  260. package/dist/test/text-overlay.test.js +48 -48
  261. package/dist/test/text-snippet-block.test.d.ts +1 -1
  262. package/dist/test/text-snippet-block.test.js +57 -57
  263. package/dist/test/tile-stats.test.d.ts +1 -1
  264. package/dist/test/tile-stats.test.js +81 -81
  265. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  266. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  267. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  268. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  269. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  270. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  271. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  272. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  273. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  274. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  275. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  276. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  277. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  278. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  279. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  280. package/dist/test/tiles/list/tile-list.test.js +297 -297
  281. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  282. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  283. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  284. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  285. package/dist/test/utils/array-equals.test.d.ts +1 -1
  286. package/dist/test/utils/array-equals.test.js +26 -26
  287. package/dist/test/utils/format-count.test.d.ts +1 -1
  288. package/dist/test/utils/format-count.test.js +23 -23
  289. package/dist/test/utils/format-date.test.d.ts +1 -1
  290. package/dist/test/utils/format-date.test.js +17 -17
  291. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  292. package/dist/test/utils/format-unit-size.test.js +17 -17
  293. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  294. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  295. package/local.archive.org.cert +86 -86
  296. package/local.archive.org.key +27 -27
  297. package/package.json +1 -1
  298. package/renovate.json +6 -6
  299. package/src/collection-browser.ts +26 -10
  300. package/src/collection-facets/facet-row.ts +3 -0
  301. package/src/collection-facets/facets-template.ts +3 -1
  302. package/src/collection-facets.ts +20 -2
  303. package/src/data-source/collection-browser-data-source.ts +1 -5
  304. package/src/empty-placeholder.ts +18 -5
  305. package/src/models.ts +8 -1
  306. package/src/sort-filter-bar/sort-filter-bar.ts +4 -0
  307. package/web-dev-server.config.mjs +30 -30
  308. package/web-test-runner.config.mjs +41 -41
@@ -1,378 +1,378 @@
1
- import type { ReactiveControllerHost } from 'lit';
2
- import { AccountExtraInfo, Aggregation, CollectionExtraInfo, FilterMap, PageElementMap, SearchParams, SearchResponseSessionContext } from '@internetarchive/search-service';
3
- import { type PrefixFilterType, TileModel, PrefixFilterCounts, RequestKind } from '../models';
4
- import { type PageSpecifierParams } from './models';
5
- import type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';
6
- import type { CollectionBrowserSearchInterface } from './collection-browser-query-state';
7
- export declare class CollectionBrowserDataSource implements CollectionBrowserDataSourceInterface {
8
- /** The host element to which this controller should attach listeners */
9
- private readonly host;
10
- /** Default size of result pages */
11
- private pageSize;
12
- /**
13
- * All pages of tile models that have been fetched so far, indexed by their page
14
- * number (with the first being page 1).
15
- */
16
- private pages;
17
- /**
18
- * Tile offset to apply when looking up tiles in the pages, in order to maintain
19
- * page alignment after tiles are removed.
20
- */
21
- private offset;
22
- /**
23
- * Total number of tile models stored in this data source's pages
24
- */
25
- private numTileModels;
26
- /**
27
- * A set of fetch IDs that are valid for the current query state
28
- */
29
- private fetchesInProgress;
30
- /**
31
- * A record of the query key used for the last search.
32
- * If this changes, we need to load new results.
33
- */
34
- private previousQueryKey;
35
- /**
36
- * Whether the initial page of search results for the current query state
37
- * is presently being fetched.
38
- */
39
- private searchResultsLoading;
40
- /**
41
- * Whether the facets (aggregations) for the current query state are
42
- * presently being fetched.
43
- */
44
- private facetsLoading;
45
- /**
46
- * Whether the facets are actually visible -- if not, then we can delay any facet
47
- * fetches until they become visible.
48
- */
49
- private facetsReadyToLoad;
50
- /**
51
- * Whether further query changes should be ignored and not trigger fetches
52
- */
53
- private suppressFetches;
54
- /**
55
- * @inheritdoc
56
- */
57
- totalResults: number;
58
- /**
59
- * @inheritdoc
60
- */
61
- endOfDataReached: boolean;
62
- /**
63
- * @inheritdoc
64
- */
65
- queryInitialized: boolean;
66
- /**
67
- * @inheritdoc
68
- */
69
- aggregations?: Record<string, Aggregation>;
70
- /**
71
- * @inheritdoc
72
- */
73
- yearHistogramAggregation?: Aggregation;
74
- /**
75
- * @inheritdoc
76
- */
77
- collectionTitles: Map<string, string>;
78
- /**
79
- * @inheritdoc
80
- */
81
- collectionExtraInfo?: CollectionExtraInfo;
82
- /**
83
- * @inheritdoc
84
- */
85
- accountExtraInfo?: AccountExtraInfo;
86
- /**
87
- * @inheritdoc
88
- */
89
- sessionContext?: SearchResponseSessionContext;
90
- /**
91
- * @inheritdoc
92
- */
93
- pageElements?: PageElementMap;
94
- /**
95
- * @inheritdoc
96
- */
97
- parentCollections?: string[];
98
- /**
99
- * @inheritdoc
100
- */
101
- prefixFilterCountMap: Partial<Record<PrefixFilterType, PrefixFilterCounts>>;
102
- /**
103
- * @inheritdoc
104
- */
105
- queryErrorMessage?: string;
106
- /**
107
- * Internal property to store the `resolve` function for the most recent
108
- * `initialSearchComplete` promise, allowing us to resolve it at the appropriate time.
109
- */
110
- private _initialSearchCompleteResolver;
111
- /**
112
- * Internal property to store the private value backing the `initialSearchComplete` getter.
113
- */
114
- private _initialSearchCompletePromise;
115
- /**
116
- * @inheritdoc
117
- */
118
- get initialSearchComplete(): Promise<boolean>;
119
- constructor(
120
- /** The host element to which this controller should attach listeners */
121
- host: ReactiveControllerHost & CollectionBrowserSearchInterface,
122
- /** Default size of result pages */
123
- pageSize?: number);
124
- hostConnected(): void;
125
- hostUpdate(): void;
126
- /**
127
- * Returns whether this data source is the one currently installed on the host component.
128
- */
129
- private get activeOnHost();
130
- /**
131
- * @inheritdoc
132
- */
133
- get size(): number;
134
- /**
135
- * @inheritdoc
136
- */
137
- reset(): void;
138
- /**
139
- * @inheritdoc
140
- */
141
- addPage(pageNum: number, pageTiles: TileModel[]): void;
142
- /**
143
- * @inheritdoc
144
- */
145
- addMultiplePages(firstPageNum: number, tiles: TileModel[]): void;
146
- /**
147
- * @inheritdoc
148
- */
149
- getPage(pageNum: number): TileModel[];
150
- /**
151
- * @inheritdoc
152
- */
153
- getAllPages(): Record<string, TileModel[]>;
154
- /**
155
- * @inheritdoc
156
- */
157
- hasPage(pageNum: number): boolean;
158
- /**
159
- * @inheritdoc
160
- */
161
- getTileModelAt(index: number): TileModel | undefined;
162
- /**
163
- * @inheritdoc
164
- */
165
- indexOf(tile: TileModel): number;
166
- /**
167
- * @inheritdoc
168
- */
169
- getPageSize(): number;
170
- /**
171
- * @inheritdoc
172
- */
173
- setPageSize(pageSize: number): void;
174
- /**
175
- * @inheritdoc
176
- */
177
- setTotalResultCount(count: number): void;
178
- /**
179
- * @inheritdoc
180
- */
181
- setFetchesSuppressed(suppressed: boolean): void;
182
- /**
183
- * @inheritdoc
184
- */
185
- handleQueryChange(): Promise<void>;
186
- /**
187
- * @inheritdoc
188
- */
189
- handleFacetReadinessChange(ready: boolean): Promise<void>;
190
- /**
191
- * Whether the data source & its host are in a state where a facet request should be fired.
192
- * (i.e., they aren't suppressed or already loading, etc.)
193
- */
194
- private get canFetchFacets();
195
- /**
196
- * @inheritdoc
197
- */
198
- map(callback: (model: TileModel, index: number, array: TileModel[]) => TileModel): void;
199
- /**
200
- * @inheritdoc
201
- */
202
- checkAllTiles: () => void;
203
- /**
204
- * @inheritdoc
205
- */
206
- uncheckAllTiles: () => void;
207
- /**
208
- * @inheritdoc
209
- */
210
- removeCheckedTiles: () => void;
211
- /**
212
- * @inheritdoc
213
- */
214
- get checkedTileModels(): TileModel[];
215
- /**
216
- * @inheritdoc
217
- */
218
- get uncheckedTileModels(): TileModel[];
219
- /**
220
- * Returns a flattened, filtered array of all the tile models in the data source
221
- * for which the given predicate returns a truthy value.
222
- *
223
- * @param predicate A callback function to apply on each tile model, as with Array.filter
224
- * @returns A filtered array of tile models satisfying the predicate
225
- */
226
- private getFilteredTileModels;
227
- /**
228
- * @inheritdoc
229
- */
230
- get canPerformSearch(): boolean;
231
- /**
232
- * Sets the state for whether the initial set of search results for the
233
- * current query is loading
234
- */
235
- private setSearchResultsLoading;
236
- /**
237
- * Sets the state for whether the facets for a query is loading
238
- */
239
- private setFacetsLoading;
240
- /**
241
- * Requests that the host perform an update, provided this data
242
- * source is actively installed on it.
243
- */
244
- private requestHostUpdate;
245
- /**
246
- * Requests that the host refresh its visible tiles, provided this
247
- * data source is actively installed on it.
248
- */
249
- private refreshVisibleResults;
250
- /**
251
- * The query key is a string that uniquely identifies the current search.
252
- * It consists of:
253
- * - The current base query
254
- * - The current collection/profile target & page element
255
- * - The current search type
256
- * - Any currently-applied facets
257
- * - Any currently-applied date range
258
- * - Any currently-applied prefix filters
259
- * - The current sort options
260
- *
261
- * This lets us internally keep track of queries so we don't persist data that's
262
- * no longer relevant. Not meant to be human-readable.
263
- */
264
- get pageFetchQueryKey(): string;
265
- /**
266
- * Similar to `pageFetchQueryKey` above, but excludes sort fields since they
267
- * are not relevant in determining aggregation queries.
268
- */
269
- get facetFetchQueryKey(): string;
270
- /**
271
- * Constructs a search service FilterMap object from the combination of
272
- * all the currently-applied filters. This includes any facets, letter
273
- * filters, and date range.
274
- */
275
- get filterMap(): FilterMap;
276
- /**
277
- * Produces a compact unique ID for a search request that can help with debugging
278
- * on the backend by making related requests easier to trace through different services.
279
- * (e.g., tying the hits/aggregations requests for the same page back to a single hash).
280
- *
281
- * @param params The search service parameters for the request
282
- * @param kind The kind of request (hits-only, aggregations-only, or both)
283
- * @returns A Promise resolving to the uid to apply to the request
284
- */
285
- requestUID(params: SearchParams, kind: RequestKind): Promise<string>;
286
- /**
287
- * @inheritdoc
288
- */
289
- get pageSpecifierParams(): PageSpecifierParams | null;
290
- /**
291
- * The full query, including year facets and date range clauses
292
- */
293
- private get fullQuery();
294
- /**
295
- * Generates a query string representing the current set of applied facets
296
- *
297
- * Example: `mediatype:("collection" OR "audio" OR -"etree") AND year:("2000" OR "2001")`
298
- */
299
- private get facetQuery();
300
- private get dateRangeQueryClause();
301
- private get sortFilterQueries();
302
- /**
303
- * Returns a query clause identifying the currently selected title filter,
304
- * e.g., `firstTitle:X`.
305
- */
306
- private get titleQuery();
307
- /**
308
- * Returns a query clause identifying the currently selected creator filter,
309
- * e.g., `firstCreator:X`.
310
- */
311
- private get creatorQuery();
312
- /**
313
- * Builds an OR-joined facet clause for the given facet name and values.
314
- *
315
- * E.g., for name `subject` and values
316
- * `{ foo: { state: 'selected' }, bar: { state: 'hidden' } }`
317
- * this will produce the clause
318
- * `subject:("foo" OR -"bar")`.
319
- *
320
- * @param facetName The facet type (e.g., 'collection')
321
- * @param facetValues The facet buckets, mapped by their keys
322
- */
323
- private buildFacetClause;
324
- /**
325
- * Handles some special pre-request normalization steps for certain facet types
326
- * that require them.
327
- *
328
- * @param facetName The name of the facet type (e.g., 'language')
329
- * @param facetValues An array of values for that facet type
330
- */
331
- private prepareFacetForFetch;
332
- /**
333
- * Takes an array of facet clauses, and combines them into a
334
- * full AND-joined facet query string. Empty clauses are ignored.
335
- */
336
- private joinFacetClauses;
337
- /**
338
- * Fires a backend request to fetch a set of aggregations (representing UI facets) for
339
- * the current search state.
340
- */
341
- private fetchFacets;
342
- /**
343
- * Performs the initial page fetch(es) for the current search state.
344
- */
345
- private doInitialPageFetch;
346
- /**
347
- * Fetches one or more pages of results and updates the data source.
348
- *
349
- * @param pageNumber The page number to fetch
350
- * @param numInitialPages If this is an initial page fetch (`pageNumber = 1`),
351
- * specifies how many pages to batch together in one request. Ignored
352
- * if `pageNumber != 1`, defaulting to a single page.
353
- */
354
- fetchPage(pageNumber: number, numInitialPages?: number): Promise<void>;
355
- /**
356
- * Update the datasource from the fetch response
357
- *
358
- * @param pageNumber
359
- * @param results
360
- */
361
- private addFetchedResultsToDataSource;
362
- /**
363
- * Fetches the aggregation buckets for the given prefix filter type.
364
- */
365
- private fetchPrefixFilterBuckets;
366
- /**
367
- * Fetches and caches the prefix filter counts for the given filter type.
368
- */
369
- updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void>;
370
- /**
371
- * @inheritdoc
372
- */
373
- updatePrefixFiltersForCurrentSort(): Promise<void>;
374
- /**
375
- * @inheritdoc
376
- */
377
- refreshLetterCounts(): void;
378
- }
1
+ import type { ReactiveControllerHost } from 'lit';
2
+ import { AccountExtraInfo, Aggregation, CollectionExtraInfo, FilterMap, PageElementMap, SearchParams, SearchResponseSessionContext } from '@internetarchive/search-service';
3
+ import { type PrefixFilterType, TileModel, PrefixFilterCounts, RequestKind } from '../models';
4
+ import { type PageSpecifierParams } from './models';
5
+ import type { CollectionBrowserDataSourceInterface } from './collection-browser-data-source-interface';
6
+ import type { CollectionBrowserSearchInterface } from './collection-browser-query-state';
7
+ export declare class CollectionBrowserDataSource implements CollectionBrowserDataSourceInterface {
8
+ /** The host element to which this controller should attach listeners */
9
+ private readonly host;
10
+ /** Default size of result pages */
11
+ private pageSize;
12
+ /**
13
+ * All pages of tile models that have been fetched so far, indexed by their page
14
+ * number (with the first being page 1).
15
+ */
16
+ private pages;
17
+ /**
18
+ * Tile offset to apply when looking up tiles in the pages, in order to maintain
19
+ * page alignment after tiles are removed.
20
+ */
21
+ private offset;
22
+ /**
23
+ * Total number of tile models stored in this data source's pages
24
+ */
25
+ private numTileModels;
26
+ /**
27
+ * A set of fetch IDs that are valid for the current query state
28
+ */
29
+ private fetchesInProgress;
30
+ /**
31
+ * A record of the query key used for the last search.
32
+ * If this changes, we need to load new results.
33
+ */
34
+ private previousQueryKey;
35
+ /**
36
+ * Whether the initial page of search results for the current query state
37
+ * is presently being fetched.
38
+ */
39
+ private searchResultsLoading;
40
+ /**
41
+ * Whether the facets (aggregations) for the current query state are
42
+ * presently being fetched.
43
+ */
44
+ private facetsLoading;
45
+ /**
46
+ * Whether the facets are actually visible -- if not, then we can delay any facet
47
+ * fetches until they become visible.
48
+ */
49
+ private facetsReadyToLoad;
50
+ /**
51
+ * Whether further query changes should be ignored and not trigger fetches
52
+ */
53
+ private suppressFetches;
54
+ /**
55
+ * @inheritdoc
56
+ */
57
+ totalResults: number;
58
+ /**
59
+ * @inheritdoc
60
+ */
61
+ endOfDataReached: boolean;
62
+ /**
63
+ * @inheritdoc
64
+ */
65
+ queryInitialized: boolean;
66
+ /**
67
+ * @inheritdoc
68
+ */
69
+ aggregations?: Record<string, Aggregation>;
70
+ /**
71
+ * @inheritdoc
72
+ */
73
+ yearHistogramAggregation?: Aggregation;
74
+ /**
75
+ * @inheritdoc
76
+ */
77
+ collectionTitles: Map<string, string>;
78
+ /**
79
+ * @inheritdoc
80
+ */
81
+ collectionExtraInfo?: CollectionExtraInfo;
82
+ /**
83
+ * @inheritdoc
84
+ */
85
+ accountExtraInfo?: AccountExtraInfo;
86
+ /**
87
+ * @inheritdoc
88
+ */
89
+ sessionContext?: SearchResponseSessionContext;
90
+ /**
91
+ * @inheritdoc
92
+ */
93
+ pageElements?: PageElementMap;
94
+ /**
95
+ * @inheritdoc
96
+ */
97
+ parentCollections?: string[];
98
+ /**
99
+ * @inheritdoc
100
+ */
101
+ prefixFilterCountMap: Partial<Record<PrefixFilterType, PrefixFilterCounts>>;
102
+ /**
103
+ * @inheritdoc
104
+ */
105
+ queryErrorMessage?: string;
106
+ /**
107
+ * Internal property to store the `resolve` function for the most recent
108
+ * `initialSearchComplete` promise, allowing us to resolve it at the appropriate time.
109
+ */
110
+ private _initialSearchCompleteResolver;
111
+ /**
112
+ * Internal property to store the private value backing the `initialSearchComplete` getter.
113
+ */
114
+ private _initialSearchCompletePromise;
115
+ /**
116
+ * @inheritdoc
117
+ */
118
+ get initialSearchComplete(): Promise<boolean>;
119
+ constructor(
120
+ /** The host element to which this controller should attach listeners */
121
+ host: ReactiveControllerHost & CollectionBrowserSearchInterface,
122
+ /** Default size of result pages */
123
+ pageSize?: number);
124
+ hostConnected(): void;
125
+ hostUpdate(): void;
126
+ /**
127
+ * Returns whether this data source is the one currently installed on the host component.
128
+ */
129
+ private get activeOnHost();
130
+ /**
131
+ * @inheritdoc
132
+ */
133
+ get size(): number;
134
+ /**
135
+ * @inheritdoc
136
+ */
137
+ reset(): void;
138
+ /**
139
+ * @inheritdoc
140
+ */
141
+ addPage(pageNum: number, pageTiles: TileModel[]): void;
142
+ /**
143
+ * @inheritdoc
144
+ */
145
+ addMultiplePages(firstPageNum: number, tiles: TileModel[]): void;
146
+ /**
147
+ * @inheritdoc
148
+ */
149
+ getPage(pageNum: number): TileModel[];
150
+ /**
151
+ * @inheritdoc
152
+ */
153
+ getAllPages(): Record<string, TileModel[]>;
154
+ /**
155
+ * @inheritdoc
156
+ */
157
+ hasPage(pageNum: number): boolean;
158
+ /**
159
+ * @inheritdoc
160
+ */
161
+ getTileModelAt(index: number): TileModel | undefined;
162
+ /**
163
+ * @inheritdoc
164
+ */
165
+ indexOf(tile: TileModel): number;
166
+ /**
167
+ * @inheritdoc
168
+ */
169
+ getPageSize(): number;
170
+ /**
171
+ * @inheritdoc
172
+ */
173
+ setPageSize(pageSize: number): void;
174
+ /**
175
+ * @inheritdoc
176
+ */
177
+ setTotalResultCount(count: number): void;
178
+ /**
179
+ * @inheritdoc
180
+ */
181
+ setFetchesSuppressed(suppressed: boolean): void;
182
+ /**
183
+ * @inheritdoc
184
+ */
185
+ handleQueryChange(): Promise<void>;
186
+ /**
187
+ * @inheritdoc
188
+ */
189
+ handleFacetReadinessChange(ready: boolean): Promise<void>;
190
+ /**
191
+ * Whether the data source & its host are in a state where a facet request should be fired.
192
+ * (i.e., they aren't suppressed or already loading, etc.)
193
+ */
194
+ private get canFetchFacets();
195
+ /**
196
+ * @inheritdoc
197
+ */
198
+ map(callback: (model: TileModel, index: number, array: TileModel[]) => TileModel): void;
199
+ /**
200
+ * @inheritdoc
201
+ */
202
+ checkAllTiles: () => void;
203
+ /**
204
+ * @inheritdoc
205
+ */
206
+ uncheckAllTiles: () => void;
207
+ /**
208
+ * @inheritdoc
209
+ */
210
+ removeCheckedTiles: () => void;
211
+ /**
212
+ * @inheritdoc
213
+ */
214
+ get checkedTileModels(): TileModel[];
215
+ /**
216
+ * @inheritdoc
217
+ */
218
+ get uncheckedTileModels(): TileModel[];
219
+ /**
220
+ * Returns a flattened, filtered array of all the tile models in the data source
221
+ * for which the given predicate returns a truthy value.
222
+ *
223
+ * @param predicate A callback function to apply on each tile model, as with Array.filter
224
+ * @returns A filtered array of tile models satisfying the predicate
225
+ */
226
+ private getFilteredTileModels;
227
+ /**
228
+ * @inheritdoc
229
+ */
230
+ get canPerformSearch(): boolean;
231
+ /**
232
+ * Sets the state for whether the initial set of search results for the
233
+ * current query is loading
234
+ */
235
+ private setSearchResultsLoading;
236
+ /**
237
+ * Sets the state for whether the facets for a query is loading
238
+ */
239
+ private setFacetsLoading;
240
+ /**
241
+ * Requests that the host perform an update, provided this data
242
+ * source is actively installed on it.
243
+ */
244
+ private requestHostUpdate;
245
+ /**
246
+ * Requests that the host refresh its visible tiles, provided this
247
+ * data source is actively installed on it.
248
+ */
249
+ private refreshVisibleResults;
250
+ /**
251
+ * The query key is a string that uniquely identifies the current search.
252
+ * It consists of:
253
+ * - The current base query
254
+ * - The current collection/profile target & page element
255
+ * - The current search type
256
+ * - Any currently-applied facets
257
+ * - Any currently-applied date range
258
+ * - Any currently-applied prefix filters
259
+ * - The current sort options
260
+ *
261
+ * This lets us internally keep track of queries so we don't persist data that's
262
+ * no longer relevant. Not meant to be human-readable.
263
+ */
264
+ get pageFetchQueryKey(): string;
265
+ /**
266
+ * Similar to `pageFetchQueryKey` above, but excludes sort fields since they
267
+ * are not relevant in determining aggregation queries.
268
+ */
269
+ get facetFetchQueryKey(): string;
270
+ /**
271
+ * Constructs a search service FilterMap object from the combination of
272
+ * all the currently-applied filters. This includes any facets, letter
273
+ * filters, and date range.
274
+ */
275
+ get filterMap(): FilterMap;
276
+ /**
277
+ * Produces a compact unique ID for a search request that can help with debugging
278
+ * on the backend by making related requests easier to trace through different services.
279
+ * (e.g., tying the hits/aggregations requests for the same page back to a single hash).
280
+ *
281
+ * @param params The search service parameters for the request
282
+ * @param kind The kind of request (hits-only, aggregations-only, or both)
283
+ * @returns A Promise resolving to the uid to apply to the request
284
+ */
285
+ requestUID(params: SearchParams, kind: RequestKind): Promise<string>;
286
+ /**
287
+ * @inheritdoc
288
+ */
289
+ get pageSpecifierParams(): PageSpecifierParams | null;
290
+ /**
291
+ * The full query, including year facets and date range clauses
292
+ */
293
+ private get fullQuery();
294
+ /**
295
+ * Generates a query string representing the current set of applied facets
296
+ *
297
+ * Example: `mediatype:("collection" OR "audio" OR -"etree") AND year:("2000" OR "2001")`
298
+ */
299
+ private get facetQuery();
300
+ private get dateRangeQueryClause();
301
+ private get sortFilterQueries();
302
+ /**
303
+ * Returns a query clause identifying the currently selected title filter,
304
+ * e.g., `firstTitle:X`.
305
+ */
306
+ private get titleQuery();
307
+ /**
308
+ * Returns a query clause identifying the currently selected creator filter,
309
+ * e.g., `firstCreator:X`.
310
+ */
311
+ private get creatorQuery();
312
+ /**
313
+ * Builds an OR-joined facet clause for the given facet name and values.
314
+ *
315
+ * E.g., for name `subject` and values
316
+ * `{ foo: { state: 'selected' }, bar: { state: 'hidden' } }`
317
+ * this will produce the clause
318
+ * `subject:("foo" OR -"bar")`.
319
+ *
320
+ * @param facetName The facet type (e.g., 'collection')
321
+ * @param facetValues The facet buckets, mapped by their keys
322
+ */
323
+ private buildFacetClause;
324
+ /**
325
+ * Handles some special pre-request normalization steps for certain facet types
326
+ * that require them.
327
+ *
328
+ * @param facetName The name of the facet type (e.g., 'language')
329
+ * @param facetValues An array of values for that facet type
330
+ */
331
+ private prepareFacetForFetch;
332
+ /**
333
+ * Takes an array of facet clauses, and combines them into a
334
+ * full AND-joined facet query string. Empty clauses are ignored.
335
+ */
336
+ private joinFacetClauses;
337
+ /**
338
+ * Fires a backend request to fetch a set of aggregations (representing UI facets) for
339
+ * the current search state.
340
+ */
341
+ private fetchFacets;
342
+ /**
343
+ * Performs the initial page fetch(es) for the current search state.
344
+ */
345
+ private doInitialPageFetch;
346
+ /**
347
+ * Fetches one or more pages of results and updates the data source.
348
+ *
349
+ * @param pageNumber The page number to fetch
350
+ * @param numInitialPages If this is an initial page fetch (`pageNumber = 1`),
351
+ * specifies how many pages to batch together in one request. Ignored
352
+ * if `pageNumber != 1`, defaulting to a single page.
353
+ */
354
+ fetchPage(pageNumber: number, numInitialPages?: number): Promise<void>;
355
+ /**
356
+ * Update the datasource from the fetch response
357
+ *
358
+ * @param pageNumber
359
+ * @param results
360
+ */
361
+ private addFetchedResultsToDataSource;
362
+ /**
363
+ * Fetches the aggregation buckets for the given prefix filter type.
364
+ */
365
+ private fetchPrefixFilterBuckets;
366
+ /**
367
+ * Fetches and caches the prefix filter counts for the given filter type.
368
+ */
369
+ updatePrefixFilterCounts(filterType: PrefixFilterType): Promise<void>;
370
+ /**
371
+ * @inheritdoc
372
+ */
373
+ updatePrefixFiltersForCurrentSort(): Promise<void>;
374
+ /**
375
+ * @inheritdoc
376
+ */
377
+ refreshLetterCounts(): void;
378
+ }