@bravobit/bb-foundation 0.42.1 → 0.42.3

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 (30) hide show
  1. package/auth/lib/auth.service.d.ts +11 -16
  2. package/elements/lib/elements.config.d.ts +2 -83
  3. package/elements/lib/elements.interfaces.d.ts +5 -0
  4. package/elements/lib/elements.module.d.ts +2 -1
  5. package/esm2022/auth/lib/auth.service.mjs +19 -46
  6. package/esm2022/elements/lib/elements.config.mjs +49 -39
  7. package/esm2022/elements/lib/elements.interfaces.mjs +1 -1
  8. package/esm2022/elements/lib/elements.module.mjs +3 -3
  9. package/esm2022/lib/core/services/files.service.mjs +8 -20
  10. package/esm2022/localize/lib/localize.service.mjs +17 -52
  11. package/esm2022/localize/lib/transforms/interpolate.transform.mjs +12 -26
  12. package/esm2022/localize/lib/transforms/plural.transform.mjs +6 -17
  13. package/esm2022/localize/lib/transforms/reference.transform.mjs +7 -17
  14. package/esm2022/recaptcha/lib/recaptcha/recaptcha.component.mjs +2 -2
  15. package/fesm2022/bravobit-bb-foundation-auth.mjs +18 -45
  16. package/fesm2022/bravobit-bb-foundation-auth.mjs.map +1 -1
  17. package/fesm2022/bravobit-bb-foundation-elements.mjs +51 -41
  18. package/fesm2022/bravobit-bb-foundation-elements.mjs.map +1 -1
  19. package/fesm2022/bravobit-bb-foundation-localize.mjs +35 -99
  20. package/fesm2022/bravobit-bb-foundation-localize.mjs.map +1 -1
  21. package/fesm2022/bravobit-bb-foundation-recaptcha.mjs +1 -1
  22. package/fesm2022/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  23. package/fesm2022/bravobit-bb-foundation.mjs +7 -18
  24. package/fesm2022/bravobit-bb-foundation.mjs.map +1 -1
  25. package/lib/core/services/files.service.d.ts +3 -7
  26. package/localize/lib/localize.service.d.ts +10 -14
  27. package/localize/lib/transforms/interpolate.transform.d.ts +4 -5
  28. package/localize/lib/transforms/plural.transform.d.ts +5 -6
  29. package/localize/lib/transforms/reference.transform.d.ts +2 -3
  30. package/package.json +39 -39
@@ -1,28 +1,23 @@
1
- import { Injector, TransferState } from '@angular/core';
2
- import { AuthConfig, AuthRedirectHandler } from './interfaces/config.interface';
3
- import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';
1
+ import { HttpHeaders, HttpParams } from '@angular/common/http';
4
2
  import { AuthProvider, AuthSignInResponse } from './interfaces/provider.interface';
5
- import { Storage } from '@bravobit/bb-foundation/storage';
6
- import { HttpConfig } from '@bravobit/bb-foundation/http';
7
3
  import { Observable } from 'rxjs';
8
- import { Platform } from '@angular/cdk/platform';
9
4
  import { AuthSession } from './auth.session';
10
5
  import * as i0 from "@angular/core";
