@testgorilla/tgo-ui 2.29.5-beta.2 → 2.29.5
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/esm2022/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.mjs
CHANGED
|
@@ -28,7 +28,7 @@ export class MobileNavbarSideSheetComponent {
|
|
|
28
28
|
this.avatarSize = AvatarSize;
|
|
29
29
|
this.activeRoutesMap = computed(() => {
|
|
30
30
|
const currentRoute = this.activedRoute();
|
|
31
|
-
return new Map(this.routes.map(route => [route.id, currentRoute
|
|
31
|
+
return new Map(this.routes.map(route => [route.id, currentRoute?.startsWith(route.id)]));
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
navigate(routeId) {
|
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
81
81
|
}], logoutEvent: [{
|
|
82
82
|
type: Output
|
|
83
83
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-navbar-side-sheet.component.js","sourceRoot":"","sources":["../../../../../../projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.ts","../../../../../../projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,QAAQ,EACR,YAAY,EACZ,KAAK,EACL,KAAK,EAEL,MAAM,GAGP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;;;;AAwBvD,MAAM,OAAO,8BAA8B;IArB3C;QAsBW,WAAM,GAAa,EAAE,CAAC;QAC/B,iBAAY,GAAwB,KAAK,CAAC,EAAE,CAAC,CAAC;QACrC,UAAK,GAAG,EAAE,CAAC;QACX,aAAQ,GAAG,EAAE,CAAC;QACd,cAAS,GAAe,EAAE,CAAC;QAE3B,cAAS,GAAG,KAAK,CAAC;QAClB,qBAAgB,GAAqB,OAAO,CAAC;QAE5C,kBAAa,GAAyB,IAAI,YAAY,EAAU,CAAC;QACjE,oBAAe,GAAyB,IAAI,YAAY,EAAU,CAAC;QACnE,gBAAW,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAElD,uBAAkB,GAAG,SAAS,CAAC;QACxC,eAAU,GAAG,UAAU,CAAC;QAElC,oBAAe,GAAgC,QAAQ,CAAC,GAAG,EAAE;YAC3D,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACzC,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,YAAY,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1F,CAAC,CAAC,CAAC;KAaJ;IAXC,QAAQ,CAAC,OAAe;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,OAAO,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,aAAa,CAAC,EAAU;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;+GAhCU,8BAA8B;mGAA9B,8BAA8B,wxCC7C3C,+2FAoFA,2zIDtDI,OAAO,mHACP,OAAO,mFACP,mBAAmB,8BACnB,aAAa,8BACb,aAAa,0BACb,eAAe,mDACf,eAAe,8BACf,wBAAwB,+BACxB,IAAI,6FACJ,gBAAgB,mJAChB,qBAAqB,uOACrB,qBAAqB,qhBACrB,SAAS;;4FAGA,8BAA8B;kBArB1C,SAAS;+BACE,6BAA6B,cAG3B,IAAI,WACP;wBACP,OAAO;wBACP,OAAO;wBACP,mBAAmB;wBACnB,aAAa;wBACb,aAAa;wBACb,eAAe;wBACf,eAAe;wBACf,wBAAwB;wBACxB,IAAI;wBACJ,gBAAgB;wBAChB,qBAAqB;wBACrB,qBAAqB;wBACrB,SAAS;qBACV;8BAGQ,MAAM;sBAAd,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import {\n  Component,\n  computed,\n  EventEmitter,\n  input,\n  Input,\n  InputSignal,\n  Output,\n  Signal,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem } from \"../navbar.model\";\nimport { AsyncPipe, NgClass, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { IconComponentModule } from \"../../icon/icon.component.module\";\nimport { MatIconModule } from \"@angular/material/icon\";\nimport { MatMenuModule } from \"@angular/material/menu\";\nimport { UiTranslatePipe } from \"../../../pipes/ui-translate.pipe\";\nimport { MatButtonModule } from \"@angular/material/button\";\nimport { AccordionComponentModule } from \"../../accordion/accordion.component.module\";\nimport { AvatarComponentModule } from \"../../avatar/avatar.component.module\";\nimport { ButtonComponentModule } from \"../../button/button.component.module\";\nimport { AvatarSize } from \"../../avatar/avatar.model\";\nimport { ApplicationTheme } from \"../../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-mobile-navbar-side-sheet',\n  templateUrl: './mobile-navbar-side-sheet.component.html',\n  styleUrls: ['./mobile-navbar-side-sheet.component.scss'],\n  standalone: true,\n  imports: [\n    NgForOf,\n    NgClass,\n    IconComponentModule,\n    MatIconModule,\n    MatMenuModule,\n    UiTranslatePipe,\n    MatButtonModule,\n    AccordionComponentModule,\n    NgIf,\n    NgTemplateOutlet,\n    AvatarComponentModule,\n    ButtonComponentModule,\n    AsyncPipe,\n  ],\n})\nexport class MobileNavbarSideSheetComponent {\n  @Input() routes: IRoute[] = [];\n  activedRoute: InputSignal<string> = input('');\n  @Input() email = '';\n  @Input() userName = '';\n  @Input() menuItems: MenuItem[] = [];\n  @Input() contentTemplateRef: TemplateRef<any>;\n  @Input() isDesktop = false;\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @Output() navigateEvent: EventEmitter<string> = new EventEmitter<string>();\n  @Output() menuItemClicked: EventEmitter<string> = new EventEmitter<string>();\n  @Output() logoutEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  protected readonly translationContext = 'NAVBAR.';\n  protected avatarSize = AvatarSize;\n\n  activeRoutesMap:Signal<Map<string, boolean>> = computed(() => {\n    const currentRoute = this.activedRoute();\n    return new Map(this.routes.map(route => [route.id, currentRoute.startsWith(route.id)]));\n  });\n\n  navigate(routeId: string) {\n    this.navigateEvent.emit(`/${routeId}`);\n  }\n\n  logout(): void {\n    this.logoutEvent.emit();\n  }\n\n  clickMenuItem(id: string) {\n    this.menuItemClicked.emit(id);\n  }\n}\n","<div class=\"mobile-navbar-container\">\n  <ng-container *ngIf=\"isDesktop\" [ngTemplateOutlet]=\"userInfo\"></ng-container>\n\n  <div class=\"routes\">\n    <div\n      *ngFor=\"let route of routes\"\n      [attr.data-testid]=\"route.id\"\n      data-test-role=\"nav-route\"\n      (click)=\"navigate(route.id)\"\n      class=\"route\"\n      [ngClass]=\"{ active: activeRoutesMap().get(route.id) }\"\n    >\n      <span>{{ route.title }}</span>\n    </div>\n  </div>\n\n  <div class=\"settings\">\n    <ng-container *ngFor=\"let e of menuItems\">\n      <div *ngIf=\"e\" class=\"menu-item\">\n        <ui-button\n          [attr.data-testid]=\"e.id\"\n          data-test-role=\"menu-item\"\n          [applicationTheme]=\"applicationTheme\"\n          [fullWidth]=\"true\"\n          [disabledScaleOnClick]=\"true\"\n          [variant]=\"'menuCell'\"\n          iconPosition=\"left\"\n          [iconName]=\"e.icon\"\n          [label]=\"e.text\"\n          (buttonClickEvent)=\"clickMenuItem(e.id)\"\n          (keydown.Tab)=\"$event.stopPropagation()\"\n          (keydown.shift.tab)=\"$event.stopPropagation()\"\n          [ariaLabel]=\"e.text + '--' + e.text\"\n        ></ui-button>\n      </div>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"bottom-content\" [ngClass]=\"{ desktop: isDesktop }\">\n  <ng-container *ngIf=\"!isDesktop\" [ngTemplateOutlet]=\"contentTemplateRef\"></ng-container>\n  <ng-container *ngIf=\"isDesktop; else tablet\">\n    <div class=\"menu-item\">\n      <ui-button\n        data-testid=\"logout-button\"\n        [applicationTheme]=\"applicationTheme\"\n        [fullWidth]=\"true\"\n        [disabledScaleOnClick]=\"true\"\n        [variant]=\"'menuCell'\"\n        iconPosition=\"left\"\n        [iconName]=\"'Logout-in-line'\"\n        [label]=\"(translationContext + 'LOG_OUT' | uiTranslate | async)!\"\n        (buttonClickEvent)=\"logout()\"\n        (keydown.Tab)=\"$event.stopPropagation()\"\n        (keydown.shift.tab)=\"$event.stopPropagation()\"\n      ></ui-button>\n    </div>\n  </ng-container>\n\n  <ng-template #tablet>\n    <ng-container [ngTemplateOutlet]=\"userInfo\"></ng-container>\n  </ng-template>\n</div>\n\n<ng-template #userInfo>\n  <div class=\"user-info\" [ngClass]=\"{ desktop: isDesktop }\">\n    <ui-avatar [size]=\"avatarSize.MEDIUM\" [name]=\"userName\"></ui-avatar>\n    <div class=\"details-container\">\n      <div class=\"name-container\">\n        <span class=\"user-name\">{{ userName }}</span>\n        <span class=\"user-email\">{{ email }}</span>\n      </div>\n      <ui-button\n        *ngIf=\"!isDesktop\"\n        data-testid=\"logout-button\"\n        [tooltip]=\"(translationContext + 'LOG_OUT' | uiTranslate | async)!\"\n        [iconName]=\"'Logout-in-line'\"\n        [applicationTheme]=\"'light'\"\n        [variant]=\"'icon-button'\"\n        (click)=\"logout()\"\n      ></ui-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-navbar-side-sheet.component.js","sourceRoot":"","sources":["../../../../../../projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.ts","../../../../../../projects/tgo-canopy-ui/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,QAAQ,EACR,YAAY,EACZ,KAAK,EACL,KAAK,EAEL,MAAM,GAGP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4CAA4C,CAAC;AACtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;;;;AAwBvD,MAAM,OAAO,8BAA8B;IArB3C;QAsBW,WAAM,GAAa,EAAE,CAAC;QAC/B,iBAAY,GAAwB,KAAK,CAAC,EAAE,CAAC,CAAC;QACrC,UAAK,GAAG,EAAE,CAAC;QACX,aAAQ,GAAG,EAAE,CAAC;QACd,cAAS,GAAe,EAAE,CAAC;QAE3B,cAAS,GAAG,KAAK,CAAC;QAClB,qBAAgB,GAAqB,OAAO,CAAC;QAE5C,kBAAa,GAAyB,IAAI,YAAY,EAAU,CAAC;QACjE,oBAAe,GAAyB,IAAI,YAAY,EAAU,CAAC;QACnE,gBAAW,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAElD,uBAAkB,GAAG,SAAS,CAAC;QACxC,eAAU,GAAG,UAAU,CAAC;QAElC,oBAAe,GAAgC,QAAQ,CAAC,GAAG,EAAE;YAC3D,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACzC,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,YAAY,EAAE,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3F,CAAC,CAAC,CAAC;KAaJ;IAXC,QAAQ,CAAC,OAAe;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,OAAO,EAAE,CAAC,CAAC;IACzC,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,aAAa,CAAC,EAAU;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;+GAhCU,8BAA8B;mGAA9B,8BAA8B,wxCC7C3C,+2FAoFA,2zIDtDI,OAAO,mHACP,OAAO,mFACP,mBAAmB,8BACnB,aAAa,8BACb,aAAa,0BACb,eAAe,mDACf,eAAe,8BACf,wBAAwB,+BACxB,IAAI,6FACJ,gBAAgB,mJAChB,qBAAqB,uOACrB,qBAAqB,qhBACrB,SAAS;;4FAGA,8BAA8B;kBArB1C,SAAS;+BACE,6BAA6B,cAG3B,IAAI,WACP;wBACP,OAAO;wBACP,OAAO;wBACP,mBAAmB;wBACnB,aAAa;wBACb,aAAa;wBACb,eAAe;wBACf,eAAe;wBACf,wBAAwB;wBACxB,IAAI;wBACJ,gBAAgB;wBAChB,qBAAqB;wBACrB,qBAAqB;wBACrB,SAAS;qBACV;8BAGQ,MAAM;sBAAd,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import {\n  Component,\n  computed,\n  EventEmitter,\n  input,\n  Input,\n  InputSignal,\n  Output,\n  Signal,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem } from \"../navbar.model\";\nimport { AsyncPipe, NgClass, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { IconComponentModule } from \"../../icon/icon.component.module\";\nimport { MatIconModule } from \"@angular/material/icon\";\nimport { MatMenuModule } from \"@angular/material/menu\";\nimport { UiTranslatePipe } from \"../../../pipes/ui-translate.pipe\";\nimport { MatButtonModule } from \"@angular/material/button\";\nimport { AccordionComponentModule } from \"../../accordion/accordion.component.module\";\nimport { AvatarComponentModule } from \"../../avatar/avatar.component.module\";\nimport { ButtonComponentModule } from \"../../button/button.component.module\";\nimport { AvatarSize } from \"../../avatar/avatar.model\";\nimport { ApplicationTheme } from \"../../../models/application-theme.model\";\n\n@Component({\n  selector: 'ui-mobile-navbar-side-sheet',\n  templateUrl: './mobile-navbar-side-sheet.component.html',\n  styleUrls: ['./mobile-navbar-side-sheet.component.scss'],\n  standalone: true,\n  imports: [\n    NgForOf,\n    NgClass,\n    IconComponentModule,\n    MatIconModule,\n    MatMenuModule,\n    UiTranslatePipe,\n    MatButtonModule,\n    AccordionComponentModule,\n    NgIf,\n    NgTemplateOutlet,\n    AvatarComponentModule,\n    ButtonComponentModule,\n    AsyncPipe,\n  ],\n})\nexport class MobileNavbarSideSheetComponent {\n  @Input() routes: IRoute[] = [];\n  activedRoute: InputSignal<string> = input('');\n  @Input() email = '';\n  @Input() userName = '';\n  @Input() menuItems: MenuItem[] = [];\n  @Input() contentTemplateRef: TemplateRef<any>;\n  @Input() isDesktop = false;\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @Output() navigateEvent: EventEmitter<string> = new EventEmitter<string>();\n  @Output() menuItemClicked: EventEmitter<string> = new EventEmitter<string>();\n  @Output() logoutEvent: EventEmitter<void> = new EventEmitter<void>();\n\n  protected readonly translationContext = 'NAVBAR.';\n  protected avatarSize = AvatarSize;\n\n  activeRoutesMap:Signal<Map<string, boolean>> = computed(() => {\n    const currentRoute = this.activedRoute();\n    return new Map(this.routes.map(route => [route.id, currentRoute?.startsWith(route.id)]));\n  });\n\n  navigate(routeId: string) {\n    this.navigateEvent.emit(`/${routeId}`);\n  }\n\n  logout(): void {\n    this.logoutEvent.emit();\n  }\n\n  clickMenuItem(id: string) {\n    this.menuItemClicked.emit(id);\n  }\n}\n","<div class=\"mobile-navbar-container\">\n  <ng-container *ngIf=\"isDesktop\" [ngTemplateOutlet]=\"userInfo\"></ng-container>\n\n  <div class=\"routes\">\n    <div\n      *ngFor=\"let route of routes\"\n      [attr.data-testid]=\"route.id\"\n      data-test-role=\"nav-route\"\n      (click)=\"navigate(route.id)\"\n      class=\"route\"\n      [ngClass]=\"{ active: activeRoutesMap().get(route.id) }\"\n    >\n      <span>{{ route.title }}</span>\n    </div>\n  </div>\n\n  <div class=\"settings\">\n    <ng-container *ngFor=\"let e of menuItems\">\n      <div *ngIf=\"e\" class=\"menu-item\">\n        <ui-button\n          [attr.data-testid]=\"e.id\"\n          data-test-role=\"menu-item\"\n          [applicationTheme]=\"applicationTheme\"\n          [fullWidth]=\"true\"\n          [disabledScaleOnClick]=\"true\"\n          [variant]=\"'menuCell'\"\n          iconPosition=\"left\"\n          [iconName]=\"e.icon\"\n          [label]=\"e.text\"\n          (buttonClickEvent)=\"clickMenuItem(e.id)\"\n          (keydown.Tab)=\"$event.stopPropagation()\"\n          (keydown.shift.tab)=\"$event.stopPropagation()\"\n          [ariaLabel]=\"e.text + '--' + e.text\"\n        ></ui-button>\n      </div>\n    </ng-container>\n  </div>\n</div>\n\n<div class=\"bottom-content\" [ngClass]=\"{ desktop: isDesktop }\">\n  <ng-container *ngIf=\"!isDesktop\" [ngTemplateOutlet]=\"contentTemplateRef\"></ng-container>\n  <ng-container *ngIf=\"isDesktop; else tablet\">\n    <div class=\"menu-item\">\n      <ui-button\n        data-testid=\"logout-button\"\n        [applicationTheme]=\"applicationTheme\"\n        [fullWidth]=\"true\"\n        [disabledScaleOnClick]=\"true\"\n        [variant]=\"'menuCell'\"\n        iconPosition=\"left\"\n        [iconName]=\"'Logout-in-line'\"\n        [label]=\"(translationContext + 'LOG_OUT' | uiTranslate | async)!\"\n        (buttonClickEvent)=\"logout()\"\n        (keydown.Tab)=\"$event.stopPropagation()\"\n        (keydown.shift.tab)=\"$event.stopPropagation()\"\n      ></ui-button>\n    </div>\n  </ng-container>\n\n  <ng-template #tablet>\n    <ng-container [ngTemplateOutlet]=\"userInfo\"></ng-container>\n  </ng-template>\n</div>\n\n<ng-template #userInfo>\n  <div class=\"user-info\" [ngClass]=\"{ desktop: isDesktop }\">\n    <ui-avatar [size]=\"avatarSize.MEDIUM\" [name]=\"userName\"></ui-avatar>\n    <div class=\"details-container\">\n      <div class=\"name-container\">\n        <span class=\"user-name\">{{ userName }}</span>\n        <span class=\"user-email\">{{ email }}</span>\n      </div>\n      <ui-button\n        *ngIf=\"!isDesktop\"\n        data-testid=\"logout-button\"\n        [tooltip]=\"(translationContext + 'LOG_OUT' | uiTranslate | async)!\"\n        [iconName]=\"'Logout-in-line'\"\n        [applicationTheme]=\"'light'\"\n        [variant]=\"'icon-button'\"\n        (click)=\"logout()\"\n      ></ui-button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -208,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
208
208
|
}], menuState: [{
|
|
209
209
|
type: Output
|
|
210
210
|
}] } });
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/navbar/navbar.component.ts","../../../../../projects/tgo-canopy-ui/components/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  DestroyRef,\n  EventEmitter,\n  Inject,\n  input,\n  Input,\n  InputSignal,\n  Optional,\n  Output, Signal,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem, MenuState, ScreenSize } from './navbar.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { map, ReplaySubject, startWith, Subject, switchMap, tap } from 'rxjs';\nimport { SideSheetService } from '../side-sheet/side-sheet.service';\nimport { MobileNavbarSideSheetComponent } from './mobile-navbar-side-sheet/mobile-navbar-side-sheet.component';\nimport { BreakpointObserver } from '@angular/cdk/layout';\nimport { ScreenBreakpoints } from '../../models/screen-breakpoints.model';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { LogoTypeEnum } from '../logo/logo.model';\nimport { AvatarSize } from '../avatar/avatar.model';\n\n@Component({\n  selector: 'ui-navbar',\n  templateUrl: './navbar.component.html',\n  styleUrls: ['./navbar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NavbarComponent {\n  /**\n   * Routes object\n   *\n   * @type {IRoute}\n   * @memberof NavbarComponent\n   * @ignore\n   */\n  @Input() routes: IRoute[] = [];\n\n  /**\n   * Actived route id\n   *\n   * @type {InputSignal<string>}\n   * @memberof NavbarComponent\n   */\n  activedRoute: InputSignal<string> = input('');\n\n  /**\n   * User first name and last name\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() userName = '';\n\n  /**\n   * User email\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() email = '';\n\n  /**\n   * Menu items to show in menu above the Log out button\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() menuItems: MenuItem[] = [];\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof NavbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * It's ng-content for mobile version\n   *\n   * @type {ApplicationTheme}\n   * @memberof NavbarComponent\n   */\n  @Input() contentTemplateRef: TemplateRef<any>;\n\n  /**\n   * Mobile breakpoint\n   * @type {number}\n   * @memberof NavbarComponent\n   */\n  @Input() set mobileBreakpoint(value: number) {\n    if (value) {\n      this._mobileBreakpoint$.next(value);\n    }\n  }\n\n  /**\n   *\n   * Show avatar with user initials\n   *\n   * @type {boolean}\n   * @memberof NavbarComponent\n   */\n  @Input() isAvatar = true;\n\n  /**\n   * Sets class for the menu\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() menuClass = '';\n\n  /**\n   * @ignore\n   */\n  @Output() navigateEvent: EventEmitter<string> = new EventEmitter<string>();\n\n  /**\n   * @ignore\n   */\n  @Output() menuItemClicked: EventEmitter<string> = new EventEmitter<string>();\n\n  /**\n   * @ignore\n   */\n  @Output() logoutEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() menuState: EventEmitter<MenuState> = new EventEmitter<MenuState>();\n\n  protected screenSize: ScreenSize = 'desktop';\n  protected readonly translationContext = 'NAVBAR.';\n  private readonly _mobileBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly _tabletBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly mobileBreakpointObs$ = this._mobileBreakpoint$.pipe(startWith(ScreenBreakpoints.MOBILE));\n  private readonly tabletBreakpointObs$ = this._tabletBreakpoint$.pipe(startWith(ScreenBreakpoints.TABLET));\n  protected readonly isMobile$ = this.mobileBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`)\n      .pipe(\n        map(v => v.matches),\n        tap(isMobile => isMobile ? this.screenSize = 'mobile' : 'desktop')\n      ))\n  );\n  protected readonly isTablet$ = this.tabletBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`)\n      .pipe(\n        map(v => v.matches),\n        tap(isTablet => isTablet ? this.screenSize = 'tablet' : 'desktop')\n      )\n    )\n  );\n  protected isOpened = false;\n  protected logoType = LogoTypeEnum;\n\n  activeRoutesMap:Signal<Map<string, boolean>> = computed(() => {\n    const currentRoute = this.activedRoute();\n    return new Map(this.routes.map(route => [route.id, currentRoute?.startsWith(route.id)]));\n  });\n\n  constructor(\n    private readonly breakpointObserver: BreakpointObserver,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private sideSheetService: SideSheetService,\n    private destroyRef: DestroyRef,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  openMobileMenu(): void {\n    const isSideSheetClosed$ = new Subject<void>();\n    const navbarSideSheetComponent = this.sideSheetService.open<MobileNavbarSideSheetComponent>({\n      componentRef: MobileNavbarSideSheetComponent,\n      showLogo: true,\n      closed: isSideSheetClosed$,\n    });\n\n    navbarSideSheetComponent.userName = this.userName;\n    navbarSideSheetComponent.menuItems = this.menuItems;\n    navbarSideSheetComponent.activedRoute = this.activedRoute;\n    navbarSideSheetComponent.routes = this.routes;\n    navbarSideSheetComponent.email = this.email;\n    navbarSideSheetComponent.contentTemplateRef = this.contentTemplateRef;\n    navbarSideSheetComponent.applicationTheme = this.applicationTheme;\n\n    navbarSideSheetComponent.logoutEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n      this.logoutEvent.emit();\n      isSideSheetClosed$.next();\n    });\n\n    navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {\n      this.menuItemClicked.emit(value);\n      isSideSheetClosed$.next();\n    });\n\n    navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {\n      this.navigateEvent.emit(value);\n      isSideSheetClosed$.next();\n    });\n  }\n\n  navigate(routeId: string) {\n    this.navigateEvent.emit(`/${routeId}`);\n  }\n\n  logout(): void {\n    this.logoutEvent.emit();\n  }\n\n  clickMenuItem(id: string) {\n    this.menuItemClicked.emit(id);\n  }\n\n  onChangeMenuState(isOpened: boolean, screenSize: ScreenSize) {\n    this.isOpened = isOpened;\n    this.menuState.emit({ isOpened, screenSize });\n  }\n\n  protected readonly AvatarSize = AvatarSize;\n}\n","<ui-side-sheet\n  [applicationTheme]=\"applicationTheme\"\n  (openChange)=\"onChangeMenuState($event, screenSize)\"\n  [position]=\"(isMobile$ | async) ? 'start' : 'end'\"\n>\n  <mat-toolbar [attr.theme]=\"applicationTheme\">\n    <div class=\"custom-toolbar row\">\n      <ui-logo\n        [applicationTheme]=\"applicationTheme\"\n        class=\"logo\"\n        (click)=\"navigate('')\"\n        [allowResizing]=\"true\"\n        [width]=\"(isMobile$ | async) ? 160 : (isTablet$ | async) ? 30 : 160\"\n        [type]=\"\n          (isMobile$ | async)\n            ? logoType.DEFAULT\n            : (isTablet$ | async)\n            ? logoType.PRIMARY_BRANDMARK_PINK\n            : logoType.DEFAULT\n        \"\n      ></ui-logo>\n\n      <ui-button\n        (click)=\"openMobileMenu()\"\n        *ngIf=\"isMobile$ | async\"\n        [variant]=\"'text'\"\n        [companyColor]=\"'#242424'\"\n        [applicationTheme]=\"'light'\"\n        [iconName]=\"isOpened ? 'Close-in-line' : 'Menu-burger-in-line'\"\n        [justIcon]=\"true\"\n      ></ui-button>\n\n      <div class=\"navigation row\">\n        <a\n          *ngFor=\"let route of routes\"\n          (click)=\"navigate(route.id); $event.preventDefault()\"\n          [href]=\"route.id\"\n          [attr.data-testid]=\"route.id\"\n          data-test-role=\"nav-route\"\n          [ngClass]=\"{ active: activeRoutesMap().get(route.id) }\"\n        >\n          <ui-badge\n            *ngIf=\"route?.badgeOptions\"\n            [label]=\"route.badgeOptions!.text\"\n            [rebrandColor]=\"route.badgeOptions!.color\"\n          ></ui-badge>\n          <span>{{ route.title }}</span>\n        </a>\n      </div>\n\n      <div class=\"actions\">\n        <div class=\"custom-actions\">\n          <ng-content select=\"[actions]\"></ng-content>\n        </div>\n\n        <button mat-button class=\"profile-menu\" *ngIf=\"isTablet$ | async; else pc\" (click)=\"openMobileMenu()\">\n          <ng-container [ngTemplateOutlet]=\"buttonContent\"></ng-container>\n        </button>\n\n        <ng-template #pc>\n          <button\n            mat-button\n            class=\"profile-menu\"\n            [disableRipple]=\"applicationTheme !== 'classic'\"\n            (menuOpened)=\"onChangeMenuState(true, 'desktop')\"\n            (menuClosed)=\"onChangeMenuState(false, 'desktop')\"\n            [matMenuTriggerFor]=\"menu\"\n          >\n            <ng-container [ngTemplateOutlet]=\"buttonContent\"></ng-container>\n          </button>\n        </ng-template>\n\n        <ng-template #buttonContent>\n          <div class=\"profile-button-content\">\n            <ng-container *ngIf=\"isAvatar; else onlyName\">\n              <ui-avatar\n                data-testid=\"profile-button\"\n                [ngClass]=\"{ opened: menu._panelAnimationState !== 'void' }\"\n                [applicationTheme]=\"applicationTheme\"\n                [name]=\"userName\"\n                [size]=\"AvatarSize.SMALL_MEDIUM\"\n              ></ui-avatar>\n            </ng-container>\n\n            <ng-template #onlyName>\n              {{ userName }}\n            </ng-template>\n\n            <mat-icon *ngIf=\"applicationTheme === 'classic'; else newThemeIcon\" iconPositionEnd>expand_more</mat-icon>\n            <ng-template #newThemeIcon>\n              <ui-icon\n                [size]=\"'24'\"\n                *ngIf=\"!isAvatar\"\n                [name]=\"menu._panelAnimationState === 'void' ? 'Arrow-chevron-down-filled' : 'Arrow-chevron-up-filled'\"\n                [applicationTheme]=\"applicationTheme\"\n              ></ui-icon>\n            </ng-template>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </mat-toolbar>\n\n  <ng-content></ng-content>\n\n  <mat-menu [class]=\"menuClass\" #menu=\"matMenu\">\n    <ng-container *ngIf=\"applicationTheme === 'classic'; else newTheme\">\n      <button\n        *ngFor=\"let e of menuItems\"\n        mat-menu-item\n        (click)=\"clickMenuItem(e.id)\"\n        [attr.data-testid]=\"e.id\"\n        data-test-role=\"profile-menu-item\"\n      >\n        <div class=\"menu-item\">\n          <ui-icon *ngIf=\"e?.icon\" [name]=\"e.icon\" size=\"24\"></ui-icon>\n          {{ e.text }}\n        </div>\n      </button>\n\n      <button data-testid=\"logout-button\" mat-menu-item (click)=\"logout()\">\n        <mat-icon>power_settings_new</mat-icon>\n        {{ translationContext + 'LOG_OUT' | uiTranslate | async }}\n      </button>\n    </ng-container>\n\n    <ng-template #newTheme>\n      <ui-mobile-navbar-side-sheet\n        [isDesktop]=\"true\"\n        [menuItems]=\"menuItems\"\n        [userName]=\"userName\"\n        [routes]=\"routes\"\n        [activedRoute]=\"activedRoute()\"\n        [email]=\"email\"\n        [applicationTheme]=\"applicationTheme\"\n        [contentTemplateRef]=\"contentTemplateRef\"\n        (menuItemClicked)=\"clickMenuItem($event)\"\n        (logoutEvent)=\"logout()\"\n      ></ui-mobile-navbar-side-sheet>\n    </ng-template>\n  </mat-menu>\n</ui-side-sheet>\n"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/navbar/navbar.component.ts","../../../../../projects/tgo-canopy-ui/components/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  DestroyRef,\n  EventEmitter,\n  Inject,\n  input,\n  Input,\n  InputSignal,\n  Optional,\n  Output,\n  Signal,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem, MenuState, ScreenSize } from './navbar.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { map, ReplaySubject, startWith, Subject, switchMap, tap } from 'rxjs';\nimport { SideSheetService } from '../side-sheet/side-sheet.service';\nimport { MobileNavbarSideSheetComponent } from './mobile-navbar-side-sheet/mobile-navbar-side-sheet.component';\nimport { BreakpointObserver } from '@angular/cdk/layout';\nimport { ScreenBreakpoints } from '../../models/screen-breakpoints.model';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { LogoTypeEnum } from '../logo/logo.model';\nimport { AvatarSize } from '../avatar/avatar.model';\n\n@Component({\n  selector: 'ui-navbar',\n  templateUrl: './navbar.component.html',\n  styleUrls: ['./navbar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NavbarComponent {\n  /**\n   * Routes object\n   *\n   * @type {IRoute}\n   * @memberof NavbarComponent\n   * @ignore\n   */\n  @Input() routes: IRoute[] = [];\n\n  /**\n   * Actived route id\n   *\n   * @type {InputSignal<string>}\n   * @memberof NavbarComponent\n   */\n  activedRoute: InputSignal<string> = input('');\n\n  /**\n   * User first name and last name\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() userName = '';\n\n  /**\n   * User email\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() email = '';\n\n  /**\n   * Menu items to show in menu above the Log out button\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() menuItems: MenuItem[] = [];\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof NavbarComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * It's ng-content for mobile version\n   *\n   * @type {ApplicationTheme}\n   * @memberof NavbarComponent\n   */\n  @Input() contentTemplateRef: TemplateRef<any>;\n\n  /**\n   * Mobile breakpoint\n   * @type {number}\n   * @memberof NavbarComponent\n   */\n  @Input() set mobileBreakpoint(value: number) {\n    if (value) {\n      this._mobileBreakpoint$.next(value);\n    }\n  }\n\n  /**\n   *\n   * Show avatar with user initials\n   *\n   * @type {boolean}\n   * @memberof NavbarComponent\n   */\n  @Input() isAvatar = true;\n\n  /**\n   * Sets class for the menu\n   *\n   * @type {string}\n   * @memberof NavbarComponent\n   */\n  @Input() menuClass = '';\n\n  /**\n   * @ignore\n   */\n  @Output() navigateEvent: EventEmitter<string> = new EventEmitter<string>();\n\n  /**\n   * @ignore\n   */\n  @Output() menuItemClicked: EventEmitter<string> = new EventEmitter<string>();\n\n  /**\n   * @ignore\n   */\n  @Output() logoutEvent: EventEmitter<void> = new EventEmitter<void>();\n  @Output() menuState: EventEmitter<MenuState> = new EventEmitter<MenuState>();\n\n  protected screenSize: ScreenSize = 'desktop';\n  protected readonly translationContext = 'NAVBAR.';\n  private readonly _mobileBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly _tabletBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly mobileBreakpointObs$ = this._mobileBreakpoint$.pipe(startWith(ScreenBreakpoints.MOBILE));\n  private readonly tabletBreakpointObs$ = this._tabletBreakpoint$.pipe(startWith(ScreenBreakpoints.TABLET));\n  protected readonly isMobile$ = this.mobileBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`)\n      .pipe(\n        map(v => v.matches),\n        tap(isMobile => isMobile ? this.screenSize = 'mobile' : 'desktop')\n      ))\n  );\n  protected readonly isTablet$ = this.tabletBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`)\n      .pipe(\n        map(v => v.matches),\n        tap(isTablet => isTablet ? this.screenSize = 'tablet' : 'desktop')\n      )\n    )\n  );\n  protected isOpened = false;\n  protected logoType = LogoTypeEnum;\n\n  activeRoutesMap:Signal<Map<string, boolean>> = computed(() => {\n    const currentRoute = this.activedRoute();\n    return new Map(this.routes.map(route => [route.id, currentRoute?.startsWith(route.id)]));\n  });\n\n  constructor(\n    private readonly breakpointObserver: BreakpointObserver,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private sideSheetService: SideSheetService,\n    private destroyRef: DestroyRef,\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  openMobileMenu(): void {\n    const isSideSheetClosed$ = new Subject<void>();\n    const navbarSideSheetComponent = this.sideSheetService.open<MobileNavbarSideSheetComponent>({\n      componentRef: MobileNavbarSideSheetComponent,\n      showLogo: true,\n      closed: isSideSheetClosed$,\n    });\n\n    navbarSideSheetComponent.userName = this.userName;\n    navbarSideSheetComponent.menuItems = this.menuItems;\n    navbarSideSheetComponent.activedRoute = this.activedRoute;\n    navbarSideSheetComponent.routes = this.routes;\n    navbarSideSheetComponent.email = this.email;\n    navbarSideSheetComponent.contentTemplateRef = this.contentTemplateRef;\n    navbarSideSheetComponent.applicationTheme = this.applicationTheme;\n\n    navbarSideSheetComponent.logoutEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n      this.logoutEvent.emit();\n      isSideSheetClosed$.next();\n    });\n\n    navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {\n      this.menuItemClicked.emit(value);\n      isSideSheetClosed$.next();\n    });\n\n    navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {\n      this.navigateEvent.emit(value);\n      isSideSheetClosed$.next();\n    });\n  }\n\n  navigate(routeId: string) {\n    this.navigateEvent.emit(`/${routeId}`);\n  }\n\n  logout(): void {\n    this.logoutEvent.emit();\n  }\n\n  clickMenuItem(id: string) {\n    this.menuItemClicked.emit(id);\n  }\n\n  onChangeMenuState(isOpened: boolean, screenSize: ScreenSize) {\n    this.isOpened = isOpened;\n    this.menuState.emit({ isOpened, screenSize });\n  }\n\n  protected readonly AvatarSize = AvatarSize;\n}\n","<ui-side-sheet\n  [applicationTheme]=\"applicationTheme\"\n  (openChange)=\"onChangeMenuState($event, screenSize)\"\n  [position]=\"(isMobile$ | async) ? 'start' : 'end'\"\n>\n  <mat-toolbar [attr.theme]=\"applicationTheme\">\n    <div class=\"custom-toolbar row\">\n      <ui-logo\n        [applicationTheme]=\"applicationTheme\"\n        class=\"logo\"\n        (click)=\"navigate('')\"\n        [allowResizing]=\"true\"\n        [width]=\"(isMobile$ | async) ? 160 : (isTablet$ | async) ? 30 : 160\"\n        [type]=\"\n          (isMobile$ | async)\n            ? logoType.DEFAULT\n            : (isTablet$ | async)\n            ? logoType.PRIMARY_BRANDMARK_PINK\n            : logoType.DEFAULT\n        \"\n      ></ui-logo>\n\n      <ui-button\n        (click)=\"openMobileMenu()\"\n        *ngIf=\"isMobile$ | async\"\n        [variant]=\"'text'\"\n        [companyColor]=\"'#242424'\"\n        [applicationTheme]=\"'light'\"\n        [iconName]=\"isOpened ? 'Close-in-line' : 'Menu-burger-in-line'\"\n        [justIcon]=\"true\"\n      ></ui-button>\n\n      <div class=\"navigation row\">\n        <a\n          *ngFor=\"let route of routes\"\n          (click)=\"navigate(route.id); $event.preventDefault()\"\n          [href]=\"route.id\"\n          [attr.data-testid]=\"route.id\"\n          data-test-role=\"nav-route\"\n          [ngClass]=\"{ active: activeRoutesMap().get(route.id) }\"\n        >\n          <ui-badge\n            *ngIf=\"route?.badgeOptions\"\n            [label]=\"route.badgeOptions!.text\"\n            [rebrandColor]=\"route.badgeOptions!.color\"\n          ></ui-badge>\n          <span>{{ route.title }}</span>\n        </a>\n      </div>\n\n      <div class=\"actions\">\n        <div class=\"custom-actions\">\n          <ng-content select=\"[actions]\"></ng-content>\n        </div>\n\n        <button mat-button class=\"profile-menu\" *ngIf=\"isTablet$ | async; else pc\" (click)=\"openMobileMenu()\">\n          <ng-container [ngTemplateOutlet]=\"buttonContent\"></ng-container>\n        </button>\n\n        <ng-template #pc>\n          <button\n            mat-button\n            class=\"profile-menu\"\n            [disableRipple]=\"applicationTheme !== 'classic'\"\n            (menuOpened)=\"onChangeMenuState(true, 'desktop')\"\n            (menuClosed)=\"onChangeMenuState(false, 'desktop')\"\n            [matMenuTriggerFor]=\"menu\"\n          >\n            <ng-container [ngTemplateOutlet]=\"buttonContent\"></ng-container>\n          </button>\n        </ng-template>\n\n        <ng-template #buttonContent>\n          <div class=\"profile-button-content\">\n            <ng-container *ngIf=\"isAvatar; else onlyName\">\n              <ui-avatar\n                data-testid=\"profile-button\"\n                [ngClass]=\"{ opened: menu._panelAnimationState !== 'void' }\"\n                [applicationTheme]=\"applicationTheme\"\n                [name]=\"userName\"\n                [size]=\"AvatarSize.SMALL_MEDIUM\"\n              ></ui-avatar>\n            </ng-container>\n\n            <ng-template #onlyName>\n              {{ userName }}\n            </ng-template>\n\n            <mat-icon *ngIf=\"applicationTheme === 'classic'; else newThemeIcon\" iconPositionEnd>expand_more</mat-icon>\n            <ng-template #newThemeIcon>\n              <ui-icon\n                [size]=\"'24'\"\n                *ngIf=\"!isAvatar\"\n                [name]=\"menu._panelAnimationState === 'void' ? 'Arrow-chevron-down-filled' : 'Arrow-chevron-up-filled'\"\n                [applicationTheme]=\"applicationTheme\"\n              ></ui-icon>\n            </ng-template>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </mat-toolbar>\n\n  <ng-content></ng-content>\n\n  <mat-menu [class]=\"menuClass\" #menu=\"matMenu\">\n    <ng-container *ngIf=\"applicationTheme === 'classic'; else newTheme\">\n      <button\n        *ngFor=\"let e of menuItems\"\n        mat-menu-item\n        (click)=\"clickMenuItem(e.id)\"\n        [attr.data-testid]=\"e.id\"\n        data-test-role=\"profile-menu-item\"\n      >\n        <div class=\"menu-item\">\n          <ui-icon *ngIf=\"e?.icon\" [name]=\"e.icon\" size=\"24\"></ui-icon>\n          {{ e.text }}\n        </div>\n      </button>\n\n      <button data-testid=\"logout-button\" mat-menu-item (click)=\"logout()\">\n        <mat-icon>power_settings_new</mat-icon>\n        {{ translationContext + 'LOG_OUT' | uiTranslate | async }}\n      </button>\n    </ng-container>\n\n    <ng-template #newTheme>\n      <ui-mobile-navbar-side-sheet\n        [isDesktop]=\"true\"\n        [menuItems]=\"menuItems\"\n        [userName]=\"userName\"\n        [routes]=\"routes\"\n        [activedRoute]=\"activedRoute()\"\n        [email]=\"email\"\n        [applicationTheme]=\"applicationTheme\"\n        [contentTemplateRef]=\"contentTemplateRef\"\n        (menuItemClicked)=\"clickMenuItem($event)\"\n        (logoutEvent)=\"logout()\"\n      ></ui-mobile-navbar-side-sheet>\n    </ng-template>\n  </mat-menu>\n</ui-side-sheet>\n"]}
|
|
@@ -8239,7 +8239,7 @@ class MobileNavbarSideSheetComponent {
|
|
|
8239
8239
|
this.avatarSize = AvatarSize;
|
|
8240
8240
|
this.activeRoutesMap = computed(() => {
|
|
8241
8241
|
const currentRoute = this.activedRoute();
|
|
8242
|
-
return new Map(this.routes.map(route => [route.id, currentRoute
|
|
8242
|
+
return new Map(this.routes.map(route => [route.id, currentRoute?.startsWith(route.id)]));
|
|
8243
8243
|
});
|
|
8244
8244
|
}
|
|
8245
8245
|
navigate(routeId) {
|