@rxap/layout 16.0.0-dev.2 → 16.0.0-dev.21

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.
Files changed (75) hide show
  1. package/CHANGELOG.md +442 -0
  2. package/LICENSE +621 -21
  3. package/LICENSE.md +621 -0
  4. package/README.md +7 -22
  5. package/esm2022/index.mjs +5 -6
  6. package/esm2022/lib/app-url.service.mjs +64 -0
  7. package/esm2022/lib/footer/footer.component.mjs +10 -41
  8. package/esm2022/lib/footer.directive.mjs +21 -22
  9. package/esm2022/lib/header/apps-button/apps-button.component.mjs +40 -120
  10. package/esm2022/lib/header/header.component.mjs +64 -141
  11. package/esm2022/lib/header/language-selector/language-selector.component.mjs +22 -115
  12. package/esm2022/lib/header/navigation-progress-bar/navigation-progress-bar.component.mjs +19 -24
  13. package/esm2022/lib/header/reset-button/reset-button.component.mjs +12 -19
  14. package/esm2022/lib/header/settings-button/settings-button.component.mjs +46 -0
  15. package/esm2022/lib/header/sidenav-toggle-button/sidenav-toggle-button.component.mjs +16 -39
  16. package/esm2022/lib/header/sign-out/sign-out.component.mjs +17 -28
  17. package/esm2022/lib/header/user-profile-icon/user-profile-icon.component.mjs +32 -117
  18. package/esm2022/lib/i18n-check.guard.mjs +30 -0
  19. package/esm2022/lib/i18n.service.mjs +36 -0
  20. package/esm2022/lib/language-selector.service.mjs +34 -0
  21. package/esm2022/lib/layout/layout.component.mjs +61 -91
  22. package/esm2022/lib/layout/layout.component.service.mjs +21 -22
  23. package/esm2022/lib/navigation/navigation-item/navigation-item.component.mjs +116 -264
  24. package/esm2022/lib/navigation/navigation-item.mjs +4 -4
  25. package/esm2022/lib/navigation/navigation.component.mjs +46 -106
  26. package/esm2022/lib/navigation/navigation.service.mjs +28 -27
  27. package/esm2022/lib/navigation/replace-router-paths.service.mjs +9 -10
  28. package/esm2022/lib/sidenav/sidenav-footer.directive.mjs +15 -16
  29. package/esm2022/lib/sidenav/sidenav-header.directive.mjs +15 -16
  30. package/esm2022/lib/sidenav/sidenav.component.mjs +29 -121
  31. package/esm2022/lib/sidenav/sidenav.component.service.mjs +8 -9
  32. package/esm2022/lib/sidenav/version/version.component.mjs +14 -48
  33. package/esm2022/lib/toggle-window-sidenav-button/toggle-window-sidenav-button.component.mjs +15 -38
  34. package/esm2022/lib/tokens.mjs +1 -1
  35. package/esm2022/lib/types.mjs +1 -1
  36. package/esm2022/lib/window-container-sidenav/window-container-sidenav.component.mjs +14 -33
  37. package/esm2022/rxap-layout.mjs +1 -1
  38. package/fesm2022/rxap-layout.mjs +824 -1534
  39. package/fesm2022/rxap-layout.mjs.map +1 -1
  40. package/index.d.ts +4 -3
  41. package/lib/app-url.service.d.ts +26 -0
  42. package/lib/footer.directive.d.ts +1 -1
  43. package/lib/header/apps-button/apps-button.component.d.ts +12 -20
  44. package/lib/header/header.component.d.ts +7 -12
  45. package/lib/header/language-selector/language-selector.component.d.ts +1 -16
  46. package/lib/header/settings-button/settings-button.component.d.ts +19 -0
  47. package/lib/header/sidenav-toggle-button/sidenav-toggle-button.component.d.ts +1 -1
  48. package/lib/header/sign-out/sign-out.component.d.ts +4 -4
  49. package/lib/header/user-profile-icon/user-profile-icon.component.d.ts +11 -7
  50. package/lib/i18n-check.guard.d.ts +11 -0
  51. package/lib/i18n.service.d.ts +12 -0
  52. package/lib/language-selector.service.d.ts +15 -0
  53. package/lib/layout/layout.component.d.ts +9 -4
  54. package/lib/navigation/navigation-item/navigation-item.component.d.ts +11 -18
  55. package/lib/navigation/navigation-item.d.ts +1 -1
  56. package/lib/navigation/navigation.component.d.ts +6 -6
  57. package/lib/navigation/navigation.service.d.ts +1 -1
  58. package/lib/sidenav/version/version.component.d.ts +2 -2
  59. package/lib/toggle-window-sidenav-button/toggle-window-sidenav-button.component.d.ts +2 -4
  60. package/lib/types.d.ts +3 -2
  61. package/lib/window-container-sidenav/window-container-sidenav.component.d.ts +1 -1
  62. package/package.json +101 -66
  63. package/theme.css +1 -0
  64. package/collection.json +0 -10
  65. package/esm2022/lib/layout/layout.component.module.mjs +0 -32
  66. package/esm2022/lib/sidenav-content/sidenav-content.component.mjs +0 -46
  67. package/esm2022/lib/sidenav-content/sidenav-content.component.service.mjs +0 -37
  68. package/lib/layout/layout.component.module.d.ts +0 -10
  69. package/lib/sidenav-content/sidenav-content.component.d.ts +0 -12
  70. package/lib/sidenav-content/sidenav-content.component.service.d.ts +0 -15
  71. package/migration.json +0 -4
  72. package/src/schematics/ng-add/index.d.ts +0 -2
  73. package/src/schematics/ng-add/index.js +0 -8
  74. package/src/schematics/ng-add/index.js.map +0 -1
  75. package/src/schematics/ng-add/schema.json +0 -7
@@ -1,73 +1,37 @@
1
- import { Component, ChangeDetectionStrategy, Input, Optional, Inject } from '@angular/core';
2
- import { Subscription } from 'rxjs';
3
- import { tap, map } from 'rxjs/operators';
1
+ import { AsyncPipe, NgClass, NgIf, } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, Inject, Input, Optional, } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatOptionModule, } from '@angular/material/core';
6
+ import { MatFormFieldModule } from '@angular/material/form-field';
7
+ import { MatIconModule } from '@angular/material/icon';
8
+ import { MatMenuModule } from '@angular/material/menu';
9
+ import { MatSelectModule } from '@angular/material/select';
4
10
  import { MatSidenav } from '@angular/material/sidenav';
5
- import { UserService } from '@rxap/authentication';
6
- import { RXAP_HEADER_COMPONENT } from '../tokens';
11
+ import { MatSlideToggleModule } from '@angular/material/slide-toggle';
12
+ import { MatToolbarModule } from '@angular/material/toolbar';
13
+ import { DataSourceCollectionDirective } from '@rxap/data-source/directive';
14
+ import { StopPropagationDirective } from '@rxap/directives';
15
+ import { StatusIndicatorComponent } from '@rxap/ngx-status-check';
7
16
  import { HeaderService } from '@rxap/services';
