@internetarchive/collection-browser 2.3.0 → 2.4.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 (299) 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 +466 -466
  72. package/dist/src/collection-browser.js +1475 -1475
  73. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  74. package/dist/src/collection-facets/facet-row.js +114 -114
  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 +17 -17
  78. package/dist/src/collection-facets/facets-template.js +114 -114
  79. package/dist/src/collection-facets/more-facets-content.d.ts +74 -74
  80. package/dist/src/collection-facets/more-facets-content.js +360 -360
  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 +510 -510
  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 +985 -985
  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 +74 -74
  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 +209 -209
  108. package/dist/src/models.js +381 -381
  109. package/dist/src/restoration-state-handler.d.ts +70 -70
  110. package/dist/src/restoration-state-handler.js +357 -357
  111. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  112. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  113. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  114. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  115. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  116. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  117. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  118. package/dist/src/sort-filter-bar/img/list.js +2 -2
  119. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  120. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  121. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  122. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  123. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  124. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  125. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  126. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  127. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  128. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  129. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +222 -222
  130. package/dist/src/sort-filter-bar/sort-filter-bar.js +696 -696
  131. package/dist/src/styles/ia-button.d.ts +2 -2
  132. package/dist/src/styles/ia-button.js +16 -16
  133. package/dist/src/styles/item-image-styles.d.ts +8 -8
  134. package/dist/src/styles/item-image-styles.js +9 -9
  135. package/dist/src/styles/sr-only.d.ts +1 -1
  136. package/dist/src/styles/sr-only.js +2 -2
  137. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  138. package/dist/src/tiles/base-tile-component.js +63 -63
  139. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  140. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  141. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  142. package/dist/src/tiles/grid/account-tile.js +72 -72
  143. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  144. package/dist/src/tiles/grid/collection-tile.js +80 -80
  145. package/dist/src/tiles/grid/item-tile.d.ts +30 -30
  146. package/dist/src/tiles/grid/item-tile.js +149 -149
  147. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  148. package/dist/src/tiles/grid/search-tile.js +51 -51
  149. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  150. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  151. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  152. package/dist/src/tiles/grid/tile-stats.js +53 -53
  153. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  154. package/dist/src/tiles/hover/hover-pane-controller.js +354 -352
  155. package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
  156. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -15
  157. package/dist/src/tiles/hover/tile-hover-pane.js +127 -47
  158. package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
  159. package/dist/src/tiles/image-block.d.ts +17 -17
  160. package/dist/src/tiles/image-block.js +74 -74
  161. package/dist/src/tiles/image-block.js.map +1 -1
  162. package/dist/src/tiles/item-image.d.ts +39 -39
  163. package/dist/src/tiles/item-image.js +154 -154
  164. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  165. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  166. package/dist/src/tiles/list/tile-list-compact.d.ts +15 -15
  167. package/dist/src/tiles/list/tile-list-compact.js +114 -114
  168. package/dist/src/tiles/list/tile-list.d.ts +50 -50
  169. package/dist/src/tiles/list/tile-list.js +315 -315
  170. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  171. package/dist/src/tiles/mediatype-icon.js +47 -47
  172. package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
  173. package/dist/src/tiles/overlay/icon-overlay.js +40 -40
  174. package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
  175. package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
  176. package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
  177. package/dist/src/tiles/overlay/text-overlay.js +42 -42
  178. package/dist/src/tiles/review-block.d.ts +12 -12
  179. package/dist/src/tiles/review-block.js +56 -56
  180. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  181. package/dist/src/tiles/text-snippet-block.js +73 -73
  182. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  183. package/dist/src/tiles/tile-dispatcher.js +229 -229
  184. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  185. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  186. package/dist/src/utils/analytics-events.d.ts +28 -28
  187. package/dist/src/utils/analytics-events.js +30 -30
  188. package/dist/src/utils/array-equals.d.ts +4 -4
  189. package/dist/src/utils/array-equals.js +10 -10
  190. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  191. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  192. package/dist/src/utils/format-count.d.ts +7 -7
  193. package/dist/src/utils/format-count.js +76 -76
  194. package/dist/src/utils/format-date.d.ts +2 -2
  195. package/dist/src/utils/format-date.js +25 -25
  196. package/dist/src/utils/format-unit-size.d.ts +2 -2
  197. package/dist/src/utils/format-unit-size.js +33 -33
  198. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  199. package/dist/src/utils/local-date-from-utc.js +15 -15
  200. package/dist/src/utils/log.d.ts +7 -7
  201. package/dist/src/utils/log.js +15 -15
  202. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  203. package/dist/src/utils/resolve-mediatype.js +23 -23
  204. package/dist/src/utils/sha1.d.ts +2 -2
  205. package/dist/src/utils/sha1.js +8 -8
  206. package/dist/test/collection-browser.test.d.ts +1 -1
  207. package/dist/test/collection-browser.test.js +1293 -1293
  208. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  209. package/dist/test/collection-facets/facet-row.test.js +203 -203
  210. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  211. package/dist/test/collection-facets/facets-template.test.js +105 -105
  212. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  213. package/dist/test/collection-facets/more-facets-content.test.js +139 -139
  214. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  215. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  216. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  217. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  218. package/dist/test/collection-facets.test.d.ts +2 -2
  219. package/dist/test/collection-facets.test.js +652 -652
  220. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  221. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  222. package/dist/test/empty-placeholder.test.d.ts +1 -1
  223. package/dist/test/empty-placeholder.test.js +63 -63
  224. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  225. package/dist/test/expanded-date-picker.test.js +95 -95
  226. package/dist/test/icon-overlay.test.d.ts +1 -1
  227. package/dist/test/icon-overlay.test.js +24 -24
  228. package/dist/test/image-block.test.d.ts +1 -1
  229. package/dist/test/image-block.test.js +48 -48
  230. package/dist/test/item-image.test.d.ts +1 -1
  231. package/dist/test/item-image.test.js +85 -85
  232. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  233. package/dist/test/manage/manage-bar.test.js +81 -81
  234. package/dist/test/mediatype-config.test.d.ts +1 -1
  235. package/dist/test/mediatype-config.test.js +16 -16
  236. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  237. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  238. package/dist/test/mocks/mock-search-responses.d.ts +24 -24
  239. package/dist/test/mocks/mock-search-responses.js +860 -860
  240. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  241. package/dist/test/mocks/mock-search-service.js +53 -53
  242. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  243. package/dist/test/restoration-state-handler.test.js +270 -270
  244. package/dist/test/review-block.test.d.ts +1 -1
  245. package/dist/test/review-block.test.js +44 -44
  246. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  247. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  248. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  249. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  250. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  251. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  252. package/dist/test/text-overlay.test.d.ts +1 -1
  253. package/dist/test/text-overlay.test.js +48 -48
  254. package/dist/test/text-snippet-block.test.d.ts +1 -1
  255. package/dist/test/text-snippet-block.test.js +57 -57
  256. package/dist/test/tile-stats.test.d.ts +1 -1
  257. package/dist/test/tile-stats.test.js +81 -81
  258. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  259. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  260. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  261. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  262. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  263. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  264. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  265. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  266. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  267. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  268. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  269. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -13
  270. package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
  271. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  272. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  273. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  274. package/dist/test/tiles/list/tile-list.test.js +297 -297
  275. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  276. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  277. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  278. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  279. package/dist/test/utils/array-equals.test.d.ts +1 -1
  280. package/dist/test/utils/array-equals.test.js +26 -26
  281. package/dist/test/utils/format-count.test.d.ts +1 -1
  282. package/dist/test/utils/format-count.test.js +23 -23
  283. package/dist/test/utils/format-date.test.d.ts +1 -1
  284. package/dist/test/utils/format-date.test.js +17 -17
  285. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  286. package/dist/test/utils/format-unit-size.test.js +17 -17
  287. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  288. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  289. package/local.archive.org.cert +86 -86
  290. package/local.archive.org.key +27 -27
  291. package/package.json +1 -1
  292. package/renovate.json +6 -6
  293. package/src/tiles/hover/hover-pane-controller.ts +2 -0
  294. package/src/tiles/hover/tile-hover-pane.ts +100 -11
  295. package/src/tiles/image-block.ts +1 -1
  296. package/test/tiles/hover/tile-hover-pane.test.ts +61 -0
  297. package/tsconfig.json +21 -21
  298. package/web-dev-server.config.mjs +30 -30
  299. package/web-test-runner.config.mjs +41 -41
@@ -1,209 +1,209 @@
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`: 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>;