@elderbyte/ngx-starter 14.1.1 → 14.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +29 -11
  2. package/esm2020/lib/components/public_api.mjs +2 -1
  3. package/esm2020/lib/components/shell/elder-shell.module.mjs +5 -4
  4. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +51 -14
  5. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +47 -22
  6. package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +62 -0
  7. package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +62 -0
  8. package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +72 -0
  9. package/esm2020/lib/components/theme/elder-theme.directive.mjs +61 -0
  10. package/esm2020/lib/components/theme/elder-theme.module.mjs +74 -0
  11. package/esm2020/lib/components/theme/elder-theme.service.mjs +123 -0
  12. package/esm2020/lib/components/theme/known-elder-themes.mjs +6 -0
  13. package/esm2020/lib/components/theme/public_api.mjs +2 -0
  14. package/esm2020/lib/components/theme/theme-spec.mjs +15 -0
  15. package/fesm2015/elderbyte-ngx-starter.mjs +619 -119
  16. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  17. package/fesm2020/elderbyte-ngx-starter.mjs +616 -119
  18. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  19. package/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.d.ts +10 -5
  20. package/lib/components/public_api.d.ts +1 -0
  21. package/lib/components/shell/elder-shell.module.d.ts +2 -1
  22. package/lib/components/shell/header/elder-app-header/elder-app-header.component.d.ts +33 -6
  23. package/lib/components/shell/shell/elder-shell.component.d.ts +16 -6
  24. package/lib/components/theme/elder-theme-applier.directive.d.ts +36 -0
  25. package/lib/components/theme/elder-theme-preference.service.d.ts +33 -0
  26. package/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.d.ts +37 -0
  27. package/lib/components/theme/elder-theme.directive.d.ts +38 -0
  28. package/lib/components/theme/elder-theme.module.d.ts +22 -0
  29. package/lib/components/theme/elder-theme.service.d.ts +51 -0
  30. package/lib/components/theme/known-elder-themes.d.ts +5 -0
  31. package/lib/components/theme/public_api.d.ts +1 -0
  32. package/lib/components/theme/theme-spec.d.ts +18 -0
  33. package/package.json +1 -1
  34. package/src/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.scss +0 -0
  35. package/theming/_elder-scrollbar-theme.scss +1 -1
