@internetarchive/collection-browser 2.7.6-alpha.0 → 2.7.6-alpha2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (330) hide show
  1. package/.editorconfig +29 -29
  2. package/.husky/pre-commit +4 -4
  3. package/LICENSE +661 -661
  4. package/README.md +83 -83
  5. package/dist/index.d.ts +13 -15
  6. package/dist/index.js +13 -15
  7. package/dist/index.js.map +1 -1
  8. package/dist/src/app-root.d.ts +99 -95
  9. package/dist/src/app-root.js +528 -494
  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/collection-browser.d.ts +584 -578
  76. package/dist/src/collection-browser.js +1640 -1614
  77. package/dist/src/collection-browser.js.map +1 -1
  78. package/dist/src/collection-facets/facet-row.d.ts +30 -30
  79. package/dist/src/collection-facets/facet-row.js +118 -118
  80. package/dist/src/collection-facets/facet-tombstone-row.d.ts +5 -5
  81. package/dist/src/collection-facets/facet-tombstone-row.js +15 -15
  82. package/dist/src/collection-facets/facets-template.d.ts +13 -13
  83. package/dist/src/collection-facets/facets-template.js +44 -44
  84. package/dist/src/collection-facets/more-facets-content.d.ts +106 -106
  85. package/dist/src/collection-facets/more-facets-content.js +407 -407
  86. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  87. package/dist/src/collection-facets/more-facets-pagination.js +196 -196
  88. package/dist/src/collection-facets/smart-facets/dedupe.d.ts +10 -10
  89. package/dist/src/collection-facets/smart-facets/dedupe.js +33 -33
  90. package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.d.ts +5 -5
  91. package/dist/src/collection-facets/smart-facets/heuristics/browser-language-heuristic.js +23 -23
  92. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.d.ts +5 -5
  93. package/dist/src/collection-facets/smart-facets/heuristics/query-keywords-heuristic.js +44 -44
  94. package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.d.ts +5 -5
  95. package/dist/src/collection-facets/smart-facets/heuristics/wikidata-heuristic.js +172 -172
  96. package/dist/src/collection-facets/smart-facets/models.d.ts +26 -26
  97. package/dist/src/collection-facets/smart-facets/models.js +1 -1
  98. package/dist/src/collection-facets/smart-facets/smart-facet-bar.d.ts +31 -31
  99. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +240 -240
  100. package/dist/src/collection-facets/smart-facets/smart-facet-button.d.ts +11 -11
  101. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +86 -86
  102. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.d.ts +16 -16
  103. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +100 -100
  104. package/dist/src/collection-facets/smart-facets/smart-facet-equals.d.ts +2 -2
  105. package/dist/src/collection-facets/smart-facets/smart-facet-equals.js +12 -12
  106. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.d.ts +5 -5
  107. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +15 -15
  108. package/dist/src/collection-facets/toggle-switch.d.ts +41 -41
  109. package/dist/src/collection-facets/toggle-switch.js +94 -94
  110. package/dist/src/collection-facets.d.ts +103 -103
  111. package/dist/src/collection-facets.js +522 -522
  112. package/dist/src/data-source/collection-browser-data-source-interface.d.ts +241 -241
  113. package/dist/src/data-source/collection-browser-data-source-interface.js +1 -1
  114. package/dist/src/data-source/collection-browser-data-source.d.ts +373 -373
  115. package/dist/src/data-source/collection-browser-data-source.js +982 -982
  116. package/dist/src/data-source/collection-browser-query-state.d.ts +43 -43
  117. package/dist/src/data-source/collection-browser-query-state.js +1 -1
  118. package/dist/src/data-source/models.d.ts +28 -28
  119. package/dist/src/data-source/models.js +8 -8
  120. package/dist/src/empty-placeholder.d.ts +23 -23
  121. package/dist/src/empty-placeholder.js +79 -79
  122. package/dist/src/expanded-date-picker.d.ts +43 -43
  123. package/dist/src/expanded-date-picker.js +109 -109
  124. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  125. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  126. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  127. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  128. package/dist/src/manage/manage-bar.d.ts +71 -30
  129. package/dist/src/manage/manage-bar.js +209 -83
  130. package/dist/src/manage/manage-bar.js.map +1 -1
  131. package/dist/src/manage/remove-items-modal-content.d.ts +13 -0
  132. package/dist/src/manage/remove-items-modal-content.js +104 -0
  133. package/dist/src/manage/remove-items-modal-content.js.map +1 -0
  134. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  135. package/dist/src/mediatype/mediatype-config.js +91 -91
  136. package/dist/src/models.d.ts +219 -219
  137. package/dist/src/models.js +401 -401
  138. package/dist/src/models.js.map +1 -1
  139. package/dist/src/restoration-state-handler.d.ts +70 -70
  140. package/dist/src/restoration-state-handler.js +363 -363
  141. package/dist/src/sort-filter-bar/alpha-bar-tooltip.d.ts +6 -6
  142. package/dist/src/sort-filter-bar/alpha-bar-tooltip.js +24 -24
  143. package/dist/src/sort-filter-bar/alpha-bar.d.ts +21 -21
  144. package/dist/src/sort-filter-bar/alpha-bar.js +128 -128
  145. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  146. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  147. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  148. package/dist/src/sort-filter-bar/img/list.js +2 -2
  149. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.d.ts +1 -1
  150. package/dist/src/sort-filter-bar/img/sort-toggle-disabled.js +2 -2
  151. package/dist/src/sort-filter-bar/img/sort-toggle-down.d.ts +1 -1
  152. package/dist/src/sort-filter-bar/img/sort-toggle-down.js +2 -2
  153. package/dist/src/sort-filter-bar/img/sort-toggle-up.d.ts +1 -1
  154. package/dist/src/sort-filter-bar/img/sort-toggle-up.js +2 -2
  155. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  156. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  157. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  158. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  159. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +223 -223
  160. package/dist/src/sort-filter-bar/sort-filter-bar.js +697 -697
  161. package/dist/src/styles/ia-button.d.ts +2 -2
  162. package/dist/src/styles/ia-button.js +51 -19
  163. package/dist/src/styles/ia-button.js.map +1 -1
  164. package/dist/src/styles/item-image-styles.d.ts +8 -8
  165. package/dist/src/styles/item-image-styles.js +9 -9
  166. package/dist/src/styles/sr-only.d.ts +1 -1
  167. package/dist/src/styles/sr-only.js +2 -2
  168. package/dist/src/tiles/base-tile-component.d.ts +19 -19
  169. package/dist/src/tiles/base-tile-component.js +64 -64
  170. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  171. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  172. package/dist/src/tiles/grid/account-tile.d.ts +18 -18
  173. package/dist/src/tiles/grid/account-tile.js +72 -72
  174. package/dist/src/tiles/grid/collection-tile.d.ts +15 -15
  175. package/dist/src/tiles/grid/collection-tile.js +80 -80
  176. package/dist/src/tiles/grid/item-tile.d.ts +34 -34
  177. package/dist/src/tiles/grid/item-tile.js +158 -158
  178. package/dist/src/tiles/grid/search-tile.d.ts +10 -10
  179. package/dist/src/tiles/grid/search-tile.js +51 -51
  180. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.d.ts +1 -1
  181. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +8 -8
  182. package/dist/src/tiles/grid/tile-stats.d.ts +11 -11
  183. package/dist/src/tiles/grid/tile-stats.js +53 -53
  184. package/dist/src/tiles/hover/hover-pane-controller.d.ts +219 -219
  185. package/dist/src/tiles/hover/hover-pane-controller.js +352 -352
  186. package/dist/src/tiles/hover/tile-hover-pane.d.ts +18 -18
  187. package/dist/src/tiles/hover/tile-hover-pane.js +69 -69
  188. package/dist/src/tiles/image-block.d.ts +18 -18
  189. package/dist/src/tiles/image-block.js +89 -89
  190. package/dist/src/tiles/item-image.d.ts +39 -39
  191. package/dist/src/tiles/item-image.js +154 -154
  192. package/dist/src/tiles/list/tile-list-compact-header.d.ts +6 -6
  193. package/dist/src/tiles/list/tile-list-compact-header.js +38 -38
  194. package/dist/src/tiles/list/tile-list-compact.d.ts +19 -19
  195. package/dist/src/tiles/list/tile-list-compact.js +122 -122
  196. package/dist/src/tiles/list/tile-list.d.ts +54 -54
  197. package/dist/src/tiles/list/tile-list.js +323 -323
  198. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  199. package/dist/src/tiles/mediatype-icon.js +47 -47
  200. package/dist/src/tiles/overlay/icon-overlay.d.ts +8 -8
  201. package/dist/src/tiles/overlay/icon-overlay.js +25 -25
  202. package/dist/src/tiles/overlay/text-overlay.d.ts +9 -9
  203. package/dist/src/tiles/overlay/text-overlay.js +31 -31
  204. package/dist/src/tiles/review-block.d.ts +12 -12
  205. package/dist/src/tiles/review-block.js +56 -56
  206. package/dist/src/tiles/text-snippet-block.d.ts +27 -27
  207. package/dist/src/tiles/text-snippet-block.js +73 -73
  208. package/dist/src/tiles/tile-dispatcher.d.ts +64 -64
  209. package/dist/src/tiles/tile-dispatcher.js +230 -230
  210. package/dist/src/tiles/tile-display-value-provider.d.ts +47 -47
  211. package/dist/src/tiles/tile-display-value-provider.js +94 -94
  212. package/dist/src/utils/analytics-events.d.ts +28 -28
  213. package/dist/src/utils/analytics-events.js +30 -30
  214. package/dist/src/utils/array-equals.d.ts +4 -4
  215. package/dist/src/utils/array-equals.js +10 -10
  216. package/dist/src/utils/collapse-repeated-quotes.d.ts +11 -11
  217. package/dist/src/utils/collapse-repeated-quotes.js +13 -13
  218. package/dist/src/utils/facet-utils.d.ts +83 -83
  219. package/dist/src/utils/facet-utils.js +145 -145
  220. package/dist/src/utils/format-count.d.ts +7 -7
  221. package/dist/src/utils/format-count.js +76 -76
  222. package/dist/src/utils/format-date.d.ts +2 -2
  223. package/dist/src/utils/format-date.js +25 -25
  224. package/dist/src/utils/format-unit-size.d.ts +2 -2
  225. package/dist/src/utils/format-unit-size.js +33 -33
  226. package/dist/src/utils/local-date-from-utc.d.ts +9 -9
  227. package/dist/src/utils/local-date-from-utc.js +15 -15
  228. package/dist/src/utils/log.d.ts +7 -7
  229. package/dist/src/utils/log.js +15 -15
  230. package/dist/src/utils/resolve-mediatype.d.ts +8 -8
  231. package/dist/src/utils/resolve-mediatype.js +23 -23
  232. package/dist/src/utils/sha1.d.ts +2 -2
  233. package/dist/src/utils/sha1.js +8 -8
  234. package/dist/test/collection-browser.test.d.ts +1 -1
  235. package/dist/test/collection-browser.test.js +1293 -1293
  236. package/dist/test/collection-facets/facet-row.test.d.ts +1 -1
  237. package/dist/test/collection-facets/facet-row.test.js +227 -227
  238. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  239. package/dist/test/collection-facets/facets-template.test.js +91 -91
  240. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  241. package/dist/test/collection-facets/more-facets-content.test.js +141 -141
  242. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  243. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  244. package/dist/test/collection-facets/toggle-switch.test.d.ts +1 -1
  245. package/dist/test/collection-facets/toggle-switch.test.js +73 -73
  246. package/dist/test/collection-facets.test.d.ts +2 -2
  247. package/dist/test/collection-facets.test.js +690 -690
  248. package/dist/test/data-source/collection-browser-data-source.test.d.ts +1 -1
  249. package/dist/test/data-source/collection-browser-data-source.test.js +89 -89
  250. package/dist/test/empty-placeholder.test.d.ts +1 -1
  251. package/dist/test/empty-placeholder.test.js +63 -63
  252. package/dist/test/expanded-date-picker.test.d.ts +1 -1
  253. package/dist/test/expanded-date-picker.test.js +95 -95
  254. package/dist/test/icon-overlay.test.d.ts +1 -1
  255. package/dist/test/icon-overlay.test.js +24 -24
  256. package/dist/test/image-block.test.d.ts +1 -1
  257. package/dist/test/image-block.test.js +107 -107
  258. package/dist/test/item-image.test.d.ts +1 -1
  259. package/dist/test/item-image.test.js +85 -85
  260. package/dist/test/manage/manage-bar.test.d.ts +1 -1
  261. package/dist/test/manage/manage-bar.test.js +91 -81
  262. package/dist/test/manage/manage-bar.test.js.map +1 -1
  263. package/dist/test/mediatype-config.test.d.ts +1 -1
  264. package/dist/test/mediatype-config.test.js +16 -16
  265. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  266. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  267. package/dist/test/mocks/mock-search-responses.d.ts +25 -25
  268. package/dist/test/mocks/mock-search-responses.js +942 -942
  269. package/dist/test/mocks/mock-search-service.d.ts +15 -15
  270. package/dist/test/mocks/mock-search-service.js +54 -54
  271. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  272. package/dist/test/restoration-state-handler.test.js +270 -270
  273. package/dist/test/review-block.test.d.ts +1 -1
  274. package/dist/test/review-block.test.js +44 -44
  275. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.d.ts +1 -1
  276. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +12 -12
  277. package/dist/test/sort-filter-bar/alpha-bar.test.d.ts +1 -1
  278. package/dist/test/sort-filter-bar/alpha-bar.test.js +73 -73
  279. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  280. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +426 -426
  281. package/dist/test/text-overlay.test.d.ts +1 -1
  282. package/dist/test/text-overlay.test.js +38 -38
  283. package/dist/test/text-snippet-block.test.d.ts +1 -1
  284. package/dist/test/text-snippet-block.test.js +57 -57
  285. package/dist/test/tile-stats.test.d.ts +1 -1
  286. package/dist/test/tile-stats.test.js +81 -81
  287. package/dist/test/tiles/grid/account-tile.test.d.ts +1 -1
  288. package/dist/test/tiles/grid/account-tile.test.js +76 -76
  289. package/dist/test/tiles/grid/collection-tile.test.d.ts +1 -1
  290. package/dist/test/tiles/grid/collection-tile.test.js +73 -73
  291. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  292. package/dist/test/tiles/grid/item-tile.test.js +312 -312
  293. package/dist/test/tiles/grid/search-tile.test.d.ts +1 -1
  294. package/dist/test/tiles/grid/search-tile.test.js +51 -51
  295. package/dist/test/tiles/hover/hover-pane-controller.test.d.ts +1 -1
  296. package/dist/test/tiles/hover/hover-pane-controller.test.js +259 -259
  297. package/dist/test/tiles/hover/tile-hover-pane.test.d.ts +1 -1
  298. package/dist/test/tiles/hover/tile-hover-pane.test.js +56 -56
  299. package/dist/test/tiles/list/tile-list-compact.test.d.ts +1 -1
  300. package/dist/test/tiles/list/tile-list-compact.test.js +143 -143
  301. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  302. package/dist/test/tiles/list/tile-list.test.js +297 -297
  303. package/dist/test/tiles/tile-dispatcher.test.d.ts +1 -1
  304. package/dist/test/tiles/tile-dispatcher.test.js +100 -100
  305. package/dist/test/tiles/tile-display-value-provider.test.d.ts +1 -1
  306. package/dist/test/tiles/tile-display-value-provider.test.js +141 -141
  307. package/dist/test/utils/array-equals.test.d.ts +1 -1
  308. package/dist/test/utils/array-equals.test.js +26 -26
  309. package/dist/test/utils/format-count.test.d.ts +1 -1
  310. package/dist/test/utils/format-count.test.js +23 -23
  311. package/dist/test/utils/format-date.test.d.ts +1 -1
  312. package/dist/test/utils/format-date.test.js +17 -17
  313. package/dist/test/utils/format-unit-size.test.d.ts +1 -1
  314. package/dist/test/utils/format-unit-size.test.js +17 -17
  315. package/dist/test/utils/local-date-from-utc.test.d.ts +1 -1
  316. package/dist/test/utils/local-date-from-utc.test.js +26 -26
  317. package/index.ts +0 -2
  318. package/local.archive.org.cert +86 -86
  319. package/local.archive.org.key +27 -27
  320. package/package.json +1 -1
  321. package/renovate.json +6 -6
  322. package/src/app-root.ts +36 -0
  323. package/src/collection-browser.ts +29 -5
  324. package/src/manage/manage-bar.ts +168 -24
  325. package/src/manage/remove-items-modal-content.ts +107 -0
  326. package/src/models.ts +2 -2
  327. package/src/styles/ia-button.ts +37 -5
  328. package/test/manage/manage-bar.test.ts +12 -0
  329. package/web-dev-server.config.mjs +30 -30
  330. package/web-test-runner.config.mjs +41 -41
