@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,209 +1,211 @@
1
- import type { MediaType } from '@internetarchive/field-parsers';
2
- import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
3
- /**
4
- * Class for converting & storing raw search results in the correct format for UI tiles.
5
- */
6
- export declare class TileModel {
7
- averageRating?: number;
8
- captureDates?: Date[];
9
- checked: boolean;
10
- collectionIdentifier?: string;
11
- collectionName?: string;
12
- collectionFilesCount: number;
13
- collections: string[];
14
- collectionSize: number;
15
- commentCount: number;
16
- creator?: string;
17
- creators: string[];
18
- dateStr?: string;
19
- dateAdded?: Date;
20
- dateArchived?: Date;
21
- datePublished?: Date;
22
- dateReviewed?: Date;
23
- description?: string;
24
- favCount: number;
25
- href?: string;
26
- identifier?: string;
27
- issue?: string;
28
- itemCount: number;
29
- mediatype: MediaType;
30
- review?: Review;
31
- source?: string;
32
- snippets?: string[];
33
- subjects: string[];
34
- title: string;
35
- viewCount?: number;
36
- volume?: string;
37
- weeklyViewCount?: number;
38
- loginRequired: boolean;
39
- contentWarning: boolean;
40
- constructor(result: SearchResult);
41
- /**
42
- * Copies the contents of this TileModel onto a new instance
43
- */
44
- clone(): TileModel;
45
- /**
46
- * Determines the appropriate tile flags for the given search result
47
- * (login required and/or content warning)
48
- */
49
- private getFlags;
50
- }
51
- export declare type RequestKind = 'full' | 'hits' | 'aggregations';
52
- export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
53
- export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
54
- /**
55
- * This is mainly used to set the cookies for the collection display mode.
56
- *
57
- * It allows the user to set different modes for different contexts (collection page, search page, etc).
58
- */
59
- export declare type CollectionBrowserContext = 'collection' | 'search';
60
- /**
61
- * The sort fields shown in the sort filter bar
62
- */
63
- export declare enum SortField {
64
- 'default' = "default",
65
- 'unrecognized' = "unrecognized",
66
- 'relevance' = "relevance",
67
- 'alltimeview' = "alltimeview",
68
- 'weeklyview' = "weeklyview",
69
- 'title' = "title",
70
- 'date' = "date",
71
- 'datearchived' = "datearchived",
72
- 'datereviewed' = "datereviewed",
73
- 'dateadded' = "dateadded",
74
- 'datefavorited' = "datefavorited",
75
- 'creator' = "creator"
76
- }
77
- export interface SortOption {
78
- /**
79
- * The SortField enum member corresponding to this option.
80
- */
81
- field: SortField;
82
- /**
83
- * The default sort direction to apply when this sort option is first selected.
84
- */
85
- defaultSortDirection: SortDirection | null;
86
- /**
87
- * Whether this sort option allows its sort direction to be changed from the default.
88
- */
89
- canSetDirection: boolean;
90
- /**
91
- * Whether this sort option may appear in the sort bar.
92
- */
93
- shownInSortBar: boolean;
94
- /**
95
- * Whether this sort option should be saved to the URL.
96
- * If false, then no `sort` param will be added to the URL when this sort option
97
- * is selected.
98
- */
99
- shownInURL: boolean;
100
- /**
101
- * Whether this sort option is passed to the search service.
102
- * If false, then no sort param will be passed to the search service at all when
103
- * this sort option is selected.
104
- */
105
- handledBySearchService: boolean;
106
- /**
107
- * The string identifying this sort field to the search service & backend API.
108
- */
109
- searchServiceKey?: string;
110
- /**
111
- * The human-readable name to use for this option in the sort bar (if applicable).
112
- */
113
- displayName: string;
114
- /**
115
- * A list of URL param keys that should be mapped to this sort option.
116
- * E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
117
- */
118
- urlNames: (string | null | undefined)[];
119
- }
120
- export declare const SORT_OPTIONS: Record<SortField, SortOption>;
121
- /**
122
- * Returns the SortOption corresponding to the given API sort name, or
123
- * the "unrecognized" SortOption if none matches.
124
- */
125
- export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
126
- export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
127
- /** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
128
- export declare type PrefixFilterType = 'title' | 'creator';
129
- /** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
130
- export declare type PrefixFilterCounts = Record<string, number>;
131
- /**
132
- * A map from prefix filter types to the corresponding aggregation keys
133
- * that are needed to fetch the filter counts from the backend.
134
- */
135
- export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
136
- /**
137
- * Different facet loading strategies that can be used with collection browser.
138
- * - `eager`: Facet data is always loaded as soon as a search is performed
139
- * - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
140
- * In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
141
- * - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
142
- * In the mobile layout, functions exactly as `lazy-mobile`.
143
- * - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
144
- * indicating that they are unavailable.
145
- */
146
- export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in' | 'off';
147
- /**
148
- * Union of the facet types that are available in the sidebar.
149
- */
150
- export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
151
- export declare type SelectedFacetState = 'selected' | 'hidden';
152
- export declare type FacetState = SelectedFacetState | 'none';
153
- export interface FacetBucket {
154
- displayText?: string;
155
- key: string;
156
- count: number;
157
- state: FacetState;
158
- }
159
- export interface FacetGroup {
160
- title: string;
161
- key: FacetOption;
162
- buckets: FacetBucket[];
163
- }
164
- /**
165
- * Information about a user interaction event on a facet.
166
- */
167
- export declare type FacetEventDetails = {
168
- /**
169
- * The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
170
- */
171
- facetType: FacetOption;
172
- /**
173
- * The bucket corresponding to the facet that was interacted with, including the
174
- * updated state of the facet after the interaction.
175
- */
176
- bucket: FacetBucket;
177
- /**
178
- * Whether the interaction occurred on a negative facet.
179
- */
180
- negative: boolean;
181
- };
182
- export declare type FacetValue = string;
183
- export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
184
- export declare const getDefaultSelectedFacets: () => SelectedFacets;
185
- export declare const facetDisplayOrder: FacetOption[];
186
- export declare const facetTitles: Record<FacetOption, string>;
187
- /**
188
- * The default sort type to use for each facet type
189
- */
190
- export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
191
- /**
192
- * The sort type corresponding to facet bucket values, for each facet type
193
- * (i.e., the opposite of "sort by count" for that type).
194
- */
195
- export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
196
- export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
197
- /**
198
- * Maps valid lending keys to whether they should be visible in the facet sidebar
199
- */
200
- export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
201
- /**
202
- * Maps valid, visible lending keys to their facet sidebar display text
203
- */
204
- export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
205
- /**
206
- * A record of which admin-only collections should be suppressed from being displayed
207
- * as facets or in an item's list of collections.
208
- */
209
- export declare const suppressedCollections: Record<string, boolean>;
1
+ import type { MediaType } from '@internetarchive/field-parsers';
2
+ import { AggregationSortType, Review, SearchResult, SortDirection } from '@internetarchive/search-service';
3
+ /**
4
+ * Class for converting & storing raw search results in the correct format for UI tiles.
5
+ */
6
+ export declare class TileModel {
7
+ averageRating?: number;
8
+ captureDates?: Date[];
9
+ checked: boolean;
10
+ collectionIdentifier?: string;
11
+ collectionName?: string;
12
+ collectionFilesCount: number;
13
+ collections: string[];
14
+ collectionSize: number;
15
+ commentCount: number;
16
+ creator?: string;
17
+ creators: string[];
18
+ dateStr?: string;
19
+ dateAdded?: Date;
20
+ dateArchived?: Date;
21
+ datePublished?: Date;
22
+ dateReviewed?: Date;
23
+ description?: string;
24
+ favCount: number;
25
+ href?: string;
26
+ identifier?: string;
27
+ issue?: string;
28
+ itemCount: number;
29
+ mediatype: MediaType;
30
+ review?: Review;
31
+ source?: string;
32
+ snippets?: string[];
33
+ subjects: string[];
34
+ title: string;
35
+ viewCount?: number;
36
+ volume?: string;
37
+ weeklyViewCount?: number;
38
+ loginRequired: boolean;
39
+ contentWarning: boolean;
40
+ constructor(result: SearchResult);
41
+ /**
42
+ * Copies the contents of this TileModel onto a new instance
43
+ */
44
+ clone(): TileModel;
45
+ /**
46
+ * Determines the appropriate tile flags for the given search result
47
+ * (login required and/or content warning)
48
+ */
49
+ private getFlags;
50
+ }
51
+ export declare type RequestKind = 'full' | 'hits' | 'aggregations';
52
+ export declare type CollectionDisplayMode = 'grid' | 'list-compact' | 'list-detail';
53
+ export declare type TileDisplayMode = 'grid' | 'list-compact' | 'list-detail' | 'list-header';
54
+ /**
55
+ * This is mainly used to set the cookies for the collection display mode.
56
+ *
57
+ * It allows the user to set different modes for different contexts (collection page, search page, etc).
58
+ */
59
+ export declare type CollectionBrowserContext = 'collection' | 'search';
60
+ /**
61
+ * The sort fields shown in the sort filter bar
62
+ */
63
+ export declare enum SortField {
64
+ 'default' = "default",
65
+ 'unrecognized' = "unrecognized",
66
+ 'relevance' = "relevance",
67
+ 'alltimeview' = "alltimeview",
68
+ 'weeklyview' = "weeklyview",
69
+ 'title' = "title",
70
+ 'date' = "date",
71
+ 'datearchived' = "datearchived",
72
+ 'datereviewed' = "datereviewed",
73
+ 'dateadded' = "dateadded",
74
+ 'datefavorited' = "datefavorited",
75
+ 'creator' = "creator"
76
+ }
77
+ export interface SortOption {
78
+ /**
79
+ * The SortField enum member corresponding to this option.
80
+ */
81
+ field: SortField;
82
+ /**
83
+ * The default sort direction to apply when this sort option is first selected.
84
+ */
85
+ defaultSortDirection: SortDirection | null;
86
+ /**
87
+ * Whether this sort option allows its sort direction to be changed from the default.
88
+ */
89
+ canSetDirection: boolean;
90
+ /**
91
+ * Whether this sort option may appear in the sort bar.
92
+ */
93
+ shownInSortBar: boolean;
94
+ /**
95
+ * Whether this sort option should be saved to the URL.
96
+ * If false, then no `sort` param will be added to the URL when this sort option
97
+ * is selected.
98
+ */
99
+ shownInURL: boolean;
100
+ /**
101
+ * Whether this sort option is passed to the search service.
102
+ * If false, then no sort param will be passed to the search service at all when
103
+ * this sort option is selected.
104
+ */
105
+ handledBySearchService: boolean;
106
+ /**
107
+ * The string identifying this sort field to the search service & backend API.
108
+ */
109
+ searchServiceKey?: string;
110
+ /**
111
+ * The human-readable name to use for this option in the sort bar (if applicable).
112
+ */
113
+ displayName: string;
114
+ /**
115
+ * A list of URL param keys that should be mapped to this sort option.
116
+ * E.g., both `title` and `titleSorter` in the URL map to the `SortField.title` option.
117
+ */
118
+ urlNames: (string | null | undefined)[];
119
+ }
120
+ export declare const SORT_OPTIONS: Record<SortField, SortOption>;
121
+ /**
122
+ * Returns the SortOption corresponding to the given API sort name, or
123
+ * the "unrecognized" SortOption if none matches.
124
+ */
125
+ export declare function sortOptionFromAPIString(sortName?: string | null): SortOption;
126
+ export declare const defaultProfileElementSorts: Record<string, Exclude<SortField, SortField.default>>;
127
+ /** A union of the fields that permit prefix filtering (e.g., alphabetical filtering) */
128
+ export declare type PrefixFilterType = 'title' | 'creator';
129
+ /** A map from prefixes (e.g., initial letters) to the number of items matching that prefix */
130
+ export declare type PrefixFilterCounts = Record<string, number>;
131
+ /**
132
+ * A map from prefix filter types to the corresponding aggregation keys
133
+ * that are needed to fetch the filter counts from the backend.
134
+ */
135
+ export declare const prefixFilterAggregationKeys: Record<PrefixFilterType, string>;
136
+ /**
137
+ * Different facet loading strategies that can be used with collection browser.
138
+ * - `eager`: Facet data is always loaded as soon as a search is performed
139
+ * - `lazy-mobile`: In the desktop layout, functions exactly as `eager`.
140
+ * In the mobile layout, facet data will only be loaded once the "Filters" accordion is opened.
141
+ * - `opt-in-or-login`: Same as `opt-in` for guest users not logged into an account, but same as `eager` for
142
+ * any logged in user.
143
+ * - `opt-in`: In the desktop layout, facet data will only be loaded after the user presses a "Load Facets" button.
144
+ * In the mobile layout, functions exactly as `lazy-mobile`.
145
+ * - `off`: Facet data will never be loaded, and a message will be displayed in place of facets
146
+ * indicating that they are unavailable.
147
+ */
148
+ export declare type FacetLoadStrategy = 'eager' | 'lazy-mobile' | 'opt-in-or-login' | 'opt-in' | 'off';
149
+ /**
150
+ * Union of the facet types that are available in the sidebar.
151
+ */
152
+ export declare type FacetOption = 'subject' | 'lending' | 'mediatype' | 'language' | 'creator' | 'collection' | 'year';
153
+ export declare type SelectedFacetState = 'selected' | 'hidden';
154
+ export declare type FacetState = SelectedFacetState | 'none';
155
+ export interface FacetBucket {
156
+ displayText?: string;
157
+ key: string;
158
+ count: number;
159
+ state: FacetState;
160
+ }
161
+ export interface FacetGroup {
162
+ title: string;
163
+ key: FacetOption;
164
+ buckets: FacetBucket[];
165
+ }
166
+ /**
167
+ * Information about a user interaction event on a facet.
168
+ */
169
+ export declare type FacetEventDetails = {
170
+ /**
171
+ * The type of facet that was interacted with (e.g., 'mediatype', 'language', ...).
172
+ */
173
+ facetType: FacetOption;
174
+ /**
175
+ * The bucket corresponding to the facet that was interacted with, including the
176
+ * updated state of the facet after the interaction.
177
+ */
178
+ bucket: FacetBucket;
179
+ /**
180
+ * Whether the interaction occurred on a negative facet.
181
+ */
182
+ negative: boolean;
183
+ };
184
+ export declare type FacetValue = string;
185
+ export declare type SelectedFacets = Record<FacetOption, Record<FacetValue, FacetBucket>>;
186
+ export declare const getDefaultSelectedFacets: () => SelectedFacets;
187
+ export declare const facetDisplayOrder: FacetOption[];
188
+ export declare const facetTitles: Record<FacetOption, string>;
189
+ /**
190
+ * The default sort type to use for each facet type
191
+ */
192
+ export declare const defaultFacetSort: Record<FacetOption, AggregationSortType>;
193
+ /**
194
+ * The sort type corresponding to facet bucket values, for each facet type
195
+ * (i.e., the opposite of "sort by count" for that type).
196
+ */
197
+ export declare const valueFacetSort: Record<FacetOption, AggregationSortType>;
198
+ export declare type LendingFacetKey = 'is_lendable' | 'is_borrowable' | 'available_to_borrow' | 'is_browsable' | 'available_to_browse' | 'is_readable' | 'available_to_waitlist';
199
+ /**
200
+ * Maps valid lending keys to whether they should be visible in the facet sidebar
201
+ */
202
+ export declare const lendingFacetKeysVisibility: Record<LendingFacetKey, boolean>;
203
+ /**
204
+ * Maps valid, visible lending keys to their facet sidebar display text
205
+ */
206
+ export declare const lendingFacetDisplayNames: Partial<Record<LendingFacetKey, string>>;
207
+ /**
208
+ * A record of which admin-only collections should be suppressed from being displayed
209
+ * as facets or in an item's list of collections.
210
+ */
211
+ export declare const suppressedCollections: Record<string, boolean>;