@internetarchive/collection-browser 0.2.14 → 0.2.15

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 (224) hide show
  1. package/package.json +1 -1
  2. package/src/collection-browser.ts +2 -1
  3. package/src/models.ts +9 -4
  4. package/src/sort-filter-bar/sort-filter-bar.ts +98 -12
  5. package/test/collection-browser.test.ts +43 -0
  6. package/test/sort-filter-bar/sort-filter-bar.test.ts +187 -0
  7. package/dist/index.d.ts +0 -9
  8. package/dist/index.js.map +0 -1
  9. package/dist/src/app-root.d.ts +0 -32
  10. package/dist/src/app-root.js +0 -285
  11. package/dist/src/app-root.js.map +0 -1
  12. package/dist/src/assets/img/icons/chevron.d.ts +0 -2
  13. package/dist/src/assets/img/icons/chevron.js +0 -4
  14. package/dist/src/assets/img/icons/chevron.js.map +0 -1
  15. package/dist/src/assets/img/icons/empty-query.d.ts +0 -2
  16. package/dist/src/assets/img/icons/empty-query.js +0 -5
  17. package/dist/src/assets/img/icons/empty-query.js.map +0 -1
  18. package/dist/src/assets/img/icons/eye-closed.d.ts +0 -2
  19. package/dist/src/assets/img/icons/eye-closed.js +0 -5
  20. package/dist/src/assets/img/icons/eye-closed.js.map +0 -1
  21. package/dist/src/assets/img/icons/eye.d.ts +0 -2
  22. package/dist/src/assets/img/icons/eye.js +0 -5
  23. package/dist/src/assets/img/icons/eye.js.map +0 -1
  24. package/dist/src/assets/img/icons/favorite-filled.d.ts +0 -1
  25. package/dist/src/assets/img/icons/favorite-filled.js +0 -11
  26. package/dist/src/assets/img/icons/favorite-filled.js.map +0 -1
  27. package/dist/src/assets/img/icons/login-required.d.ts +0 -1
  28. package/dist/src/assets/img/icons/login-required.js +0 -30
  29. package/dist/src/assets/img/icons/login-required.js.map +0 -1
  30. package/dist/src/assets/img/icons/mediatype/account.d.ts +0 -1
  31. package/dist/src/assets/img/icons/mediatype/account.js +0 -14
  32. package/dist/src/assets/img/icons/mediatype/account.js.map +0 -1
  33. package/dist/src/assets/img/icons/mediatype/audio.d.ts +0 -1
  34. package/dist/src/assets/img/icons/mediatype/audio.js +0 -14
  35. package/dist/src/assets/img/icons/mediatype/audio.js.map +0 -1
  36. package/dist/src/assets/img/icons/mediatype/collection.d.ts +0 -1
  37. package/dist/src/assets/img/icons/mediatype/collection.js +0 -12
  38. package/dist/src/assets/img/icons/mediatype/collection.js.map +0 -1
  39. package/dist/src/assets/img/icons/mediatype/data.d.ts +0 -1
  40. package/dist/src/assets/img/icons/mediatype/data.js +0 -15
  41. package/dist/src/assets/img/icons/mediatype/data.js.map +0 -1
  42. package/dist/src/assets/img/icons/mediatype/etree.d.ts +0 -1
  43. package/dist/src/assets/img/icons/mediatype/etree.js +0 -14
  44. package/dist/src/assets/img/icons/mediatype/etree.js.map +0 -1
  45. package/dist/src/assets/img/icons/mediatype/film.d.ts +0 -1
  46. package/dist/src/assets/img/icons/mediatype/film.js +0 -14
  47. package/dist/src/assets/img/icons/mediatype/film.js.map +0 -1
  48. package/dist/src/assets/img/icons/mediatype/images.d.ts +0 -1
  49. package/dist/src/assets/img/icons/mediatype/images.js +0 -13
  50. package/dist/src/assets/img/icons/mediatype/images.js.map +0 -1
  51. package/dist/src/assets/img/icons/mediatype/radio.d.ts +0 -1
  52. package/dist/src/assets/img/icons/mediatype/radio.js +0 -15
  53. package/dist/src/assets/img/icons/mediatype/radio.js.map +0 -1
  54. package/dist/src/assets/img/icons/mediatype/software.d.ts +0 -1
  55. package/dist/src/assets/img/icons/mediatype/software.js +0 -13
  56. package/dist/src/assets/img/icons/mediatype/software.js.map +0 -1
  57. package/dist/src/assets/img/icons/mediatype/texts.d.ts +0 -1
  58. package/dist/src/assets/img/icons/mediatype/texts.js +0 -13
  59. package/dist/src/assets/img/icons/mediatype/texts.js.map +0 -1
  60. package/dist/src/assets/img/icons/mediatype/tv.d.ts +0 -1
  61. package/dist/src/assets/img/icons/mediatype/tv.js +0 -14
  62. package/dist/src/assets/img/icons/mediatype/tv.js.map +0 -1
  63. package/dist/src/assets/img/icons/mediatype/video.d.ts +0 -1
  64. package/dist/src/assets/img/icons/mediatype/video.js +0 -14
  65. package/dist/src/assets/img/icons/mediatype/video.js.map +0 -1
  66. package/dist/src/assets/img/icons/mediatype/web.d.ts +0 -1
  67. package/dist/src/assets/img/icons/mediatype/web.js +0 -13
  68. package/dist/src/assets/img/icons/mediatype/web.js.map +0 -1
  69. package/dist/src/assets/img/icons/null-result.d.ts +0 -2
  70. package/dist/src/assets/img/icons/null-result.js +0 -5
  71. package/dist/src/assets/img/icons/null-result.js.map +0 -1
  72. package/dist/src/assets/img/icons/restricted.d.ts +0 -1
  73. package/dist/src/assets/img/icons/restricted.js +0 -29
  74. package/dist/src/assets/img/icons/restricted.js.map +0 -1
  75. package/dist/src/assets/img/icons/reviews.d.ts +0 -1
  76. package/dist/src/assets/img/icons/reviews.js +0 -11
  77. package/dist/src/assets/img/icons/reviews.js.map +0 -1
  78. package/dist/src/assets/img/icons/upload.d.ts +0 -1
  79. package/dist/src/assets/img/icons/upload.js +0 -12
  80. package/dist/src/assets/img/icons/upload.js.map +0 -1
  81. package/dist/src/assets/img/icons/views.d.ts +0 -1
  82. package/dist/src/assets/img/icons/views.js +0 -11
  83. package/dist/src/assets/img/icons/views.js.map +0 -1
  84. package/dist/src/circular-activity-indicator.d.ts +0 -5
  85. package/dist/src/circular-activity-indicator.js +0 -66
  86. package/dist/src/circular-activity-indicator.js.map +0 -1
  87. package/dist/src/collection-browser.d.ts +0 -214
  88. package/dist/src/collection-browser.js +0 -1241
  89. package/dist/src/collection-browser.js.map +0 -1
  90. package/dist/src/collection-facets.d.ts +0 -63
  91. package/dist/src/collection-facets.js +0 -560
  92. package/dist/src/collection-facets.js.map +0 -1
  93. package/dist/src/empty-placeholder.d.ts +0 -11
  94. package/dist/src/empty-placeholder.js +0 -83
  95. package/dist/src/empty-placeholder.js.map +0 -1
  96. package/dist/src/language-code-handler/language-code-handler.d.ts +0 -37
  97. package/dist/src/language-code-handler/language-code-handler.js +0 -27
  98. package/dist/src/language-code-handler/language-code-handler.js.map +0 -1
  99. package/dist/src/language-code-handler/language-code-mapping.d.ts +0 -1
  100. package/dist/src/language-code-handler/language-code-mapping.js +0 -563
  101. package/dist/src/language-code-handler/language-code-mapping.js.map +0 -1
  102. package/dist/src/mediatype/mediatype-config.d.ts +0 -3
  103. package/dist/src/mediatype/mediatype-config.js +0 -86
  104. package/dist/src/mediatype/mediatype-config.js.map +0 -1
  105. package/dist/src/models.d.ts +0 -84
  106. package/dist/src/models.js +0 -58
  107. package/dist/src/models.js.map +0 -1
  108. package/dist/src/restoration-state-handler.d.ts +0 -38
  109. package/dist/src/restoration-state-handler.js +0 -204
  110. package/dist/src/restoration-state-handler.js.map +0 -1
  111. package/dist/src/sort-filter-bar/alpha-bar.d.ts +0 -9
  112. package/dist/src/sort-filter-bar/alpha-bar.js +0 -98
  113. package/dist/src/sort-filter-bar/alpha-bar.js.map +0 -1
  114. package/dist/src/sort-filter-bar/img/compact.d.ts +0 -1
  115. package/dist/src/sort-filter-bar/img/compact.js +0 -5
  116. package/dist/src/sort-filter-bar/img/compact.js.map +0 -1
  117. package/dist/src/sort-filter-bar/img/list.d.ts +0 -1
  118. package/dist/src/sort-filter-bar/img/list.js +0 -5
  119. package/dist/src/sort-filter-bar/img/list.js.map +0 -1
  120. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +0 -1
  121. package/dist/src/sort-filter-bar/img/sort-triangle.js +0 -5
  122. package/dist/src/sort-filter-bar/img/sort-triangle.js.map +0 -1
  123. package/dist/src/sort-filter-bar/img/tile.d.ts +0 -1
  124. package/dist/src/sort-filter-bar/img/tile.js +0 -5
  125. package/dist/src/sort-filter-bar/img/tile.js.map +0 -1
  126. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +0 -85
  127. package/dist/src/sort-filter-bar/sort-filter-bar.js +0 -698
  128. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +0 -1
  129. package/dist/src/styles/item-image-styles.d.ts +0 -8
  130. package/dist/src/styles/item-image-styles.js +0 -102
  131. package/dist/src/styles/item-image-styles.js.map +0 -1
  132. package/dist/src/tiles/collection-browser-loading-tile.d.ts +0 -5
  133. package/dist/src/tiles/collection-browser-loading-tile.js +0 -32
  134. package/dist/src/tiles/collection-browser-loading-tile.js.map +0 -1
  135. package/dist/src/tiles/grid/account-tile.d.ts +0 -8
  136. package/dist/src/tiles/grid/account-tile.js +0 -126
  137. package/dist/src/tiles/grid/account-tile.js.map +0 -1
  138. package/dist/src/tiles/grid/collection-tile.d.ts +0 -7
  139. package/dist/src/tiles/grid/collection-tile.js +0 -159
  140. package/dist/src/tiles/grid/collection-tile.js.map +0 -1
  141. package/dist/src/tiles/grid/item-tile.d.ts +0 -21
  142. package/dist/src/tiles/grid/item-tile.js +0 -183
  143. package/dist/src/tiles/grid/item-tile.js.map +0 -1
  144. package/dist/src/tiles/grid/tile-stats.d.ts +0 -10
  145. package/dist/src/tiles/grid/tile-stats.js +0 -134
  146. package/dist/src/tiles/grid/tile-stats.js.map +0 -1
  147. package/dist/src/tiles/image-block.d.ts +0 -17
  148. package/dist/src/tiles/image-block.js +0 -136
  149. package/dist/src/tiles/image-block.js.map +0 -1
  150. package/dist/src/tiles/item-image.d.ts +0 -31
  151. package/dist/src/tiles/item-image.js +0 -118
  152. package/dist/src/tiles/item-image.js.map +0 -1
  153. package/dist/src/tiles/list/account-label.d.ts +0 -1
  154. package/dist/src/tiles/list/account-label.js +0 -7
  155. package/dist/src/tiles/list/account-label.js.map +0 -1
  156. package/dist/src/tiles/list/date-label.d.ts +0 -1
  157. package/dist/src/tiles/list/date-label.js +0 -13
  158. package/dist/src/tiles/list/date-label.js.map +0 -1
  159. package/dist/src/tiles/list/tile-list-compact-header.d.ts +0 -12
  160. package/dist/src/tiles/list/tile-list-compact-header.js +0 -84
  161. package/dist/src/tiles/list/tile-list-compact-header.js.map +0 -1
  162. package/dist/src/tiles/list/tile-list-compact.d.ts +0 -20
  163. package/dist/src/tiles/list/tile-list-compact.js +0 -180
  164. package/dist/src/tiles/list/tile-list-compact.js.map +0 -1
  165. package/dist/src/tiles/list/tile-list.d.ts +0 -48
  166. package/dist/src/tiles/list/tile-list.js +0 -455
  167. package/dist/src/tiles/list/tile-list.js.map +0 -1
  168. package/dist/src/tiles/mediatype-icon.d.ts +0 -9
  169. package/dist/src/tiles/mediatype-icon.js +0 -82
  170. package/dist/src/tiles/mediatype-icon.js.map +0 -1
  171. package/dist/src/tiles/overlay/icon-overlay.d.ts +0 -7
  172. package/dist/src/tiles/overlay/icon-overlay.js +0 -43
  173. package/dist/src/tiles/overlay/icon-overlay.js.map +0 -1
  174. package/dist/src/tiles/overlay/text-overlay.d.ts +0 -8
  175. package/dist/src/tiles/overlay/text-overlay.js +0 -57
  176. package/dist/src/tiles/overlay/text-overlay.js.map +0 -1
  177. package/dist/src/tiles/tile-dispatcher.d.ts +0 -36
  178. package/dist/src/tiles/tile-dispatcher.js +0 -215
  179. package/dist/src/tiles/tile-dispatcher.js.map +0 -1
  180. package/dist/src/utils/format-count.d.ts +0 -7
  181. package/dist/src/utils/format-count.js +0 -76
  182. package/dist/src/utils/format-count.js.map +0 -1
  183. package/dist/src/utils/format-date.d.ts +0 -2
  184. package/dist/src/utils/format-date.js +0 -24
  185. package/dist/src/utils/format-date.js.map +0 -1
  186. package/dist/test/collection-browser.test.d.ts +0 -1
  187. package/dist/test/collection-browser.test.js +0 -47
  188. package/dist/test/collection-browser.test.js.map +0 -1
  189. package/dist/test/empty-placeholder.test.d.ts +0 -1
  190. package/dist/test/empty-placeholder.test.js +0 -34
  191. package/dist/test/empty-placeholder.test.js.map +0 -1
  192. package/dist/test/icon-overlay.test.d.ts +0 -1
  193. package/dist/test/icon-overlay.test.js +0 -31
  194. package/dist/test/icon-overlay.test.js.map +0 -1
  195. package/dist/test/item-image.test.d.ts +0 -1
  196. package/dist/test/item-image.test.js +0 -73
  197. package/dist/test/item-image.test.js.map +0 -1
  198. package/dist/test/mediatype-config.test.d.ts +0 -1
  199. package/dist/test/mediatype-config.test.js +0 -17
  200. package/dist/test/mediatype-config.test.js.map +0 -1
  201. package/dist/test/mocks/mock-collection-name-cache.d.ts +0 -7
  202. package/dist/test/mocks/mock-collection-name-cache.js +0 -14
  203. package/dist/test/mocks/mock-collection-name-cache.js.map +0 -1
  204. package/dist/test/mocks/mock-search-responses.d.ts +0 -3
  205. package/dist/test/mocks/mock-search-responses.js +0 -32
  206. package/dist/test/mocks/mock-search-responses.js.map +0 -1
  207. package/dist/test/mocks/mock-search-service.d.ts +0 -8
  208. package/dist/test/mocks/mock-search-service.js +0 -16
  209. package/dist/test/mocks/mock-search-service.js.map +0 -1
  210. package/dist/test/text-overlay.test.d.ts +0 -1
  211. package/dist/test/text-overlay.test.js +0 -48
  212. package/dist/test/text-overlay.test.js.map +0 -1
  213. package/dist/test/tile-stats.test.d.ts +0 -1
  214. package/dist/test/tile-stats.test.js +0 -42
  215. package/dist/test/tile-stats.test.js.map +0 -1
  216. package/dist/test/tiles/grid/item-tile.test.d.ts +0 -1
  217. package/dist/test/tiles/grid/item-tile.test.js +0 -96
  218. package/dist/test/tiles/grid/item-tile.test.js.map +0 -1
  219. package/dist/test/utils/format-count.test.d.ts +0 -1
  220. package/dist/test/utils/format-count.test.js +0 -24
  221. package/dist/test/utils/format-count.test.js.map +0 -1
  222. package/dist/test/utils/format-date.test.d.ts +0 -1
  223. package/dist/test/utils/format-date.test.js +0 -18
  224. package/dist/test/utils/format-date.test.js.map +0 -1
@@ -1 +0,0 @@
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"]}
@@ -1 +0,0 @@
1
- export declare function accountLabel(date: Date | undefined): string;
@@ -1,7 +0,0 @@
1
- export function accountLabel(date) {
2
- if (!date) {
3
- return '';
4
- }
5
- return `Archivist since ${date.getFullYear()}`;
6
- }
7
- //# sourceMappingURL=account-label.js.map
@@ -1 +0,0 @@
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"]}
@@ -1 +0,0 @@
1
- export declare function dateLabel(sortField: string | undefined): string;
@@ -1,13 +0,0 @@
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
@@ -1 +0,0 @@
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"]}
@@ -1,12 +0,0 @@
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
- }
@@ -1,84 +0,0 @@
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
@@ -1 +0,0 @@
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"]}
@@ -1,20 +0,0 @@
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
- }
@@ -1,180 +0,0 @@
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
@@ -1 +0,0 @@
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"]}
@@ -1,48 +0,0 @@
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
- }