8
- import { MatMenuModule } from '@angular/material/menu';
9
- import { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';
10
- import { SignOutComponent } from './sign-out/sign-out.component';
11
- import { MatIconModule } from '@angular/material/icon';
12
- import { MatButtonModule } from '@angular/material/button';
13
- import { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';
17
+ import { Subscription } from 'rxjs';
18
+ import { tap } from 'rxjs/operators';
19
+ import { RXAP_HEADER_COMPONENT } from '../tokens';
14
20
  import { AppsButtonComponent } from './apps-button/apps-button.component';
15
21
  import { LanguageSelectorComponent } from './language-selector/language-selector.component';
16
- import { SidenavToggleButtonComponent } from './sidenav-toggle-button/sidenav-toggle-button.component';
17
- import { FlexModule } from '@angular/flex-layout/flex';
18
- import { NgClass, NgFor, NgComponentOutlet, NgIf, AsyncPipe } from '@angular/common';
19
- import { ExtendedModule } from '@angular/flex-layout/extended';
20
- import { MatToolbarModule } from '@angular/material/toolbar';
22
+ import { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';
23
+ import { SettingsButtonComponent } from './settings-button/settings-button.component';
24
+ import { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';
21
25
  import * as i0 from "@angular/core";
22
26
  import * as i1 from "@angular/material/toolbar";
23
- import * as i2 from "@angular/flex-layout/extended";
24
- import * as i3 from "@angular/flex-layout/flex";
25
- import * as i4 from "@angular/material/button";
26
- import * as i5 from "@angular/material/menu";
27
- import * as i6 from "@angular/material/icon";
28
- import * as i7 from "@rxap/services";
29
- import * as i8 from "@rxap/authentication";
30
- function HeaderComponent_mat_toolbar_row_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
31
- i0.ɵɵelementContainer(0);
32
- } }
33
- function HeaderComponent_mat_toolbar_row_1_Template(rf, ctx) { if (rf & 1) {
34
- i0.ɵɵelementStart(0, "mat-toolbar-row");
35
- i0.ɵɵtemplate(1, HeaderComponent_mat_toolbar_row_1_ng_container_1_Template, 1, 0, "ng-container", 7);
36
- i0.ɵɵelementEnd();
37
- } if (rf & 2) {
38
- const headerComponent_r4 = ctx.$implicit;
39
- i0.ɵɵadvance(1);
40
- i0.ɵɵproperty("ngComponentOutlet", headerComponent_r4);
41
- } }
42
- function HeaderComponent_rxap_sidenav_toggle_button_4_Template(rf, ctx) { if (rf & 1) {
43
- i0.ɵɵelement(0, "rxap-sidenav-toggle-button", 8);
44
- } if (rf & 2) {
45
- const ctx_r1 = i0.ɵɵnextContext();
46
- i0.ɵɵproperty("sidenav", ctx_r1.sidenav);
47
- } }
48
- function HeaderComponent_rxap_user_profile_icon_9_Template(rf, ctx) { if (rf & 1) {
49
- i0.ɵɵelement(0, "rxap-user-profile-icon", 5);
50
- } }
51
- function HeaderComponent_div_11_Template(rf, ctx) { if (rf & 1) {
52
- i0.ɵɵelementStart(0, "div", 5)(1, "button", 9)(2, "mat-icon");
53
- i0.ɵɵtext(3, "settings");
54
- i0.ɵɵelementEnd()()();
55
- } if (rf & 2) {
56
- const ctx_r3 = i0.ɵɵnextContext();
57
- i0.ɵɵadvance(1);
58
- i0.ɵɵproperty("matMenuTriggerFor", ctx_r3.settingsMenuPanel);
59
- } }
60
- const _c0 = function (a0) { return { open: a0 }; };
61
- const _c1 = ["*"];
62
- class HeaderComponent {
63
- constructor(headerComponentService, userService, headerComponent) {
27
+ import * as i2 from "@rxap/services";
28
+ export class HeaderComponent {
29
+ constructor(headerComponentService, headerComponent) {
64
30
  this.headerComponentService = headerComponentService;
65
- this.userService = userService;
66
31
  this.headerComponent = headerComponent;
67
32
  this.components = [];
68
33
  this.subscriptions = new Subscription();
69
- this.color = 'primary';
70
- this.hasUser$ = this.userService.user$.pipe(map(Boolean));
34
+ this.color = undefined;
71
35
  }
72
36
  ngOnInit() {
73
37
  this.updateComponents();
@@ -81,85 +45,44 @@ class HeaderComponent {
81
45
  ngOnDestroy() {
82
46
  this.subscriptions.unsubscribe();
83
47
  }
84
- static { this.ɵfac = function HeaderComponent_Factory(t) { return new (t || HeaderComponent)(i0.ɵɵdirectiveInject(HeaderService), i0.ɵɵdirectiveInject(UserService), i0.ɵɵdirectiveInject(RXAP_HEADER_COMPONENT, 8)); }; }
85
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: HeaderComponent, selectors: [["rxap-header"]], hostAttrs: [1, "rxap-layout-header"], inputs: { sidenav: "sidenav", color: "color", settingsMenuPanel: "settingsMenuPanel" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 14, vars: 10, consts: [[1, "mat-elevation-z3", 3, "ngClass", "color"], [4, "ngFor", "ngForOf"], ["fxLayout", "row", "fxLayoutAlign", "space-between center", "fxLayoutGap", "16px", 1, "content"], ["fxFlex", "nogrow", 3, "sidenav", 4, "ngIf"], ["fxFlex", "grow"], ["fxFlex", "nogrow"], ["fxFlex", "nogrow", 4, "ngIf"], [4, "ngComponentOutlet"], ["fxFlex", "nogrow", 3, "sidenav"], ["mat-icon-button", "", 3, "matMenuTriggerFor"]], template: function HeaderComponent_Template(rf, ctx) { if (rf & 1) {
86
- i0.ɵɵprojectionDef();
87
- i0.ɵɵelementStart(0, "mat-toolbar", 0);
88
- i0.ɵɵtemplate(1, HeaderComponent_mat_toolbar_row_1_Template, 2, 1, "mat-toolbar-row", 1);
89
- i0.ɵɵelementStart(2, "mat-toolbar-row")(3, "div", 2);
90
- i0.ɵɵtemplate(4, HeaderComponent_rxap_sidenav_toggle_button_4_Template, 1, 1, "rxap-sidenav-toggle-button", 3);
91
- i0.ɵɵelementStart(5, "div", 4);
92
- i0.ɵɵprojection(6);
93
- i0.ɵɵelementEnd();
94
- i0.ɵɵelement(7, "rxap-language-selector", 5)(8, "rxap-apps-button", 5);
95
- i0.ɵɵtemplate(9, HeaderComponent_rxap_user_profile_icon_9_Template, 1, 0, "rxap-user-profile-icon", 6);
96
- i0.ɵɵpipe(10, "async");
97
- i0.ɵɵtemplate(11, HeaderComponent_div_11_Template, 4, 1, "div", 6);
98
- i0.ɵɵelement(12, "rxap-sign-out", 5);
99
- i0.ɵɵelementEnd()()();
100
- i0.ɵɵelement(13, "rxap-navigation-progress-bar");
101
- } if (rf & 2) {
102
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(8, _c0, ctx.sidenav == null ? null : ctx.sidenav.opened))("color", ctx.color);
103
- i0.ɵɵadvance(1);
104
- i0.ɵɵproperty("ngForOf", ctx.components);
105
- i0.ɵɵadvance(3);
106
- i0.ɵɵproperty("ngIf", ctx.sidenav);
107
- i0.ɵɵadvance(5);
108
- i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(10, 6, ctx.hasUser$));
109
- i0.ɵɵadvance(2);
110
- i0.ɵɵproperty("ngIf", ctx.settingsMenuPanel);
111
- } }, dependencies: [MatToolbarModule, i1.MatToolbar, i1.MatToolbarRow, ExtendedModule, i2.DefaultClassDirective, NgClass,
112
- NgFor,
113
- NgComponentOutlet,
114
- FlexModule, i3.DefaultLayoutDirective, i3.DefaultLayoutGapDirective, i3.DefaultLayoutAlignDirective, i3.DefaultFlexDirective, NgIf,
115
- SidenavToggleButtonComponent,
116
- LanguageSelectorComponent,
117
- AppsButtonComponent,
118
- UserProfileIconComponent,
119
- MatButtonModule, i4.MatIconButton, MatMenuModule, i5.MatMenuTrigger, MatIconModule, i6.MatIcon, SignOutComponent,
120
- NavigationProgressBarComponent,
121
- AsyncPipe], styles: [".content[_ngcontent-%COMP%]{width:100%;height:64px}"], changeDetection: 0 }); }
48
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: HeaderComponent, deps: [{ token: HeaderService }, { token: RXAP_HEADER_COMPONENT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: HeaderComponent, isStandalone: true, selector: "rxap-header", inputs: { sidenav: "sidenav", color: "color" }, ngImport: i0, template: "<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 <rxap-status-indicator class=\"grow-0\"></rxap-status-indicator>\n <div class=\"grow\">\n <ng-content></ng-content>\n </div>\n <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\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", styles: [""], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: MatSlideToggleModule }, { kind: "component", type: NavigationProgressBarComponent, selector: "rxap-navigation-progress-bar" }, { kind: "component", type: UserProfileIconComponent, selector: "rxap-user-profile-icon" }, { kind: "component", type: AppsButtonComponent, selector: "rxap-apps-button" }, { kind: "component", type: SettingsButtonComponent, selector: "rxap-settings-button" }, { kind: "component", type: StatusIndicatorComponent, selector: "rxap-status-indicator" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
122
50
  }
123
- export { HeaderComponent };
124
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(HeaderComponent, [{
125
- type: Component,
126
- args: [{ selector: 'rxap-header', changeDetection: ChangeDetectionStrategy.OnPush, host: {
127
- class: 'rxap-layout-header'
128
- }, standalone: true, imports: [
129
- MatToolbarModule,
130
- ExtendedModule,
131
- NgClass,
132
- NgFor,
133
- NgComponentOutlet,
134
- FlexModule,
135
- NgIf,
136
- SidenavToggleButtonComponent,
137
- LanguageSelectorComponent,
138
- AppsButtonComponent,
139
- UserProfileIconComponent,
140
- MatButtonModule,
141
- MatMenuModule,
142
- MatIconModule,
143
- SignOutComponent,
144
- NavigationProgressBarComponent,
145
- AsyncPipe
146
- ], template: "<mat-toolbar [ngClass]=\"{ open: sidenav?.opened }\" [color]=\"color\" class=\"mat-elevation-z3\">\n <mat-toolbar-row *ngFor=\"let headerComponent of components\">\n <ng-container *ngComponentOutlet=\"headerComponent\"></ng-container>\n </mat-toolbar-row>\n <mat-toolbar-row>\n <div\n fxLayout=\"row\"\n fxLayoutAlign=\"space-between center\"\n fxLayoutGap=\"16px\"\n class=\"content\"\n >\n <rxap-sidenav-toggle-button *ngIf=\"sidenav\" fxFlex=\"nogrow\" [sidenav]=\"sidenav\"></rxap-sidenav-toggle-button>\n <div fxFlex=\"grow\">\n <ng-content></ng-content>\n </div>\n <rxap-language-selector fxFlex=\"nogrow\"></rxap-language-selector>\n <rxap-apps-button fxFlex=\"nogrow\"></rxap-apps-button>\n <rxap-user-profile-icon *ngIf=\"hasUser$ | async\" fxFlex=\"nogrow\"></rxap-user-profile-icon>\n <div fxFlex=\"nogrow\" *ngIf=\"settingsMenuPanel\">\n <button mat-icon-button [matMenuTriggerFor]=\"settingsMenuPanel\">\n <mat-icon>settings</mat-icon>\n </button>\n </div>\n <rxap-sign-out fxFlex=\"nogrow\"></rxap-sign-out>\n </div>\n </mat-toolbar-row>\n</mat-toolbar>\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n", styles: [".content{width:100%;height:64px}\n"] }]
147
- }], function () { return [{ type: i7.HeaderService, decorators: [{
148
- type: Inject,
149
- args: [HeaderService]
150
- }] }, { type: i8.UserService, decorators: [{
151
- type: Inject,
152
- args: [UserService]
153
- }] }, { type: undefined, decorators: [{
154
- type: Optional
155
- }, {
156
- type: Inject,
157
- args: [RXAP_HEADER_COMPONENT]
158
- }] }]; }, { sidenav: [{
159
- type: Input
160
- }], color: [{
161
- type: Input
162
- }], settingsMenuPanel: [{
163
- type: Input
164
- }] }); })();
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../libs/layout/src/lib/header/header.component.ts","../../../../../../libs/layout/src/lib/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ChangeDetectionStrategy,\n  OnDestroy,\n  Input,\n  Optional,\n  Inject\n} from '@angular/core';\nimport { Constructor } from '@rxap/utilities';\nimport {\n  Subscription,\n  Observable\n} from 'rxjs';\nimport {\n  tap,\n  map\n} from 'rxjs/operators';\nimport { MatSidenav } from '@angular/material/sidenav';\nimport { UserService } from '@rxap/authentication';\nimport { RXAP_HEADER_COMPONENT } from '../tokens';\nimport { HeaderService } from '@rxap/services';\nimport {\n  MatMenuPanel,\n  MatMenuModule\n} from '@angular/material/menu';\nimport { ThemePalette } from '@angular/material/core';\nimport { NavigationProgressBarComponent } from './navigation-progress-bar/navigation-progress-bar.component';\nimport { SignOutComponent } from './sign-out/sign-out.component';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { UserProfileIconComponent } from './user-profile-icon/user-profile-icon.component';\nimport { AppsButtonComponent } from './apps-button/apps-button.component';\nimport { LanguageSelectorComponent } from './language-selector/language-selector.component';\nimport { SidenavToggleButtonComponent } from './sidenav-toggle-button/sidenav-toggle-button.component';\nimport { FlexModule } from '@angular/flex-layout/flex';\nimport {\n  NgClass,\n  NgFor,\n  NgComponentOutlet,\n  NgIf,\n  AsyncPipe\n} from '@angular/common';\nimport { ExtendedModule } from '@angular/flex-layout/extended';\nimport { MatToolbarModule } from '@angular/material/toolbar';\n\n@Component({\n  selector:        'rxap-header',\n  templateUrl:     './header.component.html',\n  styleUrls:       [ './header.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host:            {\n    class: 'rxap-layout-header'\n  },\n  standalone:      true,\n  imports:         [\n    MatToolbarModule,\n    ExtendedModule,\n    NgClass,\n    NgFor,\n    NgComponentOutlet,\n    FlexModule,\n    NgIf,\n    SidenavToggleButtonComponent,\n    LanguageSelectorComponent,\n    AppsButtonComponent,\n    UserProfileIconComponent,\n    MatButtonModule,\n    MatMenuModule,\n    MatIconModule,\n    SignOutComponent,\n    NavigationProgressBarComponent,\n    AsyncPipe\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  public hasUser$: Observable<boolean>;\n\n  @Input()\n  public color: ThemePalette = 'primary';\n\n  @Input()\n  public settingsMenuPanel?: MatMenuPanel;\n\n  constructor(\n    @Inject(HeaderService)\n    public readonly headerComponentService: HeaderService,\n    @Inject(UserService)\n    private readonly userService: UserService<any>,\n    @Optional() @Inject(RXAP_HEADER_COMPONENT) public headerComponent: any\n  ) {\n    this.hasUser$ = this.userService.user$.pipe(map(Boolean));\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","<mat-toolbar [ngClass]=\"{ open: sidenav?.opened }\" [color]=\"color\" class=\"mat-elevation-z3\">\n  <mat-toolbar-row *ngFor=\"let headerComponent of components\">\n    <ng-container *ngComponentOutlet=\"headerComponent\"></ng-container>\n  </mat-toolbar-row>\n  <mat-toolbar-row>\n    <div\n      fxLayout=\"row\"\n      fxLayoutAlign=\"space-between center\"\n      fxLayoutGap=\"16px\"\n      class=\"content\"\n    >\n      <rxap-sidenav-toggle-button *ngIf=\"sidenav\" fxFlex=\"nogrow\" [sidenav]=\"sidenav\"></rxap-sidenav-toggle-button>\n      <div fxFlex=\"grow\">\n        <ng-content></ng-content>\n      </div>\n      <rxap-language-selector fxFlex=\"nogrow\"></rxap-language-selector>\n      <rxap-apps-button fxFlex=\"nogrow\"></rxap-apps-button>\n      <rxap-user-profile-icon *ngIf=\"hasUser$ | async\" fxFlex=\"nogrow\"></rxap-user-profile-icon>\n      <div fxFlex=\"nogrow\" *ngIf=\"settingsMenuPanel\">\n        <button mat-icon-button [matMenuTriggerFor]=\"settingsMenuPanel\">\n          <mat-icon>settings</mat-icon>\n        </button>\n      </div>\n      <rxap-sign-out fxFlex=\"nogrow\"></rxap-sign-out>\n    </div>\n  </mat-toolbar-row>\n</mat-toolbar>\n<rxap-navigation-progress-bar></rxap-navigation-progress-bar>\n"]}
51
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: HeaderComponent, decorators: [{
52
+ type: Component,
53
+ args: [{ selector: 'rxap-header', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
54
+ MatToolbarModule,
55
+ NgClass,
56
+ NgIf,
57
+ MatButtonModule,
58
+ MatMenuModule,
59
+ MatIconModule,
60
+ LanguageSelectorComponent,
61
+ MatFormFieldModule,
62
+ StopPropagationDirective,
63
+ MatSelectModule,
64
+ FormsModule,
65
+ MatOptionModule,
66
+ DataSourceCollectionDirective,
67
+ MatSlideToggleModule,
68
+ AsyncPipe,
69
+ NavigationProgressBarComponent,
70
+ UserProfileIconComponent,
71
+ AppsButtonComponent,
72
+ SettingsButtonComponent,
73
+ StatusIndicatorComponent,
74
+ ], template: "<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 <rxap-status-indicator class=\"grow-0\"></rxap-status-indicator>\n <div class=\"grow\">\n <ng-content></ng-content>\n </div>\n <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\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" }]
75
+ }], ctorParameters: function () { return [{ type: i2.HeaderService, decorators: [{
76
+ type: Inject,
77
+ args: [HeaderService]
78
+ }] }, { type: undefined, decorators: [{
79
+ type: Optional
80
+ }, {
81
+ type: Inject,
82
+ args: [RXAP_HEADER_COMPONENT]
83
+ }] }]; }, propDecorators: { sidenav: [{
84
+ type: Input
85
+ }], color: [{
86
+ type: Input
87
+ }] } });
88
+ //# 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  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 { StatusIndicatorComponent } from '@rxap/ngx-status-check';\nimport { HeaderService } 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 { SettingsButtonComponent } from './settings-button/settings-button.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    SettingsButtonComponent,\n    StatusIndicatorComponent,\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  constructor(\n    @Inject(HeaderService)\n    public readonly headerComponentService: HeaderService,\n    @Optional() @Inject(RXAP_HEADER_COMPONENT) public headerComponent: any,\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    <rxap-status-indicator class=\"grow-0\"></rxap-status-indicator>\n    <div class=\"grow\">\n      <ng-content></ng-content>\n    </div>\n    <rxap-apps-button class=\"grow-0\"></rxap-apps-button>\n    <rxap-settings-button class=\"grow-0\"></rxap-settings-button>\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"]}
@@ -1,128 +1,35 @@
1
- import { Component, ChangeDetectionStrategy, Injectable, Inject } from '@angular/core';
2
- import { ConfigService } from '@rxap/config';
1
+ import { ChangeDetectionStrategy, Component, } from '@angular/core';
3
2
  import { MatOptionModule } from '@angular/material/core';
4
3
  import { FormsModule } from '@angular/forms';
5
4
  import { MatSelectModule } from '@angular/material/select';
5
+ import { StopPropagationDirective } from '@rxap/directives';
6
6
  import { MatFormFieldModule } from '@angular/material/form-field';
7
- import { NgIf, NgFor, KeyValuePipe } from '@angular/common';
7
+ import { KeyValuePipe, NgFor, NgIf, } from '@angular/common';
8
+ import { LanguageSelectorService } from '../../language-selector.service';
8
9
  import * as i0 from "@angular/core";
9
- import * as i1 from "@rxap/config";
10
+ import * as i1 from "../../language-selector.service";
10
11
  import * as i2 from "@angular/material/form-field";
11
12
  import * as i3 from "@angular/material/select";
12
13
  import * as i4 from "@angular/material/core";
13
14
  import * as i5 from "@angular/forms";
14
- function LanguageSelectorComponent_ng_template_0_mat_option_3_Template(rf, ctx) { if (rf & 1) {
15
- i0.ɵɵelementStart(0, "mat-option", 4);
16
- i0.ɵɵtext(1);
17
- i0.ɵɵelementEnd();
18
- } if (rf & 2) {
19
- const item_r2 = ctx.$implicit;
20
- i0.ɵɵproperty("value", item_r2.key);
21
- i0.ɵɵadvance(1);
22
- i0.ɵɵtextInterpolate(item_r2.value);
23
- } }
24
- function LanguageSelectorComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
25
- const _r4 = i0.ɵɵgetCurrentView();
26
- i0.ɵɵelementStart(0, "div")(1, "mat-form-field", 1)(2, "mat-select", 2);
27
- i0.ɵɵlistener("ngModelChange", function LanguageSelectorComponent_ng_template_0_Template_mat_select_ngModelChange_2_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.language.setLanguage($event)); });
28
- i0.ɵɵtemplate(3, LanguageSelectorComponent_ng_template_0_mat_option_3_Template, 2, 2, "mat-option", 3);
29
- i0.ɵɵpipe(4, "keyvalue");
30
- i0.ɵɵelementEnd()()();
31
- } if (rf & 2) {
32
- const ctx_r0 = i0.ɵɵnextContext();
33
- i0.ɵɵadvance(2);
34
- i0.ɵɵproperty("ngModel", ctx_r0.language.selectedLanguage);
35
- i0.ɵɵadvance(1);
36
- i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(4, 2, ctx_r0.language.languages));
37
- } }
38
- export const RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY = 'rxap__selected_language';
39
- export const RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY = 'rxap__selected_language_last_change';
40
- class LanguageSelectorService {
41
- constructor(config) {
42
- this.config = config;
43
- this.languages = this.config.get('i18n.languages') ?? {};
44
- this.defaultLanguage =
45
- this.config.get('i18n.defaultLanguage') ??
46
- Object.keys(this.languages)[0] ??
47
- 'en';
48
- this.selectedLanguage =
49
- localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY) ??
50
- this.defaultLanguage;
51
- }
52
- setLanguage(language) {
53
- if (language !== this.selectedLanguage) {
54
- this.redirect(language);
55
- }
56
- }
57
- autoRedirect() {
58
- if (localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY)) {
59
- this.redirect(localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY));
60
- }
61
- }
62
- redirect(language) {
63
- const currentUrl = location.origin + location.pathname + location.search;
64
- const redirectUrl = location.origin +
65
- `/${language}` +
66
- location.pathname.replace(new RegExp(`^\/${this.selectedLanguage}`), '') +
67
- location.search;
68
- this.selectedLanguage = language;
69
- localStorage.setItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY, language);
70
- if (currentUrl !== redirectUrl) {
71
- if (this.checkLastChange()) {
72
- location.replace(redirectUrl);
73
- }
74
- }
75
- else {
76
- console.log('Redirect not required');
77
- }
78
- }
79
- checkLastChange() {
80
- const lastChangeString = localStorage.getItem(RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY);
81
- if (lastChangeString) {
82
- if (Date.now() - parseInt(lastChangeString, 10) < 1000) {
83
- return false;
84
- }
85
- }
86
- localStorage.setItem(RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY, Date.now().toFixed(0));
87
- return true;
88
- }
89
- static { this.ɵfac = function LanguageSelectorService_Factory(t) { return new (t || LanguageSelectorService)(i0.ɵɵinject(ConfigService)); }; }
90
- static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: LanguageSelectorService, factory: LanguageSelectorService.ɵfac, providedIn: 'root' }); }
91
- }
92
- export { LanguageSelectorService };
93
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LanguageSelectorService, [{
94
- type: Injectable,
95
- args: [{ providedIn: 'root' }]
96
- }], function () { return [{ type: i1.ConfigService, decorators: [{
97
- type: Inject,
98
- args: [ConfigService]
99
- }] }]; }, null); })();
100
- class LanguageSelectorComponent {
15
+ export class LanguageSelectorComponent {
101
16
  constructor(language) {
102
17
  this.language = language;
103
18
  }
104
- static { this.ɵfac = function LanguageSelectorComponent_Factory(t) { return new (t || LanguageSelectorComponent)(i0.ɵɵdirectiveInject(LanguageSelectorService)); }; }
105
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LanguageSelectorComponent, selectors: [["rxap-language-selector"]], hostAttrs: [1, "rxap-language-selector"], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 3, consts: [[3, "ngIf"], ["appearance", "outline", 1, "language-selector"], [3, "ngModel", "ngModelChange"], [3, "value", 4, "ngFor", "ngForOf"], [3, "value"]], template: function LanguageSelectorComponent_Template(rf, ctx) { if (rf & 1) {
106
- i0.ɵɵtemplate(0, LanguageSelectorComponent_ng_template_0_Template, 5, 4, "ng-template", 0);
107
- i0.ɵɵpipe(1, "keyvalue");
108
- } if (rf & 2) {
109
- i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(1, 1, ctx.language.languages).length);
110
- } }, dependencies: [NgIf,
111
- MatFormFieldModule, i2.MatFormField, MatSelectModule, i3.MatSelect, i4.MatOption, FormsModule, i5.NgControlStatus, i5.NgModel, NgFor,
112
- MatOptionModule,
113
- KeyValuePipe], styles: [".language-selector[_ngcontent-%COMP%]{width:142px}.language-selector[_ngcontent-%COMP%] .mat-form-field-wrapper{padding-bottom:0}.language-selector[_ngcontent-%COMP%] .mat-form-field-wrapper .mat-form-field-infix{padding:12px 0;border-width:6px}.language-selector[_ngcontent-%COMP%] .mat-form-field-wrapper .mat-form-field-infix .mat-select-arrow-wrapper{transform:translateY(0)}"], changeDetection: 0 }); }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LanguageSelectorComponent, deps: [{ token: i1.LanguageSelectorService }], target: i0.ɵɵFactoryTarget.Component }); }
20
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: LanguageSelectorComponent, isStandalone: true, selector: "rxap-language-selector", ngImport: i0, template: "<ng-template [ngIf]=\"(language.languages | keyvalue).length\">\n <div>\n <mat-form-field appearance=\"outline\" class=\"language-selector\" rxapStopPropagation>\n <mat-label i18n>Select Language</mat-label>\n <mat-select (ngModelChange)=\"language.setLanguage($event)\" [ngModel]=\"language.selectedLanguage\">\n <mat-option *ngFor=\"let item of language.languages | keyvalue\" [value]=\"item.key\">{{item.value}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n</ng-template>\n", styles: [".language-selector{width:calc(100% - 32px);margin:0 16px}.language-selector ::ng-deep .mat-form-field-wrapper{padding-bottom:0}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix{padding:12px 0;border-width:6px}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix .mat-select-arrow-wrapper{transform:translateY(0)}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: StopPropagationDirective, selector: "[rxapStopPropagation]" }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "pipe", type: KeyValuePipe, name: "keyvalue" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
114
21
  }
