@internetarchive/collection-browser 2.4.1-e2e-test-2 → 2.5.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 (316) hide show
  1. package/.editorconfig +29 -29
  2. package/.husky/pre-commit +4 -4
  3. package/LICENSE +661 -661
  4. package/README.md +83 -83
  5. package/dist/index.d.ts +12 -12
  6. package/dist/index.js +12 -12
  7. package/dist/src/app-root.d.ts +91 -91
  8. package/dist/src/app-root.js +487 -487
  9. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  10. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  11. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  12. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  13. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  14. package/dist/src/assets/img/icons/chevron.js +2 -2
  15. package/dist/src/assets/img/icons/contract.d.ts +2 -2
  16. package/dist/src/assets/img/icons/contract.js +2 -2
  17. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  18. package/dist/src/assets/img/icons/empty-query.js +2 -2
  19. package/dist/src/assets/img/icons/expand.d.ts +2 -2
  20. package/dist/src/assets/img/icons/expand.js +2 -2
  21. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  22. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  23. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  24. package/dist/src/assets/img/icons/eye.js +2 -2
  25. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  26. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  27. package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -1
  28. package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
  29. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  30. package/dist/src/assets/img/icons/login-required.js +2 -2
  31. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  32. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  33. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  34. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  35. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  36. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  37. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  38. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  39. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  40. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  41. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  42. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  43. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  44. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  45. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  46. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  47. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
  48. package/dist/src/assets/img/icons/mediatype/search.js +2 -2
  49. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  50. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  51. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  52. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  53. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  54. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  55. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  56. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  57. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  58. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  59. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  60. package/dist/src/assets/img/icons/null-result.js +2 -2
  61. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  62. package/dist/src/assets/img/icons/restricted.js +2 -2
  63. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  64. package/dist/src/assets/img/icons/reviews.js +2 -2
  65. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  66. package/dist/src/assets/img/icons/upload.js +2 -2
  67. package/dist/src/assets/img/icons/views.d.ts +1 -1
  68. package/dist/src/assets/img/icons/views.js +2 -2
  69. package/dist/src/circular-activity-indicator.d.ts +5 -5
  70. package/dist/src/circular-activity-indicator.js +17 -17
  71. package/dist/src/collection-browser.d.ts +564 -466
  72. package/dist/src/collection-browser.js +1568 -1479
  73. package/dist/src/collection-browser.js.map +1 -1
  74. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  75. package/dist/src/collection-facets/facet-row.js +117 -116
  76. package/dist/src/collection-facets/facet-row.js.map +1 -1
  77. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  78. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  79. package/dist/src/collection-facets/facets-template.d.ts +13 -17
  80. package/dist/src/collection-facets/facets-template.js +46 -144
  81. package/dist/src/collection-facets/facets-template.js.map +1 -1
  82. package/dist/src/collection-facets/more-facets-content.d.ts +106 -74
  83. package/dist/src/collection-facets/more-facets-content.js +424 -377
  84. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  85. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  86. package/dist/src/collection-facets/more-facets-pagination.js +196 -196
  87. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  88. package/dist/src/collection-facets/toggle-switch.js +94 -94
  89. package/dist/src/collection-facets.d.ts +103 -103
  90. package/dist/src/collection-facets.js +514 -514
  91. package/dist/src/collection-facets.js.map +1 -1
  92. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
  93. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  94. package/dist/src/data-source/collection-browser-data-source.d.ts +378 -378
  95. package/dist/src/data-source/collection-browser-data-source.js +985 -985
  96. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  97. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  98. package/dist/src/data-source/models.d.ts +28 -28
  99. package/dist/src/data-source/models.js +8 -8
  100. package/dist/src/empty-placeholder.d.ts +23 -23
  101. package/dist/src/empty-placeholder.js +74 -74
  102. package/dist/src/expanded-date-picker.d.ts +43 -43
  103. package/dist/src/expanded-date-picker.js +109 -109
  104. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  105. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  106. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  107. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  108. package/dist/src/manage/manage-bar.d.ts +30 -30
  109. package/dist/src/manage/manage-bar.js +61 -61
  110. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  111. package/dist/src/mediatype/mediatype-config.js +91 -91
  112. package/dist/src/models.d.ts +209 -209
  113. package/dist/src/models.js +381 -381
  114. package/dist/src/restoration-state-handler.d.ts +70 -70
  115. package/dist/src/restoration-state-handler.js +357 -357
  116. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  117. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  118. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  119. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  120. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  121. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  122. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  123. package/dist/src/sort-filter-bar/img/list.js +2 -2
  124. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  125. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  126. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  127. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  128. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  129. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  130. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  131. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  132. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  133. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  134. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +222 -222
  135. package/dist/src/sort-filter-bar/sort-filter-bar.js +696 -696
  136. package/dist/src/styles/ia-button.d.ts +2 -2
  137. package/dist/src/styles/ia-button.js +16 -16
  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 +18 -18
  161. package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
  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 +229 -229
  186. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  187. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  188. package/dist/src/utils/analytics-events.d.ts +28 -28
  189. package/dist/src/utils/analytics-events.js +30 -30
  190. package/dist/src/utils/array-equals.d.ts +4 -4
  191. package/dist/src/utils/array-equals.js +10 -10
  192. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  193. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  194. package/dist/src/utils/facet-utils.d.ts +83 -0
  195. package/dist/src/utils/facet-utils.js +146 -0
  196. package/dist/src/utils/facet-utils.js.map +1 -0
  197. package/dist/src/utils/format-count.d.ts +7 -7
  198. package/dist/src/utils/format-count.js +76 -76
  199. package/dist/src/utils/format-date.d.ts +2 -2
  200. package/dist/src/utils/format-date.js +25 -25
  201. package/dist/src/utils/format-unit-size.d.ts +2 -2
  202. package/dist/src/utils/format-unit-size.js +33 -33
  203. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  204. package/dist/src/utils/local-date-from-utc.js +15 -15
  205. package/dist/src/utils/log.d.ts +7 -7
  206. package/dist/src/utils/log.js +15 -15
  207. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  208. package/dist/src/utils/resolve-mediatype.js +23 -23
  209. package/dist/src/utils/sha1.d.ts +2 -2
  210. package/dist/src/utils/sha1.js +8 -8
  211. package/dist/test/collection-browser.test.d.ts +1 -1
  212. package/dist/test/collection-browser.test.js +1294 -1293
  213. package/dist/test/collection-browser.test.js.map +1 -1
  214. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  215. package/dist/test/collection-facets/facet-row.test.js +227 -203
  216. package/dist/test/collection-facets/facet-row.test.js.map +1 -1
  217. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  218. package/dist/test/collection-facets/facets-template.test.js +91 -114
  219. package/dist/test/collection-facets/facets-template.test.js.map +1 -1
  220. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  221. package/dist/test/collection-facets/more-facets-content.test.js +150 -141
  222. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
  223. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  224. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  225. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  226. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  227. package/dist/test/collection-facets.test.d.ts +2 -2
  228. package/dist/test/collection-facets.test.js +652 -652
  229. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  230. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  231. package/dist/test/empty-placeholder.test.d.ts +1 -1
  232. package/dist/test/empty-placeholder.test.js +63 -63
  233. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  234. package/dist/test/expanded-date-picker.test.js +95 -95
  235. package/dist/test/icon-overlay.test.d.ts +1 -1
  236. package/dist/test/icon-overlay.test.js +24 -24
  237. package/dist/test/image-block.test.d.ts +1 -1
  238. package/dist/test/image-block.test.js +48 -48
  239. package/dist/test/item-image.test.d.ts +1 -1
  240. package/dist/test/item-image.test.js +85 -85
  241. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  242. package/dist/test/manage/manage-bar.test.js +81 -81
  243. package/dist/test/mediatype-config.test.d.ts +1 -1
  244. package/dist/test/mediatype-config.test.js +16 -16
  245. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  246. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  247. package/dist/test/mocks/mock-search-responses.d.ts +25 -24
  248. package/dist/test/mocks/mock-search-responses.js +942 -860
  249. package/dist/test/mocks/mock-search-responses.js.map +1 -1
  250. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  251. package/dist/test/mocks/mock-search-service.js +54 -53
  252. package/dist/test/mocks/mock-search-service.js.map +1 -1
  253. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  254. package/dist/test/restoration-state-handler.test.js +270 -270
  255. package/dist/test/review-block.test.d.ts +1 -1
  256. package/dist/test/review-block.test.js +44 -44
  257. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  258. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  259. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  260. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  261. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  262. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  263. package/dist/test/text-overlay.test.d.ts +1 -1
  264. package/dist/test/text-overlay.test.js +48 -48
  265. package/dist/test/text-snippet-block.test.d.ts +1 -1
  266. package/dist/test/text-snippet-block.test.js +57 -57
  267. package/dist/test/tile-stats.test.d.ts +1 -1
  268. package/dist/test/tile-stats.test.js +81 -81
  269. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  270. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  271. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  272. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  273. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  274. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  275. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  276. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  277. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  278. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  279. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  280. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  281. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  282. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  283. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  284. package/dist/test/tiles/list/tile-list.test.js +297 -297
  285. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  286. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  287. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  288. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  289. package/dist/test/utils/array-equals.test.d.ts +1 -1
  290. package/dist/test/utils/array-equals.test.js +26 -26
  291. package/dist/test/utils/format-count.test.d.ts +1 -1
  292. package/dist/test/utils/format-count.test.js +23 -23
  293. package/dist/test/utils/format-date.test.d.ts +1 -1
  294. package/dist/test/utils/format-date.test.js +17 -17
  295. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  296. package/dist/test/utils/format-unit-size.test.js +17 -17
  297. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  298. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  299. package/local.archive.org.cert +86 -86
  300. package/local.archive.org.key +27 -27
  301. package/package.json +1 -1
  302. package/renovate.json +6 -6
  303. package/src/collection-browser.ts +106 -19
  304. package/src/collection-facets/facet-row.ts +5 -4
  305. package/src/collection-facets/facets-template.ts +10 -114
  306. package/src/collection-facets/more-facets-content.ts +219 -144
  307. package/src/collection-facets.ts +24 -12
  308. package/src/utils/facet-utils.ts +181 -0
  309. package/test/collection-browser.test.ts +1 -0
  310. package/test/collection-facets/facet-row.test.ts +30 -6
  311. package/test/collection-facets/facets-template.test.ts +6 -32
  312. package/test/collection-facets/more-facets-content.test.ts +46 -35
  313. package/test/mocks/mock-search-responses.ts +86 -0
  314. package/test/mocks/mock-search-service.ts +2 -0
  315. package/web-dev-server.config.mjs +30 -30
  316. package/web-test-runner.config.mjs +41 -41
