@internetarchive/collection-browser 0.3.1-alpha.2 → 0.3.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 (214) hide show
  1. package/.editorconfig +29 -29
  2. package/.github/workflows/ci.yml +26 -26
  3. package/.github/workflows/gh-pages-main.yml +39 -39
  4. package/.github/workflows/npm-publish.yml +39 -39
  5. package/.github/workflows/pr-preview.yml +38 -38
  6. package/.husky/pre-commit +4 -4
  7. package/LICENSE +661 -661
  8. package/README.md +83 -83
  9. package/dist/index.d.ts +9 -9
  10. package/dist/index.js +9 -9
  11. package/dist/src/app-root.d.ts +43 -43
  12. package/dist/src/app-root.js +233 -233
  13. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  14. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  15. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  16. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  17. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  18. package/dist/src/assets/img/icons/chevron.js +2 -2
  19. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  20. package/dist/src/assets/img/icons/empty-query.js +2 -2
  21. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  22. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  23. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  24. package/dist/src/assets/img/icons/eye.js +2 -2
  25. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  26. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  27. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  28. package/dist/src/assets/img/icons/login-required.js +2 -2
  29. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  30. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  31. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  32. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  33. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  34. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  35. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  36. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  37. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  38. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  39. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  40. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  41. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  42. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  43. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  44. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  45. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  46. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  47. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  48. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  49. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  50. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  51. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  52. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  53. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  54. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  55. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  56. package/dist/src/assets/img/icons/null-result.js +2 -2
  57. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  58. package/dist/src/assets/img/icons/restricted.js +2 -2
  59. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  60. package/dist/src/assets/img/icons/reviews.js +2 -2
  61. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  62. package/dist/src/assets/img/icons/upload.js +2 -2
  63. package/dist/src/assets/img/icons/views.d.ts +1 -1
  64. package/dist/src/assets/img/icons/views.js +2 -2
  65. package/dist/src/circular-activity-indicator.d.ts +5 -5
  66. package/dist/src/circular-activity-indicator.js +17 -17
  67. package/dist/src/collection-browser.d.ts +236 -236
  68. package/dist/src/collection-browser.js +1406 -1402
  69. package/dist/src/collection-browser.js.map +1 -1
  70. package/dist/src/collection-facets/facets-template.d.ts +16 -16
  71. package/dist/src/collection-facets/facets-template.js +132 -130
  72. package/dist/src/collection-facets/facets-template.js.map +1 -1
  73. package/dist/src/collection-facets/more-facets-content.d.ts +74 -74
  74. package/dist/src/collection-facets/more-facets-content.js +350 -339
  75. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  76. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  77. package/dist/src/collection-facets/more-facets-pagination.js +192 -192
  78. package/dist/src/collection-facets.d.ts +71 -71
  79. package/dist/src/collection-facets.js +496 -496
  80. package/dist/src/collection-facets.js.map +1 -1
  81. package/dist/src/empty-placeholder.d.ts +11 -11
  82. package/dist/src/empty-placeholder.js +42 -42
  83. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  84. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  85. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  86. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  87. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  88. package/dist/src/mediatype/mediatype-config.js +85 -85
  89. package/dist/src/models.d.ts +97 -97
  90. package/dist/src/models.js +100 -100
  91. package/dist/src/models.js.map +1 -1
  92. package/dist/src/restoration-state-handler.d.ts +45 -46
  93. package/dist/src/restoration-state-handler.js +220 -231
  94. package/dist/src/restoration-state-handler.js.map +1 -1
  95. package/dist/src/sort-filter-bar/alpha-bar.d.ts +9 -9
  96. package/dist/src/sort-filter-bar/alpha-bar.js +41 -41
  97. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  98. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  99. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  100. package/dist/src/sort-filter-bar/img/list.js +2 -2
  101. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  102. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  103. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  104. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  105. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +107 -107
  106. package/dist/src/sort-filter-bar/sort-filter-bar.js +423 -423
  107. package/dist/src/styles/item-image-styles.d.ts +8 -8
  108. package/dist/src/styles/item-image-styles.js +9 -9
  109. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  110. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  111. package/dist/src/tiles/grid/account-tile.d.ts +8 -8
  112. package/dist/src/tiles/grid/account-tile.js +20 -20
  113. package/dist/src/tiles/grid/collection-tile.d.ts +7 -7
  114. package/dist/src/tiles/grid/collection-tile.js +23 -23
  115. package/dist/src/tiles/grid/item-tile.d.ts +24 -24
  116. package/dist/src/tiles/grid/item-tile.js +87 -87
  117. package/dist/src/tiles/grid/tile-stats.d.ts +10 -10
  118. package/dist/src/tiles/grid/tile-stats.js +35 -35
  119. package/dist/src/tiles/image-block.d.ts +17 -17
  120. package/dist/src/tiles/image-block.js +73 -73
  121. package/dist/src/tiles/item-image.d.ts +31 -31
  122. package/dist/src/tiles/item-image.js +103 -103
  123. package/dist/src/tiles/list/account-label.d.ts +1 -1
  124. package/dist/src/tiles/list/account-label.js +6 -6
  125. package/dist/src/tiles/list/date-label.d.ts +1 -1
  126. package/dist/src/tiles/list/date-label.js +12 -12
  127. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
  128. package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
  129. package/dist/src/tiles/list/tile-list-compact.d.ts +20 -20
  130. package/dist/src/tiles/list/tile-list-compact.js +87 -87
  131. package/dist/src/tiles/list/tile-list.d.ts +50 -50
  132. package/dist/src/tiles/list/tile-list.js +264 -263
  133. package/dist/src/tiles/list/tile-list.js.map +1 -1
  134. package/dist/src/tiles/mediatype-icon.d.ts +9 -9
  135. package/dist/src/tiles/mediatype-icon.js +47 -47
  136. package/dist/src/tiles/overlay/icon-overlay.d.ts +7 -7
  137. package/dist/src/tiles/overlay/icon-overlay.js +31 -31
  138. package/dist/src/tiles/overlay/text-overlay.d.ts +8 -8
  139. package/dist/src/tiles/overlay/text-overlay.js +31 -31
  140. package/dist/src/tiles/text-snippet-block.d.ts +29 -29
  141. package/dist/src/tiles/text-snippet-block.js +81 -81
  142. package/dist/src/tiles/tile-dispatcher.d.ts +36 -36
  143. package/dist/src/tiles/tile-dispatcher.js +128 -128
  144. package/dist/src/utils/analytics-events.d.ts +18 -18
  145. package/dist/src/utils/analytics-events.js +20 -20
  146. package/dist/src/utils/format-count.d.ts +7 -7
  147. package/dist/src/utils/format-count.js +76 -75
  148. package/dist/src/utils/format-count.js.map +1 -1
  149. package/dist/src/utils/format-date.d.ts +2 -2
  150. package/dist/src/utils/format-date.js +23 -23
  151. package/dist/test/collection-browser.test.d.ts +1 -1
  152. package/dist/test/collection-browser.test.js +344 -344
  153. package/dist/test/collection-browser.test.js.map +1 -1
  154. package/dist/test/collection-facets/facets-template.test.d.ts +1 -1
  155. package/dist/test/collection-facets/facets-template.test.js +62 -62
  156. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  157. package/dist/test/collection-facets/more-facets-content.test.js +91 -91
  158. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  159. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  160. package/dist/test/collection-facets.test.d.ts +2 -2
  161. package/dist/test/collection-facets.test.js +385 -182
  162. package/dist/test/collection-facets.test.js.map +1 -1
  163. package/dist/test/empty-placeholder.test.d.ts +1 -1
  164. package/dist/test/empty-placeholder.test.js +33 -33
  165. package/dist/test/icon-overlay.test.d.ts +1 -1
  166. package/dist/test/icon-overlay.test.js +24 -24
  167. package/dist/test/item-image.test.d.ts +1 -1
  168. package/dist/test/item-image.test.js +56 -56
  169. package/dist/test/mediatype-config.test.d.ts +1 -1
  170. package/dist/test/mediatype-config.test.js +16 -16
  171. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  172. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  173. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -7
  174. package/dist/test/mocks/mock-collection-name-cache.js +13 -13
  175. package/dist/test/mocks/mock-search-responses.d.ts +5 -5
  176. package/dist/test/mocks/mock-search-responses.js +103 -103
  177. package/dist/test/mocks/mock-search-service.d.ts +13 -13
  178. package/dist/test/mocks/mock-search-service.js +25 -25
  179. package/dist/test/restoration-state-handler.test.d.ts +1 -1
  180. package/dist/test/restoration-state-handler.test.js +117 -117
  181. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  182. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +113 -113
  183. package/dist/test/text-overlay.test.d.ts +1 -1
  184. package/dist/test/text-overlay.test.js +41 -41
  185. package/dist/test/text-snippet-block.test.d.ts +1 -1
  186. package/dist/test/text-snippet-block.test.js +57 -57
  187. package/dist/test/tile-stats.test.d.ts +1 -1
  188. package/dist/test/tile-stats.test.js +33 -33
  189. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  190. package/dist/test/tiles/grid/item-tile.test.js +107 -107
  191. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  192. package/dist/test/tiles/list/tile-list.test.js +36 -36
  193. package/dist/test/utils/format-count.test.d.ts +1 -1
  194. package/dist/test/utils/format-count.test.js +23 -23
  195. package/dist/test/utils/format-date.test.d.ts +1 -1
  196. package/dist/test/utils/format-date.test.js +17 -17
  197. package/index.html +24 -24
  198. package/local.archive.org.cert +86 -86
  199. package/local.archive.org.key +27 -27
  200. package/package.json +115 -115
  201. package/renovate.json +6 -6
  202. package/src/collection-browser.ts +1530 -1526
  203. package/src/collection-facets/facets-template.ts +7 -5
  204. package/src/collection-facets/more-facets-content.ts +21 -10
  205. package/src/collection-facets.ts +569 -569
  206. package/src/models.ts +216 -216
  207. package/src/restoration-state-handler.ts +302 -314
  208. package/src/tiles/list/tile-list.ts +1 -0
  209. package/src/utils/format-count.ts +1 -0
  210. package/test/collection-browser.test.ts +490 -490
  211. package/test/collection-facets.test.ts +264 -1
  212. package/tsconfig.json +21 -21
  213. package/web-dev-server.config.mjs +30 -30
  214. package/web-test-runner.config.mjs +41 -41
