@internetarchive/collection-browser 2.6.6-alpha.1 → 2.6.6

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 (306) 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 +13 -13
  6. package/dist/index.js +13 -13
  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 +567 -567
  72. package/dist/src/collection-browser.js +1577 -1577
  73. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  74. package/dist/src/collection-facets/facet-row.js +118 -118
  75. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  76. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  77. package/dist/src/collection-facets/facets-template.d.ts +13 -13
  78. package/dist/src/collection-facets/facets-template.js +44 -44
  79. package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
  80. package/dist/src/collection-facets/more-facets-content.js +407 -407
  81. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  82. package/dist/src/collection-facets/more-facets-pagination.js +196 -196
  83. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  84. package/dist/src/collection-facets/toggle-switch.js +94 -94
  85. package/dist/src/collection-facets.d.ts +103 -103
  86. package/dist/src/collection-facets.js +522 -522
  87. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
  88. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  89. package/dist/src/data-source/collection-browser-data-source.d.ts +378 -378
  90. package/dist/src/data-source/collection-browser-data-source.js +984 -984
  91. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  92. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  93. package/dist/src/data-source/models.d.ts +28 -28
  94. package/dist/src/data-source/models.js +8 -8
  95. package/dist/src/empty-placeholder.d.ts +23 -23
  96. package/dist/src/empty-placeholder.js +79 -79
  97. package/dist/src/expanded-date-picker.d.ts +43 -43
  98. package/dist/src/expanded-date-picker.js +109 -109
  99. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  100. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  101. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  102. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  103. package/dist/src/manage/manage-bar.d.ts +30 -30
  104. package/dist/src/manage/manage-bar.js +61 -61
  105. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  106. package/dist/src/mediatype/mediatype-config.js +91 -91
  107. package/dist/src/models.d.ts +218 -218
  108. package/dist/src/models.js +392 -392
  109. package/dist/src/models.js.map +1 -1
  110. package/dist/src/restoration-state-handler.d.ts +70 -70
  111. package/dist/src/restoration-state-handler.js +357 -357
  112. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  113. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  114. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  115. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  116. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  117. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  118. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  119. package/dist/src/sort-filter-bar/img/list.js +2 -2
  120. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  121. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  122. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  123. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  124. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  125. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  126. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  127. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  128. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  129. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  130. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
  131. package/dist/src/sort-filter-bar/sort-filter-bar.js +697 -697
  132. package/dist/src/styles/ia-button.d.ts +2 -2
  133. package/dist/src/styles/ia-button.js +16 -16
  134. package/dist/src/styles/item-image-styles.d.ts +8 -8
  135. package/dist/src/styles/item-image-styles.js +9 -9
  136. package/dist/src/styles/sr-only.d.ts +1 -1
  137. package/dist/src/styles/sr-only.js +2 -2
  138. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  139. package/dist/src/tiles/base-tile-component.js +64 -64
  140. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  141. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  142. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  143. package/dist/src/tiles/grid/account-tile.js +72 -72
  144. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  145. package/dist/src/tiles/grid/collection-tile.js +80 -80
  146. package/dist/src/tiles/grid/item-tile.d.ts +34 -34
  147. package/dist/src/tiles/grid/item-tile.js +158 -158
  148. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  149. package/dist/src/tiles/grid/search-tile.js +51 -51
  150. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  151. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  152. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  153. package/dist/src/tiles/grid/tile-stats.js +53 -53
  154. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  155. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  156. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
  157. package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
  158. package/dist/src/tiles/image-block.d.ts +18 -18
  159. package/dist/src/tiles/image-block.js +89 -89
  160. package/dist/src/tiles/item-image.d.ts +39 -39
  161. package/dist/src/tiles/item-image.js +154 -154
  162. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  163. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  164. package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
  165. package/dist/src/tiles/list/tile-list-compact.js +122 -122
  166. package/dist/src/tiles/list/tile-list.d.ts +54 -54
  167. package/dist/src/tiles/list/tile-list.js +323 -323
  168. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  169. package/dist/src/tiles/mediatype-icon.js +47 -47
  170. package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
  171. package/dist/src/tiles/overlay/icon-overlay.js +25 -25
  172. package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
  173. package/dist/src/tiles/overlay/text-overlay.js +31 -31
  174. package/dist/src/tiles/review-block.d.ts +12 -12
  175. package/dist/src/tiles/review-block.js +56 -56
  176. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  177. package/dist/src/tiles/text-snippet-block.js +73 -73
  178. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  179. package/dist/src/tiles/tile-dispatcher.js +230 -230
  180. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  181. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  182. package/dist/src/utils/analytics-events.d.ts +28 -28
  183. package/dist/src/utils/analytics-events.js +30 -30
  184. package/dist/src/utils/array-equals.d.ts +4 -4
  185. package/dist/src/utils/array-equals.js +10 -10
  186. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  187. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  188. package/dist/src/utils/facet-utils.d.ts +83 -83
  189. package/dist/src/utils/facet-utils.js +145 -145
  190. package/dist/src/utils/format-count.d.ts +7 -7
  191. package/dist/src/utils/format-count.js +76 -76
  192. package/dist/src/utils/format-date.d.ts +2 -2
  193. package/dist/src/utils/format-date.js +25 -25
  194. package/dist/src/utils/format-unit-size.d.ts +2 -2
  195. package/dist/src/utils/format-unit-size.js +33 -33
  196. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  197. package/dist/src/utils/local-date-from-utc.js +15 -15
  198. package/dist/src/utils/log.d.ts +7 -7
  199. package/dist/src/utils/log.js +15 -15
  200. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  201. package/dist/src/utils/resolve-mediatype.js +23 -23
  202. package/dist/src/utils/sha1.d.ts +2 -2
  203. package/dist/src/utils/sha1.js +8 -8
  204. package/dist/test/collection-browser.test.d.ts +1 -1
  205. package/dist/test/collection-browser.test.js +1294 -1294
  206. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  207. package/dist/test/collection-facets/facet-row.test.js +227 -227
  208. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  209. package/dist/test/collection-facets/facets-template.test.js +91 -91
  210. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  211. package/dist/test/collection-facets/more-facets-content.test.js +141 -141
  212. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  213. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  214. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  215. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  216. package/dist/test/collection-facets.test.d.ts +2 -2
  217. package/dist/test/collection-facets.test.js +690 -652
  218. package/dist/test/collection-facets.test.js.map +1 -1
  219. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  220. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  221. package/dist/test/empty-placeholder.test.d.ts +1 -1
  222. package/dist/test/empty-placeholder.test.js +63 -63
  223. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  224. package/dist/test/expanded-date-picker.test.js +95 -95
  225. package/dist/test/icon-overlay.test.d.ts +1 -1
  226. package/dist/test/icon-overlay.test.js +24 -24
  227. package/dist/test/image-block.test.d.ts +1 -1
  228. package/dist/test/image-block.test.js +107 -107
  229. package/dist/test/item-image.test.d.ts +1 -1
  230. package/dist/test/item-image.test.js +85 -85
  231. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  232. package/dist/test/manage/manage-bar.test.js +81 -81
  233. package/dist/test/mediatype-config.test.d.ts +1 -1
  234. package/dist/test/mediatype-config.test.js +16 -16
  235. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  236. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  237. package/dist/test/mocks/mock-search-responses.d.ts +25 -25
  238. package/dist/test/mocks/mock-search-responses.js +942 -942
  239. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  240. package/dist/test/mocks/mock-search-service.js +54 -54
  241. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  242. package/dist/test/restoration-state-handler.test.js +270 -270
  243. package/dist/test/review-block.test.d.ts +1 -1
  244. package/dist/test/review-block.test.js +44 -44
  245. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  246. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  247. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  248. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  249. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  250. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  251. package/dist/test/text-overlay.test.d.ts +1 -1
  252. package/dist/test/text-overlay.test.js +38 -38
  253. package/dist/test/text-snippet-block.test.d.ts +1 -1
  254. package/dist/test/text-snippet-block.test.js +57 -57
  255. package/dist/test/tile-stats.test.d.ts +1 -1
  256. package/dist/test/tile-stats.test.js +81 -81
  257. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  258. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  259. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  260. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  261. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  262. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  263. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  264. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  265. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  266. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  267. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  268. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  269. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  270. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  271. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  272. package/dist/test/tiles/list/tile-list.test.js +297 -297
  273. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  274. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  275. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  276. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  277. package/dist/test/utils/array-equals.test.d.ts +1 -1
  278. package/dist/test/utils/array-equals.test.js +26 -26
  279. package/dist/test/utils/format-count.test.d.ts +1 -1
  280. package/dist/test/utils/format-count.test.js +23 -23
  281. package/dist/test/utils/format-date.test.d.ts +1 -1
  282. package/dist/test/utils/format-date.test.js +17 -17
  283. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  284. package/dist/test/utils/format-unit-size.test.js +17 -17
  285. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  286. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  287. package/local.archive.org.cert +86 -86
  288. package/local.archive.org.key +27 -27
  289. package/package.json +2 -2
  290. package/renovate.json +6 -6
  291. package/src/models.ts +1 -1
  292. package/test/collection-facets.test.ts +219 -218
  293. package/web-dev-server.config.mjs +30 -30
  294. package/web-test-runner.config.mjs +41 -41
  295. package/dist/src/collection-facets/smart-facet-bar.d.ts +0 -12
  296. package/dist/src/collection-facets/smart-facet-bar.js +0 -75
  297. package/dist/src/collection-facets/smart-facet-bar.js.map +0 -1
  298. package/dist/src/collection-facets/smart-facet-button.d.ts +0 -9
  299. package/dist/src/collection-facets/smart-facet-button.js +0 -55
  300. package/dist/src/collection-facets/smart-facet-button.js.map +0 -1
  301. package/dist/src/collection-facets/smart-facet-dropdown.d.ts +0 -0
  302. package/dist/src/collection-facets/smart-facet-dropdown.js +0 -2
  303. package/dist/src/collection-facets/smart-facet-dropdown.js.map +0 -1
  304. package/src/collection-facets/smart-facet-bar.ts +0 -92
  305. package/src/collection-facets/smart-facet-button.ts +0 -60
  306. package/src/collection-facets/smart-facet-dropdown.ts +0 -0
