@internetarchive/collection-browser 0.2.15 → 0.2.16

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 (222) hide show
  1. package/dist/index.d.ts +9 -0
  2. package/dist/index.js.map +1 -0
  3. package/dist/src/app-root.d.ts +32 -0
  4. package/dist/src/app-root.js +285 -0
  5. package/dist/src/app-root.js.map +1 -0
  6. package/dist/src/assets/img/icons/chevron.d.ts +2 -0
  7. package/dist/src/assets/img/icons/chevron.js +4 -0
  8. package/dist/src/assets/img/icons/chevron.js.map +1 -0
  9. package/dist/src/assets/img/icons/empty-query.d.ts +2 -0
  10. package/dist/src/assets/img/icons/empty-query.js +5 -0
  11. package/dist/src/assets/img/icons/empty-query.js.map +1 -0
  12. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -0
  13. package/dist/src/assets/img/icons/eye-closed.js +5 -0
  14. package/dist/src/assets/img/icons/eye-closed.js.map +1 -0
  15. package/dist/src/assets/img/icons/eye.d.ts +2 -0
  16. package/dist/src/assets/img/icons/eye.js +5 -0
  17. package/dist/src/assets/img/icons/eye.js.map +1 -0
  18. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -0
  19. package/dist/src/assets/img/icons/favorite-filled.js +11 -0
  20. package/dist/src/assets/img/icons/favorite-filled.js.map +1 -0
  21. package/dist/src/assets/img/icons/login-required.d.ts +1 -0
  22. package/dist/src/assets/img/icons/login-required.js +30 -0
  23. package/dist/src/assets/img/icons/login-required.js.map +1 -0
  24. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -0
  25. package/dist/src/assets/img/icons/mediatype/account.js +14 -0
  26. package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
  27. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
  28. package/dist/src/assets/img/icons/mediatype/audio.js +14 -0
  29. package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
  30. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
  31. package/dist/src/assets/img/icons/mediatype/collection.js +12 -0
  32. package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
  33. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -0
  34. package/dist/src/assets/img/icons/mediatype/data.js +15 -0
  35. package/dist/src/assets/img/icons/mediatype/data.js.map +1 -0
  36. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
  37. package/dist/src/assets/img/icons/mediatype/etree.js +14 -0
  38. package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
  39. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
  40. package/dist/src/assets/img/icons/mediatype/film.js +14 -0
  41. package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
  42. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
  43. package/dist/src/assets/img/icons/mediatype/images.js +13 -0
  44. package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
  45. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -0
  46. package/dist/src/assets/img/icons/mediatype/radio.js +15 -0
  47. package/dist/src/assets/img/icons/mediatype/radio.js.map +1 -0
  48. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
  49. package/dist/src/assets/img/icons/mediatype/software.js +13 -0
  50. package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
  51. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
  52. package/dist/src/assets/img/icons/mediatype/texts.js +13 -0
  53. package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
  54. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
  55. package/dist/src/assets/img/icons/mediatype/tv.js +14 -0
  56. package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
  57. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
  58. package/dist/src/assets/img/icons/mediatype/video.js +14 -0
  59. package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
  60. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
  61. package/dist/src/assets/img/icons/mediatype/web.js +13 -0
  62. package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
  63. package/dist/src/assets/img/icons/null-result.d.ts +2 -0
  64. package/dist/src/assets/img/icons/null-result.js +5 -0
  65. package/dist/src/assets/img/icons/null-result.js.map +1 -0
  66. package/dist/src/assets/img/icons/restricted.d.ts +1 -0
  67. package/dist/src/assets/img/icons/restricted.js +29 -0
  68. package/dist/src/assets/img/icons/restricted.js.map +1 -0
  69. package/dist/src/assets/img/icons/reviews.d.ts +1 -0
  70. package/dist/src/assets/img/icons/reviews.js +11 -0
  71. package/dist/src/assets/img/icons/reviews.js.map +1 -0
  72. package/dist/src/assets/img/icons/upload.d.ts +1 -0
  73. package/dist/src/assets/img/icons/upload.js +12 -0
  74. package/dist/src/assets/img/icons/upload.js.map +1 -0
  75. package/dist/src/assets/img/icons/views.d.ts +1 -0
  76. package/dist/src/assets/img/icons/views.js +11 -0
  77. package/dist/src/assets/img/icons/views.js.map +1 -0
  78. package/dist/src/circular-activity-indicator.d.ts +5 -0
  79. package/dist/src/circular-activity-indicator.js +66 -0
  80. package/dist/src/circular-activity-indicator.js.map +1 -0
  81. package/dist/src/collection-browser.d.ts +214 -0
  82. package/dist/src/collection-browser.js +1242 -0
  83. package/dist/src/collection-browser.js.map +1 -0
  84. package/dist/src/collection-facets.d.ts +63 -0
  85. package/dist/src/collection-facets.js +560 -0
  86. package/dist/src/collection-facets.js.map +1 -0
  87. package/dist/src/empty-placeholder.d.ts +11 -0
  88. package/dist/src/empty-placeholder.js +83 -0
  89. package/dist/src/empty-placeholder.js.map +1 -0
  90. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -0
  91. package/dist/src/language-code-handler/language-code-handler.js +27 -0
  92. package/dist/src/language-code-handler/language-code-handler.js.map +1 -0
  93. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -0
  94. package/dist/src/language-code-handler/language-code-mapping.js +563 -0
  95. package/dist/src/language-code-handler/language-code-mapping.js.map +1 -0
  96. package/dist/src/mediatype/mediatype-config.d.ts +3 -0
  97. package/dist/src/mediatype/mediatype-config.js +86 -0
  98. package/dist/src/mediatype/mediatype-config.js.map +1 -0
  99. package/dist/src/models.d.ts +85 -0
  100. package/dist/src/models.js +62 -0
  101. package/dist/src/models.js.map +1 -0
  102. package/dist/src/restoration-state-handler.d.ts +38 -0
  103. package/dist/src/restoration-state-handler.js +204 -0
  104. package/dist/src/restoration-state-handler.js.map +1 -0
  105. package/dist/src/sort-filter-bar/alpha-bar.d.ts +9 -0
  106. package/dist/src/sort-filter-bar/alpha-bar.js +98 -0
  107. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
  108. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -0
  109. package/dist/src/sort-filter-bar/img/compact.js +5 -0
  110. package/dist/src/sort-filter-bar/img/compact.js.map +1 -0
  111. package/dist/src/sort-filter-bar/img/list.d.ts +1 -0
  112. package/dist/src/sort-filter-bar/img/list.js +5 -0
  113. package/dist/src/sort-filter-bar/img/list.js.map +1 -0
  114. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -0
  115. package/dist/src/sort-filter-bar/img/sort-triangle.js +5 -0
  116. package/dist/src/sort-filter-bar/img/sort-triangle.js.map +1 -0
  117. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -0
  118. package/dist/src/sort-filter-bar/img/tile.js +5 -0
  119. package/dist/src/sort-filter-bar/img/tile.js.map +1 -0
  120. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +107 -0
  121. package/dist/src/sort-filter-bar/sort-filter-bar.js +782 -0
  122. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
  123. package/dist/src/styles/item-image-styles.d.ts +8 -0
  124. package/dist/src/styles/item-image-styles.js +102 -0
  125. package/dist/src/styles/item-image-styles.js.map +1 -0
  126. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -0
  127. package/dist/src/tiles/collection-browser-loading-tile.js +32 -0
  128. package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -0
  129. package/dist/src/tiles/grid/account-tile.d.ts +8 -0
  130. package/dist/src/tiles/grid/account-tile.js +126 -0
  131. package/dist/src/tiles/grid/account-tile.js.map +1 -0
  132. package/dist/src/tiles/grid/collection-tile.d.ts +7 -0
  133. package/dist/src/tiles/grid/collection-tile.js +159 -0
  134. package/dist/src/tiles/grid/collection-tile.js.map +1 -0
  135. package/dist/src/tiles/grid/item-tile.d.ts +21 -0
  136. package/dist/src/tiles/grid/item-tile.js +183 -0
  137. package/dist/src/tiles/grid/item-tile.js.map +1 -0
  138. package/dist/src/tiles/grid/tile-stats.d.ts +10 -0
  139. package/dist/src/tiles/grid/tile-stats.js +134 -0
  140. package/dist/src/tiles/grid/tile-stats.js.map +1 -0
  141. package/dist/src/tiles/image-block.d.ts +17 -0
  142. package/dist/src/tiles/image-block.js +136 -0
  143. package/dist/src/tiles/image-block.js.map +1 -0
  144. package/dist/src/tiles/item-image.d.ts +31 -0
  145. package/dist/src/tiles/item-image.js +118 -0
  146. package/dist/src/tiles/item-image.js.map +1 -0
  147. package/dist/src/tiles/list/account-label.d.ts +1 -0
  148. package/dist/src/tiles/list/account-label.js +7 -0
  149. package/dist/src/tiles/list/account-label.js.map +1 -0
  150. package/dist/src/tiles/list/date-label.d.ts +1 -0
  151. package/dist/src/tiles/list/date-label.js +13 -0
  152. package/dist/src/tiles/list/date-label.js.map +1 -0
  153. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -0
  154. package/dist/src/tiles/list/tile-list-compact-header.js +84 -0
  155. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -0
  156. package/dist/src/tiles/list/tile-list-compact.d.ts +20 -0
  157. package/dist/src/tiles/list/tile-list-compact.js +180 -0
  158. package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
  159. package/dist/src/tiles/list/tile-list.d.ts +48 -0
  160. package/dist/src/tiles/list/tile-list.js +455 -0
  161. package/dist/src/tiles/list/tile-list.js.map +1 -0
  162. package/dist/src/tiles/mediatype-icon.d.ts +9 -0
  163. package/dist/src/tiles/mediatype-icon.js +82 -0
  164. package/dist/src/tiles/mediatype-icon.js.map +1 -0
  165. package/dist/src/tiles/overlay/icon-overlay.d.ts +7 -0
  166. package/dist/src/tiles/overlay/icon-overlay.js +43 -0
  167. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -0
  168. package/dist/src/tiles/overlay/text-overlay.d.ts +8 -0
  169. package/dist/src/tiles/overlay/text-overlay.js +57 -0
  170. package/dist/src/tiles/overlay/text-overlay.js.map +1 -0
  171. package/dist/src/tiles/tile-dispatcher.d.ts +36 -0
  172. package/dist/src/tiles/tile-dispatcher.js +215 -0
  173. package/dist/src/tiles/tile-dispatcher.js.map +1 -0
  174. package/dist/src/utils/format-count.d.ts +7 -0
  175. package/dist/src/utils/format-count.js +76 -0
  176. package/dist/src/utils/format-count.js.map +1 -0
  177. package/dist/src/utils/format-date.d.ts +2 -0
  178. package/dist/src/utils/format-date.js +24 -0
  179. package/dist/src/utils/format-date.js.map +1 -0
  180. package/dist/test/collection-browser.test.d.ts +1 -0
  181. package/dist/test/collection-browser.test.js +82 -0
  182. package/dist/test/collection-browser.test.js.map +1 -0
  183. package/dist/test/empty-placeholder.test.d.ts +1 -0
  184. package/dist/test/empty-placeholder.test.js +34 -0
  185. package/dist/test/empty-placeholder.test.js.map +1 -0
  186. package/dist/test/icon-overlay.test.d.ts +1 -0
  187. package/dist/test/icon-overlay.test.js +31 -0
  188. package/dist/test/icon-overlay.test.js.map +1 -0
  189. package/dist/test/item-image.test.d.ts +1 -0
  190. package/dist/test/item-image.test.js +73 -0
  191. package/dist/test/item-image.test.js.map +1 -0
  192. package/dist/test/mediatype-config.test.d.ts +1 -0
  193. package/dist/test/mediatype-config.test.js +17 -0
  194. package/dist/test/mediatype-config.test.js.map +1 -0
  195. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -0
  196. package/dist/test/mocks/mock-collection-name-cache.js +14 -0
  197. package/dist/test/mocks/mock-collection-name-cache.js.map +1 -0
  198. package/dist/test/mocks/mock-search-responses.d.ts +3 -0
  199. package/dist/test/mocks/mock-search-responses.js +32 -0
  200. package/dist/test/mocks/mock-search-responses.js.map +1 -0
  201. package/dist/test/mocks/mock-search-service.d.ts +8 -0
  202. package/dist/test/mocks/mock-search-service.js +16 -0
  203. package/dist/test/mocks/mock-search-service.js.map +1 -0
  204. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -0
  205. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +122 -0
  206. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -0
  207. package/dist/test/text-overlay.test.d.ts +1 -0
  208. package/dist/test/text-overlay.test.js +48 -0
  209. package/dist/test/text-overlay.test.js.map +1 -0
  210. package/dist/test/tile-stats.test.d.ts +1 -0
  211. package/dist/test/tile-stats.test.js +42 -0
  212. package/dist/test/tile-stats.test.js.map +1 -0
  213. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -0
  214. package/dist/test/tiles/grid/item-tile.test.js +96 -0
  215. package/dist/test/tiles/grid/item-tile.test.js.map +1 -0
  216. package/dist/test/utils/format-count.test.d.ts +1 -0
  217. package/dist/test/utils/format-count.test.js +24 -0
  218. package/dist/test/utils/format-count.test.js.map +1 -0
  219. package/dist/test/utils/format-date.test.d.ts +1 -0
  220. package/dist/test/utils/format-date.test.js +18 -0
  221. package/dist/test/utils/format-date.test.js.map +1 -0
  222. package/package.json +1 -1
