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