@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.
Files changed (52) hide show
  1. package/dist/src/data/menus.js.map +1 -1
  2. package/dist/src/dropdown-menu.d.ts +3 -4
  3. package/dist/src/dropdown-menu.js +6 -13
  4. package/dist/src/dropdown-menu.js.map +1 -1
  5. package/dist/src/ia-topnav.d.ts +3 -0
  6. package/dist/src/ia-topnav.js +79 -69
  7. package/dist/src/ia-topnav.js.map +1 -1
  8. package/dist/src/login-button.d.ts +3 -0
  9. package/dist/src/login-button.js +28 -18
  10. package/dist/src/login-button.js.map +1 -1
  11. package/dist/src/models.js.map +1 -1
  12. package/dist/src/primary-nav.d.ts +4 -0
  13. package/dist/src/primary-nav.js +109 -90
  14. package/dist/src/primary-nav.js.map +1 -1
  15. package/dist/src/signed-out-dropdown.d.ts +1 -1
  16. package/dist/src/signed-out-dropdown.js +1 -2
  17. package/dist/src/signed-out-dropdown.js.map +1 -1
  18. package/dist/src/styles/dropdown-menu.js +1 -0
  19. package/dist/src/styles/dropdown-menu.js.map +1 -1
  20. package/dist/src/styles/ia-topnav.js +82 -82
  21. package/dist/src/styles/ia-topnav.js.map +1 -1
  22. package/dist/src/styles/primary-nav.js +353 -353
  23. package/dist/src/styles/primary-nav.js.map +1 -1
  24. package/dist/src/user-menu.d.ts +1 -2
  25. package/dist/src/user-menu.js +1 -2
  26. package/dist/src/user-menu.js.map +1 -1
  27. package/dist/test/ia-topnav.test.js +9 -9
  28. package/dist/test/ia-topnav.test.js.map +1 -1
  29. package/dist/test/primary-nav.test.js +7 -7
  30. package/dist/test/primary-nav.test.js.map +1 -1
  31. package/package.json +1 -1
  32. package/src/data/menus.ts +650 -650
  33. package/src/dropdown-menu.ts +6 -12
  34. package/src/ia-topnav.ts +332 -318
  35. package/src/login-button.ts +89 -78
  36. package/src/models.ts +58 -58
  37. package/src/primary-nav.ts +300 -277
  38. package/src/signed-out-dropdown.ts +1 -2
  39. package/src/styles/dropdown-menu.ts +1 -0
  40. package/src/styles/ia-topnav.ts +85 -85
  41. package/src/styles/primary-nav.ts +356 -356
  42. package/src/user-menu.ts +3 -4
  43. package/test/ia-topnav.test.ts +282 -282
  44. package/test/primary-nav.test.ts +135 -135
  45. package/dist/src/styles/signed-out-dropdown.d.ts +0 -2
  46. package/dist/src/styles/signed-out-dropdown.js +0 -31
  47. package/dist/src/styles/signed-out-dropdown.js.map +0 -1
  48. package/dist/src/styles/user-menu.d.ts +0 -2
  49. package/dist/src/styles/user-menu.js +0 -31
  50. package/dist/src/styles/user-menu.js.map +0 -1
  51. package/src/styles/signed-out-dropdown.ts +0 -31
  52. package/src/styles/user-menu.ts +0 -31
