@internetarchive/collection-browser 0.2.10 → 0.2.11

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