@internetarchive/ia-topnav 2.0.1-alpha-webdev8396.0 → 2.0.1
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/dropdown-menu.d.ts +2 -2
- package/dist/src/dropdown-menu.js +27 -27
- package/dist/src/dropdown-menu.js.map +1 -1
- package/dist/src/ia-topnav.js +66 -66
- package/dist/src/ia-topnav.js.map +1 -1
- package/dist/src/login-button.js +17 -17
- package/dist/src/login-button.js.map +1 -1
- package/dist/src/primary-nav.js +89 -89
- package/dist/src/primary-nav.js.map +1 -1
- package/dist/src/signed-out-dropdown.d.ts +2 -1
- package/dist/src/signed-out-dropdown.js.map +1 -1
- package/dist/src/styles/dropdown-menu.js +169 -169
- package/dist/src/styles/dropdown-menu.js.map +1 -1
- package/dist/src/user-menu.d.ts +2 -1
- package/dist/src/user-menu.js +13 -13
- package/dist/src/user-menu.js.map +1 -1
- package/package.json +1 -1
- package/src/dropdown-menu.ts +132 -126
- package/src/ia-topnav.ts +332 -332
- package/src/login-button.ts +89 -89
- package/src/primary-nav.ts +300 -300
- package/src/signed-out-dropdown.ts +11 -10
- package/src/styles/dropdown-menu.ts +172 -172
- package/src/user-menu.ts +31 -31
package/src/login-button.ts
CHANGED
|
@@ -1,89 +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, 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
|
-
}
|
|
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
|
+
}
|