@internetarchive/ia-topnav 1.3.6 → 1.3.7-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.
Files changed (85) hide show
  1. package/.eslintrc +16 -16
  2. package/LICENSE +661 -661
  3. package/README.md +147 -147
  4. package/index.d.ts +109 -109
  5. package/index.js +3 -3
  6. package/package.json +61 -61
  7. package/src/assets/img/hamburger.js +38 -38
  8. package/src/assets/img/ia-icon.js +33 -33
  9. package/src/assets/img/icon-audio.js +23 -23
  10. package/src/assets/img/icon-close.js +16 -16
  11. package/src/assets/img/icon-donate-unpadded.js +16 -16
  12. package/src/assets/img/icon-donate.js +15 -15
  13. package/src/assets/img/icon-ellipses.js +15 -15
  14. package/src/assets/img/icon-ia-logo.js +22 -22
  15. package/src/assets/img/icon-images.js +15 -15
  16. package/src/assets/img/icon-search.js +15 -15
  17. package/src/assets/img/icon-software.js +15 -15
  18. package/src/assets/img/icon-texts.js +15 -15
  19. package/src/assets/img/icon-upload-unpadded.js +14 -14
  20. package/src/assets/img/icon-upload.js +15 -15
  21. package/src/assets/img/icon-user.js +15 -15
  22. package/src/assets/img/icon-video.js +15 -15
  23. package/src/assets/img/icon-web.js +15 -15
  24. package/src/assets/img/icon.js +18 -18
  25. package/src/assets/img/icons.js +33 -33
  26. package/src/assets/img/wordmark-stacked.js +13 -13
  27. package/src/data/menus.js +646 -646
  28. package/src/desktop-subnav.js +45 -45
  29. package/src/dropdown-menu.js +110 -109
  30. package/src/ia-topnav.js +324 -314
  31. package/src/lib/formatUrl.js +1 -1
  32. package/src/lib/keyboard-navigation.js +128 -0
  33. package/src/lib/location-handler.js +5 -5
  34. package/src/lib/query-handler.js +7 -7
  35. package/src/lib/toSentenceCase.js +8 -8
  36. package/src/login-button.js +79 -79
  37. package/src/media-button.js +113 -113
  38. package/src/media-menu.js +154 -133
  39. package/src/media-slider.js +118 -104
  40. package/src/media-subnav.js +112 -112
  41. package/src/more-slider.js +33 -33
  42. package/src/nav-search.js +111 -117
  43. package/src/primary-nav.js +258 -224
  44. package/src/save-page-form.js +59 -59
  45. package/src/search-menu.js +145 -115
  46. package/src/signed-out-dropdown.js +10 -10
  47. package/src/styles/base.js +48 -48
  48. package/src/styles/desktop-subnav.js +37 -37
  49. package/src/styles/dropdown-menu.js +168 -166
  50. package/src/styles/ia-topnav.js +87 -87
  51. package/src/styles/login-button.js +82 -79
  52. package/src/styles/media-button.js +156 -156
  53. package/src/styles/media-menu.js +66 -70
  54. package/src/styles/media-slider.js +81 -81
  55. package/src/styles/media-subnav.js +156 -156
  56. package/src/styles/more-slider.js +15 -15
  57. package/src/styles/nav-search.js +136 -136
  58. package/src/styles/primary-nav.js +311 -300
  59. package/src/styles/save-page-form.js +54 -54
  60. package/src/styles/search-menu.js +105 -99
  61. package/src/styles/signed-out-dropdown.js +31 -31
  62. package/src/styles/user-menu.js +31 -31
  63. package/src/styles/wayback-search.js +48 -48
  64. package/src/styles/wayback-slider.js +30 -30
  65. package/src/tracked-element.js +29 -27
  66. package/src/user-menu.js +56 -42
  67. package/src/wayback-search.js +18 -18
  68. package/src/wayback-slider.js +87 -87
  69. package/test/assets/img/hamburger.test.js +15 -15
  70. package/test/assets/img/user.test.js +15 -15
  71. package/test/data/menus.test.js +19 -19
  72. package/test/dropdown-menu.test.js +25 -25
  73. package/test/ia-icon.test.js +13 -13
  74. package/test/ia-topnav.test.js +273 -273
  75. package/test/login-button.test.js +15 -15
  76. package/test/media-button.test.js +19 -19
  77. package/test/media-menu.test.js +40 -40
  78. package/test/media-slider.test.js +57 -57
  79. package/test/more-slider.test.js +13 -13
  80. package/test/nav-search.test.js +61 -61
  81. package/test/primary-nav.test.js +82 -82
  82. package/test/save-page-form.test.js +35 -35
  83. package/test/search-menu.test.js +49 -49
  84. package/test/user-menu.test.js +33 -33
  85. package/test/wayback-slider.test.js +80 -80
