valtech-components 2.0.66 → 2.0.68
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/esm2022/lib/components/atoms/divider/divider.component.mjs +2 -1
- package/esm2022/lib/components/molecules/searchbar/searchbar.component.mjs +3 -3
- package/esm2022/lib/components/templates/simple/simple.component.mjs +6 -4
- package/esm2022/lib/services/theme.service.mjs +4 -1
- package/fesm2022/valtech-components.mjs +120 -115
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/molecules/searchbar/searchbar.component.d.ts +1 -1
- package/lib/components/templates/simple/simple.component.d.ts +2 -0
- package/lib/services/theme.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -2,6 +2,7 @@ import { CommonModule } from '@angular/common';
|
|
|
2
2
|
import { Component, Input } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
|
+
//TODO: fix the class name colission between medium size and medium color
|
|
5
6
|
export class DividerComponent {
|
|
6
7
|
constructor() { }
|
|
7
8
|
ngOnInit() { }
|
|
@@ -14,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
14
15
|
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
15
16
|
type: Input
|
|
16
17
|
}] } });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7QUFHekQseUVBQXlFO0FBUXpFLE1BQU0sT0FBTyxnQkFBZ0I7SUFHM0IsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQzsrR0FMRixnQkFBZ0I7bUdBQWhCLGdCQUFnQixtR0FIakIsNEVBQTRFLHM1QkFENUUsWUFBWTs7NEZBSVgsZ0JBQWdCO2tCQVA1QixTQUFTOytCQUNFLGFBQWEsY0FDWCxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYiw0RUFBNEU7d0RBS3RGLEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpdmlkZXJNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG4vL1RPRE86IGZpeCB0aGUgY2xhc3MgbmFtZSBjb2xpc3Npb24gYmV0d2VlbiBtZWRpdW0gc2l6ZSBhbmQgbWVkaXVtIGNvbG9yXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtZGl2aWRlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYCA8ZGl2IFtuZ0NsYXNzXT1cIlsnZGl2aWRlcicsIHByb3BzLnNpemUsIHByb3BzLmNvbG9yLCBwcm9wcy5maWxsXVwiPjwvZGl2PiBgLFxuICBzdHlsZVVybHM6IFsnLi9kaXZpZGVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERpdmlkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwcm9wczogRGl2aWRlck1ldGFkYXRhO1xuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxufVxuIl19
|
|
@@ -18,7 +18,7 @@ export class SearchbarComponent {
|
|
|
18
18
|
this.blurEvent.emit();
|
|
19
19
|
}
|
|
20
20
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SearchbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
21
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SearchbarComponent, isStandalone: true, selector: "
|
|
21
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SearchbarComponent, isStandalone: true, selector: "val-searchbar", inputs: { disabled: "disabled" }, outputs: { focusEvent: "focusEvent", blurEvent: "blurEvent", filterEvent: "filterEvent" }, ngImport: i0, template: `
|
|
22
22
|
<ion-searchbar
|
|
23
23
|
mode="ios"
|
|
24
24
|
debounce="500"
|
|
@@ -35,7 +35,7 @@ export class SearchbarComponent {
|
|
|
35
35
|
}
|
|
36
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SearchbarComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
38
|
-
args: [{ selector: '
|
|
38
|
+
args: [{ selector: 'val-searchbar', standalone: true, imports: [IonSearchbar], template: `
|
|
39
39
|
<ion-searchbar
|
|
40
40
|
mode="ios"
|
|
41
41
|
debounce="500"
|
|
@@ -58,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
58
58
|
}], filterEvent: [{
|
|
59
59
|
type: Output
|
|
60
60
|
}] } });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3NlYXJjaGJhci9zZWFyY2hiYXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQXNCekQsTUFBTSxPQUFPLGtCQUFrQjtJQVM3QjtRQU5VLGVBQVUsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRXRDLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRXJDLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUVwQyxDQUFDO0lBRWhCLFFBQVEsQ0FBQyxNQUFXO1FBQ2xCLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDeEIsQ0FBQzsrR0F0QlUsa0JBQWtCO21HQUFsQixrQkFBa0Isc01BaEJuQjs7Ozs7Ozs7Ozs7OztHQWFULGlPQWRTLFlBQVk7OzRGQWlCWCxrQkFBa0I7a0JBcEI5QixTQUFTOytCQUNFLGVBQWUsY0FDYixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7Ozs7Ozs7Ozs7OztHQWFUO3dEQUlRLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksVUFBVTtzQkFBbkIsTUFBTTtnQkFFRyxTQUFTO3NCQUFsQixNQUFNO2dCQUVHLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uU2VhcmNoYmFyIH0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1zZWFyY2hiYXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbSW9uU2VhcmNoYmFyXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8aW9uLXNlYXJjaGJhclxuICAgICAgbW9kZT1cImlvc1wiXG4gICAgICBkZWJvdW5jZT1cIjUwMFwiXG4gICAgICBwbGFjZWhvbGRlcj1cIkLDunNxdWVkYVwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgICAgc2hvd0NhbmNlbEJ1dHRvbj1cImZvY3VzXCJcbiAgICAgIGNhbmNlbEJ1dHRvblRleHQ9XCJDYW5jZWxhclwiXG4gICAgICAoaW9uSW5wdXQpPVwib25TZWFyY2goJGV2ZW50KVwiXG4gICAgICAoaW9uQmx1cik9XCJvbkJsdXIoKVwiXG4gICAgICAoaW9uRm9jdXMpPVwib25Gb2N1cygpXCJcbiAgICA+XG4gICAgPC9pb24tc2VhcmNoYmFyPlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9zZWFyY2hiYXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgU2VhcmNoYmFyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW47XG5cbiAgQE91dHB1dCgpIGZvY3VzRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgQE91dHB1dCgpIGJsdXJFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICBAT3V0cHV0KCkgZmlsdGVyRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgb25TZWFyY2goJGV2ZW50OiBhbnkpIHtcbiAgICBjb25zdCBzZWFyY2hUZXJtID0gJGV2ZW50LmRldGFpbC52YWx1ZTtcbiAgICB0aGlzLmZpbHRlckV2ZW50LmVtaXQoc2VhcmNoVGVybSk7XG4gIH1cblxuICBvbkZvY3VzKCkge1xuICAgIHRoaXMuZm9jdXNFdmVudC5lbWl0KCk7XG4gIH1cblxuICBvbkJsdXIoKSB7XG4gICAgdGhpcy5ibHVyRXZlbnQuZW1pdCgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { NgStyle } from '@angular/common';
|
|
2
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, inject, Input, Output } from '@angular/core';
|
|
3
3
|
import { IonContent, IonHeader, IonTitle, IonToolbar } from '@ionic/angular/standalone';
|
|
4
|
+
import { ThemeService } from '../../../services/theme.service';
|
|
4
5
|
import { DividerComponent } from '../../atoms/divider/divider.component';
|
|
5
6
|
import { ExpandableTextComponent } from '../../molecules/expandable-text/expandable-text.component';
|
|
6
7
|
import { LinkComponent } from '../../molecules/link/link.component';
|
|
@@ -10,6 +11,7 @@ import * as i0 from "@angular/core";
|
|
|
10
11
|
export class SimpleComponent {
|
|
11
12
|
constructor() {
|
|
12
13
|
this.onClick = new EventEmitter();
|
|
14
|
+
this.theme = inject(ThemeService);
|
|
13
15
|
}
|
|
14
16
|
onClickHandler(token) {
|
|
15
17
|
this.onClick.emit(token);
|
|
@@ -21,7 +23,7 @@ export class SimpleComponent {
|
|
|
21
23
|
<ion-content
|
|
22
24
|
[fullscreen]="true"
|
|
23
25
|
[ngStyle]="{
|
|
24
|
-
'--background': props.background,
|
|
26
|
+
'--background': theme.IsDark ? 'var(--ion-background-color)' : props.background,
|
|
25
27
|
}"
|
|
26
28
|
>
|
|
27
29
|
<ion-header collapse="condense">
|
|
@@ -72,7 +74,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
72
74
|
<ion-content
|
|
73
75
|
[fullscreen]="true"
|
|
74
76
|
[ngStyle]="{
|
|
75
|
-
'--background': props.background,
|
|
77
|
+
'--background': theme.IsDark ? 'var(--ion-background-color)' : props.background,
|
|
76
78
|
}"
|
|
77
79
|
>
|
|
78
80
|
<ion-header collapse="condense">
|
|
@@ -108,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
108
110
|
}], onClick: [{
|
|
109
111
|
type: Output
|
|
110
112
|
}] } });
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdGVtcGxhdGVzL3NpbXBsZS9zaW1wbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDeEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQTZEN0QsTUFBTSxPQUFPLGVBQWU7SUExRDVCO1FBK0RFLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRXJDLFVBQUssR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7S0FLOUI7SUFIQyxjQUFjLENBQUMsS0FBYztRQUMzQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDOytHQVhVLGVBQWU7bUdBQWYsZUFBZSxtSUEzQ2hCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQ1Qsa0hBL0NDLE9BQU8sMkVBQ1AsU0FBUyxvR0FDVCxVQUFVLG1GQUNWLFFBQVEsaUZBQ1IsVUFBVSxrSkFDVixlQUFlLGdHQUNmLGVBQWUsdURBQ2YsZ0JBQWdCLDJFQUNoQixhQUFhLDhGQUNiLHVCQUF1Qjs7NEZBNkNkLGVBQWU7a0JBMUQzQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1A7d0JBQ1AsT0FBTzt3QkFDUCxTQUFTO3dCQUNULFVBQVU7d0JBQ1YsUUFBUTt3QkFDUixVQUFVO3dCQUNWLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2IsdUJBQXVCO3FCQUN4QixZQUNTOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQ1Q7OEJBU0QsS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nU3R5bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGluamVjdCwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uQ29udGVudCwgSW9uSGVhZGVyLCBJb25UaXRsZSwgSW9uVG9vbGJhciB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvdGhlbWUuc2VydmljZSc7XG5pbXBvcnQgeyBEaXZpZGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvZGl2aWRlci9kaXZpZGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFeHBhbmRhYmxlVGV4dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9leHBhbmRhYmxlLXRleHQvZXhwYW5kYWJsZS10ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBMaW5rQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbW9sZWN1bGVzL2xpbmsvbGluay5jb21wb25lbnQnO1xuaW1wb3J0IHsgSGVhZGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vb3JnYW5pc21zL2hlYWRlci9oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IExheW91dENvbXBvbmVudCB9IGZyb20gJy4uL2xheW91dC9sYXlvdXQuY29tcG9uZW50JztcbmltcG9ydCB7IFNpbXBsZU1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1zaW1wbGUnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTmdTdHlsZSxcbiAgICBJb25IZWFkZXIsXG4gICAgSW9uVG9vbGJhcixcbiAgICBJb25UaXRsZSxcbiAgICBJb25Db250ZW50LFxuICAgIEhlYWRlckNvbXBvbmVudCxcbiAgICBMYXlvdXRDb21wb25lbnQsXG4gICAgRGl2aWRlckNvbXBvbmVudCxcbiAgICBMaW5rQ29tcG9uZW50LFxuICAgIEV4cGFuZGFibGVUZXh0Q29tcG9uZW50LFxuICBdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDx2YWwtaGVhZGVyIFtwcm9wc109XCJwcm9wcy5oZWFkZXJcIiAvPlxuXG4gICAgPGlvbi1jb250ZW50XG4gICAgICBbZnVsbHNjcmVlbl09XCJ0cnVlXCJcbiAgICAgIFtuZ1N0eWxlXT1cIntcbiAgICAgICAgJy0tYmFja2dyb3VuZCc6IHRoZW1lLklzRGFyayA/ICd2YXIoLS1pb24tYmFja2dyb3VuZC1jb2xvciknIDogcHJvcHMuYmFja2dyb3VuZCxcbiAgICAgIH1cIlxuICAgID5cbiAgICAgIDxpb24taGVhZGVyIGNvbGxhcHNlPVwiY29uZGVuc2VcIj5cbiAgICAgICAgPGlvbi10b29sYmFyIHN0eWxlPVwiLS1iYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcIj5cbiAgICAgICAgICA8aW9uLXRpdGxlIHN0eWxlPVwicGFkZGluZzogMDtcIiBzaXplPVwibGFyZ2VcIj57eyBwcm9wcy5wYWdlVGl0bGUgfX08L2lvbi10aXRsZT5cbiAgICAgICAgPC9pb24tdG9vbGJhcj5cbiAgICAgIDwvaW9uLWhlYWRlcj5cbiAgICAgIEBpZiAocHJvcHMucGFnZURlc2NyaXB0aW9uKSB7XG4gICAgICAgIDxkaXYgY2xhc3M9XCJkZXNjcmlwdGlvbi1jb250YWluZXJcIj5cbiAgICAgICAgICA8dmFsLWV4cGFuZGFibGUtdGV4dFxuICAgICAgICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgICAgICAgbGltaXQ6IDE4MCxcbiAgICAgICAgICAgICAgY29udGVudDogcHJvcHMucGFnZURlc2NyaXB0aW9uLFxuICAgICAgICAgICAgICBjb2xvcjogJ3ByaW1hcnknLFxuICAgICAgICAgICAgICBleHBhbmRUZXh0OiAnbcOhcycsXG4gICAgICAgICAgICB9XCJcbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIH1cbiAgICAgIEBpZiAocHJvcHMubGluaykge1xuICAgICAgICA8dmFsLWxpbmsgW3Byb3BzXT1cInByb3BzLmxpbmtcIiAob25DbGljayk9XCJvbkNsaWNrSGFuZGxlcigkZXZlbnQpXCI+PC92YWwtbGluaz5cbiAgICAgIH1cbiAgICAgIEBpZiAocHJvcHMud2l0aERpdmlkZXIpIHtcbiAgICAgICAgPHZhbC1kaXZpZGVyIFtwcm9wc109XCJ7IGZpbGw6ICdzb2xpZCcsIHNpemU6ICdtZWRpdW0nLCBjb2xvcjogJ2RhcmsnIH1cIiAvPlxuICAgICAgfVxuICAgICAgPHZhbC1sYXlvdXQ+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgIDwvdmFsLWxheW91dD5cbiAgICA8L2lvbi1jb250ZW50PlxuICBgLFxuICBzdHlsZXM6IGBcbiAgICAuZGVzY3JpcHRpb24tY29udGFpbmVyIHtcbiAgICAgIHBhZGRpbmc6IDBweCAxNnB4O1xuICAgIH1cbiAgYCxcbn0pXG5leHBvcnQgY2xhc3MgU2ltcGxlQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFNpbXBsZU1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgdGhlbWUgPSBpbmplY3QoVGhlbWVTZXJ2aWNlKTtcblxuICBvbkNsaWNrSGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25DbGljay5lbWl0KHRva2VuKTtcbiAgfVxufVxuIl19
|
|
@@ -51,6 +51,9 @@ export class ThemeService {
|
|
|
51
51
|
this.toggleTheme(ThemeOption.LIGHT, true);
|
|
52
52
|
this.toggleTheme(ThemeOption.DARK, false);
|
|
53
53
|
}
|
|
54
|
+
get IsDark() {
|
|
55
|
+
return this.prefersDark;
|
|
56
|
+
}
|
|
54
57
|
get Theme() {
|
|
55
58
|
return this.theme.value;
|
|
56
59
|
}
|
|
@@ -94,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
94
97
|
providedIn: 'root',
|
|
95
98
|
}]
|
|
96
99
|
}], ctorParameters: () => [] });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/services/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { LocalStorageService } from './local-storage.service';\nimport { THEME } from '../shared/constants/storage';\n\nexport enum ThemeOption {\n  LIGHT = 'light',\n  DARK = 'dark',\n  AUTO = 'auto',\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ThemeService {\n  lightToggle = false;\n  darkToggle = false;\n  autoToggle = false;\n  currentOption = ThemeOption.AUTO;\n  themeOptions = ThemeOption;\n  prefersDark = false;\n  default = ThemeOption.AUTO;\n  theme: BehaviorSubject<ThemeOption>;\n\n  constructor() {\n    const current = LocalStorageService.get<ThemeOption>(THEME);\n    console.log('💡 ThemeConfig current::: ', current);\n    this.theme = new BehaviorSubject<ThemeOption>(current || this.default);\n    this.currentOption = this.Theme;\n    console.log('💡 ThemeConfig this.currentOption::: ', this.currentOption);\n    this.toggleUserPreference(this.currentOption);\n\n    const prefersDarkQuery = window.matchMedia('(prefers-color-scheme: dark)');\n    this.prefersDark = prefersDarkQuery.matches;\n    this.handleAutoConfiguration();\n\n    prefersDarkQuery.addEventListener('change', mediaQuery => {\n      console.log('💡 ThemeConfig addEventListener change::: ', mediaQuery);\n      this.prefersDark = mediaQuery.matches;\n      this.handleAutoConfiguration();\n    });\n  }\n\n  private handleAutoConfiguration() {\n    if (this.prefersDark && this.currentOption === ThemeOption.AUTO) {\n      console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);\n      this.toggleUserPreference(ThemeOption.AUTO);\n    }\n    if (!this.prefersDark && this.currentOption === ThemeOption.AUTO) {\n      console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);\n      this.toggleUserPreference(ThemeOption.AUTO);\n    }\n  }\n\n  private handleDarkPreference() {\n    this.toggleTheme(ThemeOption.DARK, true);\n    this.toggleTheme(ThemeOption.LIGHT, false);\n  }\n\n  private handleLightPreference() {\n    this.toggleTheme(ThemeOption.LIGHT, true);\n    this.toggleTheme(ThemeOption.DARK, false);\n  }\n\n  get IsDark(): boolean {\n    return this.prefersDark;\n  }\n\n  get Theme(): ThemeOption {\n    return this.theme.value;\n  }\n\n  set Theme(theme: ThemeOption) {\n    this.theme.next(theme);\n    LocalStorageService.set<ThemeOption>(THEME, theme);\n  }\n\n  toggleTheme(name: string, shouldAdd: boolean) {\n    console.log('toggleTheme::: ', name, shouldAdd);\n    document.body.classList.toggle(name, shouldAdd);\n  }\n\n  toggleUserPreference(option: ThemeOption) {\n    this.currentOption = option;\n    this.Theme = option;\n    this.lightToggle = option === ThemeOption.LIGHT;\n    this.darkToggle = option === ThemeOption.DARK;\n    this.autoToggle = option === ThemeOption.AUTO;\n\n    switch (option) {\n      case ThemeOption.LIGHT:\n        this.handleLightPreference();\n        break;\n      case ThemeOption.DARK:\n        this.handleDarkPreference();\n        break;\n      case ThemeOption.AUTO:\n        if (this.prefersDark) {\n          this.handleDarkPreference();\n        } else {\n          this.handleLightPreference();\n        }\n        break;\n    }\n  }\n}\n"]}
|
|
@@ -517,6 +517,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
517
517
|
type: Input
|
|
518
518
|
}] } });
|
|
519
519
|
|
|
520
|
+
//TODO: fix the class name colission between medium size and medium color
|
|
520
521
|
class DividerComponent {
|
|
521
522
|
constructor() { }
|
|
522
523
|
ngOnInit() { }
|
|
@@ -1947,7 +1948,7 @@ class SearchbarComponent {
|
|
|
1947
1948
|
this.blurEvent.emit();
|
|
1948
1949
|
}
|
|
1949
1950
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SearchbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1950
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SearchbarComponent, isStandalone: true, selector: "
|
|
1951
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SearchbarComponent, isStandalone: true, selector: "val-searchbar", inputs: { disabled: "disabled" }, outputs: { focusEvent: "focusEvent", blurEvent: "blurEvent", filterEvent: "filterEvent" }, ngImport: i0, template: `
|
|
1951
1952
|
<ion-searchbar
|
|
1952
1953
|
mode="ios"
|
|
1953
1954
|
debounce="500"
|
|
@@ -1964,7 +1965,7 @@ class SearchbarComponent {
|
|
|
1964
1965
|
}
|
|
1965
1966
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SearchbarComponent, decorators: [{
|
|
1966
1967
|
type: Component,
|
|
1967
|
-
args: [{ selector: '
|
|
1968
|
+
args: [{ selector: 'val-searchbar', standalone: true, imports: [IonSearchbar], template: `
|
|
1968
1969
|
<ion-searchbar
|
|
1969
1970
|
mode="ios"
|
|
1970
1971
|
debounce="500"
|
|
@@ -3291,9 +3292,124 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
3291
3292
|
`, styles: [".layout-container{margin:0 auto;padding:0;width:100%;box-sizing:border-box;margin-bottom:1rem}@media (max-width: 768px){.layout-container{max-width:100%}}@media (min-width: 768px){.layout-container{margin:0 auto;max-width:55rem;margin-bottom:1.5rem}}@media (min-width: 1200px){.layout-container{margin:0 auto;max-width:68.75rem}}\n"] }]
|
|
3292
3293
|
}] });
|
|
3293
3294
|
|
|
3295
|
+
class LocalStorageService {
|
|
3296
|
+
static set(reference, value) {
|
|
3297
|
+
localStorage.setItem(reference, JSON.stringify(value));
|
|
3298
|
+
}
|
|
3299
|
+
static get(reference) {
|
|
3300
|
+
const value = localStorage.getItem(reference);
|
|
3301
|
+
return JSON.parse(value);
|
|
3302
|
+
}
|
|
3303
|
+
static remove(reference) {
|
|
3304
|
+
localStorage.removeItem(reference);
|
|
3305
|
+
}
|
|
3306
|
+
static clear() {
|
|
3307
|
+
localStorage.clear();
|
|
3308
|
+
}
|
|
3309
|
+
}
|
|
3310
|
+
|
|
3311
|
+
const LANG = 'LANG';
|
|
3312
|
+
const THEME = 'THEME';
|
|
3313
|
+
|
|
3314
|
+
var ThemeOption;
|
|
3315
|
+
(function (ThemeOption) {
|
|
3316
|
+
ThemeOption["LIGHT"] = "light";
|
|
3317
|
+
ThemeOption["DARK"] = "dark";
|
|
3318
|
+
ThemeOption["AUTO"] = "auto";
|
|
3319
|
+
})(ThemeOption || (ThemeOption = {}));
|
|
3320
|
+
class ThemeService {
|
|
3321
|
+
constructor() {
|
|
3322
|
+
this.lightToggle = false;
|
|
3323
|
+
this.darkToggle = false;
|
|
3324
|
+
this.autoToggle = false;
|
|
3325
|
+
this.currentOption = ThemeOption.AUTO;
|
|
3326
|
+
this.themeOptions = ThemeOption;
|
|
3327
|
+
this.prefersDark = false;
|
|
3328
|
+
this.default = ThemeOption.AUTO;
|
|
3329
|
+
const current = LocalStorageService.get(THEME);
|
|
3330
|
+
console.log('💡 ThemeConfig current::: ', current);
|
|
3331
|
+
this.theme = new BehaviorSubject(current || this.default);
|
|
3332
|
+
this.currentOption = this.Theme;
|
|
3333
|
+
console.log('💡 ThemeConfig this.currentOption::: ', this.currentOption);
|
|
3334
|
+
this.toggleUserPreference(this.currentOption);
|
|
3335
|
+
const prefersDarkQuery = window.matchMedia('(prefers-color-scheme: dark)');
|
|
3336
|
+
this.prefersDark = prefersDarkQuery.matches;
|
|
3337
|
+
this.handleAutoConfiguration();
|
|
3338
|
+
prefersDarkQuery.addEventListener('change', mediaQuery => {
|
|
3339
|
+
console.log('💡 ThemeConfig addEventListener change::: ', mediaQuery);
|
|
3340
|
+
this.prefersDark = mediaQuery.matches;
|
|
3341
|
+
this.handleAutoConfiguration();
|
|
3342
|
+
});
|
|
3343
|
+
}
|
|
3344
|
+
handleAutoConfiguration() {
|
|
3345
|
+
if (this.prefersDark && this.currentOption === ThemeOption.AUTO) {
|
|
3346
|
+
console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);
|
|
3347
|
+
this.toggleUserPreference(ThemeOption.AUTO);
|
|
3348
|
+
}
|
|
3349
|
+
if (!this.prefersDark && this.currentOption === ThemeOption.AUTO) {
|
|
3350
|
+
console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);
|
|
3351
|
+
this.toggleUserPreference(ThemeOption.AUTO);
|
|
3352
|
+
}
|
|
3353
|
+
}
|
|
3354
|
+
handleDarkPreference() {
|
|
3355
|
+
this.toggleTheme(ThemeOption.DARK, true);
|
|
3356
|
+
this.toggleTheme(ThemeOption.LIGHT, false);
|
|
3357
|
+
}
|
|
3358
|
+
handleLightPreference() {
|
|
3359
|
+
this.toggleTheme(ThemeOption.LIGHT, true);
|
|
3360
|
+
this.toggleTheme(ThemeOption.DARK, false);
|
|
3361
|
+
}
|
|
3362
|
+
get IsDark() {
|
|
3363
|
+
return this.prefersDark;
|
|
3364
|
+
}
|
|
3365
|
+
get Theme() {
|
|
3366
|
+
return this.theme.value;
|
|
3367
|
+
}
|
|
3368
|
+
set Theme(theme) {
|
|
3369
|
+
this.theme.next(theme);
|
|
3370
|
+
LocalStorageService.set(THEME, theme);
|
|
3371
|
+
}
|
|
3372
|
+
toggleTheme(name, shouldAdd) {
|
|
3373
|
+
console.log('toggleTheme::: ', name, shouldAdd);
|
|
3374
|
+
document.body.classList.toggle(name, shouldAdd);
|
|
3375
|
+
}
|
|
3376
|
+
toggleUserPreference(option) {
|
|
3377
|
+
this.currentOption = option;
|
|
3378
|
+
this.Theme = option;
|
|
3379
|
+
this.lightToggle = option === ThemeOption.LIGHT;
|
|
3380
|
+
this.darkToggle = option === ThemeOption.DARK;
|
|
3381
|
+
this.autoToggle = option === ThemeOption.AUTO;
|
|
3382
|
+
switch (option) {
|
|
3383
|
+
case ThemeOption.LIGHT:
|
|
3384
|
+
this.handleLightPreference();
|
|
3385
|
+
break;
|
|
3386
|
+
case ThemeOption.DARK:
|
|
3387
|
+
this.handleDarkPreference();
|
|
3388
|
+
break;
|
|
3389
|
+
case ThemeOption.AUTO:
|
|
3390
|
+
if (this.prefersDark) {
|
|
3391
|
+
this.handleDarkPreference();
|
|
3392
|
+
}
|
|
3393
|
+
else {
|
|
3394
|
+
this.handleLightPreference();
|
|
3395
|
+
}
|
|
3396
|
+
break;
|
|
3397
|
+
}
|
|
3398
|
+
}
|
|
3399
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
3400
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, providedIn: 'root' }); }
|
|
3401
|
+
}
|
|
3402
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, decorators: [{
|
|
3403
|
+
type: Injectable,
|
|
3404
|
+
args: [{
|
|
3405
|
+
providedIn: 'root',
|
|
3406
|
+
}]
|
|
3407
|
+
}], ctorParameters: () => [] });
|
|
3408
|
+
|
|
3294
3409
|
class SimpleComponent {
|
|
3295
3410
|
constructor() {
|
|
3296
3411
|
this.onClick = new EventEmitter();
|
|
3412
|
+
this.theme = inject(ThemeService);
|
|
3297
3413
|
}
|
|
3298
3414
|
onClickHandler(token) {
|
|
3299
3415
|
this.onClick.emit(token);
|
|
@@ -3305,7 +3421,7 @@ class SimpleComponent {
|
|
|
3305
3421
|
<ion-content
|
|
3306
3422
|
[fullscreen]="true"
|
|
3307
3423
|
[ngStyle]="{
|
|
3308
|
-
'--background': props.background,
|
|
3424
|
+
'--background': theme.IsDark ? 'var(--ion-background-color)' : props.background,
|
|
3309
3425
|
}"
|
|
3310
3426
|
>
|
|
3311
3427
|
<ion-header collapse="condense">
|
|
@@ -3356,7 +3472,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
3356
3472
|
<ion-content
|
|
3357
3473
|
[fullscreen]="true"
|
|
3358
3474
|
[ngStyle]="{
|
|
3359
|
-
'--background': props.background,
|
|
3475
|
+
'--background': theme.IsDark ? 'var(--ion-background-color)' : props.background,
|
|
3360
3476
|
}"
|
|
3361
3477
|
>
|
|
3362
3478
|
<ion-header collapse="condense">
|
|
@@ -3407,25 +3523,6 @@ var LangOption;
|
|
|
3407
3523
|
LangOption["EN"] = "en";
|
|
3408
3524
|
})(LangOption || (LangOption = {}));
|
|
3409
3525
|
|
|
3410
|
-
class LocalStorageService {
|
|
3411
|
-
static set(reference, value) {
|
|
3412
|
-
localStorage.setItem(reference, JSON.stringify(value));
|
|
3413
|
-
}
|
|
3414
|
-
static get(reference) {
|
|
3415
|
-
const value = localStorage.getItem(reference);
|
|
3416
|
-
return JSON.parse(value);
|
|
3417
|
-
}
|
|
3418
|
-
static remove(reference) {
|
|
3419
|
-
localStorage.removeItem(reference);
|
|
3420
|
-
}
|
|
3421
|
-
static clear() {
|
|
3422
|
-
localStorage.clear();
|
|
3423
|
-
}
|
|
3424
|
-
}
|
|
3425
|
-
|
|
3426
|
-
const LANG = 'LANG';
|
|
3427
|
-
const THEME = 'THEME';
|
|
3428
|
-
|
|
3429
3526
|
const ValtechConfigService = new InjectionToken('ValtechConfig');
|
|
3430
3527
|
|
|
3431
3528
|
class LangService {
|
|
@@ -3460,98 +3557,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
3460
3557
|
args: [ValtechConfigService]
|
|
3461
3558
|
}] }] });
|
|
3462
3559
|
|
|
3463
|
-
var ThemeOption;
|
|
3464
|
-
(function (ThemeOption) {
|
|
3465
|
-
ThemeOption["LIGHT"] = "light";
|
|
3466
|
-
ThemeOption["DARK"] = "dark";
|
|
3467
|
-
ThemeOption["AUTO"] = "auto";
|
|
3468
|
-
})(ThemeOption || (ThemeOption = {}));
|
|
3469
|
-
class ThemeService {
|
|
3470
|
-
constructor() {
|
|
3471
|
-
this.lightToggle = false;
|
|
3472
|
-
this.darkToggle = false;
|
|
3473
|
-
this.autoToggle = false;
|
|
3474
|
-
this.currentOption = ThemeOption.AUTO;
|
|
3475
|
-
this.themeOptions = ThemeOption;
|
|
3476
|
-
this.prefersDark = false;
|
|
3477
|
-
this.default = ThemeOption.AUTO;
|
|
3478
|
-
const current = LocalStorageService.get(THEME);
|
|
3479
|
-
console.log('💡 ThemeConfig current::: ', current);
|
|
3480
|
-
this.theme = new BehaviorSubject(current || this.default);
|
|
3481
|
-
this.currentOption = this.Theme;
|
|
3482
|
-
console.log('💡 ThemeConfig this.currentOption::: ', this.currentOption);
|
|
3483
|
-
this.toggleUserPreference(this.currentOption);
|
|
3484
|
-
const prefersDarkQuery = window.matchMedia('(prefers-color-scheme: dark)');
|
|
3485
|
-
this.prefersDark = prefersDarkQuery.matches;
|
|
3486
|
-
this.handleAutoConfiguration();
|
|
3487
|
-
prefersDarkQuery.addEventListener('change', mediaQuery => {
|
|
3488
|
-
console.log('💡 ThemeConfig addEventListener change::: ', mediaQuery);
|
|
3489
|
-
this.prefersDark = mediaQuery.matches;
|
|
3490
|
-
this.handleAutoConfiguration();
|
|
3491
|
-
});
|
|
3492
|
-
}
|
|
3493
|
-
handleAutoConfiguration() {
|
|
3494
|
-
if (this.prefersDark && this.currentOption === ThemeOption.AUTO) {
|
|
3495
|
-
console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);
|
|
3496
|
-
this.toggleUserPreference(ThemeOption.AUTO);
|
|
3497
|
-
}
|
|
3498
|
-
if (!this.prefersDark && this.currentOption === ThemeOption.AUTO) {
|
|
3499
|
-
console.log('💡 ThemeConfig prefersDark::: ', this.prefersDark);
|
|
3500
|
-
this.toggleUserPreference(ThemeOption.AUTO);
|
|
3501
|
-
}
|
|
3502
|
-
}
|
|
3503
|
-
handleDarkPreference() {
|
|
3504
|
-
this.toggleTheme(ThemeOption.DARK, true);
|
|
3505
|
-
this.toggleTheme(ThemeOption.LIGHT, false);
|
|
3506
|
-
}
|
|
3507
|
-
handleLightPreference() {
|
|
3508
|
-
this.toggleTheme(ThemeOption.LIGHT, true);
|
|
3509
|
-
this.toggleTheme(ThemeOption.DARK, false);
|
|
3510
|
-
}
|
|
3511
|
-
get Theme() {
|
|
3512
|
-
return this.theme.value;
|
|
3513
|
-
}
|
|
3514
|
-
set Theme(theme) {
|
|
3515
|
-
this.theme.next(theme);
|
|
3516
|
-
LocalStorageService.set(THEME, theme);
|
|
3517
|
-
}
|
|
3518
|
-
toggleTheme(name, shouldAdd) {
|
|
3519
|
-
console.log('toggleTheme::: ', name, shouldAdd);
|
|
3520
|
-
document.body.classList.toggle(name, shouldAdd);
|
|
3521
|
-
}
|
|
3522
|
-
toggleUserPreference(option) {
|
|
3523
|
-
this.currentOption = option;
|
|
3524
|
-
this.Theme = option;
|
|
3525
|
-
this.lightToggle = option === ThemeOption.LIGHT;
|
|
3526
|
-
this.darkToggle = option === ThemeOption.DARK;
|
|
3527
|
-
this.autoToggle = option === ThemeOption.AUTO;
|
|
3528
|
-
switch (option) {
|
|
3529
|
-
case ThemeOption.LIGHT:
|
|
3530
|
-
this.handleLightPreference();
|
|
3531
|
-
break;
|
|
3532
|
-
case ThemeOption.DARK:
|
|
3533
|
-
this.handleDarkPreference();
|
|
3534
|
-
break;
|
|
3535
|
-
case ThemeOption.AUTO:
|
|
3536
|
-
if (this.prefersDark) {
|
|
3537
|
-
this.handleDarkPreference();
|
|
3538
|
-
}
|
|
3539
|
-
else {
|
|
3540
|
-
this.handleLightPreference();
|
|
3541
|
-
}
|
|
3542
|
-
break;
|
|
3543
|
-
}
|
|
3544
|
-
}
|
|
3545
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
3546
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, providedIn: 'root' }); }
|
|
3547
|
-
}
|
|
3548
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ThemeService, decorators: [{
|
|
3549
|
-
type: Injectable,
|
|
3550
|
-
args: [{
|
|
3551
|
-
providedIn: 'root',
|
|
3552
|
-
}]
|
|
3553
|
-
}], ctorParameters: () => [] });
|
|
3554
|
-
|
|
3555
3560
|
/*
|
|
3556
3561
|
* Public API Surface of valtech-components
|
|
3557
3562
|
*/
|