@internetarchive/collection-browser 3.3.2 → 3.3.3

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 (532) hide show
  1. package/.editorconfig +29 -29
  2. package/.github/workflows/ci.yml +27 -27
  3. package/.github/workflows/gh-pages-main.yml +39 -39
  4. package/.github/workflows/npm-publish.yml +39 -39
  5. package/.github/workflows/pr-preview.yml +38 -38
  6. package/.husky/pre-commit +4 -4
  7. package/.prettierignore +1 -1
  8. package/LICENSE +661 -661
  9. package/README.md +83 -83
  10. package/dist/index.d.ts +16 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/src/app-root.d.ts +105 -0
  13. package/dist/src/app-root.js +1076 -0
  14. package/dist/src/app-root.js.map +1 -0
  15. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -0
  16. package/dist/src/assets/img/icons/arrow-left.js +10 -0
  17. package/dist/src/assets/img/icons/arrow-left.js.map +1 -0
  18. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -0
  19. package/dist/src/assets/img/icons/arrow-right.js +10 -0
  20. package/dist/src/assets/img/icons/arrow-right.js.map +1 -0
  21. package/dist/src/assets/img/icons/chevron.d.ts +2 -0
  22. package/dist/src/assets/img/icons/chevron.js +4 -0
  23. package/dist/src/assets/img/icons/chevron.js.map +1 -0
  24. package/dist/src/assets/img/icons/close-circle-dark.d.ts +2 -0
  25. package/dist/src/assets/img/icons/close-circle-dark.js +5 -0
  26. package/dist/src/assets/img/icons/close-circle-dark.js.map +1 -0
  27. package/dist/src/assets/img/icons/contract.d.ts +2 -0
  28. package/dist/src/assets/img/icons/contract.js +9 -0
  29. package/dist/src/assets/img/icons/contract.js.map +1 -0
  30. package/dist/src/assets/img/icons/empty-query.d.ts +2 -0
  31. package/dist/src/assets/img/icons/empty-query.js +5 -0
  32. package/dist/src/assets/img/icons/empty-query.js.map +1 -0
  33. package/dist/src/assets/img/icons/expand.d.ts +2 -0
  34. package/dist/src/assets/img/icons/expand.js +9 -0
  35. package/dist/src/assets/img/icons/expand.js.map +1 -0
  36. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -0
  37. package/dist/src/assets/img/icons/eye-closed.js +5 -0
  38. package/dist/src/assets/img/icons/eye-closed.js.map +1 -0
  39. package/dist/src/assets/img/icons/eye.d.ts +2 -0
  40. package/dist/src/assets/img/icons/eye.js +5 -0
  41. package/dist/src/assets/img/icons/eye.js.map +1 -0
  42. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -0
  43. package/dist/src/assets/img/icons/favorite-filled.js +10 -0
  44. package/dist/src/assets/img/icons/favorite-filled.js.map +1 -0
  45. package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -0
  46. package/dist/src/assets/img/icons/favorite-unfilled.js +9 -0
  47. package/dist/src/assets/img/icons/favorite-unfilled.js.map +1 -0
  48. package/dist/src/assets/img/icons/filter.d.ts +2 -0
  49. package/dist/src/assets/img/icons/filter.js +10 -0
  50. package/dist/src/assets/img/icons/filter.js.map +1 -0
  51. package/dist/src/assets/img/icons/login-required.d.ts +1 -0
  52. package/dist/src/assets/img/icons/login-required.js +18 -0
  53. package/dist/src/assets/img/icons/login-required.js.map +1 -0
  54. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -0
  55. package/dist/src/assets/img/icons/mediatype/account.js +14 -0
  56. package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
  57. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
  58. package/dist/src/assets/img/icons/mediatype/audio.js +14 -0
  59. package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
  60. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
  61. package/dist/src/assets/img/icons/mediatype/collection.js +12 -0
  62. package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
  63. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -0
  64. package/dist/src/assets/img/icons/mediatype/data.js +15 -0
  65. package/dist/src/assets/img/icons/mediatype/data.js.map +1 -0
  66. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
  67. package/dist/src/assets/img/icons/mediatype/etree.js +14 -0
  68. package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
  69. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
  70. package/dist/src/assets/img/icons/mediatype/film.js +14 -0
  71. package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
  72. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
  73. package/dist/src/assets/img/icons/mediatype/images.js +13 -0
  74. package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
  75. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -0
  76. package/dist/src/assets/img/icons/mediatype/radio.js +15 -0
  77. package/dist/src/assets/img/icons/mediatype/radio.js.map +1 -0
  78. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -0
  79. package/dist/src/assets/img/icons/mediatype/search.js +14 -0
  80. package/dist/src/assets/img/icons/mediatype/search.js.map +1 -0
  81. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
  82. package/dist/src/assets/img/icons/mediatype/software.js +13 -0
  83. package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
  84. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
  85. package/dist/src/assets/img/icons/mediatype/texts.js +13 -0
  86. package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
  87. package/dist/src/assets/img/icons/mediatype/tv-commercial.d.ts +1 -0
  88. package/dist/src/assets/img/icons/mediatype/tv-commercial.js +12 -0
  89. package/dist/src/assets/img/icons/mediatype/tv-commercial.js.map +1 -0
  90. package/dist/src/assets/img/icons/mediatype/tv-fact-check.d.ts +1 -0
  91. package/dist/src/assets/img/icons/mediatype/tv-fact-check.js +12 -0
  92. package/dist/src/assets/img/icons/mediatype/tv-fact-check.js.map +1 -0
  93. package/dist/src/assets/img/icons/mediatype/tv-quote.d.ts +1 -0
  94. package/dist/src/assets/img/icons/mediatype/tv-quote.js +12 -0
  95. package/dist/src/assets/img/icons/mediatype/tv-quote.js.map +1 -0
  96. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
  97. package/dist/src/assets/img/icons/mediatype/tv.js +14 -0
  98. package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
  99. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
  100. package/dist/src/assets/img/icons/mediatype/video.js +14 -0
  101. package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
  102. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
  103. package/dist/src/assets/img/icons/mediatype/web.js +13 -0
  104. package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
  105. package/dist/src/assets/img/icons/null-result.d.ts +2 -0
  106. package/dist/src/assets/img/icons/null-result.js +5 -0
  107. package/dist/src/assets/img/icons/null-result.js.map +1 -0
  108. package/dist/src/assets/img/icons/quote.d.ts +1 -0
  109. package/dist/src/assets/img/icons/quote.js +7 -0
  110. package/dist/src/assets/img/icons/quote.js.map +1 -0
  111. package/dist/src/assets/img/icons/restricted.d.ts +1 -0
  112. package/dist/src/assets/img/icons/restricted.js +13 -0
  113. package/dist/src/assets/img/icons/restricted.js.map +1 -0
  114. package/dist/src/assets/img/icons/reviews.d.ts +1 -0
  115. package/dist/src/assets/img/icons/reviews.js +11 -0
  116. package/dist/src/assets/img/icons/reviews.js.map +1 -0
  117. package/dist/src/assets/img/icons/upload.d.ts +1 -0
  118. package/dist/src/assets/img/icons/upload.js +12 -0
  119. package/dist/src/assets/img/icons/upload.js.map +1 -0
  120. package/dist/src/assets/img/icons/views.d.ts +1 -0
  121. package/dist/src/assets/img/icons/views.js +11 -0
  122. package/dist/src/assets/img/icons/views.js.map +1 -0
  123. package/dist/src/circular-activity-indicator.d.ts +5 -0
  124. package/dist/src/circular-activity-indicator.js +66 -0
  125. package/dist/src/circular-activity-indicator.js.map +1 -0
  126. package/dist/src/collection-browser.d.ts +684 -0
  127. package/dist/src/collection-browser.js +2567 -0
  128. package/dist/src/collection-browser.js.map +1 -0
  129. package/dist/src/collection-facets/facet-row.d.ts +30 -0
  130. package/dist/src/collection-facets/facet-row.js +265 -0
  131. package/dist/src/collection-facets/facet-row.js.map +1 -0
  132. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -0
  133. package/dist/src/collection-facets/facet-tombstone-row.js +43 -0
  134. package/dist/src/collection-facets/facet-tombstone-row.js.map +1 -0
  135. package/dist/src/collection-facets/facets-template.d.ts +13 -0
  136. package/dist/src/collection-facets/facets-template.js +68 -0
  137. package/dist/src/collection-facets/facets-template.js.map +1 -0
  138. package/dist/src/collection-facets/models.d.ts +9 -0
  139. package/dist/src/collection-facets/models.js +10 -0
  140. package/dist/src/collection-facets/models.js.map +1 -0
  141. package/dist/src/collection-facets/more-facets-content.d.ts +109 -0
  142. package/dist/src/collection-facets/more-facets-content.js +547 -0
  143. package/dist/src/collection-facets/more-facets-content.js.map +1 -0
  144. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -0
  145. package/dist/src/collection-facets/more-facets-pagination.js +264 -0
  146. package/dist/src/collection-facets/more-facets-pagination.js.map +1 -0
  147. package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -0
  148. package/dist/src/collection-facets/smart-facets/dedupe.js +35 -0
  149. package/dist/src/collection-facets/smart-facets/dedupe.js.map +1 -0
  150. package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.d.ts +5 -0
  151. package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.js +24 -0
  152. package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.js.map +1 -0
  153. package/dist/src/collection-facets/smart-facets/heuristics/index.d.ts +3 -0
  154. package/dist/src/collection-facets/smart-facets/heuristics/index.js +4 -0
  155. package/dist/src/collection-facets/smart-facets/heuristics/index.js.map +1 -0
  156. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.d.ts +4 -0
  157. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js +14 -0
  158. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js.map +1 -0
  159. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.d.ts +6 -0
  160. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.js +68 -0
  161. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.js.map +1 -0
  162. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.d.ts +9 -0
  163. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.js +69 -0
  164. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.js.map +1 -0
  165. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.d.ts +21 -0
  166. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +76 -0
  167. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +1 -0
  168. package/dist/src/collection-facets/smart-facets/models.d.ts +30 -0
  169. package/dist/src/collection-facets/smart-facets/models.js +2 -0
  170. package/dist/src/collection-facets/smart-facets/models.js.map +1 -0
  171. package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +54 -0
  172. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +383 -0
  173. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -0
  174. package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -0
  175. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +133 -0
  176. package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -0
  177. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +28 -0
  178. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +172 -0
  179. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -0
  180. package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -0
  181. package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +13 -0
  182. package/dist/src/collection-facets/smart-facets/smart-facet-equals.js.map +1 -0
  183. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -0
  184. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +18 -0
  185. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -0
  186. package/dist/src/collection-facets/toggle-switch.d.ts +41 -0
  187. package/dist/src/collection-facets/toggle-switch.js +174 -0
  188. package/dist/src/collection-facets/toggle-switch.js.map +1 -0
  189. package/dist/src/collection-facets.d.ts +113 -0
  190. package/dist/src/collection-facets.js +872 -0
  191. package/dist/src/collection-facets.js.map +1 -0
  192. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +261 -0
  193. package/dist/src/data-source/collection-browser-data-source-interface.js +2 -0
  194. package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -0
  195. package/dist/src/data-source/collection-browser-data-source.d.ts +400 -0
  196. package/dist/src/data-source/collection-browser-data-source.js +1103 -0
  197. package/dist/src/data-source/collection-browser-data-source.js.map +1 -0
  198. package/dist/src/data-source/collection-browser-query-state.d.ts +49 -0
  199. package/dist/src/data-source/collection-browser-query-state.js +2 -0
  200. package/dist/src/data-source/collection-browser-query-state.js.map +1 -0
  201. package/dist/src/data-source/models.d.ts +32 -0
  202. package/dist/src/data-source/models.js +9 -0
  203. package/dist/src/data-source/models.js.map +1 -0
  204. package/dist/src/empty-placeholder.d.ts +23 -0
  205. package/dist/src/empty-placeholder.js +165 -0
  206. package/dist/src/empty-placeholder.js.map +1 -0
  207. package/dist/src/expanded-date-picker.d.ts +50 -0
  208. package/dist/src/expanded-date-picker.js +182 -0
  209. package/dist/src/expanded-date-picker.js.map +1 -0
  210. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -0
  211. package/dist/src/language-code-handler/language-code-handler.js +27 -0
  212. package/dist/src/language-code-handler/language-code-handler.js.map +1 -0
  213. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -0
  214. package/dist/src/language-code-handler/language-code-mapping.js +563 -0
  215. package/dist/src/language-code-handler/language-code-mapping.js.map +1 -0
  216. package/dist/src/manage/manage-bar.d.ts +58 -0
  217. package/dist/src/manage/manage-bar.js +237 -0
  218. package/dist/src/manage/manage-bar.js.map +1 -0
  219. package/dist/src/manage/remove-items-modal-content.d.ts +9 -0
  220. package/dist/src/manage/remove-items-modal-content.js +104 -0
  221. package/dist/src/manage/remove-items-modal-content.js.map +1 -0
  222. package/dist/src/mediatype/mediatype-config.d.ts +11 -0
  223. package/dist/src/mediatype/mediatype-config.js +116 -0
  224. package/dist/src/mediatype/mediatype-config.js.map +1 -0
  225. package/dist/src/models.d.ts +302 -0
  226. package/dist/src/models.js +511 -0
  227. package/dist/src/models.js.map +1 -0
  228. package/dist/src/restoration-state-handler.d.ts +75 -0
  229. package/dist/src/restoration-state-handler.js +403 -0
  230. package/dist/src/restoration-state-handler.js.map +1 -0
  231. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -0
  232. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +60 -0
  233. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js.map +1 -0
  234. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -0
  235. package/dist/src/sort-filter-bar/alpha-bar.js +241 -0
  236. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
  237. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -0
  238. package/dist/src/sort-filter-bar/img/compact.js +5 -0
  239. package/dist/src/sort-filter-bar/img/compact.js.map +1 -0
  240. package/dist/src/sort-filter-bar/img/list.d.ts +1 -0
  241. package/dist/src/sort-filter-bar/img/list.js +5 -0
  242. package/dist/src/sort-filter-bar/img/list.js.map +1 -0
  243. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -0
  244. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +15 -0
  245. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js.map +1 -0
  246. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -0
  247. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +17 -0
  248. package/dist/src/sort-filter-bar/img/sort-toggle-down.js.map +1 -0
  249. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -0
  250. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +17 -0
  251. package/dist/src/sort-filter-bar/img/sort-toggle-up.js.map +1 -0
  252. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -0
  253. package/dist/src/sort-filter-bar/img/sort-triangle.js +5 -0
  254. package/dist/src/sort-filter-bar/img/sort-triangle.js.map +1 -0
  255. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -0
  256. package/dist/src/sort-filter-bar/img/tile.js +5 -0
  257. package/dist/src/sort-filter-bar/img/tile.js.map +1 -0
  258. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +278 -0
  259. package/dist/src/sort-filter-bar/sort-filter-bar.js +1161 -0
  260. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
  261. package/dist/src/styles/ia-button.d.ts +2 -0
  262. package/dist/src/styles/ia-button.js +134 -0
  263. package/dist/src/styles/ia-button.js.map +1 -0
  264. package/dist/src/styles/item-image-styles.d.ts +8 -0
  265. package/dist/src/styles/item-image-styles.js +123 -0
  266. package/dist/src/styles/item-image-styles.js.map +1 -0
  267. package/dist/src/styles/sr-only.d.ts +1 -0
  268. package/dist/src/styles/sr-only.js +18 -0
  269. package/dist/src/styles/sr-only.js.map +1 -0
  270. package/dist/src/tiles/base-tile-component.d.ts +27 -0
  271. package/dist/src/tiles/base-tile-component.js +82 -0
  272. package/dist/src/tiles/base-tile-component.js.map +1 -0
  273. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -0
  274. package/dist/src/tiles/collection-browser-loading-tile.js +29 -0
  275. package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -0
  276. package/dist/src/tiles/grid/account-tile.d.ts +18 -0
  277. package/dist/src/tiles/grid/account-tile.js +111 -0
  278. package/dist/src/tiles/grid/account-tile.js.map +1 -0
  279. package/dist/src/tiles/grid/collection-tile.d.ts +15 -0
  280. package/dist/src/tiles/grid/collection-tile.js +160 -0
  281. package/dist/src/tiles/grid/collection-tile.js.map +1 -0
  282. package/dist/src/tiles/grid/item-tile.d.ts +41 -0
  283. package/dist/src/tiles/grid/item-tile.js +321 -0
  284. package/dist/src/tiles/grid/item-tile.js.map +1 -0
  285. package/dist/src/tiles/grid/search-tile.d.ts +10 -0
  286. package/dist/src/tiles/grid/search-tile.js +95 -0
  287. package/dist/src/tiles/grid/search-tile.js.map +1 -0
  288. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -0
  289. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +128 -0
  290. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -0
  291. package/dist/src/tiles/grid/tile-stats.d.ts +58 -0
  292. package/dist/src/tiles/grid/tile-stats.js +204 -0
  293. package/dist/src/tiles/grid/tile-stats.js.map +1 -0
  294. package/dist/src/tiles/hover/hover-pane-controller.d.ts +228 -0
  295. package/dist/src/tiles/hover/hover-pane-controller.js +446 -0
  296. package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -0
  297. package/dist/src/tiles/hover/tile-hover-pane.d.ts +20 -0
  298. package/dist/src/tiles/hover/tile-hover-pane.js +185 -0
  299. package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -0
  300. package/dist/src/tiles/image-block.d.ts +19 -0
  301. package/dist/src/tiles/image-block.js +175 -0
  302. package/dist/src/tiles/image-block.js.map +1 -0
  303. package/dist/src/tiles/item-image.d.ts +40 -0
  304. package/dist/src/tiles/item-image.js +191 -0
  305. package/dist/src/tiles/item-image.js.map +1 -0
  306. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -0
  307. package/dist/src/tiles/list/tile-list-compact-header.js +85 -0
  308. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -0
  309. package/dist/src/tiles/list/tile-list-compact.d.ts +19 -0
  310. package/dist/src/tiles/list/tile-list-compact.js +223 -0
  311. package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
  312. package/dist/src/tiles/list/tile-list.d.ts +54 -0
  313. package/dist/src/tiles/list/tile-list.js +621 -0
  314. package/dist/src/tiles/list/tile-list.js.map +1 -0
  315. package/dist/src/tiles/models.d.ts +1 -0
  316. package/dist/src/tiles/models.js +2 -0
  317. package/dist/src/tiles/models.js.map +1 -0
  318. package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -0
  319. package/dist/src/tiles/overlay/icon-overlay.js +55 -0
  320. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -0
  321. package/dist/src/tiles/overlay/text-overlay.d.ts +9 -0
  322. package/dist/src/tiles/overlay/text-overlay.js +74 -0
  323. package/dist/src/tiles/overlay/text-overlay.js.map +1 -0
  324. package/dist/src/tiles/review-block.d.ts +12 -0
  325. package/dist/src/tiles/review-block.js +134 -0
  326. package/dist/src/tiles/review-block.js.map +1 -0
  327. package/dist/src/tiles/text-snippet-block.d.ts +27 -0
  328. package/dist/src/tiles/text-snippet-block.js +132 -0
  329. package/dist/src/tiles/text-snippet-block.js.map +1 -0
  330. package/dist/src/tiles/tile-dispatcher.d.ts +71 -0
  331. package/dist/src/tiles/tile-dispatcher.js +472 -0
  332. package/dist/src/tiles/tile-dispatcher.js.map +1 -0
  333. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -0
  334. package/dist/src/tiles/tile-display-value-provider.js +95 -0
  335. package/dist/src/tiles/tile-display-value-provider.js.map +1 -0
  336. package/dist/src/tiles/tile-mediatype-icon.d.ts +27 -0
  337. package/dist/src/tiles/tile-mediatype-icon.js +130 -0
  338. package/dist/src/tiles/tile-mediatype-icon.js.map +1 -0
  339. package/dist/src/utils/analytics-events.d.ts +28 -0
  340. package/dist/src/utils/analytics-events.js +31 -0
  341. package/dist/src/utils/analytics-events.js.map +1 -0
  342. package/dist/src/utils/array-equals.d.ts +4 -0
  343. package/dist/src/utils/array-equals.js +11 -0
  344. package/dist/src/utils/array-equals.js.map +1 -0
  345. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -0
  346. package/dist/src/utils/collapse-repeated-quotes.js +14 -0
  347. package/dist/src/utils/collapse-repeated-quotes.js.map +1 -0
  348. package/dist/src/utils/facet-utils.d.ts +83 -0
  349. package/dist/src/utils/facet-utils.js +152 -0
  350. package/dist/src/utils/facet-utils.js.map +1 -0
  351. package/dist/src/utils/format-count.d.ts +7 -0
  352. package/dist/src/utils/format-count.js +76 -0
  353. package/dist/src/utils/format-count.js.map +1 -0
  354. package/dist/src/utils/format-date.d.ts +16 -0
  355. package/dist/src/utils/format-date.js +33 -0
  356. package/dist/src/utils/format-date.js.map +1 -0
  357. package/dist/src/utils/format-unit-size.d.ts +2 -0
  358. package/dist/src/utils/format-unit-size.js +34 -0
  359. package/dist/src/utils/format-unit-size.js.map +1 -0
  360. package/dist/src/utils/local-date-from-utc.d.ts +9 -0
  361. package/dist/src/utils/local-date-from-utc.js +16 -0
  362. package/dist/src/utils/local-date-from-utc.js.map +1 -0
  363. package/dist/src/utils/log.d.ts +7 -0
  364. package/dist/src/utils/log.js +14 -0
  365. package/dist/src/utils/log.js.map +1 -0
  366. package/dist/src/utils/resolve-mediatype.d.ts +8 -0
  367. package/dist/src/utils/resolve-mediatype.js +24 -0
  368. package/dist/src/utils/resolve-mediatype.js.map +1 -0
  369. package/dist/src/utils/sha1.d.ts +2 -0
  370. package/dist/src/utils/sha1.js +9 -0
  371. package/dist/src/utils/sha1.js.map +1 -0
  372. package/dist/test/collection-browser.test.d.ts +1 -0
  373. package/dist/test/collection-browser.test.js +1711 -0
  374. package/dist/test/collection-browser.test.js.map +1 -0
  375. package/dist/test/collection-facets/facet-row.test.d.ts +1 -0
  376. package/dist/test/collection-facets/facet-row.test.js +274 -0
  377. package/dist/test/collection-facets/facet-row.test.js.map +1 -0
  378. package/dist/test/collection-facets/facets-template.test.d.ts +1 -0
  379. package/dist/test/collection-facets/facets-template.test.js +101 -0
  380. package/dist/test/collection-facets/facets-template.test.js.map +1 -0
  381. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -0
  382. package/dist/test/collection-facets/more-facets-content.test.js +169 -0
  383. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -0
  384. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -0
  385. package/dist/test/collection-facets/more-facets-pagination.test.js +132 -0
  386. package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -0
  387. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -0
  388. package/dist/test/collection-facets/toggle-switch.test.js +96 -0
  389. package/dist/test/collection-facets/toggle-switch.test.js.map +1 -0
  390. package/dist/test/collection-facets.test.d.ts +2 -0
  391. package/dist/test/collection-facets.test.js +745 -0
  392. package/dist/test/collection-facets.test.js.map +1 -0
  393. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -0
  394. package/dist/test/data-source/collection-browser-data-source.test.js +102 -0
  395. package/dist/test/data-source/collection-browser-data-source.test.js.map +1 -0
  396. package/dist/test/empty-placeholder.test.d.ts +1 -0
  397. package/dist/test/empty-placeholder.test.js +63 -0
  398. package/dist/test/empty-placeholder.test.js.map +1 -0
  399. package/dist/test/expanded-date-picker.test.d.ts +1 -0
  400. package/dist/test/expanded-date-picker.test.js +130 -0
  401. package/dist/test/expanded-date-picker.test.js.map +1 -0
  402. package/dist/test/icon-overlay.test.d.ts +1 -0
  403. package/dist/test/icon-overlay.test.js +30 -0
  404. package/dist/test/icon-overlay.test.js.map +1 -0
  405. package/dist/test/image-block.test.d.ts +1 -0
  406. package/dist/test/image-block.test.js +218 -0
  407. package/dist/test/image-block.test.js.map +1 -0
  408. package/dist/test/item-image.test.d.ts +1 -0
  409. package/dist/test/item-image.test.js +196 -0
  410. package/dist/test/item-image.test.js.map +1 -0
  411. package/dist/test/manage/manage-bar.test.d.ts +2 -0
  412. package/dist/test/manage/manage-bar.test.js +106 -0
  413. package/dist/test/manage/manage-bar.test.js.map +1 -0
  414. package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -0
  415. package/dist/test/manage/remove-items-modal-content.test.js +65 -0
  416. package/dist/test/manage/remove-items-modal-content.test.js.map +1 -0
  417. package/dist/test/mediatype-config.test.d.ts +1 -0
  418. package/dist/test/mediatype-config.test.js +11 -0
  419. package/dist/test/mediatype-config.test.js.map +1 -0
  420. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -0
  421. package/dist/test/mocks/mock-analytics-handler.js +16 -0
  422. package/dist/test/mocks/mock-analytics-handler.js.map +1 -0
  423. package/dist/test/mocks/mock-search-responses.d.ts +31 -0
  424. package/dist/test/mocks/mock-search-responses.js +1241 -0
  425. package/dist/test/mocks/mock-search-responses.js.map +1 -0
  426. package/dist/test/mocks/mock-search-service.d.ts +16 -0
  427. package/dist/test/mocks/mock-search-service.js +65 -0
  428. package/dist/test/mocks/mock-search-service.js.map +1 -0
  429. package/dist/test/restoration-state-handler.test.d.ts +1 -0
  430. package/dist/test/restoration-state-handler.test.js +375 -0
  431. package/dist/test/restoration-state-handler.test.js.map +1 -0
  432. package/dist/test/review-block.test.d.ts +1 -0
  433. package/dist/test/review-block.test.js +48 -0
  434. package/dist/test/review-block.test.js.map +1 -0
  435. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -0
  436. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +13 -0
  437. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -0
  438. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -0
  439. package/dist/test/sort-filter-bar/alpha-bar.test.js +74 -0
  440. package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -0
  441. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -0
  442. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +609 -0
  443. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -0
  444. package/dist/test/text-overlay.test.d.ts +1 -0
  445. package/dist/test/text-overlay.test.js +42 -0
  446. package/dist/test/text-overlay.test.js.map +1 -0
  447. package/dist/test/text-snippet-block.test.d.ts +1 -0
  448. package/dist/test/text-snippet-block.test.js +63 -0
  449. package/dist/test/text-snippet-block.test.js.map +1 -0
  450. package/dist/test/tile-stats.test.d.ts +1 -0
  451. package/dist/test/tile-stats.test.js +128 -0
  452. package/dist/test/tile-stats.test.js.map +1 -0
  453. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -0
  454. package/dist/test/tiles/grid/account-tile.test.js +96 -0
  455. package/dist/test/tiles/grid/account-tile.test.js.map +1 -0
  456. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -0
  457. package/dist/test/tiles/grid/collection-tile.test.js +96 -0
  458. package/dist/test/tiles/grid/collection-tile.test.js.map +1 -0
  459. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -0
  460. package/dist/test/tiles/grid/item-tile.test.js +427 -0
  461. package/dist/test/tiles/grid/item-tile.test.js.map +1 -0
  462. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -0
  463. package/dist/test/tiles/grid/search-tile.test.js +66 -0
  464. package/dist/test/tiles/grid/search-tile.test.js.map +1 -0
  465. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -0
  466. package/dist/test/tiles/hover/hover-pane-controller.test.js +329 -0
  467. package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -0
  468. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -0
  469. package/dist/test/tiles/hover/tile-hover-pane.test.js +57 -0
  470. package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -0
  471. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -0
  472. package/dist/test/tiles/list/tile-list-compact.test.js +251 -0
  473. package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -0
  474. package/dist/test/tiles/list/tile-list.test.d.ts +1 -0
  475. package/dist/test/tiles/list/tile-list.test.js +469 -0
  476. package/dist/test/tiles/list/tile-list.test.js.map +1 -0
  477. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -0
  478. package/dist/test/tiles/tile-dispatcher.test.js +231 -0
  479. package/dist/test/tiles/tile-dispatcher.test.js.map +1 -0
  480. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -0
  481. package/dist/test/tiles/tile-display-value-provider.test.js +142 -0
  482. package/dist/test/tiles/tile-display-value-provider.test.js.map +1 -0
  483. package/dist/test/tiles/tile-mediatype-icon.test.d.ts +1 -0
  484. package/dist/test/tiles/tile-mediatype-icon.test.js +145 -0
  485. package/dist/test/tiles/tile-mediatype-icon.test.js.map +1 -0
  486. package/dist/test/utils/array-equals.test.d.ts +1 -0
  487. package/dist/test/utils/array-equals.test.js +27 -0
  488. package/dist/test/utils/array-equals.test.js.map +1 -0
  489. package/dist/test/utils/format-count.test.d.ts +1 -0
  490. package/dist/test/utils/format-count.test.js +24 -0
  491. package/dist/test/utils/format-count.test.js.map +1 -0
  492. package/dist/test/utils/format-date.test.d.ts +1 -0
  493. package/dist/test/utils/format-date.test.js +61 -0
  494. package/dist/test/utils/format-date.test.js.map +1 -0
  495. package/dist/test/utils/format-unit-size.test.d.ts +1 -0
  496. package/dist/test/utils/format-unit-size.test.js +18 -0
  497. package/dist/test/utils/format-unit-size.test.js.map +1 -0
  498. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -0
  499. package/dist/test/utils/local-date-from-utc.test.js +27 -0
  500. package/dist/test/utils/local-date-from-utc.test.js.map +1 -0
  501. package/eslint.config.mjs +53 -53
  502. package/index.html +24 -24
  503. package/local.archive.org.cert +86 -86
  504. package/local.archive.org.key +27 -27
  505. package/package.json +118 -117
  506. package/renovate.json +6 -6
  507. package/src/collection-browser.ts +2829 -2829
  508. package/src/collection-facets/more-facets-content.ts +639 -639
  509. package/src/collection-facets.ts +994 -995
  510. package/src/data-source/collection-browser-data-source.ts +1401 -1401
  511. package/src/data-source/collection-browser-query-state.ts +65 -65
  512. package/src/data-source/models.ts +43 -43
  513. package/src/tiles/base-tile-component.ts +65 -65
  514. package/src/tiles/grid/account-tile.ts +113 -113
  515. package/src/tiles/grid/collection-tile.ts +163 -163
  516. package/src/tiles/grid/item-tile.ts +340 -340
  517. package/src/tiles/hover/hover-pane-controller.ts +613 -517
  518. package/src/tiles/hover/tile-hover-pane.ts +184 -180
  519. package/src/tiles/list/tile-list-compact.ts +239 -239
  520. package/src/tiles/list/tile-list.ts +700 -700
  521. package/src/tiles/tile-dispatcher.ts +517 -490
  522. package/src/utils/format-date.ts +62 -62
  523. package/test/collection-browser.test.ts +2403 -2403
  524. package/test/tiles/grid/item-tile.test.ts +520 -520
  525. package/test/tiles/hover/hover-pane-controller.test.ts +418 -353
  526. package/test/tiles/list/tile-list-compact.test.ts +282 -282
  527. package/test/tiles/list/tile-list.test.ts +552 -552
  528. package/test/tiles/tile-dispatcher.test.ts +283 -187
  529. package/test/utils/format-date.test.ts +89 -89
  530. package/tsconfig.json +20 -20
  531. package/web-dev-server.config.mjs +30 -30
  532. package/web-test-runner.config.mjs +41 -41