@@ -1,135 +1,135 @@
1
- import {
2
- html,
3
- fixture,
4
- expect,
5
- fixtureCleanup,
6
- elementUpdated,
7
- } from '@open-wc/testing';
8
-
9
- import '../src/primary-nav';
10
- import { IATopNavConfig, IATopNavSecondIdentitySlotMode } from '../src/models';
11
- import { PrimaryNav } from '../src/primary-nav';
12
-
13
- const component = ({
14
- baseHost = 'archive.org',
15
- username = '',
16
- screenName = '',
17
- hideSearch = false,
18
- config = {},
19
- secondIdentitySlotMode = 'allow',
20
- }: {
21
- baseHost?: string;
22
- username?: string;
23
- screenName?: string;
24
- hideSearch?: boolean;
25
- config?: IATopNavConfig;
26
- secondIdentitySlotMode?: IATopNavSecondIdentitySlotMode;
27
- }) =>
28
- html` <primary-nav
29
- .baseHost=${baseHost}
30
- .username=${username}
31
- .screenName=${screenName}
32
- ?hideSearch=${hideSearch}
33
- .config=${config}
34
- .secondIdentitySlotMode=${secondIdentitySlotMode}
35
- ></primary-nav>`;
36
-
37
- afterEach(() => {
38
- fixtureCleanup();
39
- });
40
-
41
- describe('<primary-nav>', () => {
42
- it('renders the login link when no username present', async () => {
43
- const el = await fixture<PrimaryNav>(
44
- component({
45
- baseHost: 'archive.org',
46
- username: '',
47
- }),
48
- );
49
-
50
- expect(el.shadowRoot?.querySelector('login-button')).to.not.be.undefined;
51
- });
52
-
53
- it('does not render search trigger or search slot if hideSearch true', async () => {
54
- const el = await fixture<PrimaryNav>(
55
- component({
56
- baseHost: 'archive.org',
57
- username: 'shaneriley',
58
- screenName: 'shaneriley',
59
- hideSearch: true,
60
- }),
61
- );
62
-
63
- expect(el.shadowRoot?.querySelector('.search-trigger')).to.equal(null);
64
- expect(el.shadowRoot?.querySelector('.search-container')).to.not.exist;
65
- });
66
-
67
- it('renders search slot container', async () => {
68
- const el = await fixture<PrimaryNav>(
69
- component({
70
- baseHost: 'archive.org',
71
- username: 'testuser',
72
- screenName: 'testuser',
73
- }),
74
- );
75
-
76
- expect(el.shadowRoot?.querySelector('.search-container')).to.exist;
77
-
78
- const slot = el.shadowRoot?.querySelector<HTMLSlotElement>(
79
- 'slot[name="search"]',
80
- );
81
- expect(slot).to.exist;
82
- });
83
-
84
- it('renders search trigger button for mobile toggle', async () => {
85
- const el = await fixture<PrimaryNav>(
86
- component({
87
- baseHost: 'archive.org',
88
- username: 'testuser',
89
- screenName: 'testuser',
90
- }),
91
- );
92
-
93
- expect(el.shadowRoot?.querySelector('.search-trigger')).to.exist;
94
- });
95
-
96
- it('does not render nav-search', async () => {
97
- const el = await fixture<PrimaryNav>(
98
- component({
99
- baseHost: 'archive.org',
100
- username: 'testuser',
101
- screenName: 'testuser',
102
- }),
103
- );
104
-
105
- expect(el.shadowRoot?.querySelector('nav-search')).to.not.exist;
106
- });
107
-
108
- it('opens a slot with `secondIdentitySlotMode`', async () => {
109
- const el = await fixture<PrimaryNav>(
110
- component({
111
- baseHost: 'archive.org',
112
- username: 'boop',
113
- screenName: 'somesuperlongscreenname',
114
- secondIdentitySlotMode: 'allow',
115
- }),
116
- );
117
-
118
- const brandingBlock = el.shadowRoot?.querySelector('div.branding');
119
- expect(brandingBlock?.getAttribute('class')).to.contain(
120
- 'branding second-logo',
121
- );
122
-
123
- const slot = brandingBlock?.querySelector('slot');
124
- expect(slot).to.exist;
125
- expect(slot?.getAttribute('name')).to.equal('opt-sec-logo');
126
-
127
- el.secondIdentitySlotMode = '';
128
- await elementUpdated(el);
129
- const noSlotBrandingBlock = el.shadowRoot?.querySelector('div.branding');
130
- expect(noSlotBrandingBlock?.getAttribute('class')).to.contain('branding');
131
-
132
- const noSlot = noSlotBrandingBlock?.querySelector('slot');
133
- expect(noSlot).to.not.exist;
134
- });
135
- });
1
+ import {
2
+ html,
3
+ fixture,
4
+ expect,
5
+ fixtureCleanup,
6
+ elementUpdated,
7
+ } from '@open-wc/testing';
8
+
9
+ import '../src/primary-nav';
10
+ import { IATopNavConfig, IATopNavSecondIdentitySlotMode } from '../src/models';
11
+ import { PrimaryNav } from '../src/primary-nav';
12
+
13
+ const component = ({
14
+ baseHost = 'archive.org',
15
+ username = '',
16
+ screenName = '',
17
+ hideSearch = false,
18
+ config = {},
19
+ secondIdentitySlotMode = 'allow',
20
+ }: {
21
+ baseHost?: string;
22
+ username?: string;
23
+ screenName?: string;
24
+ hideSearch?: boolean;
25
+ config?: IATopNavConfig;
26
+ secondIdentitySlotMode?: IATopNavSecondIdentitySlotMode;
27
+ }) =>
28
+ html` <primary-nav
29
+ .baseHost=${baseHost}
30
+ .username=${username}
31
+ .screenName=${screenName}
32
+ ?hideSearch=${hideSearch}
33
+ .config=${config}
34
+ .secondIdentitySlotMode=${secondIdentitySlotMode}
35
+ ></primary-nav>`;
36
+
37
+ afterEach(() => {
38
+ fixtureCleanup();
39
+ });
40
+
41
+ describe('<primary-nav>', () => {
42
+ it('renders the login link when no username present', async () => {
43
+ const el = await fixture<PrimaryNav>(
44
+ component({
45
+ baseHost: 'archive.org',
46
+ username: '',
47
+ }),
48
+ );
49
+
50
+ expect(el.shadowRoot?.querySelector('login-button')).to.not.be.undefined;
51
+ });
52
+
53
+ it('does not render search trigger or search slot if hideSearch true', async () => {
54
+ const el = await fixture<PrimaryNav>(
55
+ component({
56
+ baseHost: 'archive.org',
57
+ username: 'shaneriley',
58
+ screenName: 'shaneriley',
59
+ hideSearch: true,
60
+ }),
61
+ );
62
+
63
+ expect(el.shadowRoot?.querySelector('.search-trigger')).to.equal(null);
64
+ expect(el.shadowRoot?.querySelector('.search-container')).to.not.exist;
65
+ });
66
+
67
+ it('renders search slot container', async () => {
68
+ const el = await fixture<PrimaryNav>(
69
+ component({
70
+ baseHost: 'archive.org',
71
+ username: 'testuser',
72
+ screenName: 'testuser',
73
+ }),
74
+ );
75
+
76
+ expect(el.shadowRoot?.querySelector('.search-container')).to.exist;
77
+
78
+ const slot = el.shadowRoot?.querySelector<HTMLSlotElement>(
79
+ 'slot[name="search"]',
80
+ );
81
+ expect(slot).to.exist;
82
+ });
83
+
84
+ it('renders search trigger button for mobile toggle', async () => {
85
+ const el = await fixture<PrimaryNav>(
86
+ component({
87
+ baseHost: 'archive.org',
88
+ username: 'testuser',
89
+ screenName: 'testuser',
90
+ }),
91
+ );
92
+
93
+ expect(el.shadowRoot?.querySelector('.search-trigger')).to.exist;
94
+ });
95
+
96
+ it('does not render nav-search', async () => {
97
+ const el = await fixture<PrimaryNav>(
98
+ component({
99
+ baseHost: 'archive.org',
100
+ username: 'testuser',
101
+ screenName: 'testuser',
102
+ }),
103
+ );
104
+
105
+ expect(el.shadowRoot?.querySelector('nav-search')).to.not.exist;
106
+ });
107
+
108
+ it('opens a slot with `secondIdentitySlotMode`', async () => {
109
+ const el = await fixture<PrimaryNav>(
110
+ component({
111
+ baseHost: 'archive.org',
112
+ username: 'boop',
113
+ screenName: 'somesuperlongscreenname',
114
+ secondIdentitySlotMode: 'allow',
115
+ }),
116
+ );
117
+
118
+ const brandingBlock = el.shadowRoot?.querySelector('div.branding');
119
+ expect(brandingBlock?.getAttribute('class')).to.contain(
120
+ 'branding second-logo',
121
+ );
122
+
123
+ const slot = brandingBlock?.querySelector('slot');
124
+ expect(slot).to.exist;
125
+ expect(slot?.getAttribute('name')).to.equal('opt-sec-logo');
126
+
127
+ el.secondIdentitySlotMode = '';
128
+ await elementUpdated(el);
129
+ const noSlotBrandingBlock = el.shadowRoot?.querySelector('div.branding');
130
+ expect(noSlotBrandingBlock?.getAttribute('class')).to.contain('branding');
131
+
132
+ const noSlot = noSlotBrandingBlock?.querySelector('slot');
133
+ expect(noSlot).to.not.exist;
134
+ });
135
+ });
@@ -1,2 +0,0 @@
1
- declare const _default: import("lit").CSSResult;
2
- export default _default;
@@ -1,31 +0,0 @@
1
- import { css } from 'lit';
2
- export default css `
3
- @media (min-width: 890px) {
4
- .initial,
5
- .closed,
6
- .open {
7
- right: 33.5rem;
8
- }
9
-
10
- .search-hidden.initial,
11
- .search-hidden.closed,
12
- .search-hidden.open {
13
- right: 18.5rem;
14
- }
15
- }
16
-
17
- @media (min-width: 990px) {
18
- .initial,
19
- .closed,
20
- .open {
21
- right: 40rem;
22
- }
23
-
24
- .search-hidden.initial,
25
- .search-hidden.closed,
26
- .search-hidden.open {
27
- right: 26rem;
28
- }
29
- }
30
- `;
31
- //# sourceMappingURL=signed-out-dropdown.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"signed-out-dropdown.js","sourceRoot":"","sources":["../../../src/styles/signed-out-dropdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BjB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport default css`\n @media (min-width: 890px) {\n .initial,\n .closed,\n .open {\n right: 33.5rem;\n }\n\n .search-hidden.initial,\n .search-hidden.closed,\n .search-hidden.open {\n right: 18.5rem;\n }\n }\n\n @media (min-width: 990px) {\n .initial,\n .closed,\n .open {\n right: 40rem;\n }\n\n .search-hidden.initial,\n .search-hidden.closed,\n .search-hidden.open {\n right: 26rem;\n }\n }\n`;\n"]}
@@ -1,2 +0,0 @@
1
- declare const _default: import("lit").CSSResult;
2
- export default _default;
@@ -1,31 +0,0 @@
1
- import { css } from 'lit';
2
- export default css `
3
- @media (min-width: 890px) {
4
- .initial,
5
- .closed,
6
- .open {
7
- right: 22.4rem;
8
- }
9
-
10
- .search-hidden.initial,
11
- .search-hidden.closed,
12
- .search-hidden.open {
13
- right: 5.8rem;
14
- }
15
- }
16
-
17
- @media (min-width: 990px) {
18
- .initial,
19
- .closed,
20
- .open {
21
- right: 27.2rem;
22
- }
23
-
24
- .search-hidden.initial,
25
- .search-hidden.closed,
26
- .search-hidden.open {
27
- right: 12rem;
28
- }
29
- }
30
- `;
31
- //# sourceMappingURL=user-menu.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"user-menu.js","sourceRoot":"","sources":["../../../src/styles/user-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BjB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport default css`\n @media (min-width: 890px) {\n .initial,\n .closed,\n .open {\n right: 22.4rem;\n }\n\n .search-hidden.initial,\n .search-hidden.closed,\n .search-hidden.open {\n right: 5.8rem;\n }\n }\n\n @media (min-width: 990px) {\n .initial,\n .closed,\n .open {\n right: 27.2rem;\n }\n\n .search-hidden.initial,\n .search-hidden.closed,\n .search-hidden.open {\n right: 12rem;\n }\n }\n`;\n"]}
@@ -1,31 +0,0 @@
1
- import { css } from 'lit';
2
-
3
- export default css`
4
- @media (min-width: 890px) {
5
- .initial,
6
- .closed,
7
- .open {
8
- right: 33.5rem;
9
- }
10
-
11
- .search-hidden.initial,
12
- .search-hidden.closed,
13
- .search-hidden.open {
14
- right: 18.5rem;
15
- }
16
- }
17
-
18
- @media (min-width: 990px) {
19
- .initial,
20
- .closed,
21
- .open {
22
- right: 40rem;
23
- }
24
-
25
- .search-hidden.initial,
26
- .search-hidden.closed,
27
- .search-hidden.open {
28
- right: 26rem;
29
- }
30
- }
31
- `;
@@ -1,31 +0,0 @@
1
- import { css } from 'lit';
2
-
3
- export default css`
4
- @media (min-width: 890px) {
5
- .initial,
6
- .closed,
7
- .open {
8
- right: 22.4rem;
9
- }
10
-
11
- .search-hidden.initial,
12
- .search-hidden.closed,
13
- .search-hidden.open {
14
- right: 5.8rem;
15
- }
16
- }
17
-
18
- @media (min-width: 990px) {
19
- .initial,
20
- .closed,
21
- .open {
22
- right: 27.2rem;
23
- }
24
-
25
- .search-hidden.initial,
26
- .search-hidden.closed,
27
- .search-hidden.open {
28
- right: 12rem;
29
- }
30
- }
31
- `;