@internetarchive/collection-browser 0.2.22 → 0.3.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (220) 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 +42 -39
  12. package/dist/src/app-root.js +236 -203
  13. package/dist/src/app-root.js.map +1 -1
  14. package/dist/src/assets/img/icons/arrow-left.d.ts +2 -2
  15. package/dist/src/assets/img/icons/arrow-left.js +2 -2
  16. package/dist/src/assets/img/icons/arrow-right.d.ts +2 -2
  17. package/dist/src/assets/img/icons/arrow-right.js +2 -2
  18. package/dist/src/assets/img/icons/chevron.d.ts +2 -2
  19. package/dist/src/assets/img/icons/chevron.js +2 -2
  20. package/dist/src/assets/img/icons/empty-query.d.ts +2 -2
  21. package/dist/src/assets/img/icons/empty-query.js +2 -2
  22. package/dist/src/assets/img/icons/eye-closed.d.ts +2 -2
  23. package/dist/src/assets/img/icons/eye-closed.js +2 -2
  24. package/dist/src/assets/img/icons/eye.d.ts +2 -2
  25. package/dist/src/assets/img/icons/eye.js +2 -2
  26. package/dist/src/assets/img/icons/favorite-filled.d.ts +1 -1
  27. package/dist/src/assets/img/icons/favorite-filled.js +2 -2
  28. package/dist/src/assets/img/icons/login-required.d.ts +1 -1
  29. package/dist/src/assets/img/icons/login-required.js +2 -2
  30. package/dist/src/assets/img/icons/mediatype/account.d.ts +1 -1
  31. package/dist/src/assets/img/icons/mediatype/account.js +2 -2
  32. package/dist/src/assets/img/icons/mediatype/audio.d.ts +1 -1
  33. package/dist/src/assets/img/icons/mediatype/audio.js +2 -2
  34. package/dist/src/assets/img/icons/mediatype/collection.d.ts +1 -1
  35. package/dist/src/assets/img/icons/mediatype/collection.js +2 -2
  36. package/dist/src/assets/img/icons/mediatype/data.d.ts +1 -1
  37. package/dist/src/assets/img/icons/mediatype/data.js +2 -2
  38. package/dist/src/assets/img/icons/mediatype/etree.d.ts +1 -1
  39. package/dist/src/assets/img/icons/mediatype/etree.js +2 -2
  40. package/dist/src/assets/img/icons/mediatype/film.d.ts +1 -1
  41. package/dist/src/assets/img/icons/mediatype/film.js +2 -2
  42. package/dist/src/assets/img/icons/mediatype/images.d.ts +1 -1
  43. package/dist/src/assets/img/icons/mediatype/images.js +2 -2
  44. package/dist/src/assets/img/icons/mediatype/radio.d.ts +1 -1
  45. package/dist/src/assets/img/icons/mediatype/radio.js +2 -2
  46. package/dist/src/assets/img/icons/mediatype/software.d.ts +1 -1
  47. package/dist/src/assets/img/icons/mediatype/software.js +2 -2
  48. package/dist/src/assets/img/icons/mediatype/texts.d.ts +1 -1
  49. package/dist/src/assets/img/icons/mediatype/texts.js +2 -2
  50. package/dist/src/assets/img/icons/mediatype/tv.d.ts +1 -1
  51. package/dist/src/assets/img/icons/mediatype/tv.js +2 -2
  52. package/dist/src/assets/img/icons/mediatype/video.d.ts +1 -1
  53. package/dist/src/assets/img/icons/mediatype/video.js +2 -2
  54. package/dist/src/assets/img/icons/mediatype/web.d.ts +1 -1
  55. package/dist/src/assets/img/icons/mediatype/web.js +2 -2
  56. package/dist/src/assets/img/icons/null-result.d.ts +2 -2
  57. package/dist/src/assets/img/icons/null-result.js +2 -2
  58. package/dist/src/assets/img/icons/restricted.d.ts +1 -1
  59. package/dist/src/assets/img/icons/restricted.js +2 -2
  60. package/dist/src/assets/img/icons/reviews.d.ts +1 -1
  61. package/dist/src/assets/img/icons/reviews.js +2 -2
  62. package/dist/src/assets/img/icons/upload.d.ts +1 -1
  63. package/dist/src/assets/img/icons/upload.js +2 -2
  64. package/dist/src/assets/img/icons/views.d.ts +1 -1
  65. package/dist/src/assets/img/icons/views.js +2 -2
  66. package/dist/src/circular-activity-indicator.d.ts +5 -5
  67. package/dist/src/circular-activity-indicator.js +17 -17
  68. package/dist/src/collection-browser.d.ts +235 -233
  69. package/dist/src/collection-browser.js +1032 -1046
  70. package/dist/src/collection-browser.js.map +1 -1
  71. package/dist/src/collection-facets/facets-template.d.ts +16 -16
  72. package/dist/src/collection-facets/facets-template.js +125 -125
  73. package/dist/src/collection-facets/facets-util.d.ts +10 -10
  74. package/dist/src/collection-facets/facets-util.js +19 -19
  75. package/dist/src/collection-facets/more-facets-content.d.ts +84 -83
  76. package/dist/src/collection-facets/more-facets-content.js +353 -351
  77. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  78. package/dist/src/collection-facets/more-facets-pagination.d.ts +36 -36
  79. package/dist/src/collection-facets/more-facets-pagination.js +192 -192
  80. package/dist/src/collection-facets.d.ts +71 -79
  81. package/dist/src/collection-facets.js +325 -338
  82. package/dist/src/collection-facets.js.map +1 -1
  83. package/dist/src/empty-placeholder.d.ts +11 -11
  84. package/dist/src/empty-placeholder.js +42 -42
  85. package/dist/src/language-code-handler/language-code-handler.d.ts +37 -37
  86. package/dist/src/language-code-handler/language-code-handler.js +26 -26
  87. package/dist/src/language-code-handler/language-code-mapping.d.ts +1 -1
  88. package/dist/src/language-code-handler/language-code-mapping.js +562 -562
  89. package/dist/src/mediatype/mediatype-config.d.ts +3 -3
  90. package/dist/src/mediatype/mediatype-config.js +85 -85
  91. package/dist/src/models.d.ts +90 -89
  92. package/dist/src/models.js +85 -85
  93. package/dist/src/models.js.map +1 -1
  94. package/dist/src/restoration-state-handler.d.ts +38 -38
  95. package/dist/src/restoration-state-handler.js +202 -202
  96. package/dist/src/sort-filter-bar/alpha-bar.d.ts +9 -9
  97. package/dist/src/sort-filter-bar/alpha-bar.js +41 -41
  98. package/dist/src/sort-filter-bar/img/compact.d.ts +1 -1
  99. package/dist/src/sort-filter-bar/img/compact.js +2 -2
  100. package/dist/src/sort-filter-bar/img/list.d.ts +1 -1
  101. package/dist/src/sort-filter-bar/img/list.js +2 -2
  102. package/dist/src/sort-filter-bar/img/sort-triangle.d.ts +1 -1
  103. package/dist/src/sort-filter-bar/img/sort-triangle.js +2 -2
  104. package/dist/src/sort-filter-bar/img/tile.d.ts +1 -1
  105. package/dist/src/sort-filter-bar/img/tile.js +2 -2
  106. package/dist/src/sort-filter-bar/sort-filter-bar.d.ts +107 -107
  107. package/dist/src/sort-filter-bar/sort-filter-bar.js +423 -423
  108. package/dist/src/styles/item-image-styles.d.ts +8 -8
  109. package/dist/src/styles/item-image-styles.js +9 -9
  110. package/dist/src/tiles/collection-browser-loading-tile.d.ts +5 -5
  111. package/dist/src/tiles/collection-browser-loading-tile.js +15 -15
  112. package/dist/src/tiles/grid/account-tile.d.ts +8 -8
  113. package/dist/src/tiles/grid/account-tile.js +20 -20
  114. package/dist/src/tiles/grid/collection-tile.d.ts +7 -7
  115. package/dist/src/tiles/grid/collection-tile.js +23 -23
  116. package/dist/src/tiles/grid/item-tile.d.ts +24 -24
  117. package/dist/src/tiles/grid/item-tile.js +87 -87
  118. package/dist/src/tiles/grid/tile-stats.d.ts +10 -10
  119. package/dist/src/tiles/grid/tile-stats.js +35 -35
  120. package/dist/src/tiles/image-block.d.ts +17 -17
  121. package/dist/src/tiles/image-block.js +73 -73
  122. package/dist/src/tiles/item-image.d.ts +31 -31
  123. package/dist/src/tiles/item-image.js +103 -103
  124. package/dist/src/tiles/list/account-label.d.ts +1 -1
  125. package/dist/src/tiles/list/account-label.js +6 -6
  126. package/dist/src/tiles/list/date-label.d.ts +1 -1
  127. package/dist/src/tiles/list/date-label.js +12 -12
  128. package/dist/src/tiles/list/tile-list-compact-header.d.ts +12 -12
  129. package/dist/src/tiles/list/tile-list-compact-header.js +41 -41
  130. package/dist/src/tiles/list/tile-list-compact.d.ts +20 -20
  131. package/dist/src/tiles/list/tile-list-compact.js +87 -87
  132. package/dist/src/tiles/list/tile-list.d.ts +50 -50
  133. package/dist/src/tiles/list/tile-list.js +263 -263
  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/text-snippet-block.js.map +1 -1
  143. package/dist/src/tiles/tile-dispatcher.d.ts +36 -36
  144. package/dist/src/tiles/tile-dispatcher.js +128 -128
  145. package/dist/src/utils/analytics-events.d.ts +18 -18
  146. package/dist/src/utils/analytics-events.js +20 -20
  147. package/dist/src/utils/format-count.d.ts +7 -7
  148. package/dist/src/utils/format-count.js +75 -75
  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 +328 -200
  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/facets-util.test.d.ts +1 -1
  157. package/dist/test/collection-facets/facets-util.test.js +12 -12
  158. package/dist/test/collection-facets/more-facets-content.test.d.ts +1 -1
  159. package/dist/test/collection-facets/more-facets-content.test.js +92 -91
  160. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
  161. package/dist/test/collection-facets/more-facets-pagination.test.d.ts +1 -1
  162. package/dist/test/collection-facets/more-facets-pagination.test.js +117 -117
  163. package/dist/test/collection-facets.test.d.ts +2 -2
  164. package/dist/test/collection-facets.test.js +182 -181
  165. package/dist/test/collection-facets.test.js.map +1 -1
  166. package/dist/test/empty-placeholder.test.d.ts +1 -1
  167. package/dist/test/empty-placeholder.test.js +33 -33
  168. package/dist/test/icon-overlay.test.d.ts +1 -1
  169. package/dist/test/icon-overlay.test.js +24 -24
  170. package/dist/test/item-image.test.d.ts +1 -1
  171. package/dist/test/item-image.test.js +56 -56
  172. package/dist/test/mediatype-config.test.d.ts +1 -1
  173. package/dist/test/mediatype-config.test.js +16 -16
  174. package/dist/test/mocks/mock-analytics-handler.d.ts +10 -10
  175. package/dist/test/mocks/mock-analytics-handler.js +15 -15
  176. package/dist/test/mocks/mock-collection-name-cache.d.ts +7 -7
  177. package/dist/test/mocks/mock-collection-name-cache.js +13 -13
  178. package/dist/test/mocks/mock-search-responses.d.ts +5 -4
  179. package/dist/test/mocks/mock-search-responses.js +103 -57
  180. package/dist/test/mocks/mock-search-responses.js.map +1 -1
  181. package/dist/test/mocks/mock-search-service.d.ts +13 -8
  182. package/dist/test/mocks/mock-search-service.js +25 -19
  183. package/dist/test/mocks/mock-search-service.js.map +1 -1
  184. package/dist/test/sort-filter-bar/sort-filter-bar.test.d.ts +1 -1
  185. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +113 -113
  186. package/dist/test/text-overlay.test.d.ts +1 -1
  187. package/dist/test/text-overlay.test.js +41 -41
  188. package/dist/test/text-snippet-block.test.d.ts +1 -1
  189. package/dist/test/text-snippet-block.test.js +57 -45
  190. package/dist/test/text-snippet-block.test.js.map +1 -1
  191. package/dist/test/tile-stats.test.d.ts +1 -1
  192. package/dist/test/tile-stats.test.js +33 -33
  193. package/dist/test/tiles/grid/item-tile.test.d.ts +1 -1
  194. package/dist/test/tiles/grid/item-tile.test.js +107 -107
  195. package/dist/test/tiles/list/tile-list.test.d.ts +1 -1
  196. package/dist/test/tiles/list/tile-list.test.js +36 -36
  197. package/dist/test/utils/format-count.test.d.ts +1 -1
  198. package/dist/test/utils/format-count.test.js +23 -23
  199. package/dist/test/utils/format-date.test.d.ts +1 -1
  200. package/dist/test/utils/format-date.test.js +17 -17
  201. package/index.html +24 -24
  202. package/local.archive.org.cert +86 -86
  203. package/local.archive.org.key +27 -27
  204. package/package.json +115 -115
  205. package/renovate.json +6 -6
  206. package/src/app-root.ts +49 -11
  207. package/src/collection-browser.ts +76 -86
  208. package/src/collection-facets/more-facets-content.ts +35 -27
  209. package/src/collection-facets.ts +9 -26
  210. package/src/models.ts +2 -0
  211. package/src/tiles/text-snippet-block.ts +1 -1
  212. package/test/collection-browser.test.ts +192 -0
  213. package/test/collection-facets/more-facets-content.test.ts +5 -5
  214. package/test/collection-facets.test.ts +16 -15
  215. package/test/mocks/mock-search-responses.ts +83 -34
  216. package/test/mocks/mock-search-service.ts +27 -17
  217. package/test/text-snippet-block.test.ts +17 -0
  218. package/tsconfig.json +21 -21
  219. package/web-dev-server.config.mjs +30 -30
  220. package/web-test-runner.config.mjs +41 -41
