@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,16 +1,16 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import '../src/tiles/image-block';
5
- describe('Image block component', () => {
6
- it('should render component grid display mode', async () => {
7
- var _a, _b, _c;
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import '../src/tiles/image-block';
5
+ describe('Image block component', () => {
6
+ it('should render component grid display mode', async () => {
7
+ var _a, _b, _c;
8
8
  const el = await fixture(html `
9
9
  <image-block
10
- .model=${{
11
- loginRequired: true,
12
- contentWarning: true,
13
- identifier: 'goody',
10
+ .model=${{
11
+ loginRequired: true,
12
+ contentWarning: true,
13
+ identifier: 'goody',
14
14
  }}
15
15
  .baseImageUrl=${'https://archive.org'}
16
16
  .isCompactTile=${false}
@@ -19,22 +19,22 @@ describe('Image block component', () => {
19
19
  .loggedIn=${false}
20
20
  >
21
21
  </image-block>
22
- `);
23
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.grid');
24
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
25
- const textOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('text-overlay');
26
- expect(viewSize).to.exist;
27
- expect(itemImage).to.exist;
28
- expect(textOverlay).to.exist;
29
- });
30
- it('should render component list display mode', async () => {
31
- var _a, _b, _c;
22
+ `);
23
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.grid');
24
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
25
+ const textOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('text-overlay');
26
+ expect(viewSize).to.exist;
27
+ expect(itemImage).to.exist;
28
+ expect(textOverlay).to.exist;
29
+ });
30
+ it('should render component list display mode', async () => {
31
+ var _a, _b, _c;
32
32
  const el = await fixture(html `
33
33
  <image-block
34
- .model=${{
35
- loginRequired: true,
36
- contentWarning: true,
37
- identifier: 'goody',
34
+ .model=${{
35
+ loginRequired: true,
36
+ contentWarning: true,
37
+ identifier: 'goody',
38
38
  }}
39
39
  .baseImageUrl=${'https://archive.org'}
40
40
  .isCompactTile=${false}
@@ -43,22 +43,22 @@ describe('Image block component', () => {
43
43
  .loggedIn=${false}
44
44
  >
45
45
  </image-block>
46
- `);
47
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list.desktop');
48
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
49
- const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
50
- expect(viewSize).to.exist;
51
- expect(itemImage).to.exist;
52
- expect(iconOverlay).to.exist;
53
- });
54
- it('should render component compact display mode', async () => {
55
- var _a, _b, _c;
46
+ `);
47
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list.desktop');
48
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
49
+ const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
50
+ expect(viewSize).to.exist;
51
+ expect(itemImage).to.exist;
52
+ expect(iconOverlay).to.exist;
53
+ });
54
+ it('should render component compact display mode', async () => {
55
+ var _a, _b, _c;
56
56
  const el = await fixture(html `
57
57
  <image-block
58
- .model=${{
59
- loginRequired: true,
60
- contentWarning: true,
61
- identifier: 'goody',
58
+ .model=${{
59
+ loginRequired: true,
60
+ contentWarning: true,
61
+ identifier: 'goody',
62
62
  }}
63
63
  .baseImageUrl=${'https://archive.org'}
64
64
  .isCompactTile=${true}
@@ -67,21 +67,21 @@ describe('Image block component', () => {
67
67
  .loggedIn=${false}
68
68
  >
69
69
  </image-block>
70
- `);
71
- const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list-compact.desktop');
72
- const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
73
- const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
74
- expect(viewSize).to.exist;
75
- expect(itemImage).to.exist;
76
- expect(iconOverlay).to.exist;
77
- });
78
- it('should render a login-required overlay if model requires it and not logged in', async () => {
79
- var _a;
70
+ `);
71
+ const viewSize = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.list-compact.desktop');
72
+ const itemImage = (_b = el.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('item-image');
73
+ const iconOverlay = (_c = el.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('icon-overlay');
74
+ expect(viewSize).to.exist;
75
+ expect(itemImage).to.exist;
76
+ expect(iconOverlay).to.exist;
77
+ });
78
+ it('should render a login-required overlay if model requires it and not logged in', async () => {
79
+ var _a;
80
80
  const el = await fixture(html `
81
81
  <image-block
82
- .model=${{
83
- loginRequired: true,
84
- identifier: 'goody',
82
+ .model=${{
83
+ loginRequired: true,
84
+ identifier: 'goody',
85
85
  }}
86
86
  .baseImageUrl=${'https://archive.org'}
87
87
  .isCompactTile=${false}
@@ -90,18 +90,18 @@ describe('Image block component', () => {
90
90
  .loggedIn=${false}
91
91
  >
92
92
  </image-block>
93
- `);
94
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
95
- expect(textOverlay).to.exist;
96
- expect(textOverlay.type).to.equal('login-required');
97
- });
98
- it('should render no overlay if logged in and model only requires login', async () => {
99
- var _a;
93
+ `);
94
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
95
+ expect(textOverlay).to.exist;
96
+ expect(textOverlay.type).to.equal('login-required');
97
+ });
98
+ it('should render no overlay if logged in and model only requires login', async () => {
99
+ var _a;
100
100
  const el = await fixture(html `
101
101
  <image-block
102
- .model=${{
103
- loginRequired: true,
104
- identifier: 'goody',
102
+ .model=${{
103
+ loginRequired: true,
104
+ identifier: 'goody',
105
105
  }}
106
106
  .baseImageUrl=${'https://archive.org'}
107
107
  .isCompactTile=${false}
@@ -110,17 +110,17 @@ describe('Image block component', () => {
110
110
  .loggedIn=${true}
111
111
  >
112
112
  </image-block>
113
- `);
114
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
115
- expect(textOverlay).not.to.exist;
116
- });
117
- it('should render a content-warning overlay if model requires it and no login overlay is present', async () => {
118
- var _a;
113
+ `);
114
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
115
+ expect(textOverlay).not.to.exist;
116
+ });
117
+ it('should render a content-warning overlay if model requires it and no login overlay is present', async () => {
118
+ var _a;
119
119
  const el = await fixture(html `
120
120
  <image-block
121
- .model=${{
122
- contentWarning: true,
123
- identifier: 'goody',
121
+ .model=${{
122
+ contentWarning: true,
123
+ identifier: 'goody',
124
124
  }}
125
125
  .baseImageUrl=${'https://archive.org'}
126
126
  .isCompactTile=${false}
@@ -129,19 +129,19 @@ describe('Image block component', () => {
129
129
  .loggedIn=${false}
130
130
  >
131
131
  </image-block>
132
- `);
133
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
134
- expect(textOverlay).to.exist;
135
- expect(textOverlay.type).to.equal('content-warning');
136
- });
137
- it('should prioritize login-required overlay over content-warning if both required and logged out', async () => {
138
- var _a;
132
+ `);
133
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
134
+ expect(textOverlay).to.exist;
135
+ expect(textOverlay.type).to.equal('content-warning');
136
+ });
137
+ it('should prioritize login-required overlay over content-warning if both required and logged out', async () => {
138
+ var _a;
139
139
  const el = await fixture(html `
140
140
  <image-block
141
- .model=${{
142
- loginRequired: true,
143
- contentWarning: true,
144
- identifier: 'goody',
141
+ .model=${{
142
+ loginRequired: true,
143
+ contentWarning: true,
144
+ identifier: 'goody',
145
145
  }}
146
146
  .baseImageUrl=${'https://archive.org'}
147
147
  .isCompactTile=${false}
@@ -150,19 +150,19 @@ describe('Image block component', () => {
150
150
  .loggedIn=${false}
151
151
  >
152
152
  </image-block>
153
- `);
154
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
155
- expect(textOverlay).to.exist;
156
- expect(textOverlay.type).to.equal('login-required');
157
- });
158
- it('should show content-warning overlay if both types required and logged in', async () => {
159
- var _a;
153
+ `);
154
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
155
+ expect(textOverlay).to.exist;
156
+ expect(textOverlay.type).to.equal('login-required');
157
+ });
158
+ it('should show content-warning overlay if both types required and logged in', async () => {
159
+ var _a;
160
160
  const el = await fixture(html `
161
161
  <image-block
162
- .model=${{
163
- loginRequired: true,
164
- contentWarning: true,
165
- identifier: 'goody',
162
+ .model=${{
163
+ loginRequired: true,
164
+ contentWarning: true,
165
+ identifier: 'goody',
166
166
  }}
167
167
  .baseImageUrl=${'https://archive.org'}
168
168
  .isCompactTile=${false}
@@ -171,17 +171,17 @@ describe('Image block component', () => {
171
171
  .loggedIn=${true}
172
172
  >
173
173
  </image-block>
174
- `);
175
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
176
- expect(textOverlay).to.exist;
177
- expect(textOverlay.type).to.equal('content-warning');
178
- });
179
- it('should render no overlay if neither loginRequired nor contentWarning flag present', async () => {
180
- var _a;
174
+ `);
175
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
176
+ expect(textOverlay).to.exist;
177
+ expect(textOverlay.type).to.equal('content-warning');
178
+ });
179
+ it('should render no overlay if neither loginRequired nor contentWarning flag present', async () => {
180
+ var _a;
181
181
  const el = await fixture(html `
182
182
  <image-block
183
- .model=${{
184
- identifier: 'goody',
183
+ .model=${{
184
+ identifier: 'goody',
185
185
  }}
186
186
  .baseImageUrl=${'https://archive.org'}
187
187
  .isCompactTile=${false}
@@ -190,9 +190,9 @@ describe('Image block component', () => {
190
190
  .loggedIn=${false}
191
191
  >
192
192
  </image-block>
193
- `);
194
- const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
195
- expect(textOverlay).not.to.exist;
196
- });
197
- });
193
+ `);
194
+ const textOverlay = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('text-overlay');
195
+ expect(textOverlay).not.to.exist;
196
+ });
197
+ });
198
198
  //# sourceMappingURL=image-block.test.js.map
@@ -1 +1 @@
1
- import '../src/tiles/item-image';
1
+ import '../src/tiles/item-image';
@@ -1,44 +1,44 @@
1
- /* eslint-disable import/no-duplicates */
2
- import { expect, fixture } from '@open-wc/testing';
3
- import { html } from 'lit';
4
- import { TileModel } from '../src/models';
5
- import '../src/tiles/item-image';
6
- const baseImageUrl = 'https://archive.org';
7
- const testBookModel = new TileModel({});
8
- testBookModel.checked = false;
9
- testBookModel.collections = [];
10
- testBookModel.commentCount = 0;
11
- testBookModel.creators = [];
12
- testBookModel.favCount = 0;
13
- testBookModel.identifier = '18730130BloomfieldRecordCompleteIssue';
14
- testBookModel.itemCount = 0;
15
- testBookModel.mediatype = 'texts';
16
- testBookModel.subjects = [];
17
- testBookModel.title = 'Sample Waveform';
18
- testBookModel.viewCount = 0;
19
- testBookModel.loginRequired = false;
20
- testBookModel.contentWarning = false;
21
- testBookModel.collectionFilesCount = 0;
22
- testBookModel.collectionSize = 0;
23
- const testAudioModel = new TileModel({});
24
- testAudioModel.checked = false;
25
- testAudioModel.collections = [];
26
- testAudioModel.commentCount = 0;
27
- testAudioModel.creators = [];
28
- testAudioModel.favCount = 0;
29
- testAudioModel.identifier = 'dwd2015-01-24';
30
- testAudioModel.itemCount = 0;
31
- testAudioModel.mediatype = 'audio';
32
- testAudioModel.subjects = [];
33
- testAudioModel.title = 'Sample Waveform';
34
- testAudioModel.viewCount = 0;
35
- testAudioModel.loginRequired = false;
36
- testAudioModel.contentWarning = false;
37
- testAudioModel.collectionFilesCount = 0;
38
- testAudioModel.collectionSize = 0;
39
- describe('ItemImage component', () => {
40
- it('should render initial component', async () => {
41
- var _a, _b;
1
+ /* eslint-disable import/no-duplicates */
2
+ import { expect, fixture } from '@open-wc/testing';
3
+ import { html } from 'lit';
4
+ import { TileModel } from '../src/models';
5
+ import '../src/tiles/item-image';
6
+ const baseImageUrl = 'https://archive.org';
7
+ const testBookModel = new TileModel({});
8
+ testBookModel.checked = false;
9
+ testBookModel.collections = [];
10
+ testBookModel.commentCount = 0;
11
+ testBookModel.creators = [];
12
+ testBookModel.favCount = 0;
13
+ testBookModel.identifier = '18730130BloomfieldRecordCompleteIssue';
14
+ testBookModel.itemCount = 0;
15
+ testBookModel.mediatype = 'texts';
16
+ testBookModel.subjects = [];
17
+ testBookModel.title = 'Sample Waveform';
18
+ testBookModel.viewCount = 0;
19
+ testBookModel.loginRequired = false;
20
+ testBookModel.contentWarning = false;
21
+ testBookModel.collectionFilesCount = 0;
22
+ testBookModel.collectionSize = 0;
23
+ const testAudioModel = new TileModel({});
24
+ testAudioModel.checked = false;
25
+ testAudioModel.collections = [];
26
+ testAudioModel.commentCount = 0;
27
+ testAudioModel.creators = [];
28
+ testAudioModel.favCount = 0;
29
+ testAudioModel.identifier = 'dwd2015-01-24';
30
+ testAudioModel.itemCount = 0;
31
+ testAudioModel.mediatype = 'audio';
32
+ testAudioModel.subjects = [];
33
+ testAudioModel.title = 'Sample Waveform';
34
+ testAudioModel.viewCount = 0;
35
+ testAudioModel.loginRequired = false;
36
+ testAudioModel.contentWarning = false;
37
+ testAudioModel.collectionFilesCount = 0;
38
+ testAudioModel.collectionSize = 0;
39
+ describe('ItemImage component', () => {
40
+ it('should render initial component', async () => {
41
+ var _a, _b;
42
42
  const el = await fixture(html `
43
43
  <item-image
44
44
  .isListTile=${false}
@@ -47,14 +47,14 @@ describe('ItemImage component', () => {
47
47
  .baseImageUrl=${baseImageUrl}
48
48
  >
49
49
  </item-image>
50
- `);
51
- const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
52
- const imgClassName = (_b = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img')) === null || _b === void 0 ? void 0 : _b.className;
53
- expect(dropShadow).to.exist;
54
- expect(imgClassName).to.eql(' contain ');
55
- });
56
- it('should render component if mediatype is waveform', async () => {
57
- var _a;
50
+ `);
51
+ const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
52
+ const imgClassName = (_b = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img')) === null || _b === void 0 ? void 0 : _b.className;
53
+ expect(dropShadow).to.exist;
54
+ expect(imgClassName).to.eql(' contain ');
55
+ });
56
+ it('should render component if mediatype is waveform', async () => {
57
+ var _a;
58
58
  const el = await fixture(html `
59
59
  <item-image
60
60
  .isListTile=${false}
@@ -63,19 +63,19 @@ describe('ItemImage component', () => {
63
63
  .baseImageUrl=${baseImageUrl}
64
64
  >
65
65
  </item-image>
66
- `);
67
- const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
68
- const image = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img');
69
- expect(dropShadow).to.exist;
70
- expect(image).to.exist;
71
- // simulate image onLoad event check if image className is waveform
72
- setTimeout(() => {
73
- const imgClassName = image === null || image === void 0 ? void 0 : image.className;
74
- expect(imgClassName).to.eql(' waveform ');
75
- }, 1000);
76
- });
77
- it('should not fetch image with undefined base url', async () => {
78
- var _a;
66
+ `);
67
+ const dropShadow = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.drop-shadow');
68
+ const image = dropShadow === null || dropShadow === void 0 ? void 0 : dropShadow.querySelector('img');
69
+ expect(dropShadow).to.exist;
70
+ expect(image).to.exist;
71
+ // simulate image onLoad event check if image className is waveform
72
+ setTimeout(() => {
73
+ const imgClassName = image === null || image === void 0 ? void 0 : image.className;
74
+ expect(imgClassName).to.eql(' waveform ');
75
+ }, 1000);
76
+ });
77
+ it('should not fetch image with undefined base url', async () => {
78
+ var _a;
79
79
  const el = await fixture(html `
80
80
  <item-image
81
81
  .isListTile=${false}
@@ -83,14 +83,14 @@ describe('ItemImage component', () => {
83
83
  .model=${testBookModel}
84
84
  >
85
85
  </item-image>
86
- `);
87
- // Doesn't set the image src if base url is undefined
88
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
89
- expect(img).to.exist;
90
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
91
- });
92
- it('should not fetch image with undefined model', async () => {
93
- var _a;
86
+ `);
87
+ // Doesn't set the image src if base url is undefined
88
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
89
+ expect(img).to.exist;
90
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
91
+ });
92
+ it('should not fetch image with undefined model', async () => {
93
+ var _a;
94
94
  const el = await fixture(html `
95
95
  <item-image
96
96
  .isListTile=${false}
@@ -98,14 +98,14 @@ describe('ItemImage component', () => {
98
98
  .baseImageUrl=${baseImageUrl}
99
99
  >
100
100
  </item-image>
101
- `);
102
- // Doesn't set the image src if model is not present
103
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
104
- expect(img).to.exist;
105
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
106
- });
107
- it('should not fetch image with undefined identifier', async () => {
108
- var _a;
101
+ `);
102
+ // Doesn't set the image src if model is not present
103
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
104
+ expect(img).to.exist;
105
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
106
+ });
107
+ it('should not fetch image with undefined identifier', async () => {
108
+ var _a;
109
109
  const el = await fixture(html `
110
110
  <item-image
111
111
  .isListTile=${false}
@@ -114,11 +114,11 @@ describe('ItemImage component', () => {
114
114
  .baseImageUrl=${baseImageUrl}
115
115
  >
116
116
  </item-image>
117
- `);
118
- // Doesn't set the image src if identifier is not present
119
- const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
120
- expect(img).to.exist;
121
- expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
122
- });
123
- });
117
+ `);
118
+ // Doesn't set the image src if identifier is not present
119
+ const img = (_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('img');
120
+ expect(img).to.exist;
121
+ expect(img === null || img === void 0 ? void 0 : img.getAttribute('src')).not.to.exist;
122
+ });
123
+ });
124
124
  //# sourceMappingURL=item-image.test.js.map
@@ -1 +1,2 @@
1
- import '../../src/manage/manage-bar';
1
+ import '../../src/manage/manage-bar';
2
+ import '@internetarchive/modal-manager';