@internetarchive/collection-browser 3.4.1-alpha-webdev7761.2 → 3.4.1-alpha-webdev7761.4

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 (208) hide show
  1. package/dist/src/app-root.js +19 -28
  2. package/dist/src/app-root.js.map +1 -1
  3. package/dist/src/collection-browser.d.ts +14 -10
  4. package/dist/src/collection-browser.js +870 -886
  5. package/dist/src/collection-browser.js.map +1 -1
  6. package/dist/src/collection-facets/facet-row.js +3 -4
  7. package/dist/src/collection-facets/facet-row.js.map +1 -1
  8. package/dist/src/collection-facets/models.js.map +1 -1
  9. package/dist/src/collection-facets/more-facets-content.js +145 -156
  10. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  11. package/dist/src/collection-facets/more-facets-pagination.js +6 -10
  12. package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
  13. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +16 -21
  14. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +1 -1
  15. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +7 -10
  16. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
  17. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +3 -2
  18. package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -1
  19. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +9 -11
  20. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
  21. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +7 -7
  22. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -1
  23. package/dist/src/collection-facets/toggle-switch.js +4 -6
  24. package/dist/src/collection-facets/toggle-switch.js.map +1 -1
  25. package/dist/src/collection-facets.js +34 -50
  26. package/dist/src/collection-facets.js.map +1 -1
  27. package/dist/src/combo-box/caret-closed.js +5 -11
  28. package/dist/src/combo-box/caret-closed.js.map +1 -1
  29. package/dist/src/combo-box/caret-open.js +5 -11
  30. package/dist/src/combo-box/caret-open.js.map +1 -1
  31. package/dist/src/combo-box/clear.d.ts +2 -0
  32. package/dist/src/combo-box/clear.js +11 -0
  33. package/dist/src/combo-box/clear.js.map +1 -0
  34. package/dist/src/combo-box/ia-combo-box.d.ts +40 -9
  35. package/dist/src/combo-box/ia-combo-box.js +363 -272
  36. package/dist/src/combo-box/ia-combo-box.js.map +1 -1
  37. package/dist/src/combo-box/models.d.ts +14 -0
  38. package/dist/src/combo-box/models.js +32 -1
  39. package/dist/src/combo-box/models.js.map +1 -1
  40. package/dist/src/data-source/collection-browser-data-source.js +35 -47
  41. package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
  42. package/dist/src/empty-placeholder.js +19 -18
  43. package/dist/src/empty-placeholder.js.map +1 -1
  44. package/dist/src/expanded-date-picker.js +6 -10
  45. package/dist/src/expanded-date-picker.js.map +1 -1
  46. package/dist/src/language-code-handler/language-code-handler.js +2 -2
  47. package/dist/src/language-code-handler/language-code-handler.js.map +1 -1
  48. package/dist/src/manage/manage-bar.js +86 -92
  49. package/dist/src/manage/manage-bar.js.map +1 -1
  50. package/dist/src/manage/remove-items-modal-content.js +2 -2
  51. package/dist/src/manage/remove-items-modal-content.js.map +1 -1
  52. package/dist/src/models.js +36 -40
  53. package/dist/src/models.js.map +1 -1
  54. package/dist/src/restoration-state-handler.js +9 -10
  55. package/dist/src/restoration-state-handler.js.map +1 -1
  56. package/dist/src/sort-filter-bar/alpha-bar.js +9 -14
  57. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
  58. package/dist/src/sort-filter-bar/sort-filter-bar.js +14 -24
  59. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  60. package/dist/src/tiles/base-tile-component.js +1 -2
  61. package/dist/src/tiles/base-tile-component.js.map +1 -1
  62. package/dist/src/tiles/grid/account-tile.js +36 -38
  63. package/dist/src/tiles/grid/account-tile.js.map +1 -1
  64. package/dist/src/tiles/grid/collection-tile.js +79 -82
  65. package/dist/src/tiles/grid/collection-tile.js.map +1 -1
  66. package/dist/src/tiles/grid/item-tile.js +154 -164
  67. package/dist/src/tiles/grid/item-tile.js.map +1 -1
  68. package/dist/src/tiles/grid/search-tile.js +42 -43
  69. package/dist/src/tiles/grid/search-tile.js.map +1 -1
  70. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +119 -119
  71. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -1
  72. package/dist/src/tiles/grid/tile-stats.js +2 -3
  73. package/dist/src/tiles/grid/tile-stats.js.map +1 -1
  74. package/dist/src/tiles/hover/hover-pane-controller.js +42 -49
  75. package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
  76. package/dist/src/tiles/hover/tile-hover-pane.js +113 -114
  77. package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
  78. package/dist/src/tiles/image-block.js +5 -8
  79. package/dist/src/tiles/image-block.js.map +1 -1
  80. package/dist/src/tiles/item-image.js +12 -19
  81. package/dist/src/tiles/item-image.js.map +1 -1
  82. package/dist/src/tiles/list/tile-list-compact.js +114 -122
  83. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  84. package/dist/src/tiles/list/tile-list.js +326 -347
  85. package/dist/src/tiles/list/tile-list.js.map +1 -1
  86. package/dist/src/tiles/overlay/icon-overlay.js +1 -2
  87. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -1
  88. package/dist/src/tiles/overlay/text-overlay.js +2 -4
  89. package/dist/src/tiles/overlay/text-overlay.js.map +1 -1
  90. package/dist/src/tiles/text-snippet-block.js +2 -4
  91. package/dist/src/tiles/text-snippet-block.js.map +1 -1
  92. package/dist/src/tiles/tile-dispatcher.js +233 -241
  93. package/dist/src/tiles/tile-dispatcher.js.map +1 -1
  94. package/dist/src/tiles/tile-display-value-provider.js +5 -9
  95. package/dist/src/tiles/tile-display-value-provider.js.map +1 -1
  96. package/dist/src/tiles/tile-mediatype-icon.js +12 -19
  97. package/dist/src/tiles/tile-mediatype-icon.js.map +1 -1
  98. package/dist/src/utils/collapse-repeated-quotes.js +1 -1
  99. package/dist/src/utils/collapse-repeated-quotes.js.map +1 -1
  100. package/dist/src/utils/facet-utils.js +3 -5
  101. package/dist/src/utils/facet-utils.js.map +1 -1
  102. package/dist/src/utils/format-count.js +10 -10
  103. package/dist/src/utils/format-count.js.map +1 -1
  104. package/dist/src/utils/format-date.js.map +1 -1
  105. package/dist/src/utils/resolve-mediatype.js +2 -3
  106. package/dist/src/utils/resolve-mediatype.js.map +1 -1
  107. package/dist/test/collection-browser.test.js +131 -185
  108. package/dist/test/collection-browser.test.js.map +1 -1
  109. package/dist/test/collection-facets/facet-row.test.js +60 -75
  110. package/dist/test/collection-facets/facet-row.test.js.map +1 -1
  111. package/dist/test/collection-facets/facets-template.test.js +17 -23
  112. package/dist/test/collection-facets/facets-template.test.js.map +1 -1
  113. package/dist/test/collection-facets/more-facets-content.test.js +22 -32
  114. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
  115. package/dist/test/collection-facets/more-facets-pagination.test.js +16 -22
  116. package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -1
  117. package/dist/test/collection-facets/toggle-switch.test.js +22 -19
  118. package/dist/test/collection-facets/toggle-switch.test.js.map +1 -1
  119. package/dist/test/collection-facets.test.js +80 -97
  120. package/dist/test/collection-facets.test.js.map +1 -1
  121. package/dist/test/empty-placeholder.test.js +11 -17
  122. package/dist/test/empty-placeholder.test.js.map +1 -1
  123. package/dist/test/expanded-date-picker.test.js +8 -14
  124. package/dist/test/expanded-date-picker.test.js.map +1 -1
  125. package/dist/test/icon-overlay.test.js +7 -6
  126. package/dist/test/icon-overlay.test.js.map +1 -1
  127. package/dist/test/image-block.test.js +16 -26
  128. package/dist/test/image-block.test.js.map +1 -1
  129. package/dist/test/item-image.test.js +23 -32
  130. package/dist/test/item-image.test.js.map +1 -1
  131. package/dist/test/manage/manage-bar.test.js +21 -33
  132. package/dist/test/manage/manage-bar.test.js.map +1 -1
  133. package/dist/test/manage/remove-items-modal-content.test.js +10 -15
  134. package/dist/test/manage/remove-items-modal-content.test.js.map +1 -1
  135. package/dist/test/mocks/mock-search-service.js +2 -3
  136. package/dist/test/mocks/mock-search-service.js.map +1 -1
  137. package/dist/test/restoration-state-handler.test.js +13 -21
  138. package/dist/test/restoration-state-handler.test.js.map +1 -1
  139. package/dist/test/review-block.test.js +16 -18
  140. package/dist/test/review-block.test.js.map +1 -1
  141. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +2 -3
  142. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -1
  143. package/dist/test/sort-filter-bar/alpha-bar.test.js +18 -24
  144. package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -1
  145. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +178 -180
  146. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
  147. package/dist/test/text-overlay.test.js +16 -15
  148. package/dist/test/text-overlay.test.js.map +1 -1
  149. package/dist/test/text-snippet-block.test.js +14 -19
  150. package/dist/test/text-snippet-block.test.js.map +1 -1
  151. package/dist/test/tile-stats.test.js +73 -34
  152. package/dist/test/tile-stats.test.js.map +1 -1
  153. package/dist/test/tiles/grid/account-tile.test.js +25 -25
  154. package/dist/test/tiles/grid/account-tile.test.js.map +1 -1
  155. package/dist/test/tiles/grid/collection-tile.test.js +13 -19
  156. package/dist/test/tiles/grid/collection-tile.test.js.map +1 -1
  157. package/dist/test/tiles/grid/item-tile.test.js +141 -168
  158. package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
  159. package/dist/test/tiles/grid/search-tile.test.js +9 -13
  160. package/dist/test/tiles/grid/search-tile.test.js.map +1 -1
  161. package/dist/test/tiles/hover/hover-pane-controller.test.js +50 -62
  162. package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -1
  163. package/dist/test/tiles/hover/tile-hover-pane.test.js +12 -16
  164. package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
  165. package/dist/test/tiles/list/tile-list-compact.test.js +104 -118
  166. package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
  167. package/dist/test/tiles/list/tile-list.test.js +202 -231
  168. package/dist/test/tiles/list/tile-list.test.js.map +1 -1
  169. package/dist/test/tiles/tile-dispatcher.test.js +97 -110
  170. package/dist/test/tiles/tile-dispatcher.test.js.map +1 -1
  171. package/dist/test/tiles/tile-mediatype-icon.test.js +12 -24
  172. package/dist/test/tiles/tile-mediatype-icon.test.js.map +1 -1
  173. package/dist/test/utils/format-date.test.js.map +1 -1
  174. package/index.html +1 -1
  175. package/package.json +5 -3
  176. package/src/collection-browser.ts +3060 -3030
  177. package/src/collection-facets/models.ts +10 -10
  178. package/src/collection-facets/more-facets-content.ts +639 -639
  179. package/src/collection-facets.ts +1 -1
  180. package/src/combo-box/caret-closed.ts +5 -11
  181. package/src/combo-box/caret-open.ts +5 -11
  182. package/src/combo-box/clear.ts +11 -0
  183. package/src/combo-box/ia-combo-box.ts +1288 -1180
  184. package/src/combo-box/models.ts +31 -1
  185. package/src/manage/manage-bar.ts +247 -247
  186. package/src/restoration-state-handler.ts +5 -1
  187. package/src/tiles/base-tile-component.ts +65 -65
  188. package/src/tiles/grid/account-tile.ts +113 -113
  189. package/src/tiles/grid/collection-tile.ts +163 -163
  190. package/src/tiles/grid/item-tile.ts +340 -340
  191. package/src/tiles/grid/search-tile.ts +90 -90
  192. package/src/tiles/grid/styles/tile-grid-shared-styles.ts +130 -130
  193. package/src/tiles/hover/hover-pane-controller.ts +613 -613
  194. package/src/tiles/hover/tile-hover-pane.ts +184 -184
  195. package/src/tiles/list/tile-list-compact.ts +239 -239
  196. package/src/tiles/list/tile-list.ts +700 -700
  197. package/src/tiles/tile-dispatcher.ts +517 -517
  198. package/src/utils/format-date.ts +62 -62
  199. package/test/collection-facets/facet-row.test.ts +375 -375
  200. package/test/collection-facets.test.ts +928 -928
  201. package/test/tiles/grid/item-tile.test.ts +520 -520
  202. package/test/tiles/hover/hover-pane-controller.test.ts +418 -418
  203. package/test/tiles/list/tile-list-compact.test.ts +282 -282
  204. package/test/tiles/list/tile-list.test.ts +552 -552
  205. package/test/tiles/tile-dispatcher.test.ts +283 -283
  206. package/test/utils/format-date.test.ts +89 -89
  207. package/tsconfig.json +8 -3
  208. package/vite.config.ts +29 -22
