|
1 | | -<div class="navbar-nav mr-auto" *ngIf="!(isMobile$ | async); else mobileButtons" data-test="auth-nav"> |
2 | | - <div *ngIf="!(isAuthenticated | async) && (showAuth | async)" |
3 | | - class="nav-item" |
4 | | - (click)="$event.stopPropagation();"> |
5 | | - <div ngbDropdown #loginDrop="ngbDropdown" display="dynamic" placement="bottom-right" class="d-inline-block" @fadeInOut> |
6 | | - <a href="javascript:void(0);" class="dropdownLogin px-0.5" [attr.aria-label]="'nav.login' |translate" |
7 | | - (click)="$event.preventDefault()" [attr.data-test]="'login-menu' | dsBrowserOnly" |
8 | | - role="menuitem" |
9 | | - tabindex="0" |
10 | | - aria-haspopup="menu" |
11 | | - aria-controls="loginDropdownMenu" |
12 | | - [attr.aria-expanded]="loginDrop.isOpen()" |
13 | | - ngbDropdownToggle>{{ 'nav.login' | translate }}</a> |
14 | | - <div id="loginDropdownMenu" [ngClass]="{'pl-3 pr-3': (loading | async)}" ngbDropdownMenu |
15 | | - role="menu" |
16 | | - [attr.aria-label]="'nav.login' | translate"> |
17 | | - <ds-themed-log-in |
18 | | - [isStandalonePage]="false"></ds-themed-log-in> |
| 1 | +<div *ngVar="(isAuthenticated$ | async) as isAuthenticated"> |
| 2 | + <div class="navbar-nav mr-auto" *ngIf="!(isMobile$ | async); else mobileButtons" data-test="auth-nav"> |
| 3 | + <div *ngVar="(showAuth$ | async) as showAuth"> |
| 4 | + <div *ngIf="!isAuthenticated && showAuth" |
| 5 | + class="nav-item" |
| 6 | + (click)="$event.stopPropagation();"> |
| 7 | + <div ngbDropdown #loginDrop="ngbDropdown" display="dynamic" placement="bottom-right" class="d-inline-block" |
| 8 | + @fadeInOut> |
| 9 | + <button class="dropdownLogin btn btn-link px-0" [attr.aria-label]="'nav.login' |translate" |
| 10 | + (click)="$event.preventDefault()" [attr.data-test]="'login-menu' | dsBrowserOnly" |
| 11 | + role="button" |
| 12 | + tabindex="0" |
| 13 | + aria-haspopup="menu" |
| 14 | + aria-controls="loginDropdownMenu" |
| 15 | + [attr.aria-expanded]="loginDrop.isOpen()" |
| 16 | + ngbDropdownToggle> |
| 17 | + {{ 'nav.login' | translate }} |
| 18 | + </button> |
| 19 | + <div id="loginDropdownMenu" [ngClass]="{'pl-3 pr-3': (loading | async)}" ngbDropdownMenu |
| 20 | + role="dialog" |
| 21 | + aria-modal="true" |
| 22 | + [attr.aria-label]="'nav.login' | translate"> |
| 23 | + <ds-themed-log-in |
| 24 | + [isStandalonePage]="false"></ds-themed-log-in> |
| 25 | + </div> |
| 26 | + </div> |
19 | 27 | </div> |
20 | | - </div> |
21 | | - </div> |
22 | | - <div *ngIf="(isAuthenticated | async) && (showAuth | async)" class="nav-item"> |
23 | | - <div ngbDropdown display="dynamic" placement="bottom-right" class="d-inline-block" @fadeInOut> |
24 | | - <a href="javascript:void(0);" |
25 | | - role="menuitem" |
26 | | - tabindex="0" |
27 | | - [attr.aria-label]="'nav.user-profile-menu-and-logout' | translate" |
28 | | - aria-controls="user-menu-dropdown" |
29 | | - (click)="$event.preventDefault()" [title]="'nav.user-profile-menu-and-logout' | translate" |
30 | | - class="dropdownLogout px-1" |
31 | | - [attr.data-test]="'user-menu' | dsBrowserOnly" |
32 | | - ngbDropdownToggle> |
33 | | - <i class="fas fa-user-circle fa-lg fa-fw"></i></a> |
34 | | - <div id="logoutDropdownMenu" ngbDropdownMenu> |
35 | | - <ds-themed-user-menu [inExpandableNavbar]="false"></ds-themed-user-menu> |
| 28 | + <div *ngIf="isAuthenticated && showAuth" class="nav-item"> |
| 29 | + <div ngbDropdown display="dynamic" placement="bottom-right" class="d-inline-block" @fadeInOut> |
| 30 | + <button |
| 31 | + role="button" |
| 32 | + tabindex="0" |
| 33 | + [attr.aria-label]="'nav.user-profile-menu-and-logout' | translate" |
| 34 | + aria-controls="user-menu-dropdown" |
| 35 | + (click)="$event.preventDefault()" [title]="'nav.user-profile-menu-and-logout' | translate" |
| 36 | + class="dropdownLogout btn btn-link px-0" |
| 37 | + [attr.data-test]="'user-menu' | dsBrowserOnly" |
| 38 | + ngbDropdownToggle> |
| 39 | + <i class="fas fa-user-circle fa-lg fa-fw"></i></button> |
| 40 | + <div id="logoutDropdownMenu" ngbDropdownMenu> |
| 41 | + <ds-user-menu [inExpandableNavbar]="false"></ds-user-menu> |
| 42 | + </div> |
| 43 | + </div> |
36 | 44 | </div> |
37 | 45 | </div> |
38 | 46 | </div> |
| 47 | + <ng-template #mobileButtons> |
| 48 | + <div data-test="auth-nav"> |
| 49 | + <a *ngIf="!isAuthenticated" routerLink="/login" routerLinkActive="active" class="loginLink px-0.5" role="link" |
| 50 | + tabindex="0"> |
| 51 | + {{ 'nav.login' | translate }}<span class="sr-only">(current)</span> |
| 52 | + </a> |
| 53 | + <a *ngIf="isAuthenticated" role="link" [attr.aria-label]="'nav.logout' |translate" |
| 54 | + [title]="'nav.logout' | translate" routerLink="/logout" routerLinkActive="active" class="logoutLink px-1" |
| 55 | + tabindex="0"> |
| 56 | + <i class="fas fa-sign-out-alt fa-lg fa-fw"></i> |
| 57 | + <span class="sr-only">(current)</span> |
| 58 | + </a> |
| 59 | + </div> |
| 60 | + </ng-template> |
39 | 61 | </div> |
40 | 62 |
|
41 | | - |
42 | | -<ng-template #mobileButtons> |
43 | | - <div data-test="auth-nav"> |
44 | | - <a *ngIf="!(isAuthenticated | async)" routerLink="/login" routerLinkActive="active" class="loginLink px-0.5" role="button" tabindex="0"> |
45 | | - {{ 'nav.login' | translate }}<span class="sr-only">(current)</span> |
46 | | - </a> |
47 | | - <a *ngIf="(isAuthenticated | async)" role="button" [attr.aria-label]="'nav.logout' |translate" [title]="'nav.logout' | translate" routerLink="/logout" routerLinkActive="active" class="logoutLink px-1" tabindex="0"> |
48 | | - <i class="fas fa-sign-out-alt fa-lg fa-fw"></i> |
49 | | - <span class="sr-only">(current)</span> |
50 | | - </a> |
51 | | - </div> |
52 | | -</ng-template> |
53 | | - |
54 | 63 | <!-- Do not use ul/li in this menu as it breaks e2e accessibility tests --> |
0 commit comments