@@ -1,187 +1,283 @@
1
- import { aTimeout, expect, fixture } from '@open-wc/testing';
2
- import { html } from 'lit';
3
- import sinon from 'sinon';
4
- import type { TileDispatcher } from '../../src/tiles/tile-dispatcher';
5
-
6
- import '../../src/tiles/tile-dispatcher';
7
- import type { ItemTile } from '../../src/tiles/grid/item-tile';
8
- import { TileHoverPane } from '../../src/tiles/hover/tile-hover-pane';
9
- import type { HoverPaneProperties } from '../../src/tiles/hover/hover-pane-controller';
10
-
11
- describe('Tile Dispatcher', () => {
12
- it('should render item-tile for grid mode by default', async () => {
13
- const el = await fixture<TileDispatcher>(html`
14
- <tile-dispatcher
15
- .tileDisplayMode=${'grid'}
16
- .model=${{ mediatype: 'texts' }}
17
- >
18
- </tile-dispatcher>
19
- `);
20
-
21
- const itemTile = el.shadowRoot?.querySelector('item-tile');
22
- expect(itemTile).to.exist;
23
- });
24
-
25
- it('should render collection-tile for grid mode and collection mediatype', async () => {
26
- const el = await fixture<TileDispatcher>(html`
27
- <tile-dispatcher
28
- .tileDisplayMode=${'grid'}
29
- .model=${{ mediatype: 'collection' }}
30
- >
31
- </tile-dispatcher>
32
- `);
33
-
34
- const collectionTile = el.shadowRoot?.querySelector('collection-tile');
35
- expect(collectionTile).to.exist;
36
- });
37
-
38
- it('should render account-tile for grid mode and account mediatype', async () => {
39
- const el = await fixture<TileDispatcher>(html`
40
- <tile-dispatcher
41
- .tileDisplayMode=${'grid'}
42
- .model=${{ mediatype: 'account' }}
43
- >
44
- </tile-dispatcher>
45
- `);
46
-
47
- const accountTile = el.shadowRoot?.querySelector('account-tile');
48
- expect(accountTile).to.exist;
49
- });
50
-
51
- it('should render search-tile for grid mode and search mediatype', async () => {
52
- const el = await fixture<TileDispatcher>(html`
53
- <tile-dispatcher
54
- .tileDisplayMode=${'grid'}
55
- .model=${{ mediatype: 'search' }}
56
- >
57
- </tile-dispatcher>
58
- `);
59
-
60
- const searchTile = el.shadowRoot?.querySelector('search-tile');
61
- expect(searchTile).to.exist;
62
- });
63
-
64
- it('should render tile-list for extended list mode', async () => {
65
- const el = await fixture<TileDispatcher>(html`
66
- <tile-dispatcher .tileDisplayMode=${'list-detail'} .model=${{}}>
67
- </tile-dispatcher>
68
- `);
69
-
70
- const listTile = el.shadowRoot?.querySelector('tile-list');
71
- expect(listTile).to.exist;
72
- });
73
-
74
- it('should render tile-list-compact for compact list mode', async () => {
75
- const el = await fixture<TileDispatcher>(html`
76
- <tile-dispatcher .tileDisplayMode=${'list-compact'} .model=${{}}>
77
- </tile-dispatcher>
78
- `);
79
-
80
- const compactListTile = el.shadowRoot?.querySelector('tile-list-compact');
81
- expect(compactListTile).to.exist;
82
- });
83
-
84
- it('should open item in new tab when right-clicked in manage mode', async () => {
85
- const oldWindowOpen = window.open;
86
- const spy = sinon.spy();
87
- window.open = spy;
88
-
89
- const el = await fixture<TileDispatcher>(html`
90
- <tile-dispatcher
91
- isManageView
92
- .model=${{ identifier: 'foo', href: '/foo' }}
93
- .baseNavigationUrl=${''}
94
- >
95
- </tile-dispatcher>
96
- `);
97
-
98
- const tileLink = el.shadowRoot?.querySelector(
99
- 'a[href]',
100
- ) as HTMLAnchorElement;
101
- expect(tileLink).to.exist;
102
-
103
- tileLink.dispatchEvent(new Event('contextmenu'));
104
- await el.updateComplete;
105
-
106
- expect(spy.callCount).to.equal(1);
107
- expect(spy.args[0][0]).to.equal('/foo');
108
- expect(spy.args[0][1]).to.equal('_blank');
109
-
110
- window.open = oldWindowOpen;
111
- });
112
-
113
- it('should toggle model checked state when manage check clicked', async () => {
114
- const el = await fixture<TileDispatcher>(html`
115
- <tile-dispatcher
116
- isManageView
117
- .model=${{ identifier: 'foo', href: '/foo' }}
118
- .tileDisplayMode=${'grid'}
119
- ></tile-dispatcher>
120
- `);
121
-
122
- const manageCheck = el.shadowRoot?.querySelector(
123
- '.manage-check > input[type="checkbox"]',
124
- ) as HTMLButtonElement;
125
-
126
- manageCheck.click();
127
- await el.updateComplete;
128
- expect(el.model?.checked).to.be.true;
129
-
130
- manageCheck.click();
131
- await el.updateComplete;
132
- expect(el.model?.checked).to.be.false;
133
- });
134
-
135
- it('should return hover pane props', async () => {
136
- const el = await fixture<TileDispatcher>(html`
137
- <tile-dispatcher .model=${{ identifier: 'foo' }}> </tile-dispatcher>
138
- `);
139
-
140
- expect(el.getHoverPaneProps()).to.satisfy(
141
- (props: HoverPaneProperties) => props?.model?.identifier === 'foo',
142
- );
143
- });
144
-
145
- describe('Hover pane info button behavior', () => {
146
- let oldMatchMedia: typeof window.matchMedia;
147
-
148
- before(() => {
149
- oldMatchMedia = window.matchMedia;
150
- // Pretend that there is no hover-capable input device
151
- window.matchMedia = () => ({ matches: false }) as MediaQueryList;
152
- });
153
-
154
- after(() => {
155
- window.matchMedia = oldMatchMedia;
156
- });
157
-
158
- it('should toggle hover pane when tile info button is pressed', async () => {
159
- const el = await fixture<TileDispatcher>(html`
160
- <tile-dispatcher
161
- .tileDisplayMode=${'grid'}
162
- .model=${{ mediatype: 'texts' }}
163
- .enableHoverPane=${true}
164
- >
165
- </tile-dispatcher>
166
- `);
167
-
168
- const itemTile = el.shadowRoot?.querySelector('item-tile') as ItemTile;
169
- expect(itemTile).to.exist;
170
-
171
- const infoButton = itemTile.shadowRoot?.querySelector(
172
- '.info-button',
173
- ) as HTMLButtonElement;
174
- expect(infoButton).to.exist;
175
-
176
- infoButton.click();
177
- await aTimeout(500);
178
- await el.updateComplete;
179
- expect(el.getHoverPane()).to.be.instanceOf(TileHoverPane);
180
-
181
- infoButton.click();
182
- await aTimeout(500);
183
- await el.updateComplete;
184
- expect(el.getHoverPane()).not.to.exist;
185
- });
186
- });
187
- });
1
+ import { aTimeout, expect, fixture } from '@open-wc/testing';
2
+ import { html } from 'lit';
3
+ import sinon from 'sinon';
4
+ import type { TileDispatcher } from '../../src/tiles/tile-dispatcher';
5
+
6
+ import '../../src/tiles/tile-dispatcher';
7
+ import type { ItemTile } from '../../src/tiles/grid/item-tile';
8
+ import { TileHoverPane } from '../../src/tiles/hover/tile-hover-pane';
9
+ import type { HoverPaneProperties } from '../../src/tiles/hover/hover-pane-controller';
10
+
11
+ describe('Tile Dispatcher', () => {
12
+ it('should render item-tile for grid mode by default', async () => {
13
+ const el = await fixture<TileDispatcher>(html`
14
+ <tile-dispatcher
15
+ .tileDisplayMode=${'grid'}
16
+ .model=${{ mediatype: 'texts' }}
17
+ >
18
+ </tile-dispatcher>
19
+ `);
20
+
21
+ const itemTile = el.shadowRoot?.querySelector('item-tile');
22
+ expect(itemTile).to.exist;
23
+ });
24
+
25
+ it('should render collection-tile for grid mode and collection mediatype', async () => {
26
+ const el = await fixture<TileDispatcher>(html`
27
+ <tile-dispatcher
28
+ .tileDisplayMode=${'grid'}
29
+ .model=${{ mediatype: 'collection' }}
30
+ >
31
+ </tile-dispatcher>
32
+ `);
33
+
34
+ const collectionTile = el.shadowRoot?.querySelector('collection-tile');
35
+ expect(collectionTile).to.exist;
36
+ });
37
+
38
+ it('should render account-tile for grid mode and account mediatype', async () => {
39
+ const el = await fixture<TileDispatcher>(html`
40
+ <tile-dispatcher
41
+ .tileDisplayMode=${'grid'}
42
+ .model=${{ mediatype: 'account' }}
43
+ >
44
+ </tile-dispatcher>
45
+ `);
46
+
47
+ const accountTile = el.shadowRoot?.querySelector('account-tile');
48
+ expect(accountTile).to.exist;
49
+ });
50
+
51
+ it('should render search-tile for grid mode and search mediatype', async () => {
52
+ const el = await fixture<TileDispatcher>(html`
53
+ <tile-dispatcher
54
+ .tileDisplayMode=${'grid'}
55
+ .model=${{ mediatype: 'search' }}
56
+ >
57
+ </tile-dispatcher>
58
+ `);
59
+
60
+ const searchTile = el.shadowRoot?.querySelector('search-tile');
61
+ expect(searchTile).to.exist;
62
+ });
63
+
64
+ it('should render tile-list for extended list mode', async () => {
65
+ const el = await fixture<TileDispatcher>(html`
66
+ <tile-dispatcher .tileDisplayMode=${'list-detail'} .model=${{}}>
67
+ </tile-dispatcher>
68
+ `);
69
+
70
+ const listTile = el.shadowRoot?.querySelector('tile-list');
71
+ expect(listTile).to.exist;
72
+ });
73
+
74
+ it('should render tile-list-compact for compact list mode', async () => {
75
+ const el = await fixture<TileDispatcher>(html`
76
+ <tile-dispatcher .tileDisplayMode=${'list-compact'} .model=${{}}>
77
+ </tile-dispatcher>
78
+ `);
79
+
80
+ const compactListTile = el.shadowRoot?.querySelector('tile-list-compact');
81
+ expect(compactListTile).to.exist;
82
+ });
83
+
84
+ it('should open item in new tab when right-clicked in manage mode', async () => {
85
+ const oldWindowOpen = window.open;
86
+ const spy = sinon.spy();
87
+ window.open = spy;
88
+
89
+ const el = await fixture<TileDispatcher>(html`
90
+ <tile-dispatcher
91
+ isManageView
92
+ .model=${{ identifier: 'foo', href: '/foo' }}
93
+ .baseNavigationUrl=${''}
94
+ >
95
+ </tile-dispatcher>
96
+ `);
97
+
98
+ const tileLink = el.shadowRoot?.querySelector(
99
+ 'a[href]',
100
+ ) as HTMLAnchorElement;
101
+ expect(tileLink).to.exist;
102
+
103
+ tileLink.dispatchEvent(new Event('contextmenu'));
104
+ await el.updateComplete;
105
+
106
+ expect(spy.callCount).to.equal(1);
107
+ expect(spy.args[0][0]).to.equal('/foo');
108
+ expect(spy.args[0][1]).to.equal('_blank');
109
+
110
+ window.open = oldWindowOpen;
111
+ });
112
+
113
+ it('should toggle model checked state when manage check clicked', async () => {
114
+ const el = await fixture<TileDispatcher>(html`
115
+ <tile-dispatcher
116
+ isManageView
117
+ .model=${{ identifier: 'foo', href: '/foo' }}
118
+ .tileDisplayMode=${'grid'}
119
+ ></tile-dispatcher>
120
+ `);
121
+
122
+ const manageCheck = el.shadowRoot?.querySelector(
123
+ '.manage-check > input[type="checkbox"]',
124
+ ) as HTMLButtonElement;
125
+
126
+ manageCheck.click();
127
+ await el.updateComplete;
128
+ expect(el.model?.checked).to.be.true;
129
+
130
+ manageCheck.click();
131
+ await el.updateComplete;
132
+ expect(el.model?.checked).to.be.false;
133
+ });
134
+
135
+ it('should return hover pane props', async () => {
136
+ const el = await fixture<TileDispatcher>(html`
137
+ <tile-dispatcher .model=${{ identifier: 'foo' }}> </tile-dispatcher>
138
+ `);
139
+
140
+ expect(el.getHoverPaneProps()).to.satisfy(
141
+ (props: HoverPaneProperties) => props?.model?.identifier === 'foo',
142
+ );
143
+ });
144
+
145
+ it('should focus the tile link when requested', async () => {
146
+ const el = await fixture<TileDispatcher>(html`
147
+ <tile-dispatcher .tileDisplayMode=${'grid'}> </tile-dispatcher>
148
+ `);
149
+
150
+ const tileLink = el.shadowRoot?.querySelector(
151
+ '.tile-link',
152
+ ) as HTMLAnchorElement;
153
+ expect(tileLink).to.exist;
154
+
155
+ const spyFocus = sinon.spy(tileLink, 'focus');
156
+ el.acquireFocus();
157
+ expect(spyFocus.callCount).to.equal(1);
158
+ });
159
+
160
+ it('should blur the tile link when requested', async () => {
161
+ const el = await fixture<TileDispatcher>(html`
162
+ <tile-dispatcher .tileDisplayMode=${'grid'}> </tile-dispatcher>
163
+ `);
164
+
165
+ const tileLink = el.shadowRoot?.querySelector(
166
+ '.tile-link',
167
+ ) as HTMLAnchorElement;
168
+ expect(tileLink).to.exist;
169
+
170
+ const spyBlur = sinon.spy(tileLink, 'blur');
171
+ el.releaseFocus();
172
+ expect(spyBlur.callCount).to.equal(1);
173
+ });
174
+
175
+ describe('Hover pane info button behavior', () => {
176
+ let oldMatchMedia: typeof window.matchMedia;
177
+
178
+ before(() => {
179
+ oldMatchMedia = window.matchMedia;
180
+ // Pretend that there is no hover-capable input device
181
+ window.matchMedia = () => ({ matches: false }) as MediaQueryList;
182
+ });
183
+
184
+ after(() => {
185
+ window.matchMedia = oldMatchMedia;
186
+ });
187
+
188
+ it('should toggle hover pane when tile info button is pressed', async () => {
189
+ const el = await fixture<TileDispatcher>(html`
190
+ <tile-dispatcher
191
+ .tileDisplayMode=${'grid'}
192
+ .model=${{ mediatype: 'texts' }}
193
+ .enableHoverPane=${true}
194
+ >
195
+ </tile-dispatcher>
196
+ `);
197
+
198
+ const itemTile = el.shadowRoot?.querySelector('item-tile') as ItemTile;
199
+ expect(itemTile).to.exist;
200
+
201
+ const infoButton = itemTile.shadowRoot?.querySelector(
202
+ '.info-button',
203
+ ) as HTMLButtonElement;
204
+ expect(infoButton).to.exist;
205
+
206
+ infoButton.click();
207
+ await aTimeout(500);
208
+ await el.updateComplete;
209
+ expect(el.getHoverPane()).to.be.instanceOf(TileHoverPane);
210
+
211
+ infoButton.click();
212
+ await aTimeout(500);
213
+ await el.updateComplete;
214
+ expect(el.getHoverPane()).not.to.exist;
215
+ });
216
+ });
217
+
218
+ describe('Accessibility', () => {
219
+ it('should have proper aria-label on tile link', async () => {
220
+ const el = await fixture<TileDispatcher>(html`
221
+ <tile-dispatcher
222
+ .tileDisplayMode=${'grid'}
223
+ .model=${{
224
+ title: 'Example Title',
225
+ mediatype: 'texts',
226
+ }}
227
+ >
228
+ </tile-dispatcher>
229
+ `);
230
+
231
+ const tileLink = el.shadowRoot?.querySelector(
232
+ '.tile-link',
233
+ ) as HTMLAnchorElement;
234
+ expect(tileLink).to.exist;
235
+ expect(tileLink.getAttribute('aria-label')).to.equal('Example Title');
236
+ });
237
+
238
+ it('should fallback to untitled aria-label on tile link when no title', async () => {
239
+ const el = await fixture<TileDispatcher>(html`
240
+ <tile-dispatcher
241
+ .tileDisplayMode=${'grid'}
242
+ .model=${{
243
+ mediatype: 'texts',
244
+ }}
245
+ >
246
+ </tile-dispatcher>
247
+ `);
248
+
249
+ const tileLink = el.shadowRoot?.querySelector(
250
+ '.tile-link',
251
+ ) as HTMLAnchorElement;
252
+ expect(tileLink).to.exist;
253
+ expect(tileLink.getAttribute('aria-label')).to.equal('Untitled item');
254
+ });
255
+
256
+ it('should have no accessibility violations in grid mode', async () => {
257
+ const el = await fixture<TileDispatcher>(html`
258
+ <tile-dispatcher
259
+ .tileDisplayMode=${'grid'}
260
+ .model=${{
261
+ title: 'Example Title',
262
+ mediatype: 'texts',
263
+ }}
264
+ >
265
+ </tile-dispatcher>
266
+ `);
267
+
268
+ await expect(el).to.be.accessible();
269
+ });
270
+
271
+ it('should have no accessibility violations in list mode', async () => {
272
+ const el = await fixture<TileDispatcher>(html`
273
+ <tile-dispatcher
274
+ .tileDisplayMode=${'list-detail'}
275
+ .model=${{ mediatype: 'texts' }}
276
+ >
277
+ </tile-dispatcher>
278
+ `);
279
+
280
+ await expect(el).to.be.accessible();
281
+ });
282
+ });
283
+ });
@@ -1,89 +1,89 @@
1
- import { expect } from '@open-wc/testing';
2
- import { formatDate } from '../../src/utils/format-date';
3
-
4
- const testDate = new Date(2020, 11, 9);
5
-
6
- describe('formatDate', () => {
7
- it('returns blank when undefined date', () => {
8
- expect(formatDate(undefined)).to.equal('');
9
- });
10
-
11
- it('returns short date when no DateFormat', () => {
12
- expect(formatDate(testDate)).to.equal('Dec 2020');
13
- });
14
-
15
- it('returns long date when long DateFormat', () => {
16
- expect(formatDate(testDate, 'long')).to.equal('Dec 09, 2020');
17
- });
18
-
19
- it('returns year-only date when year-only DateFormat', () => {
20
- expect(formatDate(testDate, 'year-only')).to.equal('2020');
21
- });
22
-
23
- it('returns correct year for old "Jan 1 at midnight" dates and year-only DateFormat', () => {
24
- // Many standard timezones have a discontinuity in date parsing at some point during
25
- // the 19th or 20th century, corresponding to the creation of the timezone.
26
- // Dates prior to the discontinuity generally have a non-hour-aligned timezone offset
27
- // which can throw off the calculated year for dates which are close to a year boundary.
28
- // This is particularly problematic for "Jan 1 at midnight" dates, which are what we
29
- // receive from the search engine for date metadata that only specifies the year.
30
- // So we must ensure these older dates still output the correct year, not the prior one.
31
- expect(formatDate(new Date('1234-01-01T00:00:00Z'), 'year-only')).to.equal(
32
- '1234',
33
- );
34
- });
35
-
36
- it('uses UTC time zone by default or when useLocalTime is explicitly false', () => {
37
- // Default options
38
- expect(formatDate(new Date('2025-02-15T00:00:00Z'), 'long')).to.equal(
39
- 'Feb 15, 2025',
40
- );
41
- expect(formatDate(new Date('2025-02-15T23:59:59Z'), 'long')).to.equal(
42
- 'Feb 15, 2025',
43
- );
44
-
45
- // Explicit `useLocalTime: false` option
46
- const options = { useLocalTime: false };
47
- expect(
48
- formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
49
- ).to.equal('Feb 15, 2025');
50
- expect(
51
- formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
52
- ).to.equal('Feb 15, 2025');
53
- });
54
-
55
- it('uses local time zone when specified', () => {
56
- // N.B.:
57
- // - Positive offset corresponds to UTC-x zones
58
- // - Negative offset corresponds to UTC+x zones
59
- const offset = new Date().getTimezoneOffset();
60
- const options = { useLocalTime: true };
61
-
62
- // The expected behavior depends on the local time where the tests are run:
63
- if (offset > 0) {
64
- // If we're testing under a positive offset, the first second of the UTC day should locally fall on the previous day
65
- expect(
66
- formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
67
- ).to.equal('Feb 14, 2025');
68
- } else if (offset < 0) {
69
- // If we're testing under a negative offset, the last second of the UTC day should locally fall on the next day
70
- expect(
71
- formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
72
- ).to.equal('Feb 16, 2025');
73
- } else {
74
- // If we're testing *in* UTC, then both seconds should locally fall on the same day
75
- expect(
76
- formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
77
- ).to.equal('Feb 15, 2025');
78
- expect(
79
- formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
80
- ).to.equal('Feb 15, 2025');
81
- }
82
- });
83
-
84
- it('returns locale formatted date', () => {
85
- expect(formatDate(testDate, 'long', { locale: 'de-DE' })).to.equal(
86
- '09. Dez. 2020',
87
- );
88
- });
89
- });
1
+ import { expect } from '@open-wc/testing';
2
+ import { formatDate } from '../../src/utils/format-date';
3
+
4
+ const testDate = new Date(2020, 11, 9);
5
+
6
+ describe('formatDate', () => {
7
+ it('returns blank when undefined date', () => {
8
+ expect(formatDate(undefined)).to.equal('');
9
+ });
10
+
11
+ it('returns short date when no DateFormat', () => {
12
+ expect(formatDate(testDate)).to.equal('Dec 2020');
13
+ });
14
+
15
+ it('returns long date when long DateFormat', () => {
16
+ expect(formatDate(testDate, 'long')).to.equal('Dec 09, 2020');
17
+ });
18
+
19
+ it('returns year-only date when year-only DateFormat', () => {
20
+ expect(formatDate(testDate, 'year-only')).to.equal('2020');
21
+ });
22
+
23
+ it('returns correct year for old "Jan 1 at midnight" dates and year-only DateFormat', () => {
24
+ // Many standard timezones have a discontinuity in date parsing at some point during
25
+ // the 19th or 20th century, corresponding to the creation of the timezone.
26
+ // Dates prior to the discontinuity generally have a non-hour-aligned timezone offset
27
+ // which can throw off the calculated year for dates which are close to a year boundary.
28
+ // This is particularly problematic for "Jan 1 at midnight" dates, which are what we
29
+ // receive from the search engine for date metadata that only specifies the year.
30
+ // So we must ensure these older dates still output the correct year, not the prior one.
31
+ expect(formatDate(new Date('1234-01-01T00:00:00Z'), 'year-only')).to.equal(
32
+ '1234',
33
+ );
34
+ });
35
+
36
+ it('uses UTC time zone by default or when useLocalTime is explicitly false', () => {
37
+ // Default options
38
+ expect(formatDate(new Date('2025-02-15T00:00:00Z'), 'long')).to.equal(
39
+ 'Feb 15, 2025',
40
+ );
41
+ expect(formatDate(new Date('2025-02-15T23:59:59Z'), 'long')).to.equal(
42
+ 'Feb 15, 2025',
43
+ );
44
+
45
+ // Explicit `useLocalTime: false` option
46
+ const options = { useLocalTime: false };
47
+ expect(
48
+ formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
49
+ ).to.equal('Feb 15, 2025');
50
+ expect(
51
+ formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
52
+ ).to.equal('Feb 15, 2025');
53
+ });
54
+
55
+ it('uses local time zone when specified', () => {
56
+ // N.B.:
57
+ // - Positive offset corresponds to UTC-x zones
58
+ // - Negative offset corresponds to UTC+x zones
59
+ const offset = new Date().getTimezoneOffset();
60
+ const options = { useLocalTime: true };
61
+
62
+ // The expected behavior depends on the local time where the tests are run:
63
+ if (offset > 0) {
64
+ // If we're testing under a positive offset, the first second of the UTC day should locally fall on the previous day
65
+ expect(
66
+ formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
67
+ ).to.equal('Feb 14, 2025');
68
+ } else if (offset < 0) {
69
+ // If we're testing under a negative offset, the last second of the UTC day should locally fall on the next day
70
+ expect(
71
+ formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
72
+ ).to.equal('Feb 16, 2025');
73
+ } else {
74
+ // If we're testing *in* UTC, then both seconds should locally fall on the same day
75
+ expect(
76
+ formatDate(new Date('2025-02-15T00:00:00Z'), 'long', options),
77
+ ).to.equal('Feb 15, 2025');
78
+ expect(
79
+ formatDate(new Date('2025-02-15T23:59:59Z'), 'long', options),
80
+ ).to.equal('Feb 15, 2025');
81
+ }
82
+ });
83
+
84
+ it('returns locale formatted date', () => {
85
+ expect(formatDate(testDate, 'long', { locale: 'de-DE' })).to.equal(
86
+ '09. Dez. 2020',
87
+ );
88
+ });
89
+ });