@@ -1 +1 @@
1
- {"version":3,"file":"language-code-handler.js","sourceRoot":"","sources":["../../../src/language-code-handler/language-code-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAqC5D,MAAM,OAAO,mBAAmB;IAAhC;QACU,cAAS,GAAG,GAAG,CAAC;IAyB1B,CAAC;IAvBC,kBAAkB;IAClB,6BAA6B,CAAC,aAAqB;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,CAAC;QAC7D,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAClC,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,YAAY,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;QACrD,OAAO,YAAY,aAAZ,YAAY,cAAZ,YAAY,GAAI,aAAa,CAAC;IACvC,CAAC;IAED,kBAAkB;IAClB,6BAA6B,CAAC,YAAoB;QAChD,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,MAAM,CACzD,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,YAAY,CACjD,CAAC;QACF,MAAM,gBAAgB,GAAG,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7D,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,kBAAkB;IAClB,0BAA0B,CAAC,aAAqB;QAC9C,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClD,OAAO,KAAK,CAAC;IACf,CAAC;CACF","sourcesContent":["import { codeToLanguageMap } from './language-code-mapping';\n\n// To serialize the list of potential language codes, we store\n// the string in the format `en-us|en|en-gb` with `|` being the separator.\n// This allows us to generate a query of `language:(en-us OR en OR en-gb)`\n// when we deserialize the string.\nexport interface LanguageCodeHandlerInterface {\n /**\n * This takes a list of codes in the format `en-us|en|en-gb` and\n * returns the first language code in the list.\n *\n * The codes in the string should always represent the same language name.\n * eg `en-us`, `en-gb`, and `en` should always be \"English\"\n *\n * @param languageCodes\n */\n getLanguageNameFromCodeString(languageCodes: string): string;\n\n /**\n * This creates a serialized string of language codes for the given language.\n *\n * eg. `English` becomes `en-us|en|en-gb|.....`\n *\n * @param languageName\n */\n getCodeStringFromLanguageName(languageName: string): string;\n\n /**\n * Get an array of langauge codes from a serialized string.\n *\n * eg. `en-us|en|en-gb` becomes `['en-us', 'en', 'en-gb']`\n *\n * @param languageCodes\n */\n getCodeArrayFromCodeString(languageCodes: string): string[];\n}\n\nexport class LanguageCodeHandler implements LanguageCodeHandlerInterface {\n private delimeter = '|';\n\n /** @inheritdoc */\n getLanguageNameFromCodeString(languageCodes: string): string {\n const split = this.getCodeArrayFromCodeString(languageCodes);\n if (split.length === 0) return '';\n const languageCode = split[0];\n const languageName = codeToLanguageMap[languageCode];\n return languageName ?? languageCodes;\n }\n\n /** @inheritdoc */\n getCodeStringFromLanguageName(languageName: string): string {\n const languageCodes = Object.keys(codeToLanguageMap).filter(\n code => codeToLanguageMap[code] === languageName,\n );\n const stringifiedCodes = languageCodes?.join(this.delimeter);\n return stringifiedCodes;\n }\n\n /** @inheritdoc */\n getCodeArrayFromCodeString(languageCodes: string): string[] {\n const split = languageCodes.split(this.delimeter);\n return split;\n }\n}\n"]}
1
+ {"version":3,"file":"language-code-handler.js","sourceRoot":"","sources":["../../../src/language-code-handler/language-code-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAqC5D,MAAM,OAAO,mBAAmB;IAAhC;QACU,cAAS,GAAG,GAAG,CAAC;IAyB1B,CAAC;IAvBC,kBAAkB;IAClB,6BAA6B,CAAC,aAAqB;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,CAAC;QAC7D,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAClC,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,YAAY,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;QACrD,OAAO,YAAY,IAAI,aAAa,CAAC;IACvC,CAAC;IAED,kBAAkB;IAClB,6BAA6B,CAAC,YAAoB;QAChD,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,MAAM,CACzD,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,YAAY,CACjD,CAAC;QACF,MAAM,gBAAgB,GAAG,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7D,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,kBAAkB;IAClB,0BAA0B,CAAC,aAAqB;QAC9C,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClD,OAAO,KAAK,CAAC;IACf,CAAC;CACF","sourcesContent":["import { codeToLanguageMap } from './language-code-mapping';\n\n// To serialize the list of potential language codes, we store\n// the string in the format `en-us|en|en-gb` with `|` being the separator.\n// This allows us to generate a query of `language:(en-us OR en OR en-gb)`\n// when we deserialize the string.\nexport interface LanguageCodeHandlerInterface {\n /**\n * This takes a list of codes in the format `en-us|en|en-gb` and\n * returns the first language code in the list.\n *\n * The codes in the string should always represent the same language name.\n * eg `en-us`, `en-gb`, and `en` should always be \"English\"\n *\n * @param languageCodes\n */\n getLanguageNameFromCodeString(languageCodes: string): string;\n\n /**\n * This creates a serialized string of language codes for the given language.\n *\n * eg. `English` becomes `en-us|en|en-gb|.....`\n *\n * @param languageName\n */\n getCodeStringFromLanguageName(languageName: string): string;\n\n /**\n * Get an array of langauge codes from a serialized string.\n *\n * eg. `en-us|en|en-gb` becomes `['en-us', 'en', 'en-gb']`\n *\n * @param languageCodes\n */\n getCodeArrayFromCodeString(languageCodes: string): string[];\n}\n\nexport class LanguageCodeHandler implements LanguageCodeHandlerInterface {\n private delimeter = '|';\n\n /** @inheritdoc */\n getLanguageNameFromCodeString(languageCodes: string): string {\n const split = this.getCodeArrayFromCodeString(languageCodes);\n if (split.length === 0) return '';\n const languageCode = split[0];\n const languageName = codeToLanguageMap[languageCode];\n return languageName ?? languageCodes;\n }\n\n /** @inheritdoc */\n getCodeStringFromLanguageName(languageName: string): string {\n const languageCodes = Object.keys(codeToLanguageMap).filter(\n code => codeToLanguageMap[code] === languageName,\n );\n const stringifiedCodes = languageCodes?.join(this.delimeter);\n return stringifiedCodes;\n }\n\n /** @inheritdoc */\n getCodeArrayFromCodeString(languageCodes: string): string[] {\n const split = languageCodes.split(this.delimeter);\n return split;\n }\n}\n"]}
@@ -35,43 +35,43 @@ let ManageBar = class ManageBar extends LitElement {
35
35
  this.removeAllowed = false;
36
36
  }
37
37
  render() {
38
- return html `
39
- <div class="manage-container">
40
- <span class="manage-label">${this.label}</span>
41
- <div class="manage-buttons">
42
- <button class="ia-button dark" @click=${this.cancelClicked}>
43
- ${msg('Cancel')}
44
- </button>
45
- <button
46
- class="ia-button danger"
47
- ?disabled=${!this.removeAllowed}
48
- @click=${this.showRemoveItemsModal}
49
- >
50
- ${msg('Remove selected items')} (${this.selectedItems.length})...
51
- </button>
52
- ${when(this.showItemManageButton, () => html ` <button
53
- class="ia-button warning"
54
- ?disabled=${!this.removeAllowed}
55
- @click=${this.manageItemsClicked}
56
- >
57
- ${msg('Item Manager the items')} (${this.selectedItems.length})
58
- </button>`)}
59
- <div class="selection-buttons">
60
- ${when(this.showSelectAll, () => html ` <button
61
- class="ia-button link select-all-btn"
62
- @click=${this.selectAllClicked}
63
- >
64
- ${msg('Select all')}
65
- </button>`)}
66
- ${when(this.showUnselectAll, () => html ` <button
67
- class="ia-button link unselect-all-btn"
68
- @click=${this.unselectAllClicked}
69
- >
70
- ${msg('Unselect all')}
71
- </button>`)}
72
- </div>
73
- </div>
74
- </div>
38
+ return html `
39
+ <div class="manage-container">
40
+ <span class="manage-label">${this.label}</span>
41
+ <div class="manage-buttons">
42
+ <button class="ia-button dark" @click=${this.cancelClicked}>
43
+ ${msg('Cancel')}
44
+ </button>
45
+ <button
46
+ class="ia-button danger"
47
+ ?disabled=${!this.removeAllowed}
48
+ @click=${this.showRemoveItemsModal}
49
+ >
50
+ ${msg('Remove selected items')} (${this.selectedItems.length})...
51
+ </button>
52
+ ${when(this.showItemManageButton, () => html ` <button
53
+ class="ia-button warning"
54
+ ?disabled=${!this.removeAllowed}
55
+ @click=${this.manageItemsClicked}
56
+ >
57
+ ${msg('Item Manager the items')} (${this.selectedItems.length})
58
+ </button>`)}
59
+ <div class="selection-buttons">
60
+ ${when(this.showSelectAll, () => html ` <button
61
+ class="ia-button link select-all-btn"
62
+ @click=${this.selectAllClicked}
63
+ >
64
+ ${msg('Select all')}
65
+ </button>`)}
66
+ ${when(this.showUnselectAll, () => html ` <button
67
+ class="ia-button link unselect-all-btn"
68
+ @click=${this.unselectAllClicked}
69
+ >
70
+ ${msg('Unselect all')}
71
+ </button>`)}
72
+ </div>
73
+ </div>
74
+ </div>
75
75
  `;
76
76
  }
77
77
  cancelClicked() {
@@ -94,13 +94,12 @@ let ManageBar = class ManageBar extends LitElement {
94
94
  * @param items Which items to list in the modal
95
95
  */
96
96
  showRemoveItemsModal() {
97
- var _a, _b;
98
- const customModalContent = html `
99
- <remove-items-modal-content
100
- .items=${this.selectedItems}
101
- .message=${this.manageViewModalMsg}
102
- @confirm=${() => this.removeItemsClicked()}
103
- ></remove-items-modal-content>
97
+ const customModalContent = html `
98
+ <remove-items-modal-content
99
+ .items=${this.selectedItems}
100
+ .message=${this.manageViewModalMsg}
101
+ @confirm=${() => this.removeItemsClicked()}
102
+ ></remove-items-modal-content>
104
103
  `;
105
104
  const config = new ModalConfig({
106
105
  showProcessingIndicator: false,
@@ -111,13 +110,12 @@ let ManageBar = class ManageBar extends LitElement {
111
110
  closeOnBackdropClick: true,
112
111
  title: html `${msg('Are you sure you want to remove these items?')}`,
113
112
  });
114
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
115
- (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
113
+ this.modalManager?.classList.add('remove-items');
114
+ this.modalManager?.showModal({
116
115
  config,
117
116
  customModalContent,
118
117
  userClosedModalCallback: () => {
119
- var _a;
120
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
118
+ this.modalManager?.classList.remove('remove-items');
121
119
  },
122
120
  });
123
121
  }
@@ -125,7 +123,6 @@ let ManageBar = class ManageBar extends LitElement {
125
123
  * Shows a modal dialog indicating that item removal is being processed
126
124
  */
127
125
  showRemoveItemsProcessingModal() {
128
- var _a, _b;
129
126
  const config = new ModalConfig({
130
127
  showProcessingIndicator: true,
131
128
  processingImageMode: 'processing',
@@ -135,12 +132,11 @@ let ManageBar = class ManageBar extends LitElement {
135
132
  closeOnBackdropClick: true,
136
133
  title: html `${msg('Removing selected items...')}`,
137
134
  });
138
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
139
- (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
135
+ this.modalManager?.classList.add('remove-items');
136
+ this.modalManager?.showModal({
140
137
  config,
141
138
  userClosedModalCallback: () => {
142
- var _a;
143
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
139
+ this.modalManager?.classList.remove('remove-items');
144
140
  },
145
141
  });
146
142
  }
@@ -148,7 +144,6 @@ let ManageBar = class ManageBar extends LitElement {
148
144
  * Shows a modal dialog indicating that an error occurred while removing items
149
145
  */
150
146
  showRemoveItemsErrorModal() {
151
- var _a, _b;
152
147
  const config = new ModalConfig({
153
148
  showProcessingIndicator: false,
154
149
  processingImageMode: 'processing',
@@ -159,50 +154,49 @@ let ManageBar = class ManageBar extends LitElement {
159
154
  title: html `${msg('Error: unable to remove items')}`,
160
155
  message: html `${msg('An error occurred while removing items. Please try again in a few minutes.')}`,
161
156
  });
162
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.add('remove-items');
163
- (_b = this.modalManager) === null || _b === void 0 ? void 0 : _b.showModal({
157
+ this.modalManager?.classList.add('remove-items');
158
+ this.modalManager?.showModal({
164
159
  config,
165
160
  userClosedModalCallback: () => {
166
- var _a;
167
- (_a = this.modalManager) === null || _a === void 0 ? void 0 : _a.classList.remove('remove-items');
161
+ this.modalManager?.classList.remove('remove-items');
168
162
  },
169
163
  });
170
164
  }
171
165
  static get styles() {
172
- return css `
173
- ${iaButtonStyle}
174
- .manage-container {
175
- display: flex;
176
- align-items: center;
177
- column-gap: 5px;
178
- padding: 20px 0 20px;
179
- flex-wrap: wrap;
180
- }
181
-
182
- .manage-label {
183
- display: inline-block;
184
- font-weight: bold;
185
- font-size: 1.8rem;
186
- padding-right: 10px;
187
- }
188
-
189
- .manage-buttons {
190
- display: flex;
191
- flex-wrap: wrap;
192
- align-items: center;
193
- column-gap: 5px;
194
- }
195
-
196
- .selection-buttons {
197
- display: inherit;
198
- }
199
-
200
- .ia-button,
201
- button {
202
- padding: 6px 12px;
203
- font-size: 1.4rem;
204
- margin: 3px 0;
205
- }
166
+ return css `
167
+ ${iaButtonStyle}
168
+ .manage-container {
169
+ display: flex;
170
+ align-items: center;
171
+ column-gap: 5px;
172
+ padding: 20px 0 20px;
173
+ flex-wrap: wrap;
174
+ }
175
+
176
+ .manage-label {
177
+ display: inline-block;
178
+ font-weight: bold;
179
+ font-size: 1.8rem;
180
+ padding-right: 10px;
181
+ }
182
+
183
+ .manage-buttons {
184
+ display: flex;
185
+ flex-wrap: wrap;
186
+ align-items: center;
187
+ column-gap: 5px;
188
+ }
189
+
190
+ .selection-buttons {
191
+ display: inherit;
192
+ }
193
+
194
+ .ia-button,
195
+ button {
196
+ padding: 6px 12px;
197
+ font-size: 1.4rem;
198
+ margin: 3px 0;
199
+ }
206
200
  `;
207
201
  }
208
202
  };
@@ -1 +1 @@
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';\r\nimport { LitElement, html, css, TemplateResult, CSSResultGroup } from 'lit';\r\nimport { customElement, property } from 'lit/decorators.js';\r\nimport { when } from 'lit/directives/when.js';\r\nimport {\r\n ModalConfig,\r\n type ModalManagerInterface,\r\n} from '@internetarchive/modal-manager';\r\nimport type { ManageableItem } from '../models';\r\nimport iaButtonStyle from '../styles/ia-button';\r\nimport './remove-items-modal-content';\r\n\r\n@customElement('manage-bar')\r\nexport class ManageBar extends LitElement {\r\n /**\r\n * The label displayed in front of the management buttons\r\n */\r\n @property({ type: String }) label = msg('Select items to remove');\r\n\r\n /**\r\n * The shared modal manager component for displaying modal dialogs on this page\r\n */\r\n @property({ type: Object }) modalManager?: ModalManagerInterface;\r\n\r\n /**\r\n * Array of items that have been selected for management\r\n */\r\n @property({ type: Object }) selectedItems: Array<ManageableItem> = [];\r\n\r\n /**\r\n * Message shows as note in the modal when removing items\r\n */\r\n @property({ type: String }) manageViewModalMsg?: string;\r\n\r\n /**\r\n * Whether to show the \"Select All\" button (default false)\r\n */\r\n @property({ type: Boolean }) showSelectAll = false;\r\n\r\n /**\r\n * Whether to show the \"Unselect All\" button (default false)\r\n */\r\n @property({ type: Boolean }) showUnselectAll = false;\r\n\r\n /**\r\n * Whether to show \"Item Manager the items\" button (default false)\r\n */\r\n @property({ type: Boolean }) showItemManageButton = false;\r\n\r\n /**\r\n * Whether to active delete button for selectable items\r\n */\r\n @property({ type: Boolean }) removeAllowed = false;\r\n\r\n render(): TemplateResult {\r\n return html`\r\n <div class=\"manage-container\">\r\n <span class=\"manage-label\">${this.label}</span>\r\n <div class=\"manage-buttons\">\r\n <button class=\"ia-button dark\" @click=${this.cancelClicked}>\r\n ${msg('Cancel')}\r\n </button>\r\n <button\r\n class=\"ia-button danger\"\r\n ?disabled=${!this.removeAllowed}\r\n @click=${this.showRemoveItemsModal}\r\n >\r\n ${msg('Remove selected items')} (${this.selectedItems.length})...\r\n </button>\r\n ${when(\r\n this.showItemManageButton,\r\n () =>\r\n html` <button\r\n class=\"ia-button warning\"\r\n ?disabled=${!this.removeAllowed}\r\n @click=${this.manageItemsClicked}\r\n >\r\n ${msg('Item Manager the items')} (${this.selectedItems.length})\r\n </button>`,\r\n )}\r\n <div class=\"selection-buttons\">\r\n ${when(\r\n this.showSelectAll,\r\n () =>\r\n html` <button\r\n class=\"ia-button link select-all-btn\"\r\n @click=${this.selectAllClicked}\r\n >\r\n ${msg('Select all')}\r\n </button>`,\r\n )}\r\n ${when(\r\n this.showUnselectAll,\r\n () =>\r\n html` <button\r\n class=\"ia-button link unselect-all-btn\"\r\n @click=${this.unselectAllClicked}\r\n >\r\n ${msg('Unselect all')}\r\n </button>`,\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n `;\r\n }\r\n\r\n private cancelClicked(): void {\r\n this.dispatchEvent(new CustomEvent('cancel'));\r\n }\r\n\r\n private removeItemsClicked(): void {\r\n this.dispatchEvent(new CustomEvent('removeItems'));\r\n }\r\n\r\n private manageItemsClicked(): void {\r\n this.dispatchEvent(new CustomEvent('manageItems'));\r\n }\r\n\r\n private selectAllClicked(): void {\r\n this.dispatchEvent(new CustomEvent('selectAll'));\r\n }\r\n\r\n private unselectAllClicked(): void {\r\n this.dispatchEvent(new CustomEvent('unselectAll'));\r\n }\r\n\r\n /**\r\n * Shows a modal dialog confirming the list of items to be removed\r\n * @param items Which items to list in the modal\r\n */\r\n private showRemoveItemsModal(): void {\r\n const customModalContent = html`\r\n <remove-items-modal-content\r\n .items=${this.selectedItems}\r\n .message=${this.manageViewModalMsg}\r\n @confirm=${() => this.removeItemsClicked()}\r\n ></remove-items-modal-content>\r\n `;\r\n\r\n const config = new ModalConfig({\r\n showProcessingIndicator: false,\r\n processingImageMode: 'processing',\r\n bodyColor: '#fff',\r\n headerColor: '#194880',\r\n showHeaderLogo: false,\r\n closeOnBackdropClick: true,\r\n title: html`${msg('Are you sure you want to remove these items?')}`,\r\n });\r\n\r\n this.modalManager?.classList.add('remove-items');\r\n this.modalManager?.showModal({\r\n config,\r\n customModalContent,\r\n userClosedModalCallback: () => {\r\n this.modalManager?.classList.remove('remove-items');\r\n },\r\n });\r\n }\r\n\r\n /**\r\n * Shows a modal dialog indicating that item removal is being processed\r\n */\r\n showRemoveItemsProcessingModal(): void {\r\n const config = new ModalConfig({\r\n showProcessingIndicator: true,\r\n processingImageMode: 'processing',\r\n bodyColor: '#fff',\r\n headerColor: '#194880',\r\n showHeaderLogo: false,\r\n closeOnBackdropClick: true,\r\n title: html`${msg('Removing selected items...')}`,\r\n });\r\n\r\n this.modalManager?.classList.add('remove-items');\r\n this.modalManager?.showModal({\r\n config,\r\n userClosedModalCallback: () => {\r\n this.modalManager?.classList.remove('remove-items');\r\n },\r\n });\r\n }\r\n\r\n /**\r\n * Shows a modal dialog indicating that an error occurred while removing items\r\n */\r\n showRemoveItemsErrorModal(): void {\r\n const config = new ModalConfig({\r\n showProcessingIndicator: false,\r\n processingImageMode: 'processing',\r\n bodyColor: '#fff',\r\n headerColor: '#691916',\r\n showHeaderLogo: false,\r\n closeOnBackdropClick: true,\r\n title: html`${msg('Error: unable to remove items')}`,\r\n message: html`${msg(\r\n 'An error occurred while removing items. Please try again in a few minutes.',\r\n )}`,\r\n });\r\n\r\n this.modalManager?.classList.add('remove-items');\r\n this.modalManager?.showModal({\r\n config,\r\n userClosedModalCallback: () => {\r\n this.modalManager?.classList.remove('remove-items');\r\n },\r\n });\r\n }\r\n\r\n static get styles(): CSSResultGroup {\r\n return css`\r\n ${iaButtonStyle}\r\n .manage-container {\r\n display: flex;\r\n align-items: center;\r\n column-gap: 5px;\r\n padding: 20px 0 20px;\r\n flex-wrap: wrap;\r\n }\r\n\r\n .manage-label {\r\n display: inline-block;\r\n font-weight: bold;\r\n font-size: 1.8rem;\r\n padding-right: 10px;\r\n }\r\n\r\n .manage-buttons {\r\n display: flex;\r\n flex-wrap: wrap;\r\n align-items: center;\r\n column-gap: 5px;\r\n }\r\n\r\n .selection-buttons {\r\n display: inherit;\r\n }\r\n\r\n .ia-button,\r\n button {\r\n padding: 6px 12px;\r\n font-size: 1.4rem;\r\n margin: 3px 0;\r\n }\r\n `;\r\n }\r\n}\r\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 { LitElement, html, css, TemplateResult, CSSResultGroup } 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 type { ManageableItem } from '../models';\nimport iaButtonStyle from '../styles/ia-button';\nimport './remove-items-modal-content';\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 * 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 * Message shows as note in the modal when removing items\n */\n @property({ type: String }) manageViewModalMsg?: string;\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 show \"Item Manager the items\" button (default false)\n */\n @property({ type: Boolean }) showItemManageButton = 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.showRemoveItemsModal}\n >\n ${msg('Remove selected items')} (${this.selectedItems.length})...\n </button>\n ${when(\n this.showItemManageButton,\n () =>\n html` <button\n class=\"ia-button warning\"\n ?disabled=${!this.removeAllowed}\n @click=${this.manageItemsClicked}\n >\n ${msg('Item Manager the items')} (${this.selectedItems.length})\n </button>`,\n )}\n <div class=\"selection-buttons\">\n ${when(\n this.showSelectAll,\n () =>\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 () =>\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 private removeItemsClicked(): void {\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 customModalContent = html`\n <remove-items-modal-content\n .items=${this.selectedItems}\n .message=${this.manageViewModalMsg}\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 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 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"]}
@@ -13,8 +13,8 @@ let RemoveItemsModalContent = class RemoveItemsModalContent extends LitElement {
13
13
  <ul>
14
14
  ${map(this.items, ({ title, date }) => html `
15
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>
16
+ <span class="item-title">${title ?? '[untitled]'}</span>
17
+ <span class="item-date">${date ?? ''}</span>
18
18
  </li>
19
19
  `)}
20
20
  </ul>
@@ -1 +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;AAIrC,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,UAAU;IAAhD;;QACuB,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","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';\nimport type { ManageableItem } from '../models';\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
+ {"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;AAIrC,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,UAAU;IAAhD;;QACuB,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,IAAI,YAAY;wCACtB,IAAI,IAAI,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","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';\nimport type { ManageableItem } from '../models';\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"]}
@@ -17,43 +17,42 @@ export const TILE_OVERLAY_ICONS = {
17
17
  */
18
18
  export class TileModel {
19
19
  constructor(result, hitRequestSource = 'unknown') {
20
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18;
21
20
  const flags = this.getFlags(result);
22
- this.adIds = (_a = result.ad_id) === null || _a === void 0 ? void 0 : _a.values;
23
- this.averageRating = (_b = result.avg_rating) === null || _b === void 0 ? void 0 : _b.value;
24
- this.captureDates = (_c = result.capture_dates) === null || _c === void 0 ? void 0 : _c.values;
21
+ this.adIds = result.ad_id?.values;
22
+ this.averageRating = result.avg_rating?.value;
23
+ this.captureDates = result.capture_dates?.values;
25
24
  this.checked = false;
26
- this.collections = (_e = (_d = result.collection) === null || _d === void 0 ? void 0 : _d.values) !== null && _e !== void 0 ? _e : [];
27
- this.collectionFilesCount = (_g = (_f = result.collection_files_count) === null || _f === void 0 ? void 0 : _f.value) !== null && _g !== void 0 ? _g : 0;
28
- this.collectionSize = (_j = (_h = result.collection_size) === null || _h === void 0 ? void 0 : _h.value) !== null && _j !== void 0 ? _j : 0;
29
- this.commentCount = (_l = (_k = result.num_reviews) === null || _k === void 0 ? void 0 : _k.value) !== null && _l !== void 0 ? _l : 0;
30
- this.creator = (_m = result.creator) === null || _m === void 0 ? void 0 : _m.value;
31
- this.creators = (_p = (_o = result.creator) === null || _o === void 0 ? void 0 : _o.values) !== null && _p !== void 0 ? _p : [];
32
- this.dateAdded = (_q = result.addeddate) === null || _q === void 0 ? void 0 : _q.value;
33
- this.dateArchived = (_r = result.publicdate) === null || _r === void 0 ? void 0 : _r.value;
34
- this.datePublished = (_s = result.date) === null || _s === void 0 ? void 0 : _s.value;
35
- this.dateReviewed = (_t = result.reviewdate) === null || _t === void 0 ? void 0 : _t.value;
36
- this.description = (_u = result.description) === null || _u === void 0 ? void 0 : _u.values.join('\n');
37
- this.factChecks = (_v = result.factcheck) === null || _v === void 0 ? void 0 : _v.values;
38
- this.favCount = (_x = (_w = result.num_favorites) === null || _w === void 0 ? void 0 : _w.value) !== null && _x !== void 0 ? _x : 0;
25
+ this.collections = result.collection?.values ?? [];
26
+ this.collectionFilesCount = result.collection_files_count?.value ?? 0;
27
+ this.collectionSize = result.collection_size?.value ?? 0;
28
+ this.commentCount = result.num_reviews?.value ?? 0;
29
+ this.creator = result.creator?.value;
30
+ this.creators = result.creator?.values ?? [];
31
+ this.dateAdded = result.addeddate?.value;
32
+ this.dateArchived = result.publicdate?.value;
33
+ this.datePublished = result.date?.value;
34
+ this.dateReviewed = result.reviewdate?.value;
35
+ this.description = result.description?.values.join('\n');
36
+ this.factChecks = result.factcheck?.values;
37
+ this.favCount = result.num_favorites?.value ?? 0;
39
38
  this.hitRequestSource = hitRequestSource;
40
- this.hitType = (_y = result.rawMetadata) === null || _y === void 0 ? void 0 : _y.hit_type;
41
- this.href = collapseRepeatedQuotes((_0 = (_z = result.review) === null || _z === void 0 ? void 0 : _z.__href__) !== null && _0 !== void 0 ? _0 : (_1 = result.__href__) === null || _1 === void 0 ? void 0 : _1.value);
39
+ this.hitType = result.rawMetadata?.hit_type;
40
+ this.href = collapseRepeatedQuotes(result.review?.__href__ ?? result.__href__?.value);
42
41
  this.identifier = TileModel.cleanIdentifier(result.identifier);
43
- this.isClip = (_2 = result.is_clip) === null || _2 === void 0 ? void 0 : _2.value;
44
- this.issue = (_3 = result.issue) === null || _3 === void 0 ? void 0 : _3.value;
45
- this.itemCount = (_5 = (_4 = result.item_count) === null || _4 === void 0 ? void 0 : _4.value) !== null && _5 !== void 0 ? _5 : 0;
42
+ this.isClip = result.is_clip?.value;
43
+ this.issue = result.issue?.value;
44
+ this.itemCount = result.item_count?.value ?? 0;
46
45
  this.mediatype = resolveMediatype(result);
47
46
  this.review = result.review;
48
- this.snippets = (_7 = (_6 = result.highlight) === null || _6 === void 0 ? void 0 : _6.values) !== null && _7 !== void 0 ? _7 : [];
49
- this.source = (_8 = result.source) === null || _8 === void 0 ? void 0 : _8.value;
50
- this.subjects = (_10 = (_9 = result.subject) === null || _9 === void 0 ? void 0 : _9.values) !== null && _10 !== void 0 ? _10 : [];
51
- this.thumbnailUrl = (_11 = result.__img__) === null || _11 === void 0 ? void 0 : _11.value;
52
- this.title = (_13 = (_12 = result.title) === null || _12 === void 0 ? void 0 : _12.value) !== null && _13 !== void 0 ? _13 : '';
53
- this.tvClipCount = (_15 = (_14 = result.num_clips) === null || _14 === void 0 ? void 0 : _14.value) !== null && _15 !== void 0 ? _15 : 0;
54
- this.volume = (_16 = result.volume) === null || _16 === void 0 ? void 0 : _16.value;
55
- this.viewCount = (_17 = result.downloads) === null || _17 === void 0 ? void 0 : _17.value;
56
- this.weeklyViewCount = (_18 = result.week) === null || _18 === void 0 ? void 0 : _18.value;
47
+ this.snippets = result.highlight?.values ?? [];
48
+ this.source = result.source?.value;
49
+ this.subjects = result.subject?.values ?? [];
50
+ this.thumbnailUrl = result.__img__?.value;
51
+ this.title = result.title?.value ?? '';
52
+ this.tvClipCount = result.num_clips?.value ?? 0;
53
+ this.volume = result.volume?.value;
54
+ this.viewCount = result.downloads?.value;
55
+ this.weeklyViewCount = result.week?.value;
57
56
  this.loginRequired = flags.loginRequired;
58
57
  this.contentWarning = flags.contentWarning;
59
58
  }
@@ -112,15 +111,14 @@ export class TileModel {
112
111
  * (login required and/or content warning)
113
112
  */
114
113
  getFlags(result) {
115
- var _a, _b, _c, _d;
116
114
  const flags = {
117
115
  loginRequired: false,
118
116
  contentWarning: false,
119
117
  };
120
118
  // Check if item and item in "modifying" collection, setting above flags
121
- if (((_a = result.collection) === null || _a === void 0 ? void 0 : _a.values.length) &&
122
- ((_b = result.mediatype) === null || _b === void 0 ? void 0 : _b.value) !== 'collection') {
123
- for (const collection of (_d = (_c = result.collection) === null || _c === void 0 ? void 0 : _c.values) !== null && _d !== void 0 ? _d : []) {
119
+ if (result.collection?.values.length &&
120
+ result.mediatype?.value !== 'collection') {
121
+ for (const collection of result.collection?.values ?? []) {
124
122
  if (collection === 'loggedin') {
125
123
  flags.loginRequired = true;
126
124
  if (flags.contentWarning)
@@ -136,12 +134,11 @@ export class TileModel {
136
134
  return flags;
137
135
  }
138
136
  static cleanIdentifier(identifier) {
139
- var _a;
140
137
  // Some identifiers (e.g., from Whisper) represent documents rather than items, and
141
138
  // are suffixed with values that need to be stripped. Those values are separated
142
139
  // from the item identifier itself with '|'.
143
- const barIndex = (_a = identifier === null || identifier === void 0 ? void 0 : identifier.indexOf('|')) !== null && _a !== void 0 ? _a : -1;
144
- const cleaned = barIndex > 0 ? identifier === null || identifier === void 0 ? void 0 : identifier.slice(0, barIndex) : identifier;
140
+ const barIndex = identifier?.indexOf('|') ?? -1;
141
+ const cleaned = barIndex > 0 ? identifier?.slice(0, barIndex) : identifier;
145
142
  return cleaned;
146
143
  }
147
144
  }
@@ -330,8 +327,7 @@ export const SORT_OPTIONS = {
330
327
  * the "unrecognized" SortOption if none matches.
331
328
  */
332
329
  export function sortOptionFromAPIString(sortName) {
333
- var _a;
334
- return ((_a = Object.values(SORT_OPTIONS).find(opt => opt.urlNames.some(name => sortName === name))) !== null && _a !== void 0 ? _a : SORT_OPTIONS[SortField.unrecognized]);
330
+ return (Object.values(SORT_OPTIONS).find(opt => opt.urlNames.some(name => sortName === name)) ?? SORT_OPTIONS[SortField.unrecognized]);
335
331
  }
336
332
  export const defaultSortAvailability = {
337
333
  [SortField.relevance]: true,