@testgorilla/tgo-ui 2.1.1 → 2.1.2

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.
@@ -134,12 +134,12 @@ export class NavbarComponent {
134
134
  this.logoutEvent.emit();
135
135
  isSideSheetClosed$.next();
136
136
  });
137
- navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
138
- this.menuItemClicked.emit();
137
+ navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {
138
+ this.menuItemClicked.emit(value);
139
139
  isSideSheetClosed$.next();
140
140
  });
141
- navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
142
- this.navigateEvent.emit();
141
+ navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {
142
+ this.navigateEvent.emit(value);
143
143
  isSideSheetClosed$.next();
144
144
  });
145
145
  }
@@ -190,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
190
190
  }], logoutEvent: [{
191
191
  type: Output
192
192
  }] } });
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../src/components/navbar/navbar.component.ts","../../../../../src/components/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, DestroyRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem } from './navbar.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { map, ReplaySubject, startWith, Subject, switchMap } 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';\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  // TODO: Some properties and methods are ignored on purpose because of a current issue with compodoc and angular 13\n  // https://github.com/storybookjs/storybook/issues/16865\n  // https://github.com/storybookjs/storybook/issues/17004\n\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 {string}\n   * @memberof NavbarComponent\n   */\n  @Input() activedRoute = '';\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   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof NavbarComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\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   * @tyoe {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 = false;\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\n  protected readonly translationContext = 'NAVBAR.';\n  private readonly _mobileBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly mobileBreakpointObs$ = this._mobileBreakpoint$.pipe(startWith(ScreenBreakpoints.MOBILE));\n  protected readonly isMobile$ = this.mobileBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`).pipe(map(v => v.matches)))\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.language = this.language;\n    navbarSideSheetComponent.contentTemplateRef = this.contentTemplateRef;\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(() => {\n      this.menuItemClicked.emit();\n      isSideSheetClosed$.next();\n    });\n\n    navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n      this.navigateEvent.emit();\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","<ui-side-sheet [applicationTheme]=\"applicationTheme\" [position]=\"'start'\">\n  <mat-toolbar [attr.theme]=\"applicationTheme\">\n    <div class=\"custom-toolbar row\">\n      <ui-button (click)=\"openMobileMenu()\" *ngIf=\"isMobile$ | async\" [variant]=\"'text'\" [companyColor]=\"'#242424'\"\n                 [applicationTheme]=\"'light'\" [iconName]=\"'Menu-burger-in-line'\" [justIcon]=\"true\"></ui-button>\n      <ui-logo [applicationTheme]=\"applicationTheme\" class=\"logo\" (click)=\"navigate('')\"></ui-logo>\n      <div class=\"navigation row\">\n        <a *ngFor=\"let route of routes\" (click)=\"navigate(route.id)\"\n           [ngClass]=\"{'active': activedRoute === route.id}\">\n          <span>{{ route.title }}</span>\n        </a>\n      </div>\n      <div class=\"actions\">\n        <ng-content select=\"[actions]\"></ng-content>\n        <button mat-button class=\"profile-menu\" [matMenuTriggerFor]=\"menu\">\n          <ng-container *ngIf=\"isAvatar; else onlyName\">\n            <ui-avatar [applicationTheme]=\"applicationTheme\" [name]=\"userName\"></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 [size]=\"'24'\"\n                     [name]=\"menu._panelAnimationState === 'void' ? 'Arrow-chevron-down-filled' : 'Arrow-chevron-up-filled'\"\n                     [applicationTheme]=\"applicationTheme\"></ui-icon>\n          </ng-template>\n        </button>\n      </div>\n    </div>\n  </mat-toolbar>\n\n  <ng-content></ng-content>\n\n  <mat-menu #menu=\"matMenu\">\n    <button *ngFor=\"let e of menuItems\" mat-menu-item (click)=\"clickMenuItem(e.id)\">\n      <div class=\"menu-item\">\n        <ui-icon [name]=\"e.icon\" size=\"24\"></ui-icon>\n        {{ e.text }}\n      </div>\n    </button>\n    <button mat-menu-item (click)=\"logout()\">\n      <mat-icon>power_settings_new</mat-icon>\n      {{ (translationContext + 'LOG_OUT') | uiTranslate : language }}\n    </button>\n  </mat-menu>\n</ui-side-sheet>\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"","sources":["../../../../../src/components/navbar/navbar.component.ts","../../../../../src/components/navbar/navbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, DestroyRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport { IRoute, MenuItem } from './navbar.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { map, ReplaySubject, startWith, Subject, switchMap } 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';\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  // TODO: Some properties and methods are ignored on purpose because of a current issue with compodoc and angular 13\n  // https://github.com/storybookjs/storybook/issues/16865\n  // https://github.com/storybookjs/storybook/issues/17004\n\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 {string}\n   * @memberof NavbarComponent\n   */\n  @Input() activedRoute = '';\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   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof NavbarComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\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   * @tyoe {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 = false;\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\n  protected readonly translationContext = 'NAVBAR.';\n  private readonly _mobileBreakpoint$ = new ReplaySubject<number>(1);\n  private readonly mobileBreakpointObs$ = this._mobileBreakpoint$.pipe(startWith(ScreenBreakpoints.MOBILE));\n  protected readonly isMobile$ = this.mobileBreakpointObs$.pipe(\n    switchMap(breakpoint => this.breakpointObserver.observe(`(max-width: ${breakpoint}px)`).pipe(map(v => v.matches)))\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.language = this.language;\n    navbarSideSheetComponent.contentTemplateRef = this.contentTemplateRef;\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","<ui-side-sheet [applicationTheme]=\"applicationTheme\" [position]=\"'start'\">\n  <mat-toolbar [attr.theme]=\"applicationTheme\">\n    <div class=\"custom-toolbar row\">\n      <ui-button (click)=\"openMobileMenu()\" *ngIf=\"isMobile$ | async\" [variant]=\"'text'\" [companyColor]=\"'#242424'\"\n                 [applicationTheme]=\"'light'\" [iconName]=\"'Menu-burger-in-line'\" [justIcon]=\"true\"></ui-button>\n      <ui-logo [applicationTheme]=\"applicationTheme\" class=\"logo\" (click)=\"navigate('')\"></ui-logo>\n      <div class=\"navigation row\">\n        <a *ngFor=\"let route of routes\" (click)=\"navigate(route.id)\"\n           [ngClass]=\"{'active': activedRoute === route.id}\">\n          <span>{{ route.title }}</span>\n        </a>\n      </div>\n      <div class=\"actions\">\n        <ng-content select=\"[actions]\"></ng-content>\n        <button mat-button class=\"profile-menu\" [matMenuTriggerFor]=\"menu\">\n          <ng-container *ngIf=\"isAvatar; else onlyName\">\n            <ui-avatar [applicationTheme]=\"applicationTheme\" [name]=\"userName\"></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 [size]=\"'24'\"\n                     [name]=\"menu._panelAnimationState === 'void' ? 'Arrow-chevron-down-filled' : 'Arrow-chevron-up-filled'\"\n                     [applicationTheme]=\"applicationTheme\"></ui-icon>\n          </ng-template>\n        </button>\n      </div>\n    </div>\n  </mat-toolbar>\n\n  <ng-content></ng-content>\n\n  <mat-menu #menu=\"matMenu\">\n    <button *ngFor=\"let e of menuItems\" mat-menu-item (click)=\"clickMenuItem(e.id)\">\n      <div class=\"menu-item\">\n        <ui-icon [name]=\"e.icon\" size=\"24\"></ui-icon>\n        {{ e.text }}\n      </div>\n    </button>\n    <button mat-menu-item (click)=\"logout()\">\n      <mat-icon>power_settings_new</mat-icon>\n      {{ (translationContext + 'LOG_OUT') | uiTranslate : language }}\n    </button>\n  </mat-menu>\n</ui-side-sheet>\n"]}
@@ -5293,12 +5293,12 @@ class NavbarComponent {
5293
5293
  this.logoutEvent.emit();
5294
5294
  isSideSheetClosed$.next();
5295
5295
  });
5296
- navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
5297
- this.menuItemClicked.emit();
5296
+ navbarSideSheetComponent.menuItemClicked.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {
5297
+ this.menuItemClicked.emit(value);
5298
5298
  isSideSheetClosed$.next();
5299
5299
  });
5300
- navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
5301
- this.navigateEvent.emit();
5300
+ navbarSideSheetComponent.navigateEvent.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(value => {
5301
+ this.navigateEvent.emit(value);
5302
5302
  isSideSheetClosed$.next();
5303
5303
  });
5304
5304
  }