@internetarchive/collection-browser 2.7.14-alpha-webdev7002.4 → 2.7.14-alpha-webdev7397.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (509) hide show
  1. package/.github/workflows/ci.yml +3 -3
  2. package/.github/workflows/gh-pages-main.yml +2 -2
  3. package/.github/workflows/pr-preview.yml +2 -2
  4. package/.prettierignore +1 -0
  5. package/dist/index.d.ts +13 -16
  6. package/dist/index.js +11 -16
  7. package/dist/index.js.map +1 -1
  8. package/dist/src/app-root.d.ts +107 -107
  9. package/dist/src/app-root.js +531 -531
  10. package/dist/src/app-root.js.map +1 -1
  11. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  12. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  13. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  14. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  15. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  16. package/dist/src/assets/img/icons/chevron.js +2 -2
  17. package/dist/src/assets/img/icons/contract.d.ts +2 -2
  18. package/dist/src/assets/img/icons/contract.js +2 -2
  19. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  20. package/dist/src/assets/img/icons/empty-query.js +2 -2
  21. package/dist/src/assets/img/icons/expand.d.ts +2 -2
  22. package/dist/src/assets/img/icons/expand.js +2 -2
  23. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  24. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  25. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  26. package/dist/src/assets/img/icons/eye.js +2 -2
  27. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  28. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  29. package/dist/src/assets/img/icons/favorite-unfilled.d.ts +1 -1
  30. package/dist/src/assets/img/icons/favorite-unfilled.js +2 -2
  31. package/dist/src/assets/img/icons/filter.d.ts +2 -2
  32. package/dist/src/assets/img/icons/filter.js +2 -2
  33. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  34. package/dist/src/assets/img/icons/login-required.js +2 -2
  35. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  36. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  37. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  38. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  39. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  40. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  41. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  42. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  43. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  44. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  45. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  46. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  47. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  48. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  49. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  50. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  51. package/dist/src/assets/img/icons/mediatype/search.d.ts +1 -1
  52. package/dist/src/assets/img/icons/mediatype/search.js +2 -2
  53. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  54. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  55. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  56. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  57. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  58. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  59. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  60. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  61. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  62. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  63. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  64. package/dist/src/assets/img/icons/null-result.js +2 -2
  65. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  66. package/dist/src/assets/img/icons/restricted.js +2 -2
  67. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  68. package/dist/src/assets/img/icons/reviews.js +2 -2
  69. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  70. package/dist/src/assets/img/icons/upload.js +2 -2
  71. package/dist/src/assets/img/icons/views.d.ts +1 -1
  72. package/dist/src/assets/img/icons/views.js +2 -2
  73. package/dist/src/circular-activity-indicator.d.ts +5 -5
  74. package/dist/src/circular-activity-indicator.js +17 -17
  75. package/dist/src/circular-activity-indicator.js.map +1 -1
  76. package/dist/src/collection-browser.d.ts +606 -606
  77. package/dist/src/collection-browser.js +1679 -1677
  78. package/dist/src/collection-browser.js.map +1 -1
  79. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  80. package/dist/src/collection-facets/facet-row.js +118 -118
  81. package/dist/src/collection-facets/facet-row.js.map +1 -1
  82. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  83. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  84. package/dist/src/collection-facets/facet-tombstone-row.js.map +1 -1
  85. package/dist/src/collection-facets/facets-template.d.ts +13 -13
  86. package/dist/src/collection-facets/facets-template.js +49 -49
  87. package/dist/src/collection-facets/facets-template.js.map +1 -1
  88. package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
  89. package/dist/src/collection-facets/more-facets-content.js +406 -408
  90. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  91. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  92. package/dist/src/collection-facets/more-facets-pagination.js +197 -196
  93. package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
  94. package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -10
  95. package/dist/src/collection-facets/smart-facets/dedupe.js +33 -33
  96. package/dist/src/collection-facets/smart-facets/dedupe.js.map +1 -1
  97. package/dist/src/collection-facets/smart-facets/heuristics/{browser-language/browser-language-heuristic.d.ts → browser-language-heuristic.d.ts} +5 -5
  98. package/dist/src/collection-facets/smart-facets/heuristics/{browser-language/browser-language-heuristic.js → browser-language-heuristic.js} +23 -23
  99. package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.js.map +1 -0
  100. package/dist/src/collection-facets/smart-facets/heuristics/{query-keywords/query-keywords-heuristic.d.ts → query-keywords-heuristic.d.ts} +5 -4
  101. package/dist/src/collection-facets/smart-facets/heuristics/{query-keywords/query-keywords-map.js → query-keywords-heuristic.js} +45 -35
  102. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js.map +1 -0
  103. package/dist/src/collection-facets/smart-facets/heuristics/{wikidata/wikidata-heuristic.d.ts → wikidata-heuristic.d.ts} +5 -4
  104. package/dist/src/collection-facets/smart-facets/heuristics/{wikidata/wikidata-entity-map.js → wikidata-heuristic.js} +173 -133
  105. package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js.map +1 -0
  106. package/dist/src/collection-facets/smart-facets/models.d.ts +26 -26
  107. package/dist/src/collection-facets/smart-facets/models.js +1 -1
  108. package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +31 -31
  109. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +237 -240
  110. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
  111. package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -11
  112. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +86 -86
  113. package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -1
  114. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +16 -16
  115. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +100 -100
  116. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
  117. package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -2
  118. package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +12 -12
  119. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -5
  120. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +15 -17
  121. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -1
  122. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  123. package/dist/src/collection-facets/toggle-switch.js +94 -94
  124. package/dist/src/collection-facets/toggle-switch.js.map +1 -1
  125. package/dist/src/collection-facets.d.ts +103 -103
  126. package/dist/src/collection-facets.js +521 -522
  127. package/dist/src/collection-facets.js.map +1 -1
  128. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +245 -245
  129. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  130. package/dist/src/data-source/collection-browser-data-source-interface.js.map +1 -1
  131. package/dist/src/data-source/collection-browser-data-source.d.ts +377 -377
  132. package/dist/src/data-source/collection-browser-data-source.js +1003 -1004
  133. package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
  134. package/dist/src/data-source/collection-browser-query-state.d.ts +44 -44
  135. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  136. package/dist/src/data-source/models.d.ts +28 -28
  137. package/dist/src/data-source/models.js +8 -8
  138. package/dist/src/empty-placeholder.d.ts +23 -23
  139. package/dist/src/empty-placeholder.js +87 -88
  140. package/dist/src/empty-placeholder.js.map +1 -1
  141. package/dist/src/expanded-date-picker.d.ts +43 -43
  142. package/dist/src/expanded-date-picker.js +109 -109
  143. package/dist/src/expanded-date-picker.js.map +1 -1
  144. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  145. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  146. package/dist/src/language-code-handler/language-code-handler.js.map +1 -1
  147. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  148. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  149. package/dist/src/language-code-handler/language-code-mapping.js.map +1 -1
  150. package/dist/src/manage/manage-bar.d.ts +58 -58
  151. package/dist/src/manage/manage-bar.js +175 -175
  152. package/dist/src/manage/manage-bar.js.map +1 -1
  153. package/dist/src/manage/remove-items-modal-content.d.ts +9 -9
  154. package/dist/src/manage/remove-items-modal-content.js +34 -34
  155. package/dist/src/manage/remove-items-modal-content.js.map +1 -1
  156. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  157. package/dist/src/mediatype/mediatype-config.js +92 -91
  158. package/dist/src/mediatype/mediatype-config.js.map +1 -1
  159. package/dist/src/models.d.ts +228 -228
  160. package/dist/src/models.js +401 -401
  161. package/dist/src/models.js.map +1 -1
  162. package/dist/src/restoration-state-handler.d.ts +70 -70
  163. package/dist/src/restoration-state-handler.js +362 -363
  164. package/dist/src/restoration-state-handler.js.map +1 -1
  165. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  166. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  167. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js.map +1 -1
  168. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  169. package/dist/src/sort-filter-bar/alpha-bar.js +136 -136
  170. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
  171. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  172. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  173. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  174. package/dist/src/sort-filter-bar/img/list.js +2 -2
  175. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  176. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  177. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  178. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  179. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  180. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  181. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  182. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  183. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  184. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  185. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
  186. package/dist/src/sort-filter-bar/sort-filter-bar.js +696 -697
  187. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  188. package/dist/src/styles/ia-button.d.ts +2 -2
  189. package/dist/src/styles/ia-button.js +17 -17
  190. package/dist/src/styles/item-image-styles.d.ts +8 -8
  191. package/dist/src/styles/item-image-styles.js +9 -9
  192. package/dist/src/styles/sr-only.d.ts +1 -1
  193. package/dist/src/styles/sr-only.js +2 -2
  194. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  195. package/dist/src/tiles/base-tile-component.js +64 -64
  196. package/dist/src/tiles/base-tile-component.js.map +1 -1
  197. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  198. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  199. package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -1
  200. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  201. package/dist/src/tiles/grid/account-tile.js +72 -72
  202. package/dist/src/tiles/grid/account-tile.js.map +1 -1
  203. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  204. package/dist/src/tiles/grid/collection-tile.js +80 -80
  205. package/dist/src/tiles/grid/collection-tile.js.map +1 -1
  206. package/dist/src/tiles/grid/item-tile.d.ts +34 -34
  207. package/dist/src/tiles/grid/item-tile.js +159 -160
  208. package/dist/src/tiles/grid/item-tile.js.map +1 -1
  209. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  210. package/dist/src/tiles/grid/search-tile.js +51 -51
  211. package/dist/src/tiles/grid/search-tile.js.map +1 -1
  212. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  213. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  214. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  215. package/dist/src/tiles/grid/tile-stats.js +54 -54
  216. package/dist/src/tiles/grid/tile-stats.js.map +1 -1
  217. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  218. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  219. package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
  220. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
  221. package/dist/src/tiles/hover/tile-hover-pane.js +72 -70
  222. package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
  223. package/dist/src/tiles/image-block.d.ts +18 -18
  224. package/dist/src/tiles/image-block.js +89 -89
  225. package/dist/src/tiles/image-block.js.map +1 -1
  226. package/dist/src/tiles/item-image.d.ts +39 -39
  227. package/dist/src/tiles/item-image.js +154 -154
  228. package/dist/src/tiles/item-image.js.map +1 -1
  229. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  230. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  231. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -1
  232. package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
  233. package/dist/src/tiles/list/tile-list-compact.js +122 -122
  234. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  235. package/dist/src/tiles/list/tile-list.d.ts +54 -54
  236. package/dist/src/tiles/list/tile-list.js +324 -326
  237. package/dist/src/tiles/list/tile-list.js.map +1 -1
  238. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  239. package/dist/src/tiles/mediatype-icon.js +47 -47
  240. package/dist/src/tiles/mediatype-icon.js.map +1 -1
  241. package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
  242. package/dist/src/tiles/overlay/icon-overlay.js +25 -25
  243. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -1
  244. package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
  245. package/dist/src/tiles/overlay/text-overlay.js +31 -31
  246. package/dist/src/tiles/overlay/text-overlay.js.map +1 -1
  247. package/dist/src/tiles/review-block.d.ts +12 -12
  248. package/dist/src/tiles/review-block.js +56 -56
  249. package/dist/src/tiles/review-block.js.map +1 -1
  250. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  251. package/dist/src/tiles/text-snippet-block.js +73 -73
  252. package/dist/src/tiles/text-snippet-block.js.map +1 -1
  253. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  254. package/dist/src/tiles/tile-dispatcher.js +230 -230
  255. package/dist/src/tiles/tile-dispatcher.js.map +1 -1
  256. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  257. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  258. package/dist/src/tiles/tile-display-value-provider.js.map +1 -1
  259. package/dist/src/utils/analytics-events.d.ts +28 -28
  260. package/dist/src/utils/analytics-events.js +30 -30
  261. package/dist/src/utils/array-equals.d.ts +4 -4
  262. package/dist/src/utils/array-equals.js +10 -10
  263. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  264. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  265. package/dist/src/utils/facet-utils.d.ts +83 -83
  266. package/dist/src/utils/facet-utils.js +145 -145
  267. package/dist/src/utils/facet-utils.js.map +1 -1
  268. package/dist/src/utils/format-count.d.ts +7 -7
  269. package/dist/src/utils/format-count.js +75 -76
  270. package/dist/src/utils/format-count.js.map +1 -1
  271. package/dist/src/utils/format-date.d.ts +2 -2
  272. package/dist/src/utils/format-date.js +27 -27
  273. package/dist/src/utils/format-date.js.map +1 -1
  274. package/dist/src/utils/format-unit-size.d.ts +2 -2
  275. package/dist/src/utils/format-unit-size.js +33 -33
  276. package/dist/src/utils/format-unit-size.js.map +1 -1
  277. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  278. package/dist/src/utils/local-date-from-utc.js +15 -15
  279. package/dist/src/utils/log.d.ts +7 -7
  280. package/dist/src/utils/log.js +13 -15
  281. package/dist/src/utils/log.js.map +1 -1
  282. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  283. package/dist/src/utils/resolve-mediatype.js +23 -23
  284. package/dist/src/utils/resolve-mediatype.js.map +1 -1
  285. package/dist/src/utils/sha1.d.ts +2 -2
  286. package/dist/src/utils/sha1.js +8 -8
  287. package/dist/test/collection-browser.test.d.ts +1 -1
  288. package/dist/test/collection-browser.test.js +1309 -1308
  289. package/dist/test/collection-browser.test.js.map +1 -1
  290. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  291. package/dist/test/collection-facets/facet-row.test.js +230 -227
  292. package/dist/test/collection-facets/facet-row.test.js.map +1 -1
  293. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  294. package/dist/test/collection-facets/facets-template.test.js +91 -91
  295. package/dist/test/collection-facets/facets-template.test.js.map +1 -1
  296. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  297. package/dist/test/collection-facets/more-facets-content.test.js +140 -141
  298. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
  299. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  300. package/dist/test/collection-facets/more-facets-pagination.test.js +116 -117
  301. package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -1
  302. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  303. package/dist/test/collection-facets/toggle-switch.test.js +82 -73
  304. package/dist/test/collection-facets/toggle-switch.test.js.map +1 -1
  305. package/dist/test/collection-facets.test.d.ts +2 -2
  306. package/dist/test/collection-facets.test.js +692 -692
  307. package/dist/test/collection-facets.test.js.map +1 -1
  308. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  309. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  310. package/dist/test/data-source/collection-browser-data-source.test.js.map +1 -1
  311. package/dist/test/empty-placeholder.test.d.ts +1 -1
  312. package/dist/test/empty-placeholder.test.js +62 -63
  313. package/dist/test/empty-placeholder.test.js.map +1 -1
  314. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  315. package/dist/test/expanded-date-picker.test.js +97 -96
  316. package/dist/test/expanded-date-picker.test.js.map +1 -1
  317. package/dist/test/icon-overlay.test.d.ts +1 -1
  318. package/dist/test/icon-overlay.test.js +23 -24
  319. package/dist/test/icon-overlay.test.js.map +1 -1
  320. package/dist/test/image-block.test.d.ts +1 -1
  321. package/dist/test/image-block.test.js +106 -107
  322. package/dist/test/image-block.test.js.map +1 -1
  323. package/dist/test/item-image.test.d.ts +1 -1
  324. package/dist/test/item-image.test.js +84 -85
  325. package/dist/test/item-image.test.js.map +1 -1
  326. package/dist/test/manage/manage-bar.test.d.ts +2 -2
  327. package/dist/test/manage/manage-bar.test.js +100 -101
  328. package/dist/test/manage/manage-bar.test.js.map +1 -1
  329. package/dist/test/manage/remove-items-modal-content.test.d.ts +1 -1
  330. package/dist/test/manage/remove-items-modal-content.test.js +44 -45
  331. package/dist/test/manage/remove-items-modal-content.test.js.map +1 -1
  332. package/dist/test/mediatype-config.test.d.ts +1 -1
  333. package/dist/test/mediatype-config.test.js +16 -16
  334. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  335. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  336. package/dist/test/mocks/mock-search-responses.d.ts +25 -25
  337. package/dist/test/mocks/mock-search-responses.js +942 -942
  338. package/dist/test/mocks/mock-search-responses.js.map +1 -1
  339. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  340. package/dist/test/mocks/mock-search-service.js +54 -54
  341. package/dist/test/mocks/mock-search-service.js.map +1 -1
  342. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  343. package/dist/test/restoration-state-handler.test.js +270 -270
  344. package/dist/test/restoration-state-handler.test.js.map +1 -1
  345. package/dist/test/review-block.test.d.ts +1 -1
  346. package/dist/test/review-block.test.js +43 -44
  347. package/dist/test/review-block.test.js.map +1 -1
  348. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  349. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  350. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -1
  351. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  352. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  353. package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -1
  354. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  355. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +425 -426
  356. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
  357. package/dist/test/text-overlay.test.d.ts +1 -1
  358. package/dist/test/text-overlay.test.js +37 -38
  359. package/dist/test/text-overlay.test.js.map +1 -1
  360. package/dist/test/text-snippet-block.test.d.ts +1 -1
  361. package/dist/test/text-snippet-block.test.js +56 -57
  362. package/dist/test/text-snippet-block.test.js.map +1 -1
  363. package/dist/test/tile-stats.test.d.ts +1 -1
  364. package/dist/test/tile-stats.test.js +98 -99
  365. package/dist/test/tile-stats.test.js.map +1 -1
  366. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  367. package/dist/test/tiles/grid/account-tile.test.js +75 -76
  368. package/dist/test/tiles/grid/account-tile.test.js.map +1 -1
  369. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  370. package/dist/test/tiles/grid/collection-tile.test.js +72 -73
  371. package/dist/test/tiles/grid/collection-tile.test.js.map +1 -1
  372. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  373. package/dist/test/tiles/grid/item-tile.test.js +311 -312
  374. package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
  375. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  376. package/dist/test/tiles/grid/search-tile.test.js +50 -51
  377. package/dist/test/tiles/grid/search-tile.test.js.map +1 -1
  378. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  379. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  380. package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -1
  381. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  382. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  383. package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
  384. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  385. package/dist/test/tiles/list/tile-list-compact.test.js +142 -143
  386. package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
  387. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  388. package/dist/test/tiles/list/tile-list.test.js +296 -297
  389. package/dist/test/tiles/list/tile-list.test.js.map +1 -1
  390. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  391. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  392. package/dist/test/tiles/tile-dispatcher.test.js.map +1 -1
  393. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  394. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  395. package/dist/test/utils/array-equals.test.d.ts +1 -1
  396. package/dist/test/utils/array-equals.test.js +26 -26
  397. package/dist/test/utils/format-count.test.d.ts +1 -1
  398. package/dist/test/utils/format-count.test.js +23 -23
  399. package/dist/test/utils/format-count.test.js.map +1 -1
  400. package/dist/test/utils/format-date.test.d.ts +1 -1
  401. package/dist/test/utils/format-date.test.js +30 -30
  402. package/dist/test/utils/format-date.test.js.map +1 -1
  403. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  404. package/dist/test/utils/format-unit-size.test.js +17 -17
  405. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  406. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  407. package/dist/test/utils/local-date-from-utc.test.js.map +1 -1
  408. package/eslint.config.mjs +53 -0
  409. package/index.html +0 -3
  410. package/index.ts +1 -15
  411. package/package.json +41 -39
  412. package/src/app-root.ts +21 -22
  413. package/src/collection-browser.ts +44 -40
  414. package/src/collection-facets/facets-template.ts +7 -6
  415. package/src/collection-facets/more-facets-content.ts +11 -13
  416. package/src/collection-facets/more-facets-pagination.ts +3 -2
  417. package/src/collection-facets/smart-facets/dedupe.ts +2 -2
  418. package/src/collection-facets/smart-facets/heuristics/{browser-language/browser-language-heuristic.ts → browser-language-heuristic.ts} +1 -1
  419. package/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.ts +55 -0
  420. package/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.ts +191 -0
  421. package/src/collection-facets/smart-facets/smart-facet-bar.ts +6 -8
  422. package/src/collection-facets/smart-facets/smart-facet-button.ts +5 -3
  423. package/src/collection-facets/smart-facets/smart-facet-dropdown.ts +4 -4
  424. package/src/collection-facets/smart-facets/smart-facet-heuristics.ts +8 -13
  425. package/src/collection-facets/toggle-switch.ts +2 -2
  426. package/src/collection-facets.ts +18 -19
  427. package/src/data-source/collection-browser-data-source-interface.ts +5 -1
  428. package/src/data-source/collection-browser-data-source.ts +37 -34
  429. package/src/empty-placeholder.ts +19 -16
  430. package/src/expanded-date-picker.ts +1 -1
  431. package/src/language-code-handler/language-code-handler.ts +1 -1
  432. package/src/manage/manage-bar.ts +23 -20
  433. package/src/manage/remove-items-modal-content.ts +2 -2
  434. package/src/mediatype/mediatype-config.ts +1 -0
  435. package/src/models.ts +3 -3
  436. package/src/restoration-state-handler.ts +14 -15
  437. package/src/sort-filter-bar/alpha-bar.ts +16 -17
  438. package/src/sort-filter-bar/sort-filter-bar.ts +14 -15
  439. package/src/tiles/grid/account-tile.ts +1 -1
  440. package/src/tiles/grid/collection-tile.ts +1 -1
  441. package/src/tiles/grid/item-tile.ts +9 -9
  442. package/src/tiles/grid/tile-stats.ts +4 -4
  443. package/src/tiles/hover/hover-pane-controller.ts +1 -1
  444. package/src/tiles/hover/tile-hover-pane.ts +4 -2
  445. package/src/tiles/item-image.ts +1 -1
  446. package/src/tiles/list/tile-list-compact.ts +2 -2
  447. package/src/tiles/list/tile-list.ts +22 -24
  448. package/src/tiles/tile-dispatcher.ts +5 -5
  449. package/src/tiles/tile-display-value-provider.ts +4 -4
  450. package/src/utils/facet-utils.ts +6 -6
  451. package/src/utils/format-count.ts +2 -3
  452. package/src/utils/format-date.ts +1 -1
  453. package/src/utils/format-unit-size.ts +1 -1
  454. package/src/utils/log.ts +1 -3
  455. package/test/collection-browser.test.ts +125 -124
  456. package/test/collection-facets/facet-row.test.ts +31 -28
  457. package/test/collection-facets/facets-template.test.ts +9 -9
  458. package/test/collection-facets/more-facets-content.test.ts +14 -15
  459. package/test/collection-facets/more-facets-pagination.test.ts +18 -19
  460. package/test/collection-facets/toggle-switch.test.ts +28 -18
  461. package/test/collection-facets.test.ts +46 -39
  462. package/test/data-source/collection-browser-data-source.test.ts +2 -2
  463. package/test/empty-placeholder.test.ts +6 -7
  464. package/test/expanded-date-picker.test.ts +25 -20
  465. package/test/icon-overlay.test.ts +0 -1
  466. package/test/image-block.test.ts +6 -7
  467. package/test/item-image.test.ts +0 -1
  468. package/test/manage/manage-bar.test.ts +19 -16
  469. package/test/manage/remove-items-modal-content.test.ts +4 -5
  470. package/test/mocks/mock-search-responses.ts +2 -1
  471. package/test/mocks/mock-search-service.ts +1 -1
  472. package/test/restoration-state-handler.test.ts +12 -12
  473. package/test/review-block.test.ts +1 -2
  474. package/test/sort-filter-bar/alpha-bar-tooltip.test.ts +1 -1
  475. package/test/sort-filter-bar/alpha-bar.test.ts +5 -5
  476. package/test/sort-filter-bar/sort-filter-bar.test.ts +38 -39
  477. package/test/text-overlay.test.ts +0 -1
  478. package/test/text-snippet-block.test.ts +5 -6
  479. package/test/tile-stats.test.ts +26 -35
  480. package/test/tiles/grid/account-tile.test.ts +2 -3
  481. package/test/tiles/grid/collection-tile.test.ts +3 -4
  482. package/test/tiles/grid/item-tile.test.ts +13 -14
  483. package/test/tiles/grid/search-tile.test.ts +1 -2
  484. package/test/tiles/hover/hover-pane-controller.test.ts +15 -15
  485. package/test/tiles/hover/tile-hover-pane.test.ts +5 -5
  486. package/test/tiles/list/tile-list-compact.test.ts +1 -2
  487. package/test/tiles/list/tile-list.test.ts +10 -11
  488. package/test/tiles/tile-dispatcher.test.ts +5 -5
  489. package/test/utils/format-count.test.ts +1 -1
  490. package/test/utils/format-date.test.ts +1 -1
  491. package/test/utils/local-date-from-utc.test.ts +1 -1
  492. package/tsconfig.json +0 -1
  493. package/dist/src/collection-facets/smart-facets/heuristics/browser-language/browser-language-heuristic.js.map +0 -1
  494. package/dist/src/collection-facets/smart-facets/heuristics/index.d.ts +0 -3
  495. package/dist/src/collection-facets/smart-facets/heuristics/index.js +0 -4
  496. package/dist/src/collection-facets/smart-facets/heuristics/index.js.map +0 -1
  497. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js +0 -14
  498. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.js.map +0 -1
  499. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.d.ts +0 -6
  500. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.js.map +0 -1
  501. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.d.ts +0 -9
  502. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.js.map +0 -1
  503. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +0 -49
  504. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +0 -1
  505. package/src/collection-facets/smart-facets/heuristics/index.ts +0 -3
  506. package/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-heuristic.ts +0 -17
  507. package/src/collection-facets/smart-facets/heuristics/query-keywords/query-keywords-map.ts +0 -36
  508. package/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-entity-map.ts +0 -134
  509. package/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.ts +0 -60