11
6
  export declare class Auth {
12
- private _storage;
13
- private _injector;
14
- private _platform;
15
- private _httpClient;
16
- private _state?;
17
- private _config?;
18
- private _httpConfig?;
19
- private _handler?;
7
+ private readonly _storage;
8
+ private readonly _injector;
9
+ private readonly _platform;
10
+ private readonly _httpClient;
11
+ private readonly _state?;
12
+ private readonly _config?;
13
+ private readonly _httpConfig?;
14
+ private readonly _handler?;
20
15
  private readonly _authStateKey;
21
16
  private readonly _httpAlias;
22
17
  readonly session: AuthSession;
23
18
  readonly user: Observable<any | null>;
24
19
  private _refreshHandler;
25
- constructor(_storage: Storage, _injector: Injector, _platform: Platform, _httpClient: HttpClient, _state?: TransferState, _config?: AuthConfig, _httpConfig?: HttpConfig, _handler?: AuthRedirectHandler);
20
+ constructor();
26
21
  initialize(): () => Promise<void>;
27
22
  me<T = any>(): Observable<T>;
28
23
  signIn(provider: AuthProvider, as?: string[]): Promise<AuthSignInResponse>;
@@ -51,6 +46,6 @@ export declare class Auth {
51
46
  private autoRefresh;
52
47
  private get router();
53
48
  private getUrl;
54
- static ɵfac: i0.ɵɵFactoryDeclaration<Auth, [null, null, null, null, { optional: true; }, { optional: true; }, { optional: true; }, { optional: true; }]>;
49
+ static ɵfac: i0.ɵɵFactoryDeclaration<Auth, never>;
55
50
  static ɵprov: i0.ɵɵInjectableDeclaration<Auth>;
56
51
  }
@@ -1,84 +1,3 @@
1
1
  import { EnvironmentProviders } from '@angular/core';
2
- export declare function provideElementsConfig(): EnvironmentProviders;
3
- export declare const ELEMENTS_MATERIAL_ICON: {
4
- provide: import("@angular/core").InjectionToken<import("./elements.interfaces").ElementsIcon[]>;
5
- useValue: {
6
- namespace: string;
7
- className: string;
8
- uses: string;
9
- type: string;
10
- };
11
- multi: boolean;
12
- };
13
- export declare function getErrors(): {
14
- unknown: () => string;
15
- required: () => string;
16
- pattern: () => string;
17
- email: () => string;
18
- emailTaken: () => string;
19
- passwordMatch: () => string;
20
- confirm: () => string;
21
- fullNumber: () => string;
22
- min: ({ min }: {
23
- min: any;
24
- }) => {
25
- token: string;
26
- data: {
27
- min: any;
28
- };
29
- };
30
- max: ({ max }: {
31
- max: any;
32
- }) => {
33
- token: string;
34
- data: {
35
- max: any;
36
- };
37
- };
38
- maxFileSize: ({ maxSize }: {
39
- maxSize: any;
40
- }) => {
41
- token: string;
42
- data: {
43
- maxSize: any;
44
- };
45
- };
46
- minDate: ({ date }: {
47
- date: any;
48
- }) => {
49
- token: string;
50
- data: {
51
- date: any;
52
- };
53
- };
54
- maxDate: ({ date }: {
55
- date: any;
56
- }) => {
57
- token: string;
58
- data: {
59
- date: any;
60
- };
61
- };
62
- invalidDate: () => string;
63
- invalidFileType: () => string;
64
- minlength: ({ requiredLength, actualLength }: {
65
- requiredLength: any;
66
- actualLength: any;
67
- }) => {
68
- token: string;
69
- data: {
70
- requiredLength: any;
71
- actualLength: any;
72
- };
73
- };
74
- maxlength: ({ requiredLength, actualLength }: {
75
- requiredLength: any;
76
- actualLength: any;
77
- }) => {
78
- token: string;
79
- data: {
80
- requiredLength: any;
81
- actualLength: any;
82
- };
83
- };
84
- };
2
+ import { ElementsConfig } from './elements.interfaces';
3
+ export declare function provideElementsConfig(config?: ElementsConfig): EnvironmentProviders;
@@ -23,3 +23,8 @@ export interface ElementsIconImage {
23
23
  export interface ElementsIconUnknown {
24
24
  type: 'unknown';
25
25
  }
26
+ export interface ElementsConfig {
27
+ useMaterialDesignIcons?: boolean;
28
+ iconFonts?: ElementsIconFont[];
29
+ errors?: ElementsError;
30
+ }
@@ -1,4 +1,5 @@
1
1
  import { ModuleWithProviders } from '@angular/core';
2
+ import { ElementsConfig } from './elements.interfaces';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "./form-error/form-error.component";
4
5
  import * as i2 from "./directives/form-submit.directive";
@@ -26,7 +27,7 @@ import * as i23 from "./file-picker/file-picker.component";
26
27
  import * as i24 from "./image-picker/image-picker.component";
27
28
  import * as i25 from "./date-picker/date-picker.component";
28
29
  export declare class ElementsModule {
29
- static forRoot(): ModuleWithProviders<ElementsModule>;
30
+ static forRoot(config?: ElementsConfig): ModuleWithProviders<ElementsModule>;
30
31
  static ɵfac: i0.ɵɵFactoryDeclaration<ElementsModule, never>;
31
32
  static ɵmod: i0.ɵɵNgModuleDeclaration<ElementsModule, never, [typeof i1.BbFormError, typeof i2.BbFormSubmit, typeof i3.BbFormSubmitter, typeof i4.BbInput, typeof i5.BbPrefix, typeof i5.BbSuffix, typeof i6.BbImageUpload, typeof i7.BbExtraErrorControls, typeof i8.BbFileSize, typeof i9.BbFileImage, typeof i10.BbRelativeTime, typeof i11.BbDate, typeof i12.BbButton, typeof i12.BbAnchor, typeof i13.BbSpinner, typeof i14.BbIcon, typeof i15.BbFormControl, typeof i16.BbFormGroup, typeof i17.BbCheckbox, typeof i18.BbCheckboxGroup, typeof i19.BbRadioGroup, typeof i20.BbRadioButton, typeof i21.BbAvatar, typeof i22.BbMultiFileControl, typeof i23.BbFilePicker, typeof i24.BbImagePicker, typeof i25.BbDatePicker], [typeof i1.BbFormError, typeof i2.BbFormSubmit, typeof i3.BbFormSubmitter, typeof i4.BbInput, typeof i5.BbPrefix, typeof i5.BbSuffix, typeof i6.BbImageUpload, typeof i7.BbExtraErrorControls, typeof i8.BbFileSize, typeof i9.BbFileImage, typeof i10.BbRelativeTime, typeof i11.BbDate, typeof i12.BbButton, typeof i12.BbAnchor, typeof i13.BbSpinner, typeof i14.BbIcon, typeof i15.BbFormControl, typeof i16.BbFormGroup, typeof i17.BbCheckbox, typeof i18.BbCheckboxGroup, typeof i19.BbRadioGroup, typeof i20.BbRadioButton, typeof i21.BbAvatar, typeof i22.BbMultiFileControl, typeof i23.BbFilePicker, typeof i24.BbImagePicker, typeof i25.BbDatePicker]>;
32
33
  static ɵinj: i0.ɵɵInjectorDeclaration<ElementsModule>;
@@ -1,43 +1,34 @@
1
- import { Inject, Injectable, makeStateKey, Optional } from '@angular/core';
2
1
  import { AUTH_CONFIG, AUTH_REDIRECT_HANDLER } from './interfaces/config.interface';
3
- import { HttpContext } from '@angular/common/http';
2
+ import { inject, Injectable, Injector, makeStateKey, TransferState } from '@angular/core';
3
+ import { HttpClient, HttpContext } from '@angular/common/http';
4
+ import { Storage } from '@bravobit/bb-foundation/storage';
4
5
  import { HTTP_CONFIG } from '@bravobit/bb-foundation/http';
5
6
  import { USE_AUTHORIZATION } from './tokens/use-authorization.token';
6
7
  import { AuthVerifyProvider } from './providers/verify.provider';
7
8
  import { AuthEmailProvider } from './providers/email.provider';
8
9
  import { firstValueFrom, of } from 'rxjs';
10
+ import { Platform } from '@angular/cdk/platform';
9
11
  import { AuthSession } from './auth.session';
10
12
  import { map, tap } from 'rxjs/operators';
11
13
  import { Router } from '@angular/router';
12
14
  import * as i0 from "@angular/core";
13
- import * as i1 from "@bravobit/bb-foundation/storage";
14
- import * as i2 from "@angular/cdk/platform";
15
- import * as i3 from "@angular/common/http";
16
- import * as i4 from "@bravobit/bb-foundation/http";
17
15
  export class Auth {
18
- _storage;
19
- _injector;
20
- _platform;
21
- _httpClient;
22
- _state;
23
- _config;
24
- _httpConfig;
25
- _handler;
16
+ // Dependencies.
17
+ _storage = inject(Storage);
18
+ _injector = inject(Injector);
19
+ _platform = inject(Platform);
20
+ _httpClient = inject(HttpClient);
21
+ _state = inject(TransferState, { optional: true });
22
+ _config = inject(AUTH_CONFIG, { optional: true });
23
+ _httpConfig = inject(HTTP_CONFIG, { optional: true });
24
+ _handler = inject(AUTH_REDIRECT_HANDLER, { optional: true });
26
25
  // Readonly data.
27
26
  _authStateKey = makeStateKey(`bbAuthStateKey`);
28
- _httpAlias;
27
+ _httpAlias = this._httpConfig?.defaultAlias ?? null;
29
28
  session;
30
29
  user;
31
30
  _refreshHandler = null;
32
- constructor(_storage, _injector, _platform, _httpClient, _state, _config, _httpConfig, _handler) {
33
- this._storage = _storage;
34
- this._injector = _injector;
35
- this._platform = _platform;
36
- this._httpClient = _httpClient;
37
- this._state = _state;
38
- this._config = _config;
39
- this._httpConfig = _httpConfig;
40
- this._handler = _handler;
31
+ constructor() {
41
32
  // We select a storage strategy based on the server/browser.
42
33
  // Only cookies CAN work on the server.
43
34
  const storageStrategy = this._platform.isBrowser
@@ -49,7 +40,6 @@ export class Auth {
49
40
  storage: storageStrategy
50
41
  });
51
42
  this.user = this.session.user;
52
- this._httpAlias = this._httpConfig?.defaultAlias ?? null;
53
43
  }
54
44
  initialize() {
55
45
  return async () => {
@@ -189,7 +179,7 @@ export class Auth {
189
179
  this.session.clear();
190
180
  if (this._handler) {
191
181
  const urlTree = this._handler.onFailedAuthenticated();
192
- if (!urlTree || urlTree === true) {
182
+ if (typeof urlTree === 'boolean' || urlTree === null || urlTree === undefined) {
193
183
  return;
194
184
  }
195
185
  this.router.navigateByUrl(urlTree).then(_ => _);
@@ -259,7 +249,7 @@ export class Auth {
259
249
  .filter(item => !!item)
260
250
  .join('/');
261
251
  }
262
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: Auth, deps: [{ token: i1.Storage }, { token: i0.Injector }, { token: i2.Platform }, { token: i3.HttpClient }, { token: i0.TransferState, optional: true }, { token: AUTH_CONFIG, optional: true }, { token: HTTP_CONFIG, optional: true }, { token: AUTH_REDIRECT_HANDLER, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
252
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: Auth, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
263
253
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: Auth, providedIn: 'root' });
264
254
  }
265
255
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: Auth, decorators: [{
@@ -267,22 +257,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
267
257
  args: [{
268
258
  providedIn: 'root'
269
259
  }]
270
- }], ctorParameters: () => [{ type: i1.Storage }, { type: i0.Injector }, { type: i2.Platform }, { type: i3.HttpClient }, { type: i0.TransferState, decorators: [{
271
- type: Optional
272
- }] }, { type: undefined, decorators: [{
273
- type: Optional
274
- }, {
275
- type: Inject,
276
- args: [AUTH_CONFIG]
277
- }] }, { type: i4.HttpConfig, decorators: [{
278
- type: Optional
279
- }, {
280
- type: Inject,
281
- args: [HTTP_CONFIG]
282
- }] }, { type: undefined, decorators: [{
283
- type: Optional
284
- }, {
285
- type: Inject,
286
- args: [AUTH_REDIRECT_HANDLER]
287
- }] }] });
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, Injector, makeStateKey, Optional, StateKey, TransferState} from '@angular/core';\nimport {AUTH_CONFIG, AUTH_REDIRECT_HANDLER, AuthConfig, AuthRedirectHandler} from './interfaces/config.interface';\nimport {HttpClient, HttpContext, HttpHeaders, HttpParams} from '@angular/common/http';\nimport {AuthProvider, AuthSignInResponse} from './interfaces/provider.interface';\nimport {Storage, StorageOption} from '@bravobit/bb-foundation/storage';\nimport {HttpConfig, HTTP_CONFIG} from '@bravobit/bb-foundation/http';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthVerifyProvider} from './providers/verify.provider';\nimport {AuthEmailProvider} from './providers/email.provider';\nimport {firstValueFrom, Observable, of} from 'rxjs';\nimport {Platform} from '@angular/cdk/platform';\nimport {AuthSession} from './auth.session';\nimport {map, tap} from 'rxjs/operators';\nimport {Router} from '@angular/router';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class Auth {\n\n    // Readonly data.\n    private readonly _authStateKey: StateKey<any | null> = makeStateKey(`bbAuthStateKey`);\n    private readonly _httpAlias: string | null;\n\n    readonly session: AuthSession;\n    readonly user: Observable<any | null>;\n\n    private _refreshHandler: number | null = null;\n\n    constructor(private _storage: Storage,\n                private _injector: Injector,\n                private _platform: Platform,\n                private _httpClient: HttpClient,\n                @Optional() private _state?: TransferState,\n                @Optional() @Inject(AUTH_CONFIG) private _config?: AuthConfig,\n                @Optional() @Inject(HTTP_CONFIG) private _httpConfig?: HttpConfig,\n                @Optional() @Inject(AUTH_REDIRECT_HANDLER) private _handler?: AuthRedirectHandler) {\n        // We select a storage strategy based on the server/browser.\n        // Only cookies CAN work on the server.\n        const storageStrategy = this._platform.isBrowser\n            ? this._storage.select([StorageOption.Cookie, StorageOption.Local])\n            : this._storage.cookie;\n\n        // Starting the new session.\n        this.session = new AuthSession({\n            id: this._config?.applicationId,\n            storage: storageStrategy\n        });\n        this.user = this.session.user;\n        this._httpAlias = this._httpConfig?.defaultAlias ?? null;\n    }\n\n    initialize() {\n        return async () => {\n            // Check if the app should bootstrap the authentication.\n            const shouldBootstrap = this._config?.bootstrap ?? true;\n            if (!shouldBootstrap) {\n                return this.handleAutoRefreshing();\n            }\n\n            // Only retrieve from the server when we are actually authenticated.\n            if (!this.session.authenticated()) {\n                return;\n            }\n\n            // Get the key from the server state.\n            if (this._state && this._state?.hasKey(this._authStateKey)) {\n                const user = this._state?.get(this._authStateKey, null) ?? null;\n                return this.session.setUser(user);\n            }\n\n            // Try to fetch the user from the server.\n            const user$ = this.me();\n            const user = await firstValueFrom(user$, {defaultValue: null});\n\n            // Set the state if exists.\n            if (this._state) {\n                this._state?.set<any>(this._authStateKey, user ?? null);\n            }\n\n            // Save the user in the storage and handle auto refreshing.\n            this.session.setUser(user);\n            this.handleAutoRefreshing();\n        };\n    }\n\n    me<T = any>() {\n        const url = this.getUrl('auth/me');\n        return this._httpClient.get<T>(url);\n    }\n\n    async signIn(provider: AuthProvider, as?: string[]) {\n        const {accessToken, refreshToken, user, ...result} = await provider.authenticate(this._httpClient);\n\n        // Check if the role matches.\n        const role = user?.role ?? null;\n        if (as && !as.includes(role)) {\n            throw new Error('Invalid role.');\n        }\n\n        // Validate if the provider is one of the available\n        // providers then return the user object and the provider.\n        const apiProvider = result?.provider ?? null;\n        const apiVerifyToken = result?.verifyToken ?? null;\n        const availableProviders = this._config?.providers ?? ['email', 'sms', 'totp'];\n        if (availableProviders.includes(apiProvider)) {\n            return <AuthSignInResponse>{user, provider: apiProvider, verifyToken: apiVerifyToken};\n        }\n\n        // Set the tokens in storage.\n        this.setTokens(accessToken, refreshToken);\n\n        // Set the user in storage.\n        this.session.setUser(user);\n\n        // Return the user.\n        return <AuthSignInResponse>{user};\n    }\n\n    async signInWithEmail(email: string, password: string, as?: string[]) {\n        const url = this.getUrl('auth/login');\n        return this.signIn(new AuthEmailProvider(email, password, url), as);\n    }\n\n    async signInWithVerifyCode(code: string, verifyToken: string) {\n        const url = this.getUrl('auth/verify');\n        return this.signIn(new AuthVerifyProvider(code, verifyToken, url));\n    }\n\n    async resendVerifyCode(verifyToken: string) {\n        const url = this.getUrl('auth/resend');\n        const result$ = this._httpClient.post(url, {\n            verify_token: verifyToken\n        });\n\n        return firstValueFrom(result$);\n    }\n\n    async register<T = any>(data: any, options?: {\n        headers?: HttpHeaders | {\n            [header: string]: string | string[];\n        };\n        params?: HttpParams | {\n            [param: string]: string | number | boolean | ReadonlyArray<string | number | boolean>;\n        };\n    }) {\n        // Execute API call.\n        const url = this.getUrl('auth/register');\n        const result$ = this._httpClient.post<{ token: string, refresh_token: string, user: any }>(url, data, options);\n        const result = await firstValueFrom(result$);\n\n        // Set the tokens in storage.\n        this.setTokens(result?.token, result?.refresh_token);\n\n        // Set the user in storage.\n        const user = result?.user;\n        this.session.setUser(user);\n\n        // Return the user.\n        return <T>user;\n    }\n\n    logout() {\n        // If we don't have a refresh token just clear the session.\n        // Note: We do this because else we try to invalidate\n        // an \"undefined\" refresh token.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return this.session.clear();\n        }\n\n        // We do have a refresh token, so try to\n        // invalidate it in the backend.\n        try {\n            const url = this.getUrl('auth/logout');\n            const headerName = this._config?.http?.header ?? 'Authorization';\n            const observable$ = this._httpClient.get(url, {\n                headers: {[headerName]: refreshToken}\n            });\n            firstValueFrom(observable$).then(_ => _).catch(_ => _);\n        } catch {\n            // Do nothing because the tokens will be deleted anyways from the session.\n        }\n\n        // Delete the tokens from the session.\n        return this.session.clear();\n    }\n\n    refresh() {\n        // If the refresh token does\n        // not exist just return an observable of null.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return of(null);\n        }\n\n        // Perform the refresh call.\n        const headerName = this._config?.http?.header ?? 'Authorization';\n        const scheme = this._config?.http?.scheme ?? 'Bearer';\n\n        const url = this.getUrl('auth/refresh');\n        const context = new HttpContext().set(USE_AUTHORIZATION, false);\n\n        return this._httpClient.get<{ token: string, refresh_token: string }>(url, {\n            headers: {[headerName]: `${scheme} ${refreshToken}`},\n            context: context\n        }).pipe(\n            tap(({token, refresh_token}) => this.setTokens(token, refresh_token)),\n            map(({token}) => token)\n        );\n    }\n\n    async requestPassword(email: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset');\n        const observable$ = this._httpClient.post(url, {...extraParams, email});\n        return firstValueFrom(observable$);\n    }\n\n    async resetPassword(token: string, newPassword: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset-password');\n        const observable$ = this._httpClient.post(url, {...extraParams, token, password: newPassword});\n        return firstValueFrom(observable$);\n    }\n\n    clearAndRedirect() {\n        // 1. Delete the tokens from the session.\n        this.session.clear();\n\n        if (this._handler) {\n            const urlTree = this._handler.onFailedAuthenticated();\n            if (!urlTree || urlTree === true) {\n                return;\n            }\n\n            this.router.navigateByUrl(urlTree).then(_ => _);\n            return;\n        }\n\n        // 2. Compose the route url.\n        const redirectUrl = this._config?.redirects.unauthenticated ?? null;\n\n        // 3. Route back if the user provided a redirect url.\n        if (this.router && redirectUrl) {\n            const commands = Array.isArray(redirectUrl) ? redirectUrl : [redirectUrl];\n            this.router.navigate(commands).then(_ => _);\n        }\n    }\n\n    private setTokens(accessToken: string, refreshToken: string) {\n        // Set the tokens in our session.\n        this.session.setTokens(accessToken, refreshToken);\n\n        // We need to update the auto refresh of the refresh token.\n        this.handleAutoRefreshing();\n    }\n\n    private handleAutoRefreshing() {\n        const shouldAutoRefresh = this._config?.autoRefresh ?? false;\n        if (!shouldAutoRefresh) {\n            return;\n        }\n\n        const expiresAt = this.session.refreshTokenPayload?.expiresAt ?? null;\n        if (expiresAt === null || !this._platform.isBrowser) {\n            return;\n        }\n\n        const differenceInMilliseconds = expiresAt.getTime() - Date.now();\n        const offsetInMilliseconds = 10_000; // 10 seconds.\n\n        // We want to start the refresh 10 seconds before it expires.\n        const actualTiming = differenceInMilliseconds - offsetInMilliseconds;\n        if (actualTiming <= 0) {\n            return;\n        }\n\n        // We need to cap the timings because if\n        // we get large numbers it might cause unwanted results.\n        const maxTiming = 1000 * 60 * 60 * 24; // 24 hours.\n        const cappedTiming = Math.max(1, Math.min(actualTiming, maxTiming));\n        try {\n            if (this._refreshHandler !== null) {\n                clearTimeout?.(this._refreshHandler);\n                this._refreshHandler = null;\n            }\n            this._refreshHandler = window?.setTimeout?.(() => this.autoRefresh(), cappedTiming);\n        } catch {\n            // Just ignore it.\n        }\n    }\n\n    private async autoRefresh() {\n        try {\n            // We just need to wait for it to refresh.\n            const refresh$ = this.refresh();\n            await firstValueFrom(refresh$);\n        } catch {\n            // Something went wrong refreshing, we need to clear.\n            this.clearAndRedirect();\n        }\n    }\n\n    private get router() {\n        return this._injector.get(Router);\n    }\n\n    private getUrl(endpoint: string) {\n        return [this._httpAlias, endpoint]\n            .filter(item => !!item)\n            .join('/');\n    }\n\n}\n"]}
260
+ }], ctorParameters: () => [] });
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAE,qBAAqB,EAAkC,MAAM,+BAA+B,CAAC;AAClH,OAAO,EAAC,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,EAAY,aAAa,EAAC,MAAM,eAAe,CAAC;AAClG,OAAO,EAAC,UAAU,EAAE,WAAW,EAA0B,MAAM,sBAAsB,CAAC;AAEtF,OAAO,EAAC,OAAO,EAAgB,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAa,WAAW,EAAC,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,kBAAkB,EAAC,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,cAAc,EAAc,EAAE,EAAC,MAAM,MAAM,CAAC;AACpD,OAAO,EAAC,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,GAAG,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAC;;AAKvC,MAAM,OAAO,IAAI;IAEb,gBAAgB;IACC,QAAQ,GAAY,MAAM,CAAC,OAAO,CAAC,CAAC;IACpC,SAAS,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAC;IACvC,SAAS,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAC;IACvC,WAAW,GAAe,MAAM,CAAC,UAAU,CAAC,CAAC;IAC7C,MAAM,GAAmB,MAAM,CAAC,aAAa,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IACjE,OAAO,GAAgB,MAAM,CAAC,WAAW,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IAC7D,WAAW,GAAgB,MAAM,CAAC,WAAW,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IACjE,QAAQ,GAAyB,MAAM,CAAC,qBAAqB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IAElG,iBAAiB;IACA,aAAa,GAAyB,YAAY,CAAC,gBAAgB,CAAC,CAAC;IACrE,UAAU,GAAkB,IAAI,CAAC,WAAW,EAAE,YAAY,IAAI,IAAI,CAAC;IAE3E,OAAO,CAAc;IACrB,IAAI,CAAyB;IAE9B,eAAe,GAAkB,IAAI,CAAC;IAE9C;QACI,4DAA4D;QAC5D,uCAAuC;QACvC,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS;YAC5C,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,wEAA2C,CAAC;YACnE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;QAE3B,4BAA4B;QAC5B,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,CAAC;YAC3B,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa;YAC/B,OAAO,EAAE,eAAe;SAC3B,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;IAClC,CAAC;IAED,UAAU;QACN,OAAO,KAAK,IAAI,EAAE;YACd,wDAAwD;YACxD,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,EAAE,SAAS,IAAI,IAAI,CAAC;YACxD,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnB,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACvC,CAAC;YAED,oEAAoE;YACpE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC;gBAChC,OAAO;YACX,CAAC;YAED,qCAAqC;YACrC,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;gBACzD,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC;gBAChE,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACtC,CAAC;YAED,yCAAyC;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;YACxB,MAAM,IAAI,GAAG,MAAM,cAAc,CAAC,KAAK,EAAE,EAAC,YAAY,EAAE,IAAI,EAAC,CAAC,CAAC;YAE/D,2BAA2B;YAC3B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBACd,IAAI,CAAC,MAAM,EAAE,GAAG,CAAM,IAAI,CAAC,aAAa,EAAE,IAAI,IAAI,IAAI,CAAC,CAAC;YAC5D,CAAC;YAED,2DAA2D;YAC3D,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAChC,CAAC,CAAC;IACN,CAAC;IAED,EAAE;QACE,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACnC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAI,GAAG,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,QAAsB,EAAE,EAAa;QAC9C,MAAM,EAAC,WAAW,EAAE,YAAY,EAAE,IAAI,EAAE,GAAG,MAAM,EAAC,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEnG,6BAA6B;QAC7B,MAAM,IAAI,GAAG,IAAI,EAAE,IAAI,IAAI,IAAI,CAAC;QAChC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;QACrC,CAAC;QAED,mDAAmD;QACnD,0DAA0D;QAC1D,MAAM,WAAW,GAAG,MAAM,EAAE,QAAQ,IAAI,IAAI,CAAC;QAC7C,MAAM,cAAc,GAAG,MAAM,EAAE,WAAW,IAAI,IAAI,CAAC;QACnD,MAAM,kBAAkB,GAAG,IAAI,CAAC,OAAO,EAAE,SAAS,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/E,IAAI,kBAAkB,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;YAC3C,OAA2B,EAAC,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,EAAC,CAAC;QAC1F,CAAC;QAED,6BAA6B;QAC7B,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QAE1C,2BAA2B;QAC3B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE3B,mBAAmB;QACnB,OAA2B,EAAC,IAAI,EAAC,CAAC;IACtC,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAAa,EAAE,QAAgB,EAAE,EAAa;QAChE,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,iBAAiB,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,IAAY,EAAE,WAAmB;QACxD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,kBAAkB,CAAC,IAAI,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,WAAmB;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE;YACvC,YAAY,EAAE,WAAW;SAC5B,CAAC,CAAC;QAEH,OAAO,cAAc,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,QAAQ,CAAU,IAAS,EAAE,OAOlC;QACG,oBAAoB;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAsD,GAAG,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QAC/G,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,OAAO,CAAC,CAAC;QAE7C,6BAA6B;QAC7B,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC;QAErD,2BAA2B;QAC3B,MAAM,IAAI,GAAG,MAAM,EAAE,IAAI,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE3B,mBAAmB;QACnB,OAAU,IAAI,CAAC;IACnB,CAAC;IAED,MAAM;QACF,2DAA2D;QAC3D,qDAAqD;QACrD,gCAAgC;QAChC,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QAC/C,IAAI,CAAC,YAAY,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAChC,CAAC;QAED,wCAAwC;QACxC,gCAAgC;QAChC,IAAI,CAAC;YACD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YACvC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,eAAe,CAAC;YACjE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE;gBAC1C,OAAO,EAAE,EAAC,CAAC,UAAU,CAAC,EAAE,YAAY,EAAC;aACxC,CAAC,CAAC;YACH,cAAc,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,CAAC;QAAC,MAAM,CAAC;YACL,0EAA0E;QAC9E,CAAC;QAED,sCAAsC;QACtC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IAChC,CAAC;IAED,OAAO;QACH,4BAA4B;QAC5B,+CAA+C;QAC/C,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QAC/C,IAAI,CAAC,YAAY,EAAE,CAAC;YAChB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QAED,4BAA4B;QAC5B,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,eAAe,CAAC;QACjE,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,QAAQ,CAAC;QAEtD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC;QAEhE,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAA2C,GAAG,EAAE;YACvE,OAAO,EAAE,EAAC,CAAC,UAAU,CAAC,EAAE,GAAG,MAAM,IAAI,YAAY,EAAE,EAAC;YACpD,OAAO,EAAE,OAAO;SACnB,CAAC,CAAC,IAAI,CACH,GAAG,CAAC,CAAC,EAAC,KAAK,EAAE,aAAa,EAAC,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC,EACrE,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAC1B,CAAC;IACN,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAAa,EAAE,cAAsC,EAAE;QACzE,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACtC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,EAAC,GAAG,WAAW,EAAE,KAAK,EAAC,CAAC,CAAC;QACxE,OAAO,cAAc,CAAC,WAAW,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,KAAa,EAAE,WAAmB,EAAE,cAAsC,EAAE;QAC5F,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,EAAC,GAAG,WAAW,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAC,CAAC,CAAC;QAC/F,OAAO,cAAc,CAAC,WAAW,CAAC,CAAC;IACvC,CAAC;IAED,gBAAgB;QACZ,yCAAyC;QACzC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAErB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,qBAAqB,EAAE,CAAC;YACtD,IAAI,OAAO,OAAO,KAAK,SAAS,IAAI,OAAO,KAAK,IAAI,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;gBAC5E,OAAO;YACX,CAAC;YAED,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAChD,OAAO;QACX,CAAC;QAED,4BAA4B;QAC5B,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,eAAe,IAAI,IAAI,CAAC;QAEpE,qDAAqD;QACrD,IAAI,IAAI,CAAC,MAAM,IAAI,WAAW,EAAE,CAAC;YAC7B,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;YAC1E,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,CAAC;IACL,CAAC;IAEO,SAAS,CAAC,WAAmB,EAAE,YAAoB;QACvD,iCAAiC;QACjC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QAElD,2DAA2D;QAC3D,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEO,oBAAoB;QACxB,MAAM,iBAAiB,GAAG,IAAI,CAAC,OAAO,EAAE,WAAW,IAAI,KAAK,CAAC;QAC7D,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACrB,OAAO;QACX,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,SAAS,IAAI,IAAI,CAAC;QACtE,IAAI,SAAS,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC;YAClD,OAAO;QACX,CAAC;QAED,MAAM,wBAAwB,GAAG,SAAS,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAClE,MAAM,oBAAoB,GAAG,MAAM,CAAC,CAAC,cAAc;QAEnD,6DAA6D;QAC7D,MAAM,YAAY,GAAG,wBAAwB,GAAG,oBAAoB,CAAC;QACrE,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;YACpB,OAAO;QACX,CAAC;QAED,wCAAwC;QACxC,wDAAwD;QACxD,MAAM,SAAS,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,YAAY;QACnD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC;QACpE,IAAI,CAAC;YACD,IAAI,IAAI,CAAC,eAAe,KAAK,IAAI,EAAE,CAAC;gBAChC,YAAY,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBACrC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAChC,CAAC;YACD,IAAI,CAAC,eAAe,GAAG,MAAM,EAAE,UAAU,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,YAAY,CAAC,CAAC;QACxF,CAAC;QAAC,MAAM,CAAC;YACL,kBAAkB;QACtB,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,WAAW;QACrB,IAAI,CAAC;YACD,0CAA0C;YAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAChC,MAAM,cAAc,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC;QAAC,MAAM,CAAC;YACL,qDAAqD;YACrD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC;IACL,CAAC;IAED,IAAY,MAAM;QACd,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;IAEO,MAAM,CAAC,QAAgB;QAC3B,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC;aAC7B,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;aACtB,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;uGAtSQ,IAAI;2GAAJ,IAAI,cAFD,MAAM;;2FAET,IAAI;kBAHhB,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["import {AUTH_CONFIG, AUTH_REDIRECT_HANDLER, AuthConfig, AuthRedirectHandler} from './interfaces/config.interface';\nimport {inject, Injectable, Injector, makeStateKey, StateKey, TransferState} from '@angular/core';\nimport {HttpClient, HttpContext, HttpHeaders, HttpParams} from '@angular/common/http';\nimport {AuthProvider, AuthSignInResponse} from './interfaces/provider.interface';\nimport {Storage, StorageOption} from '@bravobit/bb-foundation/storage';\nimport {HttpConfig, HTTP_CONFIG} from '@bravobit/bb-foundation/http';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthVerifyProvider} from './providers/verify.provider';\nimport {AuthEmailProvider} from './providers/email.provider';\nimport {firstValueFrom, Observable, of} from 'rxjs';\nimport {Platform} from '@angular/cdk/platform';\nimport {AuthSession} from './auth.session';\nimport {map, tap} from 'rxjs/operators';\nimport {Router} from '@angular/router';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class Auth {\n\n    // Dependencies.\n    private readonly _storage: Storage = inject(Storage);\n    private readonly _injector: Injector = inject(Injector);\n    private readonly _platform: Platform = inject(Platform);\n    private readonly _httpClient: HttpClient = inject(HttpClient);\n    private readonly _state?: TransferState = inject(TransferState, {optional: true});\n    private readonly _config?: AuthConfig = inject(AUTH_CONFIG, {optional: true});\n    private readonly _httpConfig?: HttpConfig = inject(HTTP_CONFIG, {optional: true});\n    private readonly _handler?: AuthRedirectHandler = inject(AUTH_REDIRECT_HANDLER, {optional: true});\n\n    // Readonly data.\n    private readonly _authStateKey: StateKey<any | null> = makeStateKey(`bbAuthStateKey`);\n    private readonly _httpAlias: string | null = this._httpConfig?.defaultAlias ?? null;\n\n    readonly session: AuthSession;\n    readonly user: Observable<any | null>;\n\n    private _refreshHandler: number | null = null;\n\n    constructor() {\n        // We select a storage strategy based on the server/browser.\n        // Only cookies CAN work on the server.\n        const storageStrategy = this._platform.isBrowser\n            ? this._storage.select([StorageOption.Cookie, StorageOption.Local])\n            : this._storage.cookie;\n\n        // Starting the new session.\n        this.session = new AuthSession({\n            id: this._config?.applicationId,\n            storage: storageStrategy\n        });\n        this.user = this.session.user;\n    }\n\n    initialize() {\n        return async () => {\n            // Check if the app should bootstrap the authentication.\n            const shouldBootstrap = this._config?.bootstrap ?? true;\n            if (!shouldBootstrap) {\n                return this.handleAutoRefreshing();\n            }\n\n            // Only retrieve from the server when we are actually authenticated.\n            if (!this.session.authenticated()) {\n                return;\n            }\n\n            // Get the key from the server state.\n            if (this._state && this._state?.hasKey(this._authStateKey)) {\n                const user = this._state?.get(this._authStateKey, null) ?? null;\n                return this.session.setUser(user);\n            }\n\n            // Try to fetch the user from the server.\n            const user$ = this.me();\n            const user = await firstValueFrom(user$, {defaultValue: null});\n\n            // Set the state if exists.\n            if (this._state) {\n                this._state?.set<any>(this._authStateKey, user ?? null);\n            }\n\n            // Save the user in the storage and handle auto refreshing.\n            this.session.setUser(user);\n            this.handleAutoRefreshing();\n        };\n    }\n\n    me<T = any>() {\n        const url = this.getUrl('auth/me');\n        return this._httpClient.get<T>(url);\n    }\n\n    async signIn(provider: AuthProvider, as?: string[]) {\n        const {accessToken, refreshToken, user, ...result} = await provider.authenticate(this._httpClient);\n\n        // Check if the role matches.\n        const role = user?.role ?? null;\n        if (as && !as.includes(role)) {\n            throw new Error('Invalid role.');\n        }\n\n        // Validate if the provider is one of the available\n        // providers then return the user object and the provider.\n        const apiProvider = result?.provider ?? null;\n        const apiVerifyToken = result?.verifyToken ?? null;\n        const availableProviders = this._config?.providers ?? ['email', 'sms', 'totp'];\n        if (availableProviders.includes(apiProvider)) {\n            return <AuthSignInResponse>{user, provider: apiProvider, verifyToken: apiVerifyToken};\n        }\n\n        // Set the tokens in storage.\n        this.setTokens(accessToken, refreshToken);\n\n        // Set the user in storage.\n        this.session.setUser(user);\n\n        // Return the user.\n        return <AuthSignInResponse>{user};\n    }\n\n    async signInWithEmail(email: string, password: string, as?: string[]) {\n        const url = this.getUrl('auth/login');\n        return this.signIn(new AuthEmailProvider(email, password, url), as);\n    }\n\n    async signInWithVerifyCode(code: string, verifyToken: string) {\n        const url = this.getUrl('auth/verify');\n        return this.signIn(new AuthVerifyProvider(code, verifyToken, url));\n    }\n\n    async resendVerifyCode(verifyToken: string) {\n        const url = this.getUrl('auth/resend');\n        const result$ = this._httpClient.post(url, {\n            verify_token: verifyToken\n        });\n\n        return firstValueFrom(result$);\n    }\n\n    async register<T = any>(data: any, options?: {\n        headers?: HttpHeaders | {\n            [header: string]: string | string[];\n        };\n        params?: HttpParams | {\n            [param: string]: string | number | boolean | ReadonlyArray<string | number | boolean>;\n        };\n    }) {\n        // Execute API call.\n        const url = this.getUrl('auth/register');\n        const result$ = this._httpClient.post<{ token: string, refresh_token: string, user: any }>(url, data, options);\n        const result = await firstValueFrom(result$);\n\n        // Set the tokens in storage.\n        this.setTokens(result?.token, result?.refresh_token);\n\n        // Set the user in storage.\n        const user = result?.user;\n        this.session.setUser(user);\n\n        // Return the user.\n        return <T>user;\n    }\n\n    logout() {\n        // If we don't have a refresh token just clear the session.\n        // Note: We do this because else we try to invalidate\n        // an \"undefined\" refresh token.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return this.session.clear();\n        }\n\n        // We do have a refresh token, so try to\n        // invalidate it in the backend.\n        try {\n            const url = this.getUrl('auth/logout');\n            const headerName = this._config?.http?.header ?? 'Authorization';\n            const observable$ = this._httpClient.get(url, {\n                headers: {[headerName]: refreshToken}\n            });\n            firstValueFrom(observable$).then(_ => _).catch(_ => _);\n        } catch {\n            // Do nothing because the tokens will be deleted anyways from the session.\n        }\n\n        // Delete the tokens from the session.\n        return this.session.clear();\n    }\n\n    refresh() {\n        // If the refresh token does\n        // not exist just return an observable of null.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return of(null);\n        }\n\n        // Perform the refresh call.\n        const headerName = this._config?.http?.header ?? 'Authorization';\n        const scheme = this._config?.http?.scheme ?? 'Bearer';\n\n        const url = this.getUrl('auth/refresh');\n        const context = new HttpContext().set(USE_AUTHORIZATION, false);\n\n        return this._httpClient.get<{ token: string, refresh_token: string }>(url, {\n            headers: {[headerName]: `${scheme} ${refreshToken}`},\n            context: context\n        }).pipe(\n            tap(({token, refresh_token}) => this.setTokens(token, refresh_token)),\n            map(({token}) => token)\n        );\n    }\n\n    async requestPassword(email: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset');\n        const observable$ = this._httpClient.post(url, {...extraParams, email});\n        return firstValueFrom(observable$);\n    }\n\n    async resetPassword(token: string, newPassword: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset-password');\n        const observable$ = this._httpClient.post(url, {...extraParams, token, password: newPassword});\n        return firstValueFrom(observable$);\n    }\n\n    clearAndRedirect() {\n        // 1. Delete the tokens from the session.\n        this.session.clear();\n\n        if (this._handler) {\n            const urlTree = this._handler.onFailedAuthenticated();\n            if (typeof urlTree === 'boolean' || urlTree === null || urlTree === undefined) {\n                return;\n            }\n\n            this.router.navigateByUrl(urlTree).then(_ => _);\n            return;\n        }\n\n        // 2. Compose the route url.\n        const redirectUrl = this._config?.redirects.unauthenticated ?? null;\n\n        // 3. Route back if the user provided a redirect url.\n        if (this.router && redirectUrl) {\n            const commands = Array.isArray(redirectUrl) ? redirectUrl : [redirectUrl];\n            this.router.navigate(commands).then(_ => _);\n        }\n    }\n\n    private setTokens(accessToken: string, refreshToken: string) {\n        // Set the tokens in our session.\n        this.session.setTokens(accessToken, refreshToken);\n\n        // We need to update the auto refresh of the refresh token.\n        this.handleAutoRefreshing();\n    }\n\n    private handleAutoRefreshing() {\n        const shouldAutoRefresh = this._config?.autoRefresh ?? false;\n        if (!shouldAutoRefresh) {\n            return;\n        }\n\n        const expiresAt = this.session.refreshTokenPayload?.expiresAt ?? null;\n        if (expiresAt === null || !this._platform.isBrowser) {\n            return;\n        }\n\n        const differenceInMilliseconds = expiresAt.getTime() - Date.now();\n        const offsetInMilliseconds = 10_000; // 10 seconds.\n\n        // We want to start the refresh 10 seconds before it expires.\n        const actualTiming = differenceInMilliseconds - offsetInMilliseconds;\n        if (actualTiming <= 0) {\n            return;\n        }\n\n        // We need to cap the timings because if\n        // we get large numbers it might cause unwanted results.\n        const maxTiming = 1000 * 60 * 60 * 24; // 24 hours.\n        const cappedTiming = Math.max(1, Math.min(actualTiming, maxTiming));\n        try {\n            if (this._refreshHandler !== null) {\n                clearTimeout?.(this._refreshHandler);\n                this._refreshHandler = null;\n            }\n            this._refreshHandler = window?.setTimeout?.(() => this.autoRefresh(), cappedTiming);\n        } catch {\n            // Just ignore it.\n        }\n    }\n\n    private async autoRefresh() {\n        try {\n            // We just need to wait for it to refresh.\n            const refresh$ = this.refresh();\n            await firstValueFrom(refresh$);\n        } catch {\n            // Something went wrong refreshing, we need to clear.\n            this.clearAndRedirect();\n        }\n    }\n\n    private get router() {\n        return this._injector.get(Router);\n    }\n\n    private getUrl(endpoint: string) {\n        return [this._httpAlias, endpoint]\n            .filter(item => !!item)\n            .join('/');\n    }\n\n}\n"]}
@@ -1,42 +1,52 @@
1
1
  import { makeEnvironmentProviders } from '@angular/core';
