@internetarchive/collection-browser 0.0.1-alpha.9 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (184) hide show
  1. package/README.md +8 -11
  2. package/demo/app-root.ts +16 -92
  3. package/dist/demo/app-root.d.ts +3 -5
  4. package/dist/demo/app-root.js +13 -83
  5. package/dist/demo/app-root.js.map +1 -1
  6. package/dist/index.d.ts +6 -0
  7. package/dist/index.js +6 -0
  8. package/dist/index.js.map +1 -1
  9. package/dist/src/assets/img/icons/chevron.d.ts +2 -0
  10. package/dist/src/assets/img/icons/chevron.js +4 -0
  11. package/dist/src/assets/img/icons/chevron.js.map +1 -0
  12. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -2
  13. package/dist/src/assets/img/icons/mediatype/account.js +6 -4
  14. package/dist/src/assets/img/icons/mediatype/account.js.map +1 -1
  15. package/dist/src/assets/img/icons/mediatype/audio.js +7 -4
  16. package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -1
  17. package/dist/src/assets/img/icons/mediatype/collection.js +7 -4
  18. package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -1
  19. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -0
  20. package/dist/src/assets/img/icons/mediatype/data.js +15 -0
  21. package/dist/src/assets/img/icons/mediatype/data.js.map +1 -0
  22. package/dist/src/assets/img/icons/mediatype/etree.js +10 -5
  23. package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -1
  24. package/dist/src/assets/img/icons/mediatype/film.js +2 -1
  25. package/dist/src/assets/img/icons/mediatype/film.js.map +1 -1
  26. package/dist/src/assets/img/icons/mediatype/images.js +9 -6
  27. package/dist/src/assets/img/icons/mediatype/images.js.map +1 -1
  28. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -0
  29. package/dist/src/assets/img/icons/mediatype/radio.js +15 -0
  30. package/dist/src/assets/img/icons/mediatype/radio.js.map +1 -0
  31. package/dist/src/assets/img/icons/mediatype/software.js +9 -6
  32. package/dist/src/assets/img/icons/mediatype/software.js.map +1 -1
  33. package/dist/src/assets/img/icons/mediatype/texts.js +9 -6
  34. package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -1
  35. package/dist/src/assets/img/icons/mediatype/tv.js +10 -5
  36. package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -1
  37. package/dist/src/assets/img/icons/mediatype/video.js +10 -6
  38. package/dist/src/assets/img/icons/mediatype/video.js.map +1 -1
  39. package/dist/src/assets/img/icons/mediatype/web.js +9 -6
  40. package/dist/src/assets/img/icons/mediatype/web.js.map +1 -1
  41. package/dist/src/collection-browser.d.ts +53 -31
  42. package/dist/src/collection-browser.js +504 -166
  43. package/dist/src/collection-browser.js.map +1 -1
  44. package/dist/src/collection-facets.d.ts +28 -13
  45. package/dist/src/collection-facets.js +276 -160
  46. package/dist/src/collection-facets.js.map +1 -1
  47. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -0
  48. package/dist/src/language-code-handler/language-code-handler.js +27 -0
  49. package/dist/src/language-code-handler/language-code-handler.js.map +1 -0
  50. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -0
  51. package/dist/src/language-code-handler/language-code-mapping.js +563 -0
  52. package/dist/src/language-code-handler/language-code-mapping.js.map +1 -0
  53. package/dist/src/mediatype/mediatype-config.d.ts +3 -0
  54. package/dist/src/mediatype/mediatype-config.js +86 -0
  55. package/dist/src/mediatype/mediatype-config.js.map +1 -0
  56. package/dist/src/models.d.ts +72 -13
  57. package/dist/src/models.js +57 -1
  58. package/dist/src/models.js.map +1 -1
  59. package/dist/src/restoration-state-handler.d.ts +38 -0
  60. package/dist/src/restoration-state-handler.js +204 -0
  61. package/dist/src/restoration-state-handler.js.map +1 -0
  62. package/dist/src/sort-filter-bar/alpha-bar.d.ts +1 -1
  63. package/dist/src/sort-filter-bar/alpha-bar.js +9 -2
  64. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
  65. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -0
  66. package/dist/src/sort-filter-bar/img/compact.js +5 -0
  67. package/dist/src/sort-filter-bar/img/compact.js.map +1 -0
  68. package/dist/src/sort-filter-bar/img/list.js +1 -1
  69. package/dist/src/sort-filter-bar/img/list.js.map +1 -1
  70. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -0
  71. package/dist/src/sort-filter-bar/img/tile.js +5 -0
  72. package/dist/src/sort-filter-bar/img/tile.js.map +1 -0
  73. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +71 -14
  74. package/dist/src/sort-filter-bar/sort-filter-bar.js +499 -216
  75. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  76. package/dist/src/tiles/{loading-tile.d.ts → collection-browser-loading-tile.d.ts} +1 -1
  77. package/dist/src/tiles/collection-browser-loading-tile.js +32 -0
  78. package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -0
  79. package/dist/src/tiles/grid/account-tile.d.ts +1 -1
  80. package/dist/src/tiles/grid/account-tile.js +5 -5
  81. package/dist/src/tiles/grid/account-tile.js.map +1 -1
  82. package/dist/src/tiles/grid/collection-tile.js +1 -2
  83. package/dist/src/tiles/grid/collection-tile.js.map +1 -1
  84. package/dist/src/tiles/grid/icons/views.d.ts +1 -1
  85. package/dist/src/tiles/grid/icons/views.js +2 -2
  86. package/dist/src/tiles/grid/icons/views.js.map +1 -1
  87. package/dist/src/tiles/grid/item-tile.d.ts +2 -2
  88. package/dist/src/tiles/grid/item-tile.js +57 -151
  89. package/dist/src/tiles/grid/item-tile.js.map +1 -1
  90. package/dist/src/tiles/item-image.d.ts +19 -0
  91. package/dist/src/tiles/item-image.js +204 -0
  92. package/dist/src/tiles/item-image.js.map +1 -0
  93. package/dist/src/tiles/list/account-label.d.ts +1 -0
  94. package/dist/src/tiles/list/account-label.js +7 -0
  95. package/dist/src/tiles/list/account-label.js.map +1 -0
  96. package/dist/src/tiles/list/date-label.d.ts +1 -0
  97. package/dist/src/tiles/list/date-label.js +13 -0
  98. package/dist/src/tiles/list/date-label.js.map +1 -0
  99. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -0
  100. package/dist/src/tiles/list/tile-list-compact-header.js +84 -0
  101. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -0
  102. package/dist/src/tiles/list/tile-list-compact.d.ts +12 -0
  103. package/dist/src/tiles/list/tile-list-compact.js +203 -6
  104. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  105. package/dist/src/tiles/list/tile-list.d.ts +35 -10
  106. package/dist/src/tiles/list/tile-list.js +368 -104
  107. package/dist/src/tiles/list/tile-list.js.map +1 -1
  108. package/dist/src/{mediatype-icon.d.ts → tiles/mediatype-icon.d.ts} +2 -2
  109. package/dist/src/tiles/mediatype-icon.js +78 -0
  110. package/dist/src/tiles/mediatype-icon.js.map +1 -0
  111. package/dist/src/tiles/tile-dispatcher.d.ts +11 -4
  112. package/dist/src/tiles/tile-dispatcher.js +56 -19
  113. package/dist/src/tiles/tile-dispatcher.js.map +1 -1
  114. package/dist/src/utils/format-date.js +2 -2
  115. package/dist/src/utils/format-date.js.map +1 -1
  116. package/dist/test/collection-browser.test.d.ts +1 -0
  117. package/dist/test/collection-browser.test.js +16 -2
  118. package/dist/test/collection-browser.test.js.map +1 -1
  119. package/dist/test/mediatype-config.test.d.ts +1 -0
  120. package/dist/test/mediatype-config.test.js +17 -0
  121. package/dist/test/mediatype-config.test.js.map +1 -0
  122. package/dist/test/utils/format-date.test.js +1 -1
  123. package/dist/test/utils/format-date.test.js.map +1 -1
  124. package/index.ts +6 -0
  125. package/local.archive.org.cert +86 -0
  126. package/local.archive.org.key +27 -0
  127. package/package.json +9 -5
  128. package/src/assets/img/icons/chevron.ts +4 -0
  129. package/src/assets/img/icons/mediatype/account.ts +6 -4
  130. package/src/assets/img/icons/mediatype/audio.ts +7 -4
  131. package/src/assets/img/icons/mediatype/collection.ts +7 -4
  132. package/src/assets/img/icons/mediatype/data.ts +15 -0
  133. package/src/assets/img/icons/mediatype/etree.ts +10 -5
  134. package/src/assets/img/icons/mediatype/film.ts +2 -1
  135. package/src/assets/img/icons/mediatype/images.ts +9 -6
  136. package/src/assets/img/icons/mediatype/radio.ts +15 -0
  137. package/src/assets/img/icons/mediatype/software.ts +9 -6
  138. package/src/assets/img/icons/mediatype/texts.ts +9 -6
  139. package/src/assets/img/icons/mediatype/tv.ts +10 -5
  140. package/src/assets/img/icons/mediatype/video.ts +10 -6
  141. package/src/assets/img/icons/mediatype/web.ts +9 -6
  142. package/src/collection-browser.ts +529 -163
  143. package/src/collection-facets.ts +307 -205
  144. package/src/language-code-handler/language-code-handler.ts +64 -0
  145. package/src/language-code-handler/language-code-mapping.ts +564 -0
  146. package/src/mediatype/mediatype-config.ts +86 -0
  147. package/src/models.ts +141 -13
  148. package/src/restoration-state-handler.ts +266 -0
  149. package/src/sort-filter-bar/alpha-bar.ts +9 -3
  150. package/src/sort-filter-bar/img/compact.ts +5 -0
  151. package/src/sort-filter-bar/img/list.ts +1 -1
  152. package/src/sort-filter-bar/img/tile.ts +5 -0
  153. package/src/sort-filter-bar/sort-filter-bar.ts +557 -225
  154. package/src/tiles/collection-browser-loading-tile.ts +29 -0
  155. package/src/tiles/grid/account-tile.ts +1 -1
  156. package/src/tiles/grid/collection-tile.ts +1 -2
  157. package/src/tiles/grid/icons/views.ts +2 -2
  158. package/src/tiles/grid/item-tile.ts +56 -163
  159. package/src/tiles/item-image.ts +206 -0
  160. package/src/tiles/list/account-label.ts +6 -0
  161. package/src/tiles/list/date-label.ts +12 -0
  162. package/src/tiles/list/tile-list-compact-header.ts +77 -0
  163. package/src/tiles/list/tile-list-compact.ts +218 -0
  164. package/src/tiles/list/tile-list.ts +412 -107
  165. package/src/tiles/mediatype-icon.ts +75 -0
  166. package/src/tiles/tile-dispatcher.ts +66 -18
  167. package/src/utils/format-date.ts +2 -2
  168. package/test/collection-browser.test.ts +20 -1
  169. package/test/mediatype-config.test.ts +18 -0
  170. package/test/utils/format-date.test.ts +1 -1
  171. package/web-dev-server.config.mjs +3 -1
  172. package/dist/src/mediatype-icon.js +0 -89
  173. package/dist/src/mediatype-icon.js.map +0 -1
  174. package/dist/src/sort-filter-bar/img/grid.d.ts +0 -1
  175. package/dist/src/sort-filter-bar/img/grid.js +0 -5
  176. package/dist/src/sort-filter-bar/img/grid.js.map +0 -1
  177. package/dist/src/tiles/list/tile-list-detail.d.ts +0 -7
  178. package/dist/src/tiles/list/tile-list-detail.js +0 -28
  179. package/dist/src/tiles/list/tile-list-detail.js.map +0 -1
  180. package/dist/src/tiles/loading-tile.js +0 -73
  181. package/dist/src/tiles/loading-tile.js.map +0 -1
  182. package/src/mediatype-icon.ts +0 -83
  183. package/src/sort-filter-bar/img/grid.ts +0 -5
  184. package/src/tiles/loading-tile.ts +0 -70
