@internetarchive/collection-browser 2.1.4-alpha.3 → 2.1.4-alpha2

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 (307) 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 +84 -88
  8. package/dist/src/app-root.js +454 -487
  9. package/dist/src/app-root.js.map +1 -1
  10. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  11. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  12. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  13. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  14. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  15. package/dist/src/assets/img/icons/chevron.js +2 -2
  16. package/dist/src/assets/img/icons/contract.d.ts +2 -2
  17. package/dist/src/assets/img/icons/contract.js +2 -2
  18. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  19. package/dist/src/assets/img/icons/empty-query.js +2 -2
  20. package/dist/src/assets/img/icons/expand.d.ts +2 -2
  21. package/dist/src/assets/img/icons/expand.js +2 -2
  22. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  23. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  24. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  25. package/dist/src/assets/img/icons/eye.js +2 -2
  26. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  27. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  28. package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -1
  29. package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
  30. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  31. package/dist/src/assets/img/icons/login-required.js +2 -2
  32. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  33. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  34. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  35. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  36. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  37. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  38. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  39. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  40. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  41. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  42. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  43. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  44. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  45. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  46. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  47. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  48. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
  49. package/dist/src/assets/img/icons/mediatype/search.js +2 -2
  50. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  51. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  52. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  53. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  54. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  55. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  56. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  57. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  58. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  59. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  60. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  61. package/dist/src/assets/img/icons/null-result.js +2 -2
  62. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  63. package/dist/src/assets/img/icons/restricted.js +2 -2
  64. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  65. package/dist/src/assets/img/icons/reviews.js +2 -2
  66. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  67. package/dist/src/assets/img/icons/upload.js +2 -2
  68. package/dist/src/assets/img/icons/views.d.ts +1 -1
  69. package/dist/src/assets/img/icons/views.js +2 -2
  70. package/dist/src/circular-activity-indicator.d.ts +5 -5
  71. package/dist/src/circular-activity-indicator.js +17 -17
  72. package/dist/src/collection-browser.d.ts +395 -395
  73. package/dist/src/collection-browser.js +1363 -1366
  74. package/dist/src/collection-browser.js.map +1 -1
  75. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  76. package/dist/src/collection-facets/facet-row.js +114 -114
  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 +17 -17
  80. package/dist/src/collection-facets/facets-template.js +114 -114
  81. package/dist/src/collection-facets/more-facets-content.d.ts +70 -70
  82. package/dist/src/collection-facets/more-facets-content.js +354 -354
  83. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  84. package/dist/src/collection-facets/more-facets-pagination.js +196 -196
  85. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  86. package/dist/src/collection-facets/toggle-switch.js +94 -94
  87. package/dist/src/collection-facets.d.ts +103 -103
  88. package/dist/src/collection-facets.js +509 -509
  89. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +232 -232
  90. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  91. package/dist/src/data-source/collection-browser-data-source.d.ts +360 -360
  92. package/dist/src/data-source/collection-browser-data-source.js +930 -930
  93. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  94. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  95. package/dist/src/data-source/models.d.ts +28 -28
  96. package/dist/src/data-source/models.js +8 -8
  97. package/dist/src/empty-placeholder.d.ts +23 -23
  98. package/dist/src/empty-placeholder.js +74 -74
  99. package/dist/src/expanded-date-picker.d.ts +43 -43
  100. package/dist/src/expanded-date-picker.js +109 -109
  101. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  102. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  103. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  104. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  105. package/dist/src/manage/manage-bar.d.ts +30 -26
  106. package/dist/src/manage/manage-bar.js +76 -85
  107. package/dist/src/manage/manage-bar.js.map +1 -1
  108. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  109. package/dist/src/mediatype/mediatype-config.js +91 -91
  110. package/dist/src/models.d.ts +198 -198
  111. package/dist/src/models.js +381 -381
  112. package/dist/src/restoration-state-handler.d.ts +70 -70
  113. package/dist/src/restoration-state-handler.js +357 -357
  114. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  115. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  116. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  117. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  118. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  119. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  120. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  121. package/dist/src/sort-filter-bar/img/list.js +2 -2
  122. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  123. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  124. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  125. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  126. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  127. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  128. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  129. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  130. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  131. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  132. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +219 -221
  133. package/dist/src/sort-filter-bar/sort-filter-bar.js +685 -695
  134. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  135. package/dist/src/styles/ia-button.d.ts +2 -0
  136. package/dist/src/styles/ia-button.js +102 -0
  137. package/dist/src/styles/ia-button.js.map +1 -0
  138. package/dist/src/styles/item-image-styles.d.ts +8 -8
  139. package/dist/src/styles/item-image-styles.js +9 -9
  140. package/dist/src/styles/sr-only.d.ts +1 -1
  141. package/dist/src/styles/sr-only.js +2 -2
  142. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  143. package/dist/src/tiles/base-tile-component.js +63 -63
  144. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  145. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  146. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  147. package/dist/src/tiles/grid/account-tile.js +72 -72
  148. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  149. package/dist/src/tiles/grid/collection-tile.js +80 -80
  150. package/dist/src/tiles/grid/item-tile.d.ts +30 -30
  151. package/dist/src/tiles/grid/item-tile.js +149 -149
  152. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  153. package/dist/src/tiles/grid/search-tile.js +51 -51
  154. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  155. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  156. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  157. package/dist/src/tiles/grid/tile-stats.js +53 -53
  158. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  159. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  160. package/dist/src/tiles/hover/tile-hover-pane.d.ts +15 -15
  161. package/dist/src/tiles/hover/tile-hover-pane.js +38 -38
  162. package/dist/src/tiles/image-block.d.ts +17 -17
  163. package/dist/src/tiles/image-block.js +73 -73
  164. package/dist/src/tiles/item-image.d.ts +39 -39
  165. package/dist/src/tiles/item-image.js +154 -154
  166. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  167. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  168. package/dist/src/tiles/list/tile-list-compact.d.ts +15 -15
  169. package/dist/src/tiles/list/tile-list-compact.js +114 -114
  170. package/dist/src/tiles/list/tile-list.d.ts +50 -50
  171. package/dist/src/tiles/list/tile-list.js +315 -315
  172. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  173. package/dist/src/tiles/mediatype-icon.js +47 -47
  174. package/dist/src/tiles/overlay/icon-overlay.d.ts +10 -10
  175. package/dist/src/tiles/overlay/icon-overlay.js +40 -40
  176. package/dist/src/tiles/overlay/icon-text-overlay.d.ts +9 -9
  177. package/dist/src/tiles/overlay/icon-text-overlay.js +38 -38
  178. package/dist/src/tiles/overlay/text-overlay.d.ts +10 -10
  179. package/dist/src/tiles/overlay/text-overlay.js +42 -42
  180. package/dist/src/tiles/review-block.d.ts +12 -12
  181. package/dist/src/tiles/review-block.js +56 -56
  182. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  183. package/dist/src/tiles/text-snippet-block.js +73 -73
  184. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  185. package/dist/src/tiles/tile-dispatcher.js +230 -233
  186. package/dist/src/tiles/tile-dispatcher.js.map +1 -1
  187. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  188. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  189. package/dist/src/utils/analytics-events.d.ts +25 -25
  190. package/dist/src/utils/analytics-events.js +27 -27
  191. package/dist/src/utils/array-equals.d.ts +4 -4
  192. package/dist/src/utils/array-equals.js +10 -10
  193. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  194. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  195. package/dist/src/utils/format-count.d.ts +7 -7
  196. package/dist/src/utils/format-count.js +76 -76
  197. package/dist/src/utils/format-date.d.ts +2 -2
  198. package/dist/src/utils/format-date.js +25 -25
  199. package/dist/src/utils/format-unit-size.d.ts +2 -2
  200. package/dist/src/utils/format-unit-size.js +33 -33
  201. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  202. package/dist/src/utils/local-date-from-utc.js +15 -15
  203. package/dist/src/utils/log.d.ts +7 -7
  204. package/dist/src/utils/log.js +15 -15
  205. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  206. package/dist/src/utils/resolve-mediatype.js +23 -23
  207. package/dist/src/utils/sha1.d.ts +2 -2
  208. package/dist/src/utils/sha1.js +8 -8
  209. package/dist/test/collection-browser.test.d.ts +1 -1
  210. package/dist/test/collection-browser.test.js +1243 -1215
  211. package/dist/test/collection-browser.test.js.map +1 -1
  212. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  213. package/dist/test/collection-facets/facet-row.test.js +203 -203
  214. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  215. package/dist/test/collection-facets/facets-template.test.js +105 -105
  216. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  217. package/dist/test/collection-facets/more-facets-content.test.js +133 -133
  218. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  219. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  220. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  221. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  222. package/dist/test/collection-facets.test.d.ts +2 -2
  223. package/dist/test/collection-facets.test.js +652 -652
  224. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  225. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  226. package/dist/test/empty-placeholder.test.d.ts +1 -1
  227. package/dist/test/empty-placeholder.test.js +63 -63
  228. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  229. package/dist/test/expanded-date-picker.test.js +95 -95
  230. package/dist/test/icon-overlay.test.d.ts +1 -1
  231. package/dist/test/icon-overlay.test.js +24 -24
  232. package/dist/test/image-block.test.d.ts +1 -1
  233. package/dist/test/image-block.test.js +48 -48
  234. package/dist/test/item-image.test.d.ts +1 -1
  235. package/dist/test/item-image.test.js +85 -85
  236. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  237. package/dist/test/manage/manage-bar.test.js +77 -72
  238. package/dist/test/manage/manage-bar.test.js.map +1 -1
  239. package/dist/test/mediatype-config.test.d.ts +1 -1
  240. package/dist/test/mediatype-config.test.js +16 -16
  241. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  242. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  243. package/dist/test/mocks/mock-search-responses.d.ts +24 -24
  244. package/dist/test/mocks/mock-search-responses.js +840 -840
  245. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  246. package/dist/test/mocks/mock-search-service.js +53 -53
  247. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  248. package/dist/test/restoration-state-handler.test.js +270 -270
  249. package/dist/test/review-block.test.d.ts +1 -1
  250. package/dist/test/review-block.test.js +44 -44
  251. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  252. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  253. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  254. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  255. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  256. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +420 -420
  257. package/dist/test/text-overlay.test.d.ts +1 -1
  258. package/dist/test/text-overlay.test.js +48 -48
  259. package/dist/test/text-snippet-block.test.d.ts +1 -1
  260. package/dist/test/text-snippet-block.test.js +57 -57
  261. package/dist/test/tile-stats.test.d.ts +1 -1
  262. package/dist/test/tile-stats.test.js +81 -81
  263. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  264. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  265. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  266. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  267. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  268. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  269. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  270. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  271. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  272. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  273. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  274. package/dist/test/tiles/hover/tile-hover-pane.test.js +13 -13
  275. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  276. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  277. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  278. package/dist/test/tiles/list/tile-list.test.js +297 -297
  279. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  280. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  281. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  282. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  283. package/dist/test/utils/array-equals.test.d.ts +1 -1
  284. package/dist/test/utils/array-equals.test.js +26 -26
  285. package/dist/test/utils/format-count.test.d.ts +1 -1
  286. package/dist/test/utils/format-count.test.js +23 -23
  287. package/dist/test/utils/format-date.test.d.ts +1 -1
  288. package/dist/test/utils/format-date.test.js +17 -17
  289. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  290. package/dist/test/utils/format-unit-size.test.js +17 -17
  291. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  292. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  293. package/local.archive.org.cert +86 -86
  294. package/local.archive.org.key +27 -27
  295. package/package.json +1 -1
  296. package/renovate.json +6 -6
  297. package/src/app-root.ts +25 -59
  298. package/src/collection-browser.ts +7 -9
  299. package/src/manage/manage-bar.ts +22 -33
  300. package/src/sort-filter-bar/sort-filter-bar.ts +1 -10
  301. package/src/styles/ia-button.ts +107 -0
  302. package/src/tiles/tile-dispatcher.ts +1 -3
  303. package/test/collection-browser.test.ts +38 -0
  304. package/test/manage/manage-bar.test.ts +5 -0
  305. package/tsconfig.json +21 -21
  306. package/web-dev-server.config.mjs +30 -30
  307. package/web-test-runner.config.mjs +41 -41