2
2
  import { ELEMENTS_ERRORS, ELEMENTS_ICONS } from './elements.interfaces';
3
- export function provideElementsConfig() {
4
- return makeEnvironmentProviders([
5
- { provide: ELEMENTS_ERRORS, useFactory: getErrors, multi: true },
6
- ELEMENTS_MATERIAL_ICON
7
- ]);
3
+ export function provideElementsConfig(config) {
4
+ const providers = [
5
+ {
6
+ provide: ELEMENTS_ERRORS,
7
+ multi: true,
8
+ useValue: {
9
+ unknown: () => 'form-control-errors.unknown',
10
+ required: () => 'form-control-errors.required',
11
+ pattern: () => 'form-control-errors.pattern',
12
+ email: () => 'form-control-errors.email',
13
+ emailTaken: () => 'form-control-errors.emailTaken',
14
+ passwordMatch: () => 'form-control-errors.passwordMatch',
15
+ confirm: () => 'form-control-errors.confirm',
16
+ fullNumber: () => 'form-control-errors.fullNumber',
17
+ min: ({ min }) => ({ token: 'form-control-errors.min', data: { min } }),
18
+ max: ({ max }) => ({ token: 'form-control-errors.max', data: { max } }),
19
+ maxFileSize: ({ maxSize }) => ({ token: 'form-control-errors.maxFileSize', data: { maxSize } }),
20
+ minDate: ({ date }) => ({ token: 'form-control-errors.minDate', data: { date } }),
21
+ maxDate: ({ date }) => ({ token: 'form-control-errors.maxDate', data: { date } }),
22
+ invalidDate: () => 'form-control-errors.invalidDate',
23
+ invalidFileType: () => 'form-control-errors.invalidFileType',
24
+ minlength: ({ requiredLength, actualLength }) => ({
25
+ token: 'form-control-errors.minlength',
26
+ data: { requiredLength, actualLength }
27
+ }),
28
+ maxlength: ({ requiredLength, actualLength }) => ({
29
+ token: 'form-control-errors.maxlength',
30
+ data: { requiredLength, actualLength }
31
+ })
32
+ }
33
+ }
34
+ ];
35
+ const useMaterialDesignIcons = config?.useMaterialDesignIcons ?? true;
36
+ if (useMaterialDesignIcons) {
37
+ providers.push({
38
+ provide: ELEMENTS_ICONS,
39
+ multi: true,
40
+ useValue: { namespace: 'material', className: 'material-icons', uses: 'content', type: 'font' }
41
+ });
42
+ }
43
+ const iconFonts = config?.iconFonts ?? [];
44
+ for (const font of iconFonts) {
45
+ providers.push({ provide: ELEMENTS_ICONS, multi: true, useValue: font });
46
+ }
47
+ if (config?.errors) {
48
+ providers.push({ provide: ELEMENTS_ERRORS, multi: true, useValue: config?.errors });
49
+ }
50
+ return makeEnvironmentProviders(providers);
8
51
  }
9
- export const ELEMENTS_MATERIAL_ICON = {
10
- provide: ELEMENTS_ICONS,
11
- useValue: { namespace: 'material', className: 'material-icons', uses: 'content', type: 'font' },
12
- multi: true
13
- };
14
- export function getErrors() {
15
- const data = {
16
- unknown: () => 'form-control-errors.unknown',
17
- required: () => 'form-control-errors.required',
18
- pattern: () => 'form-control-errors.pattern',
19
- email: () => 'form-control-errors.email',
20
- emailTaken: () => 'form-control-errors.emailTaken',
21
- passwordMatch: () => 'form-control-errors.passwordMatch',
22
- confirm: () => 'form-control-errors.confirm',
23
- fullNumber: () => 'form-control-errors.fullNumber',
24
- min: ({ min }) => ({ token: 'form-control-errors.min', data: { min } }),
25
- max: ({ max }) => ({ token: 'form-control-errors.max', data: { max } }),
26
- maxFileSize: ({ maxSize }) => ({ token: 'form-control-errors.maxFileSize', data: { maxSize } }),
27
- minDate: ({ date }) => ({ token: 'form-control-errors.minDate', data: { date } }),
28
- maxDate: ({ date }) => ({ token: 'form-control-errors.maxDate', data: { date } }),
29
- invalidDate: () => 'form-control-errors.invalidDate',
30
- invalidFileType: () => 'form-control-errors.invalidFileType',
31
- minlength: ({ requiredLength, actualLength }) => ({
32
- token: 'form-control-errors.minlength',
33
- data: { requiredLength, actualLength }
34
- }),
35
- maxlength: ({ requiredLength, actualLength }) => ({
36
- token: 'form-control-errors.maxlength',
37
- data: { requiredLength, actualLength }
38
- })
39
- };
40
- return data;
41
- }
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2VsZW1lbnRzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLHdCQUF3QixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBQyxlQUFlLEVBQUUsY0FBYyxFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFdEUsTUFBTSxVQUFVLHFCQUFxQjtJQUNqQyxPQUFPLHdCQUF3QixDQUFDO1FBQzVCLEVBQUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUM7UUFDOUQsc0JBQXNCO0tBQ3pCLENBQUMsQ0FBQztBQUNQLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRztJQUNsQyxPQUFPLEVBQUUsY0FBYztJQUN2QixRQUFRLEVBQUUsRUFBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUM7SUFDN0YsS0FBSyxFQUFFLElBQUk7Q0FDZCxDQUFDO0FBRUYsTUFBTSxVQUFVLFNBQVM7SUFDckIsTUFBTSxJQUFJLEdBQUc7UUFDVCxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsNkJBQTZCO1FBQzVDLFFBQVEsRUFBRSxHQUFHLEVBQUUsQ0FBQyw4QkFBOEI7UUFDOUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLDZCQUE2QjtRQUM1QyxLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsMkJBQTJCO1FBQ3hDLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0M7UUFDbEQsYUFBYSxFQUFFLEdBQUcsRUFBRSxDQUFDLG1DQUFtQztRQUN4RCxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsNkJBQTZCO1FBQzVDLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0M7UUFDbEQsR0FBRyxFQUFFLENBQUMsRUFBQyxHQUFHLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEtBQUssRUFBRSx5QkFBeUIsRUFBRSxJQUFJLEVBQUUsRUFBQyxHQUFHLEVBQUMsRUFBQyxDQUFDO1FBQ2pFLEdBQUcsRUFBRSxDQUFDLEVBQUMsR0FBRyxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBQyxLQUFLLEVBQUUseUJBQXlCLEVBQUUsSUFBSSxFQUFFLEVBQUMsR0FBRyxFQUFDLEVBQUMsQ0FBQztRQUNqRSxXQUFXLEVBQUUsQ0FBQyxFQUFDLE9BQU8sRUFBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUMsS0FBSyxFQUFFLGlDQUFpQyxFQUFFLElBQUksRUFBRSxFQUFDLE9BQU8sRUFBQyxFQUFDLENBQUM7UUFDekYsT0FBTyxFQUFFLENBQUMsRUFBQyxJQUFJLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEtBQUssRUFBRSw2QkFBNkIsRUFBRSxJQUFJLEVBQUUsRUFBQyxJQUFJLEVBQUMsRUFBQyxDQUFDO1FBQzNFLE9BQU8sRUFBRSxDQUFDLEVBQUMsSUFBSSxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBQyxLQUFLLEVBQUUsNkJBQTZCLEVBQUUsSUFBSSxFQUFFLEVBQUMsSUFBSSxFQUFDLEVBQUMsQ0FBQztRQUMzRSxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQUMsaUNBQWlDO1FBQ3BELGVBQWUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxxQ0FBcUM7UUFDNUQsU0FBUyxFQUFFLENBQUMsRUFBQyxjQUFjLEVBQUUsWUFBWSxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDNUMsS0FBSyxFQUFFLCtCQUErQjtZQUN0QyxJQUFJLEVBQUUsRUFBQyxjQUFjLEVBQUUsWUFBWSxFQUFDO1NBQ3ZDLENBQUM7UUFDRixTQUFTLEVBQUUsQ0FBQyxFQUFDLGNBQWMsRUFBRSxZQUFZLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUM1QyxLQUFLLEVBQUUsK0JBQStCO1lBQ3RDLElBQUksRUFBRSxFQUFDLGNBQWMsRUFBRSxZQUFZLEVBQUM7U0FDdkMsQ0FBQztLQUNMLENBQUM7SUFFRixPQUFPLElBQUksQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFbnZpcm9ubWVudFByb3ZpZGVycywgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RUxFTUVOVFNfRVJST1JTLCBFTEVNRU5UU19JQ09OU30gZnJvbSAnLi9lbGVtZW50cy5pbnRlcmZhY2VzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVFbGVtZW50c0NvbmZpZygpOiBFbnZpcm9ubWVudFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyhbXG4gICAgICAgIHtwcm92aWRlOiBFTEVNRU5UU19FUlJPUlMsIHVzZUZhY3Rvcnk6IGdldEVycm9ycywgbXVsdGk6IHRydWV9LFxuICAgICAgICBFTEVNRU5UU19NQVRFUklBTF9JQ09OXG4gICAgXSk7XG59XG5cbmV4cG9ydCBjb25zdCBFTEVNRU5UU19NQVRFUklBTF9JQ09OID0ge1xuICAgIHByb3ZpZGU6IEVMRU1FTlRTX0lDT05TLFxuICAgIHVzZVZhbHVlOiB7bmFtZXNwYWNlOiAnbWF0ZXJpYWwnLCBjbGFzc05hbWU6ICdtYXRlcmlhbC1pY29ucycsIHVzZXM6ICdjb250ZW50JywgdHlwZTogJ2ZvbnQnfSxcbiAgICBtdWx0aTogdHJ1ZVxufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEVycm9ycygpIHtcbiAgICBjb25zdCBkYXRhID0ge1xuICAgICAgICB1bmtub3duOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy51bmtub3duJyxcbiAgICAgICAgcmVxdWlyZWQ6ICgpID0+ICdmb3JtLWNvbnRyb2wtZXJyb3JzLnJlcXVpcmVkJyxcbiAgICAgICAgcGF0dGVybjogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMucGF0dGVybicsXG4gICAgICAgIGVtYWlsOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy5lbWFpbCcsXG4gICAgICAgIGVtYWlsVGFrZW46ICgpID0+ICdmb3JtLWNvbnRyb2wtZXJyb3JzLmVtYWlsVGFrZW4nLFxuICAgICAgICBwYXNzd29yZE1hdGNoOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy5wYXNzd29yZE1hdGNoJyxcbiAgICAgICAgY29uZmlybTogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuY29uZmlybScsXG4gICAgICAgIGZ1bGxOdW1iZXI6ICgpID0+ICdmb3JtLWNvbnRyb2wtZXJyb3JzLmZ1bGxOdW1iZXInLFxuICAgICAgICBtaW46ICh7bWlufSkgPT4gKHt0b2tlbjogJ2Zvcm0tY29udHJvbC1lcnJvcnMubWluJywgZGF0YToge21pbn19KSxcbiAgICAgICAgbWF4OiAoe21heH0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heCcsIGRhdGE6IHttYXh9fSksXG4gICAgICAgIG1heEZpbGVTaXplOiAoe21heFNpemV9KSA9PiAoe3Rva2VuOiAnZm9ybS1jb250cm9sLWVycm9ycy5tYXhGaWxlU2l6ZScsIGRhdGE6IHttYXhTaXplfX0pLFxuICAgICAgICBtaW5EYXRlOiAoe2RhdGV9KSA9PiAoe3Rva2VuOiAnZm9ybS1jb250cm9sLWVycm9ycy5taW5EYXRlJywgZGF0YToge2RhdGV9fSksXG4gICAgICAgIG1heERhdGU6ICh7ZGF0ZX0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heERhdGUnLCBkYXRhOiB7ZGF0ZX19KSxcbiAgICAgICAgaW52YWxpZERhdGU6ICgpID0+ICdmb3JtLWNvbnRyb2wtZXJyb3JzLmludmFsaWREYXRlJyxcbiAgICAgICAgaW52YWxpZEZpbGVUeXBlOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy5pbnZhbGlkRmlsZVR5cGUnLFxuICAgICAgICBtaW5sZW5ndGg6ICh7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH0pID0+ICh7XG4gICAgICAgICAgICB0b2tlbjogJ2Zvcm0tY29udHJvbC1lcnJvcnMubWlubGVuZ3RoJyxcbiAgICAgICAgICAgIGRhdGE6IHtyZXF1aXJlZExlbmd0aCwgYWN0dWFsTGVuZ3RofVxuICAgICAgICB9KSxcbiAgICAgICAgbWF4bGVuZ3RoOiAoe3JlcXVpcmVkTGVuZ3RoLCBhY3R1YWxMZW5ndGh9KSA9PiAoe1xuICAgICAgICAgICAgdG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heGxlbmd0aCcsXG4gICAgICAgICAgICBkYXRhOiB7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH1cbiAgICAgICAgfSlcbiAgICB9O1xuXG4gICAgcmV0dXJuIGRhdGE7XG59XG4iXX0=
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2VsZW1lbnRzLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLHdCQUF3QixFQUFXLE1BQU0sZUFBZSxDQUFDO0FBQ3ZGLE9BQU8sRUFBQyxlQUFlLEVBQUUsY0FBYyxFQUFpQixNQUFNLHVCQUF1QixDQUFDO0FBRXRGLE1BQU0sVUFBVSxxQkFBcUIsQ0FBQyxNQUF1QjtJQUN6RCxNQUFNLFNBQVMsR0FBZTtRQUMxQjtZQUNJLE9BQU8sRUFBRSxlQUFlO1lBQ3hCLEtBQUssRUFBRSxJQUFJO1lBQ1gsUUFBUSxFQUFFO2dCQUNOLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw2QkFBNkI7Z0JBQzVDLFFBQVEsRUFBRSxHQUFHLEVBQUUsQ0FBQyw4QkFBOEI7Z0JBQzlDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw2QkFBNkI7Z0JBQzVDLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQywyQkFBMkI7Z0JBQ3hDLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0M7Z0JBQ2xELGFBQWEsRUFBRSxHQUFHLEVBQUUsQ0FBQyxtQ0FBbUM7Z0JBQ3hELE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw2QkFBNkI7Z0JBQzVDLFVBQVUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0M7Z0JBQ2xELEdBQUcsRUFBRSxDQUFDLEVBQUMsR0FBRyxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBQyxLQUFLLEVBQUUseUJBQXlCLEVBQUUsSUFBSSxFQUFFLEVBQUMsR0FBRyxFQUFDLEVBQUMsQ0FBQztnQkFDakUsR0FBRyxFQUFFLENBQUMsRUFBQyxHQUFHLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEtBQUssRUFBRSx5QkFBeUIsRUFBRSxJQUFJLEVBQUUsRUFBQyxHQUFHLEVBQUMsRUFBQyxDQUFDO2dCQUNqRSxXQUFXLEVBQUUsQ0FBQyxFQUFDLE9BQU8sRUFBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUMsS0FBSyxFQUFFLGlDQUFpQyxFQUFFLElBQUksRUFBRSxFQUFDLE9BQU8sRUFBQyxFQUFDLENBQUM7Z0JBQ3pGLE9BQU8sRUFBRSxDQUFDLEVBQUMsSUFBSSxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBQyxLQUFLLEVBQUUsNkJBQTZCLEVBQUUsSUFBSSxFQUFFLEVBQUMsSUFBSSxFQUFDLEVBQUMsQ0FBQztnQkFDM0UsT0FBTyxFQUFFLENBQUMsRUFBQyxJQUFJLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEtBQUssRUFBRSw2QkFBNkIsRUFBRSxJQUFJLEVBQUUsRUFBQyxJQUFJLEVBQUMsRUFBQyxDQUFDO2dCQUMzRSxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQUMsaUNBQWlDO2dCQUNwRCxlQUFlLEVBQUUsR0FBRyxFQUFFLENBQUMscUNBQXFDO2dCQUM1RCxTQUFTLEVBQUUsQ0FBQyxFQUFDLGNBQWMsRUFBRSxZQUFZLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztvQkFDNUMsS0FBSyxFQUFFLCtCQUErQjtvQkFDdEMsSUFBSSxFQUFFLEVBQUMsY0FBYyxFQUFFLFlBQVksRUFBQztpQkFDdkMsQ0FBQztnQkFDRixTQUFTLEVBQUUsQ0FBQyxFQUFDLGNBQWMsRUFBRSxZQUFZLEVBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztvQkFDNUMsS0FBSyxFQUFFLCtCQUErQjtvQkFDdEMsSUFBSSxFQUFFLEVBQUMsY0FBYyxFQUFFLFlBQVksRUFBQztpQkFDdkMsQ0FBQzthQUNMO1NBQ0o7S0FDSixDQUFDO0lBRUYsTUFBTSxzQkFBc0IsR0FBRyxNQUFNLEVBQUUsc0JBQXNCLElBQUksSUFBSSxDQUFDO0lBQ3RFLElBQUksc0JBQXNCLEVBQUUsQ0FBQztRQUN6QixTQUFTLENBQUMsSUFBSSxDQUFDO1lBQ1gsT0FBTyxFQUFFLGNBQWM7WUFDdkIsS0FBSyxFQUFFLElBQUk7WUFDWCxRQUFRLEVBQUUsRUFBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUM7U0FDaEcsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELE1BQU0sU0FBUyxHQUFHLE1BQU0sRUFBRSxTQUFTLElBQUksRUFBRSxDQUFDO0lBQzFDLEtBQUssTUFBTSxJQUFJLElBQUksU0FBUyxFQUFFLENBQUM7UUFDM0IsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFDLE9BQU8sRUFBRSxjQUFjLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztJQUMzRSxDQUFDO0lBRUQsSUFBSSxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUM7UUFDakIsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBQyxDQUFDLENBQUM7SUFDdEYsQ0FBQztJQUVELE9BQU8sd0JBQXdCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDL0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RW52aXJvbm1lbnRQcm92aWRlcnMsIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycywgUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtFTEVNRU5UU19FUlJPUlMsIEVMRU1FTlRTX0lDT05TLCBFbGVtZW50c0NvbmZpZ30gZnJvbSAnLi9lbGVtZW50cy5pbnRlcmZhY2VzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVFbGVtZW50c0NvbmZpZyhjb25maWc/OiBFbGVtZW50c0NvbmZpZyk6IEVudmlyb25tZW50UHJvdmlkZXJzIHtcbiAgICBjb25zdCBwcm92aWRlcnM6IFByb3ZpZGVyW10gPSBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IEVMRU1FTlRTX0VSUk9SUyxcbiAgICAgICAgICAgIG11bHRpOiB0cnVlLFxuICAgICAgICAgICAgdXNlVmFsdWU6IHtcbiAgICAgICAgICAgICAgICB1bmtub3duOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy51bmtub3duJyxcbiAgICAgICAgICAgICAgICByZXF1aXJlZDogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMucmVxdWlyZWQnLFxuICAgICAgICAgICAgICAgIHBhdHRlcm46ICgpID0+ICdmb3JtLWNvbnRyb2wtZXJyb3JzLnBhdHRlcm4nLFxuICAgICAgICAgICAgICAgIGVtYWlsOiAoKSA9PiAnZm9ybS1jb250cm9sLWVycm9ycy5lbWFpbCcsXG4gICAgICAgICAgICAgICAgZW1haWxUYWtlbjogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuZW1haWxUYWtlbicsXG4gICAgICAgICAgICAgICAgcGFzc3dvcmRNYXRjaDogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMucGFzc3dvcmRNYXRjaCcsXG4gICAgICAgICAgICAgICAgY29uZmlybTogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuY29uZmlybScsXG4gICAgICAgICAgICAgICAgZnVsbE51bWJlcjogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuZnVsbE51bWJlcicsXG4gICAgICAgICAgICAgICAgbWluOiAoe21pbn0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1pbicsIGRhdGE6IHttaW59fSksXG4gICAgICAgICAgICAgICAgbWF4OiAoe21heH0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heCcsIGRhdGE6IHttYXh9fSksXG4gICAgICAgICAgICAgICAgbWF4RmlsZVNpemU6ICh7bWF4U2l6ZX0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heEZpbGVTaXplJywgZGF0YToge21heFNpemV9fSksXG4gICAgICAgICAgICAgICAgbWluRGF0ZTogKHtkYXRlfSkgPT4gKHt0b2tlbjogJ2Zvcm0tY29udHJvbC1lcnJvcnMubWluRGF0ZScsIGRhdGE6IHtkYXRlfX0pLFxuICAgICAgICAgICAgICAgIG1heERhdGU6ICh7ZGF0ZX0pID0+ICh7dG9rZW46ICdmb3JtLWNvbnRyb2wtZXJyb3JzLm1heERhdGUnLCBkYXRhOiB7ZGF0ZX19KSxcbiAgICAgICAgICAgICAgICBpbnZhbGlkRGF0ZTogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuaW52YWxpZERhdGUnLFxuICAgICAgICAgICAgICAgIGludmFsaWRGaWxlVHlwZTogKCkgPT4gJ2Zvcm0tY29udHJvbC1lcnJvcnMuaW52YWxpZEZpbGVUeXBlJyxcbiAgICAgICAgICAgICAgICBtaW5sZW5ndGg6ICh7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH0pID0+ICh7XG4gICAgICAgICAgICAgICAgICAgIHRva2VuOiAnZm9ybS1jb250cm9sLWVycm9ycy5taW5sZW5ndGgnLFxuICAgICAgICAgICAgICAgICAgICBkYXRhOiB7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH1cbiAgICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICAgICBtYXhsZW5ndGg6ICh7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH0pID0+ICh7XG4gICAgICAgICAgICAgICAgICAgIHRva2VuOiAnZm9ybS1jb250cm9sLWVycm9ycy5tYXhsZW5ndGgnLFxuICAgICAgICAgICAgICAgICAgICBkYXRhOiB7cmVxdWlyZWRMZW5ndGgsIGFjdHVhbExlbmd0aH1cbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgXTtcblxuICAgIGNvbnN0IHVzZU1hdGVyaWFsRGVzaWduSWNvbnMgPSBjb25maWc/LnVzZU1hdGVyaWFsRGVzaWduSWNvbnMgPz8gdHJ1ZTtcbiAgICBpZiAodXNlTWF0ZXJpYWxEZXNpZ25JY29ucykge1xuICAgICAgICBwcm92aWRlcnMucHVzaCh7XG4gICAgICAgICAgICBwcm92aWRlOiBFTEVNRU5UU19JQ09OUyxcbiAgICAgICAgICAgIG11bHRpOiB0cnVlLFxuICAgICAgICAgICAgdXNlVmFsdWU6IHtuYW1lc3BhY2U6ICdtYXRlcmlhbCcsIGNsYXNzTmFtZTogJ21hdGVyaWFsLWljb25zJywgdXNlczogJ2NvbnRlbnQnLCB0eXBlOiAnZm9udCd9XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIGNvbnN0IGljb25Gb250cyA9IGNvbmZpZz8uaWNvbkZvbnRzID8/IFtdO1xuICAgIGZvciAoY29uc3QgZm9udCBvZiBpY29uRm9udHMpIHtcbiAgICAgICAgcHJvdmlkZXJzLnB1c2goe3Byb3ZpZGU6IEVMRU1FTlRTX0lDT05TLCBtdWx0aTogdHJ1ZSwgdXNlVmFsdWU6IGZvbnR9KTtcbiAgICB9XG5cbiAgICBpZiAoY29uZmlnPy5lcnJvcnMpIHtcbiAgICAgICAgcHJvdmlkZXJzLnB1c2goe3Byb3ZpZGU6IEVMRU1FTlRTX0VSUk9SUywgbXVsdGk6IHRydWUsIHVzZVZhbHVlOiBjb25maWc/LmVycm9yc30pO1xuICAgIH1cblxuICAgIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMocHJvdmlkZXJzKTtcbn1cbiJdfQ==
@@ -1,4 +1,4 @@
1
1
  import { InjectionToken } from '@angular/core';
2
2
  export const ELEMENTS_ICONS = new InjectionToken('elements_icons');
3
3
  export const ELEMENTS_ERRORS = new InjectionToken('elements_errors');
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vZWxlbWVudHMvc3JjL2xpYi9lbGVtZW50cy5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFN0MsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFtQyxJQUFJLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQ25HLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBb0MsSUFBSSxjQUFjLENBQUMsaUJBQWlCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgRUxFTUVOVFNfSUNPTlM6IEluamVjdGlvblRva2VuPEVsZW1lbnRzSWNvbltdPiA9IG5ldyBJbmplY3Rpb25Ub2tlbignZWxlbWVudHNfaWNvbnMnKTtcbmV4cG9ydCBjb25zdCBFTEVNRU5UU19FUlJPUlM6IEluamVjdGlvblRva2VuPEVsZW1lbnRzRXJyb3JbXT4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ2VsZW1lbnRzX2Vycm9ycycpO1xuXG5leHBvcnQgdHlwZSBFbGVtZW50c0ljb24gPSBFbGVtZW50c0ljb25Gb250IHwgRWxlbWVudHNJY29uSW1hZ2UgfCBFbGVtZW50c0ljb25Vbmtub3duO1xuZXhwb3J0IHR5cGUgRWxlbWVudHNFcnJvciA9IHsgW2Vycm9yOiBzdHJpbmddOiAoZGF0YT86IGFueSkgPT4gc3RyaW5nIHwgeyB0b2tlbjogc3RyaW5nLCBkYXRhPzogYW55IH07IH07XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudHNJY29uRm9udCB7XG4gICAgbmFtZXNwYWNlOiBzdHJpbmc7XG4gICAgY2xhc3NOYW1lOiBzdHJpbmc7XG4gICAgdXNlczogJ2NvbnRlbnQnIHwgJ2RhdGEtYXR0cmlidXRlJztcbiAgICB0eXBlOiAnZm9udCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudHNJY29uSW1hZ2Uge1xuICAgIG5hbWVzcGFjZTogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBzcmM6IHN0cmluZztcbiAgICB0eXBlOiAnaW1hZ2UnO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVsZW1lbnRzSWNvblVua25vd24ge1xuICAgIHR5cGU6ICd1bmtub3duJztcbn1cbiJdfQ==
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JiLWZvdW5kYXRpb24vZWxlbWVudHMvc3JjL2xpYi9lbGVtZW50cy5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFN0MsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFtQyxJQUFJLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQ25HLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBb0MsSUFBSSxjQUFjLENBQUMsaUJBQWlCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgRUxFTUVOVFNfSUNPTlM6IEluamVjdGlvblRva2VuPEVsZW1lbnRzSWNvbltdPiA9IG5ldyBJbmplY3Rpb25Ub2tlbignZWxlbWVudHNfaWNvbnMnKTtcbmV4cG9ydCBjb25zdCBFTEVNRU5UU19FUlJPUlM6IEluamVjdGlvblRva2VuPEVsZW1lbnRzRXJyb3JbXT4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ2VsZW1lbnRzX2Vycm9ycycpO1xuXG5leHBvcnQgdHlwZSBFbGVtZW50c0ljb24gPSBFbGVtZW50c0ljb25Gb250IHwgRWxlbWVudHNJY29uSW1hZ2UgfCBFbGVtZW50c0ljb25Vbmtub3duO1xuZXhwb3J0IHR5cGUgRWxlbWVudHNFcnJvciA9IHsgW2Vycm9yOiBzdHJpbmddOiAoZGF0YT86IGFueSkgPT4gc3RyaW5nIHwgeyB0b2tlbjogc3RyaW5nLCBkYXRhPzogYW55IH07IH07XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudHNJY29uRm9udCB7XG4gICAgbmFtZXNwYWNlOiBzdHJpbmc7XG4gICAgY2xhc3NOYW1lOiBzdHJpbmc7XG4gICAgdXNlczogJ2NvbnRlbnQnIHwgJ2RhdGEtYXR0cmlidXRlJztcbiAgICB0eXBlOiAnZm9udCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudHNJY29uSW1hZ2Uge1xuICAgIG5hbWVzcGFjZTogc3RyaW5nO1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBzcmM6IHN0cmluZztcbiAgICB0eXBlOiAnaW1hZ2UnO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVsZW1lbnRzSWNvblVua25vd24ge1xuICAgIHR5cGU6ICd1bmtub3duJztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbGVtZW50c0NvbmZpZyB7XG4gICAgdXNlTWF0ZXJpYWxEZXNpZ25JY29ucz86IGJvb2xlYW47XG4gICAgaWNvbkZvbnRzPzogRWxlbWVudHNJY29uRm9udFtdO1xuICAgIGVycm9ycz86IEVsZW1lbnRzRXJyb3I7XG59XG4iXX0=
@@ -59,11 +59,11 @@ const IMPORTS_EXPORTS = [
59
59
  BbDatePicker
60
60
  ];
61
61
  export class ElementsModule {
62
- static forRoot() {
62
+ static forRoot(config) {
63
63
  return {
64
64
  ngModule: ElementsModule,
65
65
  providers: [
66
- provideElementsConfig()
66
+ provideElementsConfig(config)
67
67
  ]
68
68
  };
69
69
  }
@@ -139,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
139
139
  exports: [...IMPORTS_EXPORTS]
140
140
  }]
141
141
  }] });
