@internetarchive/collection-browser 3.4.1-alpha-webdev7761.2 → 3.4.1-alpha-webdev7761.4

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 (208) hide show
  1. package/dist/src/app-root.js +19 -28
  2. package/dist/src/app-root.js.map +1 -1
  3. package/dist/src/collection-browser.d.ts +14 -10
  4. package/dist/src/collection-browser.js +870 -886
  5. package/dist/src/collection-browser.js.map +1 -1
  6. package/dist/src/collection-facets/facet-row.js +3 -4
  7. package/dist/src/collection-facets/facet-row.js.map +1 -1
  8. package/dist/src/collection-facets/models.js.map +1 -1
  9. package/dist/src/collection-facets/more-facets-content.js +145 -156
  10. package/dist/src/collection-facets/more-facets-content.js.map +1 -1
  11. package/dist/src/collection-facets/more-facets-pagination.js +6 -10
  12. package/dist/src/collection-facets/more-facets-pagination.js.map +1 -1
  13. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js +16 -21
  14. package/dist/src/collection-facets/smart-facets/heuristics/wikidata/wikidata-heuristic.js.map +1 -1
  15. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js +7 -10
  16. package/dist/src/collection-facets/smart-facets/smart-facet-bar.js.map +1 -1
  17. package/dist/src/collection-facets/smart-facets/smart-facet-button.js +3 -2
  18. package/dist/src/collection-facets/smart-facets/smart-facet-button.js.map +1 -1
  19. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js +9 -11
  20. package/dist/src/collection-facets/smart-facets/smart-facet-dropdown.js.map +1 -1
  21. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js +7 -7
  22. package/dist/src/collection-facets/smart-facets/smart-facet-heuristics.js.map +1 -1
  23. package/dist/src/collection-facets/toggle-switch.js +4 -6
  24. package/dist/src/collection-facets/toggle-switch.js.map +1 -1
  25. package/dist/src/collection-facets.js +34 -50
  26. package/dist/src/collection-facets.js.map +1 -1
  27. package/dist/src/combo-box/caret-closed.js +5 -11
  28. package/dist/src/combo-box/caret-closed.js.map +1 -1
  29. package/dist/src/combo-box/caret-open.js +5 -11
  30. package/dist/src/combo-box/caret-open.js.map +1 -1
  31. package/dist/src/combo-box/clear.d.ts +2 -0
  32. package/dist/src/combo-box/clear.js +11 -0
  33. package/dist/src/combo-box/clear.js.map +1 -0
  34. package/dist/src/combo-box/ia-combo-box.d.ts +40 -9
  35. package/dist/src/combo-box/ia-combo-box.js +363 -272
  36. package/dist/src/combo-box/ia-combo-box.js.map +1 -1
  37. package/dist/src/combo-box/models.d.ts +14 -0
  38. package/dist/src/combo-box/models.js +32 -1
  39. package/dist/src/combo-box/models.js.map +1 -1
  40. package/dist/src/data-source/collection-browser-data-source.js +35 -47
  41. package/dist/src/data-source/collection-browser-data-source.js.map +1 -1
  42. package/dist/src/empty-placeholder.js +19 -18
  43. package/dist/src/empty-placeholder.js.map +1 -1
  44. package/dist/src/expanded-date-picker.js +6 -10
  45. package/dist/src/expanded-date-picker.js.map +1 -1
  46. package/dist/src/language-code-handler/language-code-handler.js +2 -2
  47. package/dist/src/language-code-handler/language-code-handler.js.map +1 -1
  48. package/dist/src/manage/manage-bar.js +86 -92
  49. package/dist/src/manage/manage-bar.js.map +1 -1
  50. package/dist/src/manage/remove-items-modal-content.js +2 -2
  51. package/dist/src/manage/remove-items-modal-content.js.map +1 -1
  52. package/dist/src/models.js +36 -40
  53. package/dist/src/models.js.map +1 -1
  54. package/dist/src/restoration-state-handler.js +9 -10
  55. package/dist/src/restoration-state-handler.js.map +1 -1
  56. package/dist/src/sort-filter-bar/alpha-bar.js +9 -14
  57. package/dist/src/sort-filter-bar/alpha-bar.js.map +1 -1
  58. package/dist/src/sort-filter-bar/sort-filter-bar.js +14 -24
  59. package/dist/src/sort-filter-bar/sort-filter-bar.js.map +1 -1
  60. package/dist/src/tiles/base-tile-component.js +1 -2
  61. package/dist/src/tiles/base-tile-component.js.map +1 -1
  62. package/dist/src/tiles/grid/account-tile.js +36 -38
  63. package/dist/src/tiles/grid/account-tile.js.map +1 -1
  64. package/dist/src/tiles/grid/collection-tile.js +79 -82
  65. package/dist/src/tiles/grid/collection-tile.js.map +1 -1
  66. package/dist/src/tiles/grid/item-tile.js +154 -164
  67. package/dist/src/tiles/grid/item-tile.js.map +1 -1
  68. package/dist/src/tiles/grid/search-tile.js +42 -43
  69. package/dist/src/tiles/grid/search-tile.js.map +1 -1
  70. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js +119 -119
  71. package/dist/src/tiles/grid/styles/tile-grid-shared-styles.js.map +1 -1
  72. package/dist/src/tiles/grid/tile-stats.js +2 -3
  73. package/dist/src/tiles/grid/tile-stats.js.map +1 -1
  74. package/dist/src/tiles/hover/hover-pane-controller.js +42 -49
  75. package/dist/src/tiles/hover/hover-pane-controller.js.map +1 -1
  76. package/dist/src/tiles/hover/tile-hover-pane.js +113 -114
  77. package/dist/src/tiles/hover/tile-hover-pane.js.map +1 -1
  78. package/dist/src/tiles/image-block.js +5 -8
  79. package/dist/src/tiles/image-block.js.map +1 -1
  80. package/dist/src/tiles/item-image.js +12 -19
  81. package/dist/src/tiles/item-image.js.map +1 -1
  82. package/dist/src/tiles/list/tile-list-compact.js +114 -122
  83. package/dist/src/tiles/list/tile-list-compact.js.map +1 -1
  84. package/dist/src/tiles/list/tile-list.js +326 -347
  85. package/dist/src/tiles/list/tile-list.js.map +1 -1
  86. package/dist/src/tiles/overlay/icon-overlay.js +1 -2
  87. package/dist/src/tiles/overlay/icon-overlay.js.map +1 -1
  88. package/dist/src/tiles/overlay/text-overlay.js +2 -4
  89. package/dist/src/tiles/overlay/text-overlay.js.map +1 -1
  90. package/dist/src/tiles/text-snippet-block.js +2 -4
  91. package/dist/src/tiles/text-snippet-block.js.map +1 -1
  92. package/dist/src/tiles/tile-dispatcher.js +233 -241
  93. package/dist/src/tiles/tile-dispatcher.js.map +1 -1
  94. package/dist/src/tiles/tile-display-value-provider.js +5 -9
  95. package/dist/src/tiles/tile-display-value-provider.js.map +1 -1
  96. package/dist/src/tiles/tile-mediatype-icon.js +12 -19
  97. package/dist/src/tiles/tile-mediatype-icon.js.map +1 -1
  98. package/dist/src/utils/collapse-repeated-quotes.js +1 -1
  99. package/dist/src/utils/collapse-repeated-quotes.js.map +1 -1
  100. package/dist/src/utils/facet-utils.js +3 -5
  101. package/dist/src/utils/facet-utils.js.map +1 -1
  102. package/dist/src/utils/format-count.js +10 -10
  103. package/dist/src/utils/format-count.js.map +1 -1
  104. package/dist/src/utils/format-date.js.map +1 -1
  105. package/dist/src/utils/resolve-mediatype.js +2 -3
  106. package/dist/src/utils/resolve-mediatype.js.map +1 -1
  107. package/dist/test/collection-browser.test.js +131 -185
  108. package/dist/test/collection-browser.test.js.map +1 -1
  109. package/dist/test/collection-facets/facet-row.test.js +60 -75
  110. package/dist/test/collection-facets/facet-row.test.js.map +1 -1
  111. package/dist/test/collection-facets/facets-template.test.js +17 -23
  112. package/dist/test/collection-facets/facets-template.test.js.map +1 -1
  113. package/dist/test/collection-facets/more-facets-content.test.js +22 -32
  114. package/dist/test/collection-facets/more-facets-content.test.js.map +1 -1
  115. package/dist/test/collection-facets/more-facets-pagination.test.js +16 -22
  116. package/dist/test/collection-facets/more-facets-pagination.test.js.map +1 -1
  117. package/dist/test/collection-facets/toggle-switch.test.js +22 -19
  118. package/dist/test/collection-facets/toggle-switch.test.js.map +1 -1
  119. package/dist/test/collection-facets.test.js +80 -97
  120. package/dist/test/collection-facets.test.js.map +1 -1
  121. package/dist/test/empty-placeholder.test.js +11 -17
  122. package/dist/test/empty-placeholder.test.js.map +1 -1
  123. package/dist/test/expanded-date-picker.test.js +8 -14
  124. package/dist/test/expanded-date-picker.test.js.map +1 -1
  125. package/dist/test/icon-overlay.test.js +7 -6
  126. package/dist/test/icon-overlay.test.js.map +1 -1
  127. package/dist/test/image-block.test.js +16 -26
  128. package/dist/test/image-block.test.js.map +1 -1
  129. package/dist/test/item-image.test.js +23 -32
  130. package/dist/test/item-image.test.js.map +1 -1
  131. package/dist/test/manage/manage-bar.test.js +21 -33
  132. package/dist/test/manage/manage-bar.test.js.map +1 -1
  133. package/dist/test/manage/remove-items-modal-content.test.js +10 -15
  134. package/dist/test/manage/remove-items-modal-content.test.js.map +1 -1
  135. package/dist/test/mocks/mock-search-service.js +2 -3
  136. package/dist/test/mocks/mock-search-service.js.map +1 -1
  137. package/dist/test/restoration-state-handler.test.js +13 -21
  138. package/dist/test/restoration-state-handler.test.js.map +1 -1
  139. package/dist/test/review-block.test.js +16 -18
  140. package/dist/test/review-block.test.js.map +1 -1
  141. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js +2 -3
  142. package/dist/test/sort-filter-bar/alpha-bar-tooltip.test.js.map +1 -1
  143. package/dist/test/sort-filter-bar/alpha-bar.test.js +18 -24
  144. package/dist/test/sort-filter-bar/alpha-bar.test.js.map +1 -1
  145. package/dist/test/sort-filter-bar/sort-filter-bar.test.js +178 -180
  146. package/dist/test/sort-filter-bar/sort-filter-bar.test.js.map +1 -1
  147. package/dist/test/text-overlay.test.js +16 -15
  148. package/dist/test/text-overlay.test.js.map +1 -1
  149. package/dist/test/text-snippet-block.test.js +14 -19
  150. package/dist/test/text-snippet-block.test.js.map +1 -1
  151. package/dist/test/tile-stats.test.js +73 -34
  152. package/dist/test/tile-stats.test.js.map +1 -1
  153. package/dist/test/tiles/grid/account-tile.test.js +25 -25
  154. package/dist/test/tiles/grid/account-tile.test.js.map +1 -1
  155. package/dist/test/tiles/grid/collection-tile.test.js +13 -19
  156. package/dist/test/tiles/grid/collection-tile.test.js.map +1 -1
  157. package/dist/test/tiles/grid/item-tile.test.js +141 -168
  158. package/dist/test/tiles/grid/item-tile.test.js.map +1 -1
  159. package/dist/test/tiles/grid/search-tile.test.js +9 -13
  160. package/dist/test/tiles/grid/search-tile.test.js.map +1 -1
  161. package/dist/test/tiles/hover/hover-pane-controller.test.js +50 -62
  162. package/dist/test/tiles/hover/hover-pane-controller.test.js.map +1 -1
  163. package/dist/test/tiles/hover/tile-hover-pane.test.js +12 -16
  164. package/dist/test/tiles/hover/tile-hover-pane.test.js.map +1 -1
  165. package/dist/test/tiles/list/tile-list-compact.test.js +104 -118
  166. package/dist/test/tiles/list/tile-list-compact.test.js.map +1 -1
  167. package/dist/test/tiles/list/tile-list.test.js +202 -231
  168. package/dist/test/tiles/list/tile-list.test.js.map +1 -1
  169. package/dist/test/tiles/tile-dispatcher.test.js +97 -110
  170. package/dist/test/tiles/tile-dispatcher.test.js.map +1 -1
  171. package/dist/test/tiles/tile-mediatype-icon.test.js +12 -24
  172. package/dist/test/tiles/tile-mediatype-icon.test.js.map +1 -1
  173. package/dist/test/utils/format-date.test.js.map +1 -1
  174. package/index.html +1 -1
  175. package/package.json +5 -3
  176. package/src/collection-browser.ts +3060 -3030
  177. package/src/collection-facets/models.ts +10 -10
  178. package/src/collection-facets/more-facets-content.ts +639 -639
  179. package/src/collection-facets.ts +1 -1
  180. package/src/combo-box/caret-closed.ts +5 -11
  181. package/src/combo-box/caret-open.ts +5 -11
  182. package/src/combo-box/clear.ts +11 -0
  183. package/src/combo-box/ia-combo-box.ts +1288 -1180
  184. package/src/combo-box/models.ts +31 -1
  185. package/src/manage/manage-bar.ts +247 -247
  186. package/src/restoration-state-handler.ts +5 -1
  187. package/src/tiles/base-tile-component.ts +65 -65
  188. package/src/tiles/grid/account-tile.ts +113 -113
  189. package/src/tiles/grid/collection-tile.ts +163 -163
  190. package/src/tiles/grid/item-tile.ts +340 -340
  191. package/src/tiles/grid/search-tile.ts +90 -90
  192. package/src/tiles/grid/styles/tile-grid-shared-styles.ts +130 -130
  193. package/src/tiles/hover/hover-pane-controller.ts +613 -613
  194. package/src/tiles/hover/tile-hover-pane.ts +184 -184
  195. package/src/tiles/list/tile-list-compact.ts +239 -239
  196. package/src/tiles/list/tile-list.ts +700 -700
  197. package/src/tiles/tile-dispatcher.ts +517 -517
  198. package/src/utils/format-date.ts +62 -62
  199. package/test/collection-facets/facet-row.test.ts +375 -375
  200. package/test/collection-facets.test.ts +928 -928
  201. package/test/tiles/grid/item-tile.test.ts +520 -520
  202. package/test/tiles/hover/hover-pane-controller.test.ts +418 -418
  203. package/test/tiles/list/tile-list-compact.test.ts +282 -282
  204. package/test/tiles/list/tile-list.test.ts +552 -552
  205. package/test/tiles/tile-dispatcher.test.ts +283 -283
  206. package/test/utils/format-date.test.ts +89 -89
  207. package/tsconfig.json +8 -3
  208. package/vite.config.ts +29 -22
