@ui5/theming-ngx 0.3.4-rc.0 → 0.4.0-rc.0

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.
@@ -101,10 +101,10 @@ class Ui5ThemingService {
101
101
  this._destroyed$.next();
102
102
  this._destroyed$.complete();
103
103
  }
104
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService, deps: [{ token: UI5_THEMING_CONFIGURATION, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
105
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService }); }
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingService, deps: [{ token: UI5_THEMING_CONFIGURATION, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
105
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingService }); }
106
106
  }
107
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService, decorators: [{
107
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingService, decorators: [{
108
108
  type: Injectable
109
109
  }], ctorParameters: () => [{ type: undefined, decorators: [{
110
110
  type: Optional
@@ -132,11 +132,11 @@ class Ui5ThemingModule {
132
132
  ],
133
133
  };
134
134
  }
135
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule, deps: [{ token: Ui5ThemingService, optional: true }], target: i0.ɵɵFactoryTarget.NgModule }); }
136
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule }); }
137
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule }); }
135
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingModule, deps: [{ token: Ui5ThemingService, optional: true }], target: i0.ɵɵFactoryTarget.NgModule }); }
136
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingModule }); }
137
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingModule }); }
138
138
  }
139
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule, decorators: [{
139
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.3", ngImport: i0, type: Ui5ThemingModule, decorators: [{
140
140
  type: NgModule,
141
141
  args: [{
142
142
  exports: [],
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ui5/theming-ngx",
3
- "version": "0.3.4-rc.0",
3
+ "version": "0.4.0-rc.0",
4
4
  "license": "Apache-2.0",
5
5
  "author": "SAP SE (https://www.sap.com)",
6
6
  "repository": {
@@ -9,8 +9,8 @@
9
9
  "directory": "libs/ui5-angular-theming"
10
10
  },
11
11
  "peerDependencies": {
12
- "@angular/common": "^18.0.0",
13
- "@angular/core": "^18.0.0"
12
+ "@angular/common": "^19.0.0",
13
+ "@angular/core": "^19.0.0"
14
14
  },
15
15
  "dependencies": {
16
16
  "tslib": "^2.3.0"
@@ -23,8 +23,6 @@
23
23
  },
24
24
  ".": {
25
25
  "types": "./index.d.ts",
26
- "esm2022": "./esm2022/ui5-theming-ngx.mjs",
27
- "esm": "./esm2022/ui5-theming-ngx.mjs",
28
26
  "default": "./fesm2022/ui5-theming-ngx.mjs"
29
27
  }
30
28
  },
Binary file
package/esm2022/index.mjs DELETED
@@ -1,4 +0,0 @@
1
- export { Ui5ThemingModule } from './ui5-theming.module';
2
- export { Ui5ThemingService } from './ui5-theming.service';
3
- export * from './ui5-theming.models';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3VpNS1hbmd1bGFyLXRoZW1pbmcvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBVaTVUaGVtaW5nTW9kdWxlIH0gZnJvbSAnLi91aTUtdGhlbWluZy5tb2R1bGUnO1xuZXhwb3J0IHsgVWk1VGhlbWluZ1NlcnZpY2UgfSBmcm9tICcuL3VpNS10aGVtaW5nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi91aTUtdGhlbWluZy5tb2RlbHMnO1xuIl19
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWk1LXRoZW1pbmctbmd4LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy91aTUtYW5ndWxhci10aGVtaW5nL3NyYy91aTUtdGhlbWluZy1uZ3gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -1,3 +0,0 @@
1
- import { InjectionToken } from '@angular/core';
2
- export const UI5_THEMING_CONFIGURATION = new InjectionToken('Ui5 global theming configuration.');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWk1LXRoZW1pbmcubW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy91aTUtYW5ndWxhci10aGVtaW5nL3NyYy91aTUtdGhlbWluZy5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUsvQyxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLGNBQWMsQ0FDekQsbUNBQW1DLENBQ3BDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuZXhwb3J0IGludGVyZmFjZSBUaGVtaW5nQ29uZmlnIHtcbiAgZGVmYXVsdFRoZW1lOiBzdHJpbmc7XG59XG5leHBvcnQgY29uc3QgVUk1X1RIRU1JTkdfQ09ORklHVVJBVElPTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUaGVtaW5nQ29uZmlnPihcbiAgJ1VpNSBnbG9iYWwgdGhlbWluZyBjb25maWd1cmF0aW9uLidcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVWk1VGhlbWluZ1Byb3ZpZGVyIHtcbiAgbmFtZTogc3RyaW5nO1xuICBnZXRBdmFpbGFibGVUaGVtZXMoKTogc3RyaW5nW10gfCBPYnNlcnZhYmxlPHN0cmluZ1tdPjtcbiAgc3VwcG9ydHNUaGVtZSh0aGVtZU5hbWU6IHN0cmluZyk6IGJvb2xlYW4gfCBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuICBzZXRUaGVtZSh0aGVtZU5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8Ym9vbGVhbj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVWk1VGhlbWluZ0NvbnN1bWVyIGV4dGVuZHMgT21pdDxVaTVUaGVtaW5nUHJvdmlkZXIsICduYW1lJz4ge1xuICByZWdpc3RlclByb3ZpZGVyKHByb3ZpZGVyOiBVaTVUaGVtaW5nUHJvdmlkZXIpOiB2b2lkO1xuICB1bnJlZ2lzdGVyUHJvdmlkZXIocHJvdmlkZXI6IFVpNVRoZW1pbmdQcm92aWRlcik6IHZvaWQ7XG59XG4iXX0=
@@ -1,38 +0,0 @@
1
- import { NgModule, Optional, isDevMode, } from '@angular/core';
2
- import { Ui5ThemingService } from './ui5-theming.service';
3
- import { UI5_THEMING_CONFIGURATION } from './ui5-theming.models';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "./ui5-theming.service";
6
- export class Ui5ThemingModule {
7
- constructor(theming) {
8
- this.theming = theming;
9
- if (!this.theming && isDevMode()) {
10
- console.error('Could not find Ui5ThemingService. Make sure you called .forRoot() for Ui5ThemingModule');
11
- }
12
- }
13
- static forRoot(config) {
14
- return {
15
- ngModule: Ui5ThemingModule,
16
- providers: [
17
- Ui5ThemingService,
18
- {
19
- provide: UI5_THEMING_CONFIGURATION,
20
- useValue: config,
21
- },
22
- ],
23
- };
24
- }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule, deps: [{ token: i1.Ui5ThemingService, optional: true }], target: i0.ɵɵFactoryTarget.NgModule }); }
26
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule }); }
27
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule }); }
28
- }
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingModule, decorators: [{
30
- type: NgModule,
31
- args: [{
32
- exports: [],
33
- declarations: [],
34
- }]
35
- }], ctorParameters: () => [{ type: i1.Ui5ThemingService, decorators: [{
36
- type: Optional
37
- }] }] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWk1LXRoZW1pbmcubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy91aTUtYW5ndWxhci10aGVtaW5nL3NyYy91aTUtdGhlbWluZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFFBQVEsRUFFUixRQUFRLEVBQ1IsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBaUIseUJBQXlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBTWhGLE1BQU0sT0FBTyxnQkFBZ0I7SUFDM0IsWUFBK0IsT0FBMEI7UUFBMUIsWUFBTyxHQUFQLE9BQU8sQ0FBbUI7UUFDdkQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksU0FBUyxFQUFFLEVBQUUsQ0FBQztZQUNqQyxPQUFPLENBQUMsS0FBSyxDQUNYLHdGQUF3RixDQUN6RixDQUFDO1FBQ0osQ0FBQztJQUNILENBQUM7SUFDRCxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXFCO1FBQ2xDLE9BQU87WUFDTCxRQUFRLEVBQUUsZ0JBQWdCO1lBQzFCLFNBQVMsRUFBRTtnQkFDVCxpQkFBaUI7Z0JBQ2pCO29CQUNFLE9BQU8sRUFBRSx5QkFBeUI7b0JBQ2xDLFFBQVEsRUFBRSxNQUFNO2lCQUNqQjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7OEdBbkJVLGdCQUFnQjsrR0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBSjVCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsWUFBWSxFQUFFLEVBQUU7aUJBQ2pCOzswQkFFYyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgTmdNb2R1bGUsXG4gIE1vZHVsZVdpdGhQcm92aWRlcnMsXG4gIE9wdGlvbmFsLFxuICBpc0Rldk1vZGUsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVWk1VGhlbWluZ1NlcnZpY2UgfSBmcm9tICcuL3VpNS10aGVtaW5nLnNlcnZpY2UnO1xuaW1wb3J0IHsgVGhlbWluZ0NvbmZpZywgVUk1X1RIRU1JTkdfQ09ORklHVVJBVElPTiB9IGZyb20gJy4vdWk1LXRoZW1pbmcubW9kZWxzJztcblxuQE5nTW9kdWxlKHtcbiAgZXhwb3J0czogW10sXG4gIGRlY2xhcmF0aW9uczogW10sXG59KVxuZXhwb3J0IGNsYXNzIFVpNVRoZW1pbmdNb2R1bGUge1xuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwdWJsaWMgdGhlbWluZzogVWk1VGhlbWluZ1NlcnZpY2UpIHtcbiAgICBpZiAoIXRoaXMudGhlbWluZyAmJiBpc0Rldk1vZGUoKSkge1xuICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgJ0NvdWxkIG5vdCBmaW5kIFVpNVRoZW1pbmdTZXJ2aWNlLiBNYWtlIHN1cmUgeW91IGNhbGxlZCAuZm9yUm9vdCgpIGZvciBVaTVUaGVtaW5nTW9kdWxlJ1xuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgc3RhdGljIGZvclJvb3QoY29uZmlnOiBUaGVtaW5nQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVyczxVaTVUaGVtaW5nTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBVaTVUaGVtaW5nTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIFVpNVRoZW1pbmdTZXJ2aWNlLFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogVUk1X1RIRU1JTkdfQ09ORklHVVJBVElPTixcbiAgICAgICAgICB1c2VWYWx1ZTogY29uZmlnLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9O1xuICB9XG59XG4iXX0=
@@ -1,113 +0,0 @@
1
- import { Inject, Injectable, isDevMode, Optional } from '@angular/core';
2
- import { BehaviorSubject, combineLatest, map, Observable, Subject, switchMap, takeUntil, tap, of, delay, } from 'rxjs';
3
- import { UI5_THEMING_CONFIGURATION, } from './ui5-theming.models';
4
- import * as i0 from "@angular/core";
5
- export class Ui5ThemingService {
6
- constructor(_config) {
7
- this._config = _config;
8
- this._providers$ = new BehaviorSubject([]);
9
- this._currentTheme$ = new BehaviorSubject([
10
- this._config?.defaultTheme || 'sap_fiori_3',
11
- this._config?.defaultTheme || 'sap_fiori_3',
12
- ]);
13
- this._themeChanged$ = new Subject();
14
- this._destroyed$ = new Subject();
15
- combineLatest([
16
- this._providers$,
17
- this._currentTheme$.pipe(delay(100)) // Delay so that the providers are registered. @todo: Find a better solution
18
- ])
19
- .pipe(switchMap(([providers, [previousTheme, newTheme]]) => {
20
- return combineLatest(providers.map((provider) => {
21
- const isSupported = provider.supportsTheme(newTheme);
22
- if (typeof isSupported === 'boolean') {
23
- return of([provider, isSupported]);
24
- }
25
- return isSupported.pipe(map((supported) => [provider, supported]));
26
- })).pipe(switchMap((providers) => {
27
- const unsupportedProviders = providers.filter(([, supported]) => !supported);
28
- if (unsupportedProviders.length) {
29
- if (isDevMode()) {
30
- console.warn(`The following providers do not support the theme "${newTheme}":`, unsupportedProviders.map(([provider]) => provider.name));
31
- }
32
- }
33
- return combineLatest(providers.map(([provider]) => provider.setTheme(newTheme)));
34
- }), map((providerResponses) => {
35
- if (providerResponses.every(Boolean)) {
36
- return newTheme;
37
- }
38
- return previousTheme;
39
- }));
40
- }), tap((theme) => {
41
- this._themeChanged$.next(theme);
42
- }), takeUntil(this._destroyed$))
43
- .subscribe();
44
- }
45
- supportsTheme(themeName) {
46
- return this.getAvailableThemes().pipe(map((themes) => themes.includes(themeName)));
47
- }
48
- getAvailableThemes() {
49
- return this._providers$.pipe(switchMap((providers) => {
50
- return combineLatest(providers.map((provider) => {
51
- const availableThemes = provider.getAvailableThemes();
52
- if (Array.isArray(availableThemes)) {
53
- return of(availableThemes);
54
- }
55
- return availableThemes;
56
- })).pipe(map((providerResponses) => {
57
- const uniques = providerResponses.reduce((acc, curr) => {
58
- curr.forEach((theme) => acc.add(theme));
59
- return acc;
60
- }, new Set());
61
- return [...uniques.values()];
62
- }));
63
- }));
64
- }
65
- /** Registers theming provider for further usage. */
66
- registerProvider(provider) {
67
- const providers = this._providers$.value;
68
- providers.push(provider);
69
- this._providers$.next(providers);
70
- }
71
- /** Unregisters previously registered theming provider. */
72
- unregisterProvider(provider) {
73
- const providers = this._providers$.value;
74
- const index = providers.indexOf(provider);
75
- if (index !== -1) {
76
- providers.splice(index, 1);
77
- this._providers$.next(providers);
78
- }
79
- }
80
- /** Sets the theme to the providers */
81
- setTheme(theme) {
82
- return new Observable((subscriber) => {
83
- const finalizer$ = new Subject();
84
- this._themeChanged$
85
- .pipe(takeUntil(finalizer$))
86
- .subscribe((changedTheme) => {
87
- if (changedTheme === theme) {
88
- finalizer$.next();
89
- finalizer$.complete();
90
- }
91
- subscriber.next(changedTheme === theme);
92
- subscriber.complete();
93
- });
94
- this._currentTheme$.next([this._currentTheme$.value[1], theme]);
95
- });
96
- }
97
- /** @hidden */
98
- ngOnDestroy() {
99
- this._destroyed$.next();
100
- this._destroyed$.complete();
101
- }
102
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService, deps: [{ token: UI5_THEMING_CONFIGURATION, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
103
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService }); }
104
- }
105
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: Ui5ThemingService, decorators: [{
106
- type: Injectable
107
- }], ctorParameters: () => [{ type: undefined, decorators: [{
108
- type: Optional
109
- }, {
110
- type: Inject,
111
- args: [UI5_THEMING_CONFIGURATION]
112
- }] }] });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui5-theming.service.js","sourceRoot":"","sources":["../../../../libs/ui5-angular-theming/src/ui5-theming.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable, isDevMode, OnDestroy, Optional} from '@angular/core';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  map,\n  Observable,\n  Subject,\n  switchMap,\n  takeUntil,\n  tap,\n  of, delay,\n} from 'rxjs';\nimport {\n  ThemingConfig,\n  UI5_THEMING_CONFIGURATION,\n  Ui5ThemingProvider,\n  Ui5ThemingConsumer,\n} from './ui5-theming.models';\n\n@Injectable()\nexport class Ui5ThemingService implements Ui5ThemingConsumer, OnDestroy {\n  private readonly _providers$ = new BehaviorSubject<Ui5ThemingProvider[]>([]);\n  private _currentTheme$ = new BehaviorSubject<[string, string]>([\n    this._config?.defaultTheme || 'sap_fiori_3',\n    this._config?.defaultTheme || 'sap_fiori_3',\n  ]);\n\n  private _themeChanged$ = new Subject<string>();\n\n  private _destroyed$ = new Subject<void>();\n\n  constructor(\n    @Optional() @Inject(UI5_THEMING_CONFIGURATION) private readonly _config: ThemingConfig\n  ) {\n    combineLatest([\n      this._providers$,\n      this._currentTheme$.pipe(delay(100)) // Delay so that the providers are registered. @todo: Find a better solution\n    ])\n      .pipe(\n        switchMap(([providers, [previousTheme, newTheme]]) => {\n          return combineLatest(\n            providers.map(\n              (provider): Observable<[Ui5ThemingProvider, boolean]> => {\n                const isSupported = provider.supportsTheme(newTheme);\n                if (typeof isSupported === 'boolean') {\n                  return of([provider, isSupported]);\n                }\n                return isSupported.pipe(\n                  map((supported) => [provider, supported])\n                );\n              }\n            )\n          ).pipe(\n            switchMap((providers) => {\n              const unsupportedProviders = providers.filter(\n                ([, supported]) => !supported\n              );\n              if (unsupportedProviders.length) {\n                if (isDevMode()) {\n                  console.warn(\n                    `The following providers do not support the theme \"${newTheme}\":`,\n                    unsupportedProviders.map(([provider]) => provider.name)\n                  );\n                }\n              }\n              return combineLatest(\n                providers.map(([provider]) => provider.setTheme(newTheme))\n              );\n            }),\n            map((providerResponses) => {\n              if (providerResponses.every(Boolean)) {\n                return newTheme;\n              }\n              return previousTheme;\n            })\n          );\n        }),\n        tap((theme) => {\n          this._themeChanged$.next(theme);\n        }),\n        takeUntil(this._destroyed$)\n      )\n      .subscribe();\n  }\n\n  supportsTheme(themeName: string): Observable<boolean> {\n    return this.getAvailableThemes().pipe(\n      map((themes) => themes.includes(themeName))\n    );\n  }\n\n  getAvailableThemes(): Observable<string[]> {\n    return this._providers$.pipe(\n      switchMap((providers) => {\n        return combineLatest(\n          providers.map((provider) => {\n            const availableThemes = provider.getAvailableThemes();\n            if (Array.isArray(availableThemes)) {\n              return of(availableThemes);\n            }\n            return availableThemes;\n          })\n        ).pipe(\n          map((providerResponses: Array<string[]>) => {\n            const uniques = providerResponses.reduce((acc, curr) => {\n              curr.forEach((theme) => acc.add(theme));\n              return acc;\n            }, new Set<string>());\n            return [...uniques.values()];\n          })\n        );\n      })\n    );\n  }\n\n  /** Registers theming provider for further usage. */\n  registerProvider(provider: Ui5ThemingProvider): void {\n    const providers = this._providers$.value;\n    providers.push(provider);\n    this._providers$.next(providers);\n  }\n\n  /** Unregisters previously registered theming provider. */\n  unregisterProvider(provider: Ui5ThemingProvider): void {\n    const providers = this._providers$.value;\n    const index = providers.indexOf(provider);\n    if (index !== -1) {\n      providers.splice(index, 1);\n      this._providers$.next(providers);\n    }\n  }\n\n  /** Sets the theme to the providers */\n  setTheme(theme: string): Observable<boolean> {\n    return new Observable<boolean>((subscriber) => {\n      const finalizer$ = new Subject<void>();\n      this._themeChanged$\n        .pipe(takeUntil(finalizer$))\n        .subscribe((changedTheme) => {\n          if (changedTheme === theme) {\n            finalizer$.next();\n            finalizer$.complete();\n          }\n          subscriber.next(changedTheme === theme);\n          subscriber.complete();\n        });\n      this._currentTheme$.next([this._currentTheme$.value[1], theme]);\n    });\n  }\n\n  /** @hidden */\n  ngOnDestroy(): void {\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n}\n"]}
Binary file