mirror of
https://github.com/bitwarden/browser
synced 2025-12-13 06:43:35 +00:00
This PR migrates `libs/components` to use strict TypeScript. - Remove `@ts-strict-ignore` from each file in `libs/components` and resolved any new compilation errors - Converted ViewChild and ContentChild decorators to use the new signal-based queries using the [Angular signal queries migration](https://angular.dev/reference/migrations/signal-queries) - Made view/content children `required` where appropriate, eliminating the need for additional null checking. This helped simplify the strict migration. --- Co-authored-by: Vicki League <vleague@bitwarden.com>
33 lines
1.0 KiB
TypeScript
33 lines
1.0 KiB
TypeScript
import { CommonModule } from "@angular/common";
|
|
import { Component, input } from "@angular/core";
|
|
import { RouterLinkActive, RouterLink } from "@angular/router";
|
|
|
|
import { Icon } from "../icon";
|
|
import { BitIconComponent } from "../icon/icon.component";
|
|
import { BitwardenShield } from "../icon/logos";
|
|
|
|
import { SideNavService } from "./side-nav.service";
|
|
|
|
@Component({
|
|
selector: "bit-nav-logo",
|
|
templateUrl: "./nav-logo.component.html",
|
|
imports: [CommonModule, RouterLinkActive, RouterLink, BitIconComponent],
|
|
})
|
|
export class NavLogoComponent {
|
|
/** Icon that is displayed when the side nav is closed */
|
|
readonly closedIcon = input(BitwardenShield);
|
|
|
|
/** Icon that is displayed when the side nav is open */
|
|
readonly openIcon = input.required<Icon>();
|
|
|
|
/**
|
|
* Route to be passed to internal `routerLink`
|
|
*/
|
|
readonly route = input.required<string | any[]>();
|
|
|
|
/** Passed to `attr.aria-label` and `attr.title` */
|
|
readonly label = input.required<string>();
|
|
|
|
constructor(protected sideNavService: SideNavService) {}
|
|
}
|