@@ -1,68 +1,68 @@
1
- import { __decorate } from "tslib";
2
- /* eslint-disable no-console */
3
- import { AnalyticsManager, } from '@internetarchive/analytics-manager';
4
- import { SearchService, SearchType, StringField, } from '@internetarchive/search-service';
5
- import { LocalCache } from '@internetarchive/local-cache';
6
- import { html, css, LitElement } from 'lit';
7
- import { customElement, property, query, state } from 'lit/decorators.js';
8
- import { SharedResizeObserver } from '@internetarchive/shared-resize-observer';
9
- import { CollectionNameCache } from '@internetarchive/collection-name-cache';
10
- import '../src/collection-browser';
11
- let AppRoot = class AppRoot extends LitElement {
12
- constructor() {
13
- super(...arguments);
14
- this.searchService = SearchService.default;
15
- this.resizeObserver = new SharedResizeObserver();
16
- this.localCache = new LocalCache();
17
- this.collectionNameCache = new CollectionNameCache({
18
- searchService: this.searchService,
19
- localCache: this.localCache,
20
- });
21
- this.cellWidth = 18;
22
- this.cellHeight = 29;
23
- this.rowGap = 1.7;
24
- this.colGap = 1.7;
25
- this.loggedIn = false;
26
- this.searchType = SearchType.METADATA;
27
- this.analyticsManager = new AnalyticsManager();
28
- this.analyticsHandler = {
29
- sendPing: this.sendAnalytics.bind(this),
30
- sendEvent: this.sendAnalytics.bind(this),
31
- sendEventNoSampling: this.sendAnalytics.bind(this),
32
- };
33
- }
34
- sendAnalytics(ae) {
35
- var _a;
36
- console.log('Analytics Received ----', ae);
37
- this.latestAction = ae;
38
- (_a = this.analyticsManager) === null || _a === void 0 ? void 0 : _a.sendEventNoSampling(ae);
39
- }
40
- searchPressed(e) {
41
- var _a, _b;
42
- e.preventDefault();
43
- this.searchQuery = this.baseQueryField.value;
44
- if (((_a = this.currentPage) !== null && _a !== void 0 ? _a : 1) > 1) {
45
- this.collectionBrowser.goToPage((_b = this.currentPage) !== null && _b !== void 0 ? _b : 1);
46
- }
47
- }
48
- changePagePressed(e) {
49
- e.preventDefault();
50
- this.currentPage = this.pageNumberInput.valueAsNumber;
51
- this.collectionBrowser.goToPage(this.currentPage);
52
- }
53
- updated(changed) {
54
- if (changed.has('currentPage') && this.currentPage) {
55
- this.pageNumberInput.value = this.currentPage.toString();
56
- }
57
- if (changed.has('searchQuery')) {
58
- this.queryUpdated();
59
- }
60
- }
61
- queryUpdated() {
62
- this.collectionBrowser.baseQuery = this.searchQuery;
63
- }
64
- render() {
65
- var _a;
1
+ import { __decorate } from "tslib";
2
+ /* eslint-disable no-console */
3
+ import { AnalyticsManager, } from '@internetarchive/analytics-manager';
4
+ import { SearchService, SearchType, StringField, } from '@internetarchive/search-service';
5
+ import { LocalCache } from '@internetarchive/local-cache';
6
+ import { html, css, LitElement } from 'lit';
7
+ import { customElement, property, query, state } from 'lit/decorators.js';
8
+ import { SharedResizeObserver } from '@internetarchive/shared-resize-observer';
9
+ import { CollectionNameCache } from '@internetarchive/collection-name-cache';
10
+ import '../src/collection-browser';
11
+ let AppRoot = class AppRoot extends LitElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.searchService = SearchService.default;
15
+ this.resizeObserver = new SharedResizeObserver();
16
+ this.localCache = new LocalCache();
17
+ this.collectionNameCache = new CollectionNameCache({
18
+ searchService: this.searchService,
19
+ localCache: this.localCache,
20
+ });
21
+ this.cellWidth = 18;
22
+ this.cellHeight = 29;
23
+ this.rowGap = 1.7;
24
+ this.colGap = 1.7;
25
+ this.loggedIn = false;
26
+ this.searchType = SearchType.METADATA;
27
+ this.analyticsManager = new AnalyticsManager();
28
+ this.analyticsHandler = {
29
+ sendPing: this.sendAnalytics.bind(this),
30
+ sendEvent: this.sendAnalytics.bind(this),
31
+ sendEventNoSampling: this.sendAnalytics.bind(this),
32
+ };
33
+ }
34
+ sendAnalytics(ae) {
35
+ var _a;
36
+ console.log('Analytics Received ----', ae);
37
+ this.latestAction = ae;
38
+ (_a = this.analyticsManager) === null || _a === void 0 ? void 0 : _a.sendEventNoSampling(ae);
39
+ }
40
+ searchPressed(e) {
41
+ var _a, _b;
42
+ e.preventDefault();
43
+ this.searchQuery = this.baseQueryField.value;
44
+ if (((_a = this.currentPage) !== null && _a !== void 0 ? _a : 1) > 1) {
45
+ this.collectionBrowser.goToPage((_b = this.currentPage) !== null && _b !== void 0 ? _b : 1);
46
+ }
47
+ }
48
+ changePagePressed(e) {
49
+ e.preventDefault();
50
+ this.currentPage = this.pageNumberInput.valueAsNumber;
51
+ this.collectionBrowser.goToPage(this.currentPage);
52
+ }
53
+ updated(changed) {
54
+ if (changed.has('currentPage') && this.currentPage) {
55
+ this.pageNumberInput.value = this.currentPage.toString();
56
+ }
57
+ if (changed.has('searchQuery')) {
58
+ this.queryUpdated();
59
+ }
60
+ }
61
+ queryUpdated() {
62
+ this.collectionBrowser.baseQuery = this.searchQuery;
63
+ }
64
+ render() {
65
+ var _a;
66
66
  return html `
67
67
  <div id="dev-tools">
68
68
  <div id="search-and-page-inputs">
@@ -104,21 +104,21 @@ let AppRoot = class AppRoot extends LitElement {
104
104
 
105
105
  <div id="toggle-controls">
106
106
  <button
107
- @click=${() => {
108
- var _a, _b;
109
- const details = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('cell-size-control');
110
- details === null || details === void 0 ? void 0 : details.classList.toggle('hidden');
111
- const rowGapControls = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.getElementById('cell-gap-control');
112
- rowGapControls === null || rowGapControls === void 0 ? void 0 : rowGapControls.classList.toggle('hidden');
107
+ @click=${() => {
108
+ var _a, _b;
109
+ const details = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('cell-size-control');
110
+ details === null || details === void 0 ? void 0 : details.classList.toggle('hidden');
111
+ const rowGapControls = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.getElementById('cell-gap-control');
112
+ rowGapControls === null || rowGapControls === void 0 ? void 0 : rowGapControls.classList.toggle('hidden');
113
113
  }}
114
114
  >
115
115
  Toggle Cell Controls
116
116
  </button>
117
117
  <button
118
- @click=${() => {
119
- var _a;
120
- const details = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('latest-event-details');
121
- details === null || details === void 0 ? void 0 : details.classList.toggle('hidden');
118
+ @click=${() => {
119
+ var _a;
120
+ const details = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById('latest-event-details');
121
+ details === null || details === void 0 ? void 0 : details.classList.toggle('hidden');
122
122
  }}
123
123
  >
124
124
  Last Event Captured
@@ -244,120 +244,120 @@ let AppRoot = class AppRoot extends LitElement {
244
244
  </collection-browser>
245
245
  </div>
246
246
  <modal-manager></modal-manager>
247
- `;
248
- }
249
- baseQueryChanged(e) {
250
- this.searchQuery = e.detail.baseQuery;
251
- }
252
- searchTypeChanged(e) {
253
- const target = e.target;
254
- this.searchType =
255
- target.value === 'fulltext' ? SearchType.FULLTEXT : SearchType.METADATA;
256
- // Re-perform the current search with the new search target
257
- this.reperformCurrentSearch();
258
- }
259
- loginChanged(e) {
260
- const target = e.target;
261
- if (target.checked) {
262
- this.loggedIn = true;
263
- }
264
- else {
265
- this.loggedIn = false;
266
- }
267
- }
268
- outlineChanged(e) {
269
- const target = e.target;
270
- if (target.checked) {
271
- this.collectionBrowser.style.setProperty('--infiniteScrollerCellOutline', '1px solid #33D1FF');
272
- }
273
- else {
274
- this.collectionBrowser.style.removeProperty('--infiniteScrollerCellOutline');
275
- }
276
- }
277
- toggleFacetGroupOutline(e) {
278
- const target = e.target;
279
- if (target.checked) {
280
- this.collectionBrowser.classList.add('showFacetGroupOutlines');
281
- this.modalManager.classList.add('showFacetGroupOutlines');
282
- }
283
- else {
284
- this.collectionBrowser.classList.remove('showFacetGroupOutlines');
285
- this.modalManager.classList.remove('showFacetGroupOutlines');
286
- }
287
- }
288
- async snippetsChanged(e) {
289
- const target = e.target;
290
- if (target.checked) {
291
- // Decorate the default search service with a wrapper that adds
292
- // dummy snippets to any successful searches
293
- this.searchService = {
294
- async search(params, searchType) {
295
- var _a;
296
- const searchResponse = await SearchService.default.search(params, searchType);
297
- (_a = searchResponse.success) === null || _a === void 0 ? void 0 : _a.response.results.forEach(result => {
298
- Object.defineProperty(result, 'highlight', {
299
- value: new StringField([
300
- 'this is a text {{{snippet}}} block with potentially',
301
- 'multiple {{{snippets}}} and such',
302
- 'but the {{{snippet}}} block may be quite long perhaps',
303
- 'depending on how many {{{snippet}}} matches there are',
304
- 'there may be multiple lines of {{{snippets}}} to show',
305
- 'but each {{{snippet}}} should be relatively short',
306
- 'and {{{snippets}}} are each a {{{snippet}}} of text',
307
- 'but every {{{snippet}}} might have multiple matches',
308
- 'the {{{snippets}}} should be separated and surrounded by ellipses',
309
- ]),
310
- });
311
- });
312
- return searchResponse;
313
- },
314
- };
315
- }
316
- else {
317
- // Restore the default seach service
318
- this.searchService = SearchService.default;
319
- }
320
- // Re-perform the current search to show/hide the snippets immediately
321
- this.reperformCurrentSearch();
322
- }
323
- async reperformCurrentSearch() {
324
- const oldQuery = this.searchQuery;
325
- this.searchQuery = ''; // Should just reset to the placeholder
326
- await this.updateComplete;
327
- // For unclear reasons, Safari refuses to re-apply the old query until the next tick, hence:
328
- await new Promise(res => {
329
- setTimeout(res, 0);
330
- });
331
- this.searchQuery = oldQuery; // Re-apply the original query
332
- }
333
- rowGapChanged(e) {
334
- const input = e.target;
335
- this.rowGap = parseFloat(input.value);
336
- this.collectionBrowser.style.setProperty('--collectionBrowserRowGap', `${input.value}rem`);
337
- }
338
- colGapChanged(e) {
339
- const input = e.target;
340
- this.colGap = parseFloat(input.value);
341
- this.collectionBrowser.style.setProperty('--collectionBrowserColGap', `${input.value}rem`);
342
- }
343
- widthChanged(e) {
344
- const input = e.target;
345
- this.cellWidth = parseFloat(input.value);
346
- this.collectionBrowser.style.setProperty('--collectionBrowserCellMinWidth', `${input.value}rem`);
347
- }
348
- heightChanged(e) {
349
- const input = e.target;
350
- this.cellHeight = parseFloat(input.value);
351
- this.collectionBrowser.style.setProperty('--collectionBrowserCellMinHeight', `${input.value}rem`);
352
- this.collectionBrowser.style.setProperty('--collectionBrowserCellMaxHeight', `${input.value}rem`);
353
- }
354
- visiblePageChanged(e) {
355
- const { pageNumber } = e.detail;
356
- if (pageNumber === this.currentPage)
357
- return;
358
- this.currentPage = pageNumber;
359
- }
360
- };
247
+ `;
248
+ }
249
+ baseQueryChanged(e) {
250
+ this.searchQuery = e.detail.baseQuery;
251
+ }
252
+ searchTypeChanged(e) {
253
+ const target = e.target;
254
+ this.searchType =
255
+ target.value === 'fulltext' ? SearchType.FULLTEXT : SearchType.METADATA;
256
+ // Re-perform the current search with the new search target
257
+ this.reperformCurrentSearch();
258
+ }
259
+ loginChanged(e) {
260
+ const target = e.target;
261
+ if (target.checked) {
262
+ this.loggedIn = true;
263
+ }
264
+ else {
265
+ this.loggedIn = false;
266
+ }
267
+ }
268
+ outlineChanged(e) {
269
+ const target = e.target;
270
+ if (target.checked) {
271
+ this.collectionBrowser.style.setProperty('--infiniteScrollerCellOutline', '1px solid #33D1FF');
272
+ }
273
+ else {
274
+ this.collectionBrowser.style.removeProperty('--infiniteScrollerCellOutline');
275
+ }
276
+ }
277
+ toggleFacetGroupOutline(e) {
278
+ const target = e.target;
279
+ if (target.checked) {
280
+ this.collectionBrowser.classList.add('showFacetGroupOutlines');
281
+ this.modalManager.classList.add('showFacetGroupOutlines');
282
+ }
283
+ else {
284
+ this.collectionBrowser.classList.remove('showFacetGroupOutlines');
285
+ this.modalManager.classList.remove('showFacetGroupOutlines');
286
+ }
287
+ }
288
+ async snippetsChanged(e) {
289
+ const target = e.target;
290
+ if (target.checked) {
291
+ // Decorate the default search service with a wrapper that adds
292
+ // dummy snippets to any successful searches
293
+ this.searchService = {
294
+ async search(params, searchType) {
295
+ var _a;
296
+ const searchResponse = await SearchService.default.search(params, searchType);
297
+ (_a = searchResponse.success) === null || _a === void 0 ? void 0 : _a.response.results.forEach(result => {
298
+ Object.defineProperty(result, 'highlight', {
299
+ value: new StringField([
300
+ 'this is a text {{{snippet}}} block with potentially',
301
+ 'multiple {{{snippets}}} and such',
302
+ 'but the {{{snippet}}} block may be quite long perhaps',
303
+ 'depending on how many {{{snippet}}} matches there are',
304
+ 'there may be multiple lines of {{{snippets}}} to show',
305
+ 'but each {{{snippet}}} should be relatively short',
306
+ 'and {{{snippets}}} are each a {{{snippet}}} of text',
307
+ 'but every {{{snippet}}} might have multiple matches',
308
+ 'the {{{snippets}}} should be separated and surrounded by ellipses',
309
+ ]),
310
+ });
311
+ });
312
+ return searchResponse;
313
+ },
314
+ };
315
+ }
316
+ else {
317
+ // Restore the default seach service
318
+ this.searchService = SearchService.default;
319
+ }
320
+ // Re-perform the current search to show/hide the snippets immediately
321
+ this.reperformCurrentSearch();
322
+ }
323
+ async reperformCurrentSearch() {
324
+ const oldQuery = this.searchQuery;
325
+ this.searchQuery = ''; // Should just reset to the placeholder
326
+ await this.updateComplete;
327
+ // For unclear reasons, Safari refuses to re-apply the old query until the next tick, hence:
328
+ await new Promise(res => {
329
+ setTimeout(res, 0);
330
+ });
331
+ this.searchQuery = oldQuery; // Re-apply the original query
332
+ }
333
+ rowGapChanged(e) {
334
+ const input = e.target;
335
+ this.rowGap = parseFloat(input.value);
336
+ this.collectionBrowser.style.setProperty('--collectionBrowserRowGap', `${input.value}rem`);
337
+ }
338
+ colGapChanged(e) {
339
+ const input = e.target;
340
+ this.colGap = parseFloat(input.value);
341
+ this.collectionBrowser.style.setProperty('--collectionBrowserColGap', `${input.value}rem`);
342
+ }
343
+ widthChanged(e) {
344
+ const input = e.target;
345
+ this.cellWidth = parseFloat(input.value);
346
+ this.collectionBrowser.style.setProperty('--collectionBrowserCellMinWidth', `${input.value}rem`);
347
+ }
348
+ heightChanged(e) {
349
+ const input = e.target;
350
+ this.cellHeight = parseFloat(input.value);
351
+ this.collectionBrowser.style.setProperty('--collectionBrowserCellMinHeight', `${input.value}rem`);
352
+ this.collectionBrowser.style.setProperty('--collectionBrowserCellMaxHeight', `${input.value}rem`);
353
+ }
354
+ visiblePageChanged(e) {
355
+ const { pageNumber } = e.detail;
356
+ if (pageNumber === this.currentPage)
357
+ return;
358
+ this.currentPage = pageNumber;
359
+ }
360
+ };
361
361
  AppRoot.styles = css `
