@internetarchive/collection-browser 0.2.15 → 0.2.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (222) hide show
  1. package/dist/index.d.ts +9 -0
  2. package/dist/index.js.map +1 -0
  3. package/dist/src/app-root.d.ts +32 -0
  4. package/dist/src/app-root.js +285 -0
  5. package/dist/src/app-root.js.map +1 -0
  6. package/dist/src/assets/img/icons/chevron.d.ts +2 -0
  7. package/dist/src/assets/img/icons/chevron.js +4 -0
  8. package/dist/src/assets/img/icons/chevron.js.map +1 -0
  9. package/dist/src/assets/img/icons/empty-query.d.ts +2 -0
  10. package/dist/src/assets/img/icons/empty-query.js +5 -0
  11. package/dist/src/assets/img/icons/empty-query.js.map +1 -0
  12. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -0
  13. package/dist/src/assets/img/icons/eye-closed.js +5 -0
  14. package/dist/src/assets/img/icons/eye-closed.js.map +1 -0
  15. package/dist/src/assets/img/icons/eye.d.ts +2 -0
  16. package/dist/src/assets/img/icons/eye.js +5 -0
  17. package/dist/src/assets/img/icons/eye.js.map +1 -0
  18. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -0
  19. package/dist/src/assets/img/icons/favorite-filled.js +11 -0
  20. package/dist/src/assets/img/icons/favorite-filled.js.map +1 -0
  21. package/dist/src/assets/img/icons/login-required.d.ts +1 -0
  22. package/dist/src/assets/img/icons/login-required.js +30 -0
  23. package/dist/src/assets/img/icons/login-required.js.map +1 -0
  24. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -0
  25. package/dist/src/assets/img/icons/mediatype/account.js +14 -0
  26. package/dist/src/assets/img/icons/mediatype/account.js.map +1 -0
  27. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -0
  28. package/dist/src/assets/img/icons/mediatype/audio.js +14 -0
  29. package/dist/src/assets/img/icons/mediatype/audio.js.map +1 -0
  30. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -0
  31. package/dist/src/assets/img/icons/mediatype/collection.js +12 -0
  32. package/dist/src/assets/img/icons/mediatype/collection.js.map +1 -0
  33. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -0
  34. package/dist/src/assets/img/icons/mediatype/data.js +15 -0
  35. package/dist/src/assets/img/icons/mediatype/data.js.map +1 -0
  36. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -0
  37. package/dist/src/assets/img/icons/mediatype/etree.js +14 -0
  38. package/dist/src/assets/img/icons/mediatype/etree.js.map +1 -0
  39. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -0
  40. package/dist/src/assets/img/icons/mediatype/film.js +14 -0
  41. package/dist/src/assets/img/icons/mediatype/film.js.map +1 -0
  42. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -0
  43. package/dist/src/assets/img/icons/mediatype/images.js +13 -0
  44. package/dist/src/assets/img/icons/mediatype/images.js.map +1 -0
  45. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -0
  46. package/dist/src/assets/img/icons/mediatype/radio.js +15 -0
  47. package/dist/src/assets/img/icons/mediatype/radio.js.map +1 -0
  48. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -0
  49. package/dist/src/assets/img/icons/mediatype/software.js +13 -0
  50. package/dist/src/assets/img/icons/mediatype/software.js.map +1 -0
  51. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -0
  52. package/dist/src/assets/img/icons/mediatype/texts.js +13 -0
  53. package/dist/src/assets/img/icons/mediatype/texts.js.map +1 -0
  54. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -0
  55. package/dist/src/assets/img/icons/mediatype/tv.js +14 -0
  56. package/dist/src/assets/img/icons/mediatype/tv.js.map +1 -0
  57. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -0
  58. package/dist/src/assets/img/icons/mediatype/video.js +14 -0
  59. package/dist/src/assets/img/icons/mediatype/video.js.map +1 -0
  60. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -0
  61. package/dist/src/assets/img/icons/mediatype/web.js +13 -0
  62. package/dist/src/assets/img/icons/mediatype/web.js.map +1 -0
  63. package/dist/src/assets/img/icons/null-result.d.ts +2 -0
  64. package/dist/src/assets/img/icons/null-result.js +5 -0
  65. package/dist/src/assets/img/icons/null-result.js.map +1 -0
  66. package/dist/src/assets/img/icons/restricted.d.ts +1 -0
  67. package/dist/src/assets/img/icons/restricted.js +29 -0
  68. package/dist/src/assets/img/icons/restricted.js.map +1 -0
  69. package/dist/src/assets/img/icons/reviews.d.ts +1 -0
  70. package/dist/src/assets/img/icons/reviews.js +11 -0
  71. package/dist/src/assets/img/icons/reviews.js.map +1 -0
  72. package/dist/src/assets/img/icons/upload.d.ts +1 -0
  73. package/dist/src/assets/img/icons/upload.js +12 -0
  74. package/dist/src/assets/img/icons/upload.js.map +1 -0
  75. package/dist/src/assets/img/icons/views.d.ts +1 -0
  76. package/dist/src/assets/img/icons/views.js +11 -0
  77. package/dist/src/assets/img/icons/views.js.map +1 -0
  78. package/dist/src/circular-activity-indicator.d.ts +5 -0
  79. package/dist/src/circular-activity-indicator.js +66 -0
  80. package/dist/src/circular-activity-indicator.js.map +1 -0
  81. package/dist/src/collection-browser.d.ts +214 -0
  82. package/dist/src/collection-browser.js +1242 -0
  83. package/dist/src/collection-browser.js.map +1 -0
  84. package/dist/src/collection-facets.d.ts +63 -0
  85. package/dist/src/collection-facets.js +560 -0
  86. package/dist/src/collection-facets.js.map +1 -0
  87. package/dist/src/empty-placeholder.d.ts +11 -0
  88. package/dist/src/empty-placeholder.js +83 -0
  89. package/dist/src/empty-placeholder.js.map +1 -0
  90. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -0
  91. package/dist/src/language-code-handler/language-code-handler.js +27 -0
  92. package/dist/src/language-code-handler/language-code-handler.js.map +1 -0
  93. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -0
  94. package/dist/src/language-code-handler/language-code-mapping.js +563 -0
  95. package/dist/src/language-code-handler/language-code-mapping.js.map +1 -0
  96. package/dist/src/mediatype/mediatype-config.d.ts +3 -0
  97. package/dist/src/mediatype/mediatype-config.js +86 -0
  98. package/dist/src/mediatype/mediatype-config.js.map +1 -0
  99. package/dist/src/models.d.ts +85 -0
  100. package/dist/src/models.js +62 -0
  101. package/dist/src/models.js.map +1 -0
  102. package/dist/src/restoration-state-handler.d.ts +38 -0
  103. package/dist/src/restoration-state-handler.js +204 -0
  104. package/dist/src/restoration-state-handler.js.map +1 -0
  105. package/dist/src/sort-filter-bar/alpha-bar.d.ts +9 -0
  106. package/dist/src/sort-filter-bar/alpha-bar.js +98 -0
  107. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -0
  108. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -0
  109. package/dist/src/sort-filter-bar/img/compact.js +5 -0
  110. package/dist/src/sort-filter-bar/img/compact.js.map +1 -0
  111. package/dist/src/sort-filter-bar/img/list.d.ts +1 -0
  112. package/dist/src/sort-filter-bar/img/list.js +5 -0
  113. package/dist/src/sort-filter-bar/img/list.js.map +1 -0
  114. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -0
  115. package/dist/src/sort-filter-bar/img/sort-triangle.js +5 -0
  116. package/dist/src/sort-filter-bar/img/sort-triangle.js.map +1 -0
  117. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -0
  118. package/dist/src/sort-filter-bar/img/tile.js +5 -0
  119. package/dist/src/sort-filter-bar/img/tile.js.map +1 -0
  120. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +107 -0
  121. package/dist/src/sort-filter-bar/sort-filter-bar.js +782 -0
  122. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -0
  123. package/dist/src/styles/item-image-styles.d.ts +8 -0
  124. package/dist/src/styles/item-image-styles.js +102 -0
  125. package/dist/src/styles/item-image-styles.js.map +1 -0
  126. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -0
  127. package/dist/src/tiles/collection-browser-loading-tile.js +32 -0
  128. package/dist/src/tiles/collection-browser-loading-tile.js.map +1 -0
  129. package/dist/src/tiles/grid/account-tile.d.ts +8 -0
  130. package/dist/src/tiles/grid/account-tile.js +126 -0
  131. package/dist/src/tiles/grid/account-tile.js.map +1 -0
  132. package/dist/src/tiles/grid/collection-tile.d.ts +7 -0
  133. package/dist/src/tiles/grid/collection-tile.js +159 -0
  134. package/dist/src/tiles/grid/collection-tile.js.map +1 -0
  135. package/dist/src/tiles/grid/item-tile.d.ts +21 -0
  136. package/dist/src/tiles/grid/item-tile.js +183 -0
  137. package/dist/src/tiles/grid/item-tile.js.map +1 -0
  138. package/dist/src/tiles/grid/tile-stats.d.ts +10 -0
  139. package/dist/src/tiles/grid/tile-stats.js +134 -0
  140. package/dist/src/tiles/grid/tile-stats.js.map +1 -0
  141. package/dist/src/tiles/image-block.d.ts +17 -0
  142. package/dist/src/tiles/image-block.js +136 -0
  143. package/dist/src/tiles/image-block.js.map +1 -0
  144. package/dist/src/tiles/item-image.d.ts +31 -0
  145. package/dist/src/tiles/item-image.js +118 -0
  146. package/dist/src/tiles/item-image.js.map +1 -0
  147. package/dist/src/tiles/list/account-label.d.ts +1 -0
  148. package/dist/src/tiles/list/account-label.js +7 -0
  149. package/dist/src/tiles/list/account-label.js.map +1 -0
  150. package/dist/src/tiles/list/date-label.d.ts +1 -0
  151. package/dist/src/tiles/list/date-label.js +13 -0
  152. package/dist/src/tiles/list/date-label.js.map +1 -0
  153. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -0
  154. package/dist/src/tiles/list/tile-list-compact-header.js +84 -0
  155. package/dist/src/tiles/list/tile-list-compact-header.js.map +1 -0
  156. package/dist/src/tiles/list/tile-list-compact.d.ts +20 -0
  157. package/dist/src/tiles/list/tile-list-compact.js +180 -0
  158. package/dist/src/tiles/list/tile-list-compact.js.map +1 -0
  159. package/dist/src/tiles/list/tile-list.d.ts +48 -0
  160. package/dist/src/tiles/list/tile-list.js +455 -0
  161. package/dist/src/tiles/list/tile-list.js.map +1 -0
  162. package/dist/src/tiles/mediatype-icon.d.ts +9 -0
  163. package/dist/src/tiles/mediatype-icon.js +82 -0
  164. package/dist/src/tiles/mediatype-icon.js.map +1 -0
  165. package/dist/src/tiles/overlay/icon-overlay.d.ts +7 -0
  166. package/dist/src/tiles/overlay/icon-overlay.js +43 -0
  167. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -0
  168. package/dist/src/tiles/overlay/text-overlay.d.ts +8 -0
  169. package/dist/src/tiles/overlay/text-overlay.js +57 -0
  170. package/dist/src/tiles/overlay/text-overlay.js.map +1 -0
  171. package/dist/src/tiles/tile-dispatcher.d.ts +36 -0
  172. package/dist/src/tiles/tile-dispatcher.js +215 -0
  173. package/dist/src/tiles/tile-dispatcher.js.map +1 -0
  174. package/dist/src/utils/format-count.d.ts +7 -0
  175. package/dist/src/utils/format-count.js +76 -0
  176. package/dist/src/utils/format-count.js.map +1 -0
  177. package/dist/src/utils/format-date.d.ts +2 -0
  178. package/dist/src/utils/format-date.js +24 -0
  179. package/dist/src/utils/format-date.js.map +1 -0
  180. package/dist/test/collection-browser.test.d.ts +1 -0
  181. package/dist/test/collection-browser.test.js +82 -0
  182. package/dist/test/collection-browser.test.js.map +1 -0
  183. package/dist/test/empty-placeholder.test.d.ts +1 -0
  184. package/dist/test/empty-placeholder.test.js +34 -0
  185. package/dist/test/empty-placeholder.test.js.map +1 -0
  186. package/dist/test/icon-overlay.test.d.ts +1 -0
  187. package/dist/test/icon-overlay.test.js +31 -0
  188. package/dist/test/icon-overlay.test.js.map +1 -0
  189. package/dist/test/item-image.test.d.ts +1 -0
  190. package/dist/test/item-image.test.js +73 -0
  191. package/dist/test/item-image.test.js.map +1 -0
  192. package/dist/test/mediatype-config.test.d.ts +1 -0
  193. package/dist/test/mediatype-config.test.js +17 -0
  194. package/dist/test/mediatype-config.test.js.map +1 -0
  195. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -0
  196. package/dist/test/mocks/mock-collection-name-cache.js +14 -0
  197. package/dist/test/mocks/mock-collection-name-cache.js.map +1 -0
  198. package/dist/test/mocks/mock-search-responses.d.ts +3 -0
  199. package/dist/test/mocks/mock-search-responses.js +32 -0
  200. package/dist/test/mocks/mock-search-responses.js.map +1 -0
  201. package/dist/test/mocks/mock-search-service.d.ts +8 -0
  202. package/dist/test/mocks/mock-search-service.js +16 -0
  203. package/dist/test/mocks/mock-search-service.js.map +1 -0
  204. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -0
  205. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +122 -0
  206. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -0
  207. package/dist/test/text-overlay.test.d.ts +1 -0
  208. package/dist/test/text-overlay.test.js +48 -0
  209. package/dist/test/text-overlay.test.js.map +1 -0
  210. package/dist/test/tile-stats.test.d.ts +1 -0
  211. package/dist/test/tile-stats.test.js +42 -0
  212. package/dist/test/tile-stats.test.js.map +1 -0
  213. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -0
  214. package/dist/test/tiles/grid/item-tile.test.js +96 -0
  215. package/dist/test/tiles/grid/item-tile.test.js.map +1 -0
  216. package/dist/test/utils/format-count.test.d.ts +1 -0
  217. package/dist/test/utils/format-count.test.js +24 -0
  218. package/dist/test/utils/format-count.test.js.map +1 -0
  219. package/dist/test/utils/format-date.test.d.ts +1 -0
  220. package/dist/test/utils/format-date.test.js +18 -0
  221. package/dist/test/utils/format-date.test.js.map +1 -0
  222. package/package.json +1 -1