@@ -1,29 +1,29 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, nothing } from 'lit';
3
- import { customElement } from 'lit/decorators.js';
4
- import DOMPurify from 'dompurify';
5
- import { BaseTileComponent } from '../base-tile-component';
6
- import { formatCount } from '../../utils/format-count';
7
- import { formatDate } from '../../utils/format-date';
8
- import { isFirstMillisecondOfUTCYear } from '../../utils/local-date-from-utc';
9
- import '../image-block';
10
- import '../mediatype-icon';
11
- let TileListCompact = class TileListCompact extends BaseTileComponent {
12
- /*
13
- * Reactive properties inherited from BaseTileComponent:
14
- * - model?: TileModel;
15
- * - currentWidth?: number;
16
- * - currentHeight?: number;
17
- * - baseNavigationUrl?: string;
18
- * - baseImageUrl?: string;
19
- * - collectionPagePath?: string;
20
- * - sortParam: SortParam | null = null;
21
- * - creatorFilter?: string;
22
- * - mobileBreakpoint?: number;
23
- * - loggedIn = false;
24
- */
25
- render() {
26
- var _a, _b, _c, _d, _e, _f;
1
+ import { __decorate } from "tslib";
2
+ import { css, html, nothing } from 'lit';
3
+ import { customElement } from 'lit/decorators.js';
4
+ import DOMPurify from 'dompurify';
5
+ import { BaseTileComponent } from '../base-tile-component';
6
+ import { formatCount } from '../../utils/format-count';
7
+ import { formatDate } from '../../utils/format-date';
8
+ import { isFirstMillisecondOfUTCYear } from '../../utils/local-date-from-utc';
9
+ import '../image-block';
10
+ import '../mediatype-icon';
11
+ let TileListCompact = class TileListCompact extends BaseTileComponent {
12
+ /*
13
+ * Reactive properties inherited from BaseTileComponent:
14
+ * - model?: TileModel;
15
+ * - currentWidth?: number;
16
+ * - currentHeight?: number;
17
+ * - baseNavigationUrl?: string;
18
+ * - baseImageUrl?: string;
19
+ * - collectionPagePath?: string;
20
+ * - sortParam: SortParam | null = null;
21
+ * - creatorFilter?: string;
22
+ * - mobileBreakpoint?: number;
23
+ * - loggedIn = false;
24
+ */
25
+ render() {
26
+ var _a, _b, _c, _d, _e, _f;
27
27
  return html `
28
28
  <div id="list-line" class="${this.classSize}">
29
29
  <image-block
@@ -39,8 +39,8 @@ let TileListCompact = class TileListCompact extends BaseTileComponent {
39
39
  >${DOMPurify.sanitize((_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.title) !== null && _b !== void 0 ? _b : '')}</a
40
40
  >
41
41
  <div id="creator">
42
- ${((_c = this.model) === null || _c === void 0 ? void 0 : _c.mediatype) === 'account'
43
- ? this.displayValueProvider.accountLabel
42
+ ${((_c = this.model) === null || _c === void 0 ? void 0 : _c.mediatype) === 'account'
43
+ ? this.displayValueProvider.accountLabel
44
44
  : this.creator}
45
45
  </div>
46
46
  <div id="date">${formatDate(this.date, this.dateFormatSize)}</div>
@@ -53,85 +53,85 @@ let TileListCompact = class TileListCompact extends BaseTileComponent {
53
53
  </div>
54
54
  <div id="views">${formatCount((_f = this.views) !== null && _f !== void 0 ? _f : 0, this.formatSize)}</div>
55
55
  </div>
56
- `;
57
- }
58
- get href() {
59
- var _a;
60
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.identifier) || this.baseNavigationUrl == null)
61
- return nothing;
62
- // Use the server-specified href if available.
63
- // Otherwise, construct a details page URL from the item identifier.
64
- if (this.model.href) {
65
- return `${this.baseNavigationUrl}${this.model.href}`;
66
- }
67
- return this.displayValueProvider.itemPageUrl(this.model.identifier, this.model.mediatype === 'collection');
68
- }
69
- get creator() {
70
- var _a;
71
- return (_a = this.displayValueProvider.firstCreatorMatchingFilter) !== null && _a !== void 0 ? _a : nothing;
72
- }
73
- /*
74
- * TODO: fix field names to match model in src/collection-browser.ts
75
- * private get dateSortSelector()
76
- * @see src/models.ts
77
- */
78
- get date() {
79
- var _a, _b, _c, _d, _e;
80
- // Note on 'publicdate' vs. 'date':
81
- // The search engine metadata uses 'publicdate' as the key for the date the item
82
- // was created on archive.org, which in the UI is referred to as "Date Archived".
83
- // In contrast, the search engine metadata uses 'date' to refer to the actual
84
- // publication date of the underlying media ("Date Published" in the UI).
85
- // Refer to the full metadata schema for more info.
86
- switch ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) {
87
- case 'publicdate':
88
- return (_b = this.model) === null || _b === void 0 ? void 0 : _b.dateArchived;
89
- case 'reviewdate':
90
- return (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateReviewed;
91
- case 'addeddate':
92
- return (_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded;
93
- default:
94
- return (_e = this.model) === null || _e === void 0 ? void 0 : _e.datePublished;
95
- }
96
- }
97
- get views() {
98
- var _a, _b, _c;
99
- return ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) === 'week'
100
- ? (_b = this.model) === null || _b === void 0 ? void 0 : _b.weeklyViewCount // weekly views
101
- : (_c = this.model) === null || _c === void 0 ? void 0 : _c.viewCount; // all-time views
102
- }
103
- get classSize() {
104
- if (this.mobileBreakpoint &&
105
- this.currentWidth &&
106
- this.currentWidth < this.mobileBreakpoint) {
107
- return 'mobile';
108
- }
109
- return 'desktop';
110
- }
111
- get dateFormatSize() {
112
- var _a, _b;
113
- // If we're showing a date published of Jan 1 at midnight, only show the year.
114
- // This is because items with only a year for their publication date are normalized to
115
- // Jan 1 at midnight timestamps in the search engine documents.
116
- if ((!this.isSortedByDate || ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) === 'date') && // Any sort except dates that aren't published date
117
- isFirstMillisecondOfUTCYear((_b = this.model) === null || _b === void 0 ? void 0 : _b.datePublished)) {
118
- return 'year-only';
119
- }
120
- return this.formatSize;
121
- }
122
- get formatSize() {
123
- if (this.mobileBreakpoint &&
124
- this.currentWidth &&
125
- this.currentWidth < this.mobileBreakpoint) {
126
- return 'short';
127
- }
128
- return 'long';
129
- }
130
- get isSortedByDate() {
131
- var _a;
132
- return ['date', 'reviewdate', 'addeddate', 'publicdate'].includes((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field);
133
- }
134
- static get styles() {
56
+ `;
57
+ }
58
+ get href() {
59
+ var _a;
60
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.identifier) || this.baseNavigationUrl == null)
61
+ return nothing;
62
+ // Use the server-specified href if available.
63
+ // Otherwise, construct a details page URL from the item identifier.
64
+ if (this.model.href) {
65
+ return `${this.baseNavigationUrl}${this.model.href}`;
66
+ }
67
+ return this.displayValueProvider.itemPageUrl(this.model.identifier, this.model.mediatype === 'collection');
68
+ }
69
+ get creator() {
70
+ var _a;
71
+ return (_a = this.displayValueProvider.firstCreatorMatchingFilter) !== null && _a !== void 0 ? _a : nothing;
72
+ }
73
+ /*
74
+ * TODO: fix field names to match model in src/collection-browser.ts
75
+ * private get dateSortSelector()
76
+ * @see src/models.ts
77
+ */
78
+ get date() {
79
+ var _a, _b, _c, _d, _e;
80
+ // Note on 'publicdate' vs. 'date':
81
+ // The search engine metadata uses 'publicdate' as the key for the date the item
82
+ // was created on archive.org, which in the UI is referred to as "Date Archived".
83
+ // In contrast, the search engine metadata uses 'date' to refer to the actual
84
+ // publication date of the underlying media ("Date Published" in the UI).
85
+ // Refer to the full metadata schema for more info.
86
+ switch ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) {
87
+ case 'publicdate':
88
+ return (_b = this.model) === null || _b === void 0 ? void 0 : _b.dateArchived;
89
+ case 'reviewdate':
90
+ return (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateReviewed;
91
+ case 'addeddate':
92
+ return (_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded;
93
+ default:
94
+ return (_e = this.model) === null || _e === void 0 ? void 0 : _e.datePublished;
95
+ }
96
+ }
97
+ get views() {
98
+ var _a, _b, _c;
99
+ return ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) === 'week'
100
+ ? (_b = this.model) === null || _b === void 0 ? void 0 : _b.weeklyViewCount // weekly views
101
+ : (_c = this.model) === null || _c === void 0 ? void 0 : _c.viewCount; // all-time views
102
+ }
103
+ get classSize() {
104
+ if (this.mobileBreakpoint &&
105
+ this.currentWidth &&
106
+ this.currentWidth < this.mobileBreakpoint) {
107
+ return 'mobile';
108
+ }
109
+ return 'desktop';
110
+ }
111
+ get dateFormatSize() {
112
+ var _a, _b;
113
+ // If we're showing a date published of Jan 1 at midnight, only show the year.
114
+ // This is because items with only a year for their publication date are normalized to
115
+ // Jan 1 at midnight timestamps in the search engine documents.
116
+ if ((!this.isSortedByDate || ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) === 'date') && // Any sort except dates that aren't published date
117
+ isFirstMillisecondOfUTCYear((_b = this.model) === null || _b === void 0 ? void 0 : _b.datePublished)) {
118
+ return 'year-only';
119
+ }
120
+ return this.formatSize;
121
+ }
122
+ get formatSize() {
123
+ if (this.mobileBreakpoint &&
124
+ this.currentWidth &&
125
+ this.currentWidth < this.mobileBreakpoint) {
126
+ return 'short';
127
+ }
128
+ return 'long';
129
+ }
130
+ get isSortedByDate() {
131
+ var _a;
132
+ return ['date', 'reviewdate', 'addeddate', 'publicdate'].includes((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field);
133
+ }
134
+ static get styles() {
135
135
  return css `
136
136
  html {
137
137
  font-size: unset;
@@ -205,11 +205,11 @@ let TileListCompact = class TileListCompact extends BaseTileComponent {
205
205
  --imgHeight: 100%;
206
206
  --imgWidth: 100%;
207
207
  }
208
- `;
209
- }
210
- };
211
- TileListCompact = __decorate([
212
- customElement('tile-list-compact')
213
- ], TileListCompact);
214
- export { TileListCompact };
208
+ `;
209
+ }
210
+ };
211
+ TileListCompact = __decorate([
212
+ customElement('tile-list-compact')
213
+ ], TileListCompact);
214
+ export { TileListCompact };
215
215
  //# sourceMappingURL=tile-list-compact.js.map
@@ -1,50 +1,50 @@
1
- import { PropertyValues, TemplateResult } from 'lit';
2
- import type { CollectionTitles } from '../../data-source/models';
3
- import { BaseTileComponent } from '../base-tile-component';
4
- import '../image-block';
5
- import '../review-block';
6
- import '../text-snippet-block';
7
- import '../mediatype-icon';
8
- export declare class TileList extends BaseTileComponent {
9
- collectionTitles?: CollectionTitles;
10
- private collectionLinks;
11
- render(): TemplateResult<1>;
12
- /**
13
- * Templates
14
- */
15
- private get mobileTemplate();
16
- private get desktopTemplate();
17
- private get imageBlockTemplate();
18
- private get detailsTemplate();
19
- private get iconRightTemplate();
20
- private get titleTemplate();
21
- private get itemLineTemplate();
22
- private get sourceTemplate();
23
- private get volumeTemplate();
24
- private get issueTemplate();
25
- private get creatorTemplate();
26
- private get datePublishedTemplate();
27
- private get dateSortByTemplate();
28
- private get viewsTemplate();
29
- private get ratingTemplate();
30
- private get reviewsTemplate();
31
- private get topicsTemplate();
32
- private get collectionsTemplate();
33
- private get descriptionTemplate();
34
- private get reviewBlockTemplate();
35
- private get textSnippetsTemplate();
36
- private get hasSnippets();
37
- private get webArchivesCaptureDatesTemplate();
38
- private metadataTemplate;
39
- private labelTemplate;
40
- private searchLink;
41
- private detailsLink;
42
- /** The URL of this item's mediatype collection, if defined. */
43
- private get mediatypeURL();
44
- protected updated(changed: PropertyValues): void;
45
- private buildCollectionLinks;
46
- private get date();
47
- private get classSize();
48
- private get formatSize();
49
- static get styles(): import("lit").CSSResult;
50
- }
1
+ import { PropertyValues, TemplateResult } from 'lit';
2
+ import type { CollectionTitles } from '../../data-source/models';
3
+ import { BaseTileComponent } from '../base-tile-component';
4
+ import '../image-block';
5
+ import '../review-block';
6
+ import '../text-snippet-block';
7
+ import '../mediatype-icon';
8
+ export declare class TileList extends BaseTileComponent {
9
+ collectionTitles?: CollectionTitles;
10
+ private collectionLinks;
11
+ render(): TemplateResult<1>;
12
+ /**
13
+ * Templates
14
+ */
15
+ private get mobileTemplate();
16
+ private get desktopTemplate();
17
+ private get imageBlockTemplate();
18
+ private get detailsTemplate();
19
+ private get iconRightTemplate();
20
+ private get titleTemplate();
21
+ private get itemLineTemplate();
22
+ private get sourceTemplate();
23
+ private get volumeTemplate();
24
+ private get issueTemplate();
25
+ private get creatorTemplate();
26
+ private get datePublishedTemplate();
27
+ private get dateSortByTemplate();
28
+ private get viewsTemplate();
29
+ private get ratingTemplate();
30
+ private get reviewsTemplate();
31
+ private get topicsTemplate();
32
+ private get collectionsTemplate();
33
+ private get descriptionTemplate();
34
+ private get reviewBlockTemplate();
35
+ private get textSnippetsTemplate();
36
+ private get hasSnippets();
37
+ private get webArchivesCaptureDatesTemplate();
38
+ private metadataTemplate;
39
+ private labelTemplate;
40
+ private searchLink;
41
+ private detailsLink;
42
+ /** The URL of this item's mediatype collection, if defined. */
43
+ private get mediatypeURL();
44
+ protected updated(changed: PropertyValues): void;
45
+ private buildCollectionLinks;
46
+ private get date();
47
+ private get classSize();
48
+ private get formatSize();
49
+ static get styles(): import("lit").CSSResult;
50
+ }