115
- export { LanguageSelectorComponent };
116
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LanguageSelectorComponent, [{
117
- type: Component,
118
- args: [{ selector: 'rxap-language-selector', changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'rxap-language-selector' }, standalone: true, imports: [
119
- NgIf,
120
- MatFormFieldModule,
121
- MatSelectModule,
122
- FormsModule,
123
- NgFor,
124
- MatOptionModule,
125
- KeyValuePipe
126
- ], template: "<ng-template [ngIf]=\"(language.languages | keyvalue).length\">\n <div>\n <mat-form-field appearance=\"outline\" class=\"language-selector\">\n <mat-select (ngModelChange)=\"language.setLanguage($event)\" [ngModel]=\"language.selectedLanguage\">\n <mat-option *ngFor=\"let item of language.languages | keyvalue\" [value]=\"item.key\">{{item.value}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n</ng-template>\n", styles: [".language-selector{width:142px}.language-selector ::ng-deep .mat-form-field-wrapper{padding-bottom:0}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix{padding:12px 0;border-width:6px}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix .mat-select-arrow-wrapper{transform:translateY(0)}\n"] }]
127
- }], function () { return [{ type: LanguageSelectorService }]; }, null); })();
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-selector.component.js","sourceRoot":"","sources":["../../../../../../../libs/layout/src/lib/header/language-selector/language-selector.component.ts","../../../../../../../libs/layout/src/lib/header/language-selector/language-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  Injectable,\n  Inject\n} from '@angular/core';\nimport { ConfigService } from '@rxap/config';\nimport { MatOptionModule } from '@angular/material/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport {\n  NgIf,\n  NgFor,\n  KeyValuePipe\n} from '@angular/common';\n\nexport const RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY        =\n               'rxap__selected_language';\nexport const RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY =\n               'rxap__selected_language_last_change';\n\n@Injectable({ providedIn: 'root' })\nexport class LanguageSelectorService {\n  public readonly languages: any;\n  public readonly defaultLanguage: string;\n  public selectedLanguage: string;\n\n  constructor(\n    @Inject(ConfigService)\n    private readonly config: ConfigService\n  ) {\n    this.languages = this.config.get<any>('i18n.languages') ?? {};\n    this.defaultLanguage =\n      this.config.get('i18n.defaultLanguage') ??\n      Object.keys(this.languages)[0] ??\n      'en';\n    this.selectedLanguage =\n      localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY) ??\n      this.defaultLanguage;\n  }\n\n  public setLanguage(language: string) {\n    if (language !== this.selectedLanguage) {\n      this.redirect(language);\n    }\n  }\n\n  public autoRedirect() {\n    if (localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY)) {\n      this.redirect(\n        localStorage.getItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY)!\n      );\n    }\n  }\n\n  private redirect(language: string) {\n    const currentUrl = location.origin + location.pathname + location.search;\n    const redirectUrl =\n      location.origin +\n      `/${language}` +\n      location.pathname.replace(new RegExp(`^\\/${this.selectedLanguage}`), '') +\n      location.search;\n    this.selectedLanguage = language;\n    localStorage.setItem(RXAP_SELECTED_LANGUAGE_LOCAL_STORAGE_KEY, language);\n    if (currentUrl !== redirectUrl) {\n      if (this.checkLastChange()) {\n        location.replace(redirectUrl);\n      }\n    } else {\n      console.log('Redirect not required');\n    }\n  }\n\n  private checkLastChange(): boolean {\n    const lastChangeString = localStorage.getItem(\n      RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY\n    );\n    if (lastChangeString) {\n      if (Date.now() - parseInt(lastChangeString, 10) < 1000) {\n        return false;\n      }\n    }\n    localStorage.setItem(\n      RXAP_SELECTED_LANGUAGE_CHANGE_LOCAL_STORAGE_KEY,\n      Date.now().toFixed(0)\n    );\n    return true;\n  }\n}\n\n@Component({\n  selector:        'rxap-language-selector',\n  templateUrl:     './language-selector.component.html',\n  styleUrls:       [ './language-selector.component.scss' ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host:            { class: 'rxap-language-selector' },\n  standalone:      true,\n  imports: [\n    NgIf,\n    MatFormFieldModule,\n    MatSelectModule,\n    FormsModule,\n    NgFor,\n    MatOptionModule,\n    KeyValuePipe\n  ]\n})\nexport class LanguageSelectorComponent {\n  constructor(public readonly language: LanguageSelectorService) {}\n}\n","<ng-template [ngIf]=\"(language.languages | keyvalue).length\">\n  <div>\n    <mat-form-field appearance=\"outline\" class=\"language-selector\">\n      <mat-select (ngModelChange)=\"language.setLanguage($event)\" [ngModel]=\"language.selectedLanguage\">\n        <mat-option *ngFor=\"let item of language.languages | keyvalue\" [value]=\"item.key\">{{item.value}}</mat-option>\n      </mat-select>\n    </mat-form-field>\n  </div>\n</ng-template>\n"]}
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: LanguageSelectorComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ selector: 'rxap-language-selector', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
25
+ NgIf,
26
+ MatFormFieldModule,
27
+ StopPropagationDirective,
28
+ MatSelectModule,
29
+ FormsModule,
30
+ NgFor,
31
+ MatOptionModule,
32
+ KeyValuePipe,
33
+ ], template: "<ng-template [ngIf]=\"(language.languages | keyvalue).length\">\n <div>\n <mat-form-field appearance=\"outline\" class=\"language-selector\" rxapStopPropagation>\n <mat-label i18n>Select Language</mat-label>\n <mat-select (ngModelChange)=\"language.setLanguage($event)\" [ngModel]=\"language.selectedLanguage\">\n <mat-option *ngFor=\"let item of language.languages | keyvalue\" [value]=\"item.key\">{{item.value}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n</ng-template>\n", styles: [".language-selector{width:calc(100% - 32px);margin:0 16px}.language-selector ::ng-deep .mat-form-field-wrapper{padding-bottom:0}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix{padding:12px 0;border-width:6px}.language-selector ::ng-deep .mat-form-field-wrapper .mat-form-field-infix .mat-select-arrow-wrapper{transform:translateY(0)}\n"] }]
34
+ }], ctorParameters: function () { return [{ type: i1.LanguageSelectorService }]; } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbGFuZ3VhZ2Utc2VsZWN0b3IvbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbGFuZ3VhZ2Utc2VsZWN0b3IvbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUNMLFlBQVksRUFDWixLQUFLLEVBQ0wsSUFBSSxHQUNMLE1BQU0saUJBQWlCLENBQUM7QUFDekIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0saUNBQWlDLENBQUM7Ozs7Ozs7QUFtQjFFLE1BQU0sT0FBTyx5QkFBeUI7SUFDcEMsWUFBNEIsUUFBaUM7UUFBakMsYUFBUSxHQUFSLFFBQVEsQ0FBeUI7SUFDN0QsQ0FBQzs4R0FGVSx5QkFBeUI7a0dBQXpCLHlCQUF5QixrRkNqQ3RDLDBnQkFVQSxtYURhSSxJQUFJLDRGQUNKLGtCQUFrQiwyU0FDbEIsd0JBQXdCLGlFQUN4QixlQUFlLHVUQUNmLFdBQVcsK1ZBQ1gsS0FBSyxrSEFDTCxlQUFlLDBCQUNmLFlBQVk7OzJGQUdILHlCQUF5QjtrQkFqQnJDLFNBQVM7K0JBQ0Usd0JBQXdCLG1CQUdqQix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUDt3QkFDUCxJQUFJO3dCQUNKLGtCQUFrQjt3QkFDbEIsd0JBQXdCO3dCQUN4QixlQUFlO3dCQUNmLFdBQVc7d0JBQ1gsS0FBSzt3QkFDTCxlQUFlO3dCQUNmLFlBQVk7cUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdE9wdGlvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3QnO1xuaW1wb3J0IHsgU3RvcFByb3BhZ2F0aW9uRGlyZWN0aXZlIH0gZnJvbSAnQHJ4YXAvZGlyZWN0aXZlcyc7XG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcbmltcG9ydCB7XG4gIEtleVZhbHVlUGlwZSxcbiAgTmdGb3IsXG4gIE5nSWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBMYW5ndWFnZVNlbGVjdG9yU2VydmljZSB9IGZyb20gJy4uLy4uL2xhbmd1YWdlLXNlbGVjdG9yLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyeGFwLWxhbmd1YWdlLXNlbGVjdG9yJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2xhbmd1YWdlLXNlbGVjdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbICcuL2xhbmd1YWdlLXNlbGVjdG9yLmNvbXBvbmVudC5zY3NzJyBdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE5nSWYsXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgIFN0b3BQcm9wYWdhdGlvbkRpcmVjdGl2ZSxcbiAgICBNYXRTZWxlY3RNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgTmdGb3IsXG4gICAgTWF0T3B0aW9uTW9kdWxlLFxuICAgIEtleVZhbHVlUGlwZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTGFuZ3VhZ2VTZWxlY3RvckNvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBsYW5ndWFnZTogTGFuZ3VhZ2VTZWxlY3RvclNlcnZpY2UpIHtcbiAgfVxuXG59XG4iLCI8bmctdGVtcGxhdGUgW25nSWZdPVwiKGxhbmd1YWdlLmxhbmd1YWdlcyB8IGtleXZhbHVlKS5sZW5ndGhcIj5cbiAgPGRpdj5cbiAgICA8bWF0LWZvcm0tZmllbGQgYXBwZWFyYW5jZT1cIm91dGxpbmVcIiBjbGFzcz1cImxhbmd1YWdlLXNlbGVjdG9yXCIgcnhhcFN0b3BQcm9wYWdhdGlvbj5cbiAgICAgIDxtYXQtbGFiZWwgaTE4bj5TZWxlY3QgTGFuZ3VhZ2U8L21hdC1sYWJlbD5cbiAgICAgIDxtYXQtc2VsZWN0IChuZ01vZGVsQ2hhbmdlKT1cImxhbmd1YWdlLnNldExhbmd1YWdlKCRldmVudClcIiBbbmdNb2RlbF09XCJsYW5ndWFnZS5zZWxlY3RlZExhbmd1YWdlXCI+XG4gICAgICAgIDxtYXQtb3B0aW9uICpuZ0Zvcj1cImxldCBpdGVtIG9mIGxhbmd1YWdlLmxhbmd1YWdlcyB8IGtleXZhbHVlXCIgW3ZhbHVlXT1cIml0ZW0ua2V5XCI+e3tpdGVtLnZhbHVlfX08L21hdC1vcHRpb24+XG4gICAgICA8L21hdC1zZWxlY3Q+XG4gICAgPC9tYXQtZm9ybS1maWVsZD5cbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuIl19
@@ -1,35 +1,30 @@
1
- import { Component, ChangeDetectionStrategy, Inject } from '@angular/core';
2
- import { Router, NavigationStart, NavigationEnd, NavigationCancel } from '@angular/router';
3
- import { filter, map } from 'rxjs/operators';
1
+ import { ChangeDetectionStrategy, Component, Inject, } from '@angular/core';
2
+ import { NavigationCancel, NavigationEnd, NavigationStart, Router, } from '@angular/router';
3
+ import { filter, map, } from 'rxjs/operators';
4
4
  import { MatProgressBarModule } from '@angular/material/progress-bar';
