valtech-components 1.11.65 → 1.11.67
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/title/title.component.mjs +2 -2
- package/esm2022/lib/components/molecules/check-input/check-input.component.mjs +14 -0
- package/esm2022/lib/components/molecules/comment-input/comment-input.component.mjs +19 -0
- package/esm2022/lib/components/molecules/date-input/date-input.component.mjs +20 -0
- package/esm2022/lib/components/molecules/email-input/email-input.component.mjs +19 -0
- package/esm2022/lib/components/molecules/file-input/file-input.component.mjs +37 -0
- package/esm2022/lib/components/molecules/hint/hint.component.mjs +29 -0
- package/esm2022/lib/components/molecules/hour-input/hour-input.component.mjs +19 -0
- package/esm2022/lib/components/molecules/number-input/number-input.component.mjs +19 -0
- package/esm2022/lib/components/molecules/password-input/password-input.component.mjs +21 -0
- package/esm2022/lib/components/molecules/pin-input/pin-input.component.mjs +39 -0
- package/esm2022/lib/components/molecules/prompter/prompter.component.mjs +27 -0
- package/esm2022/lib/components/molecules/prompter/types.mjs +2 -0
- package/esm2022/lib/components/molecules/radio-input/radio-input.component.mjs +20 -0
- package/esm2022/lib/components/molecules/text-input/text-input.component.mjs +20 -0
- package/esm2022/lib/components/organisms/footer/footer.component.mjs +25 -0
- package/esm2022/lib/components/organisms/footer/types.mjs +2 -0
- package/esm2022/lib/components/organisms/form/factory.mjs +8 -0
- package/esm2022/lib/components/organisms/form/form-footer/form-footer.component.mjs +36 -0
- package/esm2022/lib/components/organisms/form/form.component.mjs +75 -0
- package/esm2022/lib/components/organisms/header/header.component.mjs +24 -0
- package/esm2022/lib/components/organisms/header/types.mjs +2 -0
- package/esm2022/lib/components/organisms/wizard/types.mjs +7 -0
- package/esm2022/lib/components/organisms/wizard/wizard-footer/wizard-footer.component.mjs +57 -0
- package/esm2022/lib/components/organisms/wizard/wizard.component.mjs +72 -0
- package/esm2022/lib/components/types.mjs +16 -1
- package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +2 -2
- package/esm2022/lib/services/theme.service.mjs +2 -2
- package/esm2022/lib/shared/constants/storage.mjs +3 -0
- package/esm2022/lib/shared/utils/dom.mjs +17 -0
- package/esm2022/lib/valtech-components.module.mjs +102 -5
- package/esm2022/public-api.mjs +25 -2
- package/fesm2022/valtech-components.mjs +618 -8
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/molecules/check-input/check-input.component.d.ts +8 -0
- package/lib/components/molecules/comment-input/comment-input.component.d.ts +12 -0
- package/lib/components/molecules/date-input/date-input.component.d.ts +12 -0
- package/lib/components/molecules/email-input/email-input.component.d.ts +12 -0
- package/lib/components/molecules/file-input/file-input.component.d.ts +18 -0
- package/lib/components/molecules/hint/hint.component.d.ts +13 -0
- package/lib/components/molecules/hour-input/hour-input.component.d.ts +12 -0
- package/lib/components/molecules/number-input/number-input.component.d.ts +12 -0
- package/lib/components/molecules/password-input/password-input.component.d.ts +13 -0
- package/lib/components/molecules/pin-input/pin-input.component.d.ts +17 -0
- package/lib/components/molecules/prompter/prompter.component.d.ts +12 -0
- package/lib/components/molecules/prompter/types.d.ts +11 -0
- package/lib/components/molecules/radio-input/radio-input.component.d.ts +12 -0
- package/lib/components/molecules/text-input/text-input.component.d.ts +12 -0
- package/lib/components/organisms/footer/footer.component.d.ts +12 -0
- package/lib/components/organisms/footer/types.d.ts +6 -0
- package/lib/components/organisms/form/factory.d.ts +5 -0
- package/lib/components/organisms/form/form-footer/form-footer.component.d.ts +16 -0
- package/lib/components/organisms/form/form.component.d.ts +24 -0
- package/lib/components/organisms/header/header.component.d.ts +12 -0
- package/lib/components/organisms/header/types.d.ts +6 -0
- package/lib/components/organisms/wizard/types.d.ts +21 -0
- package/lib/components/organisms/wizard/wizard-footer/wizard-footer.component.d.ts +21 -0
- package/lib/components/organisms/wizard/wizard.component.d.ts +22 -0
- package/lib/components/types.d.ts +58 -0
- package/lib/shared/utils/dom.d.ts +3 -0
- package/lib/valtech-components.module.d.ts +25 -4
- package/package.json +3 -2
- package/public-api.d.ts +24 -1
- package/esm2022/lib/shared/contants/storage.mjs +0 -3
- /package/lib/shared/{contants → constants}/storage.d.ts +0 -0
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { InputType, ComponentStates } from '../../types';
|
|
3
|
+
import { isAtEnd } from '../../../shared/utils/dom';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
import * as i3 from "../../atoms/display/display.component";
|
|
8
|
+
import * as i4 from "../../atoms/title/title.component";
|
|
9
|
+
import * as i5 from "../../atoms/divider/divider.component";
|
|
10
|
+
import * as i6 from "../../molecules/button-group/button-group.component";
|
|
11
|
+
import * as i7 from "../../molecules/check-input/check-input.component";
|
|
12
|
+
import * as i8 from "../../molecules/comment-input/comment-input.component";
|
|
13
|
+
import * as i9 from "../../molecules/date-input/date-input.component";
|
|
14
|
+
import * as i10 from "../../molecules/email-input/email-input.component";
|
|
15
|
+
import * as i11 from "../../molecules/file-input/file-input.component";
|
|
16
|
+
import * as i12 from "../../molecules/hint/hint.component";
|
|
17
|
+
import * as i13 from "../../molecules/hour-input/hour-input.component";
|
|
18
|
+
import * as i14 from "../../molecules/number-input/number-input.component";
|
|
19
|
+
import * as i15 from "../../molecules/password-input/password-input.component";
|
|
20
|
+
import * as i16 from "../../molecules/pin-input/pin-input.component";
|
|
21
|
+
import * as i17 from "../../molecules/radio-input/radio-input.component";
|
|
22
|
+
import * as i18 from "../../molecules/text-input/text-input.component";
|
|
23
|
+
export class FormComponent {
|
|
24
|
+
constructor(fb, elementRef) {
|
|
25
|
+
this.fb = fb;
|
|
26
|
+
this.elementRef = elementRef;
|
|
27
|
+
this.onSubmit = new EventEmitter();
|
|
28
|
+
this.onInvalid = new EventEmitter();
|
|
29
|
+
this.types = InputType;
|
|
30
|
+
this.formId = 'form-wrapper';
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
const formControls = {};
|
|
34
|
+
this.props.sections.forEach((section) => {
|
|
35
|
+
section.fields.forEach((field) => {
|
|
36
|
+
formControls[field.name] = [undefined, field.validators || []];
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
this.form = this.fb.group(formControls);
|
|
40
|
+
}
|
|
41
|
+
async submitHandler(token) {
|
|
42
|
+
this.onSubmit.emit({ fields: this.form.value, token });
|
|
43
|
+
}
|
|
44
|
+
getControl(field) {
|
|
45
|
+
return this.Form.get(field);
|
|
46
|
+
}
|
|
47
|
+
get isAtEndOfForm() {
|
|
48
|
+
return isAtEnd(this.elementRef);
|
|
49
|
+
}
|
|
50
|
+
get Form() {
|
|
51
|
+
return this.form;
|
|
52
|
+
}
|
|
53
|
+
get actions() {
|
|
54
|
+
if (!this.form) {
|
|
55
|
+
return [];
|
|
56
|
+
}
|
|
57
|
+
if (this.form.valid) {
|
|
58
|
+
this.props.actions.state = ComponentStates.ENABLED;
|
|
59
|
+
}
|
|
60
|
+
return [this.props.actions];
|
|
61
|
+
}
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: FormComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: FormComponent, selector: "val-form", inputs: { props: "props" }, outputs: { onSubmit: "onSubmit", onInvalid: "onInvalid" }, ngImport: i0, template: "<div class=\"container\">\n <form [formGroup]=\"form\">\n <val-display [content]=\"props.name\" color=\"dark\" size=\"large\"></val-display>\n <div class=\"section\" *ngFor=\"let s of props.sections\">\n <val-title [content]=\"s.name\" size=\"large\"></val-title>\n <div class=\"input\" *ngFor=\"let f of s.fields\">\n <val-title color=\"dark\" [content]=\"f.label\" size=\"small\"></val-title>\n <ng-container *ngIf=\"f.type === types.TEXT\">\n <val-text-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-text-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.CHECK\">\n <val-check-input></val-check-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.COMMENT\">\n <val-comment-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-comment-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.DATE\">\n <val-date-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-date-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.EMAIL\">\n <val-email-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-email-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.FILE\">\n <val-file-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-file-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.HOUR\">\n <val-hour-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hour-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.NUMBER\">\n <val-number-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-number-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.PASSWORD\">\n <val-password-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-password-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.PIN_CODE\">\n <val-pin-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-pin-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.RADIO\">\n <val-radio-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-radio-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.SELECT\">\n <!-- <val-select-input></val-select-input> -->\n </ng-container>\n <val-hint [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hint>\n </div>\n <val-divider color=\"medium\" size=\"medium\" fill=\"solid\"></val-divider>\n </div>\n <val-button-group position=\"center\" [buttons]=\"actions\" (onClick)=\"submitHandler($event)\"></val-button-group>\n </form>\n</div>\n", styles: [".section{margin-top:1rem}.input{margin:.5rem 0}@media (min-width: 768px){.input{margin:.75rem 0}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.DisplayComponent, selector: "val-display", inputs: ["size", "color", "content"] }, { kind: "component", type: i4.TitleComponent, selector: "val-title", inputs: ["size", "color", "content"] }, { kind: "component", type: i5.DividerComponent, selector: "val-divider", inputs: ["size", "color", "fill"] }, { kind: "component", type: i6.ButtonGroupComponent, selector: "val-button-group", inputs: ["buttons", "position", "columned"], outputs: ["onClick"] }, { kind: "component", type: i7.CheckInputComponent, selector: "val-check-input" }, { kind: "component", type: i8.CommentInputComponent, selector: "val-comment-input", inputs: ["control", "metadata"] }, { kind: "component", type: i9.DateInputComponent, selector: "val-date-input", inputs: ["control", "metadata"] }, { kind: "component", type: i10.EmailInputComponent, selector: "val-email-input", inputs: ["control", "metadata"] }, { kind: "component", type: i11.FileInputComponent, selector: "val-file-input", inputs: ["control", "metadata"] }, { kind: "component", type: i12.HintComponent, selector: "val-hint", inputs: ["control", "metadata"] }, { kind: "component", type: i13.HourInputComponent, selector: "val-hour-input", inputs: ["control", "metadata"] }, { kind: "component", type: i14.NumberInputComponent, selector: "val-number-input", inputs: ["control", "metadata"] }, { kind: "component", type: i15.PasswordInputComponent, selector: "val-password-input", inputs: ["control", "metadata"] }, { kind: "component", type: i16.PinInputComponent, selector: "val-pin-input", inputs: ["control", "metadata"] }, { kind: "component", type: i17.RadioInputComponent, selector: "val-radio-input", inputs: ["control", "metadata"] }, { kind: "component", type: i18.TextInputComponent, selector: "val-text-input", inputs: ["control", "metadata"] }] }); }
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: FormComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{ selector: 'val-form', template: "<div class=\"container\">\n <form [formGroup]=\"form\">\n <val-display [content]=\"props.name\" color=\"dark\" size=\"large\"></val-display>\n <div class=\"section\" *ngFor=\"let s of props.sections\">\n <val-title [content]=\"s.name\" size=\"large\"></val-title>\n <div class=\"input\" *ngFor=\"let f of s.fields\">\n <val-title color=\"dark\" [content]=\"f.label\" size=\"small\"></val-title>\n <ng-container *ngIf=\"f.type === types.TEXT\">\n <val-text-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-text-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.CHECK\">\n <val-check-input></val-check-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.COMMENT\">\n <val-comment-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-comment-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.DATE\">\n <val-date-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-date-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.EMAIL\">\n <val-email-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-email-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.FILE\">\n <val-file-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-file-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.HOUR\">\n <val-hour-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hour-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.NUMBER\">\n <val-number-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-number-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.PASSWORD\">\n <val-password-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-password-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.PIN_CODE\">\n <val-pin-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-pin-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.RADIO\">\n <val-radio-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-radio-input>\n </ng-container>\n <ng-container *ngIf=\"f.type === types.SELECT\">\n <!-- <val-select-input></val-select-input> -->\n </ng-container>\n <val-hint [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hint>\n </div>\n <val-divider color=\"medium\" size=\"medium\" fill=\"solid\"></val-divider>\n </div>\n <val-button-group position=\"center\" [buttons]=\"actions\" (onClick)=\"submitHandler($event)\"></val-button-group>\n </form>\n</div>\n", styles: [".section{margin-top:1rem}.input{margin:.5rem 0}@media (min-width: 768px){.input{margin:.75rem 0}}\n"] }]
|
|
68
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ElementRef }], propDecorators: { props: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}], onSubmit: [{
|
|
71
|
+
type: Output
|
|
72
|
+
}], onInvalid: [{
|
|
73
|
+
type: Output
|
|
74
|
+
}] } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/form/form.component.ts","../../../../../../../projects/valtech-components/src/lib/components/organisms/form/form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAgB,SAAS,EAAc,eAAe,EAAE,MAAM,aAAa,CAAC;AAEnF,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;;;;;;;;;;;;;AAQpD,MAAM,OAAO,aAAa;IAcxB,YAAoB,EAAe,EAAU,UAAsB;QAA/C,OAAE,GAAF,EAAE,CAAa;QAAU,eAAU,GAAV,UAAU,CAAY;QATnE,aAAQ,GAAG,IAAI,YAAY,EAAc,CAAC;QAG1C,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAG/B,UAAK,GAAG,SAAS,CAAC;QAClB,WAAM,GAAG,cAAc,CAAC;IAE8C,CAAC;IAEvE,QAAQ;QACN,MAAM,YAAY,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACtC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC/B,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;YACjE,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,KAAc;QAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACzD,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAgB,CAAC;IAC7C,CAAC;IAED,IAAI,aAAa;QACf,OAAO,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,IAAI,OAAO;QACT,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QACrD,CAAC;QAED,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;8GApDU,aAAa;kGAAb,aAAa,uICX1B,iwFAkDA;;2FDvCa,aAAa;kBALzB,SAAS;+BACE,UAAU;yGAMpB,KAAK;sBADJ,KAAK;gBAIN,QAAQ;sBADP,MAAM;gBAIP,SAAS;sBADR,MAAM","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormMetadata, InputType, FormSubmit, ComponentStates } from '../../types';\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { isAtEnd } from '../../../shared/utils/dom';\nimport { ButtonMetadata } from '../../atoms/button/types';\n\n@Component({\n  selector: 'val-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.scss'],\n})\nexport class FormComponent implements OnInit {\n  @Input()\n  props: FormMetadata;\n\n  @Output()\n  onSubmit = new EventEmitter<FormSubmit>();\n\n  @Output()\n  onInvalid = new EventEmitter();\n\n  form: FormGroup;\n  types = InputType;\n  formId = 'form-wrapper';\n\n  constructor(private fb: FormBuilder, private elementRef: ElementRef) {}\n\n  ngOnInit() {\n    const formControls = {};\n    this.props.sections.forEach((section) => {\n      section.fields.forEach((field) => {\n        formControls[field.name] = [undefined, field.validators || []];\n      });\n    });\n    this.form = this.fb.group(formControls);\n  }\n\n  async submitHandler(token?: string) {\n    this.onSubmit.emit({ fields: this.form.value, token });\n  }\n\n  getControl(field: string): FormControl {\n    return this.Form.get(field) as FormControl;\n  }\n\n  get isAtEndOfForm(): boolean {\n    return isAtEnd(this.elementRef);\n  }\n\n  get Form(): FormGroup {\n    return this.form;\n  }\n\n  get actions(): ButtonMetadata[] {\n    if (!this.form) {\n      return [];\n    }\n\n    if (this.form.valid) {\n      this.props.actions.state = ComponentStates.ENABLED;\n    }\n\n    return [this.props.actions];\n  }\n}\n","<div class=\"container\">\n  <form [formGroup]=\"form\">\n    <val-display [content]=\"props.name\" color=\"dark\" size=\"large\"></val-display>\n    <div class=\"section\" *ngFor=\"let s of props.sections\">\n      <val-title [content]=\"s.name\" size=\"large\"></val-title>\n      <div class=\"input\" *ngFor=\"let f of s.fields\">\n        <val-title color=\"dark\" [content]=\"f.label\" size=\"small\"></val-title>\n        <ng-container *ngIf=\"f.type === types.TEXT\">\n          <val-text-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-text-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.CHECK\">\n          <val-check-input></val-check-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.COMMENT\">\n          <val-comment-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-comment-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.DATE\">\n          <val-date-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-date-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.EMAIL\">\n          <val-email-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-email-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.FILE\">\n          <val-file-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-file-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.HOUR\">\n          <val-hour-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hour-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.NUMBER\">\n          <val-number-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-number-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.PASSWORD\">\n          <val-password-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-password-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.PIN_CODE\">\n          <val-pin-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-pin-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.RADIO\">\n          <val-radio-input [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-radio-input>\n        </ng-container>\n        <ng-container *ngIf=\"f.type === types.SELECT\">\n          <!-- <val-select-input></val-select-input> -->\n        </ng-container>\n        <val-hint [control]=\"getControl(f.name)\" [metadata]=\"f\"></val-hint>\n      </div>\n      <val-divider color=\"medium\" size=\"medium\" fill=\"solid\"></val-divider>\n    </div>\n    <val-button-group position=\"center\" [buttons]=\"actions\" (onClick)=\"submitHandler($event)\"></val-button-group>\n  </form>\n</div>\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@ionic/angular";
|
|
4
|
+
import * as i2 from "../toolbar/toolbar.component";
|
|
5
|
+
export class HeaderComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.onClick = new EventEmitter();
|
|
8
|
+
}
|
|
9
|
+
ngOnInit() { }
|
|
10
|
+
clickHandler(token) {
|
|
11
|
+
this.onClick.emit(token);
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: HeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: HeaderComponent, selector: "val-header", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<ion-header [class.ion-no-border]=\"!props.bordered\" [translucent]=\"props.translucent\">\n <val-toolbar [props]=\"props.toolbar\" (onClick)=\"clickHandler($event)\"></val-toolbar>\n</ion-header>\n", styles: [""], dependencies: [{ kind: "component", type: i1.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i2.ToolbarComponent, selector: "val-toolbar", inputs: ["props"], outputs: ["onClick"] }] }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: HeaderComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'val-header', template: "<ion-header [class.ion-no-border]=\"!props.bordered\" [translucent]=\"props.translucent\">\n <val-toolbar [props]=\"props.toolbar\" (onClick)=\"clickHandler($event)\"></val-toolbar>\n</ion-header>\n" }]
|
|
19
|
+
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], onClick: [{
|
|
22
|
+
type: Output
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9vcmdhbmlzbXMvaGVhZGVyL2hlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUS9FLE1BQU0sT0FBTyxlQUFlO0lBTzFCO1FBRkEsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFFdEIsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLFlBQVksQ0FBQyxLQUFjO1FBQ3pCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7OEdBYlUsZUFBZTtrR0FBZixlQUFlLCtHQ1I1Qix5TUFHQTs7MkZES2EsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxZQUFZO3dEQU10QixLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSGVhZGVyTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWhlYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgSGVhZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHJvcHM6IEhlYWRlck1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBjbGlja0hhbmRsZXIodG9rZW4/OiBzdHJpbmcpIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdCh0b2tlbik7XG4gIH1cbn1cbiIsIjxpb24taGVhZGVyIFtjbGFzcy5pb24tbm8tYm9yZGVyXT1cIiFwcm9wcy5ib3JkZXJlZFwiIFt0cmFuc2x1Y2VudF09XCJwcm9wcy50cmFuc2x1Y2VudFwiPlxuICA8dmFsLXRvb2xiYXIgW3Byb3BzXT1cInByb3BzLnRvb2xiYXJcIiAob25DbGljayk9XCJjbGlja0hhbmRsZXIoJGV2ZW50KVwiPjwvdmFsLXRvb2xiYXI+XG48L2lvbi1oZWFkZXI+XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy9oZWFkZXIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRvb2xiYXJNZXRhZGF0YSB9IGZyb20gXCIuLi90b29sYmFyL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIEhlYWRlck1ldGFkYXRhID0ge1xuICB0cmFuc2x1Y2VudD86IGJvb2xlYW47XG4gIGJvcmRlcmVkPzogYm9vbGVhbjtcbiAgdG9vbGJhcjogVG9vbGJhck1ldGFkYXRhO1xufTtcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export var MOTION;
|
|
2
|
+
(function (MOTION) {
|
|
3
|
+
MOTION[MOTION["BACKWARD"] = 0] = "BACKWARD";
|
|
4
|
+
MOTION[MOTION["FORWARD"] = 1] = "FORWARD";
|
|
5
|
+
MOTION[MOTION["RETRY"] = 2] = "RETRY";
|
|
6
|
+
})(MOTION || (MOTION = {}));
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy93aXphcmQvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0JBLE1BQU0sQ0FBTixJQUFZLE1BSVg7QUFKRCxXQUFZLE1BQU07SUFDaEIsMkNBQVEsQ0FBQTtJQUNSLHlDQUFPLENBQUE7SUFDUCxxQ0FBSyxDQUFBO0FBQ1AsQ0FBQyxFQUpXLE1BQU0sS0FBTixNQUFNLFFBSWpCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnV0dG9uTWV0YWRhdGEgfSBmcm9tIFwiLi4vLi4vYXRvbXMvYnV0dG9uL3R5cGVzXCI7XG5pbXBvcnQgeyBOb0NvbnRlbnRNZXRhZGF0YSB9IGZyb20gXCIuLi8uLi9tb2xlY3VsZXMvbm8tY29udGVudC90eXBlc1wiO1xuaW1wb3J0IHsgQ29tcG9uZW50U3RhdGUgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgV2l6YXJkTWV0YWRhdGEgPSB7XG4gIHN0YXRlOiBDb21wb25lbnRTdGF0ZTtcbiAgY3VycmVudDogbnVtYmVyO1xuICBzdGVwczogU3RlcHM7XG4gIGVycm9yOiBTdGVwO1xufTtcblxuZXhwb3J0IHR5cGUgU3RlcCA9IHtcbiAgdGl0bGVzOiBOb0NvbnRlbnRNZXRhZGF0YTtcbiAgYnV0dG9uczogQnV0dG9uTWV0YWRhdGFbXTtcbn07XG5cbmV4cG9ydCB0eXBlIFN0ZXBzID0ge1xuICBbc3RlcDogbnVtYmVyXTogU3RlcDtcbn07XG5cbmV4cG9ydCBlbnVtIE1PVElPTiB7XG4gIEJBQ0tXQVJELFxuICBGT1JXQVJELFxuICBSRVRSWSxcbn1cbiJdfQ==
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { MOTION } from '../types';
|
|
3
|
+
import { ComponentStates } from '../../../types';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../../molecules/button-group/button-group.component";
|
|
6
|
+
import * as i2 from "../../../atoms/progress-bar/progress-bar.component";
|
|
7
|
+
import * as i3 from "../../footer/footer.component";
|
|
8
|
+
export class WizardFooterComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.onClick = new EventEmitter();
|
|
11
|
+
this.wrapperId = 'wizard-wrapper';
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() { }
|
|
14
|
+
clickHandler(token) {
|
|
15
|
+
if (!token) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
if (token.includes('right')) {
|
|
19
|
+
this.tryToStep(MOTION.FORWARD);
|
|
20
|
+
}
|
|
21
|
+
if (token.includes('left')) {
|
|
22
|
+
this.tryToStep(MOTION.BACKWARD);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
get Current() {
|
|
26
|
+
return this.props.steps[this.props.current];
|
|
27
|
+
}
|
|
28
|
+
get Progress() {
|
|
29
|
+
if (this.props.steps && this.props.current) {
|
|
30
|
+
return this.props.current / Object.keys(this.props.steps).length;
|
|
31
|
+
}
|
|
32
|
+
return 0;
|
|
33
|
+
}
|
|
34
|
+
get actions() {
|
|
35
|
+
if (this.props.state === ComponentStates.ERROR && this.Current.buttons.length > 1) {
|
|
36
|
+
this.Current.buttons[1].state = ComponentStates.DISABLED;
|
|
37
|
+
}
|
|
38
|
+
if (this.props.current === 1 && this.Current.buttons.length > 1) {
|
|
39
|
+
return [this.Current.buttons[1]];
|
|
40
|
+
}
|
|
41
|
+
return this.Current.buttons;
|
|
42
|
+
}
|
|
43
|
+
tryToStep(motion) {
|
|
44
|
+
this.onClick.emit({ current: this.props.current, motion });
|
|
45
|
+
}
|
|
46
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: WizardFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: WizardFooterComponent, selector: "val-wizard-footer", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<val-footer\n [props]=\"{\nbordered: false,\ntranslucent: false,\ntoolbar: {\n title: '',\n actions: [],\n color: 'background',\n withBack: false,\n withActions: false,\n },\n}\"\n>\n <val-progress-bar extra [progress]=\"Progress\" size=\"medium\"></val-progress-bar>\n <val-button-group extra [buttons]=\"actions\" position=\"spaced\" (onClick)=\"clickHandler($event)\"></val-button-group>\n</val-footer>\n", styles: [""], dependencies: [{ kind: "component", type: i1.ButtonGroupComponent, selector: "val-button-group", inputs: ["buttons", "position", "columned"], outputs: ["onClick"] }, { kind: "component", type: i2.ProgressBarComponent, selector: "val-progress-bar", inputs: ["progress", "size", "color", "buffer", "type", "rounded"] }, { kind: "component", type: i3.FooterComponent, selector: "val-footer", inputs: ["props"], outputs: ["onClick"] }] }); }
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: WizardFooterComponent, decorators: [{
|
|
50
|
+
type: Component,
|
|
51
|
+
args: [{ selector: 'val-wizard-footer', template: "<val-footer\n [props]=\"{\nbordered: false,\ntranslucent: false,\ntoolbar: {\n title: '',\n actions: [],\n color: 'background',\n withBack: false,\n withActions: false,\n },\n}\"\n>\n <val-progress-bar extra [progress]=\"Progress\" size=\"medium\"></val-progress-bar>\n <val-button-group extra [buttons]=\"actions\" position=\"spaced\" (onClick)=\"clickHandler($event)\"></val-button-group>\n</val-footer>\n" }]
|
|
52
|
+
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
53
|
+
type: Input
|
|
54
|
+
}], onClick: [{
|
|
55
|
+
type: Output
|
|
56
|
+
}] } });
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLWZvb3Rlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy93aXphcmQvd2l6YXJkLWZvb3Rlci93aXphcmQtZm9vdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL3dpemFyZC93aXphcmQtZm9vdGVyL3dpemFyZC1mb290ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsTUFBTSxFQUF3QixNQUFNLFVBQVUsQ0FBQztBQUV4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBT2pELE1BQU0sT0FBTyxxQkFBcUI7SUFTaEM7UUFKQSxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQXVDLENBQUM7UUFFbEUsY0FBUyxHQUFHLGdCQUFnQixDQUFDO0lBRWQsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLFlBQVksQ0FBQyxLQUFjO1FBQ3pCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNYLE9BQU87UUFDVCxDQUFDO1FBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakMsQ0FBQztRQUNELElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQzNCLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2xDLENBQUM7SUFDSCxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlDLENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDM0MsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDO1FBQ25FLENBQUM7UUFDRCxPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxJQUFJLE9BQU87UUFDVCxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2xGLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxlQUFlLENBQUMsUUFBUSxDQUFDO1FBQzNELENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDaEUsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkMsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUM7SUFDOUIsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFjO1FBQ3RCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDN0QsQ0FBQzs4R0FqRFUscUJBQXFCO2tHQUFyQixxQkFBcUIsc0hDVmxDLGthQWdCQTs7MkZETmEscUJBQXFCO2tCQUxqQyxTQUFTOytCQUNFLG1CQUFtQjt3REFNN0IsS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1PVElPTiwgU3RlcCwgV2l6YXJkTWV0YWRhdGEgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBCdXR0b25NZXRhZGF0YSB9IGZyb20gJy4uLy4uLy4uL2F0b21zL2J1dHRvbi90eXBlcyc7XG5pbXBvcnQgeyBDb21wb25lbnRTdGF0ZXMgfSBmcm9tICcuLi8uLi8uLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC13aXphcmQtZm9vdGVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3dpemFyZC1mb290ZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi93aXphcmQtZm9vdGVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFdpemFyZEZvb3RlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBXaXphcmRNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8eyBjdXJyZW50OiBudW1iZXI7IG1vdGlvbjogTU9USU9OIH0+KCk7XG5cbiAgd3JhcHBlcklkID0gJ3dpemFyZC13cmFwcGVyJztcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIGNsaWNrSGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIGlmICghdG9rZW4pIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgaWYgKHRva2VuLmluY2x1ZGVzKCdyaWdodCcpKSB7XG4gICAgICB0aGlzLnRyeVRvU3RlcChNT1RJT04uRk9SV0FSRCk7XG4gICAgfVxuICAgIGlmICh0b2tlbi5pbmNsdWRlcygnbGVmdCcpKSB7XG4gICAgICB0aGlzLnRyeVRvU3RlcChNT1RJT04uQkFDS1dBUkQpO1xuICAgIH1cbiAgfVxuXG4gIGdldCBDdXJyZW50KCk6IFN0ZXAge1xuICAgIHJldHVybiB0aGlzLnByb3BzLnN0ZXBzW3RoaXMucHJvcHMuY3VycmVudF07XG4gIH1cblxuICBnZXQgUHJvZ3Jlc3MoKTogbnVtYmVyIHtcbiAgICBpZiAodGhpcy5wcm9wcy5zdGVwcyAmJiB0aGlzLnByb3BzLmN1cnJlbnQpIHtcbiAgICAgIHJldHVybiB0aGlzLnByb3BzLmN1cnJlbnQgLyBPYmplY3Qua2V5cyh0aGlzLnByb3BzLnN0ZXBzKS5sZW5ndGg7XG4gICAgfVxuICAgIHJldHVybiAwO1xuICB9XG5cbiAgZ2V0IGFjdGlvbnMoKTogQnV0dG9uTWV0YWRhdGFbXSB7XG4gICAgaWYgKHRoaXMucHJvcHMuc3RhdGUgPT09IENvbXBvbmVudFN0YXRlcy5FUlJPUiAmJiB0aGlzLkN1cnJlbnQuYnV0dG9ucy5sZW5ndGggPiAxKSB7XG4gICAgICB0aGlzLkN1cnJlbnQuYnV0dG9uc1sxXS5zdGF0ZSA9IENvbXBvbmVudFN0YXRlcy5ESVNBQkxFRDtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wcm9wcy5jdXJyZW50ID09PSAxICYmIHRoaXMuQ3VycmVudC5idXR0b25zLmxlbmd0aCA+IDEpIHtcbiAgICAgIHJldHVybiBbdGhpcy5DdXJyZW50LmJ1dHRvbnNbMV1dO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5DdXJyZW50LmJ1dHRvbnM7XG4gIH1cblxuICB0cnlUb1N0ZXAobW90aW9uOiBNT1RJT04pOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdCh7IGN1cnJlbnQ6IHRoaXMucHJvcHMuY3VycmVudCwgbW90aW9uIH0pO1xuICB9XG59XG4iLCI8dmFsLWZvb3RlclxuICBbcHJvcHNdPVwie1xuYm9yZGVyZWQ6IGZhbHNlLFxudHJhbnNsdWNlbnQ6IGZhbHNlLFxudG9vbGJhcjoge1xuICB0aXRsZTogJycsXG4gIGFjdGlvbnM6IFtdLFxuICBjb2xvcjogJ2JhY2tncm91bmQnLFxuICB3aXRoQmFjazogZmFsc2UsXG4gIHdpdGhBY3Rpb25zOiBmYWxzZSxcbiAgfSxcbn1cIlxuPlxuICA8dmFsLXByb2dyZXNzLWJhciBleHRyYSBbcHJvZ3Jlc3NdPVwiUHJvZ3Jlc3NcIiBzaXplPVwibWVkaXVtXCI+PC92YWwtcHJvZ3Jlc3MtYmFyPlxuICA8dmFsLWJ1dHRvbi1ncm91cCBleHRyYSBbYnV0dG9uc109XCJhY3Rpb25zXCIgcG9zaXRpb249XCJzcGFjZWRcIiAob25DbGljayk9XCJjbGlja0hhbmRsZXIoJGV2ZW50KVwiPjwvdmFsLWJ1dHRvbi1ncm91cD5cbjwvdmFsLWZvb3Rlcj5cbiJdfQ==
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { MOTION } from './types';
|
|
3
|
+
import { goToTop } from '../../../shared/utils/dom';
|
|
4
|
+
import { ComponentStates } from '../../types';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../../molecules/content-loader/content-loader.component";
|
|
8
|
+
import * as i3 from "../../molecules/no-content/no-content.component";
|
|
9
|
+
export class WizardComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.onClick = new EventEmitter();
|
|
12
|
+
this.wrapperId = 'wizard-wrapper';
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() { }
|
|
15
|
+
working() {
|
|
16
|
+
this.props.state = ComponentStates.WORKING;
|
|
17
|
+
this.Current.buttons.map((x) => {
|
|
18
|
+
x.state = ComponentStates.DISABLED;
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
done() {
|
|
22
|
+
if (this.props.state === ComponentStates.ENABLED) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
this.props.state = ComponentStates.ENABLED;
|
|
26
|
+
this.Current.buttons.map((x) => {
|
|
27
|
+
x.state = ComponentStates.ENABLED;
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
get Current() {
|
|
31
|
+
return this.props.steps[this.props.current];
|
|
32
|
+
}
|
|
33
|
+
setCurrent(newStep) {
|
|
34
|
+
if (newStep === this.props.current) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
this.props.current = newStep;
|
|
38
|
+
goToTop(this.wrapperId);
|
|
39
|
+
}
|
|
40
|
+
setError(error) {
|
|
41
|
+
if (this.props.state === ComponentStates.ERROR) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
this.props.error.titles.content.content.bellowTitle.text = error;
|
|
45
|
+
this.props.state = ComponentStates.ERROR;
|
|
46
|
+
goToTop(this.wrapperId);
|
|
47
|
+
}
|
|
48
|
+
reset() {
|
|
49
|
+
this.props.error.titles.content.content.bellowTitle.text = '';
|
|
50
|
+
this.done();
|
|
51
|
+
}
|
|
52
|
+
clickHandler(token) {
|
|
53
|
+
if (!token) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (token.includes('retry')) {
|
|
57
|
+
this.reset();
|
|
58
|
+
}
|
|
59
|
+
this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });
|
|
60
|
+
}
|
|
61
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: WizardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: WizardComponent, selector: "val-wizard", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<div [id]=\"wrapperId\" class=\"wrapper\">\n <ng-container *ngIf=\"props.state !== 'ERROR'\">\n <val-no-content [props]=\"Current.titles\"></val-no-content>\n <div class=\"step\">\n <div *ngIf=\"props.state === 'WORKING'\">\n <val-content-loader color=\"dark\" size=\"large\" text=\"Por favor espere...\"></val-content-loader>\n </div>\n <ng-content select=\"[step]\"></ng-content>\n </div>\n </ng-container>\n <ng-container *ngIf=\"props.state === 'ERROR'\">\n <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n </ng-container>\n</div>\n", styles: [".wrapper{height:auto;display:flex;flex-direction:column;justify-content:space-between;position:relative}.step{min-height:9.375rem;margin:16px 0;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ContentLoaderComponent, selector: "val-content-loader", inputs: ["color", "size", "name", "text"] }, { kind: "component", type: i3.NoContentComponent, selector: "val-no-content", inputs: ["props"], outputs: ["onClick"] }] }); }
|
|
63
|
+
}
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: WizardComponent, decorators: [{
|
|
65
|
+
type: Component,
|
|
66
|
+
args: [{ selector: 'val-wizard', template: "<div [id]=\"wrapperId\" class=\"wrapper\">\n <ng-container *ngIf=\"props.state !== 'ERROR'\">\n <val-no-content [props]=\"Current.titles\"></val-no-content>\n <div class=\"step\">\n <div *ngIf=\"props.state === 'WORKING'\">\n <val-content-loader color=\"dark\" size=\"large\" text=\"Por favor espere...\"></val-content-loader>\n </div>\n <ng-content select=\"[step]\"></ng-content>\n </div>\n </ng-container>\n <ng-container *ngIf=\"props.state === 'ERROR'\">\n <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n </ng-container>\n</div>\n", styles: [".wrapper{height:auto;display:flex;flex-direction:column;justify-content:space-between;position:relative}.step{min-height:9.375rem;margin:16px 0;text-align:center}\n"] }]
|
|
67
|
+
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], onClick: [{
|
|
70
|
+
type: Output
|
|
71
|
+
}] } });
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL3dpemFyZC93aXphcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9vcmdhbmlzbXMvd2l6YXJkL3dpemFyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxNQUFNLEVBQXdCLE1BQU0sU0FBUyxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sYUFBYSxDQUFDOzs7OztBQU85QyxNQUFNLE9BQU8sZUFBZTtJQVMxQjtRQUpBLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBdUMsQ0FBQztRQUVsRSxjQUFTLEdBQUcsZ0JBQWdCLENBQUM7SUFFZCxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsT0FBTztRQUNMLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDM0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDN0IsQ0FBQyxDQUFDLEtBQUssR0FBRyxlQUFlLENBQUMsUUFBUSxDQUFDO1FBQ3JDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqRCxPQUFPO1FBQ1QsQ0FBQztRQUVELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDM0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDN0IsQ0FBQyxDQUFDLEtBQUssR0FBRyxlQUFlLENBQUMsT0FBTyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksT0FBTztRQUNULE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBRUQsVUFBVSxDQUFDLE9BQWU7UUFDeEIsSUFBSSxPQUFPLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNuQyxPQUFPO1FBQ1QsQ0FBQztRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUM3QixPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBYTtRQUNwQixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUMvQyxPQUFPO1FBQ1QsQ0FBQztRQUVELElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1FBQ2pFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxLQUFLLENBQUM7UUFDekMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQzlELElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCxZQUFZLENBQUMsS0FBYztRQUN6QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDWCxPQUFPO1FBQ1QsQ0FBQztRQUNELElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNmLENBQUM7UUFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0UsQ0FBQzs4R0FuRVUsZUFBZTtrR0FBZixlQUFlLCtHQ1Y1QixxbkJBY0E7OzJGREphLGVBQWU7a0JBTDNCLFNBQVM7K0JBQ0UsWUFBWTt3REFNdEIsS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1PVElPTiwgU3RlcCwgV2l6YXJkTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IGdvVG9Ub3AgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvZG9tJztcbmltcG9ydCB7IENvbXBvbmVudFN0YXRlcyB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXdpemFyZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi93aXphcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi93aXphcmQuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgV2l6YXJkQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFdpemFyZE1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjx7IGN1cnJlbnQ6IG51bWJlcjsgbW90aW9uOiBNT1RJT04gfT4oKTtcblxuICB3cmFwcGVySWQgPSAnd2l6YXJkLXdyYXBwZXInO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgd29ya2luZygpIHtcbiAgICB0aGlzLnByb3BzLnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLldPUktJTkc7XG4gICAgdGhpcy5DdXJyZW50LmJ1dHRvbnMubWFwKCh4KSA9PiB7XG4gICAgICB4LnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLkRJU0FCTEVEO1xuICAgIH0pO1xuICB9XG5cbiAgZG9uZSgpIHtcbiAgICBpZiAodGhpcy5wcm9wcy5zdGF0ZSA9PT0gQ29tcG9uZW50U3RhdGVzLkVOQUJMRUQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLnByb3BzLnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLkVOQUJMRUQ7XG4gICAgdGhpcy5DdXJyZW50LmJ1dHRvbnMubWFwKCh4KSA9PiB7XG4gICAgICB4LnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLkVOQUJMRUQ7XG4gICAgfSk7XG4gIH1cblxuICBnZXQgQ3VycmVudCgpOiBTdGVwIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5zdGVwc1t0aGlzLnByb3BzLmN1cnJlbnRdO1xuICB9XG5cbiAgc2V0Q3VycmVudChuZXdTdGVwOiBudW1iZXIpIHtcbiAgICBpZiAobmV3U3RlcCA9PT0gdGhpcy5wcm9wcy5jdXJyZW50KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMucHJvcHMuY3VycmVudCA9IG5ld1N0ZXA7XG4gICAgZ29Ub1RvcCh0aGlzLndyYXBwZXJJZCk7XG4gIH1cblxuICBzZXRFcnJvcihlcnJvcjogc3RyaW5nKSB7XG4gICAgaWYgKHRoaXMucHJvcHMuc3RhdGUgPT09IENvbXBvbmVudFN0YXRlcy5FUlJPUikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMucHJvcHMuZXJyb3IudGl0bGVzLmNvbnRlbnQuY29udGVudC5iZWxsb3dUaXRsZS50ZXh0ID0gZXJyb3I7XG4gICAgdGhpcy5wcm9wcy5zdGF0ZSA9IENvbXBvbmVudFN0YXRlcy5FUlJPUjtcbiAgICBnb1RvVG9wKHRoaXMud3JhcHBlcklkKTtcbiAgfVxuXG4gIHJlc2V0KCkge1xuICAgIHRoaXMucHJvcHMuZXJyb3IudGl0bGVzLmNvbnRlbnQuY29udGVudC5iZWxsb3dUaXRsZS50ZXh0ID0gJyc7XG4gICAgdGhpcy5kb25lKCk7XG4gIH1cblxuICBjbGlja0hhbmRsZXIodG9rZW4/OiBzdHJpbmcpIHtcbiAgICBpZiAoIXRva2VuKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0b2tlbi5pbmNsdWRlcygncmV0cnknKSkge1xuICAgICAgdGhpcy5yZXNldCgpO1xuICAgIH1cblxuICAgIHRoaXMub25DbGljay5lbWl0KHsgY3VycmVudDogdGhpcy5wcm9wcy5jdXJyZW50LCBtb3Rpb246IE1PVElPTi5SRVRSWSB9KTtcbiAgfVxufVxuIiwiPGRpdiBbaWRdPVwid3JhcHBlcklkXCIgY2xhc3M9XCJ3cmFwcGVyXCI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJwcm9wcy5zdGF0ZSAhPT0gJ0VSUk9SJ1wiPlxuICAgIDx2YWwtbm8tY29udGVudCBbcHJvcHNdPVwiQ3VycmVudC50aXRsZXNcIj48L3ZhbC1uby1jb250ZW50PlxuICAgIDxkaXYgY2xhc3M9XCJzdGVwXCI+XG4gICAgICA8ZGl2ICpuZ0lmPVwicHJvcHMuc3RhdGUgPT09ICdXT1JLSU5HJ1wiPlxuICAgICAgICA8dmFsLWNvbnRlbnQtbG9hZGVyIGNvbG9yPVwiZGFya1wiIHNpemU9XCJsYXJnZVwiIHRleHQ9XCJQb3IgZmF2b3IgZXNwZXJlLi4uXCI+PC92YWwtY29udGVudC1sb2FkZXI+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltzdGVwXVwiPjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgPC9uZy1jb250YWluZXI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJwcm9wcy5zdGF0ZSA9PT0gJ0VSUk9SJ1wiPlxuICAgIDx2YWwtbm8tY29udGVudCBbcHJvcHNdPVwicHJvcHMuZXJyb3IudGl0bGVzXCIgKG9uQ2xpY2spPVwiY2xpY2tIYW5kbGVyKCRldmVudClcIj48L3ZhbC1uby1jb250ZW50PlxuICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuIl19
|
|
@@ -11,4 +11,19 @@ export var ActionType;
|
|
|
11
11
|
ActionType[ActionType["APP_NAVIGATION"] = 3] = "APP_NAVIGATION";
|
|
12
12
|
ActionType[ActionType["BROWSER_NAVIGATION"] = 4] = "BROWSER_NAVIGATION";
|
|
13
13
|
})(ActionType || (ActionType = {}));
|
|
14
|
-
|
|
14
|
+
export var InputType;
|
|
15
|
+
(function (InputType) {
|
|
16
|
+
InputType[InputType["TEXT"] = 0] = "TEXT";
|
|
17
|
+
InputType[InputType["EMAIL"] = 1] = "EMAIL";
|
|
18
|
+
InputType[InputType["PASSWORD"] = 2] = "PASSWORD";
|
|
19
|
+
InputType[InputType["COMMENT"] = 3] = "COMMENT";
|
|
20
|
+
InputType[InputType["NUMBER"] = 4] = "NUMBER";
|
|
21
|
+
InputType[InputType["PIN_CODE"] = 5] = "PIN_CODE";
|
|
22
|
+
InputType[InputType["DATE"] = 6] = "DATE";
|
|
23
|
+
InputType[InputType["HOUR"] = 7] = "HOUR";
|
|
24
|
+
InputType[InputType["CHECK"] = 8] = "CHECK";
|
|
25
|
+
InputType[InputType["RADIO"] = 9] = "RADIO";
|
|
26
|
+
InputType[InputType["SELECT"] = 10] = "SELECT";
|
|
27
|
+
InputType[InputType["FILE"] = 11] = "FILE";
|
|
28
|
+
})(InputType || (InputType = {}));
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sT0FBTyxHQUFtQixTQUFTLENBQUM7QUFDMUMsTUFBTSxRQUFRLEdBQW1CLFVBQVUsQ0FBQztBQUM1QyxNQUFNLE9BQU8sR0FBbUIsU0FBUyxDQUFDO0FBQzFDLE1BQU0sS0FBSyxHQUFtQixPQUFPLENBQUM7QUFDdEMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLENBQUM7QUFFckUsTUFBTSxDQUFOLElBQVksVUFNWDtBQU5ELFdBQVksVUFBVTtJQUNwQixpRUFBZSxDQUFBO0lBQ2YsbUVBQWdCLENBQUE7SUFDaEIsaUVBQWUsQ0FBQTtJQUNmLCtEQUFjLENBQUE7SUFDZCx1RUFBa0IsQ0FBQTtBQUNwQixDQUFDLEVBTlcsVUFBVSxLQUFWLFVBQVUsUUFNckI7QUFRRCxNQUFNLENBQU4sSUFBWSxTQWFYO0FBYkQsV0FBWSxTQUFTO0lBQ25CLHlDQUFJLENBQUE7SUFDSiwyQ0FBSyxDQUFBO0lBQ0wsaURBQVEsQ0FBQTtJQUNSLCtDQUFPLENBQUE7SUFDUCw2Q0FBTSxDQUFBO0lBQ04saURBQVEsQ0FBQTtJQUNSLHlDQUFJLENBQUE7SUFDSix5Q0FBSSxDQUFBO0lBQ0osMkNBQUssQ0FBQTtJQUNMLDJDQUFLLENBQUE7SUFDTCw4Q0FBTSxDQUFBO0lBQ04sMENBQUksQ0FBQTtBQUNOLENBQUMsRUFiVyxTQUFTLEtBQVQsU0FBUyxRQWFwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZhbGlkYXRvckZuIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5pbXBvcnQgeyBCdXR0b25NZXRhZGF0YSB9IGZyb20gXCIuL2F0b21zL2J1dHRvbi90eXBlc1wiO1xuXG5leHBvcnQgdHlwZSBDb21wb25lbnRTdGF0ZSA9ICdFTkFCTEVEJyB8ICdESVNBQkxFRCcgfCAnV09SS0lORycgfCAnRVJST1InO1xuY29uc3QgRU5BQkxFRDogQ29tcG9uZW50U3RhdGUgPSAnRU5BQkxFRCc7XG5jb25zdCBESVNBQkxFRDogQ29tcG9uZW50U3RhdGUgPSAnRElTQUJMRUQnO1xuY29uc3QgV09SS0lORzogQ29tcG9uZW50U3RhdGUgPSAnV09SS0lORyc7XG5jb25zdCBFUlJPUjogQ29tcG9uZW50U3RhdGUgPSAnRVJST1InO1xuZXhwb3J0IGNvbnN0IENvbXBvbmVudFN0YXRlcyA9IHsgRU5BQkxFRCwgRElTQUJMRUQsIFdPUktJTkcsIEVSUk9SIH07XG5cbmV4cG9ydCBlbnVtIEFjdGlvblR5cGUge1xuICBCUk9XU0VSX05FV19UQUIsXG4gIEJST1dTRVJfRE9XTkxPQUQsXG4gIE5BVElWRV9ET1dOTE9BRCxcbiAgQVBQX05BVklHQVRJT04sXG4gIEJST1dTRVJfTkFWSUdBVElPTixcbn1cblxuZXhwb3J0IHR5cGUgQWN0aW9uID0ge1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICB0eXBlOiBBY3Rpb25UeXBlO1xuICBzb3VyY2U6IHN0cmluZztcbn07XG5cbmV4cG9ydCBlbnVtIElucHV0VHlwZSB7XG4gIFRFWFQsXG4gIEVNQUlMLFxuICBQQVNTV09SRCxcbiAgQ09NTUVOVCxcbiAgTlVNQkVSLFxuICBQSU5fQ09ERSxcbiAgREFURSxcbiAgSE9VUixcbiAgQ0hFQ0ssXG4gIFJBRElPLFxuICBTRUxFQ1QsXG4gIEZJTEUsXG59XG5cbmV4cG9ydCB0eXBlIElucHV0T3B0aW9uID0ge1xuICBpZDogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIHNlbGVjdGVkPzogYm9vbGVhbjtcbiAgb3JkZXI6IG51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIElucHV0TWV0YWRhdGEgPSB7XG4gIHRva2VuOiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgaGludDogc3RyaW5nO1xuICBwbGFjZWhvbGRlcjogc3RyaW5nO1xuICB0eXBlOiBJbnB1dFR5cGU7XG4gIG9yZGVyOiBudW1iZXI7XG4gIHZhbGlkYXRvcnM6IFZhbGlkYXRvckZuW107XG4gIG9wdGlvbnM/OiBJbnB1dE9wdGlvbltdO1xuICByYW5nZT86IHtcbiAgICBtaW46IG51bWJlcjtcbiAgICBtYXg6IG51bWJlcjtcbiAgfTtcbiAgZXJyb3JzOiB7XG4gICAgW2tleTogc3RyaW5nXTogc3RyaW5nO1xuICB9O1xuICB2YWx1ZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEZvcm1TZWN0aW9uID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIG9yZGVyOiBudW1iZXI7XG4gIGZpZWxkczogSW5wdXRNZXRhZGF0YVtdO1xufTtcblxuZXhwb3J0IHR5cGUgRm9ybVN1Ym1pdCA9IHtcbiAgZmllbGRzOiB7IGtleTogc3RyaW5nOyB2YWx1ZTogc3RyaW5nIH1bXTtcbiAgdG9rZW4/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBGb3JtTWV0YWRhdGEgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2VjdGlvbnM6IEZvcm1TZWN0aW9uW107XG4gIGFjdGlvbnM6IEJ1dHRvbk1ldGFkYXRhO1xufTtcblxuIl19
|
|
@@ -2,7 +2,7 @@ import { Inject, Injectable } from '@angular/core';
|
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import { LangOption } from './types';
|
|
4
4
|
import { LocalStorageService } from '../local-storage.service';
|
|
5
|
-
import { LANG } from '../../shared/
|
|
5
|
+
import { LANG } from '../../shared/constants/storage';
|
|
6
6
|
import { ValtechConfigService } from '../../valtech-components.module';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class LangService {
|
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
36
36
|
type: Inject,
|
|
37
37
|
args: [ValtechConfigService]
|
|
38
38
|
}] }] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZy1wcm92aWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvbGFuZy1wcm92aWRlci9sYW5nLXByb3ZpZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV2QyxPQUFPLEVBQUUsVUFBVSxFQUFpQyxNQUFNLFNBQVMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEQsT0FBTyxFQUFpQixvQkFBb0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQUt0RixNQUFNLE9BQU8sV0FBVztJQU10QixZQUEwQyxNQUFxQjtRQUovRCxZQUFPLEdBQUcsVUFBVSxDQUFDLEVBQUUsQ0FBQztRQUt0QixPQUFPLENBQUMsR0FBRyxDQUFDLG1CQUFtQixFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUM5QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixNQUFNLE9BQU8sR0FBRyxtQkFBbUIsQ0FBQyxHQUFHLENBQWEsSUFBSSxDQUFDLENBQUM7UUFDMUQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLGVBQWUsQ0FBYSxPQUFPLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9FLENBQUM7SUFFRCxJQUFJLENBQUMsU0FBaUI7UUFDcEIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xFLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUFJLElBQUksQ0FBQyxJQUFnQjtRQUN2QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM3QixtQkFBbUIsQ0FBQyxHQUFHLENBQWEsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2xELENBQUM7OEdBekJVLFdBQVcsa0JBTUYsb0JBQW9CO2tIQU43QixXQUFXLGNBRlYsTUFBTTs7MkZBRVAsV0FBVztrQkFIdkIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQU9jLE1BQU07MkJBQUMsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCBjb250ZW50IGZyb20gJy4vY29udGVudCc7XG5pbXBvcnQgeyBMYW5nT3B0aW9uLCBMYW5ndWFnZVRleHQsIENvbnRlbnRQcm92aWRlciB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgTG9jYWxTdG9yYWdlU2VydmljZSB9IGZyb20gJy4uL2xvY2FsLXN0b3JhZ2Uuc2VydmljZSc7XG5pbXBvcnQgeyBMQU5HIH0gZnJvbSAnLi4vLi4vc2hhcmVkL2NvbnN0YW50cy9zdG9yYWdlJztcbmltcG9ydCB7IFZhbHRlY2hDb25maWcsIFZhbHRlY2hDb25maWdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vdmFsdGVjaC1jb21wb25lbnRzLm1vZHVsZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBMYW5nU2VydmljZSB7XG4gIGNvbnRlbnQ6IENvbnRlbnRQcm92aWRlcjtcbiAgZGVmYXVsdCA9IExhbmdPcHRpb24uRVM7XG4gIHNlbGVjdGVkTGFuZzogQmVoYXZpb3JTdWJqZWN0PExhbmdPcHRpb24+O1xuICBjb25maWc6IFZhbHRlY2hDb25maWc7XG5cbiAgY29uc3RydWN0b3IoQEluamVjdChWYWx0ZWNoQ29uZmlnU2VydmljZSkgY29uZmlnOiBWYWx0ZWNoQ29uZmlnKSB7XG4gICAgY29uc29sZS5sb2coJ2luamVjdGVkIGNvbmZpZzogJywgY29uZmlnKTtcbiAgICB0aGlzLmNvbnRlbnQgPSBjb25maWcuY29udGVudDtcbiAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcbiAgICBjb25zdCBjdXJyZW50ID0gTG9jYWxTdG9yYWdlU2VydmljZS5nZXQ8TGFuZ09wdGlvbj4oTEFORyk7XG4gICAgdGhpcy5zZWxlY3RlZExhbmcgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PExhbmdPcHRpb24+KGN1cnJlbnQgfHwgdGhpcy5kZWZhdWx0KTtcbiAgfVxuXG4gIFRleHQoY2xhc3NOYW1lOiBzdHJpbmcpOiBMYW5ndWFnZVRleHQge1xuICAgIHJldHVybiB0aGlzLmNvbnRlbnRbY2xhc3NOYW1lXS5Db250ZW50W3RoaXMuc2VsZWN0ZWRMYW5nLnZhbHVlXTtcbiAgfVxuXG4gIGdldCBMYW5nKCk6IExhbmdPcHRpb24ge1xuICAgIHJldHVybiB0aGlzLnNlbGVjdGVkTGFuZy52YWx1ZTtcbiAgfVxuXG4gIHNldCBMYW5nKGxhbmc6IExhbmdPcHRpb24pIHtcbiAgICB0aGlzLnNlbGVjdGVkTGFuZy5uZXh0KGxhbmcpO1xuICAgIExvY2FsU3RvcmFnZVNlcnZpY2Uuc2V0PExhbmdPcHRpb24+KExBTkcsIGxhbmcpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import { LocalStorageService } from './local-storage.service';
|
|
4
|
-
import { THEME } from '../shared/
|
|
4
|
+
import { THEME } from '../shared/constants/storage';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export var ThemeOption;
|
|
7
7
|
(function (ThemeOption) {
|
|
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
94
94
|
providedIn: 'root',
|
|
95
95
|
}]
|
|
96
96
|
}], ctorParameters: () => [] });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# 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 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"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const LANG = 'LANG';
|
|
2
|
+
export const THEME = 'THEME';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL3NoYXJlZC9jb25zdGFudHMvc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDO0FBQzNCLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgTEFORyA9ICdMQU5HJztcbmV4cG9ydCBjb25zdCBUSEVNRSA9ICdUSEVNRSc7Il19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export const goToTop = (id) => {
|
|
2
|
+
const element = document.getElementById(id);
|
|
3
|
+
if (element) {
|
|
4
|
+
element.scrollIntoView({
|
|
5
|
+
block: 'start',
|
|
6
|
+
inline: 'nearest',
|
|
7
|
+
behavior: 'smooth',
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
export const isAtEnd = (elementRef) => {
|
|
12
|
+
const formElement = elementRef.nativeElement;
|
|
13
|
+
const rect = formElement.getBoundingClientRect();
|
|
14
|
+
const windowHeight = window.innerHeight;
|
|
15
|
+
return rect.bottom <= windowHeight;
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvc2hhcmVkL3V0aWxzL2RvbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxFQUFVLEVBQVEsRUFBRTtJQUMxQyxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzVDLElBQUksT0FBTyxFQUFFLENBQUM7UUFDWixPQUFPLENBQUMsY0FBYyxDQUFDO1lBQ3JCLEtBQUssRUFBRSxPQUFPO1lBQ2QsTUFBTSxFQUFFLFNBQVM7WUFDakIsUUFBUSxFQUFFLFFBQVE7U0FDbkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztBQUNILENBQUMsQ0FBQztBQUdGLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxDQUFDLFVBQXNCLEVBQVcsRUFBRTtJQUN6RCxNQUFNLFdBQVcsR0FBRyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQzdDLE1BQU0sSUFBSSxHQUFHLFdBQVcsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQ2pELE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7SUFDeEMsT0FBTyxJQUFJLENBQUMsTUFBTSxJQUFJLFlBQVksQ0FBQztBQUNyQyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGNvbnN0IGdvVG9Ub3AgPSAoaWQ6IHN0cmluZyk6IHZvaWQgPT4ge1xuICBjb25zdCBlbGVtZW50ID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoaWQpO1xuICBpZiAoZWxlbWVudCkge1xuICAgIGVsZW1lbnQuc2Nyb2xsSW50b1ZpZXcoe1xuICAgICAgYmxvY2s6ICdzdGFydCcsXG4gICAgICBpbmxpbmU6ICduZWFyZXN0JyxcbiAgICAgIGJlaGF2aW9yOiAnc21vb3RoJyxcbiAgICB9KTtcbiAgfVxufTtcblxuXG5leHBvcnQgY29uc3QgaXNBdEVuZCA9IChlbGVtZW50UmVmOiBFbGVtZW50UmVmKTogYm9vbGVhbiA9PiB7XG4gIGNvbnN0IGZvcm1FbGVtZW50ID0gZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICBjb25zdCByZWN0ID0gZm9ybUVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gIGNvbnN0IHdpbmRvd0hlaWdodCA9IHdpbmRvdy5pbm5lckhlaWdodDtcbiAgcmV0dXJuIHJlY3QuYm90dG9tIDw9IHdpbmRvd0hlaWdodDtcbn1cbiJdfQ==
|