@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.
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +29 -11
- package/esm2020/lib/components/public_api.mjs +2 -1
- package/esm2020/lib/components/shell/elder-shell.module.mjs +5 -4
- package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +51 -14
- package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +47 -22
- package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +62 -0
- package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +62 -0
- package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +72 -0
- package/esm2020/lib/components/theme/elder-theme.directive.mjs +61 -0
- package/esm2020/lib/components/theme/elder-theme.module.mjs +74 -0
- package/esm2020/lib/components/theme/elder-theme.service.mjs +123 -0
- package/esm2020/lib/components/theme/known-elder-themes.mjs +6 -0
- package/esm2020/lib/components/theme/public_api.mjs +2 -0
- package/esm2020/lib/components/theme/theme-spec.mjs +15 -0
- package/fesm2015/elderbyte-ngx-starter.mjs +619 -119
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +616 -119
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.d.ts +10 -5
- package/lib/components/public_api.d.ts +1 -0
- package/lib/components/shell/elder-shell.module.d.ts +2 -1
- package/lib/components/shell/header/elder-app-header/elder-app-header.component.d.ts +33 -6
- package/lib/components/shell/shell/elder-shell.component.d.ts +16 -6
- package/lib/components/theme/elder-theme-applier.directive.d.ts +36 -0
- package/lib/components/theme/elder-theme-preference.service.d.ts +33 -0
- package/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.d.ts +37 -0
- package/lib/components/theme/elder-theme.directive.d.ts +38 -0
- package/lib/components/theme/elder-theme.module.d.ts +22 -0
- package/lib/components/theme/elder-theme.service.d.ts +51 -0
- package/lib/components/theme/known-elder-themes.d.ts +5 -0
- package/lib/components/theme/public_api.d.ts +1 -0
- package/lib/components/theme/theme-spec.d.ts +18 -0
- package/package.json +1 -1
- package/src/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.scss +0 -0
- 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":"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","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=
|