5
- import { NgIf, AsyncPipe } from '@angular/common';
5
+ import { AsyncPipe, NgIf, } from '@angular/common';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/material/progress-bar";
8
8
  import * as i2 from "@angular/router";
9
- function NavigationProgressBarComponent_mat_progress_bar_0_Template(rf, ctx) { if (rf & 1) {
10
- i0.ɵɵelement(0, "mat-progress-bar", 1);
11
- } }
12
- class NavigationProgressBarComponent {
9
+ export class NavigationProgressBarComponent {
13
10
  constructor(router) {
14
11
  this.router = router;
15
12
  this.navigating$ = this.router.events.pipe(filter(event => event instanceof NavigationStart ||
16
13
  event instanceof NavigationEnd ||
17
14
  event instanceof NavigationCancel), map(event => event instanceof NavigationStart));
18
15
  }
19
- static { this.ɵfac = function NavigationProgressBarComponent_Factory(t) { return new (t || NavigationProgressBarComponent)(i0.ɵɵdirectiveInject(Router)); }; }
20
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NavigationProgressBarComponent, selectors: [["rxap-navigation-progress-bar"]], hostAttrs: [1, "rxap-navigation-progress-bar"], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 3, consts: [["mode", "indeterminate", "color", "accent", 4, "ngIf"], ["mode", "indeterminate", "color", "accent"]], template: function NavigationProgressBarComponent_Template(rf, ctx) { if (rf & 1) {
21
- i0.ɵɵtemplate(0, NavigationProgressBarComponent_mat_progress_bar_0_Template, 1, 0, "mat-progress-bar", 0);
22
- i0.ɵɵpipe(1, "async");
23
- } if (rf & 2) {
24
- i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(1, 1, ctx.navigating$));
25
- } }, dependencies: [NgIf, MatProgressBarModule, i1.MatProgressBar, AsyncPipe], changeDetection: 0 }); }
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: NavigationProgressBarComponent, deps: [{ token: Router }], target: i0.ɵɵFactoryTarget.Component }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: NavigationProgressBarComponent, isStandalone: true, selector: "rxap-navigation-progress-bar", ngImport: i0, template: "<mat-progress-bar\n *ngIf=\"navigating$ | async\"\n color=\"accent\"\n mode=\"indeterminate\"\n></mat-progress-bar>\n", styles: [""], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatProgressBarModule }, { kind: "component", type: i1.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
18
  }
