@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,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
- @state() private dropdownTabIndex = '';
18
-
19
- static get styles() {
20
- return loginButtonCSS;
21
- }
22
-
23
- get signupPath() {
24
- return formatUrl('/signup', this.baseHost);
25
- }
26
-
27
- get loginPath() {
28
- return formatUrl('/login', this.baseHost);
29
- }
30
-
31
- get analyticsEvent() {
32
- return `${this.config?.eventCategory}|NavLoginIcon`;
33
- }
34
-
35
- get menuOpened(): boolean {
36
- return this.openMenu === 'login';
37
- }
38
-
39
- get avatarClass() {
40
- return `dropdown-toggle${this.menuOpened ? ' active' : ''}`;
41
- }
42
-
43
- toggleDropdown(e: Event) {
44
- e.preventDefault();
45
- this.trackClick(e);
46
- this.dropdownTabIndex = this.menuOpened ? '' : '-1';
47
- this.dispatchEvent(
48
- new CustomEvent('menuToggled', {
49
- bubbles: true,
50
- composed: true,
51
- detail: {
52
- menuName: 'login',
53
- },
54
- }),
55
- );
56
- }
57
-
58
- render() {
59
- return html`
60
- <div class="logged-out-toolbar">
61
- <button
62
- class="logged-out-menu ${this.avatarClass}"
63
- @click=${this.toggleDropdown}
64
- data-event-click-tracking="${this.analyticsEvent}"
65
- aria-label="Toggle login menu"
66
- aria-expanded="${makeBooleanString(this.menuOpened)}"
67
- >
68
- ${icons.user}
69
- </button>
70
- <span>
71
- <a href="${this.signupPath}">Sign up</a>
72
- |
73
- <a href="${this.loginPath}">Log in</a>
74
- </span>
75
- </div>
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' | '';