mirror of
https://github.com/bitwarden/browser.git
synced 2024-10-28 07:49:41 +01:00
23c4d45285
* Upgrade Angular to 15 * Remove attr.allow for webauthn
82 lines
3.0 KiB
HTML
82 lines
3.0 KiB
HTML
<div
|
|
class="tw-relative"
|
|
[ngClass]="[
|
|
showActiveStyles ? 'tw-bg-background-alt4' : 'tw-bg-background-alt3',
|
|
fvwStyles$ | async
|
|
]"
|
|
>
|
|
<div
|
|
[ngStyle]="{
|
|
'padding-left': (variant === 'tree' ? 2.5 : 1) + treeDepth * 1.5 + 'rem'
|
|
}"
|
|
class="tw-relative tw-flex tw-items-center tw-pr-4"
|
|
[ngClass]="[variant === 'tree' ? 'tw-py-1' : 'tw-py-2']"
|
|
>
|
|
<div
|
|
#slotStart
|
|
class="[&>*:focus-visible::before]:!tw-ring-text-alt2 [&>*:hover]:!tw-border-text-alt2 [&>*]:!tw-text-alt2"
|
|
>
|
|
<ng-content select="[slot-start]"></ng-content>
|
|
</div>
|
|
<!-- Default content for #slotStart (for consistent sizing) -->
|
|
<div
|
|
*ngIf="slotStart.childElementCount === 0"
|
|
[ngClass]="{
|
|
'tw-w-0': variant !== 'tree'
|
|
}"
|
|
>
|
|
<button
|
|
type="button"
|
|
class="tw-invisible"
|
|
[bitIconButton]="'bwi-angle-down'"
|
|
size="small"
|
|
aria-hidden="true"
|
|
></button>
|
|
</div>
|
|
|
|
<ng-container *ngIf="route; then isAnchor; else isButton"></ng-container>
|
|
|
|
<!-- Main content of `NavItem` -->
|
|
<ng-template #anchorAndButtonContent>
|
|
<i class="bwi bwi-fw tw-text-alt2 tw-mx-1 {{ icon }}"></i
|
|
><span [ngClass]="showActiveStyles ? 'tw-font-bold' : 'tw-font-semibold'">{{ text }}</span>
|
|
</ng-template>
|
|
|
|
<!-- Show if a value was passed to `this.to` -->
|
|
<ng-template #isAnchor>
|
|
<!-- The `fvw` class passes focus to `this.focusVisibleWithin$` -->
|
|
<!-- The following `class` field should match the `#isButton` class field below -->
|
|
<a
|
|
class="fvw tw-w-full tw-overflow-hidden tw-text-ellipsis tw-whitespace-nowrap tw-border-none tw-bg-transparent tw-p-0 tw-text-start !tw-text-alt2 hover:tw-text-alt2 hover:tw-no-underline focus:tw-outline-none [&>:not(.bwi)]:hover:tw-underline"
|
|
[routerLink]="route"
|
|
[attr.aria-label]="ariaLabel || text"
|
|
routerLinkActive
|
|
[routerLinkActiveOptions]="rlaOptions"
|
|
[ariaCurrentWhenActive]="'page'"
|
|
(isActiveChange)="setActive($event)"
|
|
(click)="mainContentClicked.emit()"
|
|
>
|
|
<ng-container *ngTemplateOutlet="anchorAndButtonContent"></ng-container>
|
|
</a>
|
|
</ng-template>
|
|
|
|
<!-- Show if `this.to` is falsy -->
|
|
<ng-template #isButton>
|
|
<!-- Class field should match `#isAnchor` class field above -->
|
|
<button
|
|
type="button"
|
|
class="fvw tw-w-full tw-overflow-hidden tw-text-ellipsis tw-whitespace-nowrap tw-border-none tw-bg-transparent tw-p-0 tw-text-start !tw-text-alt2 hover:tw-text-alt2 hover:tw-no-underline focus:tw-outline-none [&>:not(.bwi)]:hover:tw-underline"
|
|
(click)="mainContentClicked.emit()"
|
|
>
|
|
<ng-container *ngTemplateOutlet="anchorAndButtonContent"></ng-container>
|
|
</button>
|
|
</ng-template>
|
|
|
|
<div
|
|
class="tw-flex tw-gap-1 [&>*:focus-visible::before]:!tw-ring-text-alt2 [&>*:hover]:!tw-border-text-alt2 [&>*]:!tw-text-alt2"
|
|
>
|
|
<ng-content select="[slot-end]"></ng-content>
|
|
</div>
|
|
</div>
|
|
</div>
|