27
- export { NavigationProgressBarComponent };
28
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NavigationProgressBarComponent, [{
29
- type: Component,
30
- args: [{ selector: 'rxap-navigation-progress-bar', changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'rxap-navigation-progress-bar' }, standalone: true, imports: [NgIf, MatProgressBarModule, AsyncPipe], template: "<mat-progress-bar\n *ngIf=\"navigating$ | async\"\n mode=\"indeterminate\"\n color=\"accent\"\n></mat-progress-bar>\n" }]
31
- }], function () { return [{ type: i2.Router, decorators: [{
32
- type: Inject,
33
- args: [Router]
34
- }] }]; }, null); })();
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsTUFBTSxFQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCxNQUFNLEVBQ04sZUFBZSxFQUNmLGFBQWEsRUFDYixnQkFBZ0IsRUFDakIsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQ0wsTUFBTSxFQUNOLEdBQUcsRUFDSixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3RFLE9BQU8sRUFDTCxJQUFJLEVBQ0osU0FBUyxFQUNWLE1BQU0saUJBQWlCLENBQUM7Ozs7O0lDcEJ6QixzQ0FJb0I7O0FEa0JwQixNQVNhLDhCQUE4QjtJQUl6QyxZQUNrQyxNQUFjO1FBQWQsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUU5QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDeEMsTUFBTSxDQUNKLEtBQUssQ0FBQyxFQUFFLENBQ04sS0FBSyxZQUFZLGVBQWU7WUFDaEMsS0FBSyxZQUFZLGFBQWE7WUFDOUIsS0FBSyxZQUFZLGdCQUFnQixDQUNwQyxFQUNELEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssWUFBWSxlQUFlLENBQUMsQ0FDL0MsQ0FBQztJQUNKLENBQUM7K0ZBaEJVLDhCQUE4Qix1QkFLL0IsTUFBTTtvRUFMTCw4QkFBOEI7WUMvQjNDLHlHQUlvQjs7O1lBSGpCLDREQUF5Qjs0QkQ0QlAsSUFBSSxFQUFFLG9CQUFvQixxQkFBRSxTQUFTOztTQUU3Qyw4QkFBOEI7dUZBQTlCLDhCQUE4QjtjQVQxQyxTQUFTOzJCQUNTLDhCQUE4QixtQkFHOUIsdUJBQXVCLENBQUMsTUFBTSxRQUM5QixFQUFFLEtBQUssRUFBRSw4QkFBOEIsRUFBRSxjQUN6QyxJQUFJLFdBQ0osQ0FBRSxJQUFJLEVBQUUsb0JBQW9CLEVBQUUsU0FBUyxDQUFFOztzQkFPdkQsTUFBTTt1QkFBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgSW5qZWN0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtcbiAgUm91dGVyLFxuICBOYXZpZ2F0aW9uU3RhcnQsXG4gIE5hdmlnYXRpb25FbmQsXG4gIE5hdmlnYXRpb25DYW5jZWxcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7XG4gIGZpbHRlcixcbiAgbWFwXG59IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IE1hdFByb2dyZXNzQmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3MtYmFyJztcbmltcG9ydCB7XG4gIE5nSWYsXG4gIEFzeW5jUGlwZVxufSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICAgICAgICAncnhhcC1uYXZpZ2F0aW9uLXByb2dyZXNzLWJhcicsXG4gIHRlbXBsYXRlVXJsOiAgICAgJy4vbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6ICAgICAgIFsgJy4vbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LnNjc3MnIF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBob3N0OiAgICAgICAgICAgIHsgY2xhc3M6ICdyeGFwLW5hdmlnYXRpb24tcHJvZ3Jlc3MtYmFyJyB9LFxuICBzdGFuZGFsb25lOiAgICAgIHRydWUsXG4gIGltcG9ydHM6ICAgICAgICAgWyBOZ0lmLCBNYXRQcm9ncmVzc0Jhck1vZHVsZSwgQXN5bmNQaXBlIF1cbn0pXG5leHBvcnQgY2xhc3MgTmF2aWdhdGlvblByb2dyZXNzQmFyQ29tcG9uZW50IHtcblxuICBwdWJsaWMgbmF2aWdhdGluZyQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoUm91dGVyKSBwdWJsaWMgcmVhZG9ubHkgcm91dGVyOiBSb3V0ZXJcbiAgKSB7XG4gICAgdGhpcy5uYXZpZ2F0aW5nJCA9IHRoaXMucm91dGVyLmV2ZW50cy5waXBlKFxuICAgICAgZmlsdGVyKFxuICAgICAgICBldmVudCA9PlxuICAgICAgICAgIGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvblN0YXJ0IHx8XG4gICAgICAgICAgZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uRW5kIHx8XG4gICAgICAgICAgZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uQ2FuY2VsXG4gICAgICApLFxuICAgICAgbWFwKGV2ZW50ID0+IGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvblN0YXJ0KVxuICAgICk7XG4gIH1cblxufVxuIiwiPG1hdC1wcm9ncmVzcy1iYXJcbiAgKm5nSWY9XCJuYXZpZ2F0aW5nJCB8IGFzeW5jXCJcbiAgbW9kZT1cImluZGV0ZXJtaW5hdGVcIlxuICBjb2xvcj1cImFjY2VudFwiXG4+PC9tYXQtcHJvZ3Jlc3MtYmFyPlxuIl19
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: NavigationProgressBarComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: 'rxap-navigation-progress-bar', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
22
+ NgIf,
23
+ MatProgressBarModule,
24
+ AsyncPipe,
25
+ ], template: "<mat-progress-bar\n *ngIf=\"navigating$ | async\"\n color=\"accent\"\n mode=\"indeterminate\"\n></mat-progress-bar>\n" }]
26
+ }], ctorParameters: function () { return [{ type: i2.Router, decorators: [{
27
+ type: Inject,
28
+ args: [Router]
29
+ }] }]; } });
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIvbmF2aWdhdGlvbi1wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsYUFBYSxFQUNiLGVBQWUsRUFDZixNQUFNLEdBQ1AsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQ0wsTUFBTSxFQUNOLEdBQUcsR0FDSixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3RFLE9BQU8sRUFDTCxTQUFTLEVBQ1QsSUFBSSxHQUNMLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFjekIsTUFBTSxPQUFPLDhCQUE4QjtJQUl6QyxZQUNrQyxNQUFjO1FBQWQsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUU5QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDeEMsTUFBTSxDQUNKLEtBQUssQ0FBQyxFQUFFLENBQ04sS0FBSyxZQUFZLGVBQWU7WUFDaEMsS0FBSyxZQUFZLGFBQWE7WUFDOUIsS0FBSyxZQUFZLGdCQUFnQixDQUNwQyxFQUNELEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssWUFBWSxlQUFlLENBQUMsQ0FDL0MsQ0FBQztJQUNKLENBQUM7OEdBaEJVLDhCQUE4QixrQkFLL0IsTUFBTTtrR0FMTCw4QkFBOEIsd0ZDbEMzQywwSEFLQSwwRER3QkksSUFBSSw0RkFDSixvQkFBb0Isb05BQ3BCLFNBQVM7OzJGQUdBLDhCQUE4QjtrQkFaMUMsU0FBUzsrQkFDRSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQO3dCQUNQLElBQUk7d0JBQ0osb0JBQW9CO3dCQUNwQixTQUFTO3FCQUNWOzswQkFPRSxNQUFNOzJCQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbmplY3QsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtcbiAgTmF2aWdhdGlvbkNhbmNlbCxcbiAgTmF2aWdhdGlvbkVuZCxcbiAgTmF2aWdhdGlvblN0YXJ0LFxuICBSb3V0ZXIsXG59IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge1xuICBmaWx0ZXIsXG4gIG1hcCxcbn0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9wcm9ncmVzcy1iYXInO1xuaW1wb3J0IHtcbiAgQXN5bmNQaXBlLFxuICBOZ0lmLFxufSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyeGFwLW5hdmlnYXRpb24tcHJvZ3Jlc3MtYmFyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL25hdmlnYXRpb24tcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbICcuL25hdmlnYXRpb24tcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5zY3NzJyBdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE5nSWYsXG4gICAgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUsXG4gICAgQXN5bmNQaXBlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZpZ2F0aW9uUHJvZ3Jlc3NCYXJDb21wb25lbnQge1xuXG4gIHB1YmxpYyBuYXZpZ2F0aW5nJDogT2JzZXJ2YWJsZTxib29sZWFuPjtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChSb3V0ZXIpIHB1YmxpYyByZWFkb25seSByb3V0ZXI6IFJvdXRlcixcbiAgKSB7XG4gICAgdGhpcy5uYXZpZ2F0aW5nJCA9IHRoaXMucm91dGVyLmV2ZW50cy5waXBlKFxuICAgICAgZmlsdGVyKFxuICAgICAgICBldmVudCA9PlxuICAgICAgICAgIGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvblN0YXJ0IHx8XG4gICAgICAgICAgZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uRW5kIHx8XG4gICAgICAgICAgZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uQ2FuY2VsLFxuICAgICAgKSxcbiAgICAgIG1hcChldmVudCA9PiBldmVudCBpbnN0YW5jZW9mIE5hdmlnYXRpb25TdGFydCksXG4gICAgKTtcbiAgfVxuXG59XG4iLCI8bWF0LXByb2dyZXNzLWJhclxuICAqbmdJZj1cIm5hdmlnYXRpbmckIHwgYXN5bmNcIlxuICBjb2xvcj1cImFjY2VudFwiXG4gIG1vZGU9XCJpbmRldGVybWluYXRlXCJcbj48L21hdC1wcm9ncmVzcy1iYXI+XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, Inject } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Inject, } from '@angular/core';
2
2
  import { ResetService } from '@rxap/services';