@@ -1,218 +1,218 @@
1
- import type { TemplateResult } from 'lit';
2
- import type { MediaType } from '@internetarchive/field-parsers';
3
- import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
4
- /**
5
- * Different types of tile overlays, corresponding to the above flags.
6
- */
7
- export declare type TileOverlayType = 'login-required' | 'content-warning';
8
- export declare const TILE_OVERLAY_TEXT: Record<TileOverlayType, string>;
9
- export declare const TILE_OVERLAY_ICONS: Record<TileOverlayType, TemplateResult>;
10
- /**
11
- * Class for converting & storing raw search results in the correct format for UI tiles.
12
- */
13
- export declare class TileModel {
14
- averageRating?: number;
15
- captureDates?: Date[];
16
- checked: boolean;
17
- collectionIdentifier?: string;
18
- collectionName?: string;
19
- collectionFilesCount: number;
20
- collections: string[];
21
- collectionSize: number;
22
- commentCount: number;
23
- creator?: string;
24
- creators: string[];
25
- dateStr?: string;
26
- dateAdded?: Date;
27
- dateArchived?: Date;
28
- datePublished?: Date;
29
- dateReviewed?: Date;
30
- description?: string;
31
- favCount: number;
32
- href?: string;
33
- identifier?: string;
34
- issue?: string;
35
- itemCount: number;
36
- mediatype: MediaType;
37
- review?: Review;
38
- source?: string;
39
- snippets?: string[];
40
- subjects: string[];
41
- title: string;
42
- viewCount?: number;
43
- volume?: string;
44
- weeklyViewCount?: number;
45
- loginRequired: boolean;
46
- contentWarning: boolean;
47
- constructor(result: SearchResult);
48
- /**
49
- * Copies the contents of this TileModel onto a new instance
50
- */
51
- clone(): TileModel;
52
- /**
53
- * Determines the appropriate tile flags for the given search result
54
- * (login required and/or content warning)
55
- */
56
- private getFlags;
57
- }
58
- export declare type RequestKind = 'full' | 'hits' | 'aggregations';
59
- export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
60
- export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
61
- /**
62
- * This is mainly used to set the cookies for the collection display mode.
63
- *
64
- * It allows the user to set different modes for different contexts (collection page, search page, etc).
65
- */
66
- export declare type CollectionBrowserContext = 'collection' | 'search';
67
- /**
68
- * The sort fields shown in the sort filter bar
69
- */
70
- export declare enum SortField {
71
- 'default' = "default",
72
- 'unrecognized' = "unrecognized",
73
- 'relevance' = "relevance",
74
- 'alltimeview' = "alltimeview",
75
- 'weeklyview' = "weeklyview",
76
- 'title' = "title",
77
- 'date' = "date",
78
- 'datearchived' = "datearchived",
79
- 'datereviewed' = "datereviewed",
80
- 'dateadded' = "dateadded",
81
- 'datefavorited' = "datefavorited",
82
- 'creator' = "creator"
83
- }
84
- export interface SortOption {
85
- /**
86
- * The SortField enum member corresponding to this option.
87
- */
88
- field: SortField;
89
- /**
90
- * The default sort direction to apply when this sort option is first selected.
91
- */
92
- defaultSortDirection: SortDirection | null;
93
- /**
94
- * Whether this sort option allows its sort direction to be changed from the default.
95
- */
96
- canSetDirection: boolean;
97
- /**
98
- * Whether this sort option may appear in the sort bar.
99
- */
100
- shownInSortBar: boolean;
101
- /**
102
- * Whether this sort option should be saved to the URL.
103
- * If false, then no `sort` param will be added to the URL when this sort option
104
- * is selected.
105
- */
106
- shownInURL: boolean;
107
- /**
108
- * Whether this sort option is passed to the search service.
109
- * If false, then no sort param will be passed to the search service at all when
110
- * this sort option is selected.
111
- */
112
- handledBySearchService: boolean;
113
- /**
114
- * The string identifying this sort field to the search service & backend API.
115
- */
116
- searchServiceKey?: string;
117
- /**
118
- * The human-readable name to use for this option in the sort bar (if applicable).
119
- */
120
- displayName: string;
121
- /**
122
- * A list of URL param keys that should be mapped to this sort option.
123
- * E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
124
- */
125
- urlNames: (string | null | undefined)[];
126
- }
127
- export declare const SORT_OPTIONS: Record<SortField, SortOption>;
128
- /**
129
- * Returns the SortOption corresponding to the given API sort name, or
130
- * the "unrecognized" SortOption if none matches.
131
- */
132
- export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
133
- export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
134
- /** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
135
- export declare type PrefixFilterType = 'title' | 'creator';
136
- /** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
137
- export declare type PrefixFilterCounts = Record<string, number>;
138
- /**
139
- * A map from prefix filter types to the corresponding aggregation keys
140
- * that are needed to fetch the filter counts from the backend.
141
- */
142
- export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
143
- /**
144
- * Different facet loading strategies that can be used with collection browser.
145
- * - `eager`: Facet data is always loaded as soon as a search is performed
146
- * - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
147
- * In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
148
- * - `opt-in-or-login`: Same as `opt-in` for guest users not logged into an account, but same as `eager` for
149
- * any logged in user.
150
- * - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
151
- * In the mobile layout, functions exactly as `lazy-mobile`.
152
- * - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
153
- * indicating that they are unavailable.
154
- */
155
- export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in-or-login' | 'opt-in' | 'off';
156
- /**
157
- * Union of the facet types that are available in the sidebar.
158
- */
159
- export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
160
- export declare type SelectedFacetState = 'selected' | 'hidden';
161
- export declare type FacetState = SelectedFacetState | 'none';
162
- export interface FacetBucket {
163
- displayText?: string;
164
- key: string;
165
- count: number;
166
- state: FacetState;
167
- }
168
- export interface FacetGroup {
169
- title: string;
170
- key: FacetOption;
171
- buckets: FacetBucket[];
172
- }
173
- /**
174
- * Information about a user interaction event on a facet.
175
- */
176
- export declare type FacetEventDetails = {
177
- /**
178
- * The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
179
- */
180
- facetType: FacetOption;
181
- /**
182
- * The bucket corresponding to the facet that was interacted with, including the
183
- * updated state of the facet after the interaction.
184
- */
185
- bucket: FacetBucket;
186
- /**
187
- * Whether the interaction occurred on a negative facet.
188
- */
189
- negative: boolean;
190
- };
191
- export declare type FacetValue = string;
192
- export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
193
- export declare const getDefaultSelectedFacets: () => SelectedFacets;
194
- export declare const facetDisplayOrder: FacetOption[];
195
- export declare const facetTitles: Record<FacetOption, string>;
196
- /**
197
- * The default sort type to use for each facet type
198
- */
199
- export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
200
- /**
201
- * The sort type corresponding to facet bucket values, for each facet type
202
- * (i.e., the opposite of "sort by count" for that type).
203
- */
204
- export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
205
- export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
206
- /**
207
- * Maps valid lending keys to whether they should be visible in the facet sidebar
208
- */
209
- export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
210
- /**
211
- * Maps valid, visible lending keys to their facet sidebar display text
212
- */
213
- export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
214
- /**
215
- * A record of which admin-only collections should be suppressed from being displayed
216
- * as facets or in an item's list of collections.
217
- */
218
- export declare const suppressedCollections: Record<string, boolean>;
1
+ import type { TemplateResult } from 'lit';
2
+ import type { MediaType } from '@internetarchive/field-parsers';
3
+ import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
4
+ /**
5
+ * Different types of tile overlays, corresponding to the above flags.
6
+ */
7
+ export declare type TileOverlayType = 'login-required' | 'content-warning';
8
+ export declare const TILE_OVERLAY_TEXT: Record<TileOverlayType, string>;
9
+ export declare const TILE_OVERLAY_ICONS: Record<TileOverlayType, TemplateResult>;
10
+ /**
11
+ * Class for converting & storing raw search results in the correct format for UI tiles.
12
+ */
13
+ export declare class TileModel {
14
+ averageRating?: number;
15
+ captureDates?: Date[];
16
+ checked: boolean;
17
+ collectionIdentifier?: string;
18
+ collectionName?: string;
19
+ collectionFilesCount: number;
20
+ collections: string[];
21
+ collectionSize: number;
22
+ commentCount: number;
23
+ creator?: string;
24
+ creators: string[];
25
+ dateStr?: string;
26
+ dateAdded?: Date;
27
+ dateArchived?: Date;
28
+ datePublished?: Date;
29
+ dateReviewed?: Date;
30
+ description?: string;
31
+ favCount: number;
32
+ href?: string;
33
+ identifier?: string;
34
+ issue?: string;
35
+ itemCount: number;
36
+ mediatype: MediaType;
37
+ review?: Review;
38
+ source?: string;
39
+ snippets?: string[];
40
+ subjects: string[];
41
+ title: string;
42
+ viewCount?: number;
43
+ volume?: string;
44
+ weeklyViewCount?: number;
45
+ loginRequired: boolean;
46
+ contentWarning: boolean;
47
+ constructor(result: SearchResult);
48
+ /**
49
+ * Copies the contents of this TileModel onto a new instance
50
+ */
51
+ clone(): TileModel;
52
+ /**
53
+ * Determines the appropriate tile flags for the given search result
54
+ * (login required and/or content warning)
55
+ */
56
+ private getFlags;
57
+ }
58
+ export declare type RequestKind = 'full' | 'hits' | 'aggregations';
59
+ export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
60
+ export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
61
+ /**
62
+ * This is mainly used to set the cookies for the collection display mode.
63
+ *
64
+ * It allows the user to set different modes for different contexts (collection page, search page, etc).
65
+ */
66
+ export declare type CollectionBrowserContext = 'collection' | 'search';
67
+ /**
68
+ * The sort fields shown in the sort filter bar
69
+ */
70
+ export declare enum SortField {
71
+ 'default' = "default",
72
+ 'unrecognized' = "unrecognized",
73
+ 'relevance' = "relevance",
74
+ 'alltimeview' = "alltimeview",
75
+ 'weeklyview' = "weeklyview",
76
+ 'title' = "title",
77
+ 'date' = "date",
78
+ 'datearchived' = "datearchived",
79
+ 'datereviewed' = "datereviewed",
80
+ 'dateadded' = "dateadded",
81
+ 'datefavorited' = "datefavorited",
82
+ 'creator' = "creator"
83
+ }
84
+ export interface SortOption {
85
+ /**
86
+ * The SortField enum member corresponding to this option.
87
+ */
88
+ field: SortField;
89
+ /**
90
+ * The default sort direction to apply when this sort option is first selected.
91
+ */
92
+ defaultSortDirection: SortDirection | null;
93
+ /**
94
+ * Whether this sort option allows its sort direction to be changed from the default.
95
+ */
96
+ canSetDirection: boolean;
97
+ /**
98
+ * Whether this sort option may appear in the sort bar.
99
+ */
100
+ shownInSortBar: boolean;
101
+ /**
102
+ * Whether this sort option should be saved to the URL.
103
+ * If false, then no `sort` param will be added to the URL when this sort option
104
+ * is selected.
105
+ */
106
+ shownInURL: boolean;
107
+ /**
108
+ * Whether this sort option is passed to the search service.
109
+ * If false, then no sort param will be passed to the search service at all when
110
+ * this sort option is selected.
111
+ */
112
+ handledBySearchService: boolean;
113
+ /**
114
+ * The string identifying this sort field to the search service & backend API.
115
+ */
116
+ searchServiceKey?: string;
117
+ /**
118
+ * The human-readable name to use for this option in the sort bar (if applicable).
119
+ */
120
+ displayName: string;
121
+ /**
122
+ * A list of URL param keys that should be mapped to this sort option.
123
+ * E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
124
+ */
125
+ urlNames: (string | null | undefined)[];
126
+ }
127
+ export declare const SORT_OPTIONS: Record<SortField, SortOption>;
128
+ /**
129
+ * Returns the SortOption corresponding to the given API sort name, or
130
+ * the "unrecognized" SortOption if none matches.
131
+ */
132
+ export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
133
+ export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
134
+ /** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
135
+ export declare type PrefixFilterType = 'title' | 'creator';
136
+ /** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
137
+ export declare type PrefixFilterCounts = Record<string, number>;
138
+ /**
139
+ * A map from prefix filter types to the corresponding aggregation keys
140
+ * that are needed to fetch the filter counts from the backend.
141
+ */
142
+ export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
143
+ /**
144
+ * Different facet loading strategies that can be used with collection browser.
145
+ * - `eager`: Facet data is always loaded as soon as a search is performed
146
+ * - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
147
+ * In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
148
+ * - `opt-in-or-login`: Same as `opt-in` for guest users not logged into an account, but same as `eager` for
149
+ * any logged in user.
150
+ * - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
151
+ * In the mobile layout, functions exactly as `lazy-mobile`.
152
+ * - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
153
+ * indicating that they are unavailable.
154
+ */
155
+ export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in-or-login' | 'opt-in' | 'off';
156
+ /**
157
+ * Union of the facet types that are available in the sidebar.
158
+ */
159
+ export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
160
+ export declare type SelectedFacetState = 'selected' | 'hidden';
161
+ export declare type FacetState = SelectedFacetState | 'none';
162
+ export interface FacetBucket {
163
+ displayText?: string;
164
+ key: string;
165
+ count: number;
166
+ state: FacetState;
167
+ }
168
+ export interface FacetGroup {
169
+ title: string;
170
+ key: FacetOption;
171
+ buckets: FacetBucket[];
172
+ }
173
+ /**
174
+ * Information about a user interaction event on a facet.
175
+ */
176
+ export declare type FacetEventDetails = {
177
+ /**
178
+ * The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
179
+ */
180
+ facetType: FacetOption;
181
+ /**
182
+ * The bucket corresponding to the facet that was interacted with, including the
183
+ * updated state of the facet after the interaction.
184
+ */
185
+ bucket: FacetBucket;
186
+ /**
187
+ * Whether the interaction occurred on a negative facet.
188
+ */
189
+ negative: boolean;
190
+ };
191
+ export declare type FacetValue = string;
192
+ export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
193
+ export declare const getDefaultSelectedFacets: () => SelectedFacets;
194
+ export declare const facetDisplayOrder: FacetOption[];
195
+ export declare const facetTitles: Record<FacetOption, string>;
196
+ /**
197
+ * The default sort type to use for each facet type
198
+ */
199
+ export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
200
+ /**
201
+ * The sort type corresponding to facet bucket values, for each facet type
202
+ * (i.e., the opposite of "sort by count" for that type).
203
+ */
204
+ export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
205
+ export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
206
+ /**
207
+ * Maps valid lending keys to whether they should be visible in the facet sidebar
208
+ */
209
+ export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
210
+ /**
211
+ * Maps valid, visible lending keys to their facet sidebar display text
212
+ */
213
+ export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
214
+ /**
215
+ * A record of which admin-only collections should be suppressed from being displayed
216
+ * as facets or in an item's list of collections.
217
+ */
218
+ export declare const suppressedCollections: Record<string, boolean>;