@@ -0,0 +1,74 @@
1
+ import { APP_INITIALIZER, NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ElderThemeApplierDirective } from './elder-theme-applier.directive';
4
+ import { ElderThemeToggleComponent } from './elder-theme-toggle/elder-theme-toggle.component';
5
+ import { MatSlideToggleModule } from '@angular/material/slide-toggle';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { FormsModule } from '@angular/forms';
8
+ import { ElderThemePreferenceService } from './elder-theme-preference.service';
9
+ import { ElderThemeDirective } from './elder-theme.directive';
10
+ import * as i0 from "@angular/core";
11
+ export { ThemeSpec } from './theme-spec';
12
+ export { KnownElderThemes } from './known-elder-themes';
13
+ export { ElderThemeService } from './elder-theme.service';
14
+ export { ElderThemePreferenceService } from './elder-theme-preference.service';
15
+ export { ElderThemeApplierDirective } from './elder-theme-applier.directive';
16
+ export { ElderThemeToggleComponent } from './elder-theme-toggle/elder-theme-toggle.component';
17
+ export { ElderThemeDirective } from './elder-theme.directive';
18
+ export function themeInit(thpref) {
19
+ return () => {
20
+ // Required so the ElderThemePreferenceService is initialized
21
+ };
22
+ }
23
+ export class ElderThemeModule {
24
+ }
25
+ ElderThemeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
26
+ ElderThemeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeModule, declarations: [ElderThemeApplierDirective,
27
+ ElderThemeToggleComponent,
28
+ ElderThemeDirective], imports: [CommonModule,
29
+ MatSlideToggleModule,
30
+ MatIconModule,
31
+ FormsModule], exports: [ElderThemeApplierDirective,
32
+ ElderThemeToggleComponent,
33
+ ElderThemeDirective] });
34
+ ElderThemeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeModule, providers: [
35
+ {
36
+ provide: APP_INITIALIZER,
37
+ useFactory: themeInit,
38
+ deps: [ElderThemePreferenceService],
39
+ multi: true
40
+ }
41
+ ], imports: [CommonModule,
42
+ MatSlideToggleModule,
43
+ MatIconModule,
44
+ FormsModule] });
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeModule, decorators: [{
46
+ type: NgModule,
47
+ args: [{
48
+ imports: [
49
+ CommonModule,
50
+ MatSlideToggleModule,
51
+ MatIconModule,
52
+ FormsModule
53
+ ],
54
+ declarations: [
55
+ ElderThemeApplierDirective,
56
+ ElderThemeToggleComponent,
57
+ ElderThemeDirective
58
+ ],
59
+ exports: [
60
+ ElderThemeApplierDirective,
61
+ ElderThemeToggleComponent,
62
+ ElderThemeDirective
63
+ ],
64
+ providers: [
65
+ {
66
+ provide: APP_INITIALIZER,
67
+ useFactory: themeInit,
68
+ deps: [ElderThemePreferenceService],
69
+ multi: true
70
+ }
71
+ ]
72
+ }]
73
+ }] });
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItdGhlbWUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy90aGVtZS9lbGRlci10aGVtZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGVBQWUsRUFBRSxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQzlGLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3BFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBRTlELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxjQUFjLENBQUM7QUFDdkMsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDN0UsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDM0UsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDNUYsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFFNUQsTUFBTSxVQUFVLFNBQVMsQ0FBQyxNQUFtQztJQUMzRCxPQUFPLEdBQUcsRUFBRTtRQUNWLDZEQUE2RDtJQUMvRCxDQUFDLENBQUM7QUFDSixDQUFDO0FBNEJELE1BQU0sT0FBTyxnQkFBZ0I7OzZHQUFoQixnQkFBZ0I7OEdBQWhCLGdCQUFnQixpQkFsQnpCLDBCQUEwQjtRQUMxQix5QkFBeUI7UUFDekIsbUJBQW1CLGFBUm5CLFlBQVk7UUFDWixvQkFBb0I7UUFDcEIsYUFBYTtRQUNiLFdBQVcsYUFRWCwwQkFBMEI7UUFDMUIseUJBQXlCO1FBQ3pCLG1CQUFtQjs4R0FXVixnQkFBZ0IsYUFUaEI7UUFDVDtZQUNFLE9BQU8sRUFBRSxlQUFlO1lBQ3hCLFVBQVUsRUFBRSxTQUFTO1lBQ3JCLElBQUksRUFBRSxDQUFDLDJCQUEyQixDQUFDO1lBQ25DLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRixZQXRCQyxZQUFZO1FBQ1osb0JBQW9CO1FBQ3BCLGFBQWE7UUFDYixXQUFXOzJGQXFCRixnQkFBZ0I7a0JBMUI1QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG9CQUFvQjt3QkFDcEIsYUFBYTt3QkFDYixXQUFXO3FCQUNaO29CQUNELFlBQVksRUFBRTt3QkFDWiwwQkFBMEI7d0JBQzFCLHlCQUF5Qjt3QkFDekIsbUJBQW1CO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMEJBQTBCO3dCQUMxQix5QkFBeUI7d0JBQ3pCLG1CQUFtQjtxQkFDcEI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxlQUFlOzRCQUN4QixVQUFVLEVBQUUsU0FBUzs0QkFDckIsSUFBSSxFQUFFLENBQUMsMkJBQTJCLENBQUM7NEJBQ25DLEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBUFBfSU5JVElBTElaRVIsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBFbGRlclRoZW1lQXBwbGllckRpcmVjdGl2ZSB9IGZyb20gJy4vZWxkZXItdGhlbWUtYXBwbGllci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRWxkZXJUaGVtZVRvZ2dsZUNvbXBvbmVudCB9IGZyb20gJy4vZWxkZXItdGhlbWUtdG9nZ2xlL2VsZGVyLXRoZW1lLXRvZ2dsZS5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRTbGlkZVRvZ2dsZU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2xpZGUtdG9nZ2xlJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge0VsZGVyVGhlbWVQcmVmZXJlbmNlU2VydmljZX0gZnJvbSAnLi9lbGRlci10aGVtZS1wcmVmZXJlbmNlLnNlcnZpY2UnO1xuaW1wb3J0IHsgRWxkZXJUaGVtZURpcmVjdGl2ZSB9IGZyb20gJy4vZWxkZXItdGhlbWUuZGlyZWN0aXZlJztcblxuZXhwb3J0IHtUaGVtZVNwZWN9IGZyb20gJy4vdGhlbWUtc3BlYyc7XG5leHBvcnQge0tub3duRWxkZXJUaGVtZXN9IGZyb20gJy4va25vd24tZWxkZXItdGhlbWVzJztcbmV4cG9ydCB7RWxkZXJUaGVtZVNlcnZpY2V9IGZyb20gJy4vZWxkZXItdGhlbWUuc2VydmljZSc7XG5leHBvcnQge0VsZGVyVGhlbWVQcmVmZXJlbmNlU2VydmljZX0gZnJvbSAnLi9lbGRlci10aGVtZS1wcmVmZXJlbmNlLnNlcnZpY2UnO1xuZXhwb3J0IHtFbGRlclRoZW1lQXBwbGllckRpcmVjdGl2ZX0gZnJvbSAnLi9lbGRlci10aGVtZS1hcHBsaWVyLmRpcmVjdGl2ZSc7XG5leHBvcnQge0VsZGVyVGhlbWVUb2dnbGVDb21wb25lbnR9IGZyb20gJy4vZWxkZXItdGhlbWUtdG9nZ2xlL2VsZGVyLXRoZW1lLXRvZ2dsZS5jb21wb25lbnQnO1xuZXhwb3J0IHtFbGRlclRoZW1lRGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXRoZW1lLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiB0aGVtZUluaXQodGhwcmVmOiBFbGRlclRoZW1lUHJlZmVyZW5jZVNlcnZpY2UpIHtcbiAgcmV0dXJuICgpID0+IHtcbiAgICAvLyBSZXF1aXJlZCBzbyB0aGUgRWxkZXJUaGVtZVByZWZlcmVuY2VTZXJ2aWNlIGlzIGluaXRpYWxpemVkXG4gIH07XG59XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0U2xpZGVUb2dnbGVNb2R1bGUsXG4gICAgTWF0SWNvbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlclRoZW1lQXBwbGllckRpcmVjdGl2ZSxcbiAgICBFbGRlclRoZW1lVG9nZ2xlQ29tcG9uZW50LFxuICAgIEVsZGVyVGhlbWVEaXJlY3RpdmVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyVGhlbWVBcHBsaWVyRGlyZWN0aXZlLFxuICAgIEVsZGVyVGhlbWVUb2dnbGVDb21wb25lbnQsXG4gICAgRWxkZXJUaGVtZURpcmVjdGl2ZVxuICBdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBBUFBfSU5JVElBTElaRVIsXG4gICAgICB1c2VGYWN0b3J5OiB0aGVtZUluaXQsXG4gICAgICBkZXBzOiBbRWxkZXJUaGVtZVByZWZlcmVuY2VTZXJ2aWNlXSxcbiAgICAgIG11bHRpOiB0cnVlXG4gICAgfVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyVGhlbWVNb2R1bGUgeyB9XG5cbiJdfQ==
@@ -0,0 +1,123 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { LoggerFactory } from '@elderbyte/ts-logger';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { filter, map } from 'rxjs/operators';
5
+ import { KnownElderThemes } from './known-elder-themes';
6
+ import * as i0 from "@angular/core";
7
+ export class ElderThemeService {
8
+ /***************************************************************************
9
+ * *
10
+ * Constructor *
11
+ * *
12
+ **************************************************************************/
13
+ constructor() {
14
+ /***************************************************************************
15
+ * *
16
+ * Fields *
17
+ * *
18
+ **************************************************************************/
19
+ this.logger = LoggerFactory.getLogger(this.constructor.name);
20
+ this._activeTheme$ = new BehaviorSubject(null);
21
+ this._defaultTheme$ = new BehaviorSubject(null);
22
+ this._themes$ = new BehaviorSubject(new Map());
23
+ this.registerTheme(KnownElderThemes.ELDER_LIGHT, true);
24
+ this.registerTheme(KnownElderThemes.ELDER_DARK);
25
+ }
26
+ /***************************************************************************
27
+ * *
28
+ * Properties *
29
+ * *
30
+ **************************************************************************/
31
+ get defaultTheme$() {
32
+ return this._defaultTheme$.asObservable();
33
+ }
34
+ get defaultThemeSnapshot() {
35
+ return this._defaultTheme$.getValue();
36
+ }
37
+ get themes$() {
38
+ return this._themes$.pipe(map(themeMap => Array.from(themeMap.values())));
39
+ }
40
+ get themesSnapshot() {
41
+ return Array.from(this._themes$.getValue().values());
42
+ }
43
+ get activeThemeSnapshot() {
44
+ return this._activeTheme$.getValue();
45
+ }
46
+ get activeTheme$() {
47
+ return this._activeTheme$
48
+ .asObservable()
49
+ .pipe(filter(theme => !!theme));
50
+ }
51
+ /***************************************************************************
52
+ * *
53
+ * Public API *
54
+ * *
55
+ **************************************************************************/
56
+ activateTheme(themeId) {
57
+ const theme = this.findTheme(themeId);
58
+ if (theme) {
59
+ this.logger.info('Activating theme ' + themeId);
60
+ this._activeTheme$.next(theme);
61
+ }
62
+ else {
63
+ this.logger.warn('Failed to activate theme ' + themeId + ' -> could not find registered theme with this id!');
64
+ }
65
+ }
66
+ defaultTheme(themeId) {
67
+ const theme = this.findTheme(themeId);
68
+ if (theme) {
69
+ this._defaultTheme$.next(theme);
70
+ }
71
+ }
72
+ registerTheme(theme, markDefault) {
73
+ this.modifyThemes(themeMap => themeMap.set(theme.id, theme));
74
+ if (markDefault || !this._defaultTheme$.getValue()) {
75
+ this._defaultTheme$.next(theme);
76
+ }
77
+ }
78
+ unregisterTheme(themeId) {
79
+ this.modifyThemes(themeMap => themeMap.delete(themeId));
80
+ }
81
+ clearThemes() {
82
+ this.modifyThemes(themeMap => themeMap.clear());
83
+ }
84
+ /***************************************************************************
85
+ * *
86
+ * Private methods *
87
+ * *
88
+ **************************************************************************/
89
+ findTheme(themeId) {
90
+ const themes = this._themes$.getValue();
91
+ return themes.get(themeId);
92
+ }
93
+ modifyThemes(themesFn) {
94
+ const themes = new Map(this._themes$.getValue());
95
+ themesFn(themes);
96
+ this.cleanUpDefaultTheme(themes);
97
+ this._themes$.next(themes);
98
+ }
99
+ cleanUpDefaultTheme(availableThemes) {
100
+ const currentDefault = this.defaultThemeSnapshot;
101
+ if (currentDefault) {
102
+ if (!availableThemes.has(currentDefault.id)) {
103
+ const available = availableThemes.values();
104
+ const newDefault = available.next().value;
105
+ if (newDefault) {
106
+ this._defaultTheme$.next(newDefault);
107
+ }
108
+ else {
109
+ this._defaultTheme$.next(null);
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+ ElderThemeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
116
+ ElderThemeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeService, providedIn: 'root' });
117
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderThemeService, decorators: [{
118
+ type: Injectable,
119
+ args: [{
120
+ providedIn: 'root'
121
+ }]
122
+ }], ctorParameters: function () { return []; } });
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-theme.service.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/theme/elder-theme.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAY,MAAM,eAAe,CAAC;AACpD,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAa,MAAM,MAAM,CAAC;AAEjD,OAAO,EAAC,MAAM,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;;AAKtD,MAAM,OAAO,iBAAiB;IAc5B;;;;gFAI4E;IAE5E;QAlBA;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAExD,kBAAa,GAAG,IAAI,eAAe,CAAY,IAAI,CAAC,CAAC;QACrD,mBAAc,GAAG,IAAI,eAAe,CAAY,IAAI,CAAC,CAAC;QACtD,aAAQ,GAAG,IAAI,eAAe,CAAyB,IAAI,GAAG,EAAE,CAAC,CAAC;QASjF,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QACvD,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;IAClD,CAAC;IAED;;;;gFAI4E;IAE5E,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IAC5C,CAAC;IAED,IAAW,oBAAoB;QAC7B,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACxC,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CACvB,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAC/C,CAAC;IACJ,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IACvC,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa;aACtB,YAAY,EAAE;aACd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;IACpC,CAAC;IAED;;;;gFAI4E;IAErE,aAAa,CAAC,OAAe;QAClC,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,GAAG,OAAO,CAAC,CAAC;YAChD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAChC;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,GAAG,OAAO,GAAG,mDAAmD,CAAC,CAAC;SAC/G;IACH,CAAC;IAEM,YAAY,CAAC,OAAe;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACjC;IACH,CAAC;IAEM,aAAa,CAAC,KAAgB,EAAE,WAAqB;QAC1D,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,CAC1C,CAAC;QACF,IAAI,WAAW,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,EAAE;YAClD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACjC;IACH,CAAC;IAEM,eAAe,CAAC,OAAe;QACpC,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CACrC,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,CAC7B,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAEpE,SAAS,CAAC,OAAe;QAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACxC,OAAO,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAEO,YAAY,CAClB,QAAoD;QAEpD,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;QACjD,QAAQ,CAAC,MAAM,CAAC,CAAC;QACjB,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAEO,mBAAmB,CACzB,eAAuC;QAEvC,MAAM,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC;QACjD,IAAI,cAAc,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE;gBAC3C,MAAM,SAAS,GAAG,eAAe,CAAC,MAAM,EAAE,CAAC;gBAC3C,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC,KAAkB,CAAC;gBACvD,IAAI,UAAU,EAAE;oBACd,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACtC;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBAChC;aACF;SACF;IACH,CAAC;;8GA1IU,iBAAiB;kHAAjB,iBAAiB,cAFhB,MAAM;2FAEP,iBAAiB;kBAH7B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import {Injectable, Renderer2} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {ThemeSpec} from './theme-spec';\nimport {filter, map} from 'rxjs/operators';\nimport {KnownElderThemes} from './known-elder-themes';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderThemeService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _activeTheme$ = new BehaviorSubject<ThemeSpec>(null);\n  private readonly _defaultTheme$ = new BehaviorSubject<ThemeSpec>(null);\n  private readonly _themes$ = new BehaviorSubject<Map<string, ThemeSpec>>(new Map());\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    this.registerTheme(KnownElderThemes.ELDER_LIGHT, true);\n    this.registerTheme(KnownElderThemes.ELDER_DARK);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get defaultTheme$(): Observable<ThemeSpec> {\n    return this._defaultTheme$.asObservable();\n  }\n\n  public get defaultThemeSnapshot(): ThemeSpec {\n    return this._defaultTheme$.getValue();\n  }\n\n  public get themes$(): Observable<ThemeSpec[]> {\n    return this._themes$.pipe(\n      map(themeMap => Array.from(themeMap.values()))\n    );\n  }\n\n  public get themesSnapshot(): ThemeSpec[] {\n    return Array.from(this._themes$.getValue().values());\n  }\n\n  public get activeThemeSnapshot(): ThemeSpec {\n    return this._activeTheme$.getValue();\n  }\n\n  public get activeTheme$(): Observable<ThemeSpec> {\n    return this._activeTheme$\n      .asObservable()\n      .pipe(filter(theme => !!theme));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public activateTheme(themeId: string): void {\n    const theme = this.findTheme(themeId);\n    if (theme) {\n      this.logger.info('Activating theme ' + themeId);\n      this._activeTheme$.next(theme);\n    } else {\n      this.logger.warn('Failed to activate theme ' + themeId + ' -> could not find registered theme with this id!');\n    }\n  }\n\n  public defaultTheme(themeId: string) {\n    const theme = this.findTheme(themeId);\n    if (theme) {\n      this._defaultTheme$.next(theme);\n    }\n  }\n\n  public registerTheme(theme: ThemeSpec, markDefault?: boolean): void {\n    this.modifyThemes(\n      themeMap => themeMap.set(theme.id, theme)\n    );\n    if (markDefault || !this._defaultTheme$.getValue()) {\n      this._defaultTheme$.next(theme);\n    }\n  }\n\n  public unregisterTheme(themeId: string) {\n    this.modifyThemes(\n      themeMap => themeMap.delete(themeId)\n    );\n  }\n\n  public clearThemes() {\n    this.modifyThemes(\n      themeMap => themeMap.clear()\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private findTheme(themeId: string): ThemeSpec | null {\n    const themes = this._themes$.getValue();\n    return themes.get(themeId);\n  }\n\n  private modifyThemes(\n    themesFn: (themeMap: Map<string, ThemeSpec>) => void\n  ) {\n    const themes = new Map(this._themes$.getValue());\n    themesFn(themes);\n    this.cleanUpDefaultTheme(themes);\n    this._themes$.next(themes);\n  }\n\n  private cleanUpDefaultTheme(\n    availableThemes: Map<string, ThemeSpec>\n  ): void {\n    const currentDefault = this.defaultThemeSnapshot;\n    if (currentDefault) {\n      if (!availableThemes.has(currentDefault.id)) {\n        const available = availableThemes.values();\n        const newDefault = available.next().value as ThemeSpec;\n        if (newDefault) {\n          this._defaultTheme$.next(newDefault);\n        } else {\n          this._defaultTheme$.next(null);\n        }\n      }\n    }\n  }\n\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import { ThemeSpec } from './theme-spec';
2
+ export class KnownElderThemes {
3
+ }
4
+ KnownElderThemes.ELDER_LIGHT = new ThemeSpec('elder-light', 'Elder Light', 'elder-light-theme', false);
5
+ KnownElderThemes.ELDER_DARK = new ThemeSpec('elder-dark', 'Elder Dark', 'elder-dark-theme', true);
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia25vd24tZWxkZXItdGhlbWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy90aGVtZS9rbm93bi1lbGRlci10aGVtZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGNBQWMsQ0FBQztBQUV2QyxNQUFNLE9BQU8sZ0JBQWdCOztBQUNiLDRCQUFXLEdBQUcsSUFBSSxTQUFTLENBQ3ZDLGFBQWEsRUFDYixhQUFhLEVBQ2IsbUJBQW1CLEVBQ25CLEtBQUssQ0FDTixDQUFDO0FBRVksMkJBQVUsR0FBRyxJQUFJLFNBQVMsQ0FDdEMsWUFBWSxFQUNaLFlBQVksRUFDWixrQkFBa0IsRUFDbEIsSUFBSSxDQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1RoZW1lU3BlY30gZnJvbSAnLi90aGVtZS1zcGVjJztcblxuZXhwb3J0IGNsYXNzIEtub3duRWxkZXJUaGVtZXMge1xuICBwdWJsaWMgc3RhdGljIEVMREVSX0xJR0hUID0gbmV3IFRoZW1lU3BlYyhcbiAgICAnZWxkZXItbGlnaHQnLFxuICAgICdFbGRlciBMaWdodCcsXG4gICAgJ2VsZGVyLWxpZ2h0LXRoZW1lJyxcbiAgICBmYWxzZVxuICApO1xuXG4gIHB1YmxpYyBzdGF0aWMgRUxERVJfREFSSyA9IG5ldyBUaGVtZVNwZWMoXG4gICAgJ2VsZGVyLWRhcmsnLFxuICAgICdFbGRlciBEYXJrJyxcbiAgICAnZWxkZXItZGFyay10aGVtZScsXG4gICAgdHJ1ZVxuICApO1xufVxuIl19
@@ -0,0 +1,2 @@
1
+ export * from './elder-theme.module';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvdGhlbWUvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lbGRlci10aGVtZS5tb2R1bGUnO1xuIl19
@@ -0,0 +1,15 @@
1
+ export class ThemeSpec {
2
+ constructor(id, name, cssClass, dark, heroBackground = null, heroIconColor = null) {
3
+ this.id = id;
4
+ this.name = name;
5
+ this.cssClass = cssClass;
6
+ this.dark = dark;
7
+ this.heroBackground = (heroBackground != null)
8
+ ? heroBackground
9
+ : dark ? undefined : 'primary';
10
+ this.heroIconColor = (heroIconColor != null)
11
+ ? heroIconColor
12
+ : dark ? 'primary' : undefined;
13
+ }
14
+ }
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtc3BlYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvdGhlbWUvdGhlbWUtc3BlYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sU0FBUztJQWNwQixZQUNrQixFQUFVLEVBQ1YsSUFBWSxFQUNaLFFBQWdCLEVBQ2hCLElBQWEsRUFDN0IsaUJBQStCLElBQUksRUFDbkMsZ0JBQThCLElBQUk7UUFMbEIsT0FBRSxHQUFGLEVBQUUsQ0FBUTtRQUNWLFNBQUksR0FBSixJQUFJLENBQVE7UUFDWixhQUFRLEdBQVIsUUFBUSxDQUFRO1FBQ2hCLFNBQUksR0FBSixJQUFJLENBQVM7UUFJN0IsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUM7WUFDNUMsQ0FBQyxDQUFDLGNBQWM7WUFDaEIsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7UUFDakMsSUFBSSxDQUFDLGFBQWEsR0FBRyxDQUFDLGFBQWEsSUFBSSxJQUFJLENBQUM7WUFDMUMsQ0FBQyxDQUFDLGFBQWE7WUFDZixDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNuQyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1RoZW1lUGFsZXR0ZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBUaGVtZVNwZWMge1xuXG4gIC8qKlxuICAgKiBIZXJvIEJhY2tncm91bmQgaXMgYSBiYWNrZ3JvdW5kIGNvbG9yIHdoaWNoIHNob3VsZFxuICAgKiBoaWdobGlnaHQgdGhlIGFwcCB0aGVtZS4gVXN1YWxseSBpdHMgdGhlIHByaW1hcnkgcGFsZXR0ZS5cbiAgICovXG4gIHB1YmxpYyByZWFkb25seSBoZXJvQmFja2dyb3VuZDogVGhlbWVQYWxldHRlO1xuXG4gIC8qKlxuICAgKiBIZXJvIEljb24gaXMgdGhlIGNvbG9yIG9mIGljb25zIHdoaWNoIGFyZSBkaXNwbGF5ZWQgb25cbiAgICogdG9wIG9mIGhlcm8gYmFja2dyb3VuZHMuIEl0IHNob3VsZCBsb29rIHdlbGwgb24gaXQuXG4gICAqL1xuICBwdWJsaWMgcmVhZG9ubHkgaGVyb0ljb25Db2xvcjogVGhlbWVQYWxldHRlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBpZDogc3RyaW5nLFxuICAgIHB1YmxpYyByZWFkb25seSBuYW1lOiBzdHJpbmcsXG4gICAgcHVibGljIHJlYWRvbmx5IGNzc0NsYXNzOiBzdHJpbmcsXG4gICAgcHVibGljIHJlYWRvbmx5IGRhcms6IGJvb2xlYW4sXG4gICAgaGVyb0JhY2tncm91bmQ6IFRoZW1lUGFsZXR0ZSA9IG51bGwsXG4gICAgaGVyb0ljb25Db2xvcjogVGhlbWVQYWxldHRlID0gbnVsbFxuICApIHtcbiAgICB0aGlzLmhlcm9CYWNrZ3JvdW5kID0gKGhlcm9CYWNrZ3JvdW5kICE9IG51bGwpXG4gICAgICA/IGhlcm9CYWNrZ3JvdW5kXG4gICAgICA6IGRhcmsgPyB1bmRlZmluZWQgOiAncHJpbWFyeSc7XG4gICAgdGhpcy5oZXJvSWNvbkNvbG9yID0gKGhlcm9JY29uQ29sb3IgIT0gbnVsbClcbiAgICAgID8gaGVyb0ljb25Db2xvclxuICAgICAgOiBkYXJrID8gJ3ByaW1hcnknIDogdW5kZWZpbmVkO1xuICB9XG59XG4iXX0=