3
3
  import { MatIconModule } from '@angular/material/icon';
4
4
  import { MatButtonModule } from '@angular/material/button';
@@ -6,25 +6,18 @@ import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/material/button";
7
7
  import * as i2 from "@angular/material/icon";
8
8
  import * as i3 from "@rxap/services";
9
- class ResetButtonComponent {
9
+ export class ResetButtonComponent {
10
10
  constructor(resetService) {
11
11
  this.resetService = resetService;
12
12
  }
13
- static { this.ɵfac = function ResetButtonComponent_Factory(t) { return new (t || ResetButtonComponent)(i0.ɵɵdirectiveInject(ResetService)); }; }
14
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResetButtonComponent, selectors: [["rxap-reset-button"]], hostAttrs: [1, "rxap-reset-button"], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 0, consts: [["mat-icon-button", "", 3, "click"]], template: function ResetButtonComponent_Template(rf, ctx) { if (rf & 1) {
15
- i0.ɵɵelementStart(0, "button", 0);
16
- i0.ɵɵlistener("click", function ResetButtonComponent_Template_button_click_0_listener() { return ctx.resetService.resetAll(); });
17
- i0.ɵɵelementStart(1, "mat-icon");
18
- i0.ɵɵtext(2, "refresh");
19
- i0.ɵɵelementEnd()();
20
- } }, dependencies: [MatButtonModule, i1.MatIconButton, MatIconModule, i2.MatIcon], changeDetection: 0 }); }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: ResetButtonComponent, deps: [{ token: ResetService }], target: i0.ɵɵFactoryTarget.Component }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.4", type: ResetButtonComponent, isStandalone: true, selector: "rxap-reset-button", ngImport: i0, template: "<button (click)=\"resetService.resetAll()\" mat-icon-button>\n <mat-icon svgIcon=\"refresh\"></mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
21
15
  }
