@rxap/layout 16.0.0-dev.11 → 16.0.0-dev.13

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/CHANGELOG.md CHANGED
@@ -3,6 +3,18 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [16.0.0-dev.13](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.12...@rxap/layout@16.0.0-dev.13) (2023-08-07)
7
+
8
+ ### Bug Fixes
9
+
10
+ - set default layout header color to undefined ([21b6199](https://gitlab.com/rxap/packages/commit/21b6199f047f2345de3e716a038306b2303e6dc6))
11
+
12
+ # [16.0.0-dev.12](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.11...@rxap/layout@16.0.0-dev.12) (2023-08-06)
13
+
14
+ ### Bug Fixes
15
+
16
+ - disable i18n check in development mode ([69f92d3](https://gitlab.com/rxap/packages/commit/69f92d3f66599ac8f07f72b4a7a4331e486d965a))
17
+
6
18
  # [16.0.0-dev.11](https://gitlab.com/rxap/packages/compare/@rxap/layout@16.0.0-dev.10...@rxap/layout@16.0.0-dev.11) (2023-08-06)
7
19
 
8
20
  ### Bug Fixes
package/README.md CHANGED
@@ -17,5 +17,5 @@ yarn add @rxap/layout
17
17
  ```
18
18
  **Install peer dependencies:**
19
19
  ```bash
20
- yarn add @angular/animations@^16.1.4 @angular/cdk@^16.1.4 @angular/common@^16.1.4 @angular/core@^16.1.4 @angular/flex-layout@^15.0.0-beta.42 @angular/forms@^16.1.4 @angular/material@^16.1.4 @angular/router@^16.1.4 @rxap/authentication@^16.0.0-dev.8 @rxap/browser-utilities@^0.0.2-dev.1 @rxap/config@^16.0.0-dev.9 @rxap/data-source@^16.0.0-dev.9 @rxap/directives@^16.0.0-dev.8 @rxap/environment@^16.0.0-dev.8 @rxap/material-directives@^16.0.0-dev.10 @rxap/services@^16.0.0-dev.8 @rxap/utilities@^16.0.0-dev.6 rxjs@^7.8.0
20
+ yarn add @angular/animations@^16.1.4 @angular/cdk@^16.1.4 @angular/common@^16.1.4 @angular/core@^16.1.4 @angular/flex-layout@^15.0.0-beta.42 @angular/forms@^16.1.4 @angular/material@^16.1.4 @angular/router@^16.1.4 @rxap/authentication@^16.0.0-dev.8 @rxap/browser-utilities@^0.0.2-dev.1 @rxap/config@^16.0.0-dev.9 @rxap/data-source@^16.0.0-dev.10 @rxap/directives@^16.0.0-dev.9 @rxap/environment@^16.0.0-dev.8 @rxap/material-directives@^16.0.0-dev.11 @rxap/services@^16.0.0-dev.8 @rxap/utilities@^16.0.0-dev.7 rxjs@^7.8.0
21
21
  ```
@@ -1,25 +1,25 @@
1
+ import { AsyncPipe, NgClass, NgIf, } from '@angular/common';
1
2
  import { ChangeDetectionStrategy, Component, Inject, Input, isDevMode, Optional, } from '@angular/core';
2
- import { Subscription } from 'rxjs';
3
- import { tap } from 'rxjs/operators';
4
- import { MatSidenav } from '@angular/material/sidenav';
5
- import { HeaderService, ThemeService, } from '@rxap/services';
6
- import { MatOptionModule, } from '@angular/material/core';
7
- import { RXAP_HEADER_COMPONENT } from '../tokens';
8
- import { MatSlideToggleModule } from '@angular/material/slide-toggle';
9
- import { DataSourceCollectionDirective } from '@rxap/data-source/directive';
10
3
  import { FormsModule } from '@angular/forms';
11
- import { MatSelectModule } from '@angular/material/select';
12
- import { StopPropagationDirective } from '@rxap/directives';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatOptionModule, } from '@angular/material/core';
13
6
  import { MatFormFieldModule } from '@angular/material/form-field';
14
- import { LanguageSelectorComponent } from './language-selector/language-selector.component';
15
7
  import { MatIconModule } from '@angular/material/icon';
16
8
  import { MatMenuModule } from '@angular/material/menu';
17
- import { MatButtonModule } from '@angular/material/button';
18
- import { AsyncPipe, NgClass, NgIf, } from '@angular/common';
9
+ import { MatSelectModule } from '@angular/material/select';
10
+ import { MatSidenav } from '@angular/material/sidenav';
11
+ import { MatSlideToggleModule } from '@angular/material/slide-toggle';
19
12
  import { MatToolbarModule } from '@angular/material/toolbar';
13
+ import { DataSourceCollectionDirective } from '@rxap/data-source/directive';
14
+ import { StopPropagationDirective } from '@rxap/directives';
15
+ import { HeaderService, ThemeService, } from '@rxap/services';
16
+ import { Subscription } from 'rxjs';
17
+ import { tap } from 'rxjs/operators';
18
+ import { RXAP_HEADER_COMPONENT } from '../tokens';
19
+ import { AppsButtonComponent } from './apps-button/apps-button.component';
20
+ import { LanguageSelectorComponent } from './language-selector/language-selector.component';
20
21
  import { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';
21
22
  import { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';
22
- import { AppsButtonComponent } from './apps-button/apps-button.component';
23
23
  import * as i0 from "@angular/core";
24
24
  import * as i1 from "@rxap/services";
25
25
  import * as i2 from "@angular/material/toolbar";
@@ -33,7 +33,7 @@ export class HeaderComponent {
33
33
  this.theme = theme;
34
34
  this.components = [];
35
35
  this.subscriptions = new Subscription();
36
- this.color = 'primary';
36
+ this.color = undefined;
37
37
  this.isDevMode = isDevMode();
38
38
  }
39
39
  ngOnInit() {
@@ -86,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImpor
86
86
  }], color: [{
87
87
  type: Input
88
88
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/header/header.component.ts","../../../../../../../packages/angular/layout/src/lib/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  Input,\n  isDevMode,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport { Constructor } from '@rxap/utilities';\nimport { Subscription } from 'rxjs';\nimport { tap } from 'rxjs/operators';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport {\n  HeaderService,\n  ThemeService,\n} from '@rxap/services';\nimport {\n  MatOptionModule,\n  ThemePalette,\n} from '@angular/material/core';\nimport { RXAP_HEADER_COMPONENT } from '../tokens';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { DataSourceCollectionDirective } from '@rxap/data-source/directive';\nimport { FormsModule } from '@angular/forms';\nimport { MatSelectModule } from '@angular/material/select';\nimport { StopPropagationDirective } from '@rxap/directives';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { LanguageSelectorComponent } from './language-selector/language-selector.component';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatButtonModule } from '@angular/material/button';\nimport {\n  AsyncPipe,\n  NgClass,\n  NgIf,\n} from '@angular/common';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';\nimport { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';\nimport { AppsButtonComponent } from './apps-button/apps-button.component';\n\n@Component({\n  selector: 'rxap-header',\n  templateUrl: './header.component.html',\n  styleUrls: [ './header.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    MatToolbarModule,\n    NgClass,\n    NgIf,\n    MatButtonModule,\n    MatMenuModule,\n    MatIconModule,\n    LanguageSelectorComponent,\n    MatFormFieldModule,\n    StopPropagationDirective,\n    MatSelectModule,\n    FormsModule,\n    MatOptionModule,\n    DataSourceCollectionDirective,\n    MatSlideToggleModule,\n    AsyncPipe,\n    NavigationProgressBarComponent,\n    UserProfileIconComponent,\n    AppsButtonComponent,\n  ],\n})\nexport class HeaderComponent implements OnInit, OnDestroy {\n  @Input()\n  public sidenav?: MatSidenav;\n\n  public components: Array<Constructor<any>> = [];\n\n  public subscriptions = new Subscription();\n\n  @Input()\n  public color: ThemePalette = 'primary';\n\n  public isDevMode = isDevMode();\n\n  constructor(\n    @Inject(HeaderService)\n    public readonly headerComponentService: HeaderService,\n    @Optional() @Inject(RXAP_HEADER_COMPONENT) public headerComponent: any,\n    public readonly theme: ThemeService,\n  ) {\n  }\n\n  public ngOnInit() {\n    this.updateComponents();\n    this.subscriptions.add(\n      this.headerComponentService.update$\n          .pipe(tap(() => this.updateComponents()))\n          .subscribe(),\n    );\n  }\n\n  public updateComponents(): void {\n    this.components = this.headerComponentService.getComponents();\n  }\n\n  public ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n}\n","<mat-toolbar [color]=\"color\" [ngClass]=\"{ open: sidenav?.opened }\" class=\"mat-elevation-z3 header\">\n  <div class=\"w-full flex flex-row gap-x-4 justify-between items-center\">\n    <div class=\"grow\">\n      <ng-content></ng-content>\n    </div>\n    <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n    <div class=\"grow-0\">\n      <button [matMenuTriggerFor]=\"menu\" mat-icon-button>\n        <mat-icon>settings</mat-icon>\n      </button>\n    </div>\n    <rxap-user-profile-icon class=\"grow-0\"></rxap-user-profile-icon>\n  </div>\n</mat-toolbar>\n\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n<mat-menu #menu=\"matMenu\">\n  <button (click)=\"theme.toggleDarkTheme()\" mat-menu-item>\n    <mat-icon *ngIf=\"theme.darkMode\">brightness_2</mat-icon>\n    <mat-icon *ngIf=\"!theme.darkMode\">brightness_5</mat-icon>\n    <span i18n>Mode</span>\n  </button>\n  <rxap-language-selector *ngIf=\"!isDevMode\"></rxap-language-selector>\n</mat-menu>\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../packages/angular/layout/src/lib/header/header.component.ts","../../../../../../../packages/angular/layout/src/lib/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AsyncPipe,\n  NgClass,\n  NgIf,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  Input,\n  isDevMode,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport {\n  MatOptionModule,\n  ThemePalette,\n} from '@angular/material/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { DataSourceCollectionDirective } from '@rxap/data-source/directive';\nimport { StopPropagationDirective } from '@rxap/directives';\nimport {\n  HeaderService,\n  ThemeService,\n} from '@rxap/services';\nimport { Constructor } from '@rxap/utilities';\nimport { Subscription } from 'rxjs';\nimport { tap } from 'rxjs/operators';\nimport { RXAP_HEADER_COMPONENT } from '../tokens';\nimport { AppsButtonComponent } from './apps-button/apps-button.component';\nimport { LanguageSelectorComponent } from './language-selector/language-selector.component';\nimport { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';\nimport { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';\n\n@Component({\n  selector: 'rxap-header',\n  templateUrl: './header.component.html',\n  styleUrls: [ './header.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    MatToolbarModule,\n    NgClass,\n    NgIf,\n    MatButtonModule,\n    MatMenuModule,\n    MatIconModule,\n    LanguageSelectorComponent,\n    MatFormFieldModule,\n    StopPropagationDirective,\n    MatSelectModule,\n    FormsModule,\n    MatOptionModule,\n    DataSourceCollectionDirective,\n    MatSlideToggleModule,\n    AsyncPipe,\n    NavigationProgressBarComponent,\n    UserProfileIconComponent,\n    AppsButtonComponent,\n  ],\n})\nexport class HeaderComponent implements OnInit, OnDestroy {\n  @Input()\n  public sidenav?: MatSidenav;\n\n  public components: Array<Constructor<any>> = [];\n\n  public subscriptions = new Subscription();\n\n  @Input()\n  public color: ThemePalette = undefined;\n\n  public isDevMode = isDevMode();\n\n  constructor(\n    @Inject(HeaderService)\n    public readonly headerComponentService: HeaderService,\n    @Optional() @Inject(RXAP_HEADER_COMPONENT) public headerComponent: any,\n    public readonly theme: ThemeService,\n  ) {\n  }\n\n  public ngOnInit() {\n    this.updateComponents();\n    this.subscriptions.add(\n      this.headerComponentService.update$\n          .pipe(tap(() => this.updateComponents()))\n          .subscribe(),\n    );\n  }\n\n  public updateComponents(): void {\n    this.components = this.headerComponentService.getComponents();\n  }\n\n  public ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n}\n","<mat-toolbar [color]=\"color\" [ngClass]=\"{ open: sidenav?.opened }\" class=\"mat-elevation-z3 header\">\n  <div class=\"w-full flex flex-row gap-x-4 justify-between items-center\">\n    <div class=\"grow\">\n      <ng-content></ng-content>\n    </div>\n    <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n    <div class=\"grow-0\">\n      <button [matMenuTriggerFor]=\"menu\" mat-icon-button>\n        <mat-icon>settings</mat-icon>\n      </button>\n    </div>\n    <rxap-user-profile-icon class=\"grow-0\"></rxap-user-profile-icon>\n  </div>\n</mat-toolbar>\n\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n<mat-menu #menu=\"matMenu\">\n  <button (click)=\"theme.toggleDarkTheme()\" mat-menu-item>\n    <mat-icon *ngIf=\"theme.darkMode\">brightness_2</mat-icon>\n    <mat-icon *ngIf=\"!theme.darkMode\">brightness_5</mat-icon>\n    <span i18n>Mode</span>\n  </button>\n  <rxap-language-selector *ngIf=\"!isDevMode\"></rxap-language-selector>\n</mat-menu>\n"]}
@@ -1,34 +1,30 @@
1
- import { Inject, Injectable, LOCALE_ID, } from '@angular/core';
2
- import { ConfigService } from '@rxap/config';
3
- import { I18nService } from './i18n.service';
1
+ import { Injectable, isDevMode, } from '@angular/core';
4
2
  import { RxapUserProfileService } from '@rxap/authentication';
3
+ import { I18nService } from './i18n.service';
5
4
  import * as i0 from "@angular/core";
6
- import * as i1 from "@rxap/config";
7
- import * as i2 from "./i18n.service";
8
- import * as i3 from "@rxap/authentication";
5
+ import * as i1 from "./i18n.service";
6
+ import * as i2 from "@rxap/authentication";
9
7
  export class I18nCheckGuard {
10
- constructor(config, localId, i18nService, userProfileService) {
11
- this.config = config;
12
- this.localId = localId;
8
+ constructor(i18nService, userProfileService) {
13
9
  this.i18nService = i18nService;
14
10
  this.userProfileService = userProfileService;
15
11
  }
16
12
  async canActivate() {
13
+ if (isDevMode()) {
14
+ return true;
15
+ }
17
16
  const selectedLanguage = (await this.userProfileService.getLanguage()) ?? 'en';
18
17
  if (this.i18nService.currentLanguage !== selectedLanguage) {
19
- await this.i18nService.redirect(selectedLanguage);
18
+ this.i18nService.redirect(selectedLanguage);
20
19
  return false;
21
20
  }
22
21
  return true;
23
22
  }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: I18nCheckGuard, deps: [{ token: i1.ConfigService }, { token: LOCALE_ID }, { token: i2.I18nService }, { token: i3.RxapUserProfileService }], target: i0.ɵɵFactoryTarget.Injectable }); }
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: I18nCheckGuard, deps: [{ token: i1.I18nService }, { token: i2.RxapUserProfileService }], target: i0.ɵɵFactoryTarget.Injectable }); }
25
24
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: I18nCheckGuard, providedIn: 'root' }); }
26
25
  }
27
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: I18nCheckGuard, decorators: [{
28
27
  type: Injectable,
29
28
  args: [{ providedIn: 'root' }]
30
- }], ctorParameters: function () { return [{ type: i1.ConfigService }, { type: undefined, decorators: [{
31
- type: Inject,
32
- args: [LOCALE_ID]
33
- }] }, { type: i2.I18nService }, { type: i3.RxapUserProfileService }]; } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi1jaGVjay5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvaTE4bi1jaGVjay5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsTUFBTSxFQUNOLFVBQVUsRUFDVixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUM3QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7O0FBRzlELE1BQU0sT0FBTyxjQUFjO0lBRXpCLFlBQ21CLE1BQXFCLEVBRXJCLE9BQWUsRUFDZixXQUF3QixFQUN4QixrQkFBMEM7UUFKMUMsV0FBTSxHQUFOLE1BQU0sQ0FBZTtRQUVyQixZQUFPLEdBQVAsT0FBTyxDQUFRO1FBQ2YsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDeEIsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUF3QjtJQUU3RCxDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQVc7UUFDZixNQUFNLGdCQUFnQixHQUFHLENBQUMsTUFBTSxJQUFJLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUM7UUFDL0UsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsS0FBSyxnQkFBZ0IsRUFBRTtZQUN6RCxNQUFNLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFDbEQsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs4R0FsQlUsY0FBYywrQ0FJZixTQUFTO2tIQUpSLGNBQWMsY0FERCxNQUFNOzsyRkFDbkIsY0FBYztrQkFEMUIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUU7OzBCQUs3QixNQUFNOzJCQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBJbmplY3QsXG4gIEluamVjdGFibGUsXG4gIExPQ0FMRV9JRCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb25maWdTZXJ2aWNlIH0gZnJvbSAnQHJ4YXAvY29uZmlnJztcbmltcG9ydCB7IEkxOG5TZXJ2aWNlIH0gZnJvbSAnLi9pMThuLnNlcnZpY2UnO1xuaW1wb3J0IHsgUnhhcFVzZXJQcm9maWxlU2VydmljZSB9IGZyb20gJ0ByeGFwL2F1dGhlbnRpY2F0aW9uJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBJMThuQ2hlY2tHdWFyZCB7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IENvbmZpZ1NlcnZpY2UsXG4gICAgQEluamVjdChMT0NBTEVfSUQpXG4gICAgcHJpdmF0ZSByZWFkb25seSBsb2NhbElkOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSByZWFkb25seSBpMThuU2VydmljZTogSTE4blNlcnZpY2UsXG4gICAgcHJpdmF0ZSByZWFkb25seSB1c2VyUHJvZmlsZVNlcnZpY2U6IFJ4YXBVc2VyUHJvZmlsZVNlcnZpY2UsXG4gICkge1xuICB9XG5cbiAgYXN5bmMgY2FuQWN0aXZhdGUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgY29uc3Qgc2VsZWN0ZWRMYW5ndWFnZSA9IChhd2FpdCB0aGlzLnVzZXJQcm9maWxlU2VydmljZS5nZXRMYW5ndWFnZSgpKSA/PyAnZW4nO1xuICAgIGlmICh0aGlzLmkxOG5TZXJ2aWNlLmN1cnJlbnRMYW5ndWFnZSAhPT0gc2VsZWN0ZWRMYW5ndWFnZSkge1xuICAgICAgYXdhaXQgdGhpcy5pMThuU2VydmljZS5yZWRpcmVjdChzZWxlY3RlZExhbmd1YWdlKTtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxufVxuIl19
29
+ }], ctorParameters: function () { return [{ type: i1.I18nService }, { type: i2.RxapUserProfileService }]; } });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi1jaGVjay5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvaTE4bi1jaGVjay5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsVUFBVSxFQUNWLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFHN0MsTUFBTSxPQUFPLGNBQWM7SUFFekIsWUFDbUIsV0FBd0IsRUFDeEIsa0JBQTBDO1FBRDFDLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQ3hCLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBd0I7SUFFN0QsQ0FBQztJQUVELEtBQUssQ0FBQyxXQUFXO1FBQ2YsSUFBSSxTQUFTLEVBQUUsRUFBRTtZQUNmLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFDRCxNQUFNLGdCQUFnQixHQUFHLENBQUMsTUFBTSxJQUFJLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUM7UUFDL0UsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsS0FBSyxnQkFBZ0IsRUFBRTtZQUN6RCxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQzVDLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7OEdBbEJVLGNBQWM7a0hBQWQsY0FBYyxjQURELE1BQU07OzJGQUNuQixjQUFjO2tCQUQxQixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEluamVjdGFibGUsXG4gIGlzRGV2TW9kZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSeGFwVXNlclByb2ZpbGVTZXJ2aWNlIH0gZnJvbSAnQHJ4YXAvYXV0aGVudGljYXRpb24nO1xuaW1wb3J0IHsgSTE4blNlcnZpY2UgfSBmcm9tICcuL2kxOG4uc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgSTE4bkNoZWNrR3VhcmQge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVhZG9ubHkgaTE4blNlcnZpY2U6IEkxOG5TZXJ2aWNlLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgdXNlclByb2ZpbGVTZXJ2aWNlOiBSeGFwVXNlclByb2ZpbGVTZXJ2aWNlLFxuICApIHtcbiAgfVxuXG4gIGFzeW5jIGNhbkFjdGl2YXRlKCk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGlmIChpc0Rldk1vZGUoKSkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIGNvbnN0IHNlbGVjdGVkTGFuZ3VhZ2UgPSAoYXdhaXQgdGhpcy51c2VyUHJvZmlsZVNlcnZpY2UuZ2V0TGFuZ3VhZ2UoKSkgPz8gJ2VuJztcbiAgICBpZiAodGhpcy5pMThuU2VydmljZS5jdXJyZW50TGFuZ3VhZ2UgIT09IHNlbGVjdGVkTGFuZ3VhZ2UpIHtcbiAgICAgIHRoaXMuaTE4blNlcnZpY2UucmVkaXJlY3Qoc2VsZWN0ZWRMYW5ndWFnZSk7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbn1cbiJdfQ==