@internetarchive/collection-browser 0.0.1-alpha.1

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 (203) hide show
  1. package/.editorconfig +29 -0
  2. package/.github/workflows/ci.yml +26 -0
  3. package/.husky/pre-commit +4 -0
  4. package/LICENSE +661 -0
  5. package/README.md +68 -0
  6. package/demo/app-root.ts +414 -0
  7. package/demo/index.html +26 -0
  8. package/dist/demo/app-root.d.ts +43 -0
  9. package/dist/demo/app-root.js +385 -0
  10. package/dist/demo/app-root.js.map +1 -0
  11. package/dist/index.d.ts +3 -0
  12. package/dist/index.js +3 -0
  13. package/dist/index.js.map +1 -0
  14. package/dist/src/assets/img/icons/audio.d.ts +1 -0
  15. package/dist/src/assets/img/icons/audio.js +9 -0
  16. package/dist/src/assets/img/icons/audio.js.map +1 -0
  17. package/dist/src/assets/img/icons/collection.d.ts +1 -0
  18. package/dist/src/assets/img/icons/collection.js +9 -0
  19. package/dist/src/assets/img/icons/collection.js.map +1 -0
  20. package/dist/src/assets/img/icons/etree.d.ts +1 -0
  21. package/dist/src/assets/img/icons/etree.js +9 -0
  22. package/dist/src/assets/img/icons/etree.js.map +1 -0
  23. package/dist/src/assets/img/icons/images.d.ts +1 -0
  24. package/dist/src/assets/img/icons/images.js +10 -0
  25. package/dist/src/assets/img/icons/images.js.map +1 -0
  26. package/dist/src/assets/img/icons/mediatype/account.d.ts +2 -0
  27. package/dist/src/assets/img/icons/mediatype/account.js +12 -0
  28. package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
  29. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
  30. package/dist/src/assets/img/icons/mediatype/audio.js +11 -0
  31. package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
  32. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
  33. package/dist/src/assets/img/icons/mediatype/collection.js +9 -0
  34. package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
  35. package/dist/src/assets/img/icons/mediatype/etree copy.d.ts +1 -0
  36. package/dist/src/assets/img/icons/mediatype/etree copy.js +9 -0
  37. package/dist/src/assets/img/icons/mediatype/etree copy.js.map +1 -0
  38. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
  39. package/dist/src/assets/img/icons/mediatype/etree.js +9 -0
  40. package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
  41. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
  42. package/dist/src/assets/img/icons/mediatype/film.js +13 -0
  43. package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
  44. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
  45. package/dist/src/assets/img/icons/mediatype/images.js +10 -0
  46. package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
  47. package/dist/src/assets/img/icons/mediatype/livemusic.d.ts +1 -0
  48. package/dist/src/assets/img/icons/mediatype/livemusic.js +7 -0
  49. package/dist/src/assets/img/icons/mediatype/livemusic.js.map +1 -0
  50. package/dist/src/assets/img/icons/mediatype/photos.d.ts +1 -0
  51. package/dist/src/assets/img/icons/mediatype/photos.js +7 -0
  52. package/dist/src/assets/img/icons/mediatype/photos.js.map +1 -0
  53. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
  54. package/dist/src/assets/img/icons/mediatype/software.js +10 -0
  55. package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
  56. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
  57. package/dist/src/assets/img/icons/mediatype/texts.js +10 -0
  58. package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
  59. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
  60. package/dist/src/assets/img/icons/mediatype/tv.js +9 -0
  61. package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
  62. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
  63. package/dist/src/assets/img/icons/mediatype/video.js +10 -0
  64. package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
  65. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
  66. package/dist/src/assets/img/icons/mediatype/web.js +10 -0
  67. package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
  68. package/dist/src/assets/img/icons/software.d.ts +1 -0
  69. package/dist/src/assets/img/icons/software.js +10 -0
  70. package/dist/src/assets/img/icons/software.js.map +1 -0
  71. package/dist/src/assets/img/icons/texts.d.ts +1 -0
  72. package/dist/src/assets/img/icons/texts.js +10 -0
  73. package/dist/src/assets/img/icons/texts.js.map +1 -0
  74. package/dist/src/assets/img/icons/tv.d.ts +1 -0
  75. package/dist/src/assets/img/icons/tv.js +9 -0
  76. package/dist/src/assets/img/icons/tv.js.map +1 -0
  77. package/dist/src/assets/img/icons/video.d.ts +1 -0
  78. package/dist/src/assets/img/icons/video.js +10 -0
  79. package/dist/src/assets/img/icons/video.js.map +1 -0
  80. package/dist/src/assets/img/icons/web.d.ts +1 -0
  81. package/dist/src/assets/img/icons/web.js +10 -0
  82. package/dist/src/assets/img/icons/web.js.map +1 -0
  83. package/dist/src/circular-activity-indicator.d.ts +5 -0
  84. package/dist/src/circular-activity-indicator.js +66 -0
  85. package/dist/src/circular-activity-indicator.js.map +1 -0
  86. package/dist/src/collection-browser.d.ts +151 -0
  87. package/dist/src/collection-browser.js +697 -0
  88. package/dist/src/collection-browser.js.map +1 -0
  89. package/dist/src/collection-facets.d.ts +34 -0
  90. package/dist/src/collection-facets.js +245 -0
  91. package/dist/src/collection-facets.js.map +1 -0
  92. package/dist/src/mediatype-icon.d.ts +9 -0
  93. package/dist/src/mediatype-icon.js +89 -0
  94. package/dist/src/mediatype-icon.js.map +1 -0
  95. package/dist/src/models.d.ts +23 -0
  96. package/dist/src/models.js +2 -0
  97. package/dist/src/models.js.map +1 -0
  98. package/dist/src/sort-filter-bar/alpha-bar.d.ts +10 -0
  99. package/dist/src/sort-filter-bar/alpha-bar.js +88 -0
  100. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
  101. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +24 -0
  102. package/dist/src/sort-filter-bar/sort-filter-bar.js +257 -0
  103. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
  104. package/dist/src/tiles/grid/account-tile.d.ts +7 -0
  105. package/dist/src/tiles/grid/account-tile.js +144 -0
  106. package/dist/src/tiles/grid/account-tile.js.map +1 -0
  107. package/dist/src/tiles/grid/collection-tile.d.ts +7 -0
  108. package/dist/src/tiles/grid/collection-tile.js +160 -0
  109. package/dist/src/tiles/grid/collection-tile.js.map +1 -0
  110. package/dist/src/tiles/grid/icons/account.d.ts +1 -0
  111. package/dist/src/tiles/grid/icons/account.js +12 -0
  112. package/dist/src/tiles/grid/icons/account.js.map +1 -0
  113. package/dist/src/tiles/grid/icons/favorite-filled.d.ts +1 -0
  114. package/dist/src/tiles/grid/icons/favorite-filled.js +11 -0
  115. package/dist/src/tiles/grid/icons/favorite-filled.js.map +1 -0
  116. package/dist/src/tiles/grid/icons/reviews.d.ts +1 -0
  117. package/dist/src/tiles/grid/icons/reviews.js +11 -0
  118. package/dist/src/tiles/grid/icons/reviews.js.map +1 -0
  119. package/dist/src/tiles/grid/icons/upload.d.ts +1 -0
  120. package/dist/src/tiles/grid/icons/upload.js +12 -0
  121. package/dist/src/tiles/grid/icons/upload.js.map +1 -0
  122. package/dist/src/tiles/grid/icons/views.d.ts +2 -0
  123. package/dist/src/tiles/grid/icons/views.js +11 -0
  124. package/dist/src/tiles/grid/icons/views.js.map +1 -0
  125. package/dist/src/tiles/grid/item-tile.d.ts +9 -0
  126. package/dist/src/tiles/grid/item-tile.js +240 -0
  127. package/dist/src/tiles/grid/item-tile.js.map +1 -0
  128. package/dist/src/tiles/list/tile-list-compact.d.ts +16 -0
  129. package/dist/src/tiles/list/tile-list-compact.js +125 -0
  130. package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
  131. package/dist/src/tiles/list/tile-list-detail.d.ts +17 -0
  132. package/dist/src/tiles/list/tile-list-detail.js +181 -0
  133. package/dist/src/tiles/list/tile-list-detail.js.map +1 -0
  134. package/dist/src/tiles/list/tile-list.d.ts +21 -0
  135. package/dist/src/tiles/list/tile-list.js +229 -0
  136. package/dist/src/tiles/list/tile-list.js.map +1 -0
  137. package/dist/src/tiles/loading-tile.d.ts +5 -0
  138. package/dist/src/tiles/loading-tile.js +73 -0
  139. package/dist/src/tiles/loading-tile.js.map +1 -0
  140. package/dist/src/tiles/tile-dispatcher.d.ts +27 -0
  141. package/dist/src/tiles/tile-dispatcher.js +160 -0
  142. package/dist/src/tiles/tile-dispatcher.js.map +1 -0
  143. package/dist/src/utils/format-count.d.ts +7 -0
  144. package/dist/src/utils/format-count.js +76 -0
  145. package/dist/src/utils/format-count.js.map +1 -0
  146. package/dist/src/utils/format-date.d.ts +2 -0
  147. package/dist/src/utils/format-date.js +24 -0
  148. package/dist/src/utils/format-date.js.map +1 -0
  149. package/dist/src/utils/format-string.d.ts +2 -0
  150. package/dist/src/utils/format-string.js +7 -0
  151. package/dist/src/utils/format-string.js.map +1 -0
  152. package/dist/test/collection-browser.test.d.ts +0 -0
  153. package/dist/test/collection-browser.test.js +3 -0
  154. package/dist/test/collection-browser.test.js.map +1 -0
  155. package/dist/test/utils/format-count.test.d.ts +1 -0
  156. package/dist/test/utils/format-count.test.js +24 -0
  157. package/dist/test/utils/format-count.test.js.map +1 -0
  158. package/dist/test/utils/format-date.test.d.ts +1 -0
  159. package/dist/test/utils/format-date.test.js +18 -0
  160. package/dist/test/utils/format-date.test.js.map +1 -0
  161. package/dist/test/utils/format-string.test.d.ts +1 -0
  162. package/dist/test/utils/format-string.test.js +17 -0
  163. package/dist/test/utils/format-string.test.js.map +1 -0
  164. package/index.ts +3 -0
  165. package/package.json +95 -0
  166. package/src/assets/img/icons/mediatype/account.ts +12 -0
  167. package/src/assets/img/icons/mediatype/audio.ts +11 -0
  168. package/src/assets/img/icons/mediatype/collection.ts +9 -0
  169. package/src/assets/img/icons/mediatype/etree.ts +9 -0
  170. package/src/assets/img/icons/mediatype/film.ts +13 -0
  171. package/src/assets/img/icons/mediatype/foo.svg +5 -0
  172. package/src/assets/img/icons/mediatype/images.ts +10 -0
  173. package/src/assets/img/icons/mediatype/software.ts +10 -0
  174. package/src/assets/img/icons/mediatype/texts.ts +10 -0
  175. package/src/assets/img/icons/mediatype/tv.ts +9 -0
  176. package/src/assets/img/icons/mediatype/video.ts +10 -0
  177. package/src/assets/img/icons/mediatype/web.ts +10 -0
  178. package/src/circular-activity-indicator.ts +64 -0
  179. package/src/collection-browser.ts +756 -0
  180. package/src/collection-facets.ts +285 -0
  181. package/src/mediatype-icon.ts +83 -0
  182. package/src/models.ts +25 -0
  183. package/src/sort-filter-bar/alpha-bar.ts +86 -0
  184. package/src/sort-filter-bar/sort-filter-bar.ts +256 -0
  185. package/src/tiles/grid/account-tile.ts +141 -0
  186. package/src/tiles/grid/collection-tile.ts +157 -0
  187. package/src/tiles/grid/icons/account.ts +12 -0
  188. package/src/tiles/grid/icons/favorite-filled.ts +11 -0
  189. package/src/tiles/grid/icons/reviews.ts +11 -0
  190. package/src/tiles/grid/icons/upload.ts +12 -0
  191. package/src/tiles/grid/icons/views.ts +11 -0
  192. package/src/tiles/grid/item-tile.ts +254 -0
  193. package/src/tiles/list/tile-list.ts +227 -0
  194. package/src/tiles/loading-tile.ts +70 -0
  195. package/src/tiles/tile-dispatcher.ts +160 -0
  196. package/src/utils/format-count.ts +95 -0
  197. package/src/utils/format-date.ts +36 -0
  198. package/test/collection-browser.test.ts +1 -0
  199. package/test/utils/format-count.test.ts +32 -0
  200. package/test/utils/format-date.test.ts +22 -0
  201. package/tsconfig.json +20 -0
  202. package/web-dev-server.config.mjs +28 -0
  203. package/web-test-runner.config.mjs +41 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alpha-bar.js","sourceRoot":"","sources":["../../../src/sort-filter-bar/alpha-bar.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,MAAM,KAAK,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG5D,IAAa,QAAQ,GAArB,MAAa,QAAS,SAAQ,UAAU;IAAxC;;QA8CmB,aAAQ,GAAG,4BAA4B,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAmCrE,CAAC;IA5EC,IAAY,uBAAuB;;QACjC,OAAO,MAAA,IAAI,CAAC,cAAc,0CAAE,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAA;YACH,IAAI,CAAC,QAAQ;;;YAGb,IAAI,CAAC,QAAQ,CAAC,GAAG,CACjB,MAAM,CAAC,EAAE,CACP,IAAI,CAAA;;0BAEQ,MAAM,KAAK,IAAI,CAAC,uBAAuB;YAC7C,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,OAAO;;uCAEU,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;sBACjD,MAAM;;;eAGb,CACJ;;;KAGN,CAAC;IACJ,CAAC;IAEO,aAAa,CAAC,MAAc;QAClC,IAAI,MAAM,KAAK,IAAI,CAAC,uBAAuB,EAAE;YAC3C,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;SACjC;aAAM;YACL,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;SAC9B;QACD,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,eAAe,EAAE;YAC/B,MAAM,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,uBAAuB,EAAE;SACzD,CAAC,CACH,CAAC;IACJ,CAAC;CAqCF,CAAA;AAjCQ,eAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgClB,CAAC;AA/E0B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;0CAAmB;AAElB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;gDAAyB;AAHzC,QAAQ;IADpB,aAAa,CAAC,WAAW,CAAC;GACd,QAAQ,CAiFpB;SAjFY,QAAQ","sourcesContent":["import { LitElement, html, css, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\n@customElement('alpha-bar')\nexport class AlphaBar extends LitElement {\n @property({ type: String }) headline?: string;\n\n @property({ type: String }) selectedLetter?: string;\n\n private get selectedUppercaseLetter(): string | undefined {\n return this.selectedLetter?.toUpperCase();\n }\n\n render() {\n return html`\n <h1>${this.headline}</h1>\n <div id=\"container\">\n <ul>\n ${this.alphabet.map(\n letter =>\n html`\n <li\n class=${letter === this.selectedUppercaseLetter\n ? 'selected'\n : nothing}\n >\n <a href=\"#\" @click=${() => this.letterClicked(letter)}>\n ${letter}\n </a>\n </li>\n `\n )}\n </ul>\n </div>\n `;\n }\n\n private letterClicked(letter: string) {\n if (letter === this.selectedUppercaseLetter) {\n this.selectedLetter = undefined;\n } else {\n this.selectedLetter = letter;\n }\n this.dispatchEvent(\n new CustomEvent('letterChanged', {\n detail: { selectedLetter: this.selectedUppercaseLetter },\n })\n );\n }\n\n private readonly alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.split('');\n\n static styles = css`\n h1 {\n font-size: 1.2rem;\n }\n\n #container {\n background-color: #ddd;\n color: #333;\n }\n\n ul {\n list-style: none;\n display: flex;\n margin: 0;\n padding: 0.5rem 1rem;\n justify-content: space-between;\n }\n\n a {\n color: #333;\n text-decoration: none;\n padding: 0.5rem 0.7rem;\n display: block;\n }\n\n .selected {\n background-color: darkgray;\n }\n\n .selected a {\n color: white;\n }\n `;\n}\n"]}
@@ -0,0 +1,24 @@
1
+ import { LitElement, PropertyValues } from 'lit';
2
+ import { CollectionDisplayMode } from '../models';
3
+ import './alpha-bar';
4
+ export declare class SortFilterBar extends LitElement {
5
+ displayMode: CollectionDisplayMode;
6
+ sortDirection: 'asc' | 'desc';
7
+ sortField: string;
8
+ titleSelectorVisible: boolean;
9
+ creatorSelectorVisible: boolean;
10
+ dateSortSelectorVisible: boolean;
11
+ render(): import("lit-html").TemplateResult<1>;
12
+ updated(changed: PropertyValues): void;
13
+ private get dateSortSelector();
14
+ private get titleSelectorBar();
15
+ private get creatorSelectorBar();
16
+ private titleLetterChanged;
17
+ private creatorLetterChanged;
18
+ private gridSelected;
19
+ private listSelected;
20
+ private detailSelected;
21
+ private displayModeChanged;
22
+ private sortChanged;
23
+ static styles: import("lit").CSSResult;
24
+ }
@@ -0,0 +1,257 @@
1
+ import { __decorate } from "tslib";
2
+ import { SortParam } from '@internetarchive/search-service';
3
+ import { LitElement, html, css, nothing } from 'lit';
4
+ import { customElement, property, state } from 'lit/decorators.js';
5
+ import './alpha-bar';
6
+ let SortFilterBar = class SortFilterBar extends LitElement {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.displayMode = 'grid';
10
+ this.sortDirection = 'desc';
11
+ this.sortField = 'week';
12
+ this.titleSelectorVisible = false;
13
+ this.creatorSelectorVisible = false;
14
+ this.dateSortSelectorVisible = false;
15
+ }
16
+ render() {
17
+ return html `
18
+ <div id="sort-bar">
19
+ <div id="sort-selector">
20
+ <ul>
21
+ <li>
22
+ <button
23
+ @click=${() => {
24
+ this.sortDirection = 'desc';
25
+ }}
26
+ >
27
+ Desc
28
+ </button>
29
+ <button
30
+ @click=${() => {
31
+ this.sortDirection = 'asc';
32
+ }}
33
+ >
34
+ Asc</button
35
+ >Sort By
36
+ </li>
37
+ <li>
38
+ <button
39
+ @click=${() => {
40
+ this.sortField = 'week';
41
+ }}
42
+ >
43
+ Views
44
+ </button>
45
+ </li>
46
+ <li>
47
+ <button
48
+ @click=${() => {
49
+ this.titleSelectorVisible = !this.titleSelectorVisible;
50
+ this.sortField = 'titleSorter';
51
+ }}
52
+ >
53
+ Title
54
+ </button>
55
+ </li>
56
+ <li>
57
+ <button
58
+ @click=${() => {
59
+ this.dateSortSelectorVisible = !this.dateSortSelectorVisible;
60
+ }}
61
+ >
62
+ Date Archived
63
+ </button>
64
+ </li>
65
+ <li>
66
+ <button
67
+ @click=${() => {
68
+ this.creatorSelectorVisible = !this.creatorSelectorVisible;
69
+ this.sortField = 'creatorSorter';
70
+ }}
71
+ >
72
+ Creator
73
+ </button>
74
+ </li>
75
+ </ul>
76
+ </div>
77
+
78
+ <div id="display-style">
79
+ <ul>
80
+ ${this.displayMode !== 'grid'
81
+ ? html `<li>
82
+ <input type="checkbox" @click=${this.detailSelected} />
83
+ Details
84
+ </li>`
85
+ : nothing}
86
+
87
+ <li>
88
+ <button id="grid-button" @click=${this.gridSelected}>Grid</button>
89
+ </li>
90
+ <li>
91
+ <button id="list-button" @click=${this.listSelected}>List</button>
92
+ </li>
93
+ </ul>
94
+ </div>
95
+ </div>
96
+
97
+ ${this.dateSortSelectorVisible ? this.dateSortSelector : nothing}
98
+ ${this.titleSelectorVisible ? this.titleSelectorBar : nothing}
99
+ ${this.creatorSelectorVisible ? this.creatorSelectorBar : nothing}
100
+ `;
101
+ }
102
+ updated(changed) {
103
+ if (changed.has('displayMode')) {
104
+ this.displayModeChanged();
105
+ }
106
+ if (changed.has('sortDirection') || changed.has('sortField')) {
107
+ this.sortChanged();
108
+ }
109
+ }
110
+ get dateSortSelector() {
111
+ return html `
112
+ <div id="date-sort-selector">
113
+ <ul>
114
+ <li>
115
+ <button
116
+ @click=${() => {
117
+ this.sortField = 'publicdate';
118
+ }}
119
+ >
120
+ Date Archived
121
+ </button>
122
+ </li>
123
+ <li>
124
+ <button
125
+ @click=${() => {
126
+ this.sortField = 'date';
127
+ }}
128
+ >
129
+ Date Published
130
+ </button>
131
+ </li>
132
+ <li>
133
+ <button
134
+ @click=${() => {
135
+ this.sortField = 'reviewdate';
136
+ }}
137
+ >
138
+ Date Reviewed
139
+ </button>
140
+ </li>
141
+ <li>
142
+ <button
143
+ @click=${() => {
144
+ this.sortField = 'addeddate';
145
+ }}
146
+ >
147
+ Date Added
148
+ </button>
149
+ </li>
150
+ </ul>
151
+ </div>
152
+ `;
153
+ }
154
+ get titleSelectorBar() {
155
+ return html ` <alpha-bar
156
+ headline="Title Starts With"
157
+ @letterChanged=${this.titleLetterChanged}
158
+ ></alpha-bar>`;
159
+ }
160
+ get creatorSelectorBar() {
161
+ return html ` <alpha-bar
162
+ headline="Creator Starts With"
163
+ @letterChanged=${this.creatorLetterChanged}
164
+ ></alpha-bar>`;
165
+ }
166
+ titleLetterChanged(e) {
167
+ const event = new CustomEvent('titleLetterChanged', {
168
+ detail: { selectedLetter: e.detail.selectedLetter },
169
+ });
170
+ this.dispatchEvent(event);
171
+ }
172
+ creatorLetterChanged(e) {
173
+ const event = new CustomEvent('creatorLetterChanged', {
174
+ detail: { selectedLetter: e.detail.selectedLetter },
175
+ });
176
+ this.dispatchEvent(event);
177
+ }
178
+ gridSelected() {
179
+ this.displayMode = 'grid';
180
+ }
181
+ listSelected() {
182
+ this.displayMode = 'list-compact';
183
+ }
184
+ detailSelected(e) {
185
+ this.displayMode = e.target.checked
186
+ ? 'list-detail'
187
+ : 'list-compact';
188
+ }
189
+ displayModeChanged() {
190
+ const event = new CustomEvent('displayModeChanged', {
191
+ detail: { displayMode: this.displayMode },
192
+ });
193
+ this.dispatchEvent(event);
194
+ }
195
+ sortChanged() {
196
+ const sort = new SortParam(this.sortField, this.sortDirection);
197
+ const event = new CustomEvent('sortChanged', {
198
+ detail: { sort },
199
+ });
200
+ this.dispatchEvent(event);
201
+ }
202
+ };
203
+ SortFilterBar.styles = css `
204
+ #sort-bar {
205
+ display: flex;
206
+ justify-content: space-between;
207
+ }
208
+
209
+ ul {
210
+ list-style: none;
211
+ display: flex;
212
+ margin: 0;
213
+ padding: 0;
214
+ align-items: center;
215
+ }
216
+
217
+ li {
218
+ padding: 0.5rem 0 0.5rem 0;
219
+ }
220
+
221
+ #sort-selector li::after {
222
+ content: '•';
223
+ padding-left: 1rem;
224
+ padding-right: 1rem;
225
+ }
226
+
227
+ #sort-selector li:first-child::after {
228
+ content: '';
229
+ }
230
+
231
+ #sort-selector li:last-child::after {
232
+ content: '';
233
+ }
234
+ `;
235
+ __decorate([
236
+ property({ type: String })
237
+ ], SortFilterBar.prototype, "displayMode", void 0);
238
+ __decorate([
239
+ property({ type: String })
240
+ ], SortFilterBar.prototype, "sortDirection", void 0);
241
+ __decorate([
242
+ property({ type: String })
243
+ ], SortFilterBar.prototype, "sortField", void 0);
244
+ __decorate([
245
+ state()
246
+ ], SortFilterBar.prototype, "titleSelectorVisible", void 0);
247
+ __decorate([
248
+ state()
249
+ ], SortFilterBar.prototype, "creatorSelectorVisible", void 0);
250
+ __decorate([
251
+ state()
252
+ ], SortFilterBar.prototype, "dateSortSelectorVisible", void 0);
253
+ SortFilterBar = __decorate([
254
+ customElement('sort-filter-bar')
255
+ ], SortFilterBar);
256
+ export { SortFilterBar };
257
+ //# sourceMappingURL=sort-filter-bar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-filter-bar.js","sourceRoot":"","sources":["../../../src/sort-filter-bar/sort-filter-bar.ts"],"names":[],"mappings":"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","sourcesContent":["import { SortParam } from '@internetarchive/search-service';\nimport { LitElement, html, css, nothing, PropertyValues } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { CollectionDisplayMode } from '../models';\nimport './alpha-bar';\n\n@customElement('sort-filter-bar')\nexport class SortFilterBar extends LitElement {\n @property({ type: String }) displayMode: CollectionDisplayMode = 'grid';\n\n @property({ type: String }) sortDirection: 'asc' | 'desc' = 'desc';\n\n @property({ type: String }) sortField = 'week';\n\n @state() titleSelectorVisible: boolean = false;\n\n @state() creatorSelectorVisible: boolean = false;\n\n @state() dateSortSelectorVisible = false;\n\n render() {\n return html`\n <div id=\"sort-bar\">\n <div id=\"sort-selector\">\n <ul>\n <li>\n <button\n @click=${() => {\n this.sortDirection = 'desc';\n }}\n >\n Desc\n </button>\n <button\n @click=${() => {\n this.sortDirection = 'asc';\n }}\n >\n Asc</button\n >Sort By\n </li>\n <li>\n <button\n @click=${() => {\n this.sortField = 'week';\n }}\n >\n Views\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.titleSelectorVisible = !this.titleSelectorVisible;\n this.sortField = 'titleSorter';\n }}\n >\n Title\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.dateSortSelectorVisible = !this.dateSortSelectorVisible;\n }}\n >\n Date Archived\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.creatorSelectorVisible = !this.creatorSelectorVisible;\n this.sortField = 'creatorSorter';\n }}\n >\n Creator\n </button>\n </li>\n </ul>\n </div>\n\n <div id=\"display-style\">\n <ul>\n ${this.displayMode !== 'grid'\n ? html`<li>\n <input type=\"checkbox\" @click=${this.detailSelected} />\n Details\n </li>`\n : nothing}\n\n <li>\n <button id=\"grid-button\" @click=${this.gridSelected}>Grid</button>\n </li>\n <li>\n <button id=\"list-button\" @click=${this.listSelected}>List</button>\n </li>\n </ul>\n </div>\n </div>\n\n ${this.dateSortSelectorVisible ? this.dateSortSelector : nothing}\n ${this.titleSelectorVisible ? this.titleSelectorBar : nothing}\n ${this.creatorSelectorVisible ? this.creatorSelectorBar : nothing}\n `;\n }\n\n updated(changed: PropertyValues) {\n if (changed.has('displayMode')) {\n this.displayModeChanged();\n }\n\n if (changed.has('sortDirection') || changed.has('sortField')) {\n this.sortChanged();\n }\n }\n\n private get dateSortSelector() {\n return html`\n <div id=\"date-sort-selector\">\n <ul>\n <li>\n <button\n @click=${() => {\n this.sortField = 'publicdate';\n }}\n >\n Date Archived\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.sortField = 'date';\n }}\n >\n Date Published\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.sortField = 'reviewdate';\n }}\n >\n Date Reviewed\n </button>\n </li>\n <li>\n <button\n @click=${() => {\n this.sortField = 'addeddate';\n }}\n >\n Date Added\n </button>\n </li>\n </ul>\n </div>\n `;\n }\n\n private get titleSelectorBar() {\n return html` <alpha-bar\n headline=\"Title Starts With\"\n @letterChanged=${this.titleLetterChanged}\n ></alpha-bar>`;\n }\n\n private get creatorSelectorBar() {\n return html` <alpha-bar\n headline=\"Creator Starts With\"\n @letterChanged=${this.creatorLetterChanged}\n ></alpha-bar>`;\n }\n\n private titleLetterChanged(\n e: CustomEvent<{ selectedLetter: string | undefined }>\n ) {\n const event = new CustomEvent('titleLetterChanged', {\n detail: { selectedLetter: e.detail.selectedLetter },\n });\n this.dispatchEvent(event);\n }\n\n private creatorLetterChanged(\n e: CustomEvent<{ selectedLetter: string | undefined }>\n ) {\n const event = new CustomEvent('creatorLetterChanged', {\n detail: { selectedLetter: e.detail.selectedLetter },\n });\n this.dispatchEvent(event);\n }\n\n private gridSelected() {\n this.displayMode = 'grid';\n }\n\n private listSelected() {\n this.displayMode = 'list-compact';\n }\n\n private detailSelected(e: Event) {\n this.displayMode = (e.target as HTMLInputElement).checked\n ? 'list-detail'\n : 'list-compact';\n }\n\n private displayModeChanged() {\n const event = new CustomEvent('displayModeChanged', {\n detail: { displayMode: this.displayMode },\n });\n this.dispatchEvent(event);\n }\n\n private sortChanged() {\n const sort = new SortParam(this.sortField, this.sortDirection);\n const event = new CustomEvent('sortChanged', {\n detail: { sort },\n });\n this.dispatchEvent(event);\n }\n\n static styles = css`\n #sort-bar {\n display: flex;\n justify-content: space-between;\n }\n\n ul {\n list-style: none;\n display: flex;\n margin: 0;\n padding: 0;\n align-items: center;\n }\n\n li {\n padding: 0.5rem 0 0.5rem 0;\n }\n\n #sort-selector li::after {\n content: '•';\n padding-left: 1rem;\n padding-right: 1rem;\n }\n\n #sort-selector li:first-child::after {\n content: '';\n }\n\n #sort-selector li:last-child::after {\n content: '';\n }\n `;\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { LitElement } from 'lit';
2
+ import { TileModel } from '../../models';
3
+ export declare class UserTile extends LitElement {
4
+ model?: TileModel;
5
+ render(): import("lit-html").TemplateResult<1>;
6
+ static get styles(): import("lit").CSSResult;
7
+ }
@@ -0,0 +1,144 @@
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { accountIcon } from './icons/account';
5
+ import { favoriteFilledIcon } from './icons/favorite-filled';
6
+ import { reviewsIcon } from './icons/reviews';
7
+ import { uploadIcon } from './icons/upload';
8
+ let UserTile = class UserTile extends LitElement {
9
+ render() {
10
+ var _a, _b, _c, _d, _e, _f, _g;
11
+ return html `
12
+ <div class="outer-holder">
13
+ <div class="inner-holder">
14
+ <div id="header-holder">
15
+ <div id="title-holder">
16
+ <h1>${(_a = this.model) === null || _a === void 0 ? void 0 : _a.identifier}</h1>
17
+ </div>
18
+ <div id="avatar-holder">
19
+ <div
20
+ id="avatar"
21
+ style="background-image: url('https://archive.org/services/img/${(_b = this
22
+ .model) === null || _b === void 0 ? void 0 : _b.identifier}')"
23
+ ></div>
24
+ </div>
25
+ </div>
26
+ <div id="year-holder">
27
+ <div id="archivist-since">
28
+ <h3>Archivist Since</h3>
29
+ </div>
30
+ <div id="year-holder">
31
+ <h3>${(_d = (_c = this.model) === null || _c === void 0 ? void 0 : _c.dateAdded) === null || _d === void 0 ? void 0 : _d.getFullYear()}</h3>
32
+ </div>
33
+ </div>
34
+ <div id="status-holder">
35
+ <div id="patron-icon">${accountIcon}</div>
36
+ <div class="stat-icon">
37
+ ${uploadIcon}
38
+ <h3>${(_e = this.model) === null || _e === void 0 ? void 0 : _e.itemCount}</h3>
39
+ </div>
40
+ <div class="stat-icon">
41
+ ${favoriteFilledIcon}
42
+ <h3>${(_f = this.model) === null || _f === void 0 ? void 0 : _f.favCount}</h3>
43
+ </div>
44
+ <div class="stat-icon">
45
+ ${reviewsIcon}
46
+ <h3>${(_g = this.model) === null || _g === void 0 ? void 0 : _g.commentCount}</h3>
47
+ </div>
48
+ </div>
49
+ </div>
50
+ </div>
51
+ `;
52
+ }
53
+ static get styles() {
54
+ return css `
55
+ h1 {
56
+ color: black;
57
+ font-size: 16px;
58
+ margin: 0;
59
+ }
60
+
61
+ h3 {
62
+ font-size: 14px;
63
+ font-weight: bold;
64
+ color: #2c2c2c;
65
+ margin: 0px;
66
+ }
67
+
68
+ .outer-holder {
69
+ background-color: #fcf5e6;
70
+ border: 1px #2c2c2c;
71
+ border-radius: 4px;
72
+ box-shadow: 1px 1px 2px 0px;
73
+ height: 100%;
74
+ display: flex;
75
+ text-align: center;
76
+ width: 100%;
77
+ }
78
+
79
+ .inner-holder {
80
+ padding: 5px;
81
+ width: 100%;
82
+ display: flex;
83
+ flex-direction: column;
84
+ }
85
+
86
+ #header-holder {
87
+ flex: 1;
88
+ }
89
+
90
+ #title-holder {
91
+ height: 40px;
92
+ margin-bottom: 5px;
93
+ }
94
+
95
+ #avatar-holder {
96
+ margin-bottom: 5px;
97
+ display: flex;
98
+ align-items: center;
99
+ justify-content: center;
100
+ }
101
+
102
+ #avatar {
103
+ background-position: 50% 50%;
104
+ border-radius: 50%;
105
+ width: 160px;
106
+ height: 160px;
107
+ box-shadow: 1px 1px 2px #888888;
108
+ }
109
+
110
+ #year-holder {
111
+ margin-bottom: 5px;
112
+ height: 40px;
113
+ }
114
+
115
+ #year-holder {
116
+ margin: 0px;
117
+ }
118
+
119
+ #status-holder {
120
+ height: 25px;
121
+ display: flex;
122
+ justify-content: space-evenly;
123
+ }
124
+
125
+ #patron-icon {
126
+ height: 25px;
127
+ width: 25px;
128
+ }
129
+
130
+ .stat-icon {
131
+ height: 10px;
132
+ width: 10px;
133
+ }
134
+ `;
135
+ }
136
+ };
137
+ __decorate([
138
+ property({ type: Object })
139
+ ], UserTile.prototype, "model", void 0);
140
+ UserTile = __decorate([
141
+ customElement('account-tile')
142
+ ], UserTile);
143
+ export { UserTile };
144
+ //# sourceMappingURL=account-tile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account-tile.js","sourceRoot":"","sources":["../../../../src/tiles/grid/account-tile.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;AAG5D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5C,IAAa,QAAQ,GAArB,MAAa,QAAS,SAAQ,UAAU;IAGtC,MAAM;;QACJ,OAAO,IAAI,CAAA;;;;;oBAKK,MAAA,IAAI,CAAC,KAAK,0CAAE,UAAU;;;;;iFAKuC,MAAA,IAAI;aAClE,KAAK,0CAAE,UAAU;;;;;;;;;oBAShB,MAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,0CAAE,WAAW,EAAE;;;;oCAIpB,WAAW;;gBAE/B,UAAU;oBACN,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS;;;gBAGzB,kBAAkB;oBACd,MAAA,IAAI,CAAC,KAAK,0CAAE,QAAQ;;;gBAGxB,WAAW;oBACP,MAAA,IAAI,CAAC,KAAK,0CAAE,YAAY;;;;;KAKvC,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgFT,CAAC;IACJ,CAAC;CACF,CAAA;AAjI6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;uCAAmB;AADnC,QAAQ;IADpB,aAAa,CAAC,cAAc,CAAC;GACjB,QAAQ,CAkIpB;SAlIY,QAAQ","sourcesContent":["import { css, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { TileModel } from '../../models';\n\nimport { accountIcon } from './icons/account';\nimport { favoriteFilledIcon } from './icons/favorite-filled';\nimport { reviewsIcon } from './icons/reviews';\nimport { uploadIcon } from './icons/upload';\n\n@customElement('account-tile')\nexport class UserTile extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n render() {\n return html`\n <div class=\"outer-holder\">\n <div class=\"inner-holder\">\n <div id=\"header-holder\">\n <div id=\"title-holder\">\n <h1>${this.model?.identifier}</h1>\n </div>\n <div id=\"avatar-holder\">\n <div\n id=\"avatar\"\n style=\"background-image: url('https://archive.org/services/img/${this\n .model?.identifier}')\"\n ></div>\n </div>\n </div>\n <div id=\"year-holder\">\n <div id=\"archivist-since\">\n <h3>Archivist Since</h3>\n </div>\n <div id=\"year-holder\">\n <h3>${this.model?.dateAdded?.getFullYear()}</h3>\n </div>\n </div>\n <div id=\"status-holder\">\n <div id=\"patron-icon\">${accountIcon}</div>\n <div class=\"stat-icon\">\n ${uploadIcon}\n <h3>${this.model?.itemCount}</h3>\n </div>\n <div class=\"stat-icon\">\n ${favoriteFilledIcon}\n <h3>${this.model?.favCount}</h3>\n </div>\n <div class=\"stat-icon\">\n ${reviewsIcon}\n <h3>${this.model?.commentCount}</h3>\n </div>\n </div>\n </div>\n </div>\n `;\n }\n\n static get styles() {\n return css`\n h1 {\n color: black;\n font-size: 16px;\n margin: 0;\n }\n\n h3 {\n font-size: 14px;\n font-weight: bold;\n color: #2c2c2c;\n margin: 0px;\n }\n\n .outer-holder {\n background-color: #fcf5e6;\n border: 1px #2c2c2c;\n border-radius: 4px;\n box-shadow: 1px 1px 2px 0px;\n height: 100%;\n display: flex;\n text-align: center;\n width: 100%;\n }\n\n .inner-holder {\n padding: 5px;\n width: 100%;\n display: flex;\n flex-direction: column;\n }\n\n #header-holder {\n flex: 1;\n }\n\n #title-holder {\n height: 40px;\n margin-bottom: 5px;\n }\n\n #avatar-holder {\n margin-bottom: 5px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n #avatar {\n background-position: 50% 50%;\n border-radius: 50%;\n width: 160px;\n height: 160px;\n box-shadow: 1px 1px 2px #888888;\n }\n\n #year-holder {\n margin-bottom: 5px;\n height: 40px;\n }\n\n #year-holder {\n margin: 0px;\n }\n\n #status-holder {\n height: 25px;\n display: flex;\n justify-content: space-evenly;\n }\n\n #patron-icon {\n height: 25px;\n width: 25px;\n }\n\n .stat-icon {\n height: 10px;\n width: 10px;\n }\n `;\n }\n}\n"]}
@@ -0,0 +1,7 @@
1
+ import { CSSResultGroup, LitElement } from 'lit';
2
+ import { TileModel } from '../../models';
3
+ export declare class CollectionTile extends LitElement {
4
+ model?: TileModel;
5
+ render(): import("lit-html").TemplateResult<1>;
6
+ static get styles(): CSSResultGroup;
7
+ }
@@ -0,0 +1,160 @@
1
+ import { __decorate } from "tslib";
2
+ import { localized, msg } from '@lit/localize';
3
+ import { css, html, LitElement } from 'lit';
4
+ import { customElement, property } from 'lit/decorators.js';
5
+ import { collectionIcon } from '../../assets/img/icons/mediatype/collection';
6
+ let CollectionTile = class CollectionTile extends LitElement {
7
+ render() {
8
+ var _a, _b, _c;
9
+ return html `
10
+ <div id="container">
11
+ <div id="collection-image-title">
12
+ <div id="collection-title">${(_a = this.model) === null || _a === void 0 ? void 0 : _a.title}</div>
13
+ <div id="collection-image-container">
14
+ <div
15
+ id="collection-image"
16
+ style="background-image:url('https://archive.org/services/img/${(_b = this
17
+ .model) === null || _b === void 0 ? void 0 : _b.identifier}')"
18
+ ></div>
19
+ </div>
20
+ </div>
21
+ <div id="item-count-container">
22
+ <div id="item-count-image-container">${collectionIcon}</div>
23
+ <div id="item-count-stacked-text">
24
+ <div id="item-count">${(_c = this.model) === null || _c === void 0 ? void 0 : _c.itemCount.toLocaleString()}</div>
25
+ <div id="items-text">${msg('items')}</div>
26
+ </div>
27
+ </div>
28
+ </div>
29
+ `;
30
+ }
31
+ static get styles() {
32
+ const cornerRadiusCss = css `var(--collectionTileCornerRadius, 4px)`;
33
+ return css `
34
+ #collection-image-container {
35
+ display: flex;
36
+ justify-content: center;
37
+ flex: 1;
38
+ }
39
+
40
+ #collection-image {
41
+ width: 16rem;
42
+ height: 16rem;
43
+ border-radius: 0.8rem;
44
+ overflow: hidden;
45
+ box-shadow: 1px 1px 2px 0px;
46
+ object-fit: cover;
47
+ background-position: center;
48
+ background-size: cover;
49
+ }
50
+
51
+ #item-count-image-container svg {
52
+ filter: invert(100%);
53
+ }
54
+
55
+ #collection-image-title {
56
+ background-color: #666;
57
+ border: 1px solid #2c2c2c;
58
+ padding: 0.5rem;
59
+ border-top-left-radius: ${cornerRadiusCss};
60
+ border-top-right-radius: ${cornerRadiusCss};
61
+ display: flex;
62
+ flex-direction: column;
63
+ flex: 1;
64
+ }
65
+
66
+ #collection-title {
67
+ font-weight: bold;
68
+ color: #fff;
69
+ font-size: 1.6rem;
70
+ text-align: center;
71
+ margin-bottom: 0.5rem;
72
+ overflow: hidden;
73
+ text-overflow: ellipsis;
74
+ display: -webkit-box;
75
+ -webkit-line-clamp: 2;
76
+ -webkit-box-orient: vertical;
77
+ line-height: 2rem;
78
+ height: 4rem;
79
+ }
80
+
81
+ #container {
82
+ box-shadow: 1px 1px 2px 0px;
83
+ border-radius: ${cornerRadiusCss};
84
+ height: 100%;
85
+ display: flex;
86
+ flex-direction: column;
87
+ }
88
+
89
+ #container:hover > #collection-image-title > #collection-title {
90
+ text-decoration: underline;
91
+ }
92
+
93
+ /* this is a workaround for Safari 15 where the hover effects are not working */
94
+ #collection-image-title:hover > #collection-title {
95
+ text-decoration: underline;
96
+ }
97
+
98
+ #container:hover > #collection-image-title {
99
+ background-color: #757575;
100
+ }
101
+
102
+ #item-count-container {
103
+ background-color: #444;
104
+ border-bottom: 1px solid #2c2c2c;
105
+ border-left: 1px solid #2c2c2c;
106
+ border-right: 1px solid #2c2c2c;
107
+ border-bottom-left-radius: ${cornerRadiusCss};
108
+ border-bottom-right-radius: ${cornerRadiusCss};
109
+ display: flex;
110
+ padding: 0rem 0.5rem;
111
+ height: 5.5rem;
112
+ align-items: center;
113
+ }
114
+
115
+ #item-count-image-container {
116
+ margin-right: 0.5rem;
117
+ }
118
+
119
+ #item-count-stacked-text {
120
+ display: flex;
121
+ align-items: baseline;
122
+ color: #fff;
123
+ }
124
+ #item-count-image-container svg {
125
+ height: 2.5rem;
126
+ align-items: baseline;
127
+ }
128
+
129
+ #container:hover > #item-count-container {
130
+ background-color: #575757;
131
+ }
132
+
133
+ #item-count {
134
+ font-size: 1.4rem;
135
+ font-weight: bold;
136
+ }
137
+
138
+ #item-count-image {
139
+ width: 3rem;
140
+ height: 3rem;
141
+ margin-right: 1rem;
142
+ }
143
+
144
+ #items-text {
145
+ font-size: 1.4rem;
146
+ font-weight: bold;
147
+ margin-left: 0.5rem;
148
+ }
149
+ `;
150
+ }
151
+ };
152
+ __decorate([
153
+ property({ type: Object })
154
+ ], CollectionTile.prototype, "model", void 0);
155
+ CollectionTile = __decorate([
156
+ localized(),
157
+ customElement('collection-tile')
158
+ ], CollectionTile);
159
+ export { CollectionTile };
160
+ //# sourceMappingURL=collection-tile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collection-tile.js","sourceRoot":"","sources":["../../../../src/tiles/grid/collection-tile.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,GAAG,EAAkB,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAK7E,IAAa,cAAc,GAA3B,MAAa,cAAe,SAAQ,UAAU;IAG5C,MAAM;;QACJ,OAAO,IAAI,CAAA;;;uCAGwB,MAAA,IAAI,CAAC,KAAK,0CAAE,KAAK;;;;8EAIsB,MAAA,IAAI;aACjE,KAAK,0CAAE,UAAU;;;;;iDAKe,cAAc;;mCAE5B,MAAA,IAAI,CAAC,KAAK,0CAAE,SAAS,CAAC,cAAc,EAAE;mCACtC,GAAG,CAAC,OAAO,CAAC;;;;KAI1C,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,MAAM;QACf,MAAM,eAAe,GAAG,GAAG,CAAA,wCAAwC,CAAC;QAEpE,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;kCA0BoB,eAAe;mCACd,eAAe;;;;;;;;;;;;;;;;;;;;;;;yBAuBzB,eAAe;;;;;;;;;;;;;;;;;;;;;;;;qCAwBH,eAAe;sCACd,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyChD,CAAC;IACJ,CAAC;CACF,CAAA;AAnJ6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;6CAAmB;AADnC,cAAc;IAF1B,SAAS,EAAE;IACX,aAAa,CAAC,iBAAiB,CAAC;GACpB,cAAc,CAoJ1B;SApJY,cAAc","sourcesContent":["import { localized, msg } from '@lit/localize';\nimport { css, CSSResultGroup, html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { collectionIcon } from '../../assets/img/icons/mediatype/collection';\nimport { TileModel } from '../../models';\n\n@localized()\n@customElement('collection-tile')\nexport class CollectionTile extends LitElement {\n @property({ type: Object }) model?: TileModel;\n\n render() {\n return html`\n <div id=\"container\">\n <div id=\"collection-image-title\">\n <div id=\"collection-title\">${this.model?.title}</div>\n <div id=\"collection-image-container\">\n <div\n id=\"collection-image\"\n style=\"background-image:url('https://archive.org/services/img/${this\n .model?.identifier}')\"\n ></div>\n </div>\n </div>\n <div id=\"item-count-container\">\n <div id=\"item-count-image-container\">${collectionIcon}</div>\n <div id=\"item-count-stacked-text\">\n <div id=\"item-count\">${this.model?.itemCount.toLocaleString()}</div>\n <div id=\"items-text\">${msg('items')}</div>\n </div>\n </div>\n </div>\n `;\n }\n\n static get styles(): CSSResultGroup {\n const cornerRadiusCss = css`var(--collectionTileCornerRadius, 4px)`;\n\n return css`\n #collection-image-container {\n display: flex;\n justify-content: center;\n flex: 1;\n }\n\n #collection-image {\n width: 16rem;\n height: 16rem;\n border-radius: 0.8rem;\n overflow: hidden;\n box-shadow: 1px 1px 2px 0px;\n object-fit: cover;\n background-position: center;\n background-size: cover;\n }\n\n #item-count-image-container svg {\n filter: invert(100%);\n }\n\n #collection-image-title {\n background-color: #666;\n border: 1px solid #2c2c2c;\n padding: 0.5rem;\n border-top-left-radius: ${cornerRadiusCss};\n border-top-right-radius: ${cornerRadiusCss};\n display: flex;\n flex-direction: column;\n flex: 1;\n }\n\n #collection-title {\n font-weight: bold;\n color: #fff;\n font-size: 1.6rem;\n text-align: center;\n margin-bottom: 0.5rem;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n line-height: 2rem;\n height: 4rem;\n }\n\n #container {\n box-shadow: 1px 1px 2px 0px;\n border-radius: ${cornerRadiusCss};\n height: 100%;\n display: flex;\n flex-direction: column;\n }\n\n #container:hover > #collection-image-title > #collection-title {\n text-decoration: underline;\n }\n\n /* this is a workaround for Safari 15 where the hover effects are not working */\n #collection-image-title:hover > #collection-title {\n text-decoration: underline;\n }\n\n #container:hover > #collection-image-title {\n background-color: #757575;\n }\n\n #item-count-container {\n background-color: #444;\n border-bottom: 1px solid #2c2c2c;\n border-left: 1px solid #2c2c2c;\n border-right: 1px solid #2c2c2c;\n border-bottom-left-radius: ${cornerRadiusCss};\n border-bottom-right-radius: ${cornerRadiusCss};\n display: flex;\n padding: 0rem 0.5rem;\n height: 5.5rem;\n align-items: center;\n }\n\n #item-count-image-container {\n margin-right: 0.5rem;\n }\n\n #item-count-stacked-text {\n display: flex;\n align-items: baseline;\n color: #fff;\n }\n #item-count-image-container svg {\n height: 2.5rem;\n align-items: baseline;\n }\n\n #container:hover > #item-count-container {\n background-color: #575757;\n }\n\n #item-count {\n font-size: 1.4rem;\n font-weight: bold;\n }\n\n #item-count-image {\n width: 3rem;\n height: 3rem;\n margin-right: 1rem;\n }\n\n #items-text {\n font-size: 1.4rem;\n font-weight: bold;\n margin-left: 0.5rem;\n }\n `;\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare const accountIcon: import("lit-html").TemplateResult<2>;
@@ -0,0 +1,12 @@
1
+ import { svg } from 'lit';
2
+ export const accountIcon = svg `
3
+ <svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
4
+ <path
5
+ d="m89.6854559 79.6500588c1.7300364 6.4823648 2.180423 13.3122689 3.3145441 20.3499412h-86c.5683151-15.8558542 2.98334063-30.7849367 15.1676149-41.6581341 22.9948067-20.518674 59.250299-9.0032844 67.517841 21.3081929zm-40.0998307-79.6500588c10.872402.0493248 19.9700408 9.25722341 19.917959 20.1421788-.0829413 11.042868-8.9616237 19.8492523-20.0602807 19.8578212-11.1181198 0-19.9397193-8.7904706-19.9397193-19.8908727-.0327543-11.11998815 9.0125781-20.17487063 20.082041-20.1091273z"
6
+ fill="#333"
7
+ fill-rule="evenodd"
8
+ />
9
+ <title>Icon of a person</title>
10
+ </svg>
11
+ `;
12
+ //# sourceMappingURL=account.js.map