@internetarchive/collection-browser 2.1.8-alpha2 → 2.1.9-alpha.0

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