@@ -1,221 +1,219 @@
1
- import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
- import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
3
- import '@internetarchive/ia-dropdown';
4
- import type { SortDirection } from '@internetarchive/search-service';
5
- import { CollectionDisplayMode, PrefixFilterCounts, PrefixFilterType, SortField } from '../models';
6
- import './alpha-bar';
7
- declare type AlphaSelector = 'creator' | 'title';
8
- export declare class SortFilterBar extends LitElement implements SharedResizeObserverResizeHandlerInterface {
9
- /** Which display mode the tiles are being rendered with (grid/list-detail/list-compact) */
10
- displayMode?: CollectionDisplayMode;
11
- /** The default sort direction to use if none is set */
12
- defaultSortDirection: SortDirection | null;
13
- /** The default sort field to use if none is set */
14
- defaultSortField: Exclude<SortField, SortField.default>;
15
- /** The current sort direction (asc/desc), or null if none is set */
16
- sortDirection: SortDirection | null;
17
- /** The field currently being sorted on (e.g., 'title'). Defaults to relevance. */
18
- selectedSort: SortField;
19
- /** The currently selected title letter filter, or null if none is set */
20
- selectedTitleFilter: string | null;
21
- /** The currently selected creator letter filter, or null if none is set */
22
- selectedCreatorFilter: string | null;
23
- /** Whether to show the Relevance sort option (default `true`) */
24
- showRelevance: boolean;
25
- /** Whether to show the Date Favorited sort option instead of Date Published/Archived/Reviewed (default `false`) */
26
- showDateFavorited: boolean;
27
- /** Whether to replace the default sort options with a slot for customization (default `false`) */
28
- enableSortOptionsSlot: boolean;
29
- /** Whether to suppress showing the three display mode options on the right of the bar (default `false`) */
30
- suppressDisplayModes: boolean;
31
- /** Maps of result counts for letters on the alphabet bar, for each letter filter type */
32
- prefixFilterCountMap?: Record<PrefixFilterType, PrefixFilterCounts>;
33
- resizeObserver?: SharedResizeObserverInterface;
34
- /**
35
- * The Views sort option that was most recently selected (or the default, if none has been selected yet)
36
- */
37
- private lastSelectedViewSort;
38
- /**
39
- * The Date sort option that was most recently selected (or the default, if none has been selected yet)
40
- */
41
- private lastSelectedDateSort;
42
- /**
43
- * Which of the alphabet bars (title/creator) should be shown, or null if one
44
- * should not currently be rendered.
45
- */
46
- alphaSelectorVisible: AlphaSelector | null;
47
- /**
48
- * Whether the transparent backdrop to catch clicks outside the dropdown menu
49
- * should be rendered.
50
- */
51
- dropdownBackdropVisible: boolean;
52
- /**
53
- * The width of the desktop view sort option container, updated upon each resize.
54
- * Used for dynamically determining whether to use desktop or mobile view.
55
- */
56
- desktopSortContainerWidth: number;
57
- /**
58
- * The width of the full sort bar, updated upon each resize.
59
- * Used for dynamically determining whether to use desktop or mobile view.
60
- */
61
- selectorBarContainerWidth: number;
62
- /**
63
- * The container for all the desktop view's sort options.
64
- * Used for dynamically determining whether to use desktop or mobile view.
65
- */
66
- private desktopSortContainer;
67
- /**
68
- * The container for the full sort bar.
69
- * Used for dynamically determining whether to use desktop or mobile view.
70
- */
71
- private sortSelectorContainer;
72
- /** The dropdown component containing options for weekly and all-time views */
73
- private viewsDropdown;
74
- /** The dropdown component containing the four date options */
75
- private dateDropdown;
76
- /** The single, consolidated dropdown component shown in mobile view */
77
- private mobileDropdown;
78
- render(): TemplateResult<1>;
79
- willUpdate(changed: PropertyValues): void;
80
- updated(changed: PropertyValues): void;
81
- private setupEscapeListeners;
82
- private boundSortBarSelectorEscapeListener;
83
- disconnectedCallback(): void;
84
- private disconnectResizeObserver;
85
- private setupResizeObserver;
86
- handleResize(entry: ResizeObserverEntry): void;
87
- /**
88
- * Whether to show the mobile sort bar because there is not enough space
89
- * for the desktop sort bar.
90
- */
91
- private get mobileSelectorVisible();
92
- /**
93
- * Template to render the alphabet bar, or `nothing` if it should not be rendered
94
- * for the current sort
95
- */
96
- private get alphaBarTemplate();
97
- /** Template to render the sort direction toggle button */
98
- private get sortDirectionSelectorTemplate();
99
- /** Template to render the sort direction button's icon in the correct current state */
100
- private get sortDirectionIcon();
101
- /** The template to render all the sort options in desktop view */
102
- private get desktopSortSelectorTemplate();
103
- /** The template to render all the sort options in mobile view */
104
- private get mobileSortSelectorTemplate();
105
- /**
106
- * This generates each of the non-dropdown sort option links.
107
- *
108
- * It manages the display value and the selected state of the option.
109
- *
110
- * @param sortField
111
- * @param options {
112
- * onClick?: (e: Event) => void; If this is provided, it will also be called when the option is clicked.
113
- * displayName?: TemplateResult; The name to display for the option. Defaults to the sortField display name.
114
- * selected?: boolean; true if the option is selected. Defaults to the selectedSort === sortField.
115
- * }
116
- * @returns
117
- */
118
- private getSortDisplayOption;
119
- /**
120
- * Generates a dropdown component containing multiple grouped sort options.
121
- *
122
- * @param options.displayName The name to use for the dropdown's visible label
123
- * @param options.id The id to apply to the dropdown element
124
- * @param options.dropdownOptions An array of option objects used to populate the dropdown
125
- * @param options.selectedOption The id of the option that should be initially selected
126
- * @param options.selected A boolean indicating whether this dropdown should use its
127
- * selected appearance
128
- * @param options.onOptionSelected A handler for optionSelected events coming from the dropdown
129
- * @param options.onDropdownClick A handler for click events on the dropdown
130
- * @param options.onLabelInteraction A handler for click events and Enter/Space keydown events
131
- * on the dropdown's label
132
- */
133
- private getSortDropdown;
134
- /** Generates a single dropdown option object for the given sort field */
135
- private getDropdownOption;
136
- /** Handler for when any sort dropdown option is selected */
137
- private dropdownOptionSelected;
138
- /** The template to render for the views dropdown */
139
- private get viewsDropdownTemplate();
140
- /** The template to render for the date dropdown */
141
- private get dateDropdownTemplate();
142
- /** Handler for when a new mobile sort dropdown option is selected */
143
- private mobileSortChanged;
144
- /** Template for rendering the three display mode options */
145
- private get displayOptionTemplate();
146
- /**
147
- * Template for rendering the transparent backdrop to capture clicks outside the
148
- * dropdown menu while it is open.
149
- */
150
- private get dropdownBackdrop();
151
- /** Closes all of the sorting dropdown components' menus */
152
- private closeDropdowns;
153
- private selectDropdownSortField;
154
- private clearAlphaBarFilters;
155
- private setSortDirection;
156
- /** Toggles the current sort direction between 'asc' and 'desc' */
157
- private toggleSortDirection;
158
- private handleSortDirectionClicked;
159
- private setSelectedSort;
160
- /** The current sort field, or the default one if no explicit sort is set */
161
- private get finalizedSortField();
162
- /** The current sort direction, or the default one if no explicit direction is set */
163
- private get finalizedSortDirection();
164
- /** Whether the sort direction button should be enabled for the current sort */
165
- private get canChangeSortDirection();
166
- /**
167
- * There are four date sort options.
168
- *
169
- * This checks to see if the current sort is one of them.
170
- *
171
- * @readonly
172
- * @private
173
- * @type {boolean}
174
- * @memberof SortFilterBar
175
- */
176
- private get dateOptionSelected();
177
- /**
178
- * There are two view sort options.
179
- *
180
- * This checks to see if the current sort is one of them.
181
- *
182
- * @readonly
183
- * @private
184
- * @type {boolean}
185
- * @memberof SortFilterBar
186
- */
187
- private get viewOptionSelected();
188
- /**
189
- * The default field for the date sort dropdown.
190
- * This is Date Favorited when that option is available, or Date Published otherwise.
191
- */
192
- private get defaultDateSortField();
193
- /**
194
- * The display name of the last selected date field
195
- *
196
- * @readonly
197
- * @private
198
- * @type {string}
199
- * @memberof SortFilterBar
200
- */
201
- private get dateSortDisplayName();
202
- /**
203
- * The display name of the last selected view field
204
- *
205
- * @readonly
206
- * @private
207
- * @type {string}
208
- * @memberof SortFilterBar
209
- */
210
- private get viewSortDisplayName();
211
- private get titleSelectorBar();
212
- private get creatorSelectorBar();
213
- private titleLetterChanged;
214
- private creatorLetterChanged;
215
- private emitTitleLetterChangedEvent;
216
- private emitCreatorLetterChangedEvent;
217
- private displayModeChanged;
218
- private emitSortChangedEvent;
219
- static get styles(): import("lit").CSSResult[];
220
- }
221
- export {};
1
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
3
+ import '@internetarchive/ia-dropdown';
4
+ import type { SortDirection } from '@internetarchive/search-service';
5
+ import { CollectionDisplayMode, PrefixFilterCounts, PrefixFilterType, SortField } from '../models';
6
+ import './alpha-bar';
7
+ declare type AlphaSelector = 'creator' | 'title';
8
+ export declare class SortFilterBar extends LitElement implements SharedResizeObserverResizeHandlerInterface {
9
+ /** Which display mode the tiles are being rendered with (grid/list-detail/list-compact) */
10
+ displayMode?: CollectionDisplayMode;
11
+ /** The default sort direction to use if none is set */
12
+ defaultSortDirection: SortDirection | null;
13
+ /** The default sort field to use if none is set */
14
+ defaultSortField: Exclude<SortField, SortField.default>;
15
+ /** The current sort direction (asc/desc), or null if none is set */
16
+ sortDirection: SortDirection | null;
17
+ /** The field currently being sorted on (e.g., 'title'). Defaults to relevance. */
18
+ selectedSort: SortField;
19
+ /** The currently selected title letter filter, or null if none is set */
20
+ selectedTitleFilter: string | null;
21
+ /** The currently selected creator letter filter, or null if none is set */
22
+ selectedCreatorFilter: string | null;
23
+ /** Whether to show the Relevance sort option (default `true`) */
24
+ showRelevance: boolean;
25
+ /** Whether to show the Date Favorited sort option instead of Date Published/Archived/Reviewed (default `false`) */
26
+ showDateFavorited: boolean;
27
+ /** Whether to replace the default sort options with a slot for customization (default `false`) */
28
+ enableSortOptionsSlot: boolean;
29
+ /** Maps of result counts for letters on the alphabet bar, for each letter filter type */
30
+ prefixFilterCountMap?: Record<PrefixFilterType, PrefixFilterCounts>;
31
+ resizeObserver?: SharedResizeObserverInterface;
32
+ /**
33
+ * The Views sort option that was most recently selected (or the default, if none has been selected yet)
34
+ */
35
+ private lastSelectedViewSort;
36
+ /**
37
+ * The Date sort option that was most recently selected (or the default, if none has been selected yet)
38
+ */
39
+ private lastSelectedDateSort;
40
+ /**
41
+ * Which of the alphabet bars (title/creator) should be shown, or null if one
42
+ * should not currently be rendered.
43
+ */
44
+ alphaSelectorVisible: AlphaSelector | null;
45
+ /**
46
+ * Whether the transparent backdrop to catch clicks outside the dropdown menu
47
+ * should be rendered.
48
+ */
49
+ dropdownBackdropVisible: boolean;
50
+ /**
51
+ * The width of the desktop view sort option container, updated upon each resize.
52
+ * Used for dynamically determining whether to use desktop or mobile view.
53
+ */
54
+ desktopSortContainerWidth: number;
55
+ /**
56
+ * The width of the full sort bar, updated upon each resize.
57
+ * Used for dynamically determining whether to use desktop or mobile view.
58
+ */
59
+ selectorBarContainerWidth: number;
60
+ /**
61
+ * The container for all the desktop view's sort options.
62
+ * Used for dynamically determining whether to use desktop or mobile view.
63
+ */
64
+ private desktopSortContainer;
65
+ /**
66
+ * The container for the full sort bar.
67
+ * Used for dynamically determining whether to use desktop or mobile view.
68
+ */
69
+ private sortSelectorContainer;
70
+ /** The dropdown component containing options for weekly and all-time views */
71
+ private viewsDropdown;
72
+ /** The dropdown component containing the four date options */
73
+ private dateDropdown;
74
+ /** The single, consolidated dropdown component shown in mobile view */
75
+ private mobileDropdown;
76
+ render(): TemplateResult<1>;
77
+ willUpdate(changed: PropertyValues): void;
78
+ updated(changed: PropertyValues): void;
79
+ private setupEscapeListeners;
80
+ private boundSortBarSelectorEscapeListener;
81
+ disconnectedCallback(): void;
82
+ private disconnectResizeObserver;
83
+ private setupResizeObserver;
84
+ handleResize(entry: ResizeObserverEntry): void;
85
+ /**
86
+ * Whether to show the mobile sort bar because there is not enough space
87
+ * for the desktop sort bar.
88
+ */
89
+ private get mobileSelectorVisible();
90
+ /**
91
+ * Template to render the alphabet bar, or `nothing` if it should not be rendered
92
+ * for the current sort
93
+ */
94
+ private get alphaBarTemplate();
95
+ /** Template to render the sort direction toggle button */
96
+ private get sortDirectionSelectorTemplate();
97
+ /** Template to render the sort direction button's icon in the correct current state */
98
+ private get sortDirectionIcon();
99
+ /** The template to render all the sort options in desktop view */
100
+ private get desktopSortSelectorTemplate();
101
+ /** The template to render all the sort options in mobile view */
102
+ private get mobileSortSelectorTemplate();
103
+ /**
104
+ * This generates each of the non-dropdown sort option links.
105
+ *
106
+ * It manages the display value and the selected state of the option.
107
+ *
108
+ * @param sortField
109
+ * @param options {
110
+ * onClick?: (e: Event) => void; If this is provided, it will also be called when the option is clicked.
111
+ * displayName?: TemplateResult; The name to display for the option. Defaults to the sortField display name.
112
+ * selected?: boolean; true if the option is selected. Defaults to the selectedSort === sortField.
113
+ * }
114
+ * @returns
115
+ */
116
+ private getSortDisplayOption;
117
+ /**
118
+ * Generates a dropdown component containing multiple grouped sort options.
119
+ *
120
+ * @param options.displayName The name to use for the dropdown's visible label
121
+ * @param options.id The id to apply to the dropdown element
122
+ * @param options.dropdownOptions An array of option objects used to populate the dropdown
123
+ * @param options.selectedOption The id of the option that should be initially selected
124
+ * @param options.selected A boolean indicating whether this dropdown should use its
125
+ * selected appearance
126
+ * @param options.onOptionSelected A handler for optionSelected events coming from the dropdown
127
+ * @param options.onDropdownClick A handler for click events on the dropdown
128
+ * @param options.onLabelInteraction A handler for click events and Enter/Space keydown events
129
+ * on the dropdown's label
130
+ */
131
+ private getSortDropdown;
132
+ /** Generates a single dropdown option object for the given sort field */
133
+ private getDropdownOption;
134
+ /** Handler for when any sort dropdown option is selected */
135
+ private dropdownOptionSelected;
136
+ /** The template to render for the views dropdown */
137
+ private get viewsDropdownTemplate();
138
+ /** The template to render for the date dropdown */
139
+ private get dateDropdownTemplate();
140
+ /** Handler for when a new mobile sort dropdown option is selected */
141
+ private mobileSortChanged;
142
+ /** Template for rendering the three display mode options */
143
+ private get displayOptionTemplate();
144
+ /**
145
+ * Template for rendering the transparent backdrop to capture clicks outside the
146
+ * dropdown menu while it is open.
147
+ */
148
+ private get dropdownBackdrop();
149
+ /** Closes all of the sorting dropdown components' menus */
150
+ private closeDropdowns;
151
+ private selectDropdownSortField;
152
+ private clearAlphaBarFilters;
153
+ private setSortDirection;
154
+ /** Toggles the current sort direction between 'asc' and 'desc' */
155
+ private toggleSortDirection;
156
+ private handleSortDirectionClicked;
157
+ private setSelectedSort;
158
+ /** The current sort field, or the default one if no explicit sort is set */
159
+ private get finalizedSortField();
160
+ /** The current sort direction, or the default one if no explicit direction is set */
161
+ private get finalizedSortDirection();
162
+ /** Whether the sort direction button should be enabled for the current sort */
163
+ private get canChangeSortDirection();
164
+ /**
165
+ * There are four date sort options.
166
+ *
167
+ * This checks to see if the current sort is one of them.
168
+ *
169
+ * @readonly
170
+ * @private
171
+ * @type {boolean}
172
+ * @memberof SortFilterBar
173
+ */
174
+ private get dateOptionSelected();
175
+ /**
176
+ * There are two view sort options.
177
+ *
178
+ * This checks to see if the current sort is one of them.
179
+ *
180
+ * @readonly
181
+ * @private
182
+ * @type {boolean}
183
+ * @memberof SortFilterBar
184
+ */
185
+ private get viewOptionSelected();
186
+ /**
187
+ * The default field for the date sort dropdown.
188
+ * This is Date Favorited when that option is available, or Date Published otherwise.
189
+ */
190
+ private get defaultDateSortField();
191
+ /**
192
+ * The display name of the last selected date field
193
+ *
194
+ * @readonly
195
+ * @private
196
+ * @type {string}
197
+ * @memberof SortFilterBar
198
+ */
199
+ private get dateSortDisplayName();
200
+ /**
201
+ * The display name of the last selected view field
202
+ *
203
+ * @readonly
204
+ * @private
205
+ * @type {string}
206
+ * @memberof SortFilterBar
207
+ */
208
+ private get viewSortDisplayName();
209
+ private get titleSelectorBar();
210
+ private get creatorSelectorBar();
211
+ private titleLetterChanged;
212
+ private creatorLetterChanged;
213
+ private emitTitleLetterChangedEvent;
214
+ private emitCreatorLetterChangedEvent;
215
+ private displayModeChanged;
216
+ private emitSortChangedEvent;
217
+ static get styles(): import("lit").CSSResult[];
218
+ }
219
+ export {};