@@ -1 +1 @@
1
- {"version":3,"file":"item-tile.js","sourceRoot":"","sources":["../../../../src/tiles/grid/item-tile.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAkB,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,OAAO,sBAAsB,CAAC;AAE9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,SAAS,MAAM,eAAe,CAAC;AAGtC,IAAa,QAAQ,GAArB,MAAa,QAAS,SAAQ,UAAU;IAKtC,IAAI,mBAAmB;;QACrB,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,iBAAiB,iBAAiB,MAAA,IAAI,CAAC,KAAK,0CAAE,UAAU,EAAE,CAAC;QACrF,MAAM,mBAAmB,GAAG,MAAA,IAAI,CAAC,KAAK,0CAAE,WAAW,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC5E,OAAO,CAAC,mBAAmB;YACzB,CAAC,CAAC,IAAI,CAAA;;wCAE4B,SAAS;gBACjC;YACV,CAAC,CAAC,IAAI,CAAA;;;0CAG8B,SAAS;;;eAGpC,CAAC;IACd,CAAC;IAED,MAAM;;QACJ,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,iBAAiB,iBAAiB,MAAA,IAAI,CAAC,KAAK,0CAAE,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;QACzF,MAAM,SAAS,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,KAAK,KAAI,EAAE,CAAC;QAC1C,MAAM,WAAW,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,OAAO,KAAI,GAAG,CAAC;QAE/C,OAAO,IAAI,CAAA;;;uEAGwD,SAAS;4CACpC,MAAA,IAAI,CAAC,KAAK,0CAAE,WAAW,CAAC,CAAC,CAAC;;;sCAGhC,SAAS;cACjC,MAAA,IAAI,CAAC,KAAK,0CAAE,KAAK;;;cAGjB,IAAI,CAAC,mBAAmB;;;;oBAIlB,WAAW;;;;;;2CAOf,MAAA,IAAI,CAAC,KAAK,0CAAE,SACd;;;gBAGE,SAAS;uCACc,WAAW,CAClC,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,EACrB,OAAO,EACP,OAAO,CACR;;;gBAGC,kBAAkB;uCACK,WAAW,CAClC,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,EACrB,OAAO,EACP,OAAO,CACR;;;gBAGC,WAAW;uCACY,WAAW,CAClC,MAAA,IAAI,CAAC,KAAK,0CAAE,QAAQ,EACpB,OAAO,EACP,OAAO,CACR;;;;;KAKV,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,MAAM,eAAe,GAAG,GAAG,CAAA,wCAAwC,CAAC;QAEpE,OAAO,GAAG,CAAA;;;yBAGW,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA+MnC,CAAC;IACJ,CAAC;CACF,CAAA;AAxS6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;uCAAmB;AAElB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAA4B;AAH5C,QAAQ;IADpB,aAAa,CAAC,WAAW,CAAC;GACd,QAAQ,CAySpB;SAzSY,QAAQ","sourcesContent":["import { css, CSSResultGroup, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { TileModel } from '../../models';\nimport { formatCount } from '../../utils/format-count';\n\nimport '../../mediatype-icon';\n\nimport { favoriteFilledIcon } from './icons/favorite-filled';\nimport { reviewsIcon } from './icons/reviews';\nimport viewsIcon from './icons/views';\n\n@customElement('item-tile')\nexport class ItemTile extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: String }) baseNavigationUrl?: string;\n\n get renderItemImageView() {\n const imgSrcUrl = `${this.baseNavigationUrl}/services/img/${this.model?.identifier}`;\n const containsDeemphasize = this.model?.collections.includes('deemphasize');\n return !containsDeemphasize\n ? html`<div\n id=\"item-image\"\n style=\"background-image:url(${imgSrcUrl})\"\n ></div>`\n : html`<div id=\"item-image-box\">\n <div\n id=\"item-image-deemphasize\"\n style=\"background-image:url(${imgSrcUrl})\"\n ></div>\n <div class=\"tile-action no-preview\">Content may be inappropriate</div>\n </div>`;\n }\n\n render() {\n const imgSrcUrl = `${this.baseNavigationUrl}/services/img/${this.model?.collections[0]}`;\n const itemTitle = this.model?.title || '';\n const itemCreator = this.model?.creator || '-';\n\n return html`\n <div id=\"container\">\n <div id=\"stealth-popup\">\n <div id=\"collection-thumbnail\" style=\"background-image:url(${imgSrcUrl})\"></div>\n <div id=\"collection-title-text\">${this.model?.collections[0]}</div>\n </div>\n <div id=\"title-image-container\">\n <h1 id=\"item-title\" title=${itemTitle}>\n ${this.model?.title}\n </h1>\n <div id=\"item-image-container\">\n ${this.renderItemImageView}\n </div>\n <div class=\"item-creator\">\n <span id=\"text-by\">By:</span>\n <span>${itemCreator}</span>\n </div>\n </div>\n <div id=\"item-stats-container\">\n <div id=\"stats-holder\">\n <div class=\"col\">\n <mediatype-icon mediatype=\"${\n this.model?.mediatype\n }\" showText=\"true\">\n </div>\n <div class=\"col\">\n ${viewsIcon}\n <p class=\"status-text\">${formatCount(\n this.model?.viewCount,\n 'short',\n 'short'\n )}</p>\n </div>\n <div class=\"col\">\n ${favoriteFilledIcon}\n <p class=\"status-text\">${formatCount(\n this.model?.itemCount,\n 'short',\n 'short'\n )}</p>\n </div>\n <div class=\"col\">\n ${reviewsIcon}\n <p class=\"status-text\">${formatCount(\n this.model?.favCount,\n 'short',\n 'short'\n )}</p>\n </div>\n </div>\n </div>\n </div>\n `;\n }\n\n static get styles(): CSSResultGroup {\n const cornerRadiusCss = css`var(--collectionTileCornerRadius, 4px)`;\n\n return css`\n #container {\n background-color: #ffffff;\n border-radius: ${cornerRadiusCss};\n box-shadow: 1px 1px 2px 0px;\n display: flex;\n flex-direction: column;\n height: 100%;\n position: relative;\n }\n\n #title-image-container {\n display: flex;\n flex: 1;\n flex-direction: column;\n padding: 0.5rem;\n }\n\n #item-title {\n font-weight: bold;\n color: #000000;\n font-size: 1.6rem;\n text-align: center;\n margin-top: 0rem;\n margin-bottom: 0.5rem;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n line-height: 2rem;\n height: 4rem;\n }\n\n #item-image-container {\n display: flex;\n justify-content: center;\n flex: 1;\n }\n\n #item-image {\n width: 16rem;\n height: 16rem;\n border-radius: 0.8rem;\n overflow: hidden;\n box-shadow: 1px 1px 2px 0px;\n object-fit: cover;\n background-position: center;\n background-size: cover;\n }\n\n #item-image-box {\n width: 16rem;\n height: 16rem;\n border-radius: 0.8rem;\n overflow: hidden;\n box-shadow: 1px 1px 2px 0px;\n border: 1px solid #000000;\n position: relative;\n display: flex;\n }\n\n #item-image-deemphasize {\n width: 16rem;\n height: 16rem;\n object-fit: cover;\n background-position: center;\n background-size: cover;\n filter: blur(15px);\n position: absolute;\n z-index: 1;\n }\n\n .tile-action {\n border: 1px solid currentColor;\n border-radius: 1px;\n padding: 5px;\n font-weight: 500;\n width: auto;\n position: absolute;\n z-index: 2;\n display: flex;\n top: 5.5rem;\n }\n\n .no-preview {\n background-color: #fffecb;\n color: #000000;\n font-size: 1.4rem;\n line-height: 2rem;\n text-align: center;\n }\n\n .hidden {\n display: none;\n }\n\n #container:hover > #title-image-container > .item-title {\n text-decoration: underline;\n }\n\n /** this is a workaround for Safari 15 where the hover effects are not working */\n #title-image-container:hover > #item-title {\n text-decoration: underline;\n }\n\n #container:hover > #item-title {\n background-color: #fcfcfc;\n }\n\n .item-creator {\n color: #000000;\n display: -webkit-box;\n font-size: 1.4rem;\n height: 3rem;\n margin: 0px;\n overflow: hidden;\n padding: 0.5rem;\n text-align: center;\n text-overflow: ellipsis;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n\n #text-by {\n font-weight: bold;\n }\n\n #item-stats-container {\n align-items: center;\n display: flex;\n height: 5.5rem;\n padding-left: 1rem;\n padding-right: 0.5rem;\n }\n\n #stats-holder {\n align-items: center;\n display: flex;\n flex: 1;\n justify-content: space-evenly;\n text-align: center;\n width: 100%;\n }\n\n svg {\n height: 10px;\n width: 10px;\n }\n\n .status-text {\n font-size: 14px;\n color: #2c2c2c;\n margin: auto;\n display: block;\n text-align: center;\n }\n\n .col {\n width: 25%;\n }\n\n #container:hover #stealth-popup {\n margin-top: -25px;\n visibility: visible;\n opacity: 1;\n }\n\n #stealth-popup {\n transition: margin-top 0.3s ease, opacity 0.3s ease;\n position: absolute;\n visibility: hidden;\n margin-left: -10px;\n text-align: left;\n display: flex;\n padding: 5px;\n width: 96%;\n background: #f5f5f7 100%;\n border: 1px #2c2c2c;\n box-shadow: 1px 1px 2px 0px;\n }\n\n #collection-thumbnail {\n display: flex;\n transition: opacity 0.3s ease;\n width: 3rem;\n height: 3rem;\n flex: 0 0 3rem;\n border-radius: 8px;\n border: 1px solid #ddd;\n overflow: hidden;\n background-size: cover;\n background-repeat: no-repeat;\n background-position: center center;\n }\n\n #collection-title-text {\n line-height: 1;\n font-size: 16px;\n font-weight: bold;\n text-align: left;\n padding-left: 0.5rem;\n padding-right: 0.5rem;\n height: 3.5rem;\n display: -webkit-box;\n overflow: hidden;\n text-overflow: ellipsis;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"item-tile.js","sourceRoot":"","sources":["../../../../src/tiles/grid/item-tile.ts"],"names":[],"mappings":";AAAA,yCAAyC;AACzC,OAAO,EAAE,GAAG,EAAkB,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG5D,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAEvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,SAAS,MAAM,eAAe,CAAC;AAEtC,OAAO,mBAAmB,CAAC;AAC3B,OAAO,eAAe,CAAC;AAGvB,IAAa,QAAQ,GAArB,MAAa,QAAS,SAAQ,UAAU;IAKtC,MAAM;;QACJ,MAAM,SAAS,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,KAAK,KAAI,EAAE,CAAC;QAC1C,MAAM,WAAW,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,OAAO,KAAI,GAAG,CAAC;QAE/C,OAAO,IAAI,CAAA;;;sCAGuB,SAAS,IAAI,MAAA,IAAI,CAAC,KAAK,0CAAE,KAAK;;;uBAG7C,IAAI,CAAC,KAAK;mCACE,IAAI,CAAC,iBAAiB;;;;;;gDAMT,WAAW;;;;;;;;;;;6BAW9B,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS;8BACpB,MAAA,IAAI,CAAC,KAAK,0CAAE,WAAW;4BACzB,IAAI;;;;;gBAKhB,SAAS;;kBAEP,WAAW,CAAC,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC;;;;gBAItD,kBAAkB;;kBAEhB,WAAW,CAAC,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC;;;;gBAItD,WAAW;;kBAET,WAAW,CAAC,MAAA,IAAI,CAAC,KAAK,0CAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC;;;;;;KAMhE,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,MAAM,eAAe,GAAG,GAAG,CAAA,wCAAwC,CAAC;QAEpE,OAAO,GAAG,CAAA;;;yBAGW,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoHnC,CAAC;IACJ,CAAC;CACF,CAAA;AA1L6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;uCAAmB;AAElB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAA4B;AAH5C,QAAQ;IADpB,aAAa,CAAC,WAAW,CAAC;GACd,QAAQ,CA2LpB;SA3LY,QAAQ","sourcesContent":["/* eslint-disable import/no-duplicates */\nimport { css, CSSResultGroup, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { TileModel } from '../../models';\nimport { formatCount } from '../../utils/format-count';\n\nimport { favoriteFilledIcon } from './icons/favorite-filled';\nimport { reviewsIcon } from './icons/reviews';\nimport viewsIcon from './icons/views';\n\nimport '../mediatype-icon';\nimport '../item-image';\n\n@customElement('item-tile')\nexport class ItemTile extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: String }) baseNavigationUrl?: string;\n\n render() {\n const itemTitle = this.model?.title || '';\n const itemCreator = this.model?.creator || '-';\n\n return html`\n <div id=\"container\">\n <div id=\"title-image-container\">\n <h1 id=\"item-title\" title=${itemTitle}>${this.model?.title}</h1>\n <div id=\"item-image-container\">\n <item-image\n .model=${this.model}\n .baseNavigationUrl=${this.baseNavigationUrl}\n >\n </item-image>\n </div>\n <div class=\"item-creator\">\n <div class=\"truncated\">\n <span><strong>By:&nbsp;</strong>${itemCreator}</span>\n </div>\n </div>\n </div>\n\n <div class=\"hr\"></div>\n\n <div id=\"item-stats-container\">\n <div id=\"stats-holder\">\n <div class=\"col\">\n <mediatype-icon\n .mediatype=${this.model?.mediatype}\n .collection=${this.model?.collections}\n ?showText=${true}\n >\n </mediatype-icon>\n </div>\n <div class=\"col\">\n ${viewsIcon}\n <p class=\"status-text\">\n ${formatCount(this.model?.viewCount, 'short', 'short')}\n </p>\n </div>\n <div class=\"col\">\n ${favoriteFilledIcon}\n <p class=\"status-text\">\n ${formatCount(this.model?.itemCount, 'short', 'short')}\n </p>\n </div>\n <div class=\"col\">\n ${reviewsIcon}\n <p class=\"status-text\">\n ${formatCount(this.model?.favCount, 'short', 'short')}\n </p>\n </div>\n </div>\n </div>\n </div>\n `;\n }\n\n static get styles(): CSSResultGroup {\n const cornerRadiusCss = css`var(--collectionTileCornerRadius, 4px)`;\n\n return css`\n #container {\n background-color: #ffffff;\n border-radius: ${cornerRadiusCss};\n box-shadow: 1px 1px 2px 0px;\n display: flex;\n flex-direction: column;\n height: 100%;\n position: relative;\n }\n\n #title-image-container {\n display: flex;\n flex: 1;\n flex-direction: column;\n padding: 0.5rem 0.5rem 0 0.5rem;\n }\n\n #item-title {\n color: #2c2c2c;\n font-size: 1.6rem;\n text-align: center;\n margin-top: 0rem;\n margin-bottom: 0.5rem;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n line-height: 2rem;\n height: 4rem;\n }\n\n #item-image-container {\n display: flex;\n justify-content: center;\n flex: 1;\n }\n\n .hidden {\n display: none;\n }\n\n #container:hover > #title-image-container > .item-title {\n text-decoration: underline;\n }\n\n /** this is a workaround for Safari 15 where the hover effects are not working */\n #title-image-container:hover > #item-title {\n text-decoration: underline;\n }\n\n #container:hover > #item-title {\n background-color: #fcfcfc;\n }\n\n .item-creator {\n display: flex;\n justify-content: center;\n align-items: flex-end; /* Important to start text from bottom */\n height: 3rem;\n padding-top: 1rem;\n }\n\n .truncated {\n flex: 1;\n min-width: 0; /* Important for long words! */\n }\n\n .truncated span {\n font-size: 1.4rem;\n color: #2c2c2c;\n -webkit-line-clamp: 2;\n text-overflow: ellipsis;\n overflow: hidden;\n display: -webkit-box;\n -webkit-box-orient: vertical;\n word-wrap: break-word;\n line-height: 2rem;\n text-align: center;\n }\n\n .hr {\n border: 0.5px solid #ccc;\n }\n\n #item-stats-container {\n align-items: center;\n display: flex;\n height: 5.5rem;\n padding-left: 1rem;\n padding-right: 0.5rem;\n }\n\n #stats-holder {\n align-items: center;\n display: flex;\n flex: 1;\n justify-content: space-evenly;\n text-align: center;\n width: 100%;\n }\n\n svg {\n height: 10px;\n width: 10px;\n }\n\n .status-text {\n font-size: 14px;\n color: #2c2c2c;\n margin: auto;\n display: block;\n text-align: center;\n }\n\n .col {\n width: 25%;\n }\n `;\n }\n}\n"]}
@@ -0,0 +1,19 @@
1
+ import { CSSResultGroup, PropertyValues, LitElement } from 'lit';
2
+ import { TileModel } from '../models';
3
+ export declare class ItemImage extends LitElement {
4
+ model?: TileModel;
5
+ baseNavigationUrl?: string;
6
+ isListTile: boolean;
7
+ private isDeemphasize;
8
+ protected updated(changed: PropertyValues): void;
9
+ private setDeemphsize;
10
+ render(): import("lit-html").TemplateResult<1>;
11
+ private get imageSrc();
12
+ private get backgroundImageTemplate();
13
+ private get waveformTemplate();
14
+ private get tileActionTemplate();
15
+ private get imageClass();
16
+ private get imageBoxClass();
17
+ private get randomGradient();
18
+ static get styles(): CSSResultGroup;
19
+ }
@@ -0,0 +1,204 @@
1
+ import { __decorate } from "tslib";
2
+ import { css, html, nothing, LitElement, } from 'lit';
3
+ import { customElement, property, state } from 'lit/decorators.js';
4
+ import { ifDefined } from 'lit/directives/if-defined.js';
5
+ let ItemImage = class ItemImage extends LitElement {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.isListTile = false;
9
+ this.isDeemphasize = false;
10
+ }
11
+ updated(changed) {
12
+ if (changed.has('model')) {
13
+ this.setDeemphsize();
14
+ }
15
+ }
16
+ setDeemphsize() {
17
+ var _a, _b;
18
+ this.isDeemphasize =
19
+ (_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.collections.includes('deemphasize')) !== null && _b !== void 0 ? _b : false;
20
+ }
21
+ render() {
22
+ var _a;
23
+ return html `
24
+ <div class=${ifDefined(this.imageBoxClass)}>
25
+ ${((_a = this.model) === null || _a === void 0 ? void 0 : _a.mediatype) === 'audio'
26
+ ? this.waveformTemplate
27
+ : this.backgroundImageTemplate}
28
+ ${this.tileActionTemplate}
29
+ </div>
30
+ `;
31
+ }
32
+ get imageSrc() {
33
+ var _a;
34
+ return `${this.baseNavigationUrl}/services/img/${(_a = this.model) === null || _a === void 0 ? void 0 : _a.identifier}`;
35
+ }
36
+ // Templates
37
+ get backgroundImageTemplate() {
38
+ return html `
39
+ <div
40
+ class=${this.imageClass}
41
+ style="background-image:url(${this.imageSrc})"
42
+ ></div>
43
+ `;
44
+ }
45
+ get waveformTemplate() {
46
+ var _a;
47
+ return html `
48
+ <div class="box" id=${this.randomGradient}>
49
+ <img
50
+ class="item-image waveform"
51
+ src="${this.imageSrc}"
52
+ alt="${ifDefined((_a = this.model) === null || _a === void 0 ? void 0 : _a.identifier)}"
53
+ />
54
+ </div>
55
+ `;
56
+ }
57
+ get tileActionTemplate() {
58
+ if (!this.isDeemphasize) {
59
+ return nothing;
60
+ }
61
+ return html `
62
+ <div class="tile-action no-preview">Content may be inappropriate</div>
63
+ `;
64
+ }
65
+ // Classes
66
+ get imageClass() {
67
+ return `item-image ${this.isDeemphasize ? 'deemphasize' : 'default'}`;
68
+ }
69
+ get imageBoxClass() {
70
+ return this.isDeemphasize ? 'item-image-box' : undefined;
71
+ }
72
+ get randomGradient() {
73
+ return `grad${Math.floor(Math.random() * (6 - 1) + 1)}`;
74
+ }
75
+ static get styles() {
76
+ return css `
77
+ .item-image-box {
78
+ width: 16rem;
79
+ height: 16rem;
80
+ overflow: hidden;
81
+ position: relative;
82
+ box-shadow: 1px 1px 2px 0px;
83
+ display: flex;
84
+ }
85
+
86
+ .item-image {
87
+ width: 16rem;
88
+ height: 16rem;
89
+ object-fit: cover;
90
+ background-repeat: no-repeat;
91
+ background-position: center center;
92
+ position: relative;
93
+ -webkit-appearance: none;
94
+ overflow: visible;
95
+ }
96
+
97
+ .waveform {
98
+ mix-blend-mode: screen;
99
+ }
100
+
101
+ .default {
102
+ background-size: contain;
103
+ filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.8));
104
+ }
105
+
106
+ .deemphasize {
107
+ background-size: cover;
108
+ filter: blur(15px);
109
+ z-index: 1;
110
+ }
111
+
112
+ .tile-action {
113
+ border: 1px solid currentColor;
114
+ border-radius: 1px;
115
+ padding: 5px;
116
+ font-weight: 500;
117
+ width: auto;
118
+ position: absolute;
119
+ z-index: 2;
120
+ display: flex;
121
+ top: 5.5rem;
122
+ }
123
+
124
+ .no-preview {
125
+ background-color: #fffecb;
126
+ color: #2c2c2c;
127
+ font-size: 1.4rem;
128
+ line-height: 2rem;
129
+ text-align: center;
130
+ }
131
+
132
+ #grad1 {
133
+ background: linear-gradient(
134
+ hsl(300, 80%, 55%),
135
+ hsl(330, 80%, 33%) 35%,
136
+ hsl(330, 80%, 22%) 70%,
137
+ hsl(0, 0%, 0%)
138
+ );
139
+ }
140
+
141
+ #grad2 {
142
+ background: linear-gradient(
143
+ hsl(200, 80%, 55%),
144
+ hsl(230, 80%, 33%) 35%,
145
+ hsl(230, 80%, 22%) 70%,
146
+ hsl(0, 0%, 0%)
147
+ );
148
+ }
149
+
150
+ #grad3 {
151
+ background: linear-gradient(
152
+ hsl(160, 80%, 55%),
153
+ hsl(190, 80%, 33%) 35%,
154
+ hsl(190, 80%, 22%) 70%,
155
+ hsl(0, 0%, 0%)
156
+ );
157
+ }
158
+
159
+ #grad4 {
160
+ background: linear-gradient(
161
+ hsl(250, 80%, 55%),
162
+ hsl(280, 80%, 33%) 35%,
163
+ hsl(280, 80%, 22%) 70%,
164
+ hsl(0, 0%, 0%)
165
+ );
166
+ }
167
+
168
+ #grad5 {
169
+ background: linear-gradient(
170
+ hsl(280, 80%, 55%),
171
+ hsl(310, 80%, 33%) 35%,
172
+ hsl(310, 80%, 22%) 70%,
173
+ hsl(0, 0%, 0%)
174
+ );
175
+ }
176
+
177
+ #grad6 {
178
+ background: linear-gradient(
179
+ hsl(340, 80%, 55%),
180
+ hsl(0, 80%, 33%) 35%,
181
+ hsl(0, 80%, 22%) 70%,
182
+ hsl(0, 0%, 0%)
183
+ );
184
+ }
185
+ `;
186
+ }
187
+ };
188
+ __decorate([
189
+ property({ type: Object })
190
+ ], ItemImage.prototype, "model", void 0);
191
+ __decorate([
192
+ property({ type: String })
193
+ ], ItemImage.prototype, "baseNavigationUrl", void 0);
194
+ __decorate([
195
+ property({ type: Boolean })
196
+ ], ItemImage.prototype, "isListTile", void 0);
197
+ __decorate([
198
+ state()
199
+ ], ItemImage.prototype, "isDeemphasize", void 0);
200
+ ItemImage = __decorate([
201
+ customElement('item-image')
202
+ ], ItemImage);
203
+ export { ItemImage };
204
+ //# sourceMappingURL=item-image.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"item-image.js","sourceRoot":"","sources":["../../../src/tiles/item-image.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n nothing,\n PropertyValues,\n LitElement,\n} from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\n\nimport { TileModel } from '../models';\n\n@customElement('item-image')\nexport class ItemImage extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: String }) baseNavigationUrl?: string;\n\n @property({ type: Boolean }) isListTile = false;\n\n @state() private isDeemphasize = false;\n\n protected updated(changed: PropertyValues): void {\n if (changed.has('model')) {\n this.setDeemphsize();\n }\n }\n\n private setDeemphsize() {\n this.isDeemphasize =\n this.model?.collections.includes('deemphasize') ?? false;\n }\n\n render() {\n return html`\n <div class=${ifDefined(this.imageBoxClass)}>\n ${this.model?.mediatype === 'audio'\n ? this.waveformTemplate\n : this.backgroundImageTemplate}\n ${this.tileActionTemplate}\n </div>\n `;\n }\n\n private get imageSrc() {\n return `${this.baseNavigationUrl}/services/img/${this.model?.identifier}`;\n }\n\n // Templates\n private get backgroundImageTemplate() {\n return html`\n <div\n class=${this.imageClass}\n style=\"background-image:url(${this.imageSrc})\"\n ></div>\n `;\n }\n\n private get waveformTemplate() {\n return html`\n <div class=\"box\" id=${this.randomGradient}>\n <img\n class=\"item-image waveform\"\n src=\"${this.imageSrc}\"\n alt=\"${ifDefined(this.model?.identifier)}\"\n />\n </div>\n `;\n }\n\n private get tileActionTemplate() {\n if (!this.isDeemphasize) {\n return nothing;\n }\n return html`\n <div class=\"tile-action no-preview\">Content may be inappropriate</div>\n `;\n }\n\n // Classes\n private get imageClass() {\n return `item-image ${this.isDeemphasize ? 'deemphasize' : 'default'}`;\n }\n\n private get imageBoxClass() {\n return this.isDeemphasize ? 'item-image-box' : undefined;\n }\n\n private get randomGradient() {\n return `grad${Math.floor(Math.random() * (6 - 1) + 1)}`;\n }\n\n static get styles(): CSSResultGroup {\n return css`\n .item-image-box {\n width: 16rem;\n height: 16rem;\n overflow: hidden;\n position: relative;\n box-shadow: 1px 1px 2px 0px;\n display: flex;\n }\n\n .item-image {\n width: 16rem;\n height: 16rem;\n object-fit: cover;\n background-repeat: no-repeat;\n background-position: center center;\n position: relative;\n -webkit-appearance: none;\n overflow: visible;\n }\n\n .waveform {\n mix-blend-mode: screen;\n }\n\n .default {\n background-size: contain;\n filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.8));\n }\n\n .deemphasize {\n background-size: cover;\n filter: blur(15px);\n z-index: 1;\n }\n\n .tile-action {\n border: 1px solid currentColor;\n border-radius: 1px;\n padding: 5px;\n font-weight: 500;\n width: auto;\n position: absolute;\n z-index: 2;\n display: flex;\n top: 5.5rem;\n }\n\n .no-preview {\n background-color: #fffecb;\n color: #2c2c2c;\n font-size: 1.4rem;\n line-height: 2rem;\n text-align: center;\n }\n\n #grad1 {\n background: linear-gradient(\n hsl(300, 80%, 55%),\n hsl(330, 80%, 33%) 35%,\n hsl(330, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n\n #grad2 {\n background: linear-gradient(\n hsl(200, 80%, 55%),\n hsl(230, 80%, 33%) 35%,\n hsl(230, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n\n #grad3 {\n background: linear-gradient(\n hsl(160, 80%, 55%),\n hsl(190, 80%, 33%) 35%,\n hsl(190, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n\n #grad4 {\n background: linear-gradient(\n hsl(250, 80%, 55%),\n hsl(280, 80%, 33%) 35%,\n hsl(280, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n\n #grad5 {\n background: linear-gradient(\n hsl(280, 80%, 55%),\n hsl(310, 80%, 33%) 35%,\n hsl(310, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n\n #grad6 {\n background: linear-gradient(\n hsl(340, 80%, 55%),\n hsl(0, 80%, 33%) 35%,\n hsl(0, 80%, 22%) 70%,\n hsl(0, 0%, 0%)\n );\n }\n `;\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare function accountLabel(date: Date | undefined): string;
@@ -0,0 +1,7 @@
1
+ export function accountLabel(date) {
2
+ if (!date) {
3
+ return '';
4
+ }
5
+ return `Archivist since ${date.getFullYear()}`;
6
+ }
7
+ //# sourceMappingURL=account-label.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account-label.js","sourceRoot":"","sources":["../../../../src/tiles/list/account-label.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,YAAY,CAAC,IAAsB;IACjD,IAAI,CAAC,IAAI,EAAE;QACT,OAAO,EAAE,CAAC;KACX;IACD,OAAO,mBAAmB,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;AACjD,CAAC","sourcesContent":["export function accountLabel(date: Date | undefined): string {\n if (!date) {\n return '';\n }\n return `Archivist since ${date.getFullYear()}`;\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare function dateLabel(sortField: string | undefined): string;
@@ -0,0 +1,13 @@
1
+ export function dateLabel(sortField) {
2
+ switch (sortField) {
3
+ case 'date':
4
+ return 'Published';
5
+ case 'reviewdate':
6
+ return 'Reviewed';
7
+ case 'addeddate':
8
+ return 'Added';
9
+ default:
10
+ return 'Archived';
11
+ }
12
+ }
13
+ //# sourceMappingURL=date-label.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date-label.js","sourceRoot":"","sources":["../../../../src/tiles/list/date-label.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,SAAS,CAAC,SAA6B;IACrD,QAAQ,SAAS,EAAE;QACjB,KAAK,MAAM;YACT,OAAO,WAAW,CAAC;QACrB,KAAK,YAAY;YACf,OAAO,UAAU,CAAC;QACpB,KAAK,WAAW;YACd,OAAO,OAAO,CAAC;QACjB;YACE,OAAO,UAAU,CAAC;KACrB;AACH,CAAC","sourcesContent":["export function dateLabel(sortField: string | undefined): string {\n switch (sortField) {\n case 'date':\n return 'Published';\n case 'reviewdate':\n return 'Reviewed';\n case 'addeddate':\n return 'Added';\n default:\n return 'Archived';\n }\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import { LitElement } from 'lit';
2
+ import { SortParam } from '@internetarchive/search-service';
3
+ import { TileModel } from '../../models';
4
+ export declare class TileListCompactHeader extends LitElement {
5
+ model?: TileModel;
6
+ currentWidth?: number;
7
+ sortParam: SortParam | null;
8
+ mobileBreakpoint?: number;
9
+ render(): import("lit-html").TemplateResult<1>;
10
+ private get classSize();
11
+ static get styles(): import("lit").CSSResult;
12
+ }
@@ -0,0 +1,84 @@
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { dateLabel } from './date-label';
5
+ let TileListCompactHeader = class TileListCompactHeader extends LitElement {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.sortParam = null;
9
+ }
10
+ render() {
11
+ var _a;
12
+ return html `
13
+ <div id="list-line-header" class="${this.classSize}">
14
+ <div id="thumb"></div>
15
+ <div id="title">Title</div>
16
+ <div id="creator">Creator</div>
17
+ <div id="date">${dateLabel((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field)}</div>
18
+ <div id="icon"></div>
19
+ <div id="views">Views</div>
20
+ </div>
21
+ `;
22
+ }
23
+ get classSize() {
24
+ if (this.mobileBreakpoint &&
25
+ this.currentWidth &&
26
+ this.currentWidth < this.mobileBreakpoint) {
27
+ return 'mobile';
28
+ }
29
+ return 'desktop';
30
+ }
31
+ static get styles() {
32
+ return css `
33
+ html {
34
+ font-size: unset;
35
+ }
36
+
37
+ div {
38
+ font-size: 14px;
39
+ font-weight: bold;
40
+ line-height: 20px;
41
+ }
42
+
43
+ .mobile #views {
44
+ display: none;
45
+ }
46
+
47
+ #views {
48
+ text-align: right;
49
+ }
50
+
51
+ #list-line-header {
52
+ display: grid;
53
+ column-gap: 10px;
54
+ align-items: flex-end;
55
+ padding-bottom: 2px;
56
+ }
57
+
58
+ #list-line-header.mobile {
59
+ grid-template-columns: 36px 3fr 2fr 91px;
60
+ }
61
+
62
+ #list-line-header.desktop {
63
+ grid-template-columns: 51px 3fr 2fr 100px 20px 60px;
64
+ }
65
+ `;
66
+ }
67
+ };
68
+ __decorate([
69
+ property({ type: Object })
70
+ ], TileListCompactHeader.prototype, "model", void 0);
71
+ __decorate([
72
+ property({ type: Number })
73
+ ], TileListCompactHeader.prototype, "currentWidth", void 0);
74
+ __decorate([
75
+ property({ type: Object })
76
+ ], TileListCompactHeader.prototype, "sortParam", void 0);
77
+ __decorate([
78
+ property({ type: Number })
79
+ ], TileListCompactHeader.prototype, "mobileBreakpoint", void 0);
80
+ TileListCompactHeader = __decorate([
81
+ customElement('tile-list-compact-header')
82
+ ], TileListCompactHeader);
83
+ export { TileListCompactHeader };
84
+ //# sourceMappingURL=tile-list-compact-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tile-list-compact-header.js","sourceRoot":"","sources":["../../../../src/tiles/list/tile-list-compact-header.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE5D,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,IAAa,qBAAqB,GAAlC,MAAa,qBAAsB,SAAQ,UAAU;IAArD;;QAK8B,cAAS,GAAqB,IAAI,CAAC;IAgEjE,CAAC;IA5DC,MAAM;;QACJ,OAAO,IAAI,CAAA;0CAC2B,IAAI,CAAC,SAAS;;;;yBAI/B,SAAS,CAAC,MAAA,IAAI,CAAC,SAAS,0CAAE,KAAK,CAAC;;;;KAIpD,CAAC;IACJ,CAAC;IAED,IAAY,SAAS;QACnB,IACE,IAAI,CAAC,gBAAgB;YACrB,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,EACzC;YACA,OAAO,QAAQ,CAAC;SACjB;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiCT,CAAC;IACJ,CAAC;CACF,CAAA;AApE6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;oDAAmB;AAElB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;2DAAuB;AAEtB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;wDAAoC;AAEnC;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;+DAA2B;AAP3C,qBAAqB;IADjC,aAAa,CAAC,0BAA0B,CAAC;GAC7B,qBAAqB,CAqEjC;SArEY,qBAAqB","sourcesContent":["import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { SortParam } from '@internetarchive/search-service';\nimport { dateLabel } from './date-label';\nimport { TileModel } from '../../models';\n\n@customElement('tile-list-compact-header')\nexport class TileListCompactHeader extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: Number }) currentWidth?: number;\n\n @property({ type: Object }) sortParam: SortParam | null = null;\n\n @property({ type: Number }) mobileBreakpoint?: number;\n\n render() {\n return html`\n <div id=\"list-line-header\" class=\"${this.classSize}\">\n <div id=\"thumb\"></div>\n <div id=\"title\">Title</div>\n <div id=\"creator\">Creator</div>\n <div id=\"date\">${dateLabel(this.sortParam?.field)}</div>\n <div id=\"icon\"></div>\n <div id=\"views\">Views</div>\n </div>\n `;\n }\n\n private get classSize(): string {\n if (\n this.mobileBreakpoint &&\n this.currentWidth &&\n this.currentWidth < this.mobileBreakpoint\n ) {\n return 'mobile';\n }\n return 'desktop';\n }\n\n static get styles() {\n return css`\n html {\n font-size: unset;\n }\n\n div {\n font-size: 14px;\n font-weight: bold;\n line-height: 20px;\n }\n\n .mobile #views {\n display: none;\n }\n\n #views {\n text-align: right;\n }\n\n #list-line-header {\n display: grid;\n column-gap: 10px;\n align-items: flex-end;\n padding-bottom: 2px;\n }\n\n #list-line-header.mobile {\n grid-template-columns: 36px 3fr 2fr 91px;\n }\n\n #list-line-header.desktop {\n grid-template-columns: 51px 3fr 2fr 100px 20px 60px;\n }\n `;\n }\n}\n"]}
@@ -1,7 +1,19 @@
1
1
  import { LitElement } from 'lit';
2
+ import { SortParam } from '@internetarchive/search-service';
2
3
  import { TileModel } from '../../models';
4
+ import '../mediatype-icon';
3
5
  export declare class TileListCompact extends LitElement {
4
6
  model?: TileModel;
7
+ baseNavigationUrl?: string;
8
+ currentWidth?: number;
9
+ currentHeight?: number;
10
+ sortParam: SortParam | null;
11
+ mobileBreakpoint?: number;
5
12
  render(): import("lit-html").TemplateResult<1>;
13
+ private get collectionColor();
14
+ private get imageTemplate();
15
+ private get date();
16
+ private get classSize();
17
+ private get formatSize();
6
18
  static get styles(): import("lit").CSSResult;
7
19
  }