142
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2VsZW1lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxtREFBbUQsQ0FBQztBQUNyRixPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUNqRixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3RFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUNwRSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDcEUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNsRSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDakUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNqRSxPQUFPLEVBQUMsUUFBUSxFQUFFLFFBQVEsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDOUQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQzlELE9BQU8sRUFBQyxRQUFRLEVBQUUsUUFBUSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFzQixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN6RCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RCxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDdEQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDbkQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxNQUFNLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7O0FBRXpDLE1BQU0sZUFBZSxHQUFHO0lBQ3BCLGNBQWM7SUFDZCxXQUFXO0lBQ1gsWUFBWTtJQUNaLGVBQWU7SUFDZixPQUFPO0lBQ1AsUUFBUTtJQUNSLFFBQVE7SUFDUixhQUFhO0lBQ2Isb0JBQW9CO0lBQ3BCLFNBQVM7SUFDVCxVQUFVO0lBQ1YsV0FBVztJQUNYLGNBQWM7SUFDZCxNQUFNO0lBQ04sY0FBYztJQUNkLFFBQVE7SUFDUixRQUFRO0lBQ1IsU0FBUztJQUNULE1BQU07SUFDTixhQUFhO0lBQ2IsV0FBVztJQUNYLFVBQVU7SUFDVixlQUFlO0lBQ2YsWUFBWTtJQUNaLGFBQWE7SUFDYixRQUFRO0lBQ1Isa0JBQWtCO0lBQ2xCLFlBQVk7SUFDWixhQUFhO0lBQ2IsWUFBWTtDQUNmLENBQUM7QUFNRixNQUFNLE9BQU8sY0FBYztJQUV2QixNQUFNLENBQUMsT0FBTztRQUNWLE9BQU87WUFDSCxRQUFRLEVBQUUsY0FBYztZQUN4QixTQUFTLEVBQUU7Z0JBQ1AscUJBQXFCLEVBQUU7YUFDMUI7U0FDSixDQUFDO0lBQ04sQ0FBQzt1R0FUUSxjQUFjO3dHQUFkLGNBQWM7WUFwQ3ZCLGNBQWM7WUFDZCxXQUFXO1lBQ1gsWUFBWTtZQUNaLGVBQWU7WUFDZixPQUFPO1lBQ1AsUUFBUTtZQUNSLFFBQVE7WUFDUixhQUFhO1lBQ2Isb0JBQW9CO1lBQ3BCLFNBQVM7WUFDVCxVQUFVO1lBQ1YsV0FBVztZQUNYLGNBQWM7WUFDZCxNQUFNO1lBQ04sY0FBYztZQUNkLFFBQVE7WUFDUixRQUFRO1lBQ1IsU0FBUztZQUNULE1BQU07WUFDTixhQUFhO1lBQ2IsV0FBVztZQUNYLFVBQVU7WUFDVixlQUFlO1lBQ2YsWUFBWTtZQUNaLGFBQWE7WUFDYixRQUFRO1lBQ1Isa0JBQWtCO1lBQ2xCLFlBQVk7WUFDWixhQUFhO1lBQ2IsWUFBWTtZQTdCWixjQUFjO1lBQ2QsV0FBVztZQUNYLFlBQVk7WUFDWixlQUFlO1lBQ2YsT0FBTztZQUNQLFFBQVE7WUFDUixRQUFRO1lBQ1IsYUFBYTtZQUNiLG9CQUFvQjtZQUNwQixTQUFTO1lBQ1QsVUFBVTtZQUNWLFdBQVc7WUFDWCxjQUFjO1lBQ2QsTUFBTTtZQUNOLGNBQWM7WUFDZCxRQUFRO1lBQ1IsUUFBUTtZQUNSLFNBQVM7WUFDVCxNQUFNO1lBQ04sYUFBYTtZQUNiLFdBQVc7WUFDWCxVQUFVO1lBQ1YsZUFBZTtZQUNmLFlBQVk7WUFDWixhQUFhO1lBQ2IsUUFBUTtZQUNSLGtCQUFrQjtZQUNsQixZQUFZO1lBQ1osYUFBYTtZQUNiLFlBQVk7d0dBT0gsY0FBYyxZQVZ2QixrQkFBa0I7WUFHbEIsWUFBWTs7MkZBT0gsY0FBYztrQkFKMUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxHQUFHLGVBQWUsQ0FBQztvQkFDN0IsT0FBTyxFQUFFLENBQUMsR0FBRyxlQUFlLENBQUM7aUJBQ2hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtCYk11bHRpRmlsZUNvbnRyb2x9IGZyb20gJy4vbXVsdGktZmlsZS1jb250cm9sL211bHRpLWZpbGUtY29udHJvbC5jb21wb25lbnQnO1xuaW1wb3J0IHtCYkV4dHJhRXJyb3JDb250cm9sc30gZnJvbSAnLi9kaXJlY3RpdmVzL2V4dHJhLWVycm9yLWNvbnRyb2xzLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiQ2hlY2tib3hHcm91cH0gZnJvbSAnLi9jaGVja2JveC1ncm91cC9jaGVja2JveC1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHtCYkZvcm1TdWJtaXR0ZXJ9IGZyb20gJy4vZGlyZWN0aXZlcy9mb3JtLXN1Ym1pdHRlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkltYWdlUGlja2VyfSBmcm9tICcuL2ltYWdlLXBpY2tlci9pbWFnZS1waWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7QmJGb3JtQ29udHJvbH0gZnJvbSAnLi9mb3JtLWNvbnRyb2wvZm9ybS1jb250cm9sLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiUmFkaW9CdXR0b259IGZyb20gJy4vcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHtCYkltYWdlVXBsb2FkfSBmcm9tICcuL2RpcmVjdGl2ZXMvaW1hZ2UtdXBsb2FkLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiRmlsZVBpY2tlcn0gZnJvbSAnLi9maWxlLXBpY2tlci9maWxlLXBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHtCYkRhdGVQaWNrZXJ9IGZyb20gJy4vZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7QmJSYWRpb0dyb3VwfSBmcm9tICcuL3JhZGlvLWdyb3VwL3JhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiUHJlZml4LCBCYlN1ZmZpeH0gZnJvbSAnLi9kaXJlY3RpdmVzL2FkZG9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiRm9ybVN1Ym1pdH0gZnJvbSAnLi9kaXJlY3RpdmVzL2Zvcm0tc3VibWl0LmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiRm9ybUdyb3VwfSBmcm9tICcuL2Zvcm0tZ3JvdXAvZm9ybS1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHtCYkZvcm1FcnJvcn0gZnJvbSAnLi9mb3JtLWVycm9yL2Zvcm0tZXJyb3IuY29tcG9uZW50JztcbmltcG9ydCB7QmJBbmNob3IsIEJiQnV0dG9ufSBmcm9tICcuL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7TW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCYlJlbGF0aXZlVGltZX0gZnJvbSAnLi9waXBlcy9yZWxhdGl2ZS10aW1lLnBpcGUnO1xuaW1wb3J0IHtCYkNoZWNrYm94fSBmcm9tICcuL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5pbXBvcnQge3Byb3ZpZGVFbGVtZW50c0NvbmZpZ30gZnJvbSAnLi9lbGVtZW50cy5jb25maWcnO1xuaW1wb3J0IHtCYlNwaW5uZXJ9IGZyb20gJy4vc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiSW5wdXR9IGZyb20gJy4vZGlyZWN0aXZlcy9pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkZpbGVJbWFnZX0gZnJvbSAnLi9waXBlcy9maWxlLWltYWdlLnBpcGUnO1xuaW1wb3J0IHtCYkF2YXRhcn0gZnJvbSAnLi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiRmlsZVNpemV9IGZyb20gJy4vcGlwZXMvZmlsZS1zaXplLnBpcGUnO1xuaW1wb3J0IHtCYkljb259IGZyb20gJy4vaWNvbi9pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiRGF0ZX0gZnJvbSAnLi9waXBlcy9kYXRlLnBpcGUnO1xuXG5jb25zdCBJTVBPUlRTX0VYUE9SVFMgPSBbXG4gICAgLy8gRGlyZWN0aXZlcy5cbiAgICBCYkZvcm1FcnJvcixcbiAgICBCYkZvcm1TdWJtaXQsXG4gICAgQmJGb3JtU3VibWl0dGVyLFxuICAgIEJiSW5wdXQsXG4gICAgQmJQcmVmaXgsXG4gICAgQmJTdWZmaXgsXG4gICAgQmJJbWFnZVVwbG9hZCxcbiAgICBCYkV4dHJhRXJyb3JDb250cm9scyxcbiAgICAvLyBQaXBlcy5cbiAgICBCYkZpbGVTaXplLFxuICAgIEJiRmlsZUltYWdlLFxuICAgIEJiUmVsYXRpdmVUaW1lLFxuICAgIEJiRGF0ZSxcbiAgICAvLyBDb21wb25lbnRzLlxuICAgIEJiQnV0dG9uLFxuICAgIEJiQW5jaG9yLFxuICAgIEJiU3Bpbm5lcixcbiAgICBCYkljb24sXG4gICAgQmJGb3JtQ29udHJvbCxcbiAgICBCYkZvcm1Hcm91cCxcbiAgICBCYkNoZWNrYm94LFxuICAgIEJiQ2hlY2tib3hHcm91cCxcbiAgICBCYlJhZGlvR3JvdXAsXG4gICAgQmJSYWRpb0J1dHRvbixcbiAgICBCYkF2YXRhcixcbiAgICBCYk11bHRpRmlsZUNvbnRyb2wsXG4gICAgQmJGaWxlUGlja2VyLFxuICAgIEJiSW1hZ2VQaWNrZXIsXG4gICAgQmJEYXRlUGlja2VyXG5dO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFsuLi5JTVBPUlRTX0VYUE9SVFNdLFxuICAgIGV4cG9ydHM6IFsuLi5JTVBPUlRTX0VYUE9SVFNdXG59KVxuZXhwb3J0IGNsYXNzIEVsZW1lbnRzTW9kdWxlIHtcblxuICAgIHN0YXRpYyBmb3JSb290KCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8RWxlbWVudHNNb2R1bGU+IHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5nTW9kdWxlOiBFbGVtZW50c01vZHVsZSxcbiAgICAgICAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICAgICAgICAgIHByb3ZpZGVFbGVtZW50c0NvbmZpZygpXG4gICAgICAgICAgICBdXG4gICAgICAgIH07XG4gICAgfVxuXG59XG4iXX0=
142
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmItZm91bmRhdGlvbi9lbGVtZW50cy9zcmMvbGliL2VsZW1lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxtREFBbUQsQ0FBQztBQUNyRixPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUNqRixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDMUUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3RFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUNwRSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDcEUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNsRSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDakUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNqRSxPQUFPLEVBQUMsUUFBUSxFQUFFLFFBQVEsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUNoRSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDOUQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQzlELE9BQU8sRUFBQyxRQUFRLEVBQUUsUUFBUSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFzQixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUN6RCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RCxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFdEQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDbkQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxNQUFNLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sbUJBQW1CLENBQUM7O0FBRXpDLE1BQU0sZUFBZSxHQUFHO0lBQ3BCLGNBQWM7SUFDZCxXQUFXO0lBQ1gsWUFBWTtJQUNaLGVBQWU7SUFDZixPQUFPO0lBQ1AsUUFBUTtJQUNSLFFBQVE7SUFDUixhQUFhO0lBQ2Isb0JBQW9CO0lBQ3BCLFNBQVM7SUFDVCxVQUFVO0lBQ1YsV0FBVztJQUNYLGNBQWM7SUFDZCxNQUFNO0lBQ04sY0FBYztJQUNkLFFBQVE7SUFDUixRQUFRO0lBQ1IsU0FBUztJQUNULE1BQU07SUFDTixhQUFhO0lBQ2IsV0FBVztJQUNYLFVBQVU7SUFDVixlQUFlO0lBQ2YsWUFBWTtJQUNaLGFBQWE7SUFDYixRQUFRO0lBQ1Isa0JBQWtCO0lBQ2xCLFlBQVk7SUFDWixhQUFhO0lBQ2IsWUFBWTtDQUNmLENBQUM7QUFNRixNQUFNLE9BQU8sY0FBYztJQUV2QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXVCO1FBQ2xDLE9BQU87WUFDSCxRQUFRLEVBQUUsY0FBYztZQUN4QixTQUFTLEVBQUU7Z0JBQ1AscUJBQXFCLENBQUMsTUFBTSxDQUFDO2FBQ2hDO1NBQ0osQ0FBQztJQUNOLENBQUM7dUdBVFEsY0FBYzt3R0FBZCxjQUFjO1lBcEN2QixjQUFjO1lBQ2QsV0FBVztZQUNYLFlBQVk7WUFDWixlQUFlO1lBQ2YsT0FBTztZQUNQLFFBQVE7WUFDUixRQUFRO1lBQ1IsYUFBYTtZQUNiLG9CQUFvQjtZQUNwQixTQUFTO1lBQ1QsVUFBVTtZQUNWLFdBQVc7WUFDWCxjQUFjO1lBQ2QsTUFBTTtZQUNOLGNBQWM7WUFDZCxRQUFRO1lBQ1IsUUFBUTtZQUNSLFNBQVM7WUFDVCxNQUFNO1lBQ04sYUFBYTtZQUNiLFdBQVc7WUFDWCxVQUFVO1lBQ1YsZUFBZTtZQUNmLFlBQVk7WUFDWixhQUFhO1lBQ2IsUUFBUTtZQUNSLGtCQUFrQjtZQUNsQixZQUFZO1lBQ1osYUFBYTtZQUNiLFlBQVk7WUE3QlosY0FBYztZQUNkLFdBQVc7WUFDWCxZQUFZO1lBQ1osZUFBZTtZQUNmLE9BQU87WUFDUCxRQUFRO1lBQ1IsUUFBUTtZQUNSLGFBQWE7WUFDYixvQkFBb0I7WUFDcEIsU0FBUztZQUNULFVBQVU7WUFDVixXQUFXO1lBQ1gsY0FBYztZQUNkLE1BQU07WUFDTixjQUFjO1lBQ2QsUUFBUTtZQUNSLFFBQVE7WUFDUixTQUFTO1lBQ1QsTUFBTTtZQUNOLGFBQWE7WUFDYixXQUFXO1lBQ1gsVUFBVTtZQUNWLGVBQWU7WUFDZixZQUFZO1lBQ1osYUFBYTtZQUNiLFFBQVE7WUFDUixrQkFBa0I7WUFDbEIsWUFBWTtZQUNaLGFBQWE7WUFDYixZQUFZO3dHQU9ILGNBQWMsWUFWdkIsa0JBQWtCO1lBR2xCLFlBQVk7OzJGQU9ILGNBQWM7a0JBSjFCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsR0FBRyxlQUFlLENBQUM7b0JBQzdCLE9BQU8sRUFBRSxDQUFDLEdBQUcsZUFBZSxDQUFDO2lCQUNoQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QmJNdWx0aUZpbGVDb250cm9sfSBmcm9tICcuL211bHRpLWZpbGUtY29udHJvbC9tdWx0aS1maWxlLWNvbnRyb2wuY29tcG9uZW50JztcbmltcG9ydCB7QmJFeHRyYUVycm9yQ29udHJvbHN9IGZyb20gJy4vZGlyZWN0aXZlcy9leHRyYS1lcnJvci1jb250cm9scy5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkNoZWNrYm94R3JvdXB9IGZyb20gJy4vY2hlY2tib3gtZ3JvdXAvY2hlY2tib3gtZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7QmJGb3JtU3VibWl0dGVyfSBmcm9tICcuL2RpcmVjdGl2ZXMvZm9ybS1zdWJtaXR0ZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7QmJJbWFnZVBpY2tlcn0gZnJvbSAnLi9pbWFnZS1waWNrZXIvaW1hZ2UtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiRm9ybUNvbnRyb2x9IGZyb20gJy4vZm9ybS1jb250cm9sL2Zvcm0tY29udHJvbC5jb21wb25lbnQnO1xuaW1wb3J0IHtCYlJhZGlvQnV0dG9ufSBmcm9tICcuL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7QmJJbWFnZVVwbG9hZH0gZnJvbSAnLi9kaXJlY3RpdmVzL2ltYWdlLXVwbG9hZC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkZpbGVQaWNrZXJ9IGZyb20gJy4vZmlsZS1waWNrZXIvZmlsZS1waWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7QmJEYXRlUGlja2VyfSBmcm9tICcuL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiUmFkaW9Hcm91cH0gZnJvbSAnLi9yYWRpby1ncm91cC9yYWRpby1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHtCYlByZWZpeCwgQmJTdWZmaXh9IGZyb20gJy4vZGlyZWN0aXZlcy9hZGRvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkZvcm1TdWJtaXR9IGZyb20gJy4vZGlyZWN0aXZlcy9mb3JtLXN1Ym1pdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYkZvcm1Hcm91cH0gZnJvbSAnLi9mb3JtLWdyb3VwL2Zvcm0tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7QmJGb3JtRXJyb3J9IGZyb20gJy4vZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudCc7XG5pbXBvcnQge0JiQW5jaG9yLCBCYkJ1dHRvbn0gZnJvbSAnLi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQge01vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QmJSZWxhdGl2ZVRpbWV9IGZyb20gJy4vcGlwZXMvcmVsYXRpdmUtdGltZS5waXBlJztcbmltcG9ydCB7QmJDaGVja2JveH0gZnJvbSAnLi9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuaW1wb3J0IHtwcm92aWRlRWxlbWVudHNDb25maWd9IGZyb20gJy4vZWxlbWVudHMuY29uZmlnJztcbmltcG9ydCB7QmJTcGlubmVyfSBmcm9tICcuL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQnO1xuaW1wb3J0IHtFbGVtZW50c0NvbmZpZ30gZnJvbSAnLi9lbGVtZW50cy5pbnRlcmZhY2VzJztcbmltcG9ydCB7QmJJbnB1dH0gZnJvbSAnLi9kaXJlY3RpdmVzL2lucHV0LmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiRmlsZUltYWdlfSBmcm9tICcuL3BpcGVzL2ZpbGUtaW1hZ2UucGlwZSc7XG5pbXBvcnQge0JiQXZhdGFyfSBmcm9tICcuL2F2YXRhci9hdmF0YXIuY29tcG9uZW50JztcbmltcG9ydCB7QmJGaWxlU2l6ZX0gZnJvbSAnLi9waXBlcy9maWxlLXNpemUucGlwZSc7XG5pbXBvcnQge0JiSWNvbn0gZnJvbSAnLi9pY29uL2ljb24uY29tcG9uZW50JztcbmltcG9ydCB7QmJEYXRlfSBmcm9tICcuL3BpcGVzL2RhdGUucGlwZSc7XG5cbmNvbnN0IElNUE9SVFNfRVhQT1JUUyA9IFtcbiAgICAvLyBEaXJlY3RpdmVzLlxuICAgIEJiRm9ybUVycm9yLFxuICAgIEJiRm9ybVN1Ym1pdCxcbiAgICBCYkZvcm1TdWJtaXR0ZXIsXG4gICAgQmJJbnB1dCxcbiAgICBCYlByZWZpeCxcbiAgICBCYlN1ZmZpeCxcbiAgICBCYkltYWdlVXBsb2FkLFxuICAgIEJiRXh0cmFFcnJvckNvbnRyb2xzLFxuICAgIC8vIFBpcGVzLlxuICAgIEJiRmlsZVNpemUsXG4gICAgQmJGaWxlSW1hZ2UsXG4gICAgQmJSZWxhdGl2ZVRpbWUsXG4gICAgQmJEYXRlLFxuICAgIC8vIENvbXBvbmVudHMuXG4gICAgQmJCdXR0b24sXG4gICAgQmJBbmNob3IsXG4gICAgQmJTcGlubmVyLFxuICAgIEJiSWNvbixcbiAgICBCYkZvcm1Db250cm9sLFxuICAgIEJiRm9ybUdyb3VwLFxuICAgIEJiQ2hlY2tib3gsXG4gICAgQmJDaGVja2JveEdyb3VwLFxuICAgIEJiUmFkaW9Hcm91cCxcbiAgICBCYlJhZGlvQnV0dG9uLFxuICAgIEJiQXZhdGFyLFxuICAgIEJiTXVsdGlGaWxlQ29udHJvbCxcbiAgICBCYkZpbGVQaWNrZXIsXG4gICAgQmJJbWFnZVBpY2tlcixcbiAgICBCYkRhdGVQaWNrZXJcbl07XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogWy4uLklNUE9SVFNfRVhQT1JUU10sXG4gICAgZXhwb3J0czogWy4uLklNUE9SVFNfRVhQT1JUU11cbn0pXG5leHBvcnQgY2xhc3MgRWxlbWVudHNNb2R1bGUge1xuXG4gICAgc3RhdGljIGZvclJvb3QoY29uZmlnPzogRWxlbWVudHNDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEVsZW1lbnRzTW9kdWxlPiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBuZ01vZHVsZTogRWxlbWVudHNNb2R1bGUsXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICAgICAgICBwcm92aWRlRWxlbWVudHNDb25maWcoY29uZmlnKVxuICAgICAgICAgICAgXVxuICAgICAgICB9O1xuICAgIH1cblxufVxuIl19