@@ -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 { css, CSSResultGroup, html, LitElement } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { ClassInfo, classMap } from 'lit/directives/class-map.js';\n\nimport type { TileModel } from '../models';\n\nimport {\n baseItemImageStyles,\n waveformGradientStyles,\n} from '../styles/item-image-styles';\n\n@customElement('item-image')\nexport class ItemImage extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: String }) baseImageUrl?: string;\n\n @property({ type: Boolean }) isListTile = false;\n\n @property({ type: Boolean }) isCompactTile = false;\n\n @property({ type: Boolean }) loggedIn = false;\n\n @state() private isWaveform = false;\n\n @query('img') private baseImage!: HTMLImageElement;\n\n render() {\n return html`\n <div class=${classMap(this.itemBaseClass)}>\n <img\n class=${classMap(this.itemImageClass)}\n src=\"${this.imageSrc}\"\n alt=\"\"\n @load=${this.onLoad}\n />\n </div>\n `;\n }\n\n /**\n * Helpers\n */\n private get imageSrc() {\n return `${this.baseImageUrl}/services/img/${this.model?.identifier}`;\n }\n\n private get hashBasedGradient() {\n if (!this.model?.identifier) {\n return 'waveform-grad0';\n }\n const gradient = this.hashStrToInt(this.model.identifier) % 6; // returns 0-5\n return `waveform-grad${gradient}`;\n }\n\n private hashStrToInt(str: string): number {\n return str\n .split('')\n .reduce((acc: number, char: string) => acc + char.charCodeAt(0), 0);\n }\n\n /**\n * Classes\n */\n private get itemBaseClass(): ClassInfo {\n return {\n 'drop-shadow': true,\n 'list-box': this.isListTile,\n [this.hashBasedGradient]: this.isWaveform,\n };\n }\n\n private get itemImageClass(): ClassInfo {\n const toBlur = this.model?.contentWarning || this.model?.loginRequired;\n\n return {\n contain: !this.isCompactTile && !this.isWaveform,\n cover: this.isCompactTile,\n blur: toBlur || false,\n waveform: this.isWaveform,\n };\n }\n\n /**\n * Event listener sets isWaveform true if image is waveform\n */\n private onLoad() {\n if (\n (this.model?.mediatype === 'audio' ||\n this.model?.mediatype === 'etree') &&\n this.baseImage.naturalWidth / this.baseImage.naturalHeight === 4\n ) {\n this.isWaveform = true;\n }\n }\n\n /**\n * CSS\n */\n static get styles(): CSSResultGroup {\n return [\n baseItemImageStyles,\n waveformGradientStyles,\n css`\n img {\n height: var(--imgHeight, 16rem);\n width: var(--imgWidth, 16rem);\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 type { SortParam } from '@internetarchive/search-service';
3
+ import type { 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 type { SortParam } from '@internetarchive/search-service';\nimport { dateLabel } from './date-label';\nimport type { 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"]}
@@ -0,0 +1,20 @@
1
+ import { LitElement } from 'lit';
2
+ import type { SortParam } from '@internetarchive/search-service';
3
+ import type { TileModel } from '../../models';
4
+ import '../image-block';
5
+ import '../mediatype-icon';
6
+ export declare class TileListCompact extends LitElement {
7
+ model?: TileModel;
8
+ baseNavigationUrl?: string;
9
+ currentWidth?: number;
10
+ currentHeight?: number;
11
+ sortParam: SortParam | null;
12
+ mobileBreakpoint?: number;
13
+ baseImageUrl?: string;
14
+ loggedIn: boolean;
15
+ render(): import("lit-html").TemplateResult<1>;
16
+ private get date();
17
+ private get classSize();
18
+ private get formatSize();
19
+ static get styles(): import("lit").CSSResult;
20
+ }
@@ -0,0 +1,180 @@
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import DOMPurify from 'dompurify';
5
+ import { formatCount } from '../../utils/format-count';
6
+ import { formatDate } from '../../utils/format-date';
7
+ import { accountLabel } from './account-label';
8
+ import '../image-block';
9
+ import '../mediatype-icon';
10
+ let TileListCompact = class TileListCompact extends LitElement {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.sortParam = null;
14
+ this.loggedIn = false;
15
+ }
16
+ render() {
17
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
18
+ return html `
19
+ <div id="list-line" class="${this.classSize}">
20
+ <image-block
21
+ .model=${this.model}
22
+ .baseImageUrl=${this.baseImageUrl}
23
+ .isCompactTile=${true}
24
+ .isListTile=${true}
25
+ .viewSize=${this.classSize}
26
+ >
27
+ </image-block>
28
+ <div id="title">${DOMPurify.sanitize((_b = (_a = this.model) === null || _a === void 0 ? void 0 : _a.title) !== null && _b !== void 0 ? _b : '')}</div>
29
+ <div id="creator">
30
+ ${((_c = this.model) === null || _c === void 0 ? void 0 : _c.mediatype) === 'account'
31
+ ? accountLabel((_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded)
32
+ : DOMPurify.sanitize((_f = (_e = this.model) === null || _e === void 0 ? void 0 : _e.creator) !== null && _f !== void 0 ? _f : '')}
33
+ </div>
34
+ <div id="date">${formatDate(this.date, this.formatSize)}</div>
35
+ <div id="icon">
36
+ <mediatype-icon
37
+ .mediatype=${(_g = this.model) === null || _g === void 0 ? void 0 : _g.mediatype}
38
+ .collections=${(_h = this.model) === null || _h === void 0 ? void 0 : _h.collections}
39
+ >
40
+ </mediatype-icon>
41
+ </div>
42
+ <div id="views">
43
+ ${formatCount((_k = (_j = this.model) === null || _j === void 0 ? void 0 : _j.viewCount) !== null && _k !== void 0 ? _k : 0, this.formatSize)}
44
+ </div>
45
+ </div>
46
+ `;
47
+ }
48
+ /*
49
+ * TODO: fix field names to match model in src/collection-browser.ts
50
+ * private get dateSortSelector()
51
+ * @see src/models.ts
52
+ */
53
+ get date() {
54
+ var _a, _b, _c, _d, _e;
55
+ switch ((_a = this.sortParam) === null || _a === void 0 ? void 0 : _a.field) {
56
+ case 'date':
57
+ return (_b = this.model) === null || _b === void 0 ? void 0 : _b.datePublished;
58
+ case 'reviewdate':
59
+ return (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateReviewed;
60
+ case 'addeddate':
61
+ return (_d = this.model) === null || _d === void 0 ? void 0 : _d.dateAdded;
62
+ default:
63
+ return (_e = this.model) === null || _e === void 0 ? void 0 : _e.dateArchived; // publicdate
64
+ }
65
+ }
66
+ get classSize() {
67
+ if (this.mobileBreakpoint &&
68
+ this.currentWidth &&
69
+ this.currentWidth < this.mobileBreakpoint) {
70
+ return 'mobile';
71
+ }
72
+ return 'desktop';
73
+ }
74
+ get formatSize() {
75
+ if (this.mobileBreakpoint &&
76
+ this.currentWidth &&
77
+ this.currentWidth < this.mobileBreakpoint) {
78
+ return 'short';
79
+ }
80
+ return 'long';
81
+ }
82
+ static get styles() {
83
+ return css `
84
+ html {
85
+ font-size: unset;
86
+ }
87
+
88
+ div {
89
+ font-size: 14px;
90
+ }
91
+
92
+ #list-line {
93
+ display: grid;
94
+ column-gap: 10px;
95
+ border-top: 1px solid #ddd;
96
+ align-items: center;
97
+ line-height: 20px;
98
+ padding-top: 5px;
99
+ padding-bottom: 5px;
100
+ }
101
+
102
+ #list-line.mobile {
103
+ grid-template-columns: 36px 3fr 2fr 62px 19px;
104
+ }
105
+
106
+ #list-line.desktop {
107
+ grid-template-columns: 51px 3fr 2fr 100px 20px 60px;
108
+ }
109
+
110
+ #list-line:hover #title {
111
+ text-decoration: underline;
112
+ }
113
+
114
+ #title {
115
+ color: #4b64ff;
116
+ text-decoration: none;
117
+ }
118
+
119
+ #title,
120
+ #creator {
121
+ text-overflow: ellipsis;
122
+ overflow: hidden;
123
+ white-space: nowrap;
124
+ }
125
+
126
+ #views {
127
+ text-align: right;
128
+ padding-right: 8px;
129
+ }
130
+
131
+ .mobile #views {
132
+ display: none;
133
+ }
134
+
135
+ .mobile mediatype-icon {
136
+ --iconHeight: 14px;
137
+ --iconWidth: 14px;
138
+ }
139
+
140
+ .desktop #icon {
141
+ --iconHeight: 20px;
142
+ --iconWidth: 20px;
143
+ }
144
+
145
+ item-image {
146
+ --imgHeight: 100%;
147
+ --imgWidth: 100%;
148
+ }
149
+ `;
150
+ }
151
+ };
152
+ __decorate([
153
+ property({ type: Object })
154
+ ], TileListCompact.prototype, "model", void 0);
155
+ __decorate([
156
+ property({ type: String })
157
+ ], TileListCompact.prototype, "baseNavigationUrl", void 0);
158
+ __decorate([
159
+ property({ type: Number })
160
+ ], TileListCompact.prototype, "currentWidth", void 0);
161
+ __decorate([
162
+ property({ type: Number })
163
+ ], TileListCompact.prototype, "currentHeight", void 0);
164
+ __decorate([
165
+ property({ type: Object })
166
+ ], TileListCompact.prototype, "sortParam", void 0);
167
+ __decorate([
168
+ property({ type: Number })
169
+ ], TileListCompact.prototype, "mobileBreakpoint", void 0);
170
+ __decorate([
171
+ property({ type: String })
172
+ ], TileListCompact.prototype, "baseImageUrl", void 0);
173
+ __decorate([
174
+ property({ type: Boolean })
175
+ ], TileListCompact.prototype, "loggedIn", void 0);
176
+ TileListCompact = __decorate([
177
+ customElement('tile-list-compact')
178
+ ], TileListCompact);
179
+ export { TileListCompact };
180
+ //# sourceMappingURL=tile-list-compact.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tile-list-compact.js","sourceRoot":"","sources":["../../../../src/tiles/list/tile-list-compact.ts"],"names":[],"mappings":"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","sourcesContent":["import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport DOMPurify from 'dompurify';\nimport type { SortParam } from '@internetarchive/search-service';\nimport type { TileModel } from '../../models';\n\nimport { formatCount, NumberFormat } from '../../utils/format-count';\nimport { formatDate, DateFormat } from '../../utils/format-date';\nimport { accountLabel } from './account-label';\n\nimport '../image-block';\nimport '../mediatype-icon';\n\n@customElement('tile-list-compact')\nexport class TileListCompact extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n @property({ type: String }) baseNavigationUrl?: string;\n\n @property({ type: Number }) currentWidth?: number;\n\n @property({ type: Number }) currentHeight?: number;\n\n @property({ type: Object }) sortParam: SortParam | null = null;\n\n @property({ type: Number }) mobileBreakpoint?: number;\n\n @property({ type: String }) baseImageUrl?: string;\n\n @property({ type: Boolean }) loggedIn = false;\n\n render() {\n return html`\n <div id=\"list-line\" class=\"${this.classSize}\">\n <image-block\n .model=${this.model}\n .baseImageUrl=${this.baseImageUrl}\n .isCompactTile=${true}\n .isListTile=${true}\n .viewSize=${this.classSize}\n >\n </image-block>\n <div id=\"title\">${DOMPurify.sanitize(this.model?.title ?? '')}</div>\n <div id=\"creator\">\n ${this.model?.mediatype === 'account'\n ? accountLabel(this.model?.dateAdded)\n : DOMPurify.sanitize(this.model?.creator ?? '')}\n </div>\n <div id=\"date\">${formatDate(this.date, this.formatSize)}</div>\n <div id=\"icon\">\n <mediatype-icon\n .mediatype=${this.model?.mediatype}\n .collections=${this.model?.collections}\n >\n </mediatype-icon>\n </div>\n <div id=\"views\">\n ${formatCount(this.model?.viewCount ?? 0, this.formatSize)}\n </div>\n </div>\n `;\n }\n\n /*\n * TODO: fix field names to match model in src/collection-browser.ts\n * private get dateSortSelector()\n * @see src/models.ts\n */\n private get date(): Date | undefined {\n switch (this.sortParam?.field) {\n case 'date':\n return this.model?.datePublished;\n case 'reviewdate':\n return this.model?.dateReviewed;\n case 'addeddate':\n return this.model?.dateAdded;\n default:\n return this.model?.dateArchived; // publicdate\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 private get formatSize(): DateFormat | NumberFormat {\n if (\n this.mobileBreakpoint &&\n this.currentWidth &&\n this.currentWidth < this.mobileBreakpoint\n ) {\n return 'short';\n }\n return 'long';\n }\n\n static get styles() {\n return css`\n html {\n font-size: unset;\n }\n\n div {\n font-size: 14px;\n }\n\n #list-line {\n display: grid;\n column-gap: 10px;\n border-top: 1px solid #ddd;\n align-items: center;\n line-height: 20px;\n padding-top: 5px;\n padding-bottom: 5px;\n }\n\n #list-line.mobile {\n grid-template-columns: 36px 3fr 2fr 62px 19px;\n }\n\n #list-line.desktop {\n grid-template-columns: 51px 3fr 2fr 100px 20px 60px;\n }\n\n #list-line:hover #title {\n text-decoration: underline;\n }\n\n #title {\n color: #4b64ff;\n text-decoration: none;\n }\n\n #title,\n #creator {\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n }\n\n #views {\n text-align: right;\n padding-right: 8px;\n }\n\n .mobile #views {\n display: none;\n }\n\n .mobile mediatype-icon {\n --iconHeight: 14px;\n --iconWidth: 14px;\n }\n\n .desktop #icon {\n --iconHeight: 20px;\n --iconWidth: 20px;\n }\n\n item-image {\n --imgHeight: 100%;\n --imgWidth: 100%;\n }\n `;\n }\n}\n"]}
@@ -0,0 +1,48 @@
1
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
3
+ import type { SortParam } from '@internetarchive/search-service';
4
+ import type { TileModel } from '../../models';
5
+ import '../image-block';
6
+ import '../mediatype-icon';
7
+ export declare class TileList extends LitElement {
8
+ model?: TileModel;
9
+ baseNavigationUrl?: string;
10
+ collectionNameCache?: CollectionNameCacheInterface;
11
+ currentWidth?: number;
12
+ currentHeight?: number;
13
+ sortParam: SortParam | null;
14
+ mobileBreakpoint?: number;
15
+ private collectionLinks;
16
+ baseImageUrl?: string;
17
+ loggedIn: boolean;
18
+ protected updated(changed: PropertyValues): void;
19
+ private fetchCollectionNames;
20
+ render(): TemplateResult<1>;
21
+ private get mobileTemplate();
22
+ private get desktopTemplate();
23
+ private get imageBlockTemplate();
24
+ private get detailsTemplate();
25
+ private get iconRightTemplate();
26
+ private get titleTemplate();
27
+ private get itemLineTemplate();
28
+ private get sourceTemplate();
29
+ private get volumeTemplate();
30
+ private get issueTemplate();
31
+ private get creatorTemplate();
32
+ private get datePublishedTemplate();
33
+ private get dateSortByTemplate();
34
+ private get viewsTemplate();
35
+ private get ratingTemplate();
36
+ private get reviewsTemplate();
37
+ private get topicsTemplate();
38
+ private get collectionsTemplate();
39
+ private get descriptionTemplate();
40
+ private metadataTemplate;
41
+ private labelTemplate;
42
+ private searchLink;
43
+ private detailsLink;
44
+ private get date();
45
+ private get classSize();
46
+ private get formatSize();
47
+ static get styles(): import("lit").CSSResult;
48
+ }