@@ -1,31 +1,31 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, LitElement } from 'lit';
3
- import { customElement, property } from 'lit/decorators.js';
4
- import { mediatypeConfig } from '../mediatype/mediatype-config';
5
- let MediatypeIcon = class MediatypeIcon extends LitElement {
6
- constructor() {
7
- super(...arguments);
8
- this.showText = false;
9
- }
10
- get displayMediatype() {
11
- var _a, _b;
12
- const tvIdentifier = ['tvnews', 'tvarchive', 'television'];
13
- const radioIdentifier = ['radio', 'radioprogram'];
14
- if (this.mediatype === 'movies' &&
15
- ((_a = this.collections) === null || _a === void 0 ? void 0 : _a.some(id => tvIdentifier.indexOf(id) >= 0))) {
16
- return 'tv';
17
- }
18
- if (this.mediatype === 'audio' &&
19
- ((_b = this.collections) === null || _b === void 0 ? void 0 : _b.some(id => radioIdentifier.indexOf(id) >= 0))) {
20
- return 'radio';
21
- }
22
- return this.mediatype || '';
23
- }
24
- render() {
25
- const config = mediatypeConfig[this.displayMediatype];
26
- if (!config) {
27
- return html ``;
28
- }
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { mediatypeConfig } from '../mediatype/mediatype-config';
5
+ let MediatypeIcon = class MediatypeIcon extends LitElement {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.showText = false;
9
+ }
10
+ get displayMediatype() {
11
+ var _a, _b;
12
+ const tvIdentifier = ['tvnews', 'tvarchive', 'television'];
13
+ const radioIdentifier = ['radio', 'radioprogram'];
14
+ if (this.mediatype === 'movies' &&
15
+ ((_a = this.collections) === null || _a === void 0 ? void 0 : _a.some(id => tvIdentifier.indexOf(id) >= 0))) {
16
+ return 'tv';
17
+ }
18
+ if (this.mediatype === 'audio' &&
19
+ ((_b = this.collections) === null || _b === void 0 ? void 0 : _b.some(id => radioIdentifier.indexOf(id) >= 0))) {
20
+ return 'radio';
21
+ }
22
+ return this.mediatype || '';
23
+ }
24
+ render() {
25
+ const config = mediatypeConfig[this.displayMediatype];
26
+ if (!config) {
27
+ return html ``;
28
+ }
29
29
  return html `
30
30
  <div
31
31
  id="icon"
@@ -35,9 +35,9 @@ let MediatypeIcon = class MediatypeIcon extends LitElement {
35
35
  ${config.icon}
36
36
  <p class="status-text">${config.text}</p>
37
37
  </div>
38
- `;
39
- }
40
- static get styles() {
38
+ `;
39
+ }
40
+ static get styles() {
41
41
  return css `
42
42
  #icon {
43
43
  height: var(--iconHeight, 25px);
@@ -63,20 +63,20 @@ let MediatypeIcon = class MediatypeIcon extends LitElement {
63
63
  .fill-color {
64
64
  fill: var(--iconFillColor, '#000000');
65
65
  }
66
- `;
67
- }
68
- };
69
- __decorate([
70
- property({ type: String })
71
- ], MediatypeIcon.prototype, "mediatype", void 0);
72
- __decorate([
73
- property({ type: Array })
74
- ], MediatypeIcon.prototype, "collections", void 0);
75
- __decorate([
76
- property({ type: Boolean })
77
- ], MediatypeIcon.prototype, "showText", void 0);
78
- MediatypeIcon = __decorate([
79
- customElement('mediatype-icon')
80
- ], MediatypeIcon);
81
- export { MediatypeIcon };
66
+ `;
67
+ }
68
+ };
69
+ __decorate([
70
+ property({ type: String })
71
+ ], MediatypeIcon.prototype, "mediatype", void 0);
72
+ __decorate([
73
+ property({ type: Array })
74
+ ], MediatypeIcon.prototype, "collections", void 0);
75
+ __decorate([
76
+ property({ type: Boolean })
77
+ ], MediatypeIcon.prototype, "showText", void 0);
78
+ MediatypeIcon = __decorate([
79
+ customElement('mediatype-icon')
80
+ ], MediatypeIcon);
81
+ export { MediatypeIcon };
82
82
  //# sourceMappingURL=mediatype-icon.js.map
@@ -1,7 +1,7 @@
1
- import { CSSResultGroup, LitElement } from 'lit';
2
- export declare class IconOverlay extends LitElement {
3
- loggedIn: boolean;
4
- loginRequired: boolean;
5
- render(): import("lit-html").TemplateResult<1>;
6
- static get styles(): CSSResultGroup;
7
- }
1
+ import { CSSResultGroup, LitElement } from 'lit';
2
+ export declare class IconOverlay extends LitElement {
3
+ loggedIn: boolean;
4
+ loginRequired: boolean;
5
+ render(): import("lit-html").TemplateResult<1>;
6
+ static get styles(): CSSResultGroup;
7
+ }
@@ -1,21 +1,21 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, LitElement } from 'lit';
3
- import { customElement, property } from 'lit/decorators.js';
4
- import { restrictedIcon } from '../../assets/img/icons/restricted';
5
- import { loginRequiredIcon } from '../../assets/img/icons/login-required';
6
- let IconOverlay = class IconOverlay extends LitElement {
7
- constructor() {
8
- super(...arguments);
9
- this.loggedIn = false;
10
- this.loginRequired = false;
11
- }
12
- render() {
13
- if (this.loginRequired && !this.loggedIn) {
14
- return html `${loginRequiredIcon} `;
15
- }
16
- return html `${restrictedIcon}`;
17
- }
18
- static get styles() {
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { restrictedIcon } from '../../assets/img/icons/restricted';
5
+ import { loginRequiredIcon } from '../../assets/img/icons/login-required';
6
+ let IconOverlay = class IconOverlay extends LitElement {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.loggedIn = false;
10
+ this.loginRequired = false;
11
+ }
12
+ render() {
13
+ if (this.loginRequired && !this.loggedIn) {
14
+ return html `${loginRequiredIcon} `;
15
+ }
16
+ return html `${restrictedIcon}`;
17
+ }
18
+ static get styles() {
19
19
  return css `
20
20
  :host {
21
21
  position: absolute;
@@ -27,17 +27,17 @@ let IconOverlay = class IconOverlay extends LitElement {
27
27
  height: 50%;
28
28
  z-index: 2;
29
29
  }
30
- `;
31
- }
32
- };
33
- __decorate([
34
- property({ type: Boolean })
35
- ], IconOverlay.prototype, "loggedIn", void 0);
36
- __decorate([
37
- property({ type: Boolean })
38
- ], IconOverlay.prototype, "loginRequired", void 0);
39
- IconOverlay = __decorate([
40
- customElement('icon-overlay')
41
- ], IconOverlay);
42
- export { IconOverlay };
30
+ `;
31
+ }
32
+ };
33
+ __decorate([
34
+ property({ type: Boolean })
35
+ ], IconOverlay.prototype, "loggedIn", void 0);
36
+ __decorate([
37
+ property({ type: Boolean })
38
+ ], IconOverlay.prototype, "loginRequired", void 0);
39
+ IconOverlay = __decorate([
40
+ customElement('icon-overlay')
41
+ ], IconOverlay);
42
+ export { IconOverlay };
43
43
  //# sourceMappingURL=icon-overlay.js.map
@@ -1,8 +1,8 @@
1
- import { CSSResultGroup, LitElement } from 'lit';
2
- export declare class TextOverlay extends LitElement {
3
- loggedIn: boolean;
4
- loginRequired: boolean;
5
- render(): import("lit-html").TemplateResult<1>;
6
- private get textDisplay();
7
- static get styles(): CSSResultGroup;
8
- }
1
+ import { CSSResultGroup, LitElement } from 'lit';
2
+ export declare class TextOverlay extends LitElement {
3
+ loggedIn: boolean;
4
+ loginRequired: boolean;
5
+ render(): import("lit-html").TemplateResult<1>;
6
+ private get textDisplay();
7
+ static get styles(): CSSResultGroup;
8
+ }
@@ -1,21 +1,21 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, LitElement } from 'lit';
3
- import { customElement, property } from 'lit/decorators.js';
4
- let TextOverlay = class TextOverlay extends LitElement {
5
- constructor() {
6
- super(...arguments);
7
- this.loggedIn = false;
8
- this.loginRequired = false;
9
- }
10
- render() {
11
- return html ` <div class="overlay no-preview">${this.textDisplay}</div> `;
12
- }
13
- get textDisplay() {
14
- return this.loginRequired && !this.loggedIn
15
- ? 'Log in\nto view this item'
16
- : 'Content may be inappropriate';
17
- }
18
- static get styles() {
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ let TextOverlay = class TextOverlay extends LitElement {
5
+ constructor() {
6
+ super(...arguments);
7
+ this.loggedIn = false;
8
+ this.loginRequired = false;
9
+ }
10
+ render() {
11
+ return html ` <div class="overlay no-preview">${this.textDisplay}</div> `;
12
+ }
13
+ get textDisplay() {
14
+ return this.loginRequired && !this.loggedIn
15
+ ? 'Log in\nto view this item'
16
+ : 'Content may be inappropriate';
17
+ }
18
+ static get styles() {
19
19
  return css `
20
20
  :host {
21
21
  align-items: center;
@@ -41,17 +41,17 @@ let TextOverlay = class TextOverlay extends LitElement {
41
41
  text-align: center;
42
42
  white-space: pre-wrap; // for the newline character
43
43
  }
44
- `;
45
- }
46
- };
47
- __decorate([
48
- property({ type: Boolean })
49
- ], TextOverlay.prototype, "loggedIn", void 0);
50
- __decorate([
51
- property({ type: Boolean })
52
- ], TextOverlay.prototype, "loginRequired", void 0);
53
- TextOverlay = __decorate([
54
- customElement('text-overlay')
55
- ], TextOverlay);
56
- export { TextOverlay };
44
+ `;
45
+ }
46
+ };
47
+ __decorate([
48
+ property({ type: Boolean })
49
+ ], TextOverlay.prototype, "loggedIn", void 0);
50
+ __decorate([
51
+ property({ type: Boolean })
52
+ ], TextOverlay.prototype, "loginRequired", void 0);
53
+ TextOverlay = __decorate([
54
+ customElement('text-overlay')
55
+ ], TextOverlay);
56
+ export { TextOverlay };
57
57
  //# sourceMappingURL=text-overlay.js.map
@@ -1,29 +1,29 @@
1
- import { CSSResultGroup, LitElement, TemplateResult } from 'lit';
2
- export declare class TextSnippetBlock extends LitElement {
3
- snippets?: string[];
4
- viewSize: string;
5
- render(): TemplateResult<1>;
6
- private get viewSizeClass();
7
- private get containerClasses();
8
- /**
9
- * An array of HTML templates derived from the snippets, with ellipses inserted
10
- * at the beginning, end, and between each pair of snippets.
11
- */
12
- private get ellipsisJoinedSnippets();
13
- /**
14
- * Returns an array of HTML span templates containing this item's snippets with all of
15
- * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
16
- *
17
- * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
18
- * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
19
- *
20
- * Note on `<em>` vs. `<mark>`:
21
- * The old search page snippets had search keywords demarcated with `<em>` tags.
22
- * The `<mark>` tag is semantically more accurate for this use case than `<em>`,
23
- * but screen-reader behavior may be different. `<em>` will likely be read in a
24
- * different tone, while `<mark>` is often read no differently than ordinary text
25
- * in many screen-readers (though there are ways to work around this if needed).
26
- */
27
- private get snippetTemplates();
28
- static get styles(): CSSResultGroup;
29
- }
1
+ import { CSSResultGroup, LitElement, TemplateResult } from 'lit';
2
+ export declare class TextSnippetBlock extends LitElement {
3
+ snippets?: string[];
4
+ viewSize: string;
5
+ render(): TemplateResult<1>;
6
+ private get viewSizeClass();
7
+ private get containerClasses();
8
+ /**
9
+ * An array of HTML templates derived from the snippets, with ellipses inserted
10
+ * at the beginning, end, and between each pair of snippets.
11
+ */
12
+ private get ellipsisJoinedSnippets();
13
+ /**
14
+ * Returns an array of HTML span templates containing this item's snippets with all of
15
+ * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
16
+ *
17
+ * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
18
+ * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
19
+ *
20
+ * Note on `<em>` vs. `<mark>`:
21
+ * The old search page snippets had search keywords demarcated with `<em>` tags.
22
+ * The `<mark>` tag is semantically more accurate for this use case than `<em>`,
23
+ * but screen-reader behavior may be different. `<em>` will likely be read in a
24
+ * different tone, while `<mark>` is often read no differently than ordinary text
25
+ * in many screen-readers (though there are ways to work around this if needed).
26
+ */
27
+ private get snippetTemplates();
28
+ static get styles(): CSSResultGroup;
29
+ }
@@ -1,80 +1,80 @@
1
- import { __decorate } from "tslib";
2
- import { css, html, LitElement, nothing, } from 'lit';
3
- import { customElement, property } from 'lit/decorators.js';
4
- import { join } from 'lit/directives/join.js';
5
- let TextSnippetBlock = class TextSnippetBlock extends LitElement {
6
- constructor() {
7
- super(...arguments);
8
- this.snippets = [];
9
- this.viewSize = 'desktop';
10
- }
11
- render() {
12
- var _a;
13
- if (!((_a = this.snippets) === null || _a === void 0 ? void 0 : _a.length))
14
- return html `${nothing}`;
1
+ import { __decorate } from "tslib";
2
+ import { css, html, LitElement, nothing, } from 'lit';
3
+ import { customElement, property } from 'lit/decorators.js';
4
+ import { join } from 'lit/directives/join.js';
5
+ let TextSnippetBlock = class TextSnippetBlock extends LitElement {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.snippets = [];
9
+ this.viewSize = 'desktop';
10
+ }
11
+ render() {
12
+ var _a;
13
+ if (!((_a = this.snippets) === null || _a === void 0 ? void 0 : _a.length))
14
+ return html `${nothing}`;
15
15
  return html `
16
16
  <div class="${this.containerClasses}">${this.ellipsisJoinedSnippets}</div>
17
17
 
18
- ${this.viewSize === 'grid'
19
- ? html `<div class="separator"></div>`
18
+ ${this.viewSize === 'grid'
19
+ ? html `<div class="separator"></div>`
20
20
  : nothing}
21
- `;
22
- }
23
- get viewSizeClass() {
24
- return this.viewSize === 'grid' ? 'grid' : 'list';
25
- }
26
- get containerClasses() {
27
- return `container ${this.viewSizeClass}`;
28
- }
29
- /**
30
- * An array of HTML templates derived from the snippets, with ellipses inserted
31
- * at the beginning, end, and between each pair of snippets.
32
- */
33
- get ellipsisJoinedSnippets() {
21
+ `;
22
+ }
23
+ get viewSizeClass() {
24
+ return this.viewSize === 'grid' ? 'grid' : 'list';
25
+ }
26
+ get containerClasses() {
27
+ return `container ${this.viewSizeClass}`;
28
+ }
29
+ /**
30
+ * An array of HTML templates derived from the snippets, with ellipses inserted
31
+ * at the beginning, end, and between each pair of snippets.
32
+ */
33
+ get ellipsisJoinedSnippets() {
34
34
  return html `
35
35
  &hellip; ${join(this.snippetTemplates, html ` &hellip; `)} &hellip;
36
- `;
37
- }
38
- /**
39
- * Returns an array of HTML span templates containing this item's snippets with all of
40
- * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
41
- *
42
- * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
43
- * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
44
- *
45
- * Note on `<em>` vs. `<mark>`:
46
- * The old search page snippets had search keywords demarcated with `<em>` tags.
47
- * The `<mark>` tag is semantically more accurate for this use case than `<em>`,
48
- * but screen-reader behavior may be different. `<em>` will likely be read in a
49
- * different tone, while `<mark>` is often read no differently than ordinary text
50
- * in many screen-readers (though there are ways to work around this if needed).
51
- */
52
- get snippetTemplates() {
53
- var _a;
54
- return (_a = this.snippets) === null || _a === void 0 ? void 0 : _a.map(s => {
55
- const matches = s.matchAll(/{{{(.+?)}}}/g);
56
- const templates = [];
57
- // Convert each match into an HTML template that includes:
58
- // - Everything from the end of the previous match (or the beginning of the
59
- // string) up to the current match, as raw text.
60
- // - The current match (excluding the curly braces) wrapped in a `<mark>` tag.
61
- let index = 0;
62
- for (const match of matches) {
63
- if (match.index != null) {
36
+ `;
37
+ }
38
+ /**
39
+ * Returns an array of HTML span templates containing this item's snippets with all of
40
+ * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.
41
+ *
42
+ * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags
43
+ * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.
44
+ *
45
+ * Note on `<em>` vs. `<mark>`:
46
+ * The old search page snippets had search keywords demarcated with `<em>` tags.
47
+ * The `<mark>` tag is semantically more accurate for this use case than `<em>`,
48
+ * but screen-reader behavior may be different. `<em>` will likely be read in a
49
+ * different tone, while `<mark>` is often read no differently than ordinary text
50
+ * in many screen-readers (though there are ways to work around this if needed).
51
+ */
52
+ get snippetTemplates() {
53
+ var _a;
54
+ return (_a = this.snippets) === null || _a === void 0 ? void 0 : _a.map(s => {
55
+ const matches = s.matchAll(/{{{(.+?)}}}/gs);
56
+ const templates = [];
57
+ // Convert each match into an HTML template that includes:
58
+ // - Everything from the end of the previous match (or the beginning of the
59
+ // string) up to the current match, as raw text.
60
+ // - The current match (excluding the curly braces) wrapped in a `<mark>` tag.
61
+ let index = 0;
62
+ for (const match of matches) {
63
+ if (match.index != null) {
64
64
  templates.push(html `
65
65
  ${s.slice(index, match.index)}
66
66
  <mark>${match[1]}</mark>
67
- `);
68
- index = match.index + match[0].length;
69
- }
70
- }
71
- // Include any text from the last match to the end
72
- templates.push(html `${s.slice(index)}`);
73
- // Squash everything into a single span template
74
- return html `<span>${templates}</span>`;
75
- });
76
- }
77
- static get styles() {
67
+ `);
68
+ index = match.index + match[0].length;
69
+ }
70
+ }
71
+ // Include any text from the last match to the end
72
+ templates.push(html `${s.slice(index)}`);
73
+ // Squash everything into a single span template
74
+ return html `<span>${templates}</span>`;
75
+ });
76
+ }
77
+ static get styles() {
78
78
  return css `
79
79
  .container {
80
80
  display: -webkit-box;
@@ -112,17 +112,17 @@ let TextSnippetBlock = class TextSnippetBlock extends LitElement {
112
112
  background-color: #0000ff33;
113
113
  color: inherit;
114
114
  }
115
- `;
116
- }
117
- };
118
- __decorate([
119
- property({ type: Array })
120
- ], TextSnippetBlock.prototype, "snippets", void 0);
121
- __decorate([
122
- property({ type: String })
123
- ], TextSnippetBlock.prototype, "viewSize", void 0);
124
- TextSnippetBlock = __decorate([
125
- customElement('text-snippet-block')
126
- ], TextSnippetBlock);
127
- export { TextSnippetBlock };
115
+ `;
116
+ }
117
+ };
118
+ __decorate([
119
+ property({ type: Array })
120
+ ], TextSnippetBlock.prototype, "snippets", void 0);
121
+ __decorate([
122
+ property({ type: String })
123
+ ], TextSnippetBlock.prototype, "viewSize", void 0);
124
+ TextSnippetBlock = __decorate([
125
+ customElement('text-snippet-block')
126
+ ], TextSnippetBlock);
127
+ export { TextSnippetBlock };
128
128
  //# sourceMappingURL=text-snippet-block.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"text-snippet-block.js","sourceRoot":"","sources":["../../../src/tiles/text-snippet-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAG9C,IAAa,gBAAgB,GAA7B,MAAa,gBAAiB,SAAQ,UAAU;IAAhD;;QAC6B,aAAQ,GAAc,EAAE,CAAC;QAExB,aAAQ,GAAW,SAAS,CAAC;IAkH3D,CAAC;IAhHC,MAAM;;QACJ,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,MAAM,CAAA;YAAE,OAAO,IAAI,CAAA,GAAG,OAAO,EAAE,CAAC;QAEpD,OAAO,IAAI,CAAA;oBACK,IAAI,CAAC,gBAAgB,KAAK,IAAI,CAAC,sBAAsB;;QAEjE,IAAI,CAAC,QAAQ,KAAK,MAAM;YACxB,CAAC,CAAC,IAAI,CAAA,+BAA+B;YACrC,CAAC,CAAC,OAAO;KACZ,CAAC;IACJ,CAAC;IAED,IAAY,aAAa;QACvB,OAAO,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;IACpD,CAAC;IAED,IAAY,gBAAgB;QAC1B,OAAO,aAAa,IAAI,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED;;;OAGG;IACH,IAAY,sBAAsB;QAChC,OAAO,IAAI,CAAA;iBACE,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAA,YAAY,CAAC;KACzD,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,IAAY,gBAAgB;;QAC1B,OAAO,MAAA,IAAI,CAAC,QAAQ,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE;YAC5B,MAAM,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;YAC3C,MAAM,SAAS,GAAqB,EAAE,CAAC;YAEvC,0DAA0D;YAC1D,4EAA4E;YAC5E,qDAAqD;YACrD,+EAA+E;YAC/E,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;gBAC3B,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,EAAE;oBACvB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA;cACf,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC;oBACrB,KAAK,CAAC,CAAC,CAAC;WACjB,CAAC,CAAC;oBACH,KAAK,GAAG,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;iBACvC;aACF;YAED,kDAAkD;YAClD,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAExC,gDAAgD;YAChD,OAAO,IAAI,CAAA,SAAS,SAAS,SAAS,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAqCT,CAAC;IACJ,CAAC;CACF,CAAA;AApH4B;IAA1B,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;kDAA0B;AAExB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAA8B;AAH9C,gBAAgB;IAD5B,aAAa,CAAC,oBAAoB,CAAC;GACvB,gBAAgB,CAqH5B;SArHY,gBAAgB","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n LitElement,\n nothing,\n TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { join } from 'lit/directives/join.js';\n\n@customElement('text-snippet-block')\nexport class TextSnippetBlock extends LitElement {\n @property({ type: Array }) snippets?: string[] = [];\n\n @property({ type: String }) viewSize: string = 'desktop';\n\n render() {\n if (!this.snippets?.length) return html`${nothing}`;\n\n return html`\n <div class=\"${this.containerClasses}\">${this.ellipsisJoinedSnippets}</div>\n\n ${this.viewSize === 'grid'\n ? html`<div class=\"separator\"></div>`\n : nothing}\n `;\n }\n\n private get viewSizeClass() {\n return this.viewSize === 'grid' ? 'grid' : 'list';\n }\n\n private get containerClasses() {\n return `container ${this.viewSizeClass}`;\n }\n\n /**\n * An array of HTML templates derived from the snippets, with ellipses inserted\n * at the beginning, end, and between each pair of snippets.\n */\n private get ellipsisJoinedSnippets(): TemplateResult {\n return html`\n &hellip; ${join(this.snippetTemplates, html` &hellip; `)} &hellip;\n `;\n }\n\n /**\n * Returns an array of HTML span templates containing this item's snippets with all of\n * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.\n *\n * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags\n * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.\n *\n * Note on `<em>` vs. `<mark>`:\n * The old search page snippets had search keywords demarcated with `<em>` tags.\n * The `<mark>` tag is semantically more accurate for this use case than `<em>`,\n * but screen-reader behavior may be different. `<em>` will likely be read in a\n * different tone, while `<mark>` is often read no differently than ordinary text\n * in many screen-readers (though there are ways to work around this if needed).\n */\n private get snippetTemplates(): TemplateResult[] | undefined {\n return this.snippets?.map(s => {\n const matches = s.matchAll(/{{{(.+?)}}}/g);\n const templates: TemplateResult[] = [];\n\n // Convert each match into an HTML template that includes:\n // - Everything from the end of the previous match (or the beginning of the\n // string) up to the current match, as raw text.\n // - The current match (excluding the curly braces) wrapped in a `<mark>` tag.\n let index = 0;\n for (const match of matches) {\n if (match.index != null) {\n templates.push(html`\n ${s.slice(index, match.index)}\n <mark>${match[1]}</mark>\n `);\n index = match.index + match[0].length;\n }\n }\n\n // Include any text from the last match to the end\n templates.push(html`${s.slice(index)}`);\n\n // Squash everything into a single span template\n return html`<span>${templates}</span>`;\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n .container {\n display: -webkit-box;\n font-family: 'Times New Roman', serif;\n overflow: hidden;\n overflow-wrap: break-word;\n -webkit-line-clamp: var(--maxLines, 3);\n -webkit-box-orient: vertical;\n }\n\n .separator {\n /* Border line should extend to the edges of the tile */\n margin: 0 -5px;\n border-bottom: 1px solid #bbb;\n }\n\n .grid {\n /* Bottom margin reduced by 1px to account for the separator */\n margin: 0.5rem 0 0.4rem;\n font-size: 1.2rem;\n line-height: 1.5rem;\n }\n\n .list {\n margin: 1rem 0 0;\n padding: 0 0 0 1.5rem;\n border-left: 0.5rem solid #194880;\n border-radius: 3px;\n font-size: 1.4rem;\n line-height: 2rem;\n }\n\n mark {\n /* blue, 20% transparency */\n background-color: #0000ff33;\n color: inherit;\n }\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"text-snippet-block.js","sourceRoot":"","sources":["../../../src/tiles/text-snippet-block.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,GAAG,EAEH,IAAI,EACJ,UAAU,EACV,OAAO,GAER,MAAM,KAAK,CAAC;AACb,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAG9C,IAAa,gBAAgB,GAA7B,MAAa,gBAAiB,SAAQ,UAAU;IAAhD;;QAC6B,aAAQ,GAAc,EAAE,CAAC;QAExB,aAAQ,GAAW,SAAS,CAAC;IAkH3D,CAAC;IAhHC,MAAM;;QACJ,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,MAAM,CAAA;YAAE,OAAO,IAAI,CAAA,GAAG,OAAO,EAAE,CAAC;QAEpD,OAAO,IAAI,CAAA;oBACK,IAAI,CAAC,gBAAgB,KAAK,IAAI,CAAC,sBAAsB;;QAEjE,IAAI,CAAC,QAAQ,KAAK,MAAM;YACxB,CAAC,CAAC,IAAI,CAAA,+BAA+B;YACrC,CAAC,CAAC,OAAO;KACZ,CAAC;IACJ,CAAC;IAED,IAAY,aAAa;QACvB,OAAO,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;IACpD,CAAC;IAED,IAAY,gBAAgB;QAC1B,OAAO,aAAa,IAAI,CAAC,aAAa,EAAE,CAAC;IAC3C,CAAC;IAED;;;OAGG;IACH,IAAY,sBAAsB;QAChC,OAAO,IAAI,CAAA;iBACE,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAA,YAAY,CAAC;KACzD,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,IAAY,gBAAgB;;QAC1B,OAAO,MAAA,IAAI,CAAC,QAAQ,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE;YAC5B,MAAM,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;YAC5C,MAAM,SAAS,GAAqB,EAAE,CAAC;YAEvC,0DAA0D;YAC1D,4EAA4E;YAC5E,qDAAqD;YACrD,+EAA+E;YAC/E,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;gBAC3B,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,EAAE;oBACvB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA;cACf,CAAC,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC;oBACrB,KAAK,CAAC,CAAC,CAAC;WACjB,CAAC,CAAC;oBACH,KAAK,GAAG,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;iBACvC;aACF;YAED,kDAAkD;YAClD,SAAS,CAAC,IAAI,CAAC,IAAI,CAAA,GAAG,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAExC,gDAAgD;YAChD,OAAO,IAAI,CAAA,SAAS,SAAS,SAAS,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,KAAK,MAAM;QACf,OAAO,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAqCT,CAAC;IACJ,CAAC;CACF,CAAA;AApH4B;IAA1B,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;kDAA0B;AAExB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;kDAA8B;AAH9C,gBAAgB;IAD5B,aAAa,CAAC,oBAAoB,CAAC;GACvB,gBAAgB,CAqH5B;SArHY,gBAAgB","sourcesContent":["import {\n css,\n CSSResultGroup,\n html,\n LitElement,\n nothing,\n TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { join } from 'lit/directives/join.js';\n\n@customElement('text-snippet-block')\nexport class TextSnippetBlock extends LitElement {\n @property({ type: Array }) snippets?: string[] = [];\n\n @property({ type: String }) viewSize: string = 'desktop';\n\n render() {\n if (!this.snippets?.length) return html`${nothing}`;\n\n return html`\n <div class=\"${this.containerClasses}\">${this.ellipsisJoinedSnippets}</div>\n\n ${this.viewSize === 'grid'\n ? html`<div class=\"separator\"></div>`\n : nothing}\n `;\n }\n\n private get viewSizeClass() {\n return this.viewSize === 'grid' ? 'grid' : 'list';\n }\n\n private get containerClasses() {\n return `container ${this.viewSizeClass}`;\n }\n\n /**\n * An array of HTML templates derived from the snippets, with ellipses inserted\n * at the beginning, end, and between each pair of snippets.\n */\n private get ellipsisJoinedSnippets(): TemplateResult {\n return html`\n &hellip; ${join(this.snippetTemplates, html` &hellip; `)} &hellip;\n `;\n }\n\n /**\n * Returns an array of HTML span templates containing this item's snippets with all of\n * their `{{{triple-brace-delimited}}}` matches replaced by `<mark>HTML mark tags</mark>`.\n *\n * This approach safely avoids the use of `unsafeHTML` and leaves any existing HTML tags\n * in the snippets intact (as inert text), rather than stripping them away with DOMPurify.\n *\n * Note on `<em>` vs. `<mark>`:\n * The old search page snippets had search keywords demarcated with `<em>` tags.\n * The `<mark>` tag is semantically more accurate for this use case than `<em>`,\n * but screen-reader behavior may be different. `<em>` will likely be read in a\n * different tone, while `<mark>` is often read no differently than ordinary text\n * in many screen-readers (though there are ways to work around this if needed).\n */\n private get snippetTemplates(): TemplateResult[] | undefined {\n return this.snippets?.map(s => {\n const matches = s.matchAll(/{{{(.+?)}}}/gs);\n const templates: TemplateResult[] = [];\n\n // Convert each match into an HTML template that includes:\n // - Everything from the end of the previous match (or the beginning of the\n // string) up to the current match, as raw text.\n // - The current match (excluding the curly braces) wrapped in a `<mark>` tag.\n let index = 0;\n for (const match of matches) {\n if (match.index != null) {\n templates.push(html`\n ${s.slice(index, match.index)}\n <mark>${match[1]}</mark>\n `);\n index = match.index + match[0].length;\n }\n }\n\n // Include any text from the last match to the end\n templates.push(html`${s.slice(index)}`);\n\n // Squash everything into a single span template\n return html`<span>${templates}</span>`;\n });\n }\n\n static get styles(): CSSResultGroup {\n return css`\n .container {\n display: -webkit-box;\n font-family: 'Times New Roman', serif;\n overflow: hidden;\n overflow-wrap: break-word;\n -webkit-line-clamp: var(--maxLines, 3);\n -webkit-box-orient: vertical;\n }\n\n .separator {\n /* Border line should extend to the edges of the tile */\n margin: 0 -5px;\n border-bottom: 1px solid #bbb;\n }\n\n .grid {\n /* Bottom margin reduced by 1px to account for the separator */\n margin: 0.5rem 0 0.4rem;\n font-size: 1.2rem;\n line-height: 1.5rem;\n }\n\n .list {\n margin: 1rem 0 0;\n padding: 0 0 0 1.5rem;\n border-left: 0.5rem solid #194880;\n border-radius: 3px;\n font-size: 1.4rem;\n line-height: 2rem;\n }\n\n mark {\n /* blue, 20% transparency */\n background-color: #0000ff33;\n color: inherit;\n }\n `;\n }\n}\n"]}
@@ -1,36 +1,36 @@
1
- import { LitElement, PropertyValues } from 'lit';
2
- import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
3
- import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
4
- import type { SortParam } from '@internetarchive/search-service';
5
- import type { TileDisplayMode, TileModel } from '../models';
6
- import './grid/collection-tile';
7
- import './grid/item-tile';
8
- import './grid/account-tile';
9
- import './list/tile-list';
10
- import './list/tile-list-compact';
11
- import './list/tile-list-compact-header';
12
- export declare class TileDispatcher extends LitElement implements SharedResizeObserverResizeHandlerInterface {
13
- tileDisplayMode?: TileDisplayMode;
14
- model?: TileModel;
15
- baseNavigationUrl?: string;
16
- currentWidth?: number;
17
- currentHeight?: number;
18
- resizeObserver?: SharedResizeObserverInterface;
19
- collectionNameCache?: CollectionNameCacheInterface;
20
- sortParam: SortParam | null;
21
- private container;
22
- mobileBreakpoint?: number;
23
- baseImageUrl?: string;
24
- loggedIn: boolean;
25
- render(): import("lit-html").TemplateResult<1>;
26
- private get headerTemplate();
27
- private get tileTemplate();
28
- private get linkTileTemplate();
29
- handleResize(entry: ResizeObserverEntry): void;
30
- disconnectedCallback(): void;
31
- private stopResizeObservation;
32
- private startResizeObservation;
33
- updated(props: PropertyValues): void;
34
- private get tile();
35
- static get styles(): import("lit").CSSResult;
36
- }
1
+ import { LitElement, PropertyValues } from 'lit';
2
+ import type { SharedResizeObserverInterface, SharedResizeObserverResizeHandlerInterface } from '@internetarchive/shared-resize-observer';
3
+ import type { CollectionNameCacheInterface } from '@internetarchive/collection-name-cache';
4
+ import type { SortParam } from '@internetarchive/search-service';
5
+ import type { TileDisplayMode, TileModel } from '../models';
6
+ import './grid/collection-tile';
7
+ import './grid/item-tile';
8
+ import './grid/account-tile';
9
+ import './list/tile-list';
10
+ import './list/tile-list-compact';
11
+ import './list/tile-list-compact-header';
12
+ export declare class TileDispatcher extends LitElement implements SharedResizeObserverResizeHandlerInterface {
13
+ tileDisplayMode?: TileDisplayMode;
14
+ model?: TileModel;
15
+ baseNavigationUrl?: string;
16
+ currentWidth?: number;
17
+ currentHeight?: number;
18
+ resizeObserver?: SharedResizeObserverInterface;
19
+ collectionNameCache?: CollectionNameCacheInterface;
20
+ sortParam: SortParam | null;
21
+ private container;
22
+ mobileBreakpoint?: number;
23
+ baseImageUrl?: string;
24
+ loggedIn: boolean;
25
+ render(): import("lit-html").TemplateResult<1>;
26
+ private get headerTemplate();
27
+ private get tileTemplate();
28
+ private get linkTileTemplate();
29
+ handleResize(entry: ResizeObserverEntry): void;
30
+ disconnectedCallback(): void;
31
+ private stopResizeObservation;
32
+ private startResizeObservation;
33
+ updated(props: PropertyValues): void;
34
+ private get tile();
35
+ static get styles(): import("lit").CSSResult;
36
+ }