@internetarchive/collection-browser 2.7.7 → 2.7.8

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 (330) 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 +107 -99
  8. package/dist/src/app-root.js +539 -505
  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/filter.d.ts +2 -2
  31. package/dist/src/assets/img/icons/filter.js +2 -2
  32. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  33. package/dist/src/assets/img/icons/login-required.js +2 -2
  34. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  35. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  36. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  37. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  38. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  39. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  40. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  41. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  42. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  43. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  44. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  45. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  46. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  47. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  48. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  49. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  50. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
  51. package/dist/src/assets/img/icons/mediatype/search.js +2 -2
  52. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  53. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  54. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  55. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  56. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  57. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  58. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  59. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  60. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  61. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  62. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  63. package/dist/src/assets/img/icons/null-result.js +2 -2
  64. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  65. package/dist/src/assets/img/icons/restricted.js +2 -2
  66. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  67. package/dist/src/assets/img/icons/reviews.js +2 -2
  68. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  69. package/dist/src/assets/img/icons/upload.js +2 -2
  70. package/dist/src/assets/img/icons/views.d.ts +1 -1
  71. package/dist/src/assets/img/icons/views.js +2 -2
  72. package/dist/src/circular-activity-indicator.d.ts +5 -5
  73. package/dist/src/circular-activity-indicator.js +17 -17
  74. package/dist/src/collection-browser.d.ts +591 -582
  75. package/dist/src/collection-browser.js +1644 -1629
  76. package/dist/src/collection-browser.js.map +1 -1
  77. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  78. package/dist/src/collection-facets/facet-row.js +118 -118
  79. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  80. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  81. package/dist/src/collection-facets/facets-template.d.ts +13 -13
  82. package/dist/src/collection-facets/facets-template.js +44 -44
  83. package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
  84. package/dist/src/collection-facets/more-facets-content.js +407 -407
  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/smart-facets/dedupe.d.ts +10 -10
  88. package/dist/src/collection-facets/smart-facets/dedupe.js +33 -33
  89. package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.d.ts +5 -5
  90. package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.js +23 -23
  91. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.d.ts +5 -5
  92. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js +44 -44
  93. package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.d.ts +5 -5
  94. package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js +172 -172
  95. package/dist/src/collection-facets/smart-facets/models.d.ts +26 -26
  96. package/dist/src/collection-facets/smart-facets/models.js +1 -1
  97. package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +31 -31
  98. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +240 -240
  99. package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -11
  100. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +86 -86
  101. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +16 -16
  102. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +100 -100
  103. package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -2
  104. package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +12 -12
  105. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -5
  106. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +15 -15
  107. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  108. package/dist/src/collection-facets/toggle-switch.js +94 -94
  109. package/dist/src/collection-facets.d.ts +103 -103
  110. package/dist/src/collection-facets.js +522 -522
  111. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
  112. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  113. package/dist/src/data-source/collection-browser-data-source.d.ts +373 -373
  114. package/dist/src/data-source/collection-browser-data-source.js +982 -982
  115. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  116. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  117. package/dist/src/data-source/models.d.ts +28 -28
  118. package/dist/src/data-source/models.js +8 -8
  119. package/dist/src/empty-placeholder.d.ts +23 -23
  120. package/dist/src/empty-placeholder.js +79 -79
  121. package/dist/src/expanded-date-picker.d.ts +43 -43
  122. package/dist/src/expanded-date-picker.js +109 -109
  123. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  124. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  125. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  126. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  127. package/dist/src/manage/manage-bar.d.ts +58 -35
  128. package/dist/src/manage/manage-bar.js +173 -79
  129. package/dist/src/manage/manage-bar.js.map +1 -1
  130. package/dist/src/manage/remove-items-modal-content.d.ts +9 -0
  131. package/dist/src/manage/remove-items-modal-content.js +104 -0
  132. package/dist/src/manage/remove-items-modal-content.js.map +1 -0
  133. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  134. package/dist/src/mediatype/mediatype-config.js +91 -91
  135. package/dist/src/models.d.ts +228 -219
  136. package/dist/src/models.js +401 -401
  137. package/dist/src/models.js.map +1 -1
  138. package/dist/src/restoration-state-handler.d.ts +70 -70
  139. package/dist/src/restoration-state-handler.js +363 -363
  140. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  141. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  142. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  143. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  144. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  145. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  146. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  147. package/dist/src/sort-filter-bar/img/list.js +2 -2
  148. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  149. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  150. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  151. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  152. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  153. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  154. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  155. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  156. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  157. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  158. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
  159. package/dist/src/sort-filter-bar/sort-filter-bar.js +697 -697
  160. package/dist/src/styles/ia-button.d.ts +2 -2
  161. package/dist/src/styles/ia-button.js +17 -17
  162. package/dist/src/styles/item-image-styles.d.ts +8 -8
  163. package/dist/src/styles/item-image-styles.js +9 -9
  164. package/dist/src/styles/sr-only.d.ts +1 -1
  165. package/dist/src/styles/sr-only.js +2 -2
  166. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  167. package/dist/src/tiles/base-tile-component.js +64 -64
  168. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  169. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  170. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  171. package/dist/src/tiles/grid/account-tile.js +72 -72
  172. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  173. package/dist/src/tiles/grid/collection-tile.js +80 -80
  174. package/dist/src/tiles/grid/item-tile.d.ts +34 -34
  175. package/dist/src/tiles/grid/item-tile.js +158 -158
  176. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  177. package/dist/src/tiles/grid/search-tile.js +51 -51
  178. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  179. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  180. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  181. package/dist/src/tiles/grid/tile-stats.js +53 -53
  182. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  183. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  184. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
  185. package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
  186. package/dist/src/tiles/image-block.d.ts +18 -18
  187. package/dist/src/tiles/image-block.js +89 -89
  188. package/dist/src/tiles/item-image.d.ts +39 -39
  189. package/dist/src/tiles/item-image.js +154 -154
  190. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  191. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  192. package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
  193. package/dist/src/tiles/list/tile-list-compact.js +122 -122
  194. package/dist/src/tiles/list/tile-list.d.ts +54 -54
  195. package/dist/src/tiles/list/tile-list.js +323 -323
  196. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  197. package/dist/src/tiles/mediatype-icon.js +47 -47
  198. package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
  199. package/dist/src/tiles/overlay/icon-overlay.js +25 -25
  200. package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
  201. package/dist/src/tiles/overlay/text-overlay.js +31 -31
  202. package/dist/src/tiles/review-block.d.ts +12 -12
  203. package/dist/src/tiles/review-block.js +56 -56
  204. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  205. package/dist/src/tiles/text-snippet-block.js +73 -73
  206. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  207. package/dist/src/tiles/tile-dispatcher.js +230 -230
  208. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  209. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  210. package/dist/src/utils/analytics-events.d.ts +28 -28
  211. package/dist/src/utils/analytics-events.js +30 -30
  212. package/dist/src/utils/array-equals.d.ts +4 -4
  213. package/dist/src/utils/array-equals.js +10 -10
  214. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  215. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  216. package/dist/src/utils/facet-utils.d.ts +83 -83
  217. package/dist/src/utils/facet-utils.js +145 -145
  218. package/dist/src/utils/format-count.d.ts +7 -7
  219. package/dist/src/utils/format-count.js +76 -76
  220. package/dist/src/utils/format-date.d.ts +2 -2
  221. package/dist/src/utils/format-date.js +27 -27
  222. package/dist/src/utils/format-unit-size.d.ts +2 -2
  223. package/dist/src/utils/format-unit-size.js +33 -33
  224. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  225. package/dist/src/utils/local-date-from-utc.js +15 -15
  226. package/dist/src/utils/log.d.ts +7 -7
  227. package/dist/src/utils/log.js +15 -15
  228. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  229. package/dist/src/utils/resolve-mediatype.js +23 -23
  230. package/dist/src/utils/sha1.d.ts +2 -2
  231. package/dist/src/utils/sha1.js +8 -8
  232. package/dist/test/collection-browser.test.d.ts +1 -1
  233. package/dist/test/collection-browser.test.js +1293 -1293
  234. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  235. package/dist/test/collection-facets/facet-row.test.js +227 -227
  236. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  237. package/dist/test/collection-facets/facets-template.test.js +91 -91
  238. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  239. package/dist/test/collection-facets/more-facets-content.test.js +141 -141
  240. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  241. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  242. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  243. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  244. package/dist/test/collection-facets.test.d.ts +2 -2
  245. package/dist/test/collection-facets.test.js +690 -690
  246. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  247. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  248. package/dist/test/empty-placeholder.test.d.ts +1 -1
  249. package/dist/test/empty-placeholder.test.js +63 -63
  250. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  251. package/dist/test/expanded-date-picker.test.js +95 -95
  252. package/dist/test/icon-overlay.test.d.ts +1 -1
  253. package/dist/test/icon-overlay.test.js +24 -24
  254. package/dist/test/image-block.test.d.ts +1 -1
  255. package/dist/test/image-block.test.js +107 -107
  256. package/dist/test/item-image.test.d.ts +1 -1
  257. package/dist/test/item-image.test.js +85 -85
  258. package/dist/test/manage/manage-bar.test.d.ts +2 -1
  259. package/dist/test/manage/manage-bar.test.js +106 -91
  260. package/dist/test/manage/manage-bar.test.js.map +1 -1
  261. package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -0
  262. package/dist/test/manage/remove-items-modal-content.test.js +66 -0
  263. package/dist/test/manage/remove-items-modal-content.test.js.map +1 -0
  264. package/dist/test/mediatype-config.test.d.ts +1 -1
  265. package/dist/test/mediatype-config.test.js +16 -16
  266. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  267. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  268. package/dist/test/mocks/mock-search-responses.d.ts +25 -25
  269. package/dist/test/mocks/mock-search-responses.js +942 -942
  270. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  271. package/dist/test/mocks/mock-search-service.js +54 -54
  272. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  273. package/dist/test/restoration-state-handler.test.js +270 -270
  274. package/dist/test/review-block.test.d.ts +1 -1
  275. package/dist/test/review-block.test.js +44 -44
  276. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  277. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  278. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  279. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  280. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  281. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  282. package/dist/test/text-overlay.test.d.ts +1 -1
  283. package/dist/test/text-overlay.test.js +38 -38
  284. package/dist/test/text-snippet-block.test.d.ts +1 -1
  285. package/dist/test/text-snippet-block.test.js +57 -57
  286. package/dist/test/tile-stats.test.d.ts +1 -1
  287. package/dist/test/tile-stats.test.js +81 -81
  288. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  289. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  290. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  291. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  292. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  293. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  294. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  295. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  296. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  297. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  298. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  299. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  300. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  301. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  302. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  303. package/dist/test/tiles/list/tile-list.test.js +297 -297
  304. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  305. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  306. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  307. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  308. package/dist/test/utils/array-equals.test.d.ts +1 -1
  309. package/dist/test/utils/array-equals.test.js +26 -26
  310. package/dist/test/utils/format-count.test.d.ts +1 -1
  311. package/dist/test/utils/format-count.test.js +23 -23
  312. package/dist/test/utils/format-date.test.d.ts +1 -1
  313. package/dist/test/utils/format-date.test.js +30 -30
  314. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  315. package/dist/test/utils/format-unit-size.test.js +17 -17
  316. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  317. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  318. package/local.archive.org.cert +86 -86
  319. package/local.archive.org.key +27 -27
  320. package/package.json +1 -1
  321. package/renovate.json +6 -6
  322. package/src/app-root.ts +38 -4
  323. package/src/collection-browser.ts +36 -16
  324. package/src/manage/manage-bar.ts +119 -23
  325. package/src/manage/remove-items-modal-content.ts +102 -0
  326. package/src/models.ts +10 -0
  327. package/test/manage/manage-bar.test.ts +41 -18
  328. package/test/manage/remove-items-modal-content.test.ts +82 -0
  329. package/web-dev-server.config.mjs +30 -30
  330. package/web-test-runner.config.mjs +41 -41