@@ -1,364 +1,363 @@
1
- import { SearchType } from '@internetarchive/search-service';
2
- import { getCookie, setCookie } from 'typescript-cookie';
3
- import { SortField, getDefaultSelectedFacets, sortOptionFromAPIString, SORT_OPTIONS, } from './models';
4
- import { arrayEquals } from './utils/array-equals';
5
- export class RestorationStateHandler {
6
- constructor(options) {
7
- this.cookieDomain = '.archive.org';
8
- this.cookieExpiration = 30;
9
- this.cookiePath = '/';
10
- this.context = options.context;
11
- }
12
- persistState(state, forceReplace = false) {
13
- if (state.displayMode)
14
- this.persistViewStateToCookies(state.displayMode);
15
- this.persistQueryStateToUrl(state, forceReplace);
16
- }
17
- getRestorationState() {
18
- const restorationState = this.loadQueryStateFromUrl();
19
- const displayMode = this.loadTileViewStateFromCookies();
20
- restorationState.displayMode = displayMode;
21
- return restorationState;
22
- }
23
- persistViewStateToCookies(displayMode) {
24
- const gridState = displayMode === 'grid' ? 'tiles' : 'lists';
25
- setCookie(`view-${this.context}`, gridState, {
26
- domain: this.cookieDomain,
27
- expires: this.cookieExpiration,
28
- path: this.cookiePath,
29
- });
30
- const detailsState = displayMode === 'list-detail' ? 'showdetails' : '';
31
- setCookie(`showdetails-${this.context}`, detailsState, {
32
- domain: this.cookieDomain,
33
- expires: this.cookieExpiration,
34
- path: this.cookiePath,
35
- });
36
- }
37
- loadTileViewStateFromCookies() {
38
- const viewState = getCookie(`view-${this.context}`);
39
- const detailsState = getCookie(`showdetails-${this.context}`);
40
- if (viewState === 'tiles' || viewState === undefined)
41
- return 'grid';
42
- if (detailsState === 'showdetails')
43
- return 'list-detail';
44
- return 'list-compact';
45
- }
46
- persistQueryStateToUrl(state, forceReplace = false) {
47
- var _a, _b, _c;
48
- const url = new URL(window.location.href);
49
- const oldParams = new URLSearchParams(url.searchParams);
50
- const newParams = this.removeRecognizedParams(url.searchParams);
51
- let replaceEmptySin = false;
52
- if (state.baseQuery) {
53
- newParams.set('query', state.baseQuery);
54
- }
55
- if (state.searchType === SearchType.FULLTEXT) {
56
- newParams.set('sin', 'TXT');
57
- }
58
- else if (state.searchType === SearchType.RADIO) {
59
- newParams.set('sin', 'RADIO');
60
- }
61
- if (oldParams.get('sin') === '') {
62
- // Treat empty sin the same as no sin at all
63
- oldParams.delete('sin');
64
- replaceEmptySin = true;
65
- }
66
- if (state.currentPage) {
67
- if (state.currentPage > 1) {
68
- newParams.set('page', state.currentPage.toString());
69
- }
70
- else {
71
- newParams.delete('page');
72
- }
73
- }
74
- if (state.selectedSort) {
75
- const sortOption = SORT_OPTIONS[state.selectedSort];
76
- let prefix = this.sortDirectionPrefix(state.sortDirection);
77
- if (sortOption.field === SortField.unrecognized) {
78
- // For unrecognized sorts, use the existing param, possibly updating its direction
79
- const oldSortParam = (_a = oldParams.get('sort')) !== null && _a !== void 0 ? _a : '';
80
- const { field, direction } = this.getSortFieldAndDirection(oldSortParam);
81
- // Use the state-specified direction if available, or extract one from the param if not
82
- if (!state.sortDirection)
83
- prefix = this.sortDirectionPrefix(direction);
84
- if (field) {
85
- newParams.set('sort', `${prefix}${field}`);
86
- }
87
- else {
88
- newParams.set('sort', oldSortParam);
89
- }
90
- }
91
- else if (sortOption.shownInURL) {
92
- // Otherwise, use the canonical API form of the sort option
93
- const canonicalApiSort = sortOption.urlNames[0];
94
- newParams.set('sort', `${prefix}${canonicalApiSort}`);
95
- }
96
- }
97
- if (state.selectedFacets) {
98
- for (const [facetName, facetValues] of Object.entries(state.selectedFacets)) {
99
- const facetEntries = Object.entries(facetValues);
100
- // eslint-disable-next-line no-continue
101
- if (facetEntries.length === 0)
102
- continue;
103
- for (const [key, data] of facetEntries) {
104
- const notValue = data.state === 'hidden';
105
- const paramValue = `${facetName}:"${key}"`;
106
- if (notValue) {
107
- newParams.append('not[]', paramValue);
108
- }
109
- else {
110
- newParams.append('and[]', paramValue);
111
- }
112
- }
113
- }
114
- }
115
- if (state.minSelectedDate && state.maxSelectedDate) {
116
- newParams.append('and[]', `year:[${state.minSelectedDate} TO ${state.maxSelectedDate}]`);
117
- }
118
- if (state.titleQuery) {
119
- newParams.append('and[]', state.titleQuery);
120
- }
121
- if (state.creatorQuery) {
122
- newParams.append('and[]', state.creatorQuery);
123
- }
124
- // Ensure we aren't pushing consecutive identical states to the history stack.
125
- // - If the state has changed, we push a new history entry.
126
- // - If only the page number has changed, we replace the current history entry.
127
- // - If the state hasn't changed, then do nothing.
128
- let historyMethod = forceReplace
129
- ? 'replaceState'
130
- : 'pushState';
131
- const nonQueryParamsMatch = this.paramsMatch(oldParams, newParams, [
132
- 'sin',
133
- 'sort',
134
- 'and[]',
135
- 'not[]',
136
- ]);
137
- if (nonQueryParamsMatch &&
138
- this.paramsMatch(oldParams, newParams, ['query'])) {
139
- if (replaceEmptySin) {
140
- // Get rid of any empty sin param
141
- newParams.delete('sin');
142
- }
143
- else if (this.paramsMatch(oldParams, newParams, ['page'])) {
144
- // For page number, we want to replace the page state when it changes,
145
- // not push a new history entry. If it hasn't changed, then we're done.
146
- return;
147
- }
148
- historyMethod = 'replaceState';
149
- }
150
- else if (nonQueryParamsMatch && this.hasLegacyParam(oldParams)) {
151
- // Similarly, if the only non-matching param was a legacy query param, then
152
- // we just want to overwrite it.
153
- historyMethod = 'replaceState';
154
- }
155
- (_c = (_b = window.history)[historyMethod]) === null || _c === void 0 ? void 0 : _c.call(_b, {
156
- query: state.baseQuery,
157
- searchType: state.searchType,
158
- page: state.currentPage,
159
- sort: { field: state.selectedSort, direction: state.sortDirection },
160
- minDate: state.minSelectedDate,
161
- maxDate: state.maxSelectedDate,
162
- facets: state.selectedFacets,
163
- }, '', url);
164
- }
165
- loadQueryStateFromUrl() {
166
- var _a;
167
- const url = new URL(window.location.href);
168
- const searchInside = url.searchParams.get('sin');
169
- const pageNumber = url.searchParams.get('page');
170
- const searchQuery = url.searchParams.get('query');
171
- const sortQuery = url.searchParams.get('sort');
172
- const facetAnds = url.searchParams.getAll('and[]');
173
- const facetNots = url.searchParams.getAll('not[]');
174
- // We also need to check for the presence of params like 'and[0]', 'not[1]', etc.
175
- // since Facebook automatically converts URLs with [] into those forms.
176
- for (const [key, val] of url.searchParams.entries()) {
177
- if (/and\[\d+\]/.test(key)) {
178
- facetAnds.push(val);
179
- }
180
- else if (/not\[\d+\]/.test(key)) {
181
- facetNots.push(val);
182
- }
183
- }
184
- // Legacy search allowed `q` and `search` params for the query, so in the interest
185
- // of backwards-compatibility with old bookmarks, we recognize those here too.
186
- // (However, they still get upgraded to a `query` param when we persist our state
187
- // to the URL).
188
- const legacySearchQuery = (_a = url.searchParams.get('q')) !== null && _a !== void 0 ? _a : url.searchParams.get('search');
189
- const restorationState = {
190
- selectedFacets: getDefaultSelectedFacets(),
191
- };
192
- if (searchQuery) {
193
- restorationState.baseQuery = searchQuery;
194
- }
195
- else if (legacySearchQuery) {
196
- restorationState.baseQuery = legacySearchQuery;
197
- }
198
- switch (searchInside) {
199
- // Eventually there will be TV/Radio search types here too.
200
- case 'TXT':
201
- restorationState.searchType = SearchType.FULLTEXT;
202
- break;
203
- case 'RADIO':
204
- restorationState.searchType = SearchType.RADIO;
205
- break;
206
- default:
207
- restorationState.searchType = SearchType.METADATA;
208
- break;
209
- }
210
- if (pageNumber) {
211
- const parsed = parseInt(pageNumber, 10);
212
- restorationState.currentPage = parsed;
213
- }
214
- else {
215
- restorationState.currentPage = 1;
216
- }
217
- if (sortQuery) {
218
- const { field, direction } = this.getSortFieldAndDirection(sortQuery);
219
- const sortOption = sortOptionFromAPIString(field);
220
- restorationState.selectedSort = sortOption.field;
221
- if (['asc', 'desc'].includes(direction)) {
222
- restorationState.sortDirection = direction;
223
- }
224
- }
225
- if (facetAnds) {
226
- facetAnds.forEach(and => {
227
- // eslint-disable-next-line prefer-const
228
- let [field, value] = and.split(':');
229
- // Legacy search allowed and[] fields like 'creatorSorter', 'languageSorter', etc.
230
- // which we want to normalize to 'creator', 'language', etc. if redirected here.
231
- field = field.replace(/Sorter$/, '');
232
- // Legacy search also allowed a form of negative faceting like `and[]=-collection:foo`
233
- // which we want to normalize to a not[] param instead
234
- if (field.startsWith('-')) {
235
- facetNots.push(and.slice(1));
236
- return;
237
- }
238
- switch (field) {
239
- case 'year': {
240
- const [minDate, maxDate] = value.split(' TO ');
241
- // we have two potential ways of filtering by date:
242
- // the range with "date TO date" or the single date with "date"
243
- // this is checking for the range case and if we don't have those, fall
244
- // back to the single date case
245
- if (minDate && maxDate) {
246
- restorationState.minSelectedDate = minDate.substring(1, minDate.length);
247
- restorationState.maxSelectedDate = maxDate.substring(0, maxDate.length - 1);
248
- }
249
- else {
250
- this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
251
- }
252
- break;
253
- }
254
- case 'firstTitle':
255
- restorationState.selectedTitleFilter = value;
256
- break;
257
- case 'firstCreator':
258
- restorationState.selectedCreatorFilter = value;
259
- break;
260
- default:
261
- this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
262
- }
263
- });
264
- }
265
- if (facetNots) {
266
- facetNots.forEach(not => {
267
- const [field, value] = not.split(':');
268
- this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'hidden');
269
- });
270
- }
271
- return restorationState;
272
- }
273
- /**
274
- * Converts a URL sort param into a field/direction pair, if possible.
275
- * Either or both may be undefined if the param is not in a recognized format.
276
- */
277
- getSortFieldAndDirection(sortParam) {
278
- // check for two different sort formats: `date desc` and `-date`
279
- const hasSpace = sortParam.indexOf(' ') > -1;
280
- let field;
281
- let direction;
282
- if (hasSpace) {
283
- [field, direction] = sortParam.split(' ');
284
- }
285
- else {
286
- field = sortParam.startsWith('-') ? sortParam.slice(1) : sortParam;
287
- direction = sortParam.startsWith('-') ? 'desc' : 'asc';
288
- }
289
- return { field, direction };
290
- }
291
- /** Returns the `-` prefix for `desc` sort, or the empty string otherwise. */
292
- sortDirectionPrefix(sortDirection) {
293
- return sortDirection === 'desc' ? '-' : '';
294
- }
295
- /** Remove optional opening and closing quotes from a string */
296
- stripQuotes(value) {
297
- if (value.startsWith('"') && value.endsWith('"')) {
298
- return value.substring(1, value.length - 1);
299
- }
300
- return value;
301
- }
302
- /**
303
- * Returns whether the two given URLSearchParams objects have
304
- * identical values for all of the given param keys. If either
305
- * object contains more than one value for a given key, then
306
- * all of the values for that key must match (disregarding order).
307
- */
308
- paramsMatch(searchParams1, searchParams2, keys) {
309
- return keys.every(key => arrayEquals(searchParams1.getAll(key).sort(), searchParams2.getAll(key).sort()));
310
- }
311
- /**
312
- * Deletes any params from the given URLSearchParams object that are recognized
313
- * when loading state from the URL.
314
- */
315
- removeRecognizedParams(searchParams) {
316
- // Remove all of our standard params
317
- searchParams.delete('query');
318
- searchParams.delete('sin');
319
- searchParams.delete('page');
320
- searchParams.delete('sort');
321
- searchParams.delete('and[]');
322
- searchParams.delete('not[]');
323
- // Remove any and/not facet params that contain numbers in their square brackets
324
- for (const key of searchParams.keys()) {
325
- if (/(and|not)\[\d+\]/.test(key)) {
326
- searchParams.delete(key);
327
- }
328
- }
329
- // Also remove some legacy params that should have been upgraded to the ones above
330
- searchParams.delete('q');
331
- searchParams.delete('search');
332
- return searchParams;
333
- }
334
- /**
335
- * Returns whether the given URLSearchParams object contains a param that is
336
- * only recognized as a holdover from legacy search, and should not be
337
- * persisted to the URL.
338
- */
339
- hasLegacyParam(searchParams) {
340
- return searchParams.has('q') || searchParams.has('search');
341
- }
342
- /**
343
- * Sets the facet state for the given field & value to the given state,
344
- * creating any previously-undefined buckets as needed.
345
- */
346
- setSelectedFacetState(selectedFacets, field, value, state) {
347
- var _a;
348
- const facet = selectedFacets[field];
349
- if (!facet)
350
- return; // Unrecognized facet group, ignore it.
351
- const unQuotedValue = this.stripQuotes(value);
352
- (_a = facet[unQuotedValue]) !== null && _a !== void 0 ? _a : (facet[unQuotedValue] = this.getDefaultBucket(value));
353
- facet[unQuotedValue].state = state;
354
- }
355
- /** Returns a default bucket with the given key, count of 0, and state 'none'. */
356
- getDefaultBucket(key) {
357
- return {
358
- key,
359
- count: 0,
360
- state: 'none',
361
- };
362
- }
363
- }
1
+ import { SearchType } from '@internetarchive/search-service';
2
+ import { getCookie, setCookie } from 'typescript-cookie';
3
+ import { SortField, getDefaultSelectedFacets, sortOptionFromAPIString, SORT_OPTIONS, } from './models';
4
+ import { arrayEquals } from './utils/array-equals';
5
+ export class RestorationStateHandler {
6
+ constructor(options) {
7
+ this.cookieDomain = '.archive.org';
8
+ this.cookieExpiration = 30;
9
+ this.cookiePath = '/';
10
+ this.context = options.context;
11
+ }
12
+ persistState(state, forceReplace = false) {
13
+ if (state.displayMode)
14
+ this.persistViewStateToCookies(state.displayMode);
15
+ this.persistQueryStateToUrl(state, forceReplace);
16
+ }
17
+ getRestorationState() {
18
+ const restorationState = this.loadQueryStateFromUrl();
19
+ const displayMode = this.loadTileViewStateFromCookies();
20
+ restorationState.displayMode = displayMode;
21
+ return restorationState;
22
+ }
23
+ persistViewStateToCookies(displayMode) {
24
+ const gridState = displayMode === 'grid' ? 'tiles' : 'lists';
25
+ setCookie(`view-${this.context}`, gridState, {
26
+ domain: this.cookieDomain,
27
+ expires: this.cookieExpiration,
28
+ path: this.cookiePath,
29
+ });
30
+ const detailsState = displayMode === 'list-detail' ? 'showdetails' : '';
31
+ setCookie(`showdetails-${this.context}`, detailsState, {
32
+ domain: this.cookieDomain,
33
+ expires: this.cookieExpiration,
34
+ path: this.cookiePath,
35
+ });
36
+ }
37
+ loadTileViewStateFromCookies() {
38
+ const viewState = getCookie(`view-${this.context}`);
39
+ const detailsState = getCookie(`showdetails-${this.context}`);
40
+ if (viewState === 'tiles' || viewState === undefined)
41
+ return 'grid';
42
+ if (detailsState === 'showdetails')
43
+ return 'list-detail';
44
+ return 'list-compact';
45
+ }
46
+ persistQueryStateToUrl(state, forceReplace = false) {
47
+ var _a, _b, _c;
48
+ const url = new URL(window.location.href);
49
+ const oldParams = new URLSearchParams(url.searchParams);
50
+ const newParams = this.removeRecognizedParams(url.searchParams);
51
+ let replaceEmptySin = false;
52
+ if (state.baseQuery) {
53
+ newParams.set('query', state.baseQuery);
54
+ }
55
+ if (state.searchType === SearchType.FULLTEXT) {
56
+ newParams.set('sin', 'TXT');
57
+ }
58
+ else if (state.searchType === SearchType.RADIO) {
59
+ newParams.set('sin', 'RADIO');
60
+ }
61
+ if (oldParams.get('sin') === '') {
62
+ // Treat empty sin the same as no sin at all
63
+ oldParams.delete('sin');
64
+ replaceEmptySin = true;
65
+ }
66
+ if (state.currentPage) {
67
+ if (state.currentPage > 1) {
68
+ newParams.set('page', state.currentPage.toString());
69
+ }
70
+ else {
71
+ newParams.delete('page');
72
+ }
73
+ }
74
+ if (state.selectedSort) {
75
+ const sortOption = SORT_OPTIONS[state.selectedSort];
76
+ let prefix = this.sortDirectionPrefix(state.sortDirection);
77
+ if (sortOption.field === SortField.unrecognized) {
78
+ // For unrecognized sorts, use the existing param, possibly updating its direction
79
+ const oldSortParam = (_a = oldParams.get('sort')) !== null && _a !== void 0 ? _a : '';
80
+ const { field, direction } = this.getSortFieldAndDirection(oldSortParam);
81
+ // Use the state-specified direction if available, or extract one from the param if not
82
+ if (!state.sortDirection)
83
+ prefix = this.sortDirectionPrefix(direction);
84
+ if (field) {
85
+ newParams.set('sort', `${prefix}${field}`);
86
+ }
87
+ else {
88
+ newParams.set('sort', oldSortParam);
89
+ }
90
+ }
91
+ else if (sortOption.shownInURL) {
92
+ // Otherwise, use the canonical API form of the sort option
93
+ const canonicalApiSort = sortOption.urlNames[0];
94
+ newParams.set('sort', `${prefix}${canonicalApiSort}`);
95
+ }
96
+ }
97
+ if (state.selectedFacets) {
98
+ for (const [facetName, facetValues] of Object.entries(state.selectedFacets)) {
99
+ const facetEntries = Object.entries(facetValues);
100
+ if (facetEntries.length === 0)
101
+ continue;
102
+ for (const [key, data] of facetEntries) {
103
+ const notValue = data.state === 'hidden';
104
+ const paramValue = `${facetName}:"${key}"`;
105
+ if (notValue) {
106
+ newParams.append('not[]', paramValue);
107
+ }
108
+ else {
109
+ newParams.append('and[]', paramValue);
110
+ }
111
+ }
112
+ }
113
+ }
114
+ if (state.minSelectedDate && state.maxSelectedDate) {
115
+ newParams.append('and[]', `year:[${state.minSelectedDate} TO ${state.maxSelectedDate}]`);
116
+ }
117
+ if (state.titleQuery) {
118
+ newParams.append('and[]', state.titleQuery);
119
+ }
120
+ if (state.creatorQuery) {
121
+ newParams.append('and[]', state.creatorQuery);
122
+ }
123
+ // Ensure we aren't pushing consecutive identical states to the history stack.
124
+ // - If the state has changed, we push a new history entry.
125
+ // - If only the page number has changed, we replace the current history entry.
126
+ // - If the state hasn't changed, then do nothing.
127
+ let historyMethod = forceReplace
128
+ ? 'replaceState'
129
+ : 'pushState';
130
+ const nonQueryParamsMatch = this.paramsMatch(oldParams, newParams, [
131
+ 'sin',
132
+ 'sort',
133
+ 'and[]',
134
+ 'not[]',
135
+ ]);
136
+ if (nonQueryParamsMatch &&
137
+ this.paramsMatch(oldParams, newParams, ['query'])) {
138
+ if (replaceEmptySin) {
139
+ // Get rid of any empty sin param
140
+ newParams.delete('sin');
141
+ }
142
+ else if (this.paramsMatch(oldParams, newParams, ['page'])) {
143
+ // For page number, we want to replace the page state when it changes,
144
+ // not push a new history entry. If it hasn't changed, then we're done.
145
+ return;
146
+ }
147
+ historyMethod = 'replaceState';
148
+ }
149
+ else if (nonQueryParamsMatch && this.hasLegacyParam(oldParams)) {
150
+ // Similarly, if the only non-matching param was a legacy query param, then
151
+ // we just want to overwrite it.
152
+ historyMethod = 'replaceState';
153
+ }
154
+ (_c = (_b = window.history)[historyMethod]) === null || _c === void 0 ? void 0 : _c.call(_b, {
155
+ query: state.baseQuery,
156
+ searchType: state.searchType,
157
+ page: state.currentPage,
158
+ sort: { field: state.selectedSort, direction: state.sortDirection },
159
+ minDate: state.minSelectedDate,
160
+ maxDate: state.maxSelectedDate,
161
+ facets: state.selectedFacets,
162
+ }, '', url);
163
+ }
164
+ loadQueryStateFromUrl() {
165
+ var _a;
166
+ const url = new URL(window.location.href);
167
+ const searchInside = url.searchParams.get('sin');
168
+ const pageNumber = url.searchParams.get('page');
169
+ const searchQuery = url.searchParams.get('query');
170
+ const sortQuery = url.searchParams.get('sort');
171
+ const facetAnds = url.searchParams.getAll('and[]');
172
+ const facetNots = url.searchParams.getAll('not[]');
173
+ // We also need to check for the presence of params like 'and[0]', 'not[1]', etc.
174
+ // since Facebook automatically converts URLs with [] into those forms.
175
+ for (const [key, val] of url.searchParams.entries()) {
176
+ if (/and\[\d+\]/.test(key)) {
177
+ facetAnds.push(val);
178
+ }
179
+ else if (/not\[\d+\]/.test(key)) {
180
+ facetNots.push(val);
181
+ }
182
+ }
183
+ // Legacy search allowed `q` and `search` params for the query, so in the interest
184
+ // of backwards-compatibility with old bookmarks, we recognize those here too.
185
+ // (However, they still get upgraded to a `query` param when we persist our state
186
+ // to the URL).
187
+ const legacySearchQuery = (_a = url.searchParams.get('q')) !== null && _a !== void 0 ? _a : url.searchParams.get('search');
188
+ const restorationState = {
189
+ selectedFacets: getDefaultSelectedFacets(),
190
+ };
191
+ if (searchQuery) {
192
+ restorationState.baseQuery = searchQuery;
193
+ }
194
+ else if (legacySearchQuery) {
195
+ restorationState.baseQuery = legacySearchQuery;
196
+ }
197
+ switch (searchInside) {
198
+ // Eventually there will be TV/Radio search types here too.
199
+ case 'TXT':
200
+ restorationState.searchType = SearchType.FULLTEXT;
201
+ break;
202
+ case 'RADIO':
203
+ restorationState.searchType = SearchType.RADIO;
204
+ break;
205
+ default:
206
+ restorationState.searchType = SearchType.METADATA;
207
+ break;
208
+ }
209
+ if (pageNumber) {
210
+ const parsed = parseInt(pageNumber, 10);
211
+ restorationState.currentPage = parsed;
212
+ }
213
+ else {
214
+ restorationState.currentPage = 1;
215
+ }
216
+ if (sortQuery) {
217
+ const { field, direction } = this.getSortFieldAndDirection(sortQuery);
218
+ const sortOption = sortOptionFromAPIString(field);
219
+ restorationState.selectedSort = sortOption.field;
220
+ if (['asc', 'desc'].includes(direction)) {
221
+ restorationState.sortDirection = direction;
222
+ }
223
+ }
224
+ if (facetAnds) {
225
+ facetAnds.forEach(and => {
226
+ // eslint-disable-next-line prefer-const
227
+ let [field, value] = and.split(':');
228
+ // Legacy search allowed and[] fields like 'creatorSorter', 'languageSorter', etc.
229
+ // which we want to normalize to 'creator', 'language', etc. if redirected here.
230
+ field = field.replace(/Sorter$/, '');
231
+ // Legacy search also allowed a form of negative faceting like `and[]=-collection:foo`
232
+ // which we want to normalize to a not[] param instead
233
+ if (field.startsWith('-')) {
234
+ facetNots.push(and.slice(1));
235
+ return;
236
+ }
237
+ switch (field) {
238
+ case 'year': {
239
+ const [minDate, maxDate] = value.split(' TO ');
240
+ // we have two potential ways of filtering by date:
241
+ // the range with "date TO date" or the single date with "date"
242
+ // this is checking for the range case and if we don't have those, fall
243
+ // back to the single date case
244
+ if (minDate && maxDate) {
245
+ restorationState.minSelectedDate = minDate.substring(1, minDate.length);
246
+ restorationState.maxSelectedDate = maxDate.substring(0, maxDate.length - 1);
247
+ }
248
+ else {
249
+ this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
250
+ }
251
+ break;
252
+ }
253
+ case 'firstTitle':
254
+ restorationState.selectedTitleFilter = value;
255
+ break;
256
+ case 'firstCreator':
257
+ restorationState.selectedCreatorFilter = value;
258
+ break;
259
+ default:
260
+ this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'selected');
261
+ }
262
+ });
263
+ }
264
+ if (facetNots) {
265
+ facetNots.forEach(not => {
266
+ const [field, value] = not.split(':');
267
+ this.setSelectedFacetState(restorationState.selectedFacets, field, value, 'hidden');
268
+ });
269
+ }
270
+ return restorationState;
271
+ }
272
+ /**
273
+ * Converts a URL sort param into a field/direction pair, if possible.
274
+ * Either or both may be undefined if the param is not in a recognized format.
275
+ */
276
+ getSortFieldAndDirection(sortParam) {
277
+ // check for two different sort formats: `date desc` and `-date`
278
+ const hasSpace = sortParam.indexOf(' ') > -1;
279
+ let field;
280
+ let direction;
281
+ if (hasSpace) {
282
+ [field, direction] = sortParam.split(' ');
283
+ }
284
+ else {
285
+ field = sortParam.startsWith('-') ? sortParam.slice(1) : sortParam;
286
+ direction = sortParam.startsWith('-') ? 'desc' : 'asc';
287
+ }
288
+ return { field, direction };
289
+ }
290
+ /** Returns the `-` prefix for `desc` sort, or the empty string otherwise. */
291
+ sortDirectionPrefix(sortDirection) {
292
+ return sortDirection === 'desc' ? '-' : '';
293
+ }
294
+ /** Remove optional opening and closing quotes from a string */
295
+ stripQuotes(value) {
296
+ if (value.startsWith('"') && value.endsWith('"')) {
297
+ return value.substring(1, value.length - 1);
298
+ }
299
+ return value;
300
+ }
301
+ /**
302
+ * Returns whether the two given URLSearchParams objects have
303
+ * identical values for all of the given param keys. If either
304
+ * object contains more than one value for a given key, then
305
+ * all of the values for that key must match (disregarding order).
306
+ */
307
+ paramsMatch(searchParams1, searchParams2, keys) {
308
+ return keys.every(key => arrayEquals(searchParams1.getAll(key).sort(), searchParams2.getAll(key).sort()));
309
+ }
310
+ /**
311
+ * Deletes any params from the given URLSearchParams object that are recognized
312
+ * when loading state from the URL.
313
+ */
314
+ removeRecognizedParams(searchParams) {
315
+ // Remove all of our standard params
316
+ searchParams.delete('query');
317
+ searchParams.delete('sin');
318
+ searchParams.delete('page');
319
+ searchParams.delete('sort');
320
+ searchParams.delete('and[]');
321
+ searchParams.delete('not[]');
322
+ // Remove any and/not facet params that contain numbers in their square brackets
323
+ for (const key of searchParams.keys()) {
324
+ if (/(and|not)\[\d+\]/.test(key)) {
325
+ searchParams.delete(key);
326
+ }
327
+ }
328
+ // Also remove some legacy params that should have been upgraded to the ones above
329
+ searchParams.delete('q');
330
+ searchParams.delete('search');
331
+ return searchParams;
332
+ }
333
+ /**
334
+ * Returns whether the given URLSearchParams object contains a param that is
335
+ * only recognized as a holdover from legacy search, and should not be
336
+ * persisted to the URL.
337
+ */
338
+ hasLegacyParam(searchParams) {
339
+ return searchParams.has('q') || searchParams.has('search');
340
+ }
341
+ /**
342
+ * Sets the facet state for the given field & value to the given state,
343
+ * creating any previously-undefined buckets as needed.
344
+ */
345
+ setSelectedFacetState(selectedFacets, field, value, state) {
346
+ var _a;
347
+ const facet = selectedFacets[field];
348
+ if (!facet)
349
+ return; // Unrecognized facet group, ignore it.
350
+ const unQuotedValue = this.stripQuotes(value);
351
+ (_a = facet[unQuotedValue]) !== null && _a !== void 0 ? _a : (facet[unQuotedValue] = this.getDefaultBucket(value));
352
+ facet[unQuotedValue].state = state;
353
+ }
354
+ /** Returns a default bucket with the given key, count of 0, and state 'none'. */
355
+ getDefaultBucket(key) {
356
+ return {
357
+ key,
358
+ count: 0,
359
+ state: 'none',
360
+ };
361
+ }
362
+ }
364
363
  //# sourceMappingURL=restoration-state-handler.js.map