362
362
  :host {
363
363
  display: block;
@@ -456,48 +456,48 @@ AppRoot.styles = css `
456
456
  background-color: aliceblue;
457
457
  font-size: 1.6rem;
458
458
  }
459
- `;
460
- __decorate([
461
- state()
462
- ], AppRoot.prototype, "currentPage", void 0);
463
- __decorate([
464
- state()
465
- ], AppRoot.prototype, "searchQuery", void 0);
466
- __decorate([
467
- state()
468
- ], AppRoot.prototype, "cellWidth", void 0);
469
- __decorate([
470
- state()
471
- ], AppRoot.prototype, "cellHeight", void 0);
472
- __decorate([
473
- state()
474
- ], AppRoot.prototype, "rowGap", void 0);
475
- __decorate([
476
- state()
477
- ], AppRoot.prototype, "colGap", void 0);
478
- __decorate([
479
- state()
480
- ], AppRoot.prototype, "loggedIn", void 0);
481
- __decorate([
482
- state()
483
- ], AppRoot.prototype, "searchType", void 0);
484
- __decorate([
485
- property({ type: Object, reflect: false })
486
- ], AppRoot.prototype, "latestAction", void 0);
487
- __decorate([
488
- query('#base-query-field')
489
- ], AppRoot.prototype, "baseQueryField", void 0);
490
- __decorate([
491
- query('#page-number-input')
492
- ], AppRoot.prototype, "pageNumberInput", void 0);
493
- __decorate([
494
- query('collection-browser')
495
- ], AppRoot.prototype, "collectionBrowser", void 0);
496
- __decorate([
497
- query('modal-manager')
498
- ], AppRoot.prototype, "modalManager", void 0);
499
- AppRoot = __decorate([
500
- customElement('app-root')
501
- ], AppRoot);
502
- export { AppRoot };
459
+ `;
460
+ __decorate([
461
+ state()
462
+ ], AppRoot.prototype, "currentPage", void 0);
463
+ __decorate([
464
+ state()
465
+ ], AppRoot.prototype, "searchQuery", void 0);
466
+ __decorate([
467
+ state()
468
+ ], AppRoot.prototype, "cellWidth", void 0);
469
+ __decorate([
470
+ state()
471
+ ], AppRoot.prototype, "cellHeight", void 0);
472
+ __decorate([
473
+ state()
474
+ ], AppRoot.prototype, "rowGap", void 0);
475
+ __decorate([
476
+ state()
477
+ ], AppRoot.prototype, "colGap", void 0);
478
+ __decorate([
479
+ state()
480
+ ], AppRoot.prototype, "loggedIn", void 0);
481
+ __decorate([
482
+ state()
483
+ ], AppRoot.prototype, "searchType", void 0);
484
+ __decorate([
485
+ property({ type: Object, reflect: false })
486
+ ], AppRoot.prototype, "latestAction", void 0);
487
+ __decorate([
488
+ query('#base-query-field')
489
+ ], AppRoot.prototype, "baseQueryField", void 0);
490
+ __decorate([
491
+ query('#page-number-input')
492
+ ], AppRoot.prototype, "pageNumberInput", void 0);
493
+ __decorate([
494
+ query('collection-browser')
495
+ ], AppRoot.prototype, "collectionBrowser", void 0);
496
+ __decorate([
497
+ query('modal-manager')
498
+ ], AppRoot.prototype, "modalManager", void 0);
499
+ AppRoot = __decorate([
500
+ customElement('app-root')
501
+ ], AppRoot);
502
+ export { AppRoot };
503
503
  //# sourceMappingURL=app-root.js.map
@@ -1,2 +1,2 @@
1
- declare const _default: import("lit-html").TemplateResult<2>;
2
- export default _default;
1
+ declare const _default: import("lit-html").TemplateResult<2>;
2
+ export default _default;
@@ -1,4 +1,4 @@
1
- import { svg } from 'lit';
1
+ import { svg } from 'lit';
2
2
  export default svg `
3
3
  <svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
4
4
  <path
@@ -6,5 +6,5 @@ export default svg `
6
6
  />
7
7
  <title>Go left icon</title>
8
8
  </svg>
9
- `;
9
+ `;
10
10
  //# sourceMappingURL=arrow-left.js.map
@@ -1,2 +1,2 @@
1
- declare const _default: import("lit-html").TemplateResult<2>;
2
- export default _default;
1
+ declare const _default: import("lit-html").TemplateResult<2>;
2
+ export default _default;
@@ -1,4 +1,4 @@
1
- import { svg } from 'lit';
1
+ import { svg } from 'lit';
2
2
  export default svg `
3
3
  <svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
4
4
  <path
@@ -6,5 +6,5 @@ export default svg `
6
6
  />
7
7
  <title>Go right icon</title>
8
8
  </svg>
9
- `;
9
+ `;
10
10
  //# sourceMappingURL=arrow-right.js.map
@@ -1,2 +1,2 @@
1
- declare const _default: import("lit-html").TemplateResult<2>;
2
- export default _default;
1
+ declare const _default: import("lit-html").TemplateResult<2>;
2
+ export default _default;
@@ -1,4 +1,4 @@
1
- import { svg } from 'lit';
1
+ import { svg } from 'lit';
2
2
  export default svg `<svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><path d="m79.8883285 50.0035012.1116715-.1085359-43.1159942-46.61088155c-2.401537-2.18938917-4.6902018-3.28408375-6.8659943-3.28408375s-4.1642651.63837733-5.9654178 1.91513199c-1.8011528 1.27675467-3.1520173 2.97248092-4.0525937 5.08717877l39.4020173 42.99768924-39.4020173 42.9976892c.9005764 2.1146979 2.2514409 3.8104241 4.0525937 5.0871788 1.8011527 1.2767547 3.7896253 1.915132 5.9654178 1.915132 2.1013449 0 4.3900096-1.0573489 6.8659943-3.1720468l43.1159942-46.7194174z"/></svg>
3
- `;
3
+ `;
4
4
  //# sourceMappingURL=chevron.js.map
@@ -1,2 +1,2 @@
1
- declare const _default: import("lit-html").TemplateResult<2>;
2
- export default _default;
1
+ declare const _default: import("lit-html").TemplateResult<2>;
2
+ export default _default;