@@ -1,184 +1,184 @@
1
- import type { SortParam } from '@internetarchive/search-service';
2
- import {
3
- css,
4
- CSSResultGroup,
5
- html,
6
- LitElement,
7
- nothing,
8
- TemplateResult,
9
- } from 'lit';
10
- import { customElement, property } from 'lit/decorators.js';
11
- import '@a11y/focus-trap';
12
-
13
- import { suppressedCollections, type TileModel } from '../../models';
14
- import type { CollectionTitles } from '../../data-source/models';
15
- import '../list/tile-list';
16
-
17
- @customElement('tile-hover-pane')
18
- export class TileHoverPane extends LitElement {
19
- @property({ type: Object }) model?: TileModel;
20
-
21
- @property({ type: String }) baseNavigationUrl?: string;
22
-
23
- @property({ type: String }) baseImageUrl?: string;
24
-
25
- @property({ type: Boolean }) loggedIn: boolean = false;
26
-
27
- @property({ type: Boolean }) suppressBlurring: boolean = false;
28
-
29
- @property({ type: Object }) sortParam?: SortParam;
30
-
31
- @property({ type: Number }) mobileBreakpoint?: number;
32
-
33
- @property({ type: Number }) currentWidth?: number;
34
-
35
- @property({ type: Object })
36
- collectionTitles?: CollectionTitles;
37
-
38
- protected render(): TemplateResult {
39
- return html`
40
- <div id="container">
41
- <focus-trap>
42
- ${this.headerTemplate}
43
- <div id="hover-tile-list">
44
- <tile-list
45
- .model=${this.model}
46
- .baseNavigationUrl=${this.baseNavigationUrl}
47
- .baseImageUrl=${this.baseImageUrl}
48
- .loggedIn=${this.loggedIn}
49
- .suppressBlurring=${this.suppressBlurring}
50
- .sortParam=${this.sortParam}
51
- .collectionTitles=${this.collectionTitles}
52
- .mobileBreakpoint=${this.mobileBreakpoint}
53
- .currentWidth=${this.currentWidth}
54
- ></tile-list>
55
- </div>
56
- </focus-trap>
57
- </div>
58
- `;
59
- }
60
-
61
- private get headerTemplate(): TemplateResult | typeof nothing {
62
- // early return if item does't have parent collection
63
- if (this.model?.collections?.length === 0) return nothing;
64
-
65
- let collectionTitle = '';
66
- let collectionIdentifier = '';
67
-
68
- for (const collection of this.model?.collections || []) {
69
- if (
70
- !suppressedCollections[collection] &&
71
- !collection.startsWith('fav-')
72
- ) {
73
- collectionTitle = this.collectionTitles?.get(collection) ?? collection;
74
- collectionIdentifier = collection;
75
- break;
76
- }
77
- }
78
-
79
- // sometimes item does have collections but they are in suppressed or favorite list,
80
- // let's not render that
81
- if (!collectionIdentifier) return nothing;
82
-
83
- return html`
84
- <div id="list-line-header">
85
- <a href="${this.baseNavigationUrl}/details/${collectionIdentifier}">
86
- <img
87
- src="${this.baseImageUrl}/services/img/${collectionIdentifier}"
88
- alt=""
89
- /><span>${collectionTitle}</span>
90
- </a>
91
- </div>
92
- `;
93
- }
94
-
95
- static get styles(): CSSResultGroup {
96
- const hoverPaneHeaderBGColor = css`var(--hoverPaneHeaderBGColor, #edf0ff)`;
97
- const iaLinkColor = css`var(--ia-theme-link-color, #4b64ff)`;
98
- const iaFontFamily = css`var(--ia-theme-base-font-family, "Helvetica Neue", Helvetica, Arial, sans-serif);`;
99
-
100
- return css`
101
- :host {
102
- margin: 0;
103
- border: 0;
104
- padding: 0;
105
- overflow: visible;
106
- color: inherit;
107
- background: none;
108
- visibility: hidden;
109
- opacity: 0;
110
- transform: translateY(8px);
111
- transition:
112
- opacity 0.1s ease-in,
113
- transform 0.1s ease-in;
114
- --image-width: auto;
115
- }
116
-
117
- :host(.visible) {
118
- visibility: visible;
119
- }
120
-
121
- :host(.fade-in) {
122
- opacity: 1;
123
- transform: translateY(0);
124
- }
125
-
126
- @media (prefers-reduced-motion: reduce) {
127
- :host {
128
- transition-duration: 0.001s !important; /* Imperceptibly fast */
129
- }
130
- }
131
-
132
- #container {
133
- width: max-content;
134
- max-width: min(45vw, 600px);
135
- border: 1px solid #ddd;
136
- border-radius: 4px;
137
- box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.8);
138
- background: white;
139
- }
140
-
141
- @media screen and (max-width: 600px) {
142
- #container {
143
- max-width: 80vw;
144
- }
145
- }
146
-
147
- /* main tile-list container */
148
- #hover-tile-list {
149
- padding: 10px;
150
- }
151
-
152
- /* header on hover panel to show collection icon and title */
153
- #list-line-header {
154
- background: ${hoverPaneHeaderBGColor};
155
- }
156
- #list-line-header a {
157
- display: flex;
158
- align-items: center;
159
- column-gap: 5px;
160
- height: 3.4rem;
161
- padding: 0 10px;
162
- border-radius: 4px 4px 0 0;
163
- width: fit-content;
164
- font-size: 1.4rem;
165
- color: ${iaLinkColor};
166
- font-family: ${iaFontFamily};
167
- text-decoration: none;
168
- width: auto;
169
- }
170
- #list-line-header a span {
171
- white-space: nowrap;
172
- overflow: hidden;
173
- text-overflow: ellipsis;
174
- }
175
- #list-line-header a:hover {
176
- text-decoration: underline;
177
- }
178
- #list-line-header a img {
179
- width: 30px;
180
- max-height: 30px;
181
- }
182
- `;
183
- }
184
- }
1
+ import type { SortParam } from '@internetarchive/search-service';
2
+ import {
3
+ css,
4
+ CSSResultGroup,
5
+ html,
6
+ LitElement,
7
+ nothing,
8
+ TemplateResult,
9
+ } from 'lit';
10
+ import { customElement, property } from 'lit/decorators.js';
11
+ import '@a11y/focus-trap';
12
+
13
+ import { suppressedCollections, type TileModel } from '../../models';
14
+ import type { CollectionTitles } from '../../data-source/models';
15
+ import '../list/tile-list';
16
+
17
+ @customElement('tile-hover-pane')
18
+ export class TileHoverPane extends LitElement {
19
+ @property({ type: Object }) model?: TileModel;
20
+
21
+ @property({ type: String }) baseNavigationUrl?: string;
22
+
23
+ @property({ type: String }) baseImageUrl?: string;
24
+
25
+ @property({ type: Boolean }) loggedIn: boolean = false;
26
+
27
+ @property({ type: Boolean }) suppressBlurring: boolean = false;
28
+
29
+ @property({ type: Object }) sortParam?: SortParam;
30
+
31
+ @property({ type: Number }) mobileBreakpoint?: number;
32
+
33
+ @property({ type: Number }) currentWidth?: number;
34
+
35
+ @property({ type: Object })
36
+ collectionTitles?: CollectionTitles;
37
+
38
+ protected render(): TemplateResult {
39
+ return html`
40
+ <div id="container">
41
+ <focus-trap>
42
+ ${this.headerTemplate}
43
+ <div id="hover-tile-list">
44
+ <tile-list
45
+ .model=${this.model}
46
+ .baseNavigationUrl=${this.baseNavigationUrl}
47
+ .baseImageUrl=${this.baseImageUrl}
48
+ .loggedIn=${this.loggedIn}
49
+ .suppressBlurring=${this.suppressBlurring}
50
+ .sortParam=${this.sortParam}
51
+ .collectionTitles=${this.collectionTitles}
52
+ .mobileBreakpoint=${this.mobileBreakpoint}
53
+ .currentWidth=${this.currentWidth}
54
+ ></tile-list>
55
+ </div>
56
+ </focus-trap>
57
+ </div>
58
+ `;
59
+ }
60
+
61
+ private get headerTemplate(): TemplateResult | typeof nothing {
62
+ // early return if item does't have parent collection
63
+ if (this.model?.collections?.length === 0) return nothing;
64
+
65
+ let collectionTitle = '';
66
+ let collectionIdentifier = '';
67
+
68
+ for (const collection of this.model?.collections || []) {
69
+ if (
70
+ !suppressedCollections[collection] &&
71
+ !collection.startsWith('fav-')
72
+ ) {
73
+ collectionTitle = this.collectionTitles?.get(collection) ?? collection;
74
+ collectionIdentifier = collection;
75
+ break;
76
+ }
77
+ }
78
+
79
+ // sometimes item does have collections but they are in suppressed or favorite list,
80
+ // let's not render that
81
+ if (!collectionIdentifier) return nothing;
82
+
83
+ return html`
84
+ <div id="list-line-header">
85
+ <a href="${this.baseNavigationUrl}/details/${collectionIdentifier}">
86
+ <img
87
+ src="${this.baseImageUrl}/services/img/${collectionIdentifier}"
88
+ alt=""
89
+ /><span>${collectionTitle}</span>
90
+ </a>
91
+ </div>
92
+ `;
93
+ }
94
+
95
+ static get styles(): CSSResultGroup {
96
+ const hoverPaneHeaderBGColor = css`var(--hoverPaneHeaderBGColor, #edf0ff)`;
97
+ const iaLinkColor = css`var(--ia-theme-link-color, #4b64ff)`;
98
+ const iaFontFamily = css`var(--ia-theme-base-font-family, "Helvetica Neue", Helvetica, Arial, sans-serif);`;
99
+
100
+ return css`
101
+ :host {
102
+ margin: 0;
103
+ border: 0;
104
+ padding: 0;
105
+ overflow: visible;
106
+ color: inherit;
107
+ background: none;
108
+ visibility: hidden;
109
+ opacity: 0;
110
+ transform: translateY(8px);
111
+ transition:
112
+ opacity 0.1s ease-in,
113
+ transform 0.1s ease-in;
114
+ --image-width: auto;
115
+ }
116
+
117
+ :host(.visible) {
118
+ visibility: visible;
119
+ }
120
+
121
+ :host(.fade-in) {
122
+ opacity: 1;
123
+ transform: translateY(0);
124
+ }
125
+
126
+ @media (prefers-reduced-motion: reduce) {
127
+ :host {
128
+ transition-duration: 0.001s !important; /* Imperceptibly fast */
129
+ }
130
+ }
131
+
132
+ #container {
133
+ width: max-content;
134
+ max-width: min(45vw, 600px);
135
+ border: 1px solid #ddd;
136
+ border-radius: 4px;
137
+ box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.8);
138
+ background: white;
139
+ }
140
+
141
+ @media screen and (max-width: 600px) {
142
+ #container {
143
+ max-width: 80vw;
144
+ }
145
+ }
146
+
147
+ /* main tile-list container */
148
+ #hover-tile-list {
149
+ padding: 10px;
150
+ }
151
+
152
+ /* header on hover panel to show collection icon and title */
153
+ #list-line-header {
154
+ background: ${hoverPaneHeaderBGColor};
155
+ }
156
+ #list-line-header a {
157
+ display: flex;
158
+ align-items: center;
159
+ column-gap: 5px;
160
+ height: 3.4rem;
161
+ padding: 0 10px;
162
+ border-radius: 4px 4px 0 0;
163
+ width: fit-content;
164
+ font-size: 1.4rem;
165
+ color: ${iaLinkColor};
166
+ font-family: ${iaFontFamily};
167
+ text-decoration: none;
168
+ width: auto;
169
+ }
170
+ #list-line-header a span {
171
+ white-space: nowrap;
172
+ overflow: hidden;
173
+ text-overflow: ellipsis;
174
+ }
175
+ #list-line-header a:hover {
176
+ text-decoration: underline;
177
+ }
178
+ #list-line-header a img {
179
+ width: 30px;
180
+ max-height: 30px;
181
+ }
182
+ `;
183
+ }
184
+ }