@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.
- package/.editorconfig +29 -0
- package/.github/workflows/ci.yml +26 -0
- package/.husky/pre-commit +4 -0
- package/LICENSE +661 -0
- package/README.md +68 -0
- package/demo/app-root.ts +414 -0
- package/demo/index.html +26 -0
- package/dist/demo/app-root.d.ts +43 -0
- package/dist/demo/app-root.js +385 -0
- package/dist/demo/app-root.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/src/assets/img/icons/audio.d.ts +1 -0
- package/dist/src/assets/img/icons/audio.js +9 -0
- package/dist/src/assets/img/icons/audio.js.map +1 -0
- package/dist/src/assets/img/icons/collection.d.ts +1 -0
- package/dist/src/assets/img/icons/collection.js +9 -0
- package/dist/src/assets/img/icons/collection.js.map +1 -0
- package/dist/src/assets/img/icons/etree.d.ts +1 -0
- package/dist/src/assets/img/icons/etree.js +9 -0
- package/dist/src/assets/img/icons/etree.js.map +1 -0
- package/dist/src/assets/img/icons/images.d.ts +1 -0
- package/dist/src/assets/img/icons/images.js +10 -0
- package/dist/src/assets/img/icons/images.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/account.d.ts +2 -0
- package/dist/src/assets/img/icons/mediatype/account.js +12 -0
- package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/audio.js +11 -0
- package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/collection.js +9 -0
- package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/etree copy.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/etree copy.js +9 -0
- package/dist/src/assets/img/icons/mediatype/etree copy.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/etree.js +9 -0
- package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/film.js +13 -0
- package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/images.js +10 -0
- package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/livemusic.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/livemusic.js +7 -0
- package/dist/src/assets/img/icons/mediatype/livemusic.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/photos.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/photos.js +7 -0
- package/dist/src/assets/img/icons/mediatype/photos.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/software.js +10 -0
- package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/texts.js +10 -0
- package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/tv.js +9 -0
- package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/video.js +10 -0
- package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
- package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
- package/dist/src/assets/img/icons/mediatype/web.js +10 -0
- package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
- package/dist/src/assets/img/icons/software.d.ts +1 -0
- package/dist/src/assets/img/icons/software.js +10 -0
- package/dist/src/assets/img/icons/software.js.map +1 -0
- package/dist/src/assets/img/icons/texts.d.ts +1 -0
- package/dist/src/assets/img/icons/texts.js +10 -0
- package/dist/src/assets/img/icons/texts.js.map +1 -0
- package/dist/src/assets/img/icons/tv.d.ts +1 -0
- package/dist/src/assets/img/icons/tv.js +9 -0
- package/dist/src/assets/img/icons/tv.js.map +1 -0
- package/dist/src/assets/img/icons/video.d.ts +1 -0
- package/dist/src/assets/img/icons/video.js +10 -0
- package/dist/src/assets/img/icons/video.js.map +1 -0
- package/dist/src/assets/img/icons/web.d.ts +1 -0
- package/dist/src/assets/img/icons/web.js +10 -0
- package/dist/src/assets/img/icons/web.js.map +1 -0
- package/dist/src/circular-activity-indicator.d.ts +5 -0
- package/dist/src/circular-activity-indicator.js +66 -0
- package/dist/src/circular-activity-indicator.js.map +1 -0
- package/dist/src/collection-browser.d.ts +151 -0
- package/dist/src/collection-browser.js +697 -0
- package/dist/src/collection-browser.js.map +1 -0
- package/dist/src/collection-facets.d.ts +34 -0
- package/dist/src/collection-facets.js +245 -0
- package/dist/src/collection-facets.js.map +1 -0
- package/dist/src/mediatype-icon.d.ts +9 -0
- package/dist/src/mediatype-icon.js +89 -0
- package/dist/src/mediatype-icon.js.map +1 -0
- package/dist/src/models.d.ts +23 -0
- package/dist/src/models.js +2 -0
- package/dist/src/models.js.map +1 -0
- package/dist/src/sort-filter-bar/alpha-bar.d.ts +10 -0
- package/dist/src/sort-filter-bar/alpha-bar.js +88 -0
- package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +24 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.js +257 -0
- package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
- package/dist/src/tiles/grid/account-tile.d.ts +7 -0
- package/dist/src/tiles/grid/account-tile.js +144 -0
- package/dist/src/tiles/grid/account-tile.js.map +1 -0
- package/dist/src/tiles/grid/collection-tile.d.ts +7 -0
- package/dist/src/tiles/grid/collection-tile.js +160 -0
- package/dist/src/tiles/grid/collection-tile.js.map +1 -0
- package/dist/src/tiles/grid/icons/account.d.ts +1 -0
- package/dist/src/tiles/grid/icons/account.js +12 -0
- package/dist/src/tiles/grid/icons/account.js.map +1 -0
- package/dist/src/tiles/grid/icons/favorite-filled.d.ts +1 -0
- package/dist/src/tiles/grid/icons/favorite-filled.js +11 -0
- package/dist/src/tiles/grid/icons/favorite-filled.js.map +1 -0
- package/dist/src/tiles/grid/icons/reviews.d.ts +1 -0
- package/dist/src/tiles/grid/icons/reviews.js +11 -0
- package/dist/src/tiles/grid/icons/reviews.js.map +1 -0
- package/dist/src/tiles/grid/icons/upload.d.ts +1 -0
- package/dist/src/tiles/grid/icons/upload.js +12 -0
- package/dist/src/tiles/grid/icons/upload.js.map +1 -0
- package/dist/src/tiles/grid/icons/views.d.ts +2 -0
- package/dist/src/tiles/grid/icons/views.js +11 -0
- package/dist/src/tiles/grid/icons/views.js.map +1 -0
- package/dist/src/tiles/grid/item-tile.d.ts +9 -0
- package/dist/src/tiles/grid/item-tile.js +240 -0
- package/dist/src/tiles/grid/item-tile.js.map +1 -0
- package/dist/src/tiles/list/tile-list-compact.d.ts +16 -0
- package/dist/src/tiles/list/tile-list-compact.js +125 -0
- package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
- package/dist/src/tiles/list/tile-list-detail.d.ts +17 -0
- package/dist/src/tiles/list/tile-list-detail.js +181 -0
- package/dist/src/tiles/list/tile-list-detail.js.map +1 -0
- package/dist/src/tiles/list/tile-list.d.ts +21 -0
- package/dist/src/tiles/list/tile-list.js +229 -0
- package/dist/src/tiles/list/tile-list.js.map +1 -0
- package/dist/src/tiles/loading-tile.d.ts +5 -0
- package/dist/src/tiles/loading-tile.js +73 -0
- package/dist/src/tiles/loading-tile.js.map +1 -0
- package/dist/src/tiles/tile-dispatcher.d.ts +27 -0
- package/dist/src/tiles/tile-dispatcher.js +160 -0
- package/dist/src/tiles/tile-dispatcher.js.map +1 -0
- package/dist/src/utils/format-count.d.ts +7 -0
- package/dist/src/utils/format-count.js +76 -0
- package/dist/src/utils/format-count.js.map +1 -0
- package/dist/src/utils/format-date.d.ts +2 -0
- package/dist/src/utils/format-date.js +24 -0
- package/dist/src/utils/format-date.js.map +1 -0
- package/dist/src/utils/format-string.d.ts +2 -0
- package/dist/src/utils/format-string.js +7 -0
- package/dist/src/utils/format-string.js.map +1 -0
- package/dist/test/collection-browser.test.d.ts +0 -0
- package/dist/test/collection-browser.test.js +3 -0
- package/dist/test/collection-browser.test.js.map +1 -0
- package/dist/test/utils/format-count.test.d.ts +1 -0
- package/dist/test/utils/format-count.test.js +24 -0
- package/dist/test/utils/format-count.test.js.map +1 -0
- package/dist/test/utils/format-date.test.d.ts +1 -0
- package/dist/test/utils/format-date.test.js +18 -0
- package/dist/test/utils/format-date.test.js.map +1 -0
- package/dist/test/utils/format-string.test.d.ts +1 -0
- package/dist/test/utils/format-string.test.js +17 -0
- package/dist/test/utils/format-string.test.js.map +1 -0
- package/index.ts +3 -0
- package/package.json +95 -0
- package/src/assets/img/icons/mediatype/account.ts +12 -0
- package/src/assets/img/icons/mediatype/audio.ts +11 -0
- package/src/assets/img/icons/mediatype/collection.ts +9 -0
- package/src/assets/img/icons/mediatype/etree.ts +9 -0
- package/src/assets/img/icons/mediatype/film.ts +13 -0
- package/src/assets/img/icons/mediatype/foo.svg +5 -0
- package/src/assets/img/icons/mediatype/images.ts +10 -0
- package/src/assets/img/icons/mediatype/software.ts +10 -0
- package/src/assets/img/icons/mediatype/texts.ts +10 -0
- package/src/assets/img/icons/mediatype/tv.ts +9 -0
- package/src/assets/img/icons/mediatype/video.ts +10 -0
- package/src/assets/img/icons/mediatype/web.ts +10 -0
- package/src/circular-activity-indicator.ts +64 -0
- package/src/collection-browser.ts +756 -0
- package/src/collection-facets.ts +285 -0
- package/src/mediatype-icon.ts +83 -0
- package/src/models.ts +25 -0
- package/src/sort-filter-bar/alpha-bar.ts +86 -0
- package/src/sort-filter-bar/sort-filter-bar.ts +256 -0
- package/src/tiles/grid/account-tile.ts +141 -0
- package/src/tiles/grid/collection-tile.ts +157 -0
- package/src/tiles/grid/icons/account.ts +12 -0
- package/src/tiles/grid/icons/favorite-filled.ts +11 -0
- package/src/tiles/grid/icons/reviews.ts +11 -0
- package/src/tiles/grid/icons/upload.ts +12 -0
- package/src/tiles/grid/icons/views.ts +11 -0
- package/src/tiles/grid/item-tile.ts +254 -0
- package/src/tiles/list/tile-list.ts +227 -0
- package/src/tiles/loading-tile.ts +70 -0
- package/src/tiles/tile-dispatcher.ts +160 -0
- package/src/utils/format-count.ts +95 -0
- package/src/utils/format-date.ts +36 -0
- package/test/collection-browser.test.ts +1 -0
- package/test/utils/format-count.test.ts +32 -0
- package/test/utils/format-date.test.ts +22 -0
- package/tsconfig.json +20 -0
- package/web-dev-server.config.mjs +28 -0
- 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,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,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
|