22
- export { ResetButtonComponent };
23
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResetButtonComponent, [{
24
- type: Component,
25
- args: [{ selector: 'rxap-reset-button', changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'rxap-reset-button' }, standalone: true, imports: [MatButtonModule, MatIconModule], template: "<button (click)=\"resetService.resetAll()\" mat-icon-button>\n <mat-icon>refresh</mat-icon>\n</button>\n" }]
26
- }], function () { return [{ type: i3.ResetService, decorators: [{
27
- type: Inject,
28
- args: [ResetService]
29
- }] }]; }, null); })();
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZXQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbGF5b3V0L3NyYy9saWIvaGVhZGVyL3Jlc2V0LWJ1dHRvbi9yZXNldC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvcmVzZXQtYnV0dG9uL3Jlc2V0LWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULHVCQUF1QixFQUN2QixNQUFNLEVBQ1AsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7O0FBRTNELE1BU2Esb0JBQW9CO0lBQy9CLFlBRWtCLFlBQTBCO1FBQTFCLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQ3pDLENBQUM7cUZBSk8sb0JBQW9CLHVCQUVyQixZQUFZO29FQUZYLG9CQUFvQjtZQ2xCakMsaUNBQTBEO1lBQWxELGlHQUFTLDJCQUF1QixJQUFDO1lBQ3ZDLGdDQUFVO1lBQUEsdUJBQU87WUFBQSxpQkFBVyxFQUFBOzRCRGVULGVBQWUsb0JBQUUsYUFBYTs7U0FFdEMsb0JBQW9CO3VGQUFwQixvQkFBb0I7Y0FUaEMsU0FBUzsyQkFDUyxtQkFBbUIsbUJBR25CLHVCQUF1QixDQUFDLE1BQU0sUUFDOUIsRUFBRSxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsY0FDOUIsSUFBSSxXQUNKLENBQUUsZUFBZSxFQUFFLGFBQWEsQ0FBRTs7c0JBSWhELE1BQU07dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIEluamVjdFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJlc2V0U2VydmljZSB9IGZyb20gJ0ByeGFwL3NlcnZpY2VzJztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogICAgICAgICdyeGFwLXJlc2V0LWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAgICAgJy4vcmVzZXQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiAgICAgICBbICcuL3Jlc2V0LWJ1dHRvbi5jb21wb25lbnQuc2NzcycgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGhvc3Q6ICAgICAgICAgICAgeyBjbGFzczogJ3J4YXAtcmVzZXQtYnV0dG9uJyB9LFxuICBzdGFuZGFsb25lOiAgICAgIHRydWUsXG4gIGltcG9ydHM6ICAgICAgICAgWyBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUgXVxufSlcbmV4cG9ydCBjbGFzcyBSZXNldEJ1dHRvbkNvbXBvbmVudCB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoUmVzZXRTZXJ2aWNlKVxuICAgIHB1YmxpYyByZWFkb25seSByZXNldFNlcnZpY2U6IFJlc2V0U2VydmljZVxuICApIHt9XG59XG4iLCI8YnV0dG9uIChjbGljayk9XCJyZXNldFNlcnZpY2UucmVzZXRBbGwoKVwiIG1hdC1pY29uLWJ1dHRvbj5cbiAgPG1hdC1pY29uPnJlZnJlc2g8L21hdC1pY29uPlxuPC9idXR0b24+XG4iXX0=
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.4", ngImport: i0, type: ResetButtonComponent, decorators: [{
17
+ type: Component,
18
+ args: [{ selector: 'rxap-reset-button', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [MatButtonModule, MatIconModule], template: "<button (click)=\"resetService.resetAll()\" mat-icon-button>\n <mat-icon svgIcon=\"refresh\"></mat-icon>\n</button>\n" }]
19
+ }], ctorParameters: function () { return [{ type: i3.ResetService, decorators: [{
20
+ type: Inject,
21
+ args: [ResetService]
22
+ }] }]; } });
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzZXQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXIvbGF5b3V0L3NyYy9saWIvaGVhZGVyL3Jlc2V0LWJ1dHRvbi9yZXNldC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9sYXlvdXQvc3JjL2xpYi9oZWFkZXIvcmVzZXQtYnV0dG9uL3Jlc2V0LWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7O0FBVTNELE1BQU0sT0FBTyxvQkFBb0I7SUFDL0IsWUFFa0IsWUFBMEI7UUFBMUIsaUJBQVksR0FBWixZQUFZLENBQWM7SUFFNUMsQ0FBQzs4R0FMVSxvQkFBb0Isa0JBRXJCLFlBQVk7a0dBRlgsb0JBQW9CLDZFQ2pCakMsd0hBR0EseUREWWEsZUFBZSwyTEFBRSxhQUFhOzsyRkFFOUIsb0JBQW9CO2tCQVJoQyxTQUFTOytCQUNFLG1CQUFtQixtQkFHWix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFFLGVBQWUsRUFBRSxhQUFhLENBQUU7OzBCQUl4QyxNQUFNOzJCQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbmplY3QsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmVzZXRTZXJ2aWNlIH0gZnJvbSAnQHJ4YXAvc2VydmljZXMnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncnhhcC1yZXNldC1idXR0b24nLFxuICB0ZW1wbGF0ZVVybDogJy4vcmVzZXQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbICcuL3Jlc2V0LWJ1dHRvbi5jb21wb25lbnQuc2NzcycgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFsgTWF0QnV0dG9uTW9kdWxlLCBNYXRJY29uTW9kdWxlIF0sXG59KVxuZXhwb3J0IGNsYXNzIFJlc2V0QnV0dG9uQ29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChSZXNldFNlcnZpY2UpXG4gICAgcHVibGljIHJlYWRvbmx5IHJlc2V0U2VydmljZTogUmVzZXRTZXJ2aWNlLFxuICApIHtcbiAgfVxufVxuIiwiPGJ1dHRvbiAoY2xpY2spPVwicmVzZXRTZXJ2aWNlLnJlc2V0QWxsKClcIiBtYXQtaWNvbi1idXR0b24+XG4gIDxtYXQtaWNvbiBzdmdJY29uPVwicmVmcmVzaFwiPjwvbWF0LWljb24+XG48L2J1dHRvbj5cbiJdfQ==