@@ -1,53 +1,53 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, nothing } from 'lit';
3
- import { ifDefined } from 'lit/directives/if-defined.js';
4
- import { join } from 'lit/directives/join.js';
5
- import { map } from 'lit/directives/map.js';
6
- import { unsafeHTML } from 'lit/directives/unsafe-html.js';
7
- import { customElement, property, state } from 'lit/decorators.js';
8
- import { msg } from '@lit/localize';
9
- import DOMPurify from 'dompurify';
10
- import { suppressedCollections } from '../../models';
11
- import { BaseTileComponent } from '../base-tile-component';
12
- import { formatCount } from '../../utils/format-count';
13
- import { formatDate } from '../../utils/format-date';
14
- import { isFirstMillisecondOfUTCYear } from '../../utils/local-date-from-utc';
15
- import '../image-block';
16
- import '../review-block';
17
- import '../text-snippet-block';
18
- import '../mediatype-icon';
19
- let TileList = class TileList extends BaseTileComponent {
20
- constructor() {
21
- /*
22
- * Reactive properties inherited from BaseTileComponent:
23
- * - model?: TileModel;
24
- * - currentWidth?: number;
25
- * - currentHeight?: number;
26
- * - baseNavigationUrl?: string;
27
- * - baseImageUrl?: string;
28
- * - collectionPagePath?: string;
29
- * - sortParam: SortParam | null = null;
30
- * - defaultSortParam: SortParam | null = null;
31
- * - creatorFilter?: string;
32
- * - mobileBreakpoint?: number;
33
- * - loggedIn = false;
34
- */
35
- super(...arguments);
36
- this.collectionLinks = [];
37
- }
38
- render() {
1
+ import { __decorate } from "tslib";
2
+ import { css, html, nothing } from 'lit';
3
+ import { ifDefined } from 'lit/directives/if-defined.js';
4
+ import { join } from 'lit/directives/join.js';
5
+ import { map } from 'lit/directives/map.js';
6
+ import { unsafeHTML } from 'lit/directives/unsafe-html.js';
7
+ import { customElement, property, state } from 'lit/decorators.js';
8
+ import { msg } from '@lit/localize';
9
+ import DOMPurify from 'dompurify';
10
+ import { suppressedCollections } from '../../models';
11
+ import { BaseTileComponent } from '../base-tile-component';
12
+ import { formatCount } from '../../utils/format-count';
13
+ import { formatDate } from '../../utils/format-date';
14
+ import { isFirstMillisecondOfUTCYear } from '../../utils/local-date-from-utc';
15
+ import '../image-block';
16
+ import '../review-block';
17
+ import '../text-snippet-block';
18
+ import '../mediatype-icon';
19
+ let TileList = class TileList extends BaseTileComponent {
20
+ constructor() {
21
+ /*
22
+ * Reactive properties inherited from BaseTileComponent:
23
+ * - model?: TileModel;
24
+ * - currentWidth?: number;
25
+ * - currentHeight?: number;
26
+ * - baseNavigationUrl?: string;
27
+ * - baseImageUrl?: string;
28
+ * - collectionPagePath?: string;
29
+ * - sortParam: SortParam | null = null;
30
+ * - defaultSortParam: SortParam | null = null;
31
+ * - creatorFilter?: string;
32
+ * - mobileBreakpoint?: number;
33
+ * - loggedIn = false;
34
+ */
35
+ super(...arguments);
36
+ this.collectionLinks = [];
37
+ }
38
+ render() {
39
39
  return html `
40
40
  <div id="list-line" class="${this.classSize}">
41
- ${this.classSize === 'mobile'
42
- ? this.mobileTemplate
41
+ ${this.classSize === 'mobile'
42
+ ? this.mobileTemplate
43
43
  : this.desktopTemplate}
44
44
  </div>
45
- `;
46
- }
47
- /**
48
- * Templates
49
- */
50
- get mobileTemplate() {
45
+ `;
46
+ }
47
+ /**
48
+ * Templates
49
+ */
50
+ get mobileTemplate() {
51
51
  return html `
52
52
  <div id="list-line-top">
53
53
  <div id="list-line-left">${this.imageBlockTemplate}</div>
@@ -59,9 +59,9 @@ let TileList = class TileList extends BaseTileComponent {
59
59
  </div>
60
60
  </div>
61
61
  <div id="list-line-bottom">${this.detailsTemplate}</div>
62
- `;
63
- }
64
- get desktopTemplate() {
62
+ `;
63
+ }
64
+ get desktopTemplate() {
65
65
  return html `
66
66
  <div id="list-line-left">${this.imageBlockTemplate}</div>
67
67
  <div id="list-line-right">
@@ -71,13 +71,13 @@ let TileList = class TileList extends BaseTileComponent {
71
71
  </div>
72
72
  ${this.detailsTemplate}
73
73
  </div>
74
- `;
75
- }
76
- get imageBlockTemplate() {
77
- if (!this.model)
78
- return nothing;
79
- const isCollection = this.model.mediatype === 'collection';
80
- const href = this.displayValueProvider.itemPageUrl(this.model.identifier, isCollection);
74
+ `;
75
+ }
76
+ get imageBlockTemplate() {
77
+ if (!this.model)
78
+ return nothing;
79
+ const isCollection = this.model.mediatype === 'collection';
80
+ const href = this.displayValueProvider.itemPageUrl(this.model.identifier, isCollection);
81
81
  return html `<a href=${href}>
82
82
  <image-block
83
83
  .model=${this.model}
@@ -88,9 +88,9 @@ let TileList = class TileList extends BaseTileComponent {
88
88
  .loggedIn=${this.loggedIn}
89
89
  >
90
90
  </image-block>
91
- </a> `;
92
- }
93
- get detailsTemplate() {
91
+ </a> `;
92
+ }
93
+ get detailsTemplate() {
94
94
  return html `
95
95
  ${this.itemLineTemplate} ${this.creatorTemplate}
96
96
  <div id="dates-line">
@@ -103,11 +103,11 @@ let TileList = class TileList extends BaseTileComponent {
103
103
  ${this.topicsTemplate} ${this.collectionsTemplate}
104
104
  ${this.descriptionTemplate} ${this.textSnippetsTemplate}
105
105
  ${this.reviewBlockTemplate}
106
- `;
107
- }
108
- // Data templates
109
- get iconRightTemplate() {
110
- var _a, _b;
106
+ `;
107
+ }
108
+ // Data templates
109
+ get iconRightTemplate() {
110
+ var _a, _b;
111
111
  return html `
112
112
  <a id="icon-right" href=${this.mediatypeURL}>
113
113
  <mediatype-icon
@@ -116,151 +116,151 @@ let TileList = class TileList extends BaseTileComponent {
116
116
  >
117
117
  </mediatype-icon>
118
118
  </a>
119
- `;
120
- }
121
- get titleTemplate() {
122
- var _a, _b, _c;
123
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.title)) {
124
- return nothing;
125
- }
126
- // If the model has a server-specified href, use it
127
- // Otherwise construct a details link using the identifier
128
- return ((_b = this.model) === null || _b === void 0 ? void 0 : _b.href)
119
+ `;
120
+ }
121
+ get titleTemplate() {
122
+ var _a, _b, _c;
123
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.title)) {
124
+ return nothing;
125
+ }
126
+ // If the model has a server-specified href, use it
127
+ // Otherwise construct a details link using the identifier
128
+ return ((_b = this.model) === null || _b === void 0 ? void 0 : _b.href)
129
129
  ? html `<a href="${this.baseNavigationUrl}${this.model.href}"
130
130
  >${(_c = this.model.title) !== null && _c !== void 0 ? _c : this.model.identifier}</a
131
- >`
132
- : this.detailsLink(this.model.identifier, this.model.title, this.model.mediatype === 'collection');
133
- }
134
- get itemLineTemplate() {
135
- const source = this.sourceTemplate;
136
- const volume = this.volumeTemplate;
137
- const issue = this.issueTemplate;
138
- if (!source && !volume && !issue) {
139
- return nothing;
140
- }
141
- return html ` <div id="item-line">${source} ${volume} ${issue}</div> `;
142
- }
143
- get sourceTemplate() {
144
- var _a;
145
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.source)) {
146
- return nothing;
147
- }
131
+ >`
132
+ : this.detailsLink(this.model.identifier, this.model.title, this.model.mediatype === 'collection');
133
+ }
134
+ get itemLineTemplate() {
135
+ const source = this.sourceTemplate;
136
+ const volume = this.volumeTemplate;
137
+ const issue = this.issueTemplate;
138
+ if (!source && !volume && !issue) {
139
+ return nothing;
140
+ }
141
+ return html ` <div id="item-line">${source} ${volume} ${issue}</div> `;
142
+ }
143
+ get sourceTemplate() {
144
+ var _a;
145
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.source)) {
146
+ return nothing;
147
+ }
148
148
  return html `
149
149
  <div id="source" class="metadata">
150
150
  ${this.labelTemplate(msg('Source'))}
151
151
  ${this.searchLink('source', this.model.source)}
152
152
  </div>
153
- `;
154
- }
155
- get volumeTemplate() {
156
- var _a;
157
- return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.volume, msg('Volume'));
158
- }
159
- get issueTemplate() {
160
- var _a;
161
- return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.issue, msg('Issue'));
162
- }
163
- get creatorTemplate() {
164
- var _a, _b, _c;
165
- // "Archivist since" if account
166
- if (((_a = this.model) === null || _a === void 0 ? void 0 : _a.mediatype) === 'account') {
153
+ `;
154
+ }
155
+ get volumeTemplate() {
156
+ var _a;
157
+ return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.volume, msg('Volume'));
158
+ }
159
+ get issueTemplate() {
160
+ var _a;
161
+ return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.issue, msg('Issue'));
162
+ }
163
+ get creatorTemplate() {
164
+ var _a, _b, _c;
165
+ // "Archivist since" if account
166
+ if (((_a = this.model) === null || _a === void 0 ? void 0 : _a.mediatype) === 'account') {
167
167
  return html `
168
168
  <div id="creator" class="metadata">
169
169
  <span class="label"
170
170
  >${(_b = this.displayValueProvider.accountLabel) !== null && _b !== void 0 ? _b : nothing}</span
171
171
  >
172
172
  </div>
173
- `;
174
- }
175
- // "Creator" if not account tile
176
- if (!((_c = this.model) === null || _c === void 0 ? void 0 : _c.creators) || this.model.creators.length === 0) {
177
- return nothing;
178
- }
173
+ `;
174
+ }
175
+ // "Creator" if not account tile
176
+ if (!((_c = this.model) === null || _c === void 0 ? void 0 : _c.creators) || this.model.creators.length === 0) {
177
+ return nothing;
178
+ }
179
179
  return html `
180
180
  <div id="creator" class="metadata">
181
181
  ${this.labelTemplate(msg('By'))}
182
182
  ${join(map(this.model.creators, id => this.searchLink('creator', id)), ', ')}
183
183
  </div>
184
- `;
185
- }
186
- get datePublishedTemplate() {
187
- var _a;
188
- // If we're showing a date published of Jan 1 at midnight, only show the year.
189
- // This is because items with only a year for their publication date are normalized to
190
- // Jan 1 at midnight timestamps in the search engine documents.
191
- const date = (_a = this.model) === null || _a === void 0 ? void 0 : _a.datePublished;
192
- let format = 'long';
193
- if (isFirstMillisecondOfUTCYear(date)) {
194
- format = 'year-only';
195
- }
196
- return this.metadataTemplate(formatDate(date, format), msg('Published'));
197
- }
198
- // Show date label/value when sorted by date type
199
- // Except datePublished which is always shown
200
- get dateSortByTemplate() {
201
- if (this.effectiveSort &&
202
- (this.effectiveSort.field === 'addeddate' ||
203
- this.effectiveSort.field === 'reviewdate' ||
204
- this.effectiveSort.field === 'publicdate')) {
205
- return this.metadataTemplate(formatDate(this.date, 'long'), this.displayValueProvider.dateLabel);
206
- }
207
- return nothing;
208
- }
209
- get viewsTemplate() {
210
- var _a, _b, _c, _d;
211
- const viewCount = ((_a = this.effectiveSort) === null || _a === void 0 ? void 0 : _a.field) === 'week'
212
- ? (_b = this.model) === null || _b === void 0 ? void 0 : _b.weeklyViewCount // weekly views
213
- : (_c = this.model) === null || _c === void 0 ? void 0 : _c.viewCount; // all-time views
214
- if (viewCount == null)
215
- return nothing;
216
- // when its a search-tile, we don't have any stats to show
217
- if (((_d = this.model) === null || _d === void 0 ? void 0 : _d.mediatype) === 'search') {
218
- return this.metadataTemplate('(Favorited search query)', '');
219
- }
220
- return this.metadataTemplate(`${formatCount(viewCount, this.formatSize)}`, msg('Views'));
221
- }
222
- get ratingTemplate() {
223
- var _a;
224
- return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.averageRating, msg('Avg Rating'));
225
- }
226
- get reviewsTemplate() {
227
- var _a;
228
- return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.commentCount, msg('Reviews'));
229
- }
230
- get topicsTemplate() {
231
- var _a;
232
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.subjects) || this.model.subjects.length === 0) {
233
- return nothing;
234
- }
184
+ `;
185
+ }
186
+ get datePublishedTemplate() {
187
+ var _a;
188
+ // If we're showing a date published of Jan 1 at midnight, only show the year.
189
+ // This is because items with only a year for their publication date are normalized to
190
+ // Jan 1 at midnight timestamps in the search engine documents.
191
+ const date = (_a = this.model) === null || _a === void 0 ? void 0 : _a.datePublished;
192
+ let format = 'long';
193
+ if (isFirstMillisecondOfUTCYear(date)) {
194
+ format = 'year-only';
195
+ }
196
+ return this.metadataTemplate(formatDate(date, format), msg('Published'));
197
+ }
198
+ // Show date label/value when sorted by date type
199
+ // Except datePublished which is always shown
200
+ get dateSortByTemplate() {
201
+ if (this.effectiveSort &&
202
+ (this.effectiveSort.field === 'addeddate' ||
203
+ this.effectiveSort.field === 'reviewdate' ||
204
+ this.effectiveSort.field === 'publicdate')) {
205
+ return this.metadataTemplate(formatDate(this.date, 'long'), this.displayValueProvider.dateLabel);
206
+ }
207
+ return nothing;
208
+ }
209
+ get viewsTemplate() {
210
+ var _a, _b, _c, _d;
211
+ const viewCount = ((_a = this.effectiveSort) === null || _a === void 0 ? void 0 : _a.field) === 'week'
212
+ ? (_b = this.model) === null || _b === void 0 ? void 0 : _b.weeklyViewCount // weekly views
213
+ : (_c = this.model) === null || _c === void 0 ? void 0 : _c.viewCount; // all-time views
214
+ if (viewCount == null)
215
+ return nothing;
216
+ // when its a search-tile, we don't have any stats to show
217
+ if (((_d = this.model) === null || _d === void 0 ? void 0 : _d.mediatype) === 'search') {
218
+ return this.metadataTemplate('(Favorited search query)', '');
219
+ }
220
+ return this.metadataTemplate(`${formatCount(viewCount, this.formatSize)}`, msg('Views'));
221
+ }
222
+ get ratingTemplate() {
223
+ var _a;
224
+ return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.averageRating, msg('Avg Rating'));
225
+ }
226
+ get reviewsTemplate() {
227
+ var _a;
228
+ return this.metadataTemplate((_a = this.model) === null || _a === void 0 ? void 0 : _a.commentCount, msg('Reviews'));
229
+ }
230
+ get topicsTemplate() {
231
+ var _a;
232
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.subjects) || this.model.subjects.length === 0) {
233
+ return nothing;
234
+ }
235
235
  return html `
236
236
  <div id="topics" class="metadata">
237
237
  ${this.labelTemplate(msg('Topics'))}
238
238
  ${join(map(this.model.subjects, id => this.searchLink('subject', id)), ', ')}
239
239
  </div>
240
- `;
241
- }
242
- get collectionsTemplate() {
243
- if (!this.collectionLinks || this.collectionLinks.length === 0) {
244
- return nothing;
245
- }
240
+ `;
241
+ }
242
+ get collectionsTemplate() {
243
+ if (!this.collectionLinks || this.collectionLinks.length === 0) {
244
+ return nothing;
245
+ }
246
246
  return html `
247
247
  <div id="collections" class="metadata">
248
248
  ${this.labelTemplate(msg('Collections'))}
249
249
  ${join(this.collectionLinks, ', ')}
250
250
  </div>
251
- `;
252
- }
253
- get descriptionTemplate() {
254
- var _a, _b, _c;
255
- return this.metadataTemplate(
256
- // Sanitize away any HTML tags and convert line breaks to spaces.
257
- unsafeHTML(DOMPurify.sanitize((_c = (_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.description) === null || _b === void 0 ? void 0 : _b.replace(/\n/g, ' ')) !== null && _c !== void 0 ? _c : '')), '', 'description');
258
- }
259
- get reviewBlockTemplate() {
260
- var _a;
261
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.review))
262
- return nothing;
263
- const { title, body, stars } = this.model.review;
251
+ `;
252
+ }
253
+ get descriptionTemplate() {
254
+ var _a, _b, _c;
255
+ return this.metadataTemplate(
256
+ // Sanitize away any HTML tags and convert line breaks to spaces.
257
+ unsafeHTML(DOMPurify.sanitize((_c = (_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.description) === null || _b === void 0 ? void 0 : _b.replace(/\n/g, ' ')) !== null && _c !== void 0 ? _c : '')), '', 'description');
258
+ }
259
+ get reviewBlockTemplate() {
260
+ var _a;
261
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.review))
262
+ return nothing;
263
+ const { title, body, stars } = this.model.review;
264
264
  return html `
265
265
  <review-block
266
266
  viewsize="list"
@@ -269,153 +269,153 @@ let TileList = class TileList extends BaseTileComponent {
269
269
  .starRating=${stars}
270
270
  >
271
271
  </review-block>
272
- `;
273
- }
274
- get textSnippetsTemplate() {
275
- var _a;
276
- if (!this.hasSnippets)
277
- return nothing;
272
+ `;
273
+ }
274
+ get textSnippetsTemplate() {
275
+ var _a;
276
+ if (!this.hasSnippets)
277
+ return nothing;
278
278
  return html `<text-snippet-block
279
279
  viewsize="list"
280
280
  .snippets=${(_a = this.model) === null || _a === void 0 ? void 0 : _a.snippets}
281
- ></text-snippet-block>`;
282
- }
283
- get hasSnippets() {
284
- var _a, _b;
285
- return !!((_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.snippets) === null || _b === void 0 ? void 0 : _b.length);
286
- }
287
- get webArchivesCaptureDatesTemplate() {
288
- var _a;
289
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.captureDates) || !this.model.title)
290
- return nothing;
281
+ ></text-snippet-block>`;
282
+ }
283
+ get hasSnippets() {
284
+ var _a, _b;
285
+ return !!((_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.snippets) === null || _b === void 0 ? void 0 : _b.length);
286
+ }
287
+ get webArchivesCaptureDatesTemplate() {
288
+ var _a;
289
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.captureDates) || !this.model.title)
290
+ return nothing;
291
291
  return html `
292
292
  <ul class="capture-dates">
293
293
  ${map(this.model.captureDates, date => html `<li>