@@ -1,30 +1,71 @@
1
- import { LitElement, TemplateResult, CSSResultGroup } from 'lit';
2
- export interface ManageableItem {
3
- identifier: string;
4
- title?: string;
5
- dateStr?: string;
6
- }
7
- export declare class ManageBar extends LitElement {
8
- /**
9
- * The label displayed in front of the management buttons
10
- */
11
- label: string;
12
- /**
13
- * Whether to show the "Select All" button (default false)
14
- */
15
- showSelectAll: boolean;
16
- /**
17
- * Whether to show the "Unselect All" button (default false)
18
- */
19
- showUnselectAll: boolean;
20
- /**
21
- * Whether to active delete button for selectable items
22
- */
23
- removeAllowed: boolean;
24
- render(): TemplateResult;
25
- private cancelClicked;
26
- private removeClicked;
27
- private selectAllClicked;
28
- private unselectAllClicked;
29
- static get styles(): CSSResultGroup;
30
- }
1
+ import { LitElement, TemplateResult, CSSResultGroup, PropertyValues } from 'lit';
2
+ import { type ModalManagerInterface } from '@internetarchive/modal-manager';
3
+ import './remove-items-modal-content';
4
+ export interface ManageableItem {
5
+ identifier: string;
6
+ title?: string;
7
+ dateStr?: string;
8
+ }
9
+ export declare class ManageBar extends LitElement {
10
+ /**
11
+ * The label displayed in front of the management buttons
12
+ */
13
+ label: string;
14
+ /**
15
+ * Specifies the context in which the collection browser is being used
16
+ */
17
+ activeTabId?: string;
18
+ /**
19
+ * The shared modal manager component for displaying modal dialogs on this page
20
+ */
21
+ modalManager?: ModalManagerInterface;
22
+ /**
23
+ * Array of items that have been selected for management
24
+ */
25
+ selectedItems: Array<ManageableItem>;
26
+ /**
27
+ * Whether to show the "Select All" button (default false)
28
+ */
29
+ showSelectAll: boolean;
30
+ /**
31
+ * Whether to show the "Unselect All" button (default false)
32
+ */
33
+ showUnselectAll: boolean;
34
+ /**
35
+ * Item removal failure message, if any
36
+ */
37
+ isItemDeleted: boolean;
38
+ /**
39
+ * Whether to show "Item Manager the items" button (default false)
40
+ */
41
+ showManageButton: boolean;
42
+ /**
43
+ * Whether to active delete button for selectable items
44
+ */
45
+ removeAllowed: boolean;
46
+ updated(changed: PropertyValues): void;
47
+ render(): TemplateResult;
48
+ private cancelClicked;
49
+ /**
50
+ * Shows a modal dialog confirming the list of items to be removed
51
+ * @param items Which items to list in the modal
52
+ */
53
+ private removeItemsClicked;
54
+ private manageItemsClicked;
55
+ private selectAllClicked;
56
+ private unselectAllClicked;
57
+ /**
58
+ * Shows a modal dialog confirming the list of items to be removed
59
+ * @param items Which items to list in the modal
60
+ */
61
+ private showRemoveItemsModal;
62
+ /**
63
+ * Shows a modal dialog indicating that item removal is being processed
64
+ */
65
+ private showRemoveItemsProcessingModal;
66
+ /**
67
+ * Shows a modal dialog indicating that an error occurred while removing items
68
+ */
69
+ private showRemoveItemsErrorModal;
70
+ static get styles(): CSSResultGroup;
71
+ }
@@ -1,30 +1,57 @@
1
- import { __decorate } from "tslib";
2
- import { msg } from '@lit/localize';
3
- import { LitElement, html, css } from 'lit';
4
- import { customElement, property } from 'lit/decorators.js';
5
- import { when } from 'lit/directives/when.js';
6
- import iaButtonStyle from '../styles/ia-button';
7
- let ManageBar = class ManageBar extends LitElement {
8
- constructor() {
9
- super(...arguments);
10
- /**
11
- * The label displayed in front of the management buttons
12
- */
13
- this.label = msg('Select items to remove');
14
- /**
15
- * Whether to show the "Select All" button (default false)
16
- */
17
- this.showSelectAll = false;
18
- /**
19
- * Whether to show the "Unselect All" button (default false)
20
- */
21
- this.showUnselectAll = false;
22
- /**
23
- * Whether to active delete button for selectable items
24
- */
25
- this.removeAllowed = false;
26
- }
27
- render() {
1
+ import { __decorate } from "tslib";
2
+ import { msg } from '@lit/localize';
3
+ import { LitElement, html, css, } from 'lit';
4
+ import { customElement, property } from 'lit/decorators.js';
5
+ import { when } from 'lit/directives/when.js';
6
+ import { ModalConfig, } from '@internetarchive/modal-manager';
7
+ import iaButtonStyle from '../styles/ia-button';
8
+ import './remove-items-modal-content';
9
+ let ManageBar = class ManageBar extends LitElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ /**
13
+ * The label displayed in front of the management buttons
14
+ */
15
+ this.label = msg('Select items to remove');
16
+ /**
17
+ * Array of items that have been selected for management
18
+ */
19
+ this.selectedItems = [];
20
+ /**
21
+ * Whether to show the "Select All" button (default false)
22
+ */
23
+ this.showSelectAll = false;
24
+ /**
25
+ * Whether to show the "Unselect All" button (default false)
26
+ */
27
+ this.showUnselectAll = false;
28
+ /**
29
+ * Item removal failure message, if any
30
+ */
31
+ this.isItemDeleted = true;
32
+ /**
33
+ * Whether to show "Item Manager the items" button (default false)
34
+ */
35
+ this.showManageButton = false;
36
+ /**
37
+ * Whether to active delete button for selectable items
38
+ */
39
+ this.removeAllowed = false;
40
+ }
41
+ updated(changed) {
42
+ var _a, _b;
43
+ if (changed.has('isItemDeleted')) {
44
+ console.log(this.isItemDeleted);
45
+ if (this.isItemDeleted === false) {
46
+ this.showRemoveItemsErrorModal();
47
+ }
48
+ else {
49
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.closeModal();
50
+ (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.classList.remove('remove-items');
51
+ }
52
+ }
53
+ }
54
+ render() {
28
55
  return html `
29
56
  <div class="manage-container">
30
57
  <span class="manage-label">${this.label}</span>
@@ -35,19 +62,26 @@ let ManageBar = class ManageBar extends LitElement {
35
62
  <button
36
63
  class="ia-button danger"
37
64
  ?disabled=${!this.removeAllowed}
38
- @click=${this.removeClicked}
65
+ @click=${this.showRemoveItemsModal}
39
66
  >
40
67
  ${msg('Remove selected items')}
41
68
  </button>
69
+ ${when(this.showManageButton, () => html ` <button
70
+ class="ia-button warning"
71
+ ?disabled=${!this.removeAllowed}
72
+ @click=${this.manageItemsClicked}
73
+ >
74
+ ${msg('Item Manager the items')}
75
+ </button>`)}
42
76
  <div class="selection-buttons">
43
77
  ${when(this.showSelectAll, () => html ` <button
44
- class="link-styled select-all-btn"
78
+ class="ia-button link select-all-btn"
45
79
  @click=${this.selectAllClicked}
46
80
  >
47
81
  ${msg('Select all')}
48
82
  </button>`)}
49
83
  ${when(this.showUnselectAll, () => html ` <button
50
- class="link-styled unselect-all-btn"
84
+ class="ia-button link unselect-all-btn"
51
85
  @click=${this.unselectAllClicked}
52
86
  >
53
87
  ${msg('Unselect all')}
@@ -55,21 +89,111 @@ let ManageBar = class ManageBar extends LitElement {
55
89
  </div>
56
90
  </div>
57
91
  </div>
58
- `;
59
- }
60
- cancelClicked() {
61
- this.dispatchEvent(new CustomEvent('cancel'));
62
- }
63
- removeClicked() {
64
- this.dispatchEvent(new CustomEvent('removeItems'));
65
- }
66
- selectAllClicked() {
67
- this.dispatchEvent(new CustomEvent('selectAll'));
68
- }
69
- unselectAllClicked() {
70
- this.dispatchEvent(new CustomEvent('unselectAll'));
71
- }
72
- static get styles() {
92
+ `;
93
+ }
94
+ cancelClicked() {
95
+ this.dispatchEvent(new CustomEvent('cancel'));
96
+ }
97
+ /**
98
+ * Shows a modal dialog confirming the list of items to be removed
99
+ * @param items Which items to list in the modal
100
+ */
101
+ removeItemsClicked() {
102
+ this.showRemoveItemsProcessingModal();
103
+ this.dispatchEvent(new CustomEvent('removeItems'));
104
+ }
105
+ manageItemsClicked() {
106
+ this.dispatchEvent(new CustomEvent('manageItems'));
107
+ }
108
+ selectAllClicked() {
109
+ this.dispatchEvent(new CustomEvent('selectAll'));
110
+ }
111
+ unselectAllClicked() {
112
+ this.dispatchEvent(new CustomEvent('unselectAll'));
113
+ }
114
+ /**
115
+ * Shows a modal dialog confirming the list of items to be removed
116
+ * @param items Which items to list in the modal
117
+ */
118
+ showRemoveItemsModal() {
119
+ var _a, _b;
120
+ const delayMessage = this.activeTabId === 'uploads'
121
+ ? msg('Note: it may take a few minutes for these items to stop appearing in your uploads list.')
122
+ : undefined;
123
+ const customModalContent = html `
124
+ <remove-items-modal-content
125
+ .items=${this.selectedItems}
126
+ .message=${delayMessage}
127
+ @confirm=${() => this.removeItemsClicked()}
128
+ ></remove-items-modal-content>
129
+ `;
130
+ const config = new ModalConfig({
131
+ showProcessingIndicator: false,
132
+ processingImageMode: 'processing',
133
+ bodyColor: '#fff',
134
+ headerColor: '#194880',
135
+ showHeaderLogo: false,
136
+ closeOnBackdropClick: true,
137
+ title: html `${msg('Are you sure you want to remove these items?')}`,
138
+ });
139
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
140
+ (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
141
+ config,
142
+ customModalContent,
143
+ userClosedModalCallback: () => {
144
+ var _a;
145
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
146
+ },
147
+ });
148
+ }
149
+ /**
150
+ * Shows a modal dialog indicating that item removal is being processed
151
+ */
152
+ showRemoveItemsProcessingModal() {
153
+ var _a, _b;
154
+ const config = new ModalConfig({
155
+ showProcessingIndicator: true,
156
+ processingImageMode: 'processing',
157
+ bodyColor: '#fff',
158
+ headerColor: '#194880',
159
+ showHeaderLogo: false,
160
+ closeOnBackdropClick: true,
161
+ title: html `${msg('Removing selected items...')}`,
162
+ });
163
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
164
+ (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
165
+ config,
166
+ userClosedModalCallback: () => {
167
+ var _a;
168
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
169
+ },
170
+ });
171
+ }
172
+ /**
173
+ * Shows a modal dialog indicating that an error occurred while removing items
174
+ */
175
+ showRemoveItemsErrorModal() {
176
+ var _a, _b;
177
+ const config = new ModalConfig({
178
+ showProcessingIndicator: false,
179
+ processingImageMode: 'processing',
180
+ bodyColor: '#fff',
181
+ headerColor: '#691916',
182
+ showHeaderLogo: false,
183
+ closeOnBackdropClick: true,
184
+ title: html `${msg('Error: unable to remove items')}`,
185
+ message: html `${msg('An error occurred while removing items. Please try again in a few minutes.')}`,
186
+ });
187
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
188
+ (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
189
+ config,
190
+ userClosedModalCallback: () => {
191
+ var _a;
192
+ (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
193
+ },
194
+ });
195
+ }
196
+ static get styles() {
73
197
  return css `
74
198
  ${iaButtonStyle}
75
199
  .manage-container {
@@ -89,51 +213,53 @@ let ManageBar = class ManageBar extends LitElement {
89
213
 
90
214
  .manage-buttons {
91
215
  display: flex;
216
+ flex-wrap: wrap;
92
217
  align-items: center;
93
218
  column-gap: 5px;
94
219
  }
95
220
 
221
+ .selection-buttons {
222
+ display: inherit;
223
+ }
224
+
96
225
  .ia-button,
97
226
  button {
98
227
  padding: 6px 12px;
99
228
  font-size: 1.4rem;
229
+ margin: 3px 0;
100
230
  }
101
-
102
- .ia-button.danger:disabled {
103
- opacity: 0.5;
104
- }
105
-
106
- button.link-styled {
107
- margin: 0;
108
- padding: 6px;
109
- border: 0;
110
- appearance: none;
111
- background: none;
112
- color: var(--ia-theme-link-color, #4b64ff);
113
- font: inherit;
114
- text-decoration: none;
115
- cursor: pointer;
116
- }
117
- button.link-styled:hover {
118
- text-decoration: underline;
119
- }
120
- `;
121
- }
122
- };
123
- __decorate([
124
- property({ type: String })
125
- ], ManageBar.prototype, "label", void 0);
126
- __decorate([
127
- property({ type: Boolean })
128
- ], ManageBar.prototype, "showSelectAll", void 0);
129
- __decorate([
130
- property({ type: Boolean })
131
- ], ManageBar.prototype, "showUnselectAll", void 0);
132
- __decorate([
133
- property({ type: Boolean })
134
- ], ManageBar.prototype, "removeAllowed", void 0);
135
- ManageBar = __decorate([
136
- customElement('manage-bar')
137
- ], ManageBar);
138
- export { ManageBar };
231
+ `;
232
+ }
233
+ };
234
+ __decorate([
235
+ property({ type: String })
236
+ ], ManageBar.prototype, "label", void 0);
237
+ __decorate([
238
+ property({ type: String })
239
+ ], ManageBar.prototype, "activeTabId", void 0);
240
+ __decorate([
241
+ property({ type: Object })
242
+ ], ManageBar.prototype, "modalManager", void 0);
243
+ __decorate([
244
+ property({ type: Object })
245
+ ], ManageBar.prototype, "selectedItems", void 0);
246
+ __decorate([
247
+ property({ type: Boolean })
248
+ ], ManageBar.prototype, "showSelectAll", void 0);
249
+ __decorate([
250
+ property({ type: Boolean })
251
+ ], ManageBar.prototype, "showUnselectAll", void 0);
252
+ __decorate([
253
+ property({ type: Boolean })
254
+ ], ManageBar.prototype, "isItemDeleted", void 0);
255
+ __decorate([
256
+ property({ type: Boolean })
257
+ ], ManageBar.prototype, "showManageButton", void 0);
258
+ __decorate([
259
+ property({ type: Boolean })
260
+ ], ManageBar.prototype, "removeAllowed", void 0);
261
+ ManageBar = __decorate([
262
+ customElement('manage-bar')
263
+ ], ManageBar);
264
+ export { ManageBar };
139
265
  //# sourceMappingURL=manage-bar.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"manage-bar.js","sourceRoot":"","sources":["../../../src/manage/manage-bar.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAkC,MAAM,KAAK,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAC9C,OAAO,aAAa,MAAM,qBAAqB,CAAC;AAShD,IAAa,SAAS,GAAtB,MAAa,SAAU,SAAQ,UAAU;IAAzC;;QACE;;WAEG;QACyB,UAAK,GAAG,GAAG,CAAC,wBAAwB,CAAC,CAAC;QAElE;;WAEG;QAC0B,kBAAa,GAAG,KAAK,CAAC;QAEnD;;WAEG;QAC0B,oBAAe,GAAG,KAAK,CAAC;QAErD;;WAEG;QAC0B,kBAAa,GAAG,KAAK,CAAC;IA4GrD,CAAC;IA1GC,MAAM;QACJ,OAAO,IAAI,CAAA;;qCAEsB,IAAI,CAAC,KAAK;;kDAEG,IAAI,CAAC,aAAa;cACtD,GAAG,CAAC,QAAQ,CAAC;;;;wBAIH,CAAC,IAAI,CAAC,aAAa;qBACtB,IAAI,CAAC,aAAa;;cAEzB,GAAG,CAAC,uBAAuB,CAAC;;;cAG5B,IAAI,CACJ,IAAI,CAAC,aAAa,EAClB,GAAG,EAAE,CAAC,IAAI,CAAA;;yBAEC,IAAI,CAAC,gBAAgB;;kBAE5B,GAAG,CAAC,YAAY,CAAC;wBACX,CACX;cACC,IAAI,CACJ,IAAI,CAAC,eAAe,EACpB,GAAG,EAAE,CAAC,IAAI,CAAA;;yBAEC,IAAI,CAAC,kBAAkB;;kBAE9B,GAAG,CAAC,cAAc,CAAC;wBACb,CACX;;;;KAIR,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChD,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC;IACnD,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;QACN,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA8ChB,CAAC;IACJ,CAAC;CACF,CAAA;AA3H6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wCAAuC;AAKrC;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;gDAAuB;AAKtB;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;kDAAyB;AAKxB;IAA5B,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;gDAAuB;AAnBxC,SAAS;IADrB,aAAa,CAAC,YAAY,CAAC;GACf,SAAS,CA+HrB;SA/HY,SAAS","sourcesContent":["import { msg } from '@lit/localize';\nimport { LitElement, html, css, TemplateResult, CSSResultGroup } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { when } from 'lit/directives/when.js';\nimport iaButtonStyle from '../styles/ia-button';\n\nexport interface ManageableItem {\n identifier: string;\n title?: string;\n dateStr?: string;\n}\n\n@customElement('manage-bar')\nexport class ManageBar extends LitElement {\n /**\n * The label displayed in front of the management buttons\n */\n @property({ type: String }) label = msg('Select items to remove');\n\n /**\n * Whether to show the \"Select All\" button (default false)\n */\n @property({ type: Boolean }) showSelectAll = false;\n\n /**\n * Whether to show the \"Unselect All\" button (default false)\n */\n @property({ type: Boolean }) showUnselectAll = false;\n\n /**\n * Whether to active delete button for selectable items\n */\n @property({ type: Boolean }) removeAllowed = false;\n\n render(): TemplateResult {\n return html`\n <div class=\"manage-container\">\n <span class=\"manage-label\">${this.label}</span>\n <div class=\"manage-buttons\">\n <button class=\"ia-button dark\" @click=${this.cancelClicked}>\n ${msg('Cancel')}\n </button>\n <button\n class=\"ia-button danger\"\n ?disabled=${!this.removeAllowed}\n @click=${this.removeClicked}\n >\n ${msg('Remove selected items')}\n </button>\n <div class=\"selection-buttons\">\n ${when(\n this.showSelectAll,\n () => html` <button\n class=\"link-styled select-all-btn\"\n @click=${this.selectAllClicked}\n >\n ${msg('Select all')}\n </button>`\n )}\n ${when(\n this.showUnselectAll,\n () => html` <button\n class=\"link-styled unselect-all-btn\"\n @click=${this.unselectAllClicked}\n >\n ${msg('Unselect all')}\n </button>`\n )}\n </div>\n </div>\n </div>\n `;\n }\n\n private cancelClicked(): void {\n this.dispatchEvent(new CustomEvent('cancel'));\n }\n\n private removeClicked(): void {\n this.dispatchEvent(new CustomEvent('removeItems'));\n }\n\n private selectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('selectAll'));\n }\n\n private unselectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('unselectAll'));\n }\n\n static get styles(): CSSResultGroup {\n return css`\n ${iaButtonStyle}\n .manage-container {\n display: flex;\n align-items: center;\n column-gap: 5px;\n padding: 20px 0 20px;\n flex-wrap: wrap;\n }\n\n .manage-label {\n display: inline-block;\n font-weight: bold;\n font-size: 1.8rem;\n padding-right: 10px;\n }\n\n .manage-buttons {\n display: flex;\n align-items: center;\n column-gap: 5px;\n }\n\n .ia-button,\n button {\n padding: 6px 12px;\n font-size: 1.4rem;\n }\n\n .ia-button.danger:disabled {\n opacity: 0.5;\n }\n\n button.link-styled {\n margin: 0;\n padding: 6px;\n border: 0;\n appearance: none;\n background: none;\n color: var(--ia-theme-link-color, #4b64ff);\n font: inherit;\n text-decoration: none;\n cursor: pointer;\n }\n button.link-styled:hover {\n text-decoration: underline;\n }\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"manage-bar.js","sourceRoot":"","sources":["../../../src/manage/manage-bar.ts"],"names":[],"mappings":"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","sourcesContent":["import { msg } from '@lit/localize';\nimport {\n LitElement,\n html,\n css,\n TemplateResult,\n CSSResultGroup,\n PropertyValues,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { when } from 'lit/directives/when.js';\nimport {\n ModalConfig,\n type ModalManagerInterface,\n} from '@internetarchive/modal-manager';\nimport iaButtonStyle from '../styles/ia-button';\nimport './remove-items-modal-content';\n\nexport interface ManageableItem {\n identifier: string;\n title?: string;\n dateStr?: string;\n}\n\n@customElement('manage-bar')\nexport class ManageBar extends LitElement {\n /**\n * The label displayed in front of the management buttons\n */\n @property({ type: String }) label = msg('Select items to remove');\n\n /**\n * Specifies the context in which the collection browser is being used\n */\n @property({ type: String }) activeTabId?: string;\n\n /**\n * The shared modal manager component for displaying modal dialogs on this page\n */\n @property({ type: Object }) modalManager?: ModalManagerInterface;\n\n /**\n * Array of items that have been selected for management\n */\n @property({ type: Object }) selectedItems: Array<ManageableItem> = [];\n\n /**\n * Whether to show the \"Select All\" button (default false)\n */\n @property({ type: Boolean }) showSelectAll = false;\n\n /**\n * Whether to show the \"Unselect All\" button (default false)\n */\n @property({ type: Boolean }) showUnselectAll = false;\n\n /**\n * Item removal failure message, if any\n */\n @property({ type: Boolean }) isItemDeleted = true;\n\n /**\n * Whether to show \"Item Manager the items\" button (default false)\n */\n @property({ type: Boolean }) showManageButton = false;\n\n /**\n * Whether to active delete button for selectable items\n */\n @property({ type: Boolean }) removeAllowed = false;\n\n updated(changed: PropertyValues): void {\n if (changed.has('isItemDeleted')) {\n console.log(this.isItemDeleted)\n if (this.isItemDeleted === false) {\n this.showRemoveItemsErrorModal();\n } else {\n this.modalManager?.closeModal();\n this.modalManager?.classList.remove('remove-items');\n }\n }\n }\n\n render(): TemplateResult {\n return html`\n <div class=\"manage-container\">\n <span class=\"manage-label\">${this.label}</span>\n <div class=\"manage-buttons\">\n <button class=\"ia-button dark\" @click=${this.cancelClicked}>\n ${msg('Cancel')}\n </button>\n <button\n class=\"ia-button danger\"\n ?disabled=${!this.removeAllowed}\n @click=${this.showRemoveItemsModal}\n >\n ${msg('Remove selected items')}\n </button>\n ${when(\n this.showManageButton,\n () => html` <button\n class=\"ia-button warning\"\n ?disabled=${!this.removeAllowed}\n @click=${this.manageItemsClicked}\n >\n ${msg('Item Manager the items')}\n </button>`\n )}\n <div class=\"selection-buttons\">\n ${when(\n this.showSelectAll,\n () => html` <button\n class=\"ia-button link select-all-btn\"\n @click=${this.selectAllClicked}\n >\n ${msg('Select all')}\n </button>`\n )}\n ${when(\n this.showUnselectAll,\n () => html` <button\n class=\"ia-button link unselect-all-btn\"\n @click=${this.unselectAllClicked}\n >\n ${msg('Unselect all')}\n </button>`\n )}\n </div>\n </div>\n </div>\n `;\n }\n\n private cancelClicked(): void {\n this.dispatchEvent(new CustomEvent('cancel'));\n }\n\n /**\n * Shows a modal dialog confirming the list of items to be removed\n * @param items Which items to list in the modal\n */\n private removeItemsClicked(): void {\n this.showRemoveItemsProcessingModal();\n this.dispatchEvent(new CustomEvent('removeItems'));\n }\n\n private manageItemsClicked(): void {\n this.dispatchEvent(new CustomEvent('manageItems'));\n }\n\n private selectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('selectAll'));\n }\n\n private unselectAllClicked(): void {\n this.dispatchEvent(new CustomEvent('unselectAll'));\n }\n\n /**\n * Shows a modal dialog confirming the list of items to be removed\n * @param items Which items to list in the modal\n */\n private showRemoveItemsModal(): void {\n const delayMessage =\n this.activeTabId === 'uploads'\n ? msg(\n 'Note: it may take a few minutes for these items to stop appearing in your uploads list.'\n )\n : undefined;\n\n const customModalContent = html`\n <remove-items-modal-content\n .items=${this.selectedItems}\n .message=${delayMessage}\n @confirm=${() => this.removeItemsClicked()}\n ></remove-items-modal-content>\n `;\n\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Are you sure you want to remove these items?')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n customModalContent,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that item removal is being processed\n */\n private showRemoveItemsProcessingModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: true,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#194880',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Removing selected items...')}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n /**\n * Shows a modal dialog indicating that an error occurred while removing items\n */\n private showRemoveItemsErrorModal(): void {\n const config = new ModalConfig({\n showProcessingIndicator: false,\n processingImageMode: 'processing',\n bodyColor: '#fff',\n headerColor: '#691916',\n showHeaderLogo: false,\n closeOnBackdropClick: true,\n title: html`${msg('Error: unable to remove items')}`,\n message: html`${msg(\n 'An error occurred while removing items. Please try again in a few minutes.',\n )}`,\n });\n\n this.modalManager?.classList.add('remove-items');\n this.modalManager?.showModal({\n config,\n userClosedModalCallback: () => {\n this.modalManager?.classList.remove('remove-items');\n },\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n ${iaButtonStyle}\n .manage-container {\n display: flex;\n align-items: center;\n column-gap: 5px;\n padding: 20px 0 20px;\n flex-wrap: wrap;\n }\n\n .manage-label {\n display: inline-block;\n font-weight: bold;\n font-size: 1.8rem;\n padding-right: 10px;\n }\n\n .manage-buttons {\n display: flex;\n flex-wrap: wrap;\n align-items: center;\n column-gap: 5px;\n }\n\n .selection-buttons {\n display: inherit;\n }\n\n .ia-button,\n button {\n padding: 6px 12px;\n font-size: 1.4rem;\n margin: 3px 0;\n }\n `;\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { LitElement, TemplateResult, CSSResult } from 'lit';
2
+ export interface ManageableItem {
3
+ identifier: string;
4
+ title?: string;
5
+ date?: string;
6
+ }
7
+ export declare class RemoveItemsModalContent extends LitElement {
8
+ items: ManageableItem[];
9
+ message?: string;
10
+ render(): TemplateResult;
11
+ private removeItemsBtnClicked;
12
+ static get styles(): CSSResult;
13
+ }
@@ -0,0 +1,104 @@
1
+ import { __decorate } from "tslib";
2
+ import { LitElement, html, css, nothing } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { msg } from '@lit/localize';
5
+ import { map } from 'lit/directives/map.js';
6
+ let RemoveItemsModalContent = class RemoveItemsModalContent extends LitElement {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.items = [];
10
+ }
11
+ render() {
12
+ return html `
13
+ <ul>
14
+ ${map(this.items, ({ title, date }) => html `
15
+ <li>
16
+ <span class="item-title">${title !== null && title !== void 0 ? title : '[untitled]'}</span>
17
+ <span class="item-date">${date !== null && date !== void 0 ? date : ''}</span>
18
+ </li>
19
+ `)}
20
+ </ul>
21
+ ${this.message ? html `<p class="message">${this.message}</p>` : nothing}
22
+ <div class="button-bar">
23
+ <button class="remove-items-btn" @click=${this.removeItemsBtnClicked}>
24
+ ${msg('Remove items')}
25
+ </button>
26
+ </div>
27
+ `;
28
+ }
29
+ removeItemsBtnClicked() {
30
+ this.dispatchEvent(new CustomEvent('confirm', {
31
+ detail: {
32
+ items: this.items,
33
+ },
34
+ }));
35
+ }
36
+ static get styles() {
37
+ return css `
38
+ ul {
39
+ margin: 0;
40
+ padding: 0 10px;
41
+ font-size: 1.4rem;
42
+ list-style-type: none;
43
+ max-height: min(400px, 40vh);
44
+ overflow-y: auto;
45
+ }
46
+
47
+ li {
48
+ display: flex;
49
+ justify-content: space-between;
50
+ padding: 2px 0;
51
+ }
52
+ li:not(:last-of-type) {
53
+ border-bottom: 1px solid rgb(232, 232, 232);
54
+ }
55
+
56
+ .item-title {
57
+ word-break: break-word;
58
+ }
59
+
60
+ .item-date {
61
+ white-space: nowrap;
62
+ }
63
+
64
+ .message {
65
+ font-size: 1.4rem;
66
+ padding: 5px 10px;
67
+ }
68
+
69
+ .button-bar {
70
+ display: flex;
71
+ justify-content: center;
72
+ margin: 10px 5px;
73
+ }
74
+
75
+ .remove-items-btn {
76
+ margin-bottom: 10px;
77
+ padding: 10px;
78
+ border: 1px solid var(--primaryErrorCTABorder, #d43f3a);
79
+ border-radius: 4px;
80
+ color: white;
81
+ background: var(--primaryErrorCTAFill, #d9534f);
82
+ appearance: none;
83
+ cursor: pointer;
84
+ }
85
+ .remove-items-btn:hover {
86
+ background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.9);
87
+ }
88
+ .remove-items-btn:active {
89
+ background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.7);
90
+ }
91
+ `;
92
+ }
93
+ };
94
+ __decorate([
95
+ property({ type: Object })
96
+ ], RemoveItemsModalContent.prototype, "items", void 0);
97
+ __decorate([
98
+ property({ type: String })
99
+ ], RemoveItemsModalContent.prototype, "message", void 0);
100
+ RemoveItemsModalContent = __decorate([
101
+ customElement('remove-items-modal-content')
102
+ ], RemoveItemsModalContent);
103
+ export { RemoveItemsModalContent };
104
+ //# sourceMappingURL=remove-items-modal-content.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"remove-items-modal-content.js","sourceRoot":"","sources":["../../../src/manage/remove-items-modal-content.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAA6B,MAAM,KAAK,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AACpC,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAS5C,IAAa,uBAAuB,GAApC,MAAa,uBAAwB,SAAQ,UAAU;IAAvD;;QAC8B,UAAK,GAAqB,EAAE,CAAC;IA6F3D,CAAC;IAzFC,MAAM;QACJ,OAAO,IAAI,CAAA;;UAEL,GAAG,CACH,IAAI,CAAC,KAAK,EACV,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAA;;yCAEM,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,YAAY;wCACtB,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,EAAE;;WAEvC,CACF;;QAED,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAA,sBAAsB,IAAI,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC,OAAO;;kDAE3B,IAAI,CAAC,qBAAqB;YAChE,GAAG,CAAC,cAAc,CAAC;;;KAG1B,CAAC;IACJ,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAA8B,SAAS,EAAE;YACtD,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,KAAK;aAClB;SACF,CAAC,CACH,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAsDT,CAAC;IACJ,CAAC;CACF,CAAA;AA7F6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;sDAA8B;AAE7B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wDAAkB;AAHlC,uBAAuB;IADnC,aAAa,CAAC,4BAA4B,CAAC;GAC/B,uBAAuB,CA8FnC;SA9FY,uBAAuB","sourcesContent":["import { LitElement, html, css, nothing, TemplateResult, CSSResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { msg } from '@lit/localize';\nimport { map } from 'lit/directives/map.js';\n\nexport interface ManageableItem {\n identifier: string;\n title?: string;\n date?: string;\n}\n\n@customElement('remove-items-modal-content')\nexport class RemoveItemsModalContent extends LitElement {\n @property({ type: Object }) items: ManageableItem[] = [];\n\n @property({ type: String }) message?: string;\n\n render(): TemplateResult {\n return html`\n <ul>\n ${map(\n this.items,\n ({ title, date }) => html`\n <li>\n <span class=\"item-title\">${title ?? '[untitled]'}</span>\n <span class=\"item-date\">${date ?? ''}</span>\n </li>\n `\n )}\n </ul>\n ${this.message ? html`<p class=\"message\">${this.message}</p>` : nothing}\n <div class=\"button-bar\">\n <button class=\"remove-items-btn\" @click=${this.removeItemsBtnClicked}>\n ${msg('Remove items')}\n </button>\n </div>\n `;\n }\n\n private removeItemsBtnClicked(): void {\n this.dispatchEvent(\n new CustomEvent<{ items: ManageableItem[] }>('confirm', {\n detail: {\n items: this.items,\n },\n })\n );\n }\n\n static get styles(): CSSResult {\n return css`\n ul {\n margin: 0;\n padding: 0 10px;\n font-size: 1.4rem;\n list-style-type: none;\n max-height: min(400px, 40vh);\n overflow-y: auto;\n }\n\n li {\n display: flex;\n justify-content: space-between;\n padding: 2px 0;\n }\n li:not(:last-of-type) {\n border-bottom: 1px solid rgb(232, 232, 232);\n }\n\n .item-title {\n word-break: break-word;\n }\n\n .item-date {\n white-space: nowrap;\n }\n\n .message {\n font-size: 1.4rem;\n padding: 5px 10px;\n }\n\n .button-bar {\n display: flex;\n justify-content: center;\n margin: 10px 5px;\n }\n\n .remove-items-btn {\n margin-bottom: 10px;\n padding: 10px;\n border: 1px solid var(--primaryErrorCTABorder, #d43f3a);\n border-radius: 4px;\n color: white;\n background: var(--primaryErrorCTAFill, #d9534f);\n appearance: none;\n cursor: pointer;\n }\n .remove-items-btn:hover {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.9);\n }\n .remove-items-btn:active {\n background: rgba(var(--primaryErrorCTAFillRGB, 229, 28, 38), 0.7);\n }\n `;\n }\n}\n"]}
@@ -1,3 +1,3 @@
1
- export declare const mediatypeConfig: {
2
- [key: string]: any;
3
- };
1
+ export declare const mediatypeConfig: {
2
+ [key: string]: any;
3
+ };