@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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dropdown-menu.js","sourceRoot":"","sources":["../../../src/styles/dropdown-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyKjB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport default css`\n .nav-container {\n position: relative;\n }\n\n nav {\n position: absolute;\n right: 0;\n z-index: 4;\n overflow: hidden;\n font-size: 1.6rem;\n background-color: var(--dropdownMenuBg);\n transition-property: top;\n transition-duration: 0.2s;\n transition-timing-function: ease;\n }\n\n .initial,\n .closed {\n top: var(--topOffset, -1500px);\n }\n\n .closed {\n transition-duration: 0.5s;\n }\n\n .open {\n max-width: 100vw;\n overflow: auto;\n }\n\n h3 {\n padding: 0.6rem 2rem;\n margin: 0;\n font-size: inherit;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n ul {\n padding: 0.4rem 0 0.7rem 0;\n margin: 0;\n list-style: none;\n /* viewport height - nav height + bottom nav border */\n max-height: calc(100vh - 7.2rem + 1px);\n overflow: auto;\n box-sizing: border-box;\n }\n\n .divider {\n margin: 0.5rem 0;\n border-bottom: 1px solid var(--dropdownMenuDivider);\n }\n\n a,\n .info-item {\n display: block;\n color: var(--primaryTextColor);\n text-decoration: none;\n padding: 1rem 2rem;\n }\n\n .info-item {\n font-size: 0.8em;\n color: var(--dropdownMenuInfoItem);\n }\n\n .callout {\n position: absolute;\n margin-left: 10px;\n padding: 0 5px;\n border-radius: 2px;\n background: #fee257;\n color: #2c2c2c;\n font-size: 1.4rem;\n font-weight: bold;\n }\n\n a.mobile-upload {\n display: flex;\n justify-content: left;\n align-items: center;\n }\n a.mobile-upload svg {\n fill: var(--white);\n margin-right: 1rem;\n height: 1.4rem;\n width: 1.4rem;\n }\n\n @media (min-width: 890px) {\n nav {\n display: flex;\n overflow: visible;\n top: 0;\n left: auto;\n right: var(--dropdownMenuRight, 0);\n z-index: 5;\n transition: opacity 0.2s ease-in-out;\n font-size: 1.4rem;\n border-radius: 2px;\n background: var(--primaryTextColor);\n box-shadow: 0 1px 2px 1px rgba(0, 0, 0, 0.15);\n }\n\n nav:after {\n position: absolute;\n right: 7px;\n top: -7px;\n width: 12px;\n height: 7px;\n box-sizing: border-box;\n color: var(--white);\n content: '';\n border-bottom: 7px solid currentColor;\n border-left: 6px solid transparent;\n border-right: 6px solid transparent;\n }\n\n h3 {\n display: none;\n }\n\n ul {\n /* viewport height - nav height + bottom nav border */\n max-height: calc(100vh - 8.5rem + 1px);\n }\n\n .divider {\n border-bottom-color: var(--dropdownMenuDivider);\n }\n\n a {\n padding: 0.5rem 2rem;\n color: var(--inverseTextColor);\n transition:\n background 0.1s ease-out,\n color 0.1s ease-out;\n }\n\n .info-item {\n padding: 0.5rem 2rem;\n font-size: 0.8em;\n color: var(--inverseDropdownMenuInfoItem);\n }\n\n a:hover,\n a:active,\n a:focus {\n color: var(--linkHoverColor);\n background: var(--linkColor);\n outline: none;\n }\n\n .initial,\n .closed {\n opacity: 0;\n transition-duration: 0.2s;\n }\n\n .open {\n opacity: 1;\n overflow: visible;\n }\n\n a.mobile-upload {\n display: none;\n }\n }\n`;\n"]}
|
|
1
|
+
{"version":3,"file":"dropdown-menu.js","sourceRoot":"","sources":["../../../src/styles/dropdown-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyKjB,CAAC","sourcesContent":["import { css } from 'lit';\r\n\r\nexport default css`\r\n .nav-container {\r\n position: relative;\r\n }\r\n\r\n nav {\r\n position: absolute;\r\n right: 0;\r\n z-index: 4;\r\n overflow: hidden;\r\n font-size: 1.6rem;\r\n background-color: var(--dropdownMenuBg);\r\n transition-property: top;\r\n transition-duration: 0.2s;\r\n transition-timing-function: ease;\r\n }\r\n\r\n .initial,\r\n .closed {\r\n top: var(--topOffset, -1500px);\r\n }\r\n\r\n .closed {\r\n transition-duration: 0.5s;\r\n }\r\n\r\n .open {\r\n max-width: 100vw;\r\n overflow: auto;\r\n }\r\n\r\n h3 {\r\n padding: 0.6rem 2rem;\r\n margin: 0;\r\n font-size: inherit;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n }\r\n\r\n ul {\r\n padding: 0.4rem 0 0.7rem 0;\r\n margin: 0;\r\n list-style: none;\r\n /* viewport height - nav height + bottom nav border */\r\n max-height: calc(100vh - 7.2rem + 1px);\r\n overflow: auto;\r\n box-sizing: border-box;\r\n }\r\n\r\n .divider {\r\n margin: 0.5rem 0;\r\n border-bottom: 1px solid var(--dropdownMenuDivider);\r\n }\r\n\r\n a,\r\n .info-item {\r\n display: block;\r\n color: var(--primaryTextColor);\r\n text-decoration: none;\r\n padding: 1rem 2rem;\r\n }\r\n\r\n .info-item {\r\n font-size: 0.8em;\r\n color: var(--dropdownMenuInfoItem);\r\n }\r\n\r\n .callout {\r\n position: absolute;\r\n margin-left: 10px;\r\n padding: 0 5px;\r\n border-radius: 2px;\r\n background: #fee257;\r\n color: #2c2c2c;\r\n font-size: 1.4rem;\r\n font-weight: bold;\r\n }\r\n\r\n a.mobile-upload {\r\n display: flex;\r\n justify-content: left;\r\n align-items: center;\r\n }\r\n a.mobile-upload svg {\r\n fill: var(--white);\r\n margin-right: 1rem;\r\n height: 1.4rem;\r\n width: 1.4rem;\r\n }\r\n\r\n @media (min-width: 890px) {\r\n nav {\r\n display: flex;\r\n overflow: visible;\r\n top: 0;\r\n left: auto;\r\n right: var(--dropdownMenuRight, 0);\r\n z-index: 5;\r\n transition: opacity 0.2s ease-in-out;\r\n font-size: 1.4rem;\r\n border-radius: 2px;\r\n background: var(--primaryTextColor);\r\n box-shadow: 0 1px 2px 1px rgba(0, 0, 0, 0.15);\r\n }\r\n\r\n nav:after {\r\n position: absolute;\r\n right: 7px;\r\n top: -7px;\r\n width: 12px;\r\n height: 7px;\r\n box-sizing: border-box;\r\n color: var(--white);\r\n content: '';\r\n border-bottom: 7px solid currentColor;\r\n border-left: 6px solid transparent;\r\n border-right: 6px solid transparent;\r\n }\r\n\r\n h3 {\r\n display: none;\r\n }\r\n\r\n ul {\r\n /* viewport height - nav height + bottom nav border */\r\n max-height: calc(100vh - 8.5rem + 1px);\r\n }\r\n\r\n .divider {\r\n border-bottom-color: var(--dropdownMenuDivider);\r\n }\r\n\r\n a {\r\n padding: 0.5rem 2rem;\r\n color: var(--inverseTextColor);\r\n transition:\r\n background 0.1s ease-out,\r\n color 0.1s ease-out;\r\n }\r\n\r\n .info-item {\r\n padding: 0.5rem 2rem;\r\n font-size: 0.8em;\r\n color: var(--inverseDropdownMenuInfoItem);\r\n }\r\n\r\n a:hover,\r\n a:active,\r\n a:focus {\r\n color: var(--linkHoverColor);\r\n background: var(--linkColor);\r\n outline: none;\r\n }\r\n\r\n .initial,\r\n .closed {\r\n opacity: 0;\r\n transition-duration: 0.2s;\r\n }\r\n\r\n .open {\r\n opacity: 1;\r\n overflow: visible;\r\n }\r\n\r\n a.mobile-upload {\r\n display: none;\r\n }\r\n }\r\n`;\r\n"]}
|
package/dist/src/user-menu.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { CSSResultGroup } from 'lit';
|
|
1
2
|
import DropdownMenu from './dropdown-menu';
|
|
2
3
|
export default class UserMenu extends DropdownMenu {
|
|
3
4
|
username: string;
|
|
4
5
|
screenName: string;
|
|
5
|
-
static get styles():
|
|
6
|
+
static get styles(): CSSResultGroup;
|
|
6
7
|
render(): import("lit").TemplateResult<1>;
|
|
7
8
|
}
|
package/dist/src/user-menu.js
CHANGED
|
@@ -13,19 +13,19 @@ let UserMenu = class UserMenu extends DropdownMenu {
|
|
|
13
13
|
return dropdownStyles;
|
|
14
14
|
}
|
|
15
15
|
render() {
|
|
16
|
-
return html `
|
|
17
|
-
<div class="nav-container">
|
|
18
|
-
<nav
|
|
19
|
-
class="${this.menuClass}"
|
|
20
|
-
aria-hidden=${!this.open}
|
|
21
|
-
aria-expanded=${this.open}
|
|
22
|
-
>
|
|
23
|
-
<h3>${this.screenName}</h3>
|
|
24
|
-
<ul>
|
|
25
|
-
${this.dropdownItems}
|
|
26
|
-
</ul>
|
|
27
|
-
</nav>
|
|
28
|
-
</div>
|
|
16
|
+
return html `
|
|
17
|
+
<div class="nav-container">
|
|
18
|
+
<nav
|
|
19
|
+
class="${this.menuClass}"
|
|
20
|
+
aria-hidden=${!this.open}
|
|
21
|
+
aria-expanded=${this.open}
|
|
22
|
+
>
|
|
23
|
+
<h3>${this.screenName}</h3>
|
|
24
|
+
<ul>
|
|
25
|
+
${this.dropdownItems}
|
|
26
|
+
</ul>
|
|
27
|
+
</nav>
|
|
28
|
+
</div>
|
|
29
29
|
`;
|
|
30
30
|
}
|
|
31
31
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user-menu.js","sourceRoot":"","sources":["../../src/user-menu.ts"],"names":[],"mappings":";AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"user-menu.js","sourceRoot":"","sources":["../../src/user-menu.ts"],"names":[],"mappings":";AAAA,OAAO,EAAkB,IAAI,EAAE,MAAM,KAAK,CAAC;AAC3C,OAAO,YAAY,MAAM,iBAAiB,CAAC;AAC3C,OAAO,cAAc,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG7C,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,YAAY;IAAnC;;QACe,aAAQ,GAAG,EAAE,CAAC;QACd,eAAU,GAAG,EAAE,CAAC;IAsB9C,CAAC;IApBC,MAAM,KAAK,MAAM;QACf,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAA;;;mBAGI,IAAI,CAAC,SAAS;wBACT,CAAC,IAAI,CAAC,IAAI;0BACR,IAAI,CAAC,IAAI;;gBAEnB,IAAI,CAAC,UAAU;;cAEjB,IAAI,CAAC,aAAa;;;;KAI3B,CAAC;IACJ,CAAC;CACF,CAAA;AAvB6B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;0CAAe;AACd;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;4CAAiB;AAFzB,QAAQ;IAD5B,aAAa,CAAC,WAAW,CAAC;GACN,QAAQ,CAwB5B;eAxBoB,QAAQ","sourcesContent":["import { CSSResultGroup, html } from 'lit';\r\nimport DropdownMenu from './dropdown-menu';\r\nimport dropdownStyles from './styles/dropdown-menu';\r\nimport { customElement, property } from 'lit/decorators.js';\r\n\r\n@customElement('user-menu')\r\nexport default class UserMenu extends DropdownMenu {\r\n @property({ type: String }) username = '';\r\n @property({ type: String }) screenName = '';\r\n\r\n static get styles(): CSSResultGroup {\r\n return dropdownStyles;\r\n }\r\n\r\n render() {\r\n return html`\r\n <div class=\"nav-container\">\r\n <nav\r\n class=\"${this.menuClass}\"\r\n aria-hidden=${!this.open}\r\n aria-expanded=${this.open}\r\n >\r\n <h3>${this.screenName}</h3>\r\n <ul>\r\n ${this.dropdownItems}\r\n </ul>\r\n </nav>\r\n </div>\r\n `;\r\n }\r\n}\r\n"]}
|
package/package.json
CHANGED
package/src/dropdown-menu.ts
CHANGED
|
@@ -1,126 +1,132 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
import {
|
|
9
|
-
|
|
10
|
-
import
|
|
11
|
-
import {
|
|
12
|
-
import
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
(
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
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
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
${
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
return
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
return
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
CSSResultGroup,
|
|
3
|
+
html,
|
|
4
|
+
nothing,
|
|
5
|
+
PropertyValues,
|
|
6
|
+
TemplateResult,
|
|
7
|
+
} from 'lit';
|
|
8
|
+
import { property } from 'lit/decorators.js';
|
|
9
|
+
|
|
10
|
+
import icons from './assets/img/icons';
|
|
11
|
+
import { defaultTopNavConfig } from './data/menus';
|
|
12
|
+
import formatUrl from './lib/format-url';
|
|
13
|
+
import { makeBooleanString } from './lib/make-boolean-string';
|
|
14
|
+
import { IATopNavConfig, IATopNavLink } from './models';
|
|
15
|
+
import dropdownMenuCSS from './styles/dropdown-menu';
|
|
16
|
+
import TrackedElement from './tracked-element';
|
|
17
|
+
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
18
|
+
import KeyboardNavigation from './lib/keyboard-navigation';
|
|
19
|
+
|
|
20
|
+
export default class DropdownMenu extends TrackedElement {
|
|
21
|
+
@property({ type: String }) baseHost = '';
|
|
22
|
+
@property({ type: Object }) config: IATopNavConfig = defaultTopNavConfig;
|
|
23
|
+
@property({ type: Array }) menuItems: IATopNavLink[] | IATopNavLink[][] = [];
|
|
24
|
+
@property({ type: Boolean }) animated = false;
|
|
25
|
+
@property({ type: Boolean }) open = false;
|
|
26
|
+
|
|
27
|
+
private previousKeydownListener?: // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
28
|
+
(this: HTMLElement, ev: KeyboardEvent) => any;
|
|
29
|
+
|
|
30
|
+
static get styles(): CSSResultGroup {
|
|
31
|
+
return dropdownMenuCSS;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
updated(props: PropertyValues) {
|
|
35
|
+
if (props.has('open') && this.open) {
|
|
36
|
+
const container = this.shadowRoot?.querySelector(
|
|
37
|
+
'.nav-container',
|
|
38
|
+
) as HTMLElement;
|
|
39
|
+
|
|
40
|
+
if (container) {
|
|
41
|
+
const keyboardNavigation = new KeyboardNavigation(
|
|
42
|
+
container,
|
|
43
|
+
'usermenu',
|
|
44
|
+
);
|
|
45
|
+
this.addEventListener('keydown', keyboardNavigation.handleKeyDown);
|
|
46
|
+
if (this.previousKeydownListener) {
|
|
47
|
+
this.removeEventListener('keydown', this.previousKeydownListener);
|
|
48
|
+
}
|
|
49
|
+
this.previousKeydownListener = keyboardNavigation.handleKeyDown;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
get dropdownItems() {
|
|
55
|
+
if (!this.menuItems) return nothing;
|
|
56
|
+
|
|
57
|
+
if (!Array.isArray(this.menuItems[0])) {
|
|
58
|
+
const submenu = this.menuItems as IATopNavLink[];
|
|
59
|
+
return this.dropdownSection(submenu);
|
|
60
|
+
}
|
|
61
|
+
return this.menuItems.map((submenu, i) => {
|
|
62
|
+
const joiner = i ? DropdownMenu.dropdownDivider : html``;
|
|
63
|
+
if (!Array.isArray(submenu)) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
return [joiner, ...this.dropdownSection(submenu)];
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
static get dropdownDivider() {
|
|
71
|
+
return html`<li class="divider"></li>`;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
private dropdownSection(submenu: IATopNavLink[]): TemplateResult[] {
|
|
75
|
+
return submenu.map(
|
|
76
|
+
(item) => html`
|
|
77
|
+
<li>
|
|
78
|
+
${item.url
|
|
79
|
+
? this.dropdownLink(item)
|
|
80
|
+
: DropdownMenu.dropdownText(item)}
|
|
81
|
+
</li>
|
|
82
|
+
`,
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
dropdownLink(link: IATopNavLink): TemplateResult {
|
|
87
|
+
const calloutText = this.config?.callouts?.[link.title];
|
|
88
|
+
const isMobileUpload = link.class === 'mobile-upload';
|
|
89
|
+
const isTabbable = this.open && !isMobileUpload;
|
|
90
|
+
|
|
91
|
+
return html`<a
|
|
92
|
+
href="${formatUrl(link.url, this.baseHost)}"
|
|
93
|
+
class=${ifDefined(link.class)}
|
|
94
|
+
tabindex="${isTabbable ? '' : '-1'}"
|
|
95
|
+
@click=${this.trackClick}
|
|
96
|
+
data-event-click-tracking="${this.config
|
|
97
|
+
?.eventCategory}|Nav${link.analyticsEvent}"
|
|
98
|
+
aria-label=${calloutText ? `New feature: ${link.title}` : nothing}
|
|
99
|
+
>
|
|
100
|
+
${isMobileUpload ? icons.uploadUnpadded : nothing} ${link.title}
|
|
101
|
+
${calloutText
|
|
102
|
+
? html`<span class="callout" aria-hidden="true">${calloutText}</span>`
|
|
103
|
+
: nothing}
|
|
104
|
+
</a>`;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
static dropdownText(item: IATopNavLink) {
|
|
108
|
+
return html`<span class="info-item">${item.title}</span>`;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
get menuClass() {
|
|
112
|
+
if (this.open) return 'open';
|
|
113
|
+
if (this.animated) return 'closed';
|
|
114
|
+
return 'initial';
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
render() {
|
|
118
|
+
return html`
|
|
119
|
+
<div class="nav-container">
|
|
120
|
+
<nav
|
|
121
|
+
class="${this.menuClass}"
|
|
122
|
+
aria-hidden="${makeBooleanString(!this.open)}"
|
|
123
|
+
aria-expanded="${makeBooleanString(this.open)}"
|
|
124
|
+
>
|
|
125
|
+
<ul>
|
|
126
|
+
${this.dropdownItems}
|
|
127
|
+
</ul>
|
|
128
|
+
</nav>
|
|
129
|
+
</div>
|
|
130
|
+
`;
|
|
131
|
+
}
|
|
132
|
+
}
|