294
294
  ${this.displayValueProvider.webArchivesCaptureLink(this.model.title, date)}
295
295
  </li>`)}
296
296
  </ul>
297
- `;
298
- }
299
- // Utility functions
300
- // eslint-disable-next-line default-param-last
301
- metadataTemplate(text, label = '', id) {
302
- if (!text)
303
- return nothing;
297
+ `;
298
+ }
299
+ // Utility functions
300
+ // eslint-disable-next-line default-param-last
301
+ metadataTemplate(text, label = '', id) {
302
+ if (!text)
303
+ return nothing;
304
304
  return html `
305
305
  <div id=${ifDefined(id)} class="metadata">
306
306
  ${this.labelTemplate(label)} ${text}
307
307
  </div>
308
- `;
309
- }
310
- labelTemplate(label) {
311
- return html ` ${label
312
- ? html `<span class="label">${label}: </span>`
313
- : nothing}`;
314
- }
315
- searchLink(field, searchTerm) {
316
- if (!field || !searchTerm) {
317
- return nothing;
318
- }
319
- const query = encodeURIComponent(`${field}:"${searchTerm}"`);
320
- // No whitespace after closing tag
321
- // Note: single ' for href='' to wrap " in query var gets changed back by yarn format
322
- /* eslint-disable lit/no-invalid-html */
308
+ `;
309
+ }
310
+ labelTemplate(label) {
311
+ return html ` ${label
312
+ ? html `<span class="label">${label}: </span>`
313
+ : nothing}`;
314
+ }
315
+ searchLink(field, searchTerm) {
316
+ if (!field || !searchTerm) {
317
+ return nothing;
318
+ }
319
+ const query = encodeURIComponent(`${field}:"${searchTerm}"`);
320
+ // No whitespace after closing tag
321
+ // Note: single ' for href='' to wrap " in query var gets changed back by yarn format
322
+ /* eslint-disable lit/no-invalid-html */
323
323
  return html `<a
324
324
  href="${this.baseNavigationUrl}/search?query=${query}"
325
325
  rel="nofollow"
326
326
  >
327
327
  ${DOMPurify.sanitize(searchTerm)}</a
328
- >`;
329
- /* eslint-enable lit/no-invalid-html */
330
- }
331
- detailsLink(identifier, text, isCollection = false) {
332
- if (!identifier)
333
- return nothing;
334
- const linkText = text !== null && text !== void 0 ? text : identifier;
335
- const linkHref = this.displayValueProvider.itemPageUrl(identifier, isCollection);
336
- return html `<a href=${linkHref}> ${DOMPurify.sanitize(linkText)} </a>`;
337
- }
338
- /** The URL of this item's mediatype collection, if defined. */
339
- get mediatypeURL() {
340
- var _a;
341
- // NB: baseNavigationUrl can be an empty string
342
- if (this.baseNavigationUrl === undefined || !((_a = this.model) === null || _a === void 0 ? void 0 : _a.mediatype))
343
- return nothing;
344
- // Need special handling for certain mediatypes that don't have a top-level collection page
345
- switch (this.model.mediatype) {
346
- case 'collection':
347
- return `${this.baseNavigationUrl}/search?query=mediatype:collection&sort=-downloads`;
348
- case 'account':
349
- return nothing;
350
- default:
351
- return this.displayValueProvider.itemPageUrl(this.model.mediatype, true);
352
- }
353
- }
354
- updated(changed) {
355
- if (changed.has('model') || changed.has('collectionTitles')) {
356
- this.buildCollectionLinks();
357
- }
358
- }
359
- async buildCollectionLinks() {
360
- var _a, _b, _c;
361
- if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.collections) || this.model.collections.length === 0) {
362
- return;
363
- }
364
- // Note: quirk of Lit: need to replace collectionLinks array,
365
- // otherwise it will not re-render. Can't simply alter the array.
366
- this.collectionLinks = [];
367
- const newCollectionLinks = [];
368
- for (const collection of this.model.collections) {
369
- // Don't include favorites or collections that are meant to be suppressed
370
- if (!suppressedCollections[collection] &&
371
- !collection.startsWith('fav-')) {
372
- newCollectionLinks.push(this.detailsLink(collection, (_c = (_b = this.collectionTitles) === null || _b === void 0 ? void 0 : _b.get(collection)) !== null && _c !== void 0 ? _c : collection, true));
373
- }
374
- }
375
- this.collectionLinks = newCollectionLinks;
376
- }
377
- /*
378
- * TODO: fix field names to match model in src/collection-browser.ts
379
- * private get dateSortSelector()
380
- * @see src/models.ts
381
- */
382
- get date() {
383
- var _a, _b, _c, _d, _e;
384
- switch ((_a = this.effectiveSort) === null || _a === void 0 ? void 0 : _a.field) {
385
- case 'date':
386
- return (_b = this.model) === null || _b === void 0 ? void 0 : _b.datePublished;
387
- case 'reviewdate':
388
- return (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateReviewed;
389
- case 'addeddate':
390
- return (_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded;
391
- default:
392
- return (_e = this.model) === null || _e === void 0 ? void 0 : _e.dateArchived; // publicdate
393
- }
394
- }
395
- /**
396
- * Returns the active sort param if one is set, or the default sort param otherwise.
397
- */
398
- get effectiveSort() {
399
- var _a;
400
- return (_a = this.sortParam) !== null && _a !== void 0 ? _a : this.defaultSortParam;
401
- }
402
- get classSize() {
403
- if (this.mobileBreakpoint &&
404
- this.currentWidth &&
405
- this.currentWidth < this.mobileBreakpoint) {
406
- return 'mobile';
407
- }
408
- return 'desktop';
409
- }
410
- get formatSize() {
411
- if (this.mobileBreakpoint &&
412
- this.currentWidth &&
413
- this.currentWidth < this.mobileBreakpoint) {
414
- return 'short';
415
- }
416
- return 'long';
417
- }
418
- static get styles() {
328
+ >`;
329
+ /* eslint-enable lit/no-invalid-html */
330
+ }
331
+ detailsLink(identifier, text, isCollection = false) {
332
+ if (!identifier)
333
+ return nothing;
334
+ const linkText = text !== null && text !== void 0 ? text : identifier;
335
+ const linkHref = this.displayValueProvider.itemPageUrl(identifier, isCollection);
336
+ return html `<a href=${linkHref}> ${DOMPurify.sanitize(linkText)} </a>`;
337
+ }
338
+ /** The URL of this item's mediatype collection, if defined. */
339
+ get mediatypeURL() {
340
+ var _a;
341
+ // NB: baseNavigationUrl can be an empty string
342
+ if (this.baseNavigationUrl === undefined || !((_a = this.model) === null || _a === void 0 ? void 0 : _a.mediatype))
343
+ return nothing;
344
+ // Need special handling for certain mediatypes that don't have a top-level collection page
345
+ switch (this.model.mediatype) {
346
+ case 'collection':
347
+ return `${this.baseNavigationUrl}/search?query=mediatype:collection&sort=-downloads`;
348
+ case 'account':
349
+ return nothing;
350
+ default:
351
+ return this.displayValueProvider.itemPageUrl(this.model.mediatype, true);
352
+ }
353
+ }
354
+ updated(changed) {
355
+ if (changed.has('model') || changed.has('collectionTitles')) {
356
+ this.buildCollectionLinks();
357
+ }
358
+ }
359
+ async buildCollectionLinks() {
360
+ var _a, _b, _c;
361
+ if (!((_a = this.model) === null || _a === void 0 ? void 0 : _a.collections) || this.model.collections.length === 0) {
362
+ return;
363
+ }
364
+ // Note: quirk of Lit: need to replace collectionLinks array,
365
+ // otherwise it will not re-render. Can't simply alter the array.
366
+ this.collectionLinks = [];
367
+ const newCollectionLinks = [];
368
+ for (const collection of this.model.collections) {
369
+ // Don't include favorites or collections that are meant to be suppressed
370
+ if (!suppressedCollections[collection] &&
371
+ !collection.startsWith('fav-')) {
372
+ newCollectionLinks.push(this.detailsLink(collection, (_c = (_b = this.collectionTitles) === null || _b === void 0 ? void 0 : _b.get(collection)) !== null && _c !== void 0 ? _c : collection, true));
373
+ }
374
+ }
375
+ this.collectionLinks = newCollectionLinks;
376
+ }
377
+ /*
378
+ * TODO: fix field names to match model in src/collection-browser.ts
379
+ * private get dateSortSelector()
380
+ * @see src/models.ts
381
+ */
382
+ get date() {
383
+ var _a, _b, _c, _d, _e;
384
+ switch ((_a = this.effectiveSort) === null || _a === void 0 ? void 0 : _a.field) {
385
+ case 'date':
386
+ return (_b = this.model) === null || _b === void 0 ? void 0 : _b.datePublished;
387
+ case 'reviewdate':
388
+ return (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateReviewed;
389
+ case 'addeddate':
390
+ return (_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded;
391
+ default:
392
+ return (_e = this.model) === null || _e === void 0 ? void 0 : _e.dateArchived; // publicdate
393
+ }
394
+ }
395
+ /**
396
+ * Returns the active sort param if one is set, or the default sort param otherwise.
397
+ */
398
+ get effectiveSort() {
399
+ var _a;
400
+ return (_a = this.sortParam) !== null && _a !== void 0 ? _a : this.defaultSortParam;
401
+ }
402
+ get classSize() {
403
+ if (this.mobileBreakpoint &&
404
+ this.currentWidth &&
405
+ this.currentWidth < this.mobileBreakpoint) {
406
+ return 'mobile';
407
+ }
408
+ return 'desktop';
409
+ }
410
+ get formatSize() {
411
+ if (this.mobileBreakpoint &&
412
+ this.currentWidth &&
413
+ this.currentWidth < this.mobileBreakpoint) {
414
+ return 'short';
415
+ }
416
+ return 'long';
417
+ }
418
+ static get styles() {
419
419
  return css `
420
420
  html {
421
421
  font-size: unset;
@@ -600,17 +600,17 @@ let TileList = class TileList extends BaseTileComponent {
600
600
  .capture-dates a:hover {
601
601
  text-decoration: underline;
602
602
  }
603
- `;
604
- }
605
- };
606
- __decorate([
607
- property({ type: Object })
608
- ], TileList.prototype, "collectionTitles", void 0);
609
- __decorate([
610
- state()
611
- ], TileList.prototype, "collectionLinks", void 0);
612
- TileList = __decorate([
613
- customElement('tile-list')
614
- ], TileList);
615
- export { TileList };
603
+ `;
604
+ }
605
+ };
606
+ __decorate([
607
+ property({ type: Object })
608
+ ], TileList.prototype, "collectionTitles", void 0);
609
+ __decorate([
610
+ state()
611
+ ], TileList.prototype, "collectionLinks", void 0);
612
+ TileList = __decorate([
613
+ customElement('tile-list')
614
+ ], TileList);
615
+ export { TileList };
616
616
  //# sourceMappingURL=tile-list.js.map