@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/login-button.ts
CHANGED
|
@@ -1,78 +1,89 @@
|
|
|
1
|
-
import { html } from 'lit';
|
|
2
|
-
import TrackedElement from './tracked-element';
|
|
3
|
-
import icons from './assets/img/icons';
|
|
4
|
-
import loginButtonCSS from './styles/login-button';
|
|
5
|
-
import formatUrl from './lib/format-url';
|
|
6
|
-
import { makeBooleanString } from './lib/make-boolean-string';
|
|
7
|
-
import { customElement, property, state } from 'lit/decorators.js';
|
|
8
|
-
import { IATopNavConfig } from './models';
|
|
9
|
-
import { defaultTopNavConfig } from './data/menus';
|
|
10
|
-
|
|
11
|
-
@customElement('login-button')
|
|
12
|
-
export class LoginButton extends TrackedElement {
|
|
13
|
-
@property({ type: String }) baseHost = '';
|
|
14
|
-
@property({ type: Object }) config: IATopNavConfig = defaultTopNavConfig;
|
|
15
|
-
@property({ type: String }) openMenu = '';
|
|
16
|
-
|
|
17
|
-
@
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
return
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
this.
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
1
|
+
import { html } from 'lit';
|
|
2
|
+
import TrackedElement from './tracked-element';
|
|
3
|
+
import icons from './assets/img/icons';
|
|
4
|
+
import loginButtonCSS from './styles/login-button';
|
|
5
|
+
import formatUrl from './lib/format-url';
|
|
6
|
+
import { makeBooleanString } from './lib/make-boolean-string';
|
|
7
|
+
import { customElement, property, query, state } from 'lit/decorators.js';
|
|
8
|
+
import { IATopNavConfig } from './models';
|
|
9
|
+
import { defaultTopNavConfig } from './data/menus';
|
|
10
|
+
|
|
11
|
+
@customElement('login-button')
|
|
12
|
+
export class LoginButton extends TrackedElement {
|
|
13
|
+
@property({ type: String }) baseHost = '';
|
|
14
|
+
@property({ type: Object }) config: IATopNavConfig = defaultTopNavConfig;
|
|
15
|
+
@property({ type: String }) openMenu = '';
|
|
16
|
+
|
|
17
|
+
@query('button.logged-out-menu') private toggleButton?: HTMLButtonElement;
|
|
18
|
+
|
|
19
|
+
@state() private dropdownTabIndex = '';
|
|
20
|
+
|
|
21
|
+
static get styles() {
|
|
22
|
+
return loginButtonCSS;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/** Distance (px) from this element's right edge to the right edge of the dropdown toggle icon. */
|
|
26
|
+
getDropdownToggleOffset(): number {
|
|
27
|
+
if (!this.toggleButton) return 0;
|
|
28
|
+
return (
|
|
29
|
+
this.getBoundingClientRect().right -
|
|
30
|
+
this.toggleButton.getBoundingClientRect().right
|
|
31
|
+
);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
get signupPath() {
|
|
35
|
+
return formatUrl('/signup', this.baseHost);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
get loginPath() {
|
|
39
|
+
return formatUrl('/login', this.baseHost);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
get analyticsEvent() {
|
|
43
|
+
return `${this.config?.eventCategory}|NavLoginIcon`;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
get menuOpened(): boolean {
|
|
47
|
+
return this.openMenu === 'login';
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
get avatarClass() {
|
|
51
|
+
return `dropdown-toggle${this.menuOpened ? ' active' : ''}`;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
toggleDropdown(e: Event) {
|
|
55
|
+
e.preventDefault();
|
|
56
|
+
this.trackClick(e);
|
|
57
|
+
this.dropdownTabIndex = this.menuOpened ? '' : '-1';
|
|
58
|
+
this.dispatchEvent(
|
|
59
|
+
new CustomEvent('menuToggled', {
|
|
60
|
+
bubbles: true,
|
|
61
|
+
composed: true,
|
|
62
|
+
detail: {
|
|
63
|
+
menuName: 'login',
|
|
64
|
+
},
|
|
65
|
+
}),
|
|
66
|
+
);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
render() {
|
|
70
|
+
return html`
|
|
71
|
+
<div class="logged-out-toolbar">
|
|
72
|
+
<button
|
|
73
|
+
class="logged-out-menu ${this.avatarClass}"
|
|
74
|
+
@click=${this.toggleDropdown}
|
|
75
|
+
data-event-click-tracking="${this.analyticsEvent}"
|
|
76
|
+
aria-label="Toggle login menu"
|
|
77
|
+
aria-expanded="${makeBooleanString(this.menuOpened)}"
|
|
78
|
+
>
|
|
79
|
+
${icons.user}
|
|
80
|
+
</button>
|
|
81
|
+
<span>
|
|
82
|
+
<a href="${this.signupPath}">Sign up</a>
|
|
83
|
+
|
|
|
84
|
+
<a href="${this.loginPath}">Log in</a>
|
|
85
|
+
</span>
|
|
86
|
+
</div>
|
|
87
|
+
`;
|
|
88
|
+
}
|
|
89
|
+
}
|
package/src/models.ts
CHANGED
|
@@ -1,58 +1,58 @@
|
|
|
1
|
-
export interface IATopNavConfig {
|
|
2
|
-
/**
|
|
3
|
-
* Google Analytics event category
|
|
4
|
-
*/
|
|
5
|
-
eventCategory?: string;
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Copy to display for number of pages archived at the top of the Wayback search form
|
|
9
|
-
*
|
|
10
|
-
* ie. "425 billion"
|
|
11
|
-
*/
|
|
12
|
-
waybackPagesArchived?: string;
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Map from dropdown item ids to any callout text that should be applied beside them
|
|
16
|
-
*/
|
|
17
|
-
callouts?: Record<string, string>;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export interface IATopNavLink {
|
|
21
|
-
title: string;
|
|
22
|
-
|
|
23
|
-
url?: string;
|
|
24
|
-
|
|
25
|
-
class?: string;
|
|
26
|
-
|
|
27
|
-
icon?: string;
|
|
28
|
-
|
|
29
|
-
analyticsEvent?: string;
|
|
30
|
-
|
|
31
|
-
external?: boolean;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
export interface IATopNavMediaMenu {
|
|
35
|
-
heading: string;
|
|
36
|
-
iconLinks: IATopNavLink[];
|
|
37
|
-
featuredLinks: IATopNavLink[];
|
|
38
|
-
links: IATopNavLink[];
|
|
39
|
-
mobileAppsLinks: IATopNavLink[];
|
|
40
|
-
browserExtensionsLinks: IATopNavLink[];
|
|
41
|
-
archiveItLinks: IATopNavLink[];
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export interface IATopNavMenuConfig {
|
|
45
|
-
audio: IATopNavMediaMenu;
|
|
46
|
-
images: IATopNavMediaMenu;
|
|
47
|
-
more: IATopNavMediaMenu;
|
|
48
|
-
signedOut: IATopNavLink[];
|
|
49
|
-
software: IATopNavMediaMenu;
|
|
50
|
-
texts: IATopNavMediaMenu;
|
|
51
|
-
user: IATopNavLink[];
|
|
52
|
-
userAdmin: IATopNavLink[];
|
|
53
|
-
userAdminFlags: IATopNavLink[];
|
|
54
|
-
video: IATopNavMediaMenu;
|
|
55
|
-
web: IATopNavMediaMenu;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
export type IATopNavSecondIdentitySlotMode = 'allow' | '';
|
|
1
|
+
export interface IATopNavConfig {
|
|
2
|
+
/**
|
|
3
|
+
* Google Analytics event category
|
|
4
|
+
*/
|
|
5
|
+
eventCategory?: string;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Copy to display for number of pages archived at the top of the Wayback search form
|
|
9
|
+
*
|
|
10
|
+
* ie. "425 billion"
|
|
11
|
+
*/
|
|
12
|
+
waybackPagesArchived?: string;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Map from dropdown item ids to any callout text that should be applied beside them
|
|
16
|
+
*/
|
|
17
|
+
callouts?: Record<string, string>;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface IATopNavLink {
|
|
21
|
+
title: string;
|
|
22
|
+
|
|
23
|
+
url?: string;
|
|
24
|
+
|
|
25
|
+
class?: string;
|
|
26
|
+
|
|
27
|
+
icon?: string;
|
|
28
|
+
|
|
29
|
+
analyticsEvent?: string;
|
|
30
|
+
|
|
31
|
+
external?: boolean;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export interface IATopNavMediaMenu {
|
|
35
|
+
heading: string;
|
|
36
|
+
iconLinks: IATopNavLink[];
|
|
37
|
+
featuredLinks: IATopNavLink[];
|
|
38
|
+
links: IATopNavLink[];
|
|
39
|
+
mobileAppsLinks: IATopNavLink[];
|
|
40
|
+
browserExtensionsLinks: IATopNavLink[];
|
|
41
|
+
archiveItLinks: IATopNavLink[];
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export interface IATopNavMenuConfig {
|
|
45
|
+
audio: IATopNavMediaMenu;
|
|
46
|
+
images: IATopNavMediaMenu;
|
|
47
|
+
more: IATopNavMediaMenu;
|
|
48
|
+
signedOut: IATopNavLink[];
|
|
49
|
+
software: IATopNavMediaMenu;
|
|
50
|
+
texts: IATopNavMediaMenu;
|
|
51
|
+
user: IATopNavLink[];
|
|
52
|
+
userAdmin: IATopNavLink[];
|
|
53
|
+
userAdminFlags: IATopNavLink[];
|
|
54
|
+
video: IATopNavMediaMenu;
|
|
55
|
+
web: IATopNavMediaMenu;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export type IATopNavSecondIdentitySlotMode = 'allow' | '';
|