@internetarchive/ia-topnav 2.0.0 → 2.0.1-alpha-webdev8396.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/data/menus.js.map +1 -1
- package/dist/src/dropdown-menu.d.ts +3 -4
- package/dist/src/dropdown-menu.js +6 -13
- package/dist/src/dropdown-menu.js.map +1 -1
- package/dist/src/ia-topnav.d.ts +3 -0
- package/dist/src/ia-topnav.js +79 -69
- package/dist/src/ia-topnav.js.map +1 -1
- package/dist/src/login-button.d.ts +3 -0
- package/dist/src/login-button.js +28 -18
- package/dist/src/login-button.js.map +1 -1
- package/dist/src/models.js.map +1 -1
- package/dist/src/primary-nav.d.ts +4 -0
- package/dist/src/primary-nav.js +109 -90
- package/dist/src/primary-nav.js.map +1 -1
- package/dist/src/signed-out-dropdown.d.ts +1 -1
- package/dist/src/signed-out-dropdown.js +1 -2
- package/dist/src/signed-out-dropdown.js.map +1 -1
- package/dist/src/styles/dropdown-menu.js +1 -0
- package/dist/src/styles/dropdown-menu.js.map +1 -1
- package/dist/src/styles/ia-topnav.js +82 -82
- package/dist/src/styles/ia-topnav.js.map +1 -1
- package/dist/src/styles/primary-nav.js +353 -353
- package/dist/src/styles/primary-nav.js.map +1 -1
- package/dist/src/user-menu.d.ts +1 -2
- package/dist/src/user-menu.js +1 -2
- package/dist/src/user-menu.js.map +1 -1
- package/dist/test/ia-topnav.test.js +9 -9
- package/dist/test/ia-topnav.test.js.map +1 -1
- package/dist/test/primary-nav.test.js +7 -7
- package/dist/test/primary-nav.test.js.map +1 -1
- package/package.json +1 -1
- package/src/data/menus.ts +650 -650
- package/src/dropdown-menu.ts +6 -12
- package/src/ia-topnav.ts +332 -318
- package/src/login-button.ts +89 -78
- package/src/models.ts +58 -58
- package/src/primary-nav.ts +300 -277
- package/src/signed-out-dropdown.ts +1 -2
- package/src/styles/dropdown-menu.ts +1 -0
- package/src/styles/ia-topnav.ts +85 -85
- package/src/styles/primary-nav.ts +356 -356
- package/src/user-menu.ts +3 -4
- package/test/ia-topnav.test.ts +282 -282
- package/test/primary-nav.test.ts +135 -135
- package/dist/src/styles/signed-out-dropdown.d.ts +0 -2
- package/dist/src/styles/signed-out-dropdown.js +0 -31
- package/dist/src/styles/signed-out-dropdown.js.map +0 -1
- package/dist/src/styles/user-menu.d.ts +0 -2
- package/dist/src/styles/user-menu.js +0 -31
- package/dist/src/styles/user-menu.js.map +0 -1
- package/src/styles/signed-out-dropdown.ts +0 -31
- package/src/styles/user-menu.ts +0 -31
package/src/user-menu.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { html } from 'lit';
|
|
2
2
|
import DropdownMenu from './dropdown-menu';
|
|
3
|
-
import userMenuCSS from './styles/user-menu';
|
|
4
3
|
import dropdownStyles from './styles/dropdown-menu';
|
|
5
4
|
import { customElement, property } from 'lit/decorators.js';
|
|
6
5
|
|
|
@@ -9,8 +8,8 @@ export default class UserMenu extends DropdownMenu {
|
|
|
9
8
|
@property({ type: String }) username = '';
|
|
10
9
|
@property({ type: String }) screenName = '';
|
|
11
10
|
|
|
12
|
-
static get styles()
|
|
13
|
-
return
|
|
11
|
+
static get styles() {
|
|
12
|
+
return dropdownStyles;
|
|
14
13
|
}
|
|
15
14
|
|
|
16
15
|
render() {
|
package/test/ia-topnav.test.ts
CHANGED
|
@@ -1,282 +1,282 @@
|
|
|
1
|
-
import {
|
|
2
|
-
html,
|
|
3
|
-
fixture,
|
|
4
|
-
expect,
|
|
5
|
-
oneEvent,
|
|
6
|
-
fixtureCleanup,
|
|
7
|
-
elementUpdated,
|
|
8
|
-
} from '@open-wc/testing';
|
|
9
|
-
|
|
10
|
-
import '../src/ia-topnav';
|
|
11
|
-
import { IATopNav } from '../src/ia-topnav';
|
|
12
|
-
import { SignedOutDropdown } from '../src/signed-out-dropdown';
|
|
13
|
-
import UserMenu from '../src/user-menu';
|
|
14
|
-
|
|
15
|
-
const verifyClosed = (instance: IATopNav) => {
|
|
16
|
-
expect(instance.mediaSliderOpen).to.be.false;
|
|
17
|
-
expect(instance.selectedMenuOption).to.equal('');
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
const verifyOpened = (instance: IATopNav, mediatype: string) => {
|
|
21
|
-
expect(instance.mediaSliderOpen).to.be.true;
|
|
22
|
-
expect(instance.selectedMenuOption).to.equal(mediatype);
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
afterEach(() => {
|
|
26
|
-
fixtureCleanup();
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
describe('<ia-topnav>', () => {
|
|
30
|
-
it('dispatches an analyticsClick event when trackClick event fired', async () => {
|
|
31
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
32
|
-
const clickEvent = new MouseEvent('click');
|
|
33
|
-
|
|
34
|
-
setTimeout(() =>
|
|
35
|
-
el.shadowRoot
|
|
36
|
-
?.querySelector('primary-nav')
|
|
37
|
-
?.shadowRoot?.querySelector('.hamburger')
|
|
38
|
-
?.dispatchEvent(clickEvent),
|
|
39
|
-
);
|
|
40
|
-
const response = await oneEvent(el, 'trackClick');
|
|
41
|
-
|
|
42
|
-
expect(response).to.exist;
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('closes all menus when close-layer clicked', async () => {
|
|
46
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
47
|
-
|
|
48
|
-
el.openMenu = 'media';
|
|
49
|
-
el.selectedMenuOption = 'texts';
|
|
50
|
-
el.mediaSliderOpen = true;
|
|
51
|
-
await el.updateComplete;
|
|
52
|
-
el.closeMenus();
|
|
53
|
-
await el.updateComplete;
|
|
54
|
-
|
|
55
|
-
expect(el.mediaSliderOpen).to.be.false;
|
|
56
|
-
expect(el.openMenu).to.equal('');
|
|
57
|
-
expect(el.selectedMenuOption).to.equal('');
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it('sets media slider to closed', async () => {
|
|
61
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
62
|
-
|
|
63
|
-
el.mediaSliderOpen = true;
|
|
64
|
-
el.selectedMenuOption = 'foo';
|
|
65
|
-
el.closeMediaSlider();
|
|
66
|
-
|
|
67
|
-
verifyClosed(el);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('toggles media slider visibility and starts animation', async () => {
|
|
71
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
72
|
-
const mediatype = 'foo';
|
|
73
|
-
|
|
74
|
-
el.selectedMenuOption = mediatype;
|
|
75
|
-
el.openMediaSlider();
|
|
76
|
-
|
|
77
|
-
verifyOpened(el, mediatype);
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it('closes media slider if selected menu type is the open menu type', async () => {
|
|
81
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
82
|
-
const mediatype = 'foo';
|
|
83
|
-
|
|
84
|
-
el.selectedMenuOption = mediatype;
|
|
85
|
-
|
|
86
|
-
const event = new CustomEvent('mediaTypeSelected', {
|
|
87
|
-
detail: {
|
|
88
|
-
mediatype,
|
|
89
|
-
},
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
el.mediaTypeSelected(event);
|
|
93
|
-
|
|
94
|
-
verifyClosed(el);
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
it('opens media slider menu and starts animation', async () => {
|
|
98
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
99
|
-
const mediatype = 'foo';
|
|
100
|
-
|
|
101
|
-
const event = new CustomEvent('mediaTypeSelected', {
|
|
102
|
-
detail: {
|
|
103
|
-
mediatype,
|
|
104
|
-
},
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
el.mediaTypeSelected(event);
|
|
108
|
-
|
|
109
|
-
verifyOpened(el, mediatype);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it('closes slider when menu closed', async () => {
|
|
113
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
114
|
-
|
|
115
|
-
el.openMenu = 'media';
|
|
116
|
-
el.selectedMenuOption = 'foo';
|
|
117
|
-
el.mediaSliderOpen = true;
|
|
118
|
-
await el.updateComplete;
|
|
119
|
-
|
|
120
|
-
const event = new CustomEvent('menuToggled', {
|
|
121
|
-
detail: {
|
|
122
|
-
menuName: '',
|
|
123
|
-
},
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
el.menuToggled(event);
|
|
127
|
-
await el.updateComplete;
|
|
128
|
-
|
|
129
|
-
expect(el.selectedMenuOption).to.equal('');
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
it('toggles user menu tabindex when dropdown open', async () => {
|
|
133
|
-
const el = await fixture<IATopNav>(
|
|
134
|
-
html` <ia-topnav username="shaneriley" ?localLinks=${false}></ia-topnav>`,
|
|
135
|
-
);
|
|
136
|
-
|
|
137
|
-
el.openMenu = 'user';
|
|
138
|
-
await el.updateComplete;
|
|
139
|
-
|
|
140
|
-
expect(
|
|
141
|
-
el.shadowRoot?.querySelector('user-menu')?.getAttribute('tabindex'),
|
|
142
|
-
).to.equal('');
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
it('toggles signed out menu tabindex when dropdown open', async () => {
|
|
146
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
147
|
-
|
|
148
|
-
el.openMenu = 'login';
|
|
149
|
-
await el.updateComplete;
|
|
150
|
-
|
|
151
|
-
expect(
|
|
152
|
-
el.shadowRoot
|
|
153
|
-
?.querySelector('signed-out-dropdown')
|
|
154
|
-
?.getAttribute('tabindex'),
|
|
155
|
-
).to.equal('');
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
it('toggles search menu when search toggle button clicked', async () => {
|
|
159
|
-
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
160
|
-
(
|
|
161
|
-
el.shadowRoot
|
|
162
|
-
?.querySelector('primary-nav')
|
|
163
|
-
?.shadowRoot?.querySelector('.search-trigger') as HTMLButtonElement
|
|
164
|
-
).click();
|
|
165
|
-
await el.updateComplete;
|
|
166
|
-
|
|
167
|
-
expect(el.openMenu).to.equal('search');
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
it('toggles user menu when search user avatar clicked', async () => {
|
|
171
|
-
const el = await fixture<IATopNav>(
|
|
172
|
-
html` <ia-topnav
|
|
173
|
-
username="shaneriley"
|
|
174
|
-
screenName="shaneriley"
|
|
175
|
-
?localLinks=${false}
|
|
176
|
-
></ia-topnav>`,
|
|
177
|
-
);
|
|
178
|
-
|
|
179
|
-
(
|
|
180
|
-
el.shadowRoot
|
|
181
|
-
?.querySelector('primary-nav')
|
|
182
|
-
?.shadowRoot?.querySelector('.user-menu') as HTMLButtonElement
|
|
183
|
-
).click();
|
|
184
|
-
await el.updateComplete;
|
|
185
|
-
|
|
186
|
-
expect(el.openMenu).to.equal('user');
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
it('uses localLinks for archive.org logo link', async () => {
|
|
190
|
-
const el = await fixture<IATopNav>(
|
|
191
|
-
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
192
|
-
);
|
|
193
|
-
const logoLink = el.shadowRoot
|
|
194
|
-
?.querySelector('primary-nav')
|
|
195
|
-
?.shadowRoot?.querySelector('.link-home');
|
|
196
|
-
expect(logoLink?.getAttribute('href')).to.match(/\/\/archive\.org/);
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
describe('sets localLinks properly', async () => {
|
|
200
|
-
it('uses localLinks to archive.org links on common child components', async () => {
|
|
201
|
-
const el = await fixture<IATopNav>(
|
|
202
|
-
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
203
|
-
);
|
|
204
|
-
const componentSelectors = [
|
|
205
|
-
'primary-nav',
|
|
206
|
-
'media-slider',
|
|
207
|
-
'desktop-subnav',
|
|
208
|
-
];
|
|
209
|
-
componentSelectors.forEach((selector) => {
|
|
210
|
-
const component = el.shadowRoot?.querySelector(selector) as unknown as {
|
|
211
|
-
baseHost: string;
|
|
212
|
-
};
|
|
213
|
-
expect(component?.baseHost).to.equal('https://archive.org');
|
|
214
|
-
});
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
it('uses localLinks to archive.org links on the signed out dropdown', async () => {
|
|
218
|
-
const el = await fixture<IATopNav>(
|
|
219
|
-
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
220
|
-
);
|
|
221
|
-
const signedOutDropdown = el.shadowRoot?.querySelector(
|
|
222
|
-
'signed-out-dropdown',
|
|
223
|
-
) as SignedOutDropdown;
|
|
224
|
-
expect(signedOutDropdown?.baseHost).to.equal('https://archive.org');
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
it('uses localLinks to archive.org links on the user dropdown', async () => {
|
|
228
|
-
const el = await fixture<IATopNav>(
|
|
229
|
-
html` <ia-topnav username="foopey" ?localLinks=${false}></ia-topnav>`,
|
|
230
|
-
);
|
|
231
|
-
const signedOutDropdown = el.shadowRoot?.querySelector(
|
|
232
|
-
'user-menu',
|
|
233
|
-
) as UserMenu;
|
|
234
|
-
expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
|
|
235
|
-
});
|
|
236
|
-
});
|
|
237
|
-
|
|
238
|
-
describe('search slot', () => {
|
|
239
|
-
it('forwards search slot to primary-nav', async () => {
|
|
240
|
-
const el = await fixture<IATopNav>(html`<ia-topnav></ia-topnav>`);
|
|
241
|
-
await el.updateComplete;
|
|
242
|
-
|
|
243
|
-
const primaryNav = el.shadowRoot?.querySelector('primary-nav');
|
|
244
|
-
const slot = primaryNav?.querySelector('slot[name="search"]');
|
|
245
|
-
expect(slot).to.exist;
|
|
246
|
-
});
|
|
247
|
-
|
|
248
|
-
it('does not render search-menu', async () => {
|
|
249
|
-
const el = await fixture<IATopNav>(html`<ia-topnav></ia-topnav>`);
|
|
250
|
-
await el.updateComplete;
|
|
251
|
-
|
|
252
|
-
expect(el.shadowRoot?.querySelector('search-menu')).to.not.exist;
|
|
253
|
-
});
|
|
254
|
-
});
|
|
255
|
-
|
|
256
|
-
describe('slot pass throughs', () => {
|
|
257
|
-
describe('slot for <primary-nav>', () => {
|
|
258
|
-
it('opens a slot with `secondIdentitySlotMode`', async () => {
|
|
259
|
-
const el = await fixture<IATopNav>(
|
|
260
|
-
html`<ia-topnav
|
|
261
|
-
?localLinks=${false}
|
|
262
|
-
username="boop"
|
|
263
|
-
screenName="somesuperlongscreenname"
|
|
264
|
-
secondIdentitySlotMode="allow"
|
|
265
|
-
></ia-topnav>`,
|
|
266
|
-
);
|
|
267
|
-
|
|
268
|
-
const slot = el.shadowRoot
|
|
269
|
-
?.querySelector('primary-nav')
|
|
270
|
-
?.querySelector('slot[name="opt-sec-logo"]');
|
|
271
|
-
expect(slot).to.exist;
|
|
272
|
-
|
|
273
|
-
el.secondIdentitySlotMode = '';
|
|
274
|
-
await elementUpdated(el);
|
|
275
|
-
const noSlot = el.shadowRoot
|
|
276
|
-
?.querySelector('primary-nav')
|
|
277
|
-
?.querySelector('slot[name="opt-sec-logo"]');
|
|
278
|
-
expect(noSlot).to.not.exist;
|
|
279
|
-
});
|
|
280
|
-
});
|
|
281
|
-
});
|
|
282
|
-
});
|
|
1
|
+
import {
|
|
2
|
+
html,
|
|
3
|
+
fixture,
|
|
4
|
+
expect,
|
|
5
|
+
oneEvent,
|
|
6
|
+
fixtureCleanup,
|
|
7
|
+
elementUpdated,
|
|
8
|
+
} from '@open-wc/testing';
|
|
9
|
+
|
|
10
|
+
import '../src/ia-topnav';
|
|
11
|
+
import { IATopNav } from '../src/ia-topnav';
|
|
12
|
+
import { SignedOutDropdown } from '../src/signed-out-dropdown';
|
|
13
|
+
import UserMenu from '../src/user-menu';
|
|
14
|
+
|
|
15
|
+
const verifyClosed = (instance: IATopNav) => {
|
|
16
|
+
expect(instance.mediaSliderOpen).to.be.false;
|
|
17
|
+
expect(instance.selectedMenuOption).to.equal('');
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
const verifyOpened = (instance: IATopNav, mediatype: string) => {
|
|
21
|
+
expect(instance.mediaSliderOpen).to.be.true;
|
|
22
|
+
expect(instance.selectedMenuOption).to.equal(mediatype);
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
afterEach(() => {
|
|
26
|
+
fixtureCleanup();
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
describe('<ia-topnav>', () => {
|
|
30
|
+
it('dispatches an analyticsClick event when trackClick event fired', async () => {
|
|
31
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
32
|
+
const clickEvent = new MouseEvent('click');
|
|
33
|
+
|
|
34
|
+
setTimeout(() =>
|
|
35
|
+
el.shadowRoot
|
|
36
|
+
?.querySelector('primary-nav')
|
|
37
|
+
?.shadowRoot?.querySelector('.hamburger')
|
|
38
|
+
?.dispatchEvent(clickEvent),
|
|
39
|
+
);
|
|
40
|
+
const response = await oneEvent(el, 'trackClick');
|
|
41
|
+
|
|
42
|
+
expect(response).to.exist;
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it('closes all menus when close-layer clicked', async () => {
|
|
46
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
47
|
+
|
|
48
|
+
el.openMenu = 'media';
|
|
49
|
+
el.selectedMenuOption = 'texts';
|
|
50
|
+
el.mediaSliderOpen = true;
|
|
51
|
+
await el.updateComplete;
|
|
52
|
+
el.closeMenus();
|
|
53
|
+
await el.updateComplete;
|
|
54
|
+
|
|
55
|
+
expect(el.mediaSliderOpen).to.be.false;
|
|
56
|
+
expect(el.openMenu).to.equal('');
|
|
57
|
+
expect(el.selectedMenuOption).to.equal('');
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('sets media slider to closed', async () => {
|
|
61
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
62
|
+
|
|
63
|
+
el.mediaSliderOpen = true;
|
|
64
|
+
el.selectedMenuOption = 'foo';
|
|
65
|
+
el.closeMediaSlider();
|
|
66
|
+
|
|
67
|
+
verifyClosed(el);
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('toggles media slider visibility and starts animation', async () => {
|
|
71
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
72
|
+
const mediatype = 'foo';
|
|
73
|
+
|
|
74
|
+
el.selectedMenuOption = mediatype;
|
|
75
|
+
el.openMediaSlider();
|
|
76
|
+
|
|
77
|
+
verifyOpened(el, mediatype);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it('closes media slider if selected menu type is the open menu type', async () => {
|
|
81
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
82
|
+
const mediatype = 'foo';
|
|
83
|
+
|
|
84
|
+
el.selectedMenuOption = mediatype;
|
|
85
|
+
|
|
86
|
+
const event = new CustomEvent('mediaTypeSelected', {
|
|
87
|
+
detail: {
|
|
88
|
+
mediatype,
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
el.mediaTypeSelected(event);
|
|
93
|
+
|
|
94
|
+
verifyClosed(el);
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
it('opens media slider menu and starts animation', async () => {
|
|
98
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
99
|
+
const mediatype = 'foo';
|
|
100
|
+
|
|
101
|
+
const event = new CustomEvent('mediaTypeSelected', {
|
|
102
|
+
detail: {
|
|
103
|
+
mediatype,
|
|
104
|
+
},
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
el.mediaTypeSelected(event);
|
|
108
|
+
|
|
109
|
+
verifyOpened(el, mediatype);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it('closes slider when menu closed', async () => {
|
|
113
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
114
|
+
|
|
115
|
+
el.openMenu = 'media';
|
|
116
|
+
el.selectedMenuOption = 'foo';
|
|
117
|
+
el.mediaSliderOpen = true;
|
|
118
|
+
await el.updateComplete;
|
|
119
|
+
|
|
120
|
+
const event = new CustomEvent('menuToggled', {
|
|
121
|
+
detail: {
|
|
122
|
+
menuName: '',
|
|
123
|
+
},
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
el.menuToggled(event);
|
|
127
|
+
await el.updateComplete;
|
|
128
|
+
|
|
129
|
+
expect(el.selectedMenuOption).to.equal('');
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
it('toggles user menu tabindex when dropdown open', async () => {
|
|
133
|
+
const el = await fixture<IATopNav>(
|
|
134
|
+
html` <ia-topnav username="shaneriley" ?localLinks=${false}></ia-topnav>`,
|
|
135
|
+
);
|
|
136
|
+
|
|
137
|
+
el.openMenu = 'user';
|
|
138
|
+
await el.updateComplete;
|
|
139
|
+
|
|
140
|
+
expect(
|
|
141
|
+
el.shadowRoot?.querySelector('user-menu')?.getAttribute('tabindex'),
|
|
142
|
+
).to.equal('');
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
it('toggles signed out menu tabindex when dropdown open', async () => {
|
|
146
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
147
|
+
|
|
148
|
+
el.openMenu = 'login';
|
|
149
|
+
await el.updateComplete;
|
|
150
|
+
|
|
151
|
+
expect(
|
|
152
|
+
el.shadowRoot
|
|
153
|
+
?.querySelector('signed-out-dropdown')
|
|
154
|
+
?.getAttribute('tabindex'),
|
|
155
|
+
).to.equal('');
|
|
156
|
+
});
|
|
157
|
+
|
|
158
|
+
it('toggles search menu when search toggle button clicked', async () => {
|
|
159
|
+
const el = await fixture<IATopNav>(html` <ia-topnav></ia-topnav>`);
|
|
160
|
+
(
|
|
161
|
+
el.shadowRoot
|
|
162
|
+
?.querySelector('primary-nav')
|
|
163
|
+
?.shadowRoot?.querySelector('.search-trigger') as HTMLButtonElement
|
|
164
|
+
).click();
|
|
165
|
+
await el.updateComplete;
|
|
166
|
+
|
|
167
|
+
expect(el.openMenu).to.equal('search');
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('toggles user menu when search user avatar clicked', async () => {
|
|
171
|
+
const el = await fixture<IATopNav>(
|
|
172
|
+
html` <ia-topnav
|
|
173
|
+
username="shaneriley"
|
|
174
|
+
screenName="shaneriley"
|
|
175
|
+
?localLinks=${false}
|
|
176
|
+
></ia-topnav>`,
|
|
177
|
+
);
|
|
178
|
+
|
|
179
|
+
(
|
|
180
|
+
el.shadowRoot
|
|
181
|
+
?.querySelector('primary-nav')
|
|
182
|
+
?.shadowRoot?.querySelector('.user-menu') as HTMLButtonElement
|
|
183
|
+
).click();
|
|
184
|
+
await el.updateComplete;
|
|
185
|
+
|
|
186
|
+
expect(el.openMenu).to.equal('user');
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
it('uses localLinks for archive.org logo link', async () => {
|
|
190
|
+
const el = await fixture<IATopNav>(
|
|
191
|
+
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
192
|
+
);
|
|
193
|
+
const logoLink = el.shadowRoot
|
|
194
|
+
?.querySelector('primary-nav')
|
|
195
|
+
?.shadowRoot?.querySelector('.link-home');
|
|
196
|
+
expect(logoLink?.getAttribute('href')).to.match(/\/\/archive\.org/);
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
describe('sets localLinks properly', async () => {
|
|
200
|
+
it('uses localLinks to archive.org links on common child components', async () => {
|
|
201
|
+
const el = await fixture<IATopNav>(
|
|
202
|
+
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
203
|
+
);
|
|
204
|
+
const componentSelectors = [
|
|
205
|
+
'primary-nav',
|
|
206
|
+
'media-slider',
|
|
207
|
+
'desktop-subnav',
|
|
208
|
+
];
|
|
209
|
+
componentSelectors.forEach((selector) => {
|
|
210
|
+
const component = el.shadowRoot?.querySelector(selector) as unknown as {
|
|
211
|
+
baseHost: string;
|
|
212
|
+
};
|
|
213
|
+
expect(component?.baseHost).to.equal('https://archive.org');
|
|
214
|
+
});
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
it('uses localLinks to archive.org links on the signed out dropdown', async () => {
|
|
218
|
+
const el = await fixture<IATopNav>(
|
|
219
|
+
html` <ia-topnav ?localLinks=${false}></ia-topnav>`,
|
|
220
|
+
);
|
|
221
|
+
const signedOutDropdown = el.shadowRoot?.querySelector(
|
|
222
|
+
'signed-out-dropdown',
|
|
223
|
+
) as SignedOutDropdown;
|
|
224
|
+
expect(signedOutDropdown?.baseHost).to.equal('https://archive.org');
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
it('uses localLinks to archive.org links on the user dropdown', async () => {
|
|
228
|
+
const el = await fixture<IATopNav>(
|
|
229
|
+
html` <ia-topnav username="foopey" ?localLinks=${false}></ia-topnav>`,
|
|
230
|
+
);
|
|
231
|
+
const signedOutDropdown = el.shadowRoot?.querySelector(
|
|
232
|
+
'user-menu',
|
|
233
|
+
) as UserMenu;
|
|
234
|
+
expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
describe('search slot', () => {
|
|
239
|
+
it('forwards search slot to primary-nav', async () => {
|
|
240
|
+
const el = await fixture<IATopNav>(html`<ia-topnav></ia-topnav>`);
|
|
241
|
+
await el.updateComplete;
|
|
242
|
+
|
|
243
|
+
const primaryNav = el.shadowRoot?.querySelector('primary-nav');
|
|
244
|
+
const slot = primaryNav?.querySelector('slot[name="search"]');
|
|
245
|
+
expect(slot).to.exist;
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
it('does not render search-menu', async () => {
|
|
249
|
+
const el = await fixture<IATopNav>(html`<ia-topnav></ia-topnav>`);
|
|
250
|
+
await el.updateComplete;
|
|
251
|
+
|
|
252
|
+
expect(el.shadowRoot?.querySelector('search-menu')).to.not.exist;
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
describe('slot pass throughs', () => {
|
|
257
|
+
describe('slot for <primary-nav>', () => {
|
|
258
|
+
it('opens a slot with `secondIdentitySlotMode`', async () => {
|
|
259
|
+
const el = await fixture<IATopNav>(
|
|
260
|
+
html`<ia-topnav
|
|
261
|
+
?localLinks=${false}
|
|
262
|
+
username="boop"
|
|
263
|
+
screenName="somesuperlongscreenname"
|
|
264
|
+
secondIdentitySlotMode="allow"
|
|
265
|
+
></ia-topnav>`,
|
|
266
|
+
);
|
|
267
|
+
|
|
268
|
+
const slot = el.shadowRoot
|
|
269
|
+
?.querySelector('primary-nav')
|
|
270
|
+
?.querySelector('slot[name="opt-sec-logo"]');
|
|
271
|
+
expect(slot).to.exist;
|
|
272
|
+
|
|
273
|
+
el.secondIdentitySlotMode = '';
|
|
274
|
+
await elementUpdated(el);
|
|
275
|
+
const noSlot = el.shadowRoot
|
|
276
|
+
?.querySelector('primary-nav')
|
|
277
|
+
?.querySelector('slot[name="opt-sec-logo"]');
|
|
278
|
+
expect(noSlot).to.not.exist;
|
|
279
|
+
});
|
|
280
|
+
});
|
|
281
|
+
});
|
|
282
|
+
});
|