@@ -0,0 +1,782 @@
1
+ import { __decorate } from "tslib";
2
+ import { LitElement, html, css, nothing, } from 'lit';
3
+ import { customElement, property, query, state } from 'lit/decorators.js';
4
+ import { SortField, SortFieldDisplayName, } from '../models';
5
+ import './alpha-bar';
6
+ import { sortIcon } from './img/sort-triangle';
7
+ import { tileIcon } from './img/tile';
8
+ import { listIcon } from './img/list';
9
+ import { compactIcon } from './img/compact';
10
+ let SortFilterBar = class SortFilterBar extends LitElement {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.sortDirection = null;
14
+ this.selectedSort = SortField.relevance;
15
+ this.selectedTitleFilter = null;
16
+ this.selectedCreatorFilter = null;
17
+ this.showRelevance = true;
18
+ this.alphaSelectorVisible = null;
19
+ this.dateSortSelectorVisible = false;
20
+ this.viewSortSelectorVisible = false;
21
+ this.desktopSelectorBarWidth = 0;
22
+ this.selectorBarContainerWidth = 0;
23
+ this.hoveringOverDateSortOptions = false;
24
+ this.boundSortBarSelectorEscapeListener = (e) => {
25
+ if (e.key === 'Escape') {
26
+ this.viewSortSelectorVisible = false;
27
+ this.dateSortSelectorVisible = false;
28
+ }
29
+ };
30
+ }
31
+ render() {
32
+ return html `
33
+ <div id="container">
34
+ <div id="sort-bar">
35
+ <div id="sort-direction-container">
36
+ ${this.sortDirectionSelectorTemplate}
37
+ </div>
38
+
39
+ <div id="sort-selector-container">
40
+ ${this.mobileSortSelectorTemplate}
41
+ ${this.desktopSortSelectorTemplate}
42
+ </div>
43
+
44
+ <div id="display-style-selector">${this.displayOptionTemplate}</div>
45
+ </div>
46
+
47
+ ${this.viewSortSelectorVisible && !this.mobileSelectorVisible
48
+ ? this.viewSortSelector
49
+ : nothing}
50
+ ${this.dateSortSelectorVisible && !this.mobileSelectorVisible
51
+ ? this.dateSortSelector
52
+ : nothing}
53
+ ${this.alphaBarTemplate}
54
+
55
+ <div id="bottom-shadow"></div>
56
+ </div>
57
+ `;
58
+ }
59
+ updated(changed) {
60
+ if (changed.has('displayMode')) {
61
+ this.displayModeChanged();
62
+ }
63
+ if (changed.has('selectedSort') && this.sortDirection === null) {
64
+ this.sortDirection = 'desc';
65
+ }
66
+ if (changed.has('selectedTitleFilter') && this.selectedTitleFilter) {
67
+ this.alphaSelectorVisible = 'title';
68
+ }
69
+ if (changed.has('selectedCreatorFilter') && this.selectedCreatorFilter) {
70
+ this.alphaSelectorVisible = 'creator';
71
+ }
72
+ if (changed.has('dateSortSelectorVisible') ||
73
+ changed.has('viewSortSelectorVisible')) {
74
+ this.setupEscapeListeners();
75
+ }
76
+ if (changed.has('resizeObserver')) {
77
+ const oldObserver = changed.get('resizeObserver');
78
+ if (oldObserver)
79
+ this.disconnectResizeObserver(oldObserver);
80
+ this.setupResizeObserver();
81
+ }
82
+ }
83
+ setupEscapeListeners() {
84
+ if (this.dateSortSelectorVisible || this.viewSortSelectorVisible) {
85
+ document.addEventListener('keydown', this.boundSortBarSelectorEscapeListener);
86
+ }
87
+ else {
88
+ document.removeEventListener('keydown', this.boundSortBarSelectorEscapeListener);
89
+ }
90
+ }
91
+ disconnectedCallback() {
92
+ if (this.resizeObserver) {
93
+ this.disconnectResizeObserver(this.resizeObserver);
94
+ }
95
+ }
96
+ disconnectResizeObserver(resizeObserver) {
97
+ resizeObserver.removeObserver({
98
+ target: this.sortSelectorContainer,
99
+ handler: this,
100
+ });
101
+ resizeObserver.removeObserver({
102
+ target: this.desktopSortSelector,
103
+ handler: this,
104
+ });
105
+ }
106
+ setupResizeObserver() {
107
+ if (!this.resizeObserver)
108
+ return;
109
+ this.resizeObserver.addObserver({
110
+ target: this.sortSelectorContainer,
111
+ handler: this,
112
+ });
113
+ this.resizeObserver.addObserver({
114
+ target: this.desktopSortSelector,
115
+ handler: this,
116
+ });
117
+ }
118
+ get mobileSelectorVisible() {
119
+ return this.selectorBarContainerWidth - 10 < this.desktopSelectorBarWidth;
120
+ }
121
+ get alphaBarTemplate() {
122
+ if (!['title', 'creator'].includes(this.selectedSort))
123
+ return nothing;
124
+ if (this.alphaSelectorVisible === null) {
125
+ if (this.selectedSort === 'creator')
126
+ return this.creatorSelectorBar;
127
+ if (this.selectedSort === 'title')
128
+ return this.titleSelectorBar;
129
+ }
130
+ else {
131
+ return this.alphaSelectorVisible === 'creator'
132
+ ? this.creatorSelectorBar
133
+ : this.titleSelectorBar;
134
+ }
135
+ return nothing;
136
+ }
137
+ handleResize(entry) {
138
+ if (entry.target === this.desktopSortSelector) {
139
+ this.desktopSelectorBarWidth = entry.contentRect.width;
140
+ }
141
+ else if (entry.target === this.sortSelectorContainer) {
142
+ this.selectorBarContainerWidth = entry.contentRect.width;
143
+ }
144
+ }
145
+ get sortDirectionSelectorTemplate() {
146
+ return html `
147
+ <div id="sort-direction-selector">
148
+ <button
149
+ id="sort-ascending-btn"
150
+ class="sort-button ${this.sortDirection === 'asc' ? 'selected' : ''}"
151
+ ?disabled=${this.selectedSort === 'relevance'}
152
+ @click=${() => {
153
+ this.setSortDirections('asc');
154
+ }}
155
+ >
156
+ ${sortIcon}
157
+ </button>
158
+ <button
159
+ id="sort-descending-btn"
160
+ class="sort-button ${this.sortDirection === 'desc' ? 'selected' : ''}"
161
+ ?disabled=${this.selectedSort === 'relevance'}
162
+ @click=${() => {
163
+ this.setSortDirections('desc');
164
+ }}
165
+ >
166
+ ${sortIcon}
167
+ </button>
168
+ </div>
169
+ `;
170
+ }
171
+ get desktopSortSelectorTemplate() {
172
+ return html `
173
+ <ul
174
+ id="desktop-sort-selector"
175
+ class=${this.mobileSelectorVisible ? 'hidden' : 'visible'}
176
+ >
177
+ <li id="sort-by-text">Sort By</li>
178
+ <li>
179
+ ${this.showRelevance
180
+ ? this.getSortDisplayOption(SortField.relevance)
181
+ : nothing}
182
+ </li>
183
+ <li>
184
+ ${this.getSortDisplayOption(SortField.weeklyview, {
185
+ clickEvent: () => {
186
+ if (!this.viewOptionSelected)
187
+ this.setSelectedSort(SortField.weeklyview);
188
+ this.viewSortSelectorVisible = !this.viewSortSelectorVisible;
189
+ this.dateSortSelectorVisible = false;
190
+ this.alphaSelectorVisible = null;
191
+ this.selectedTitleFilter = null;
192
+ this.selectedCreatorFilter = null;
193
+ this.emitTitleLetterChangedEvent();
194
+ this.emitCreatorLetterChangedEvent();
195
+ },
196
+ displayName: html `${this.viewSortField}`,
197
+ isSelected: () => this.viewOptionSelected,
198
+ })}
199
+ </li>
200
+ <li>
201
+ ${this.getSortDisplayOption(SortField.title, {
202
+ clickEvent: () => {
203
+ this.alphaSelectorVisible = 'title';
204
+ this.selectedCreatorFilter = null;
205
+ this.dateSortSelectorVisible = false;
206
+ this.viewSortSelectorVisible = false;
207
+ this.setSelectedSort(SortField.title);
208
+ this.emitCreatorLetterChangedEvent();
209
+ },
210
+ })}
211
+ </li>
212
+ <li>
213
+ ${this.getSortDisplayOption(SortField.date, {
214
+ clickEvent: () => {
215
+ if (!this.dateOptionSelected)
216
+ this.setSelectedSort(SortField.date);
217
+ this.dateSortSelectorVisible = !this.dateSortSelectorVisible;
218
+ this.viewSortSelectorVisible = false;
219
+ this.alphaSelectorVisible = null;
220
+ this.selectedTitleFilter = null;
221
+ this.selectedCreatorFilter = null;
222
+ this.emitTitleLetterChangedEvent();
223
+ this.emitCreatorLetterChangedEvent();
224
+ },
225
+ displayName: html `${this.dateSortField}`,
226
+ isSelected: () => this.dateOptionSelected,
227
+ })}
228
+ </li>
229
+ <li>
230
+ ${this.getSortDisplayOption(SortField.creator, {
231
+ clickEvent: () => {
232
+ this.alphaSelectorVisible = 'creator';
233
+ this.selectedTitleFilter = null;
234
+ this.dateSortSelectorVisible = false;
235
+ this.setSelectedSort(SortField.creator);
236
+ this.emitTitleLetterChangedEvent();
237
+ },
238
+ })}
239
+ </li>
240
+ </ul>
241
+ `;
242
+ }
243
+ /**
244
+ * This generates each of the sort option links.
245
+ *
246
+ * It manages the display value and the selected state of the option.
247
+ *
248
+ * @param sortField
249
+ * @param options {
250
+ * additionalClickEvent?: () => void; If this is provided, it will also be called when the option is clicked.
251
+ * displayName?: TemplateResult; The name to display for the option. Defaults to the sortField display name.
252
+ * isSelected?: () => boolean; A function that returns true if the option is selected. Defaults to the selectedSort === sortField.
253
+ * }
254
+ * @returns
255
+ */
256
+ getSortDisplayOption(sortField, options) {
257
+ var _a, _b;
258
+ const isSelected = (_a = options === null || options === void 0 ? void 0 : options.isSelected) !== null && _a !== void 0 ? _a : (() => this.selectedSort === sortField);
259
+ const displayName = (_b = options === null || options === void 0 ? void 0 : options.displayName) !== null && _b !== void 0 ? _b : SortFieldDisplayName[sortField];
260
+ return html `
261
+ <a
262
+ href="#"
263
+ @click=${(e) => {
264
+ e.preventDefault();
265
+ if (options === null || options === void 0 ? void 0 : options.clickEvent) {
266
+ options.clickEvent(e);
267
+ }
268
+ else {
269
+ this.alphaSelectorVisible = null;
270
+ this.dateSortSelectorVisible = false;
271
+ this.selectedTitleFilter = null;
272
+ this.selectedCreatorFilter = null;
273
+ this.setSelectedSort(sortField);
274
+ this.emitTitleLetterChangedEvent();
275
+ this.emitCreatorLetterChangedEvent();
276
+ }
277
+ }}
278
+ class=${isSelected() ? 'selected' : ''}
279
+ >
280
+ ${displayName}
281
+ </a>
282
+ `;
283
+ }
284
+ get mobileSortSelectorTemplate() {
285
+ return html `
286
+ <select
287
+ id="mobile-sort-selector"
288
+ @change=${this.mobileSortChanged}
289
+ class=${this.mobileSelectorVisible ? 'visible' : 'hidden'}
290
+ >
291
+ ${Object.keys(SortField).map(field => html `
292
+ <option value="${field}" ?selected=${this.selectedSort === field}>
293
+ ${SortFieldDisplayName[field]}
294
+ </option>
295
+ `)}
296
+ </select>
297
+ `;
298
+ }
299
+ mobileSortChanged(e) {
300
+ const target = e.target;
301
+ this.setSelectedSort(target.value);
302
+ }
303
+ get displayOptionTemplate() {
304
+ return html `
305
+ <ul>
306
+ <li>
307
+ <button
308
+ id="grid-button"
309
+ @click=${() => {
310
+ this.displayMode = 'grid';
311
+ }}
312
+ class=${this.displayMode === 'grid' ? 'active' : ''}
313
+ title="Tile view"
314
+ >
315
+ ${tileIcon}
316
+ </button>
317
+ </li>
318
+ <li>
319
+ <button
320
+ id="list-detail-button"
321
+ @click=${() => {
322
+ this.displayMode = 'list-detail';
323
+ }}
324
+ class=${this.displayMode === 'list-detail' ? 'active' : ''}
325
+ title="List view"
326
+ >
327
+ ${listIcon}
328
+ </button>
329
+ </li>
330
+ <li>
331
+ <button
332
+ id="list-compact-button"
333
+ @click=${() => {
334
+ this.displayMode = 'list-compact';
335
+ }}
336
+ class=${this.displayMode === 'list-compact' ? 'active' : ''}
337
+ title="Compact list view"
338
+ >
339
+ ${compactIcon}
340
+ </button>
341
+ </li>
342
+ </ul>
343
+ `;
344
+ }
345
+ get dateSortSelector() {
346
+ return html `
347
+ <div
348
+ id="date-sort-selector-backdrop"
349
+ @keyup=${() => {
350
+ this.dateSortSelectorVisible = false;
351
+ }}
352
+ @click=${() => {
353
+ this.dateSortSelectorVisible = false;
354
+ }}
355
+ ></div>
356
+ <div id="date-sort-selector">
357
+ <ul>
358
+ <li>${this.getDateSortButton(SortField.datearchived)}</li>
359
+ <li>${this.getDateSortButton(SortField.date)}</li>
360
+ <li>${this.getDateSortButton(SortField.datereviewed)}</li>
361
+ <li>${this.getDateSortButton(SortField.dateadded)}</li>
362
+ </ul>
363
+ </div>
364
+ `;
365
+ }
366
+ get viewSortSelector() {
367
+ return html `
368
+ <div
369
+ id="view-sort-selector-backdrop"
370
+ @keyup=${() => {
371
+ this.viewSortSelectorVisible = false;
372
+ }}
373
+ @click=${() => {
374
+ this.viewSortSelectorVisible = false;
375
+ }}
376
+ ></div>
377
+ <div id="view-sort-selector">
378
+ <ul>
379
+ <li>${this.getDateSortButton(SortField.alltimeview)}</li>
380
+ <li>${this.getDateSortButton(SortField.weeklyview)}</li>
381
+ </ul>
382
+ </div>
383
+ `;
384
+ }
385
+ getDateSortButton(sortField) {
386
+ return html `
387
+ <button
388
+ @click=${() => {
389
+ this.selectDateSort(sortField);
390
+ }}
391
+ class=${this.selectedSort === sortField ? 'selected' : ''}
392
+ >
393
+ ${SortFieldDisplayName[sortField]}
394
+ </button>
395
+ `;
396
+ }
397
+ selectDateSort(sortField) {
398
+ this.dateSortSelectorVisible = false;
399
+ this.viewSortSelectorVisible = false;
400
+ this.setSelectedSort(sortField);
401
+ }
402
+ setSortDirections(sortDirection) {
403
+ this.sortDirection = sortDirection;
404
+ this.emitSortChangedEvent();
405
+ }
406
+ setSelectedSort(sort) {
407
+ this.selectedSort = sort;
408
+ this.emitSortChangedEvent();
409
+ }
410
+ /**
411
+ * There are four date sort options.
412
+ *
413
+ * This checks to see if the current sort is one of them.
414
+ *
415
+ * @readonly
416
+ * @private
417
+ * @type {boolean}
418
+ * @memberof SortFilterBar
419
+ */
420
+ get dateOptionSelected() {
421
+ const dateSortFields = [
422
+ SortField.datearchived,
423
+ SortField.date,
424
+ SortField.datereviewed,
425
+ SortField.dateadded,
426
+ ];
427
+ return dateSortFields.includes(this.selectedSort);
428
+ }
429
+ /**
430
+ * There are two view sort options.
431
+ *
432
+ * This checks to see if the current sort is one of them.
433
+ *
434
+ * @readonly
435
+ * @private
436
+ * @type {boolean}
437
+ * @memberof SortFilterBar
438
+ */
439
+ get viewOptionSelected() {
440
+ const viewSortFields = [
441
+ SortField.alltimeview,
442
+ SortField.weeklyview,
443
+ ];
444
+ return viewSortFields.includes(this.selectedSort);
445
+ }
446
+ /**
447
+ * The display name of the current date field
448
+ *
449
+ * @readonly
450
+ * @private
451
+ * @type {string}
452
+ * @memberof SortFilterBar
453
+ */
454
+ get dateSortField() {
455
+ var _a;
456
+ const defaultSort = SortFieldDisplayName[SortField.date];
457
+ const name = this.dateOptionSelected
458
+ ? (_a = SortFieldDisplayName[this.selectedSort]) !== null && _a !== void 0 ? _a : defaultSort
459
+ : defaultSort;
460
+ return name;
461
+ }
462
+ /**
463
+ * The display name of the current view field
464
+ *
465
+ * @readonly
466
+ * @private
467
+ * @type {string}
468
+ * @memberof SortFilterBar
469
+ */
470
+ get viewSortField() {
471
+ var _a;
472
+ const defaultSort = SortFieldDisplayName[SortField.weeklyview];
473
+ const name = this.viewOptionSelected
474
+ ? (_a = SortFieldDisplayName[this.selectedSort]) !== null && _a !== void 0 ? _a : defaultSort
475
+ : defaultSort;
476
+ return name;
477
+ }
478
+ get titleSelectorBar() {
479
+ return html ` <alpha-bar
480
+ .selectedLetter=${this.selectedTitleFilter}
481
+ @letterChanged=${this.titleLetterChanged}
482
+ ></alpha-bar>`;
483
+ }
484
+ get creatorSelectorBar() {
485
+ return html ` <alpha-bar
486
+ .selectedLetter=${this.selectedCreatorFilter}
487
+ @letterChanged=${this.creatorLetterChanged}
488
+ ></alpha-bar>`;
489
+ }
490
+ titleLetterChanged(e) {
491
+ var _a;
492
+ this.selectedTitleFilter = (_a = e.detail.selectedLetter) !== null && _a !== void 0 ? _a : null;
493
+ this.emitTitleLetterChangedEvent();
494
+ }
495
+ creatorLetterChanged(e) {
496
+ var _a;
497
+ this.selectedCreatorFilter = (_a = e.detail.selectedLetter) !== null && _a !== void 0 ? _a : null;
498
+ this.emitCreatorLetterChangedEvent();
499
+ }
500
+ emitTitleLetterChangedEvent() {
501
+ const event = new CustomEvent('titleLetterChanged', {
502
+ detail: { selectedLetter: this.selectedTitleFilter },
503
+ });
504
+ this.dispatchEvent(event);
505
+ }
506
+ emitCreatorLetterChangedEvent() {
507
+ const event = new CustomEvent('creatorLetterChanged', {
508
+ detail: { selectedLetter: this.selectedCreatorFilter },
509
+ });
510
+ this.dispatchEvent(event);
511
+ }
512
+ displayModeChanged() {
513
+ const event = new CustomEvent('displayModeChanged', {
514
+ detail: { displayMode: this.displayMode },
515
+ });
516
+ this.dispatchEvent(event);
517
+ }
518
+ emitSortChangedEvent() {
519
+ const event = new CustomEvent('sortChanged', {
520
+ detail: {
521
+ selectedSort: this.selectedSort,
522
+ sortDirection: this.sortDirection,
523
+ },
524
+ });
525
+ this.dispatchEvent(event);
526
+ }
527
+ };
528
+ SortFilterBar.styles = css `
529
+ #container {
530
+ position: relative;
531
+ }
532
+
533
+ #sort-bar {
534
+ display: flex;
535
+ justify-content: space-between;
536
+ border: 1px solid rgb(232, 232, 232);
537
+ align-items: center;
538
+ padding: 0.5rem 1.5rem;
539
+ }
540
+
541
+ #sort-direction-container {
542
+ flex: 0;
543
+ }
544
+
545
+ #sort-by-text {
546
+ text-transform: uppercase;
547
+ }
548
+
549
+ #bottom-shadow {
550
+ height: 1px;
551
+ width: 100%;
552
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
553
+ background-color: #bbb;
554
+ }
555
+
556
+ ul {
557
+ list-style: none;
558
+ display: flex;
559
+ margin: 0;
560
+ padding: 0;
561
+ align-items: center;
562
+ }
563
+
564
+ li {
565
+ padding: 0;
566
+ }
567
+
568
+ .sort-button {
569
+ background: none;
570
+ color: inherit;
571
+ border: none;
572
+ padding: 0;
573
+ cursor: pointer;
574
+ outline: inherit;
575
+ width: 12px;
576
+ height: 12px;
577
+ opacity: 0.5;
578
+ }
579
+
580
+ .sort-button.selected {
581
+ opacity: 1;
582
+ }
583
+
584
+ .sort-button:disabled {
585
+ opacity: 0.25;
586
+ cursor: default;
587
+ }
588
+
589
+ #date-sort-selector,
590
+ #view-sort-selector {
591
+ position: absolute;
592
+ left: 150px;
593
+ top: 45px;
594
+
595
+ z-index: 1;
596
+ padding: 1rem;
597
+ background-color: white;
598
+ border-radius: 2.5rem;
599
+ border: 1px solid #404142;
600
+ }
601
+
602
+ #date-sort-selector button,
603
+ #view-sort-selector button {
604
+ background: none;
605
+ border-radius: 15px;
606
+ color: #404142;
607
+ border: none;
608
+ appearance: none;
609
+ cursor: pointer;
610
+ -webkit-appearance: none;
611
+ font-size: 1.4rem;
612
+ font-weight: 400;
613
+ padding: 0.5rem 1.2rem;
614
+ }
615
+
616
+ #date-sort-selector button.selected,
617
+ #view-sort-selector button.selected {
618
+ background-color: #404142;
619
+ color: white;
620
+ }
621
+
622
+ #show-details {
623
+ text-transform: uppercase;
624
+ cursor: pointer;
625
+ display: flex;
626
+ }
627
+
628
+ #show-details input {
629
+ margin-right: 0.5rem;
630
+ flex: 0 0 12px;
631
+ }
632
+
633
+ #sort-descending-btn {
634
+ transform: rotate(180deg);
635
+ }
636
+
637
+ #sort-direction-selector {
638
+ display: flex;
639
+ flex-direction: column;
640
+ gap: 3px;
641
+ margin-right: 1rem;
642
+ }
643
+
644
+ #sort-selector-container {
645
+ flex: 1;
646
+ }
647
+
648
+ /*
649
+ we move the desktop sort selector offscreen instead of display: none
650
+ because we need to observe the width of it vs its container to determine
651
+ if it's wide enough to display the desktop version and if you displY: none,
652
+ the width becomes 0
653
+ */
654
+ #desktop-sort-selector.hidden {
655
+ position: absolute;
656
+ top: -9999px;
657
+ left: -9999px;
658
+ }
659
+
660
+ #mobile-sort-selector.hidden {
661
+ display: none;
662
+ }
663
+
664
+ #date-sort-selector-backdrop,
665
+ #view-sort-selector-backdrop {
666
+ position: fixed;
667
+ top: 0;
668
+ left: 0;
669
+ width: 100%;
670
+ height: 100%;
671
+ z-index: 1;
672
+ background-color: rgba(255, 255, 255, 0.5);
673
+ }
674
+
675
+ #desktop-sort-selector {
676
+ display: inline-flex;
677
+ }
678
+
679
+ #desktop-sort-selector li {
680
+ display: flex;
681
+ align-items: center;
682
+ }
683
+
684
+ #desktop-sort-selector li a {
685
+ text-decoration: none;
686
+ text-transform: uppercase;
687
+ font-size: 1.4rem;
688
+ color: #333;
689
+ line-height: 2.5;
690
+ }
691
+
692
+ #desktop-sort-selector li a.selected {
693
+ font-weight: bold;
694
+ }
695
+
696
+ #desktop-sort-selector li::after {
697
+ content: '•';
698
+ padding-left: 1rem;
699
+ padding-right: 1rem;
700
+ }
701
+
702
+ #desktop-sort-selector li:first-child::after {
703
+ content: '';
704
+ }
705
+
706
+ #desktop-sort-selector li:last-child::after {
707
+ content: '';
708
+ }
709
+
710
+ #display-style-selector {
711
+ flex: 0;
712
+ }
713
+
714
+ #display-style-selector button {
715
+ background: none;
716
+ color: inherit;
717
+ border: none;
718
+ appearance: none;
719
+ cursor: pointer;
720
+ -webkit-appearance: none;
721
+ opacity: 0.5;
722
+ }
723
+
724
+ #display-style-selector button.active {
725
+ opacity: 1;
726
+ }
727
+
728
+ #display-style-selector button svg {
729
+ width: 24px;
730
+ height: 24px;
731
+ }
732
+ `;
733
+ __decorate([
734
+ property({ type: String })
735
+ ], SortFilterBar.prototype, "displayMode", void 0);
736
+ __decorate([
737
+ property({ type: String })
738
+ ], SortFilterBar.prototype, "sortDirection", void 0);
739
+ __decorate([
740
+ property({ type: String })
741
+ ], SortFilterBar.prototype, "selectedSort", void 0);
742
+ __decorate([
743
+ property({ type: String })
744
+ ], SortFilterBar.prototype, "selectedTitleFilter", void 0);
745
+ __decorate([
746
+ property({ type: String })
747
+ ], SortFilterBar.prototype, "selectedCreatorFilter", void 0);
748
+ __decorate([
749
+ property({ type: Boolean })
750
+ ], SortFilterBar.prototype, "showRelevance", void 0);
751
+ __decorate([
752
+ property({ type: Object })
753
+ ], SortFilterBar.prototype, "resizeObserver", void 0);
754
+ __decorate([
755
+ state()
756
+ ], SortFilterBar.prototype, "alphaSelectorVisible", void 0);
757
+ __decorate([
758
+ state()
759
+ ], SortFilterBar.prototype, "dateSortSelectorVisible", void 0);
760
+ __decorate([
761
+ state()
762
+ ], SortFilterBar.prototype, "viewSortSelectorVisible", void 0);
763
+ __decorate([
764
+ state()
765
+ ], SortFilterBar.prototype, "desktopSelectorBarWidth", void 0);
766
+ __decorate([
767
+ state()
768
+ ], SortFilterBar.prototype, "selectorBarContainerWidth", void 0);
769
+ __decorate([
770
+ state()
771
+ ], SortFilterBar.prototype, "hoveringOverDateSortOptions", void 0);
772
+ __decorate([
773
+ query('#desktop-sort-selector')
774
+ ], SortFilterBar.prototype, "desktopSortSelector", void 0);
775
+ __decorate([
776
+ query('#sort-selector-container')
777
+ ], SortFilterBar.prototype, "sortSelectorContainer", void 0);
778
+ SortFilterBar = __decorate([
779
+ customElement('sort-filter-bar')
780
+ ], SortFilterBar);
781
+ export { SortFilterBar };
782
+ //# sourceMappingURL=sort-filter-bar.js.map