@@ -1,273 +1,273 @@
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
-
12
- const container = ({
13
- username = '',
14
- screenName = '',
15
- config = {},
16
- localLinks = true,
17
- secondIdentitySlotMode = ''
18
- } = {}) => (
19
- html`<ia-topnav
20
- .screenName=${screenName}
21
- username=${username}
22
- localLinks=${localLinks}
23
- .config=${config}
24
- .secondIdentitySlotMode=${secondIdentitySlotMode}
25
- ></ia-topnav>`
26
- );
27
-
28
- const verifyClosed = (instance) => {
29
- expect(instance.mediaSliderOpen).to.be.false;
30
- expect(instance.selectedMenuOption).to.equal('');
31
- };
32
-
33
- const verifyOpened = (instance, mediatype) => {
34
- expect(instance.mediaSliderOpen).to.be.true;
35
- expect(instance.selectedMenuOption).to.equal(mediatype);
36
- };
37
-
38
- afterEach(() => {
39
- fixtureCleanup();
40
- });
41
-
42
- describe('<ia-topnav>', () => {
43
- it('assigns a value to "search in" from outside event', async () => {
44
- const el = await fixture(container());
45
- const query = 'atari';
46
- const searchMenu = el
47
- .shadowRoot
48
- .querySelector('search-menu');
49
-
50
- searchMenu.searchInChanged({
51
- target: {
52
- value: query
53
- }
54
- });
55
- await el.updateComplete;
56
-
57
- expect(el.searchIn).to.equal(query);
58
- });
59
-
60
- it('dispatches an analyticsClick event when trackClick event fired', async () => {
61
- const el = await fixture(container());
62
- const clickEvent = new MouseEvent('click');
63
-
64
- setTimeout(() => (
65
- el
66
- .shadowRoot
67
- .querySelector('primary-nav')
68
- .shadowRoot
69
- .querySelector('.hamburger')
70
- .dispatchEvent(clickEvent)
71
- ));
72
- const response = await oneEvent(el, 'trackClick');
73
-
74
- expect(response).to.exist;
75
- });
76
-
77
- it('dispatches an analyticsSubmit event when trackSubmit event fired', async () => {
78
- const el = await fixture(container());
79
- const submitEvent = new Event('submit');
80
- const form = el
81
- .shadowRoot
82
- .querySelector('primary-nav')
83
- .shadowRoot
84
- .querySelector('nav-search')
85
- .shadowRoot
86
- .querySelector('form');
87
-
88
- form.addEventListener('submit', e => e.preventDefault());
89
- form.querySelector('[name=query]').value = 'atari';
90
- setTimeout(() => form.dispatchEvent(submitEvent));
91
- const response = await oneEvent(el, 'trackSubmit');
92
-
93
- expect(response).to.exist;
94
- });
95
-
96
- it('closes all menus when close-layer clicked', async () => {
97
- const el = await fixture(container());
98
-
99
- el.openMenu = 'media';
100
- el.selectedMenuOption = 'texts';
101
- el.mediaSliderOpen = true;
102
- await el.updateComplete;
103
- el.closeMenus();
104
- await el.updateComplete;
105
-
106
- expect(el.mediaSliderOpen).to.be.false;
107
- expect(el.openMenu).to.equal('');
108
- expect(el.selectedMenuOption).to.equal('');
109
- });
110
-
111
- it('sets media slider to closed', async () => {
112
- const el = await fixture(container());
113
-
114
- el.mediaSliderOpen = true;
115
- el.selectedMenuOption = 'foo';
116
- el.closeMediaSlider();
117
-
118
- verifyClosed(el);
119
- });
120
-
121
- it('toggles media slider visibility and starts animation', async () => {
122
- const el = await fixture(container());
123
- const mediatype = 'foo';
124
-
125
- el.selectedMenuOption = mediatype;
126
- el.openMediaSlider();
127
-
128
- verifyOpened(el, mediatype);
129
- });
130
-
131
- it('closes media slider if selected menu type is the open menu type', async () => {
132
- const el = await fixture(container());
133
- const mediatype = 'foo';
134
-
135
- el.selectedMenuOption = mediatype;
136
- el.mediaTypeSelected({
137
- detail: {
138
- mediatype
139
- }
140
- });
141
-
142
- verifyClosed(el);
143
- });
144
-
145
- it('opens media slider menu and starts animation', async () => {
146
- const el = await fixture(container());
147
- const mediatype = 'foo';
148
-
149
- el.mediaTypeSelected({
150
- detail: {
151
- mediatype
152
- }
153
- });
154
-
155
- verifyOpened(el, mediatype);
156
- });
157
-
158
- it('closes slider when menu closed', async () => {
159
- const el = await fixture(container());
160
-
161
- el.openMenu = 'media';
162
- el.selectedMenuOption = 'foo';
163
- el.mediaSliderOpen = true;
164
- await el.updateComplete;
165
-
166
- el.menuToggled({ detail: { menuName: '' } });
167
- await el.updateComplete;
168
-
169
- expect(el.selectedMenuOption).to.equal('');
170
- });
171
-
172
- it('toggles search menu tabindex when dropdown open', async () => {
173
- const el = await fixture(container());
174
-
175
- el.openMenu = 'search';
176
- await el.updateComplete;
177
-
178
- expect(el.shadowRoot.querySelector('search-menu').getAttribute('tabindex')).to.equal('');
179
- });
180
-
181
- it('toggles user menu tabindex when dropdown open', async () => {
182
- const el = await fixture(container({ username: 'shaneriley' }));
183
-
184
- el.openMenu = 'user';
185
- await el.updateComplete;
186
-
187
- expect(el.shadowRoot.querySelector('user-menu').getAttribute('tabindex')).to.equal('');
188
- });
189
-
190
- it('toggles signed out menu tabindex when dropdown open', async () => {
191
- const el = await fixture(container());
192
-
193
- el.openMenu = 'login';
194
- await el.updateComplete;
195
-
196
- expect(el.shadowRoot.querySelector('signed-out-dropdown').getAttribute('tabindex')).to.equal('');
197
- });
198
-
199
- it('toggles search menu when search toggle button clicked', async () => {
200
- const el = await fixture(container());
201
- el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.search-trigger').click();
202
- await el.updateComplete;
203
-
204
- expect(el.openMenu).to.equal('search');
205
- });
206
-
207
- it('toggles user menu when search user avatar clicked', async () => {
208
- const el = await fixture(container({
209
- username: 'shaneriley',
210
- screenName: 'shaneriley',
211
- }));
212
-
213
- el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.user-menu').click();
214
- await el.updateComplete;
215
-
216
- expect(el.openMenu).to.equal('user');
217
- });
218
-
219
- it('uses localLinks for archive.org logo link', async () => {
220
- const el = await fixture(container({ localLinks: false }));
221
- const logoLink = el
222
- .shadowRoot
223
- .querySelector('primary-nav')
224
- .shadowRoot
225
- .querySelector('.link-home');
226
- expect(logoLink.getAttribute('href')).to.match(/\/\/archive\.org/);
227
- });
228
-
229
- describe('sets localLinks properly', async () => {
230
- it('uses localLinks to archive.org links on common child components', async () => {
231
- const el = await fixture(container({ localLinks: false }));
232
- const componentSelectors = ['primary-nav', 'media-slider', 'desktop-subnav', 'search-menu'];
233
- componentSelectors.forEach((selector) => {
234
- const component = el.shadowRoot.querySelector(selector);
235
- expect(component.baseHost).to.equal('https://archive.org');
236
- });
237
- });
238
-
239
- it('uses localLinks to archive.org links on the signed out dropdown', async () => {
240
- const el = await fixture(container({ localLinks: false }));
241
- const signedOutDropdown = el.shadowRoot.querySelector('signed-out-dropdown');
242
- expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
243
- });
244
-
245
- it('uses localLinks to archive.org links on the user dropdown', async () => {
246
- const el = await fixture(container({ username: 'foo', localLinks: false }));
247
- const signedOutDropdown = el.shadowRoot.querySelector('user-menu');
248
- expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
249
- });
250
- });
251
-
252
- describe('slot pass throughs', () => {
253
- describe('slot for <primary-nav>', () => {
254
- it('opens a slot with `secondIdentitySlotMode`', async () => {
255
- const el = await fixture(container({
256
- localLinks: false,
257
- username: 'boop',
258
- screenName: 'somesuperlongscreenname',
259
- secondIdentitySlotMode: 'allow'
260
- }));
261
-
262
- const slot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
263
- expect(slot).to.exist;
264
- expect(slot.getAttribute('name')).to.equal('opt-sec-logo');
265
-
266
- el.secondIdentitySlotMode = '';
267
- await elementUpdated(el);
268
- const noSlot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
269
- expect(noSlot).to.not.exist;
270
- });
271
- });
272
- });
273
- });
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
+
12
+ const container = ({
13
+ username = '',
14
+ screenName = '',
15
+ config = {},
16
+ localLinks = true,
17
+ secondIdentitySlotMode = ''
18
+ } = {}) => (
19
+ html`<ia-topnav
20
+ .screenName=${screenName}
21
+ username=${username}
22
+ localLinks=${localLinks}
23
+ .config=${config}
24
+ .secondIdentitySlotMode=${secondIdentitySlotMode}
25
+ ></ia-topnav>`
26
+ );
27
+
28
+ const verifyClosed = (instance) => {
29
+ expect(instance.mediaSliderOpen).to.be.false;
30
+ expect(instance.selectedMenuOption).to.equal('');
31
+ };
32
+
33
+ const verifyOpened = (instance, mediatype) => {
34
+ expect(instance.mediaSliderOpen).to.be.true;
35
+ expect(instance.selectedMenuOption).to.equal(mediatype);
36
+ };
37
+
38
+ afterEach(() => {
39
+ fixtureCleanup();
40
+ });
41
+
42
+ describe('<ia-topnav>', () => {
43
+ it('assigns a value to "search in" from outside event', async () => {
44
+ const el = await fixture(container());
45
+ const query = 'atari';
46
+ const searchMenu = el
47
+ .shadowRoot
48
+ .querySelector('search-menu');
49
+
50
+ searchMenu.searchInChanged({
51
+ target: {
52
+ value: query
53
+ }
54
+ });
55
+ await el.updateComplete;
56
+
57
+ expect(el.searchIn).to.equal(query);
58
+ });
59
+
60
+ it('dispatches an analyticsClick event when trackClick event fired', async () => {
61
+ const el = await fixture(container());
62
+ const clickEvent = new MouseEvent('click');
63
+
64
+ setTimeout(() => (
65
+ el
66
+ .shadowRoot
67
+ .querySelector('primary-nav')
68
+ .shadowRoot
69
+ .querySelector('.hamburger')
70
+ .dispatchEvent(clickEvent)
71
+ ));
72
+ const response = await oneEvent(el, 'trackClick');
73
+
74
+ expect(response).to.exist;
75
+ });
76
+
77
+ it('dispatches an analyticsSubmit event when trackSubmit event fired', async () => {
78
+ const el = await fixture(container());
79
+ const submitEvent = new Event('submit');
80
+ const form = el
81
+ .shadowRoot
82
+ .querySelector('primary-nav')
83
+ .shadowRoot
84
+ .querySelector('nav-search')
85
+ .shadowRoot
86
+ .querySelector('form');
87
+
88
+ form.addEventListener('submit', e => e.preventDefault());
89
+ form.querySelector('[name=query]').value = 'atari';
90
+ setTimeout(() => form.dispatchEvent(submitEvent));
91
+ const response = await oneEvent(el, 'trackSubmit');
92
+
93
+ expect(response).to.exist;
94
+ });
95
+
96
+ it('closes all menus when close-layer clicked', async () => {
97
+ const el = await fixture(container());
98
+
99
+ el.openMenu = 'media';
100
+ el.selectedMenuOption = 'texts';
101
+ el.mediaSliderOpen = true;
102
+ await el.updateComplete;
103
+ el.closeMenus();
104
+ await el.updateComplete;
105
+
106
+ expect(el.mediaSliderOpen).to.be.false;
107
+ expect(el.openMenu).to.equal('');
108
+ expect(el.selectedMenuOption).to.equal('');
109
+ });
110
+
111
+ it('sets media slider to closed', async () => {
112
+ const el = await fixture(container());
113
+
114
+ el.mediaSliderOpen = true;
115
+ el.selectedMenuOption = 'foo';
116
+ el.closeMediaSlider();
117
+
118
+ verifyClosed(el);
119
+ });
120
+
121
+ it('toggles media slider visibility and starts animation', async () => {
122
+ const el = await fixture(container());
123
+ const mediatype = 'foo';
124
+
125
+ el.selectedMenuOption = mediatype;
126
+ el.openMediaSlider();
127
+
128
+ verifyOpened(el, mediatype);
129
+ });
130
+
131
+ it('closes media slider if selected menu type is the open menu type', async () => {
132
+ const el = await fixture(container());
133
+ const mediatype = 'foo';
134
+
135
+ el.selectedMenuOption = mediatype;
136
+ el.mediaTypeSelected({
137
+ detail: {
138
+ mediatype
139
+ }
140
+ });
141
+
142
+ verifyClosed(el);
143
+ });
144
+
145
+ it('opens media slider menu and starts animation', async () => {
146
+ const el = await fixture(container());
147
+ const mediatype = 'foo';
148
+
149
+ el.mediaTypeSelected({
150
+ detail: {
151
+ mediatype
152
+ }
153
+ });
154
+
155
+ verifyOpened(el, mediatype);
156
+ });
157
+
158
+ it('closes slider when menu closed', async () => {
159
+ const el = await fixture(container());
160
+
161
+ el.openMenu = 'media';
162
+ el.selectedMenuOption = 'foo';
163
+ el.mediaSliderOpen = true;
164
+ await el.updateComplete;
165
+
166
+ el.menuToggled({ detail: { menuName: '' } });
167
+ await el.updateComplete;
168
+
169
+ expect(el.selectedMenuOption).to.equal('');
170
+ });
171
+
172
+ it('toggles search menu tabindex when dropdown open', async () => {
173
+ const el = await fixture(container());
174
+
175
+ el.openMenu = 'search';
176
+ await el.updateComplete;
177
+
178
+ expect(el.shadowRoot.querySelector('search-menu').getAttribute('tabindex')).to.equal('');
179
+ });
180
+
181
+ it('toggles user menu tabindex when dropdown open', async () => {
182
+ const el = await fixture(container({ username: 'shaneriley' }));
183
+
184
+ el.openMenu = 'user';
185
+ await el.updateComplete;
186
+
187
+ expect(el.shadowRoot.querySelector('user-menu').getAttribute('tabindex')).to.equal('');
188
+ });
189
+
190
+ it('toggles signed out menu tabindex when dropdown open', async () => {
191
+ const el = await fixture(container());
192
+
193
+ el.openMenu = 'login';
194
+ await el.updateComplete;
195
+
196
+ expect(el.shadowRoot.querySelector('signed-out-dropdown').getAttribute('tabindex')).to.equal('');
197
+ });
198
+
199
+ it('toggles search menu when search toggle button clicked', async () => {
200
+ const el = await fixture(container());
201
+ el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.search-trigger').click();
202
+ await el.updateComplete;
203
+
204
+ expect(el.openMenu).to.equal('search');
205
+ });
206
+
207
+ it('toggles user menu when search user avatar clicked', async () => {
208
+ const el = await fixture(container({
209
+ username: 'shaneriley',
210
+ screenName: 'shaneriley',
211
+ }));
212
+
213
+ el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.user-menu').click();
214
+ await el.updateComplete;
215
+
216
+ expect(el.openMenu).to.equal('user');
217
+ });
218
+
219
+ it('uses localLinks for archive.org logo link', async () => {
220
+ const el = await fixture(container({ localLinks: false }));
221
+ const logoLink = el
222
+ .shadowRoot
223
+ .querySelector('primary-nav')
224
+ .shadowRoot
225
+ .querySelector('.link-home');
226
+ expect(logoLink.getAttribute('href')).to.match(/\/\/archive\.org/);
227
+ });
228
+
229
+ describe('sets localLinks properly', async () => {
230
+ it('uses localLinks to archive.org links on common child components', async () => {
231
+ const el = await fixture(container({ localLinks: false }));
232
+ const componentSelectors = ['primary-nav', 'media-slider', 'desktop-subnav', 'search-menu'];
233
+ componentSelectors.forEach((selector) => {
234
+ const component = el.shadowRoot.querySelector(selector);
235
+ expect(component.baseHost).to.equal('https://archive.org');
236
+ });
237
+ });
238
+
239
+ it('uses localLinks to archive.org links on the signed out dropdown', async () => {
240
+ const el = await fixture(container({ localLinks: false }));
241
+ const signedOutDropdown = el.shadowRoot.querySelector('signed-out-dropdown');
242
+ expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
243
+ });
244
+
245
+ it('uses localLinks to archive.org links on the user dropdown', async () => {
246
+ const el = await fixture(container({ username: 'foo', localLinks: false }));
247
+ const signedOutDropdown = el.shadowRoot.querySelector('user-menu');
248
+ expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
249
+ });
250
+ });
251
+
252
+ describe('slot pass throughs', () => {
253
+ describe('slot for <primary-nav>', () => {
254
+ it('opens a slot with `secondIdentitySlotMode`', async () => {
255
+ const el = await fixture(container({
256
+ localLinks: false,
257
+ username: 'boop',
258
+ screenName: 'somesuperlongscreenname',
259
+ secondIdentitySlotMode: 'allow'
260
+ }));
261
+
262
+ const slot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
263
+ expect(slot).to.exist;
264
+ expect(slot.getAttribute('name')).to.equal('opt-sec-logo');
265
+
266
+ el.secondIdentitySlotMode = '';
267
+ await elementUpdated(el);
268
+ const noSlot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
269
+ expect(noSlot).to.not.exist;
270
+ });
271
+ });
272
+ });
273
+ });
@@ -1,15 +1,15 @@
1
- import { html, fixture, expect } from '@open-wc/testing';
2
- import '../src/login-button';
3
-
4
- const component = html`<login-button></login-button>`;
5
-
6
- describe('<login-button>', () => {
7
- it('toggles active class when avatar clicked', async () => {
8
- const el = await fixture(component);
9
-
10
- el.shadowRoot.querySelector('.dropdown-toggle').click();
11
- await el.updateComplete;
12
-
13
- expect(el.shadowRoot.querySelector('.active')).to.not.be.undefined;
14
- });
15
- });
1
+ import { html, fixture, expect } from '@open-wc/testing';
2
+ import '../src/login-button';
3
+
4
+ const component = html`<login-button></login-button>`;
5
+
6
+ describe('<login-button>', () => {
7
+ it('toggles active class when avatar clicked', async () => {
8
+ const el = await fixture(component);
9
+
10
+ el.shadowRoot.querySelector('.dropdown-toggle').click();
11
+ await el.updateComplete;
12
+
13
+ expect(el.shadowRoot.querySelector('.active')).to.not.be.undefined;
14
+ });
15
+ });
@@ -1,19 +1,19 @@
1
- import {
2
- html,
3
- fixture,
4
- expect,
5
- oneEvent,
6
- } from '@open-wc/testing';
7
-
8
- import '../src/media-button';
9
-
10
- describe('<media-button>', () => {
11
- it('emits an event when button pressed', async () => {
12
- const el = await fixture(html`<media-button></media-button>`);
13
-
14
- setTimeout(() => el.shadowRoot.querySelector('.menu-item').click());
15
- const response = await oneEvent(el, 'mediaTypeSelected');
16
-
17
- expect(response).to.exist;
18
- });
19
- });
1
+ import {
2
+ html,
3
+ fixture,
4
+ expect,
5
+ oneEvent,
6
+ } from '@open-wc/testing';
7
+
8
+ import '../src/media-button';
9
+
10
+ describe('<media-button>', () => {
11
+ it('emits an event when button pressed', async () => {
12
+ const el = await fixture(html`<media-button></media-button>`);
13
+
14
+ setTimeout(() => el.shadowRoot.querySelector('.menu-item').click());
15
+ const response = await oneEvent(el, 'mediaTypeSelected');
16
+
17
+ expect(response).to.exist;
18
+ });
19
+ });