valtech-components 2.0.434 → 2.0.435
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/fab/fab.component.mjs +5 -4
- package/esm2022/lib/components/molecules/comment-input/comment-input.component.mjs +13 -5
- package/esm2022/lib/components/molecules/comment-input/types.mjs +2 -0
- package/esm2022/lib/components/molecules/date-input/date-input.component.mjs +23 -4
- package/esm2022/lib/components/molecules/date-input/types.mjs +2 -0
- package/esm2022/lib/components/molecules/feedback-form/feedback-form.component.mjs +352 -0
- package/esm2022/lib/components/molecules/feedback-form/types.mjs +2 -0
- package/esm2022/lib/components/molecules/file-input/file-input.component.mjs +7 -7
- package/esm2022/lib/components/molecules/file-input/types.mjs +2 -0
- package/esm2022/lib/components/molecules/number-from-to/number-from-to.component.mjs +23 -9
- package/esm2022/lib/components/molecules/number-from-to/types.mjs +2 -0
- package/esm2022/lib/components/molecules/pin-input/pin-input.component.mjs +2 -2
- package/esm2022/lib/components/molecules/pin-input/types.mjs +2 -0
- package/esm2022/lib/components/organisms/form/form.component.mjs +108 -30
- package/esm2022/lib/services/content/content-types/blog.mjs +275 -0
- package/esm2022/lib/services/content/content-types/documentation.mjs +303 -0
- package/esm2022/lib/services/content/content-types/news.mjs +277 -0
- package/esm2022/lib/services/content/index.mjs +51 -0
- package/esm2022/lib/services/content/transformer.mjs +265 -0
- package/esm2022/lib/services/content/types.mjs +41 -0
- package/esm2022/lib/services/feedback/config.mjs +49 -0
- package/esm2022/lib/services/feedback/feedback.service.mjs +174 -0
- package/esm2022/lib/services/feedback/index.mjs +44 -0
- package/esm2022/lib/services/feedback/types.mjs +30 -0
- package/esm2022/lib/services/firebase/index.mjs +3 -1
- package/esm2022/lib/services/firebase/shared-config.mjs +132 -0
- package/esm2022/public-api.mjs +14 -1
- package/fesm2022/valtech-components.mjs +2225 -177
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/fab/fab.component.d.ts +2 -0
- package/lib/components/molecules/comment-input/comment-input.component.d.ts +4 -4
- package/lib/components/molecules/comment-input/types.d.ts +59 -0
- package/lib/components/molecules/date-input/date-input.component.d.ts +4 -3
- package/lib/components/molecules/date-input/types.d.ts +74 -0
- package/lib/components/molecules/feedback-form/feedback-form.component.d.ts +56 -0
- package/lib/components/molecules/feedback-form/types.d.ts +54 -0
- package/lib/components/molecules/file-input/file-input.component.d.ts +5 -3
- package/lib/components/molecules/file-input/types.d.ts +72 -0
- package/lib/components/molecules/number-from-to/number-from-to.component.d.ts +8 -2
- package/lib/components/molecules/number-from-to/types.d.ts +76 -0
- package/lib/components/molecules/pin-input/pin-input.component.d.ts +4 -3
- package/lib/components/molecules/pin-input/types.d.ts +63 -0
- package/lib/components/organisms/form/form.component.d.ts +16 -2
- package/lib/services/content/content-types/blog.d.ts +148 -0
- package/lib/services/content/content-types/documentation.d.ts +183 -0
- package/lib/services/content/content-types/news.d.ts +162 -0
- package/lib/services/content/index.d.ts +49 -0
- package/lib/services/content/transformer.d.ts +96 -0
- package/lib/services/content/types.d.ts +220 -0
- package/lib/services/feedback/config.d.ts +35 -0
- package/lib/services/feedback/feedback.service.d.ts +76 -0
- package/lib/services/feedback/index.d.ts +40 -0
- package/lib/services/feedback/types.d.ts +107 -0
- package/lib/services/firebase/index.d.ts +1 -0
- package/lib/services/firebase/shared-config.d.ts +120 -0
- package/package.json +1 -1
- package/public-api.d.ts +9 -0
|
@@ -10,9 +10,9 @@ import * as i0 from "@angular/core";
|
|
|
10
10
|
* A file input component for uploading files, integrated with Angular forms.
|
|
11
11
|
*
|
|
12
12
|
* @example
|
|
13
|
-
* <val-file-input [props]="{ control: myControl }"></val-file-input>
|
|
13
|
+
* <val-file-input [props]="{ control: myControl, accept: 'image/*' }"></val-file-input>
|
|
14
14
|
*
|
|
15
|
-
* @input props:
|
|
15
|
+
* @input props: FileInputMetadata - Configuration for the file input (form control, accept types, etc.)
|
|
16
16
|
*/
|
|
17
17
|
export class FileInputComponent {
|
|
18
18
|
constructor() {
|
|
@@ -33,13 +33,13 @@ export class FileInputComponent {
|
|
|
33
33
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FileInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
34
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FileInputComponent, isStandalone: true, selector: "val-file-input", inputs: { props: "props" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: `
|
|
35
35
|
<div class="file-container">
|
|
36
|
-
<input style="display: none" type="file" (change)="onFileSelected($event)" #fileInput />
|
|
36
|
+
<input style="display: none" type="file" (change)="onFileSelected($event)" #fileInput [accept]="props.accept" />
|
|
37
37
|
<div class="name-container">
|
|
38
38
|
<ion-icon [name]="selectedFile ? 'checkmark-circle-outline' : 'alert-circle-outline'"></ion-icon>
|
|
39
39
|
<val-text
|
|
40
40
|
style="margin-left: 4px;"
|
|
41
41
|
[props]="{
|
|
42
|
-
content: selectedFile ? selectedFile.name : 'No has seleccionado archivo',
|
|
42
|
+
content: selectedFile ? selectedFile.name : (props.noFileText || 'No has seleccionado archivo'),
|
|
43
43
|
color: 'dark',
|
|
44
44
|
bold: false,
|
|
45
45
|
size: 'medium',
|
|
@@ -54,13 +54,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
54
54
|
type: Component,
|
|
55
55
|
args: [{ selector: 'val-file-input', standalone: true, imports: [IonIcon, TextComponent, ButtonComponent], template: `
|
|
56
56
|
<div class="file-container">
|
|
57
|
-
<input style="display: none" type="file" (change)="onFileSelected($event)" #fileInput />
|
|
57
|
+
<input style="display: none" type="file" (change)="onFileSelected($event)" #fileInput [accept]="props.accept" />
|
|
58
58
|
<div class="name-container">
|
|
59
59
|
<ion-icon [name]="selectedFile ? 'checkmark-circle-outline' : 'alert-circle-outline'"></ion-icon>
|
|
60
60
|
<val-text
|
|
61
61
|
style="margin-left: 4px;"
|
|
62
62
|
[props]="{
|
|
63
|
-
content: selectedFile ? selectedFile.name : 'No has seleccionado archivo',
|
|
63
|
+
content: selectedFile ? selectedFile.name : (props.noFileText || 'No has seleccionado archivo'),
|
|
64
64
|
color: 'dark',
|
|
65
65
|
bold: false,
|
|
66
66
|
size: 'medium',
|
|
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
76
76
|
type: ViewChild,
|
|
77
77
|
args: ['fileInput']
|
|
78
78
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1pbnB1dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2ZpbGUtaW5wdXQvZmlsZS1pbnB1dC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDNUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQTRCaEU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQWlCN0I7UUFOQSxtQkFBYyxHQUFtQjtZQUMvQixHQUFHLDhCQUE4QixDQUFDLGVBQWUsQ0FBQztZQUNsRCxLQUFLLEVBQUUsT0FBTztTQUNmLENBQUM7SUFHYSxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsY0FBYyxDQUFDLEtBQUs7UUFDbEIsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztJQUMxQyxDQUFDOytHQTdCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw4TUE5Qm5COzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCVCxzeEZBbEJTLE9BQU8sMkpBQUUsYUFBYSx3RUFBRSxlQUFlOzs0RkErQnRDLGtCQUFrQjtrQkFsQzlCLFNBQVM7K0JBQ0UsZ0JBQWdCLGNBQ2QsSUFBSSxXQUNQLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxlQUFlLENBQUMsWUFDeEM7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJUO3dEQW9CUSxLQUFLO3NCQUFiLEtBQUs7Z0JBRWtCLFNBQVM7c0JBQWhDLFNBQVM7dUJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJb25JY29uIH0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQcmltYXJ5U29saWREZWZhdWx0Um91bmRCdXR0b24gfSBmcm9tICcuLi8uLi9hdG9tcy9idXR0b24vZmFjdG9yeSc7XG5pbXBvcnQgeyBUZXh0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvdGV4dC90ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25NZXRhZGF0YSB9IGZyb20gJy4uLy4uL3R5cGVzJztcbmltcG9ydCB7IEZpbGVJbnB1dE1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1maWxlLWlucHV0JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0lvbkljb24sIFRleHRDb21wb25lbnQsIEJ1dHRvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImZpbGUtY29udGFpbmVyXCI+XG4gICAgICA8aW5wdXQgc3R5bGU9XCJkaXNwbGF5OiBub25lXCIgdHlwZT1cImZpbGVcIiAoY2hhbmdlKT1cIm9uRmlsZVNlbGVjdGVkKCRldmVudClcIiAjZmlsZUlucHV0IFthY2NlcHRdPVwicHJvcHMuYWNjZXB0XCIgLz5cbiAgICAgIDxkaXYgY2xhc3M9XCJuYW1lLWNvbnRhaW5lclwiPlxuICAgICAgICA8aW9uLWljb24gW25hbWVdPVwic2VsZWN0ZWRGaWxlID8gJ2NoZWNrbWFyay1jaXJjbGUtb3V0bGluZScgOiAnYWxlcnQtY2lyY2xlLW91dGxpbmUnXCI+PC9pb24taWNvbj5cbiAgICAgICAgPHZhbC10ZXh0XG4gICAgICAgICAgc3R5bGU9XCJtYXJnaW4tbGVmdDogNHB4O1wiXG4gICAgICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgICAgIGNvbnRlbnQ6IHNlbGVjdGVkRmlsZSA/IHNlbGVjdGVkRmlsZS5uYW1lIDogKHByb3BzLm5vRmlsZVRleHQgfHwgJ05vIGhhcyBzZWxlY2Npb25hZG8gYXJjaGl2bycpLFxuICAgICAgICAgICAgY29sb3I6ICdkYXJrJyxcbiAgICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgICAgc2l6ZTogJ21lZGl1bScsXG4gICAgICAgICAgfVwiXG4gICAgICAgID48L3ZhbC10ZXh0PlxuICAgICAgPC9kaXY+XG4gICAgICA8dmFsLWJ1dHRvbiBbcHJvcHNdPVwiY29udHJhc3RCdXR0b25cIiAob25DbGljayk9XCJmaWxlSW5wdXQuY2xpY2soKVwiPjwvdmFsLWJ1dHRvbj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS1pbnB1dC5jb21wb25lbnQuc2NzcyddLFxufSlcbi8qKlxuICogdmFsLWZpbGUtaW5wdXRcbiAqXG4gKiBBIGZpbGUgaW5wdXQgY29tcG9uZW50IGZvciB1cGxvYWRpbmcgZmlsZXMsIGludGVncmF0ZWQgd2l0aCBBbmd1bGFyIGZvcm1zLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8dmFsLWZpbGUtaW5wdXQgW3Byb3BzXT1cInsgY29udHJvbDogbXlDb250cm9sLCBhY2NlcHQ6ICdpbWFnZS8qJyB9XCI+PC92YWwtZmlsZS1pbnB1dD5cbiAqXG4gKiBAaW5wdXQgcHJvcHM6IEZpbGVJbnB1dE1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGZpbGUgaW5wdXQgKGZvcm0gY29udHJvbCwgYWNjZXB0IHR5cGVzLCBldGMuKVxuICovXG5leHBvcnQgY2xhc3MgRmlsZUlucHV0Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIElucHV0IGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICAgKiBAdHlwZSB7RmlsZUlucHV0TWV0YWRhdGF9XG4gICAqIEBwcm9wZXJ0eSBjb250cm9sIC0gVGhlIEFuZ3VsYXIgRm9ybUNvbnRyb2wgZm9yIHRoZSBmaWxlIGlucHV0LlxuICAgKiBAcHJvcGVydHkgYWNjZXB0IC0gQWNjZXB0ZWQgZmlsZSB0eXBlcyAoZS5nLiwgJ2ltYWdlLyonLCAnLnBkZicpLlxuICAgKi9cbiAgQElucHV0KCkgcHJvcHM6IEZpbGVJbnB1dE1ldGFkYXRhO1xuXG4gIEBWaWV3Q2hpbGQoJ2ZpbGVJbnB1dCcpIGZpbGVJbnB1dDtcblxuICBjb250cmFzdEJ1dHRvbjogQnV0dG9uTWV0YWRhdGEgPSB7XG4gICAgLi4uUHJpbWFyeVNvbGlkRGVmYXVsdFJvdW5kQnV0dG9uKCdTdWJpciBhcmNoaXZvJyksXG4gICAgY29sb3I6ICdsaWdodCcsXG4gIH07XG4gIHNlbGVjdGVkRmlsZTogRmlsZTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIG9uRmlsZVNlbGVjdGVkKGV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5zZWxlY3RlZEZpbGUgPSBldmVudC50YXJnZXQuZmlsZXNbMF07XG4gICAgdGhpcy5wcm9wcy5jb250cm9sLnNldFZhbHVlKHRoaXMuc2VsZWN0ZWRGaWxlKTtcbiAgfVxuXG4gIHJlc2V0KCk6IHZvaWQge1xuICAgIHRoaXMuc2VsZWN0ZWRGaWxlID0gbnVsbDtcbiAgICB0aGlzLmZpbGVJbnB1dC5uYXRpdmVFbGVtZW50LnZhbHVlID0gJyc7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2ZpbGUtaW5wdXQvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29sb3IgfSBmcm9tICdAaW9uaWMvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRTdGF0ZSB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuLyoqXG4gKiBNZXRhZGF0YSBmb3IgdGhlIGZpbGUgaW5wdXQgY29tcG9uZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZpbGVJbnB1dE1ldGFkYXRhIHtcbiAgLyoqIEZvcm0gY29udHJvbCBmb3IgdGhlIGZpbGUgKHN0b3JlcyBGaWxlIG9iamVjdCkgKi9cbiAgY29udHJvbDogRm9ybUNvbnRyb2w8RmlsZSB8IG51bGw+O1xuICAvKiogVW5pcXVlIHRva2VuIGZvciB0aGUgaW5wdXQgKi9cbiAgdG9rZW4/OiBzdHJpbmc7XG4gIC8qKiBEaXNwbGF5IGxhYmVsICovXG4gIGxhYmVsPzogc3RyaW5nO1xuICAvKiogRmllbGQgbmFtZSAqL1xuICBuYW1lPzogc3RyaW5nO1xuICAvKiogSGVscCB0ZXh0ICovXG4gIGhpbnQ/OiBzdHJpbmc7XG4gIC8qKiBGaWVsZCBzdGF0ZSAqL1xuICBzdGF0ZT86IENvbXBvbmVudFN0YXRlO1xuXG4gIC8vID09PSBGaWxlIGNvbmZpZ3VyYXRpb24gPT09XG4gIC8qKiBBY2NlcHRlZCBmaWxlIHR5cGVzIChlLmcuLCAnaW1hZ2UvKicsICcucGRmLC5kb2MnKSAqL1xuICBhY2NlcHQ/OiBzdHJpbmc7XG4gIC8qKiBBbGxvdyBtdWx0aXBsZSBmaWxlcyAqL1xuICBtdWx0aXBsZT86IGJvb2xlYW47XG4gIC8qKiBNYXhpbXVtIGZpbGUgc2l6ZSBpbiBieXRlcyAqL1xuICBtYXhTaXplPzogbnVtYmVyO1xuICAvKiogTWF4aW11bSBudW1iZXIgb2YgZmlsZXMgKHdoZW4gbXVsdGlwbGUgaXMgdHJ1ZSkgKi9cbiAgbWF4RmlsZXM/OiBudW1iZXI7XG5cbiAgLy8gPT09IExhYmVscyA9PT1cbiAgLyoqIEJ1dHRvbiB0ZXh0IGZvciBzZWxlY3RpbmcgZmlsZSAqL1xuICBidXR0b25UZXh0Pzogc3RyaW5nO1xuICAvKiogVGV4dCBzaG93biB3aGVuIG5vIGZpbGUgaXMgc2VsZWN0ZWQgKi9cbiAgbm9GaWxlVGV4dD86IHN0cmluZztcblxuICAvLyA9PT0gU3R5bGluZyA9PT1cbiAgLyoqIENvbXBvbmVudCBjb2xvciAqL1xuICBjb2xvcj86IENvbG9yO1xuICAvKiogQnV0dG9uIGNvbG9yICovXG4gIGJ1dHRvbkNvbG9yPzogQ29sb3I7XG4gIC8qKiBDdXN0b20gQ1NTIGNsYXNzICovXG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuXG4gIC8vID09PSBSZWFjdGl2ZSBjb250ZW50ID09PVxuICAvKiogQ29udGVudCBrZXkgZm9yIHJlYWN0aXZlIGxhYmVsICovXG4gIGNvbnRlbnRLZXk/OiBzdHJpbmc7XG4gIC8qKiBDb21wb25lbnQgY2xhc3MgbmFtZSBmb3IgY29udGVudCBsb29rdXAgKi9cbiAgY29udGVudENsYXNzPzogc3RyaW5nO1xuICAvKiogRmFsbGJhY2sgdGV4dCBpZiBjb250ZW50IGtleSBpcyBub3QgZm91bmQgKi9cbiAgY29udGVudEZhbGxiYWNrPzogc3RyaW5nO1xuXG4gIC8vID09PSBWYWxpZGF0aW9uIGRpc3BsYXkgPT09XG4gIC8qKiBDdXN0b20gZXJyb3IgbWVzc2FnZXMgKi9cbiAgZXJyb3JzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgLyoqIFNob3cgdmFsaWRhdGlvbiBlcnJvcnMgKi9cbiAgc2hvd0Vycm9ycz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogRXZlbnQgZW1pdHRlZCB3aGVuIGZpbGUgaXMgc2VsZWN0ZWQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZUlucHV0Q2hhbmdlRXZlbnQge1xuICAvKiogU2VsZWN0ZWQgZmlsZSAqL1xuICBmaWxlOiBGaWxlIHwgbnVsbDtcbiAgLyoqIEZpbGUgbmFtZSAqL1xuICBmaWxlTmFtZTogc3RyaW5nIHwgbnVsbDtcbiAgLyoqIEZpbGUgc2l6ZSBpbiBieXRlcyAqL1xuICBmaWxlU2l6ZTogbnVtYmVyIHwgbnVsbDtcbiAgLyoqIEZpbGUgdHlwZS9NSU1FICovXG4gIGZpbGVUeXBlOiBzdHJpbmcgfCBudWxsO1xufVxuXG4vKipcbiAqIEV2ZW50IGVtaXR0ZWQgd2hlbiBtdWx0aXBsZSBmaWxlcyBhcmUgc2VsZWN0ZWQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZXNJbnB1dENoYW5nZUV2ZW50IHtcbiAgLyoqIFNlbGVjdGVkIGZpbGVzICovXG4gIGZpbGVzOiBGaWxlW107XG4gIC8qKiBUb3RhbCBjb3VudCAqL1xuICBjb3VudDogbnVtYmVyO1xuICAvKiogVG90YWwgc2l6ZSBpbiBieXRlcyAqL1xuICB0b3RhbFNpemU6IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -3,6 +3,16 @@ import { ReactiveFormsModule } from '@angular/forms';
|
|
|
3
3
|
import { IonInput, IonLabel } from '@ionic/angular/standalone';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/forms";
|
|
6
|
+
/**
|
|
7
|
+
* val-number-from-to
|
|
8
|
+
*
|
|
9
|
+
* A dual number input for specifying a range (from/to values), integrated with Angular forms.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* <val-number-from-to [props]="{ fromControl: fromCtrl, toControl: toCtrl, min: 0, max: 100 }"></val-number-from-to>
|
|
13
|
+
*
|
|
14
|
+
* @input props: NumberFromToMetadata - Configuration for the number range input.
|
|
15
|
+
*/
|
|
6
16
|
export class NumberFromToComponent {
|
|
7
17
|
constructor() { }
|
|
8
18
|
ngOnInit() {
|
|
@@ -70,8 +80,9 @@ export class NumberFromToComponent {
|
|
|
70
80
|
[formControl]="fromControl"
|
|
71
81
|
type="number"
|
|
72
82
|
[placeholder]="props.fromPlaceholder || props.placeholder"
|
|
73
|
-
[min]="props.
|
|
74
|
-
[max]="props.
|
|
83
|
+
[min]="props.min"
|
|
84
|
+
[max]="props.max"
|
|
85
|
+
[step]="props.step"
|
|
75
86
|
>
|
|
76
87
|
</ion-input>
|
|
77
88
|
|
|
@@ -80,8 +91,9 @@ export class NumberFromToComponent {
|
|
|
80
91
|
[formControl]="toControl"
|
|
81
92
|
type="number"
|
|
82
93
|
[placeholder]="props.toPlaceholder || props.placeholder"
|
|
83
|
-
[min]="props.
|
|
84
|
-
[max]="props.
|
|
94
|
+
[min]="props.min"
|
|
95
|
+
[max]="props.max"
|
|
96
|
+
[step]="props.step"
|
|
85
97
|
>
|
|
86
98
|
</ion-input>
|
|
87
99
|
</div>
|
|
@@ -96,8 +108,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
96
108
|
[formControl]="fromControl"
|
|
97
109
|
type="number"
|
|
98
110
|
[placeholder]="props.fromPlaceholder || props.placeholder"
|
|
99
|
-
[min]="props.
|
|
100
|
-
[max]="props.
|
|
111
|
+
[min]="props.min"
|
|
112
|
+
[max]="props.max"
|
|
113
|
+
[step]="props.step"
|
|
101
114
|
>
|
|
102
115
|
</ion-input>
|
|
103
116
|
|
|
@@ -106,8 +119,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
106
119
|
[formControl]="toControl"
|
|
107
120
|
type="number"
|
|
108
121
|
[placeholder]="props.toPlaceholder || props.placeholder"
|
|
109
|
-
[min]="props.
|
|
110
|
-
[max]="props.
|
|
122
|
+
[min]="props.min"
|
|
123
|
+
[max]="props.max"
|
|
124
|
+
[step]="props.step"
|
|
111
125
|
>
|
|
112
126
|
</ion-input>
|
|
113
127
|
</div>
|
|
@@ -115,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
115
129
|
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
116
130
|
type: Input
|
|
117
131
|
}] } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-from-to.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/number-from-to/number-from-to.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { IonInput, IonLabel } from '@ionic/angular/standalone';\nimport { NumberFromToMetadata } from './types';\n\n@Component({\n  selector: 'val-number-from-to',\n  standalone: true,\n  imports: [ReactiveFormsModule, IonInput, IonLabel],\n  template: `\n    <div class=\"number-from-to-container\">\n      <ion-label position=\"stacked\">{{ props.fromLabel || 'Inicial' }}</ion-label>\n      <ion-input\n        [formControl]=\"fromControl\"\n        type=\"number\"\n        [placeholder]=\"props.fromPlaceholder || props.placeholder\"\n        [min]=\"props.min\"\n        [max]=\"props.max\"\n        [step]=\"props.step\"\n      >\n      </ion-input>\n\n      <ion-label position=\"stacked\">{{ props.toLabel || 'Final' }}</ion-label>\n      <ion-input\n        [formControl]=\"toControl\"\n        type=\"number\"\n        [placeholder]=\"props.toPlaceholder || props.placeholder\"\n        [min]=\"props.min\"\n        [max]=\"props.max\"\n        [step]=\"props.step\"\n      >\n      </ion-input>\n    </div>\n  `,\n  styleUrls: ['./number-from-to.component.scss'],\n})\n/**\n * val-number-from-to\n *\n * A dual number input for specifying a range (from/to values), integrated with Angular forms.\n *\n * @example\n * <val-number-from-to [props]=\"{ fromControl: fromCtrl, toControl: toCtrl, min: 0, max: 100 }\"></val-number-from-to>\n *\n * @input props: NumberFromToMetadata - Configuration for the number range input.\n */\nexport class NumberFromToComponent implements OnInit {\n  /**\n   * Input configuration object.\n   * @type {NumberFromToMetadata}\n   * @property fromControl - The Angular FormControl for the \"from\" value.\n   * @property toControl - The Angular FormControl for the \"to\" value.\n   */\n  @Input() props: NumberFromToMetadata;\n\n  constructor() {}\n\n  ngOnInit() {\n    // Apply default values if configured\n    if (this.props?.withDefault || this.props?.value) {\n      this.applyDefaultValues();\n    }\n  }\n\n  private applyDefaultValues() {\n    const defaultValue = this.resolveDefaultValue();\n    if (defaultValue !== null) {\n      if (typeof defaultValue === 'object' && defaultValue.from !== undefined) {\n        this.fromControl?.setValue(defaultValue.from);\n        this.toControl?.setValue(defaultValue.to);\n      } else {\n        // Si es un valor simple, aplicarlo a ambos controles\n        this.fromControl?.setValue(defaultValue);\n        this.toControl?.setValue(defaultValue);\n      }\n      this.fromControl?.markAsPristine();\n      this.toControl?.markAsPristine();\n      this.fromControl?.updateValueAndValidity();\n      this.toControl?.updateValueAndValidity();\n    }\n  }\n\n  private resolveDefaultValue(): any {\n    // Explicit value takes precedence\n    if (this.props.value !== undefined && this.props.value !== null && this.props.value !== '') {\n      return this.parseValue(this.props.value);\n    }\n\n    // No default configuration\n    if (!this.props.withDefault) {\n      return null;\n    }\n\n    // Custom default value\n    if (typeof this.props.withDefault === 'string') {\n      return this.parseValue(this.props.withDefault);\n    }\n\n    // Auto default value (withDefault === true)\n    return { from: 0, to: 0 };\n  }\n\n  private parseValue(value: string): any {\n    try {\n      // Try to parse as JSON first (for object values)\n      return JSON.parse(value);\n    } catch {\n      // If not JSON, treat as number\n      const numValue = parseFloat(value) || 0;\n      return { from: numValue, to: numValue };\n    }\n  }\n\n  get fromControl(): FormControl {\n    return this.props.fromControl;\n  }\n\n  get toControl(): FormControl {\n    return this.props.toControl;\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL251bWJlci1mcm9tLXRvL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbG9yIH0gZnJvbSAnQGlvbmljL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50U3RhdGUgfSBmcm9tICcuLi8uLi90eXBlcyc7XG5cbi8qKlxuICogTnVtYmVyIHJhbmdlIHZhbHVlIHdpdGggZnJvbSBhbmQgdG8uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyRnJvbVRvVmFsdWUge1xuICAvKiogU3RhcnRpbmcgdmFsdWUgKi9cbiAgZnJvbTogbnVtYmVyIHwgbnVsbDtcbiAgLyoqIEVuZGluZyB2YWx1ZSAqL1xuICB0bzogbnVtYmVyIHwgbnVsbDtcbn1cblxuLyoqXG4gKiBNZXRhZGF0YSBmb3IgdGhlIG51bWJlciBmcm9tLXRvIGlucHV0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOdW1iZXJGcm9tVG9NZXRhZGF0YSB7XG4gIC8qKiBNYWluIGZvcm0gY29udHJvbCAob3B0aW9uYWwsIHN0b3JlcyBjb21iaW5lZCB2YWx1ZSkgKi9cbiAgY29udHJvbD86IEZvcm1Db250cm9sPE51bWJlckZyb21Ub1ZhbHVlIHwgbnVsbD47XG4gIC8qKiBGb3JtIGNvbnRyb2wgZm9yIFwiZnJvbVwiIHZhbHVlIChyZXF1aXJlZCBmb3Igc3RhbmRhbG9uZSB1c2UpICovXG4gIGZyb21Db250cm9sPzogRm9ybUNvbnRyb2w8bnVtYmVyIHwgbnVsbD47XG4gIC8qKiBGb3JtIGNvbnRyb2wgZm9yIFwidG9cIiB2YWx1ZSAocmVxdWlyZWQgZm9yIHN0YW5kYWxvbmUgdXNlKSAqL1xuICB0b0NvbnRyb2w/OiBGb3JtQ29udHJvbDxudW1iZXIgfCBudWxsPjtcbiAgLyoqIFVuaXF1ZSB0b2tlbiBmb3IgdGhlIGlucHV0ICovXG4gIHRva2VuPzogc3RyaW5nO1xuICAvKiogRGlzcGxheSBsYWJlbCAqL1xuICBsYWJlbD86IHN0cmluZztcbiAgLyoqIEZpZWxkIG5hbWUgKi9cbiAgbmFtZT86IHN0cmluZztcbiAgLyoqIEhlbHAgdGV4dCAqL1xuICBoaW50Pzogc3RyaW5nO1xuICAvKiogRmllbGQgc3RhdGUgKi9cbiAgc3RhdGU/OiBDb21wb25lbnRTdGF0ZTtcblxuICAvLyA9PT0gTGFiZWxzID09PVxuICAvKiogTGFiZWwgZm9yIFwiZnJvbVwiIGZpZWxkICovXG4gIGZyb21MYWJlbD86IHN0cmluZztcbiAgLyoqIExhYmVsIGZvciBcInRvXCIgZmllbGQgKi9cbiAgdG9MYWJlbD86IHN0cmluZztcbiAgLyoqIFBsYWNlaG9sZGVyIGZvciBtYWluIGlucHV0ICovXG4gIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICAvKiogUGxhY2Vob2xkZXIgZm9yIFwiZnJvbVwiIGZpZWxkICovXG4gIGZyb21QbGFjZWhvbGRlcj86IHN0cmluZztcbiAgLyoqIFBsYWNlaG9sZGVyIGZvciBcInRvXCIgZmllbGQgKi9cbiAgdG9QbGFjZWhvbGRlcj86IHN0cmluZztcblxuICAvLyA9PT0gUmFuZ2UgY29uZmlndXJhdGlvbiA9PT1cbiAgLyoqIE1pbmltdW0gdmFsdWUgKi9cbiAgbWluPzogbnVtYmVyO1xuICAvKiogTWF4aW11bSB2YWx1ZSAqL1xuICBtYXg/OiBudW1iZXI7XG4gIC8qKiBTdGVwIGluY3JlbWVudCAqL1xuICBzdGVwPzogbnVtYmVyO1xuXG4gIC8vID09PSBTdHlsaW5nID09PVxuICAvKiogQ29tcG9uZW50IGNvbG9yICovXG4gIGNvbG9yPzogQ29sb3I7XG4gIC8qKiBDdXN0b20gQ1NTIGNsYXNzICovXG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuXG4gIC8vID09PSBEZWZhdWx0IHZhbHVlID09PVxuICAvKiogSW5pdGlhbCB2YWx1ZSBmb3IgdGhlIGZpZWxkICovXG4gIHZhbHVlPzogc3RyaW5nO1xuICAvKiogRGVmYXVsdCB2YWx1ZSBjb25maWd1cmF0aW9uIC0gc3RyaW5nIGZvciBjdXN0b20gZGVmYXVsdHMsIHRydWUgZm9yIGF1dG8gZGVmYXVsdHMgKi9cbiAgd2l0aERlZmF1bHQ/OiBzdHJpbmcgfCBib29sZWFuO1xuXG4gIC8vID09PSBSZWFjdGl2ZSBjb250ZW50ID09PVxuICAvKiogQ29udGVudCBrZXkgZm9yIHJlYWN0aXZlIGxhYmVsICovXG4gIGNvbnRlbnRLZXk/OiBzdHJpbmc7XG4gIC8qKiBDb21wb25lbnQgY2xhc3MgbmFtZSBmb3IgY29udGVudCBsb29rdXAgKi9cbiAgY29udGVudENsYXNzPzogc3RyaW5nO1xuICAvKiogRmFsbGJhY2sgdGV4dCBpZiBjb250ZW50IGtleSBpcyBub3QgZm91bmQgKi9cbiAgY29udGVudEZhbGxiYWNrPzogc3RyaW5nO1xuXG4gIC8vID09PSBWYWxpZGF0aW9uIGRpc3BsYXkgPT09XG4gIC8qKiBDdXN0b20gZXJyb3IgbWVzc2FnZXMgKi9cbiAgZXJyb3JzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgLyoqIFNob3cgdmFsaWRhdGlvbiBlcnJvcnMgKi9cbiAgc2hvd0Vycm9ycz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogRXZlbnQgZW1pdHRlZCB3aGVuIG51bWJlciByYW5nZSBjaGFuZ2VzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE51bWJlckZyb21Ub0NoYW5nZUV2ZW50IHtcbiAgLyoqIE51bWJlciByYW5nZSB2YWx1ZSAqL1xuICB2YWx1ZTogTnVtYmVyRnJvbVRvVmFsdWU7XG4gIC8qKiBXaGV0aGVyIHRoZSByYW5nZSBpcyB2YWxpZCAoZnJvbSA8PSB0bykgKi9cbiAgaXNWYWxpZDogYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -10,7 +10,7 @@ import * as i1 from "ng-otp-input";
|
|
|
10
10
|
* @example
|
|
11
11
|
* <val-pin-input [props]="{ control: myControl }"></val-pin-input>
|
|
12
12
|
*
|
|
13
|
-
* @input props:
|
|
13
|
+
* @input props: PinInputMetadata - Configuration for the PIN input (form control, length, etc.)
|
|
14
14
|
*/
|
|
15
15
|
export class PinInputComponent {
|
|
16
16
|
constructor() {
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
52
52
|
}], props: [{
|
|
53
53
|
type: Input
|
|
54
54
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGluLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvcGluLWlucHV0L3Bpbi1pbnB1dC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxtQkFBbUIsRUFBb0IsZ0JBQWdCLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQWN2Rjs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLE9BQU8saUJBQWlCO0lBdUI1QjtRQVpBLGVBQVUsR0FBRyxDQUFDLENBQUM7UUFDZixtQkFBYyxHQUFxQjtZQUNqQyxXQUFXLEVBQUU7Z0JBQ1gsV0FBVyxFQUFFLE1BQU07Z0JBQ25CLEtBQUssRUFBRSxNQUFNO2dCQUNiLE1BQU0sRUFBRSxNQUFNO2FBQ2Y7WUFDRCxVQUFVLEVBQUUsZUFBZTtZQUMzQixNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDdkIsZ0JBQWdCLEVBQUUsSUFBSTtTQUN2QixDQUFDO0lBRWEsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLEtBQUs7UUFDSCxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQzsrR0EvQlUsaUJBQWlCO21HQUFqQixpQkFBaUIsOElBQ2pCLG1CQUFtQixnREFsQnBCOzs7O0dBSVQscXpGQUxTLGdCQUFnQjs7NEZBa0JmLGlCQUFpQjtrQkFyQjdCLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLGdCQUFnQixDQUFDLFlBQ2pCOzs7O0dBSVQ7d0RBY2tELE9BQU87c0JBQXpELFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO2dCQVF4QyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdHBJbnB1dENvbXBvbmVudCwgTmdPdHBJbnB1dENvbmZpZywgTmdPdHBJbnB1dE1vZHVsZSB9IGZyb20gJ25nLW90cC1pbnB1dCc7XG5pbXBvcnQgeyBQaW5JbnB1dE1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1waW4taW5wdXQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdPdHBJbnB1dE1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cIm90cFwiPlxuICAgICAgPG5nLW90cC1pbnB1dCBbZm9ybUN0cmxdPVwicHJvcHMuY29udHJvbFwiIFtjb25maWddPVwib3RwSW5wdXRDb25maWdcIj48L25nLW90cC1pbnB1dD5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vcGluLWlucHV0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtcGluLWlucHV0XG4gKlxuICogQSBQSU4gY29kZSBpbnB1dCB1c2luZyBuZy1vdHAtaW5wdXQsIGludGVncmF0ZWQgd2l0aCBBbmd1bGFyIGZvcm1zLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8dmFsLXBpbi1pbnB1dCBbcHJvcHNdPVwieyBjb250cm9sOiBteUNvbnRyb2wgfVwiPjwvdmFsLXBpbi1pbnB1dD5cbiAqXG4gKiBAaW5wdXQgcHJvcHM6IFBpbklucHV0TWV0YWRhdGEgLSBDb25maWd1cmF0aW9uIGZvciB0aGUgUElOIGlucHV0IChmb3JtIGNvbnRyb2wsIGxlbmd0aCwgZXRjLilcbiAqL1xuZXhwb3J0IGNsYXNzIFBpbklucHV0Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQFZpZXdDaGlsZChOZ090cElucHV0Q29tcG9uZW50LCB7IHN0YXRpYzogZmFsc2UgfSkgcGluQ29kZTogTmdPdHBJbnB1dENvbXBvbmVudCB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogSW5wdXQgY29uZmlndXJhdGlvbiBvYmplY3QuXG4gICAqIEB0eXBlIHtQaW5JbnB1dE1ldGFkYXRhfVxuICAgKiBAcHJvcGVydHkgY29udHJvbCAtIFRoZSBBbmd1bGFyIEZvcm1Db250cm9sIGZvciB0aGUgUElOIGlucHV0LlxuICAgKiBAcHJvcGVydHkgbGVuZ3RoIC0gTnVtYmVyIG9mIGRpZ2l0cyBpbiBQSU4gKGRlZmF1bHQ6IDUpLlxuICAgKi9cbiAgQElucHV0KCkgcHJvcHM6IFBpbklucHV0TWV0YWRhdGE7XG5cbiAgY29kZUxlbmd0aCA9IDU7XG4gIG90cElucHV0Q29uZmlnOiBOZ090cElucHV0Q29uZmlnID0ge1xuICAgIGlucHV0U3R5bGVzOiB7XG4gICAgICAnZm9udC1zaXplJzogJzMycHgnLFxuICAgICAgd2lkdGg6ICc1OHB4JyxcbiAgICAgIGhlaWdodDogJzYwcHgnLFxuICAgIH0sXG4gICAgaW5wdXRDbGFzczogJ290cC1pbnB1dC1ib3gnLFxuICAgIGxlbmd0aDogdGhpcy5jb2RlTGVuZ3RoLFxuICAgIGFsbG93TnVtYmVyc09ubHk6IHRydWUsXG4gIH07XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICByZXNldCgpIHtcbiAgICBpZiAodGhpcy5waW5Db2RlKSB7XG4gICAgICB0aGlzLnBpbkNvZGUuc2V0VmFsdWUoJycpO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3Bpbi1pbnB1dC90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBDb2xvciB9IGZyb20gJ0Bpb25pYy9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG4vKipcbiAqIE1ldGFkYXRhIGZvciB0aGUgUElOIGlucHV0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQaW5JbnB1dE1ldGFkYXRhIHtcbiAgLyoqIEZvcm0gY29udHJvbCBmb3IgdGhlIFBJTiB2YWx1ZSAoc3RvcmVzIHN0cmluZykgKi9cbiAgY29udHJvbDogRm9ybUNvbnRyb2w8c3RyaW5nIHwgbnVsbD47XG4gIC8qKiBVbmlxdWUgdG9rZW4gZm9yIHRoZSBpbnB1dCAqL1xuICB0b2tlbj86IHN0cmluZztcbiAgLyoqIERpc3BsYXkgbGFiZWwgKi9cbiAgbGFiZWw/OiBzdHJpbmc7XG4gIC8qKiBGaWVsZCBuYW1lICovXG4gIG5hbWU/OiBzdHJpbmc7XG4gIC8qKiBIZWxwIHRleHQgKi9cbiAgaGludD86IHN0cmluZztcbiAgLyoqIEZpZWxkIHN0YXRlICovXG4gIHN0YXRlPzogQ29tcG9uZW50U3RhdGU7XG5cbiAgLy8gPT09IFBJTiBjb25maWd1cmF0aW9uID09PVxuICAvKiogTnVtYmVyIG9mIGRpZ2l0cyBpbiBQSU4gKGRlZmF1bHQ6IDUpICovXG4gIGxlbmd0aD86IG51bWJlcjtcbiAgLyoqIEFsbG93IG9ubHkgbnVtYmVycyAqL1xuICBhbGxvd051bWJlcnNPbmx5PzogYm9vbGVhbjtcbiAgLyoqIE1hc2sgaW5wdXQgKHNob3cgZG90cyBpbnN0ZWFkIG9mIGNoYXJhY3RlcnMpICovXG4gIG1hc2s/OiBib29sZWFuO1xuICAvKiogTWFzayBjaGFyYWN0ZXIgdG8gZGlzcGxheSAqL1xuICBtYXNrQ2hhcj86IHN0cmluZztcbiAgLyoqIERpc2FibGUgcGFzdGUgZnVuY3Rpb25hbGl0eSAqL1xuICBkaXNhYmxlUGFzdGU/OiBib29sZWFuO1xuICAvKiogQXV0byBmb2N1cyBmaXJzdCBpbnB1dCAqL1xuICBhdXRvRm9jdXM/OiBib29sZWFuO1xuICAvKiogQXV0byBzdWJtaXQgd2hlbiBjb21wbGV0ZSAqL1xuICBhdXRvU3VibWl0PzogYm9vbGVhbjtcblxuICAvLyA9PT0gU3R5bGluZyA9PT1cbiAgLyoqIENvbXBvbmVudCBjb2xvciAqL1xuICBjb2xvcj86IENvbG9yO1xuICAvKiogQ3VzdG9tIENTUyBjbGFzcyAqL1xuICBjc3NDbGFzcz86IHN0cmluZztcbiAgLyoqIElucHV0IGJveCBzdHlsZXMgKi9cbiAgaW5wdXRTdHlsZXM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuICAvKiogSW5wdXQgYm94IGNsYXNzICovXG4gIGlucHV0Q2xhc3M/OiBzdHJpbmc7XG5cbiAgLy8gPT09IFJlYWN0aXZlIGNvbnRlbnQgPT09XG4gIC8qKiBDb250ZW50IGtleSBmb3IgcmVhY3RpdmUgbGFiZWwgKi9cbiAgY29udGVudEtleT86IHN0cmluZztcbiAgLyoqIENvbXBvbmVudCBjbGFzcyBuYW1lIGZvciBjb250ZW50IGxvb2t1cCAqL1xuICBjb250ZW50Q2xhc3M/OiBzdHJpbmc7XG4gIC8qKiBGYWxsYmFjayB0ZXh0IGlmIGNvbnRlbnQga2V5IGlzIG5vdCBmb3VuZCAqL1xuICBjb250ZW50RmFsbGJhY2s/OiBzdHJpbmc7XG5cbiAgLy8gPT09IFZhbGlkYXRpb24gZGlzcGxheSA9PT1cbiAgLyoqIEN1c3RvbSBlcnJvciBtZXNzYWdlcyAqL1xuICBlcnJvcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuICAvKiogU2hvdyB2YWxpZGF0aW9uIGVycm9ycyAqL1xuICBzaG93RXJyb3JzPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBFdmVudCBlbWl0dGVkIHdoZW4gUElOIGlucHV0IGNoYW5nZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGluSW5wdXRDaGFuZ2VFdmVudCB7XG4gIC8qKiBDdXJyZW50IFBJTiB2YWx1ZSAqL1xuICB2YWx1ZTogc3RyaW5nO1xuICAvKiogV2hldGhlciB0aGUgUElOIGlzIGNvbXBsZXRlICovXG4gIGlzQ29tcGxldGU6IGJvb2xlYW47XG4gIC8qKiBOdW1iZXIgb2YgZGlnaXRzIGVudGVyZWQgKi9cbiAgbGVuZ3RoOiBudW1iZXI7XG59XG4iXX0=
|
|
@@ -35,6 +35,9 @@ export class FormComponent {
|
|
|
35
35
|
this.onSelectChange = new EventEmitter();
|
|
36
36
|
this.types = InputType;
|
|
37
37
|
this.subscriptions = [];
|
|
38
|
+
// Cache para evitar crear nuevos objetos en cada ciclo de change detection
|
|
39
|
+
this.fieldPropsCache = new Map();
|
|
40
|
+
this.actionsCache = [];
|
|
38
41
|
}
|
|
39
42
|
ngOnInit() {
|
|
40
43
|
const formControls = {};
|
|
@@ -61,6 +64,86 @@ export class FormComponent {
|
|
|
61
64
|
this.trackSelectChanges(field.name);
|
|
62
65
|
});
|
|
63
66
|
});
|
|
67
|
+
// Construir cache inicial
|
|
68
|
+
this.rebuildFieldPropsCache();
|
|
69
|
+
this.updateActionsCache();
|
|
70
|
+
this.previousState = this.props.state;
|
|
71
|
+
}
|
|
72
|
+
ngOnChanges(changes) {
|
|
73
|
+
// Cuando props cambia, reconstruir el cache
|
|
74
|
+
if (changes['props'] && this.form) {
|
|
75
|
+
this.rebuildFieldPropsCache();
|
|
76
|
+
this.updateActionsCache();
|
|
77
|
+
this.previousState = this.props.state;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
ngDoCheck() {
|
|
81
|
+
// Detectar cambios en el estado del formulario (mutación sin cambiar referencia)
|
|
82
|
+
if (this.form && this.props && this.props.state !== this.previousState) {
|
|
83
|
+
this.previousState = this.props.state;
|
|
84
|
+
this.updateActionsCache();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Reconstruye el cache de props para cada field.
|
|
89
|
+
* Esto evita crear nuevos objetos en cada ciclo de change detection.
|
|
90
|
+
*/
|
|
91
|
+
rebuildFieldPropsCache() {
|
|
92
|
+
this.fieldPropsCache.clear();
|
|
93
|
+
this.props.sections.forEach(section => {
|
|
94
|
+
section.fields.forEach(field => {
|
|
95
|
+
const token = field.token || `input-${field.type}-${field.name}`;
|
|
96
|
+
if (field.type === this.types.NUMBER_FROM_TO) {
|
|
97
|
+
const fromControl = this.getControl(`${field.name}_from`);
|
|
98
|
+
const toControl = this.getControl(`${field.name}_to`);
|
|
99
|
+
if (field.state === ComponentStates.DISABLED) {
|
|
100
|
+
fromControl.disable({ emitEvent: false });
|
|
101
|
+
toControl.disable({ emitEvent: false });
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
fromControl.enable({ emitEvent: false });
|
|
105
|
+
toControl.enable({ emitEvent: false });
|
|
106
|
+
}
|
|
107
|
+
this.fieldPropsCache.set(field.name, {
|
|
108
|
+
...field,
|
|
109
|
+
token,
|
|
110
|
+
fromControl,
|
|
111
|
+
toControl,
|
|
112
|
+
control: undefined,
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
const control = this.getControl(field.name);
|
|
117
|
+
if (field.state === ComponentStates.DISABLED) {
|
|
118
|
+
control.disable({ emitEvent: false });
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
control.enable({ emitEvent: false });
|
|
122
|
+
}
|
|
123
|
+
this.fieldPropsCache.set(field.name, {
|
|
124
|
+
...field,
|
|
125
|
+
token,
|
|
126
|
+
control,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Actualiza el cache de actions basado en el estado actual del form.
|
|
134
|
+
*/
|
|
135
|
+
updateActionsCache() {
|
|
136
|
+
let actionState = this.props.actions.state;
|
|
137
|
+
if (this.props.state === ComponentStates.WORKING) {
|
|
138
|
+
actionState = ComponentStates.WORKING;
|
|
139
|
+
}
|
|
140
|
+
else if (this.props.state === ComponentStates.DISABLED) {
|
|
141
|
+
actionState = ComponentStates.DISABLED;
|
|
142
|
+
}
|
|
143
|
+
else if (this.props.state === ComponentStates.ENABLED || this.form?.valid) {
|
|
144
|
+
actionState = ComponentStates.ENABLED;
|
|
145
|
+
}
|
|
146
|
+
this.actionsCache = [{ ...this.props.actions, state: actionState }];
|
|
64
147
|
}
|
|
65
148
|
ngOnDestroy() {
|
|
66
149
|
// Cleanup subscriptions to avoid memory leaks
|
|
@@ -80,40 +163,49 @@ export class FormComponent {
|
|
|
80
163
|
return this.Form.get(field);
|
|
81
164
|
}
|
|
82
165
|
getFieldProp(field) {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
166
|
+
// Retornar del cache para evitar crear nuevos objetos en cada ciclo de change detection
|
|
167
|
+
const cached = this.fieldPropsCache.get(field.name);
|
|
168
|
+
if (cached) {
|
|
169
|
+
return cached;
|
|
86
170
|
}
|
|
171
|
+
// Fallback: generar y cachear si no existe (no debería ocurrir normalmente)
|
|
172
|
+
const token = field.token || `input-${field.type}-${field.name}`;
|
|
87
173
|
if (field.type === this.types.NUMBER_FROM_TO) {
|
|
88
174
|
const fromControl = this.getControl(`${field.name}_from`);
|
|
89
175
|
const toControl = this.getControl(`${field.name}_to`);
|
|
90
176
|
if (field.state === ComponentStates.DISABLED) {
|
|
91
|
-
fromControl.disable();
|
|
92
|
-
toControl.disable();
|
|
177
|
+
fromControl.disable({ emitEvent: false });
|
|
178
|
+
toControl.disable({ emitEvent: false });
|
|
93
179
|
}
|
|
94
180
|
else {
|
|
95
|
-
fromControl.enable();
|
|
96
|
-
toControl.enable();
|
|
181
|
+
fromControl.enable({ emitEvent: false });
|
|
182
|
+
toControl.enable({ emitEvent: false });
|
|
97
183
|
}
|
|
98
|
-
|
|
184
|
+
const props = {
|
|
99
185
|
...field,
|
|
186
|
+
token,
|
|
100
187
|
fromControl,
|
|
101
188
|
toControl,
|
|
102
|
-
control: undefined,
|
|
189
|
+
control: undefined,
|
|
103
190
|
};
|
|
191
|
+
this.fieldPropsCache.set(field.name, props);
|
|
192
|
+
return props;
|
|
104
193
|
}
|
|
105
194
|
else {
|
|
106
195
|
const control = this.getControl(field.name);
|
|
107
196
|
if (field.state === ComponentStates.DISABLED) {
|
|
108
|
-
control.disable();
|
|
197
|
+
control.disable({ emitEvent: false });
|
|
109
198
|
}
|
|
110
199
|
else {
|
|
111
|
-
control.enable();
|
|
200
|
+
control.enable({ emitEvent: false });
|
|
112
201
|
}
|
|
113
|
-
|
|
202
|
+
const props = {
|
|
114
203
|
...field,
|
|
204
|
+
token,
|
|
115
205
|
control,
|
|
116
206
|
};
|
|
207
|
+
this.fieldPropsCache.set(field.name, props);
|
|
208
|
+
return props;
|
|
117
209
|
}
|
|
118
210
|
}
|
|
119
211
|
get isAtEndOfForm() {
|
|
@@ -129,25 +221,11 @@ export class FormComponent {
|
|
|
129
221
|
};
|
|
130
222
|
}
|
|
131
223
|
get actions() {
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
}
|
|
135
|
-
if (this.form.valid) {
|
|
136
|
-
this.props.actions.state = ComponentStates.ENABLED;
|
|
137
|
-
}
|
|
138
|
-
if (this.props.state === ComponentStates.WORKING) {
|
|
139
|
-
this.props.actions.state = ComponentStates.WORKING;
|
|
140
|
-
}
|
|
141
|
-
if (this.props.state === ComponentStates.ENABLED) {
|
|
142
|
-
this.props.actions.state = ComponentStates.ENABLED;
|
|
143
|
-
}
|
|
144
|
-
if (this.props.state === ComponentStates.DISABLED) {
|
|
145
|
-
this.props.actions.state = ComponentStates.DISABLED;
|
|
146
|
-
}
|
|
147
|
-
return [this.props.actions];
|
|
224
|
+
// Retornar del cache para evitar crear nuevos objetos en cada ciclo de change detection
|
|
225
|
+
return this.actionsCache;
|
|
148
226
|
}
|
|
149
227
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
150
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormComponent, isStandalone: true, selector: "val-form", inputs: { props: "props" }, outputs: { onSubmit: "onSubmit", onInvalid: "onInvalid", onSelectChange: "onSelectChange" }, ngImport: i0, template: `
|
|
228
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormComponent, isStandalone: true, selector: "val-form", inputs: { props: "props" }, outputs: { onSubmit: "onSubmit", onInvalid: "onInvalid", onSelectChange: "onSelectChange" }, usesOnChanges: true, ngImport: i0, template: `
|
|
151
229
|
<div class="container">
|
|
152
230
|
<form [formGroup]="form">
|
|
153
231
|
<val-display
|
|
@@ -326,4 +404,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
326
404
|
}], onSelectChange: [{
|
|
327
405
|
type: Output
|
|
328
406
|
}] } });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { isAtEnd } from '../../../shared/utils/dom';\nimport { DisplayComponent } from '../../atoms/display/display.component';\nimport { DividerComponent } from '../../atoms/divider/divider.component';\nimport { TitleComponent } from '../../atoms/title/title.component';\nimport { ButtonGroupComponent } from '../../molecules/button-group/button-group.component';\nimport { CheckInputComponent } from '../../molecules/check-input/check-input.component';\nimport { CommentInputComponent } from '../../molecules/comment-input/comment-input.component';\nimport { DateInputComponent } from '../../molecules/date-input/date-input.component';\nimport { EmailInputComponent } from '../../molecules/email-input/email-input.component';\nimport { FileInputComponent } from '../../molecules/file-input/file-input.component';\nimport { HintComponent } from '../../molecules/hint/hint.component';\nimport { HourInputComponent } from '../../molecules/hour-input/hour-input.component';\nimport { NumberInputComponent } from '../../molecules/number-input/number-input.component';\nimport { NumberFromToComponent } from '../../molecules/number-from-to/number-from-to.component';\nimport { PasswordInputComponent } from '../../molecules/password-input/password-input.component';\nimport { PinInputComponent } from '../../molecules/pin-input/pin-input.component';\nimport { RadioInputComponent } from '../../molecules/radio-input/radio-input.component';\nimport { SearchSelectorComponent } from '../../molecules/select-input/select-input.component';\nimport { SelectSearchComponent } from '../../molecules/select-search/select-search.component';\nimport { MultiSelectSearchComponent } from '../../molecules/multi-select-search/multi-select-search.component';\nimport { TextInputComponent } from '../../molecules/text-input/text-input.component';\nimport { ButtonMetadata, ComponentStates, FormMetadata, FormSubmit, InputMetadata, InputType } from '../../types';\n\n@Component({\n  selector: 'val-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    DisplayComponent,\n    TitleComponent,\n    TextInputComponent,\n    CheckInputComponent,\n    ButtonGroupComponent,\n    DividerComponent,\n    HintComponent,\n    CommentInputComponent,\n    DateInputComponent,\n    FileInputComponent,\n    HourInputComponent,\n    EmailInputComponent,\n    NumberInputComponent,\n    NumberFromToComponent,\n    RadioInputComponent,\n    PasswordInputComponent,\n    PinInputComponent,\n    SelectSearchComponent,\n    MultiSelectSearchComponent,\n    SearchSelectorComponent,\n  ],\n  template: `\n    <div class=\"container\">\n      <form [formGroup]=\"form\">\n        <val-display\n          *ngIf=\"props.name\"\n          [props]=\"{\n            content: props.name,\n            color: 'dark',\n            size: 'large',\n          }\"\n        ></val-display>\n        <div class=\"section\" *ngFor=\"let s of props.sections\">\n          <val-title [props]=\"{ content: s.name, size: 'large', color: '', bold: false }\"></val-title>\n          <div class=\"input\" *ngFor=\"let f of s.fields\">\n            <val-title [props]=\"{ content: f.label, size: 'small', color: 'dark', bold: false }\"></val-title>\n            <ng-container *ngIf=\"f.type === types.TEXT\">\n              <val-text-input [props]=\"getFieldProp(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 [props]=\"getFieldProp(f)\"></val-comment-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.DATE\">\n              <val-date-input [props]=\"getFieldProp(f)\"></val-date-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.EMAIL\">\n              <val-email-input [props]=\"getFieldProp(f)\"></val-email-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.FILE\">\n              <val-file-input [props]=\"getFieldProp(f)\"></val-file-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.HOUR\">\n              <val-hour-input [props]=\"getFieldProp(f)\"></val-hour-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.NUMBER\">\n              <val-number-input [props]=\"getFieldProp(f)\"></val-number-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.NUMBER_FROM_TO\">\n              <val-number-from-to [props]=\"getFieldProp(f)\"></val-number-from-to>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.PASSWORD\">\n              <val-password-input [props]=\"getFieldProp(f)\"></val-password-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.PIN_CODE\">\n              <val-pin-input [props]=\"getFieldProp(f)\"></val-pin-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.RADIO\">\n              <val-radio-input [props]=\"getFieldProp(f)\"></val-radio-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.SELECT\">\n              <val-select-input [props]=\"getFieldProp(f)\"></val-select-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.SEARCH_SELECT\">\n              <val-select-search [props]=\"getFieldProp(f)\"></val-select-search>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.MULTI_SELECT\">\n              <val-multi-select-search [props]=\"getFieldProp(f)\"></val-multi-select-search>\n            </ng-container>\n            <val-hint [props]=\"getFieldProp(f)\"></val-hint>\n          </div>\n          <val-divider [props]=\"{ fill: 'solid', size: 'medium', color: 'medium' }\"></val-divider>\n          <ng-content></ng-content>\n        </div>\n        <val-button-group\n          [props]=\"{ buttons: actions, position: 'center', columned: false }\"\n          (onClick)=\"submitHandler($event)\"\n        ></val-button-group>\n      </form>\n    </div>\n  `,\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  @Output()\n  onSelectChange = new EventEmitter<{ field: string; value: any }>();\n\n  form: FormGroup;\n  types = InputType;\n  private subscriptions: Subscription[] = [];\n\n  constructor(\n    private fb: FormBuilder,\n    private elementRef: ElementRef\n  ) {}\n\n  ngOnInit() {\n    const formControls = {};\n    this.props.sections.forEach(section => {\n      section.fields.forEach(field => {\n        if (field.type === this.types.NUMBER_FROM_TO) {\n          // Crear dos controles para campos NUMBER_FROM_TO\n          formControls[`${field.name}_from`] = [undefined, field.validators || []];\n          formControls[`${field.name}_to`] = [undefined, field.validators || []];\n        } else {\n          formControls[field.name] = [undefined, field.validators || []];\n        }\n      });\n    });\n    this.form = this.fb.group(formControls);\n    this.props.sections.forEach(section => {\n      section.fields\n        .filter(\n          x =>\n            x.type === this.types.SELECT ||\n            x.type === this.types.TEXT ||\n            x.type === this.types.SEARCH_SELECT ||\n            x.type === this.types.MULTI_SELECT\n        )\n        .forEach(field => {\n          this.trackSelectChanges(field.name);\n        });\n    });\n  }\n\n  ngOnDestroy() {\n    // Cleanup subscriptions to avoid memory leaks\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n\n  trackSelectChanges(fieldName: string) {\n    const control = this.getControl(fieldName);\n    const subscription = control.valueChanges.subscribe(value => {\n      this.onSelectChange.emit({ field: fieldName, value });\n    });\n    this.subscriptions.push(subscription);\n  }\n\n  async submitHandler(token?: string) {\n    this.onSubmit.emit({ fields: this.form.getRawValue(), token });\n  }\n\n  getControl(field: string): FormControl {\n    return this.Form.get(field) as FormControl;\n  }\n\n  getFieldProp(field: InputMetadata): InputMetadata {\n    field.token;\n    if (!field.token) {\n      field.token = `input-${field.type}-${field.name}`;\n    }\n\n    if (field.type === this.types.NUMBER_FROM_TO) {\n      const fromControl = this.getControl(`${field.name}_from`);\n      const toControl = this.getControl(`${field.name}_to`);\n\n      if (field.state === ComponentStates.DISABLED) {\n        fromControl.disable();\n        toControl.disable();\n      } else {\n        fromControl.enable();\n        toControl.enable();\n      }\n\n      return {\n        ...field,\n        fromControl,\n        toControl,\n        control: undefined, // Remove control for NUMBER_FROM_TO fields\n      };\n    } else {\n      const control = this.getControl(field.name);\n      if (field.state === ComponentStates.DISABLED) {\n        control.disable();\n      } else {\n        control.enable();\n      }\n      return {\n        ...field,\n        control,\n      };\n    }\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 FormState(): { form: FormGroup; data: FormMetadata } {\n    return {\n      form: this.Form,\n      data: this.props,\n    };\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    if (this.props.state === ComponentStates.WORKING) {\n      this.props.actions.state = ComponentStates.WORKING;\n    }\n\n    if (this.props.state === ComponentStates.ENABLED) {\n      this.props.actions.state = ComponentStates.ENABLED;\n    }\n\n    if (this.props.state === ComponentStates.DISABLED) {\n      this.props.actions.state = ComponentStates.DISABLED;\n    }\n\n    return [this.props.actions];\n  }\n}\n"]}
|
|
407
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, DoCheck, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormBuilder, FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { isAtEnd } from '../../../shared/utils/dom';\nimport { DisplayComponent } from '../../atoms/display/display.component';\nimport { DividerComponent } from '../../atoms/divider/divider.component';\nimport { TitleComponent } from '../../atoms/title/title.component';\nimport { ButtonGroupComponent } from '../../molecules/button-group/button-group.component';\nimport { CheckInputComponent } from '../../molecules/check-input/check-input.component';\nimport { CommentInputComponent } from '../../molecules/comment-input/comment-input.component';\nimport { DateInputComponent } from '../../molecules/date-input/date-input.component';\nimport { EmailInputComponent } from '../../molecules/email-input/email-input.component';\nimport { FileInputComponent } from '../../molecules/file-input/file-input.component';\nimport { HintComponent } from '../../molecules/hint/hint.component';\nimport { HourInputComponent } from '../../molecules/hour-input/hour-input.component';\nimport { NumberInputComponent } from '../../molecules/number-input/number-input.component';\nimport { NumberFromToComponent } from '../../molecules/number-from-to/number-from-to.component';\nimport { PasswordInputComponent } from '../../molecules/password-input/password-input.component';\nimport { PinInputComponent } from '../../molecules/pin-input/pin-input.component';\nimport { RadioInputComponent } from '../../molecules/radio-input/radio-input.component';\nimport { SearchSelectorComponent } from '../../molecules/select-input/select-input.component';\nimport { SelectSearchComponent } from '../../molecules/select-search/select-search.component';\nimport { MultiSelectSearchComponent } from '../../molecules/multi-select-search/multi-select-search.component';\nimport { TextInputComponent } from '../../molecules/text-input/text-input.component';\nimport { ButtonMetadata, ComponentStates, FormMetadata, FormSubmit, InputMetadata, InputType } from '../../types';\n\n@Component({\n  selector: 'val-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    DisplayComponent,\n    TitleComponent,\n    TextInputComponent,\n    CheckInputComponent,\n    ButtonGroupComponent,\n    DividerComponent,\n    HintComponent,\n    CommentInputComponent,\n    DateInputComponent,\n    FileInputComponent,\n    HourInputComponent,\n    EmailInputComponent,\n    NumberInputComponent,\n    NumberFromToComponent,\n    RadioInputComponent,\n    PasswordInputComponent,\n    PinInputComponent,\n    SelectSearchComponent,\n    MultiSelectSearchComponent,\n    SearchSelectorComponent,\n  ],\n  template: `\n    <div class=\"container\">\n      <form [formGroup]=\"form\">\n        <val-display\n          *ngIf=\"props.name\"\n          [props]=\"{\n            content: props.name,\n            color: 'dark',\n            size: 'large',\n          }\"\n        ></val-display>\n        <div class=\"section\" *ngFor=\"let s of props.sections\">\n          <val-title [props]=\"{ content: s.name, size: 'large', color: '', bold: false }\"></val-title>\n          <div class=\"input\" *ngFor=\"let f of s.fields\">\n            <val-title [props]=\"{ content: f.label, size: 'small', color: 'dark', bold: false }\"></val-title>\n            <ng-container *ngIf=\"f.type === types.TEXT\">\n              <val-text-input [props]=\"getFieldProp(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 [props]=\"getFieldProp(f)\"></val-comment-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.DATE\">\n              <val-date-input [props]=\"getFieldProp(f)\"></val-date-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.EMAIL\">\n              <val-email-input [props]=\"getFieldProp(f)\"></val-email-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.FILE\">\n              <val-file-input [props]=\"getFieldProp(f)\"></val-file-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.HOUR\">\n              <val-hour-input [props]=\"getFieldProp(f)\"></val-hour-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.NUMBER\">\n              <val-number-input [props]=\"getFieldProp(f)\"></val-number-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.NUMBER_FROM_TO\">\n              <val-number-from-to [props]=\"getFieldProp(f)\"></val-number-from-to>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.PASSWORD\">\n              <val-password-input [props]=\"getFieldProp(f)\"></val-password-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.PIN_CODE\">\n              <val-pin-input [props]=\"getFieldProp(f)\"></val-pin-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.RADIO\">\n              <val-radio-input [props]=\"getFieldProp(f)\"></val-radio-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.SELECT\">\n              <val-select-input [props]=\"getFieldProp(f)\"></val-select-input>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.SEARCH_SELECT\">\n              <val-select-search [props]=\"getFieldProp(f)\"></val-select-search>\n            </ng-container>\n            <ng-container *ngIf=\"f.type === types.MULTI_SELECT\">\n              <val-multi-select-search [props]=\"getFieldProp(f)\"></val-multi-select-search>\n            </ng-container>\n            <val-hint [props]=\"getFieldProp(f)\"></val-hint>\n          </div>\n          <val-divider [props]=\"{ fill: 'solid', size: 'medium', color: 'medium' }\"></val-divider>\n          <ng-content></ng-content>\n        </div>\n        <val-button-group\n          [props]=\"{ buttons: actions, position: 'center', columned: false }\"\n          (onClick)=\"submitHandler($event)\"\n        ></val-button-group>\n      </form>\n    </div>\n  `,\n  styleUrls: ['./form.component.scss'],\n})\nexport class FormComponent implements OnInit, OnChanges, DoCheck {\n  @Input()\n  props: FormMetadata;\n\n  @Output()\n  onSubmit = new EventEmitter<FormSubmit>();\n\n  @Output()\n  onInvalid = new EventEmitter();\n\n  @Output()\n  onSelectChange = new EventEmitter<{ field: string; value: any }>();\n\n  form: FormGroup;\n  types = InputType;\n  private subscriptions: Subscription[] = [];\n\n  // Cache para evitar crear nuevos objetos en cada ciclo de change detection\n  private fieldPropsCache: Map<string, InputMetadata> = new Map();\n  private actionsCache: ButtonMetadata[] = [];\n\n  // Estado previo para detectar cambios en ngDoCheck\n  private previousState: string | undefined;\n\n  constructor(\n    private fb: FormBuilder,\n    private elementRef: ElementRef\n  ) {}\n\n  ngOnInit() {\n    const formControls = {};\n    this.props.sections.forEach(section => {\n      section.fields.forEach(field => {\n        if (field.type === this.types.NUMBER_FROM_TO) {\n          // Crear dos controles para campos NUMBER_FROM_TO\n          formControls[`${field.name}_from`] = [undefined, field.validators || []];\n          formControls[`${field.name}_to`] = [undefined, field.validators || []];\n        } else {\n          formControls[field.name] = [undefined, field.validators || []];\n        }\n      });\n    });\n    this.form = this.fb.group(formControls);\n    this.props.sections.forEach(section => {\n      section.fields\n        .filter(\n          x =>\n            x.type === this.types.SELECT ||\n            x.type === this.types.TEXT ||\n            x.type === this.types.SEARCH_SELECT ||\n            x.type === this.types.MULTI_SELECT\n        )\n        .forEach(field => {\n          this.trackSelectChanges(field.name);\n        });\n    });\n\n    // Construir cache inicial\n    this.rebuildFieldPropsCache();\n    this.updateActionsCache();\n    this.previousState = this.props.state;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    // Cuando props cambia, reconstruir el cache\n    if (changes['props'] && this.form) {\n      this.rebuildFieldPropsCache();\n      this.updateActionsCache();\n      this.previousState = this.props.state;\n    }\n  }\n\n  ngDoCheck() {\n    // Detectar cambios en el estado del formulario (mutación sin cambiar referencia)\n    if (this.form && this.props && this.props.state !== this.previousState) {\n      this.previousState = this.props.state;\n      this.updateActionsCache();\n    }\n  }\n\n  /**\n   * Reconstruye el cache de props para cada field.\n   * Esto evita crear nuevos objetos en cada ciclo de change detection.\n   */\n  private rebuildFieldPropsCache() {\n    this.fieldPropsCache.clear();\n    this.props.sections.forEach(section => {\n      section.fields.forEach(field => {\n        const token = field.token || `input-${field.type}-${field.name}`;\n\n        if (field.type === this.types.NUMBER_FROM_TO) {\n          const fromControl = this.getControl(`${field.name}_from`);\n          const toControl = this.getControl(`${field.name}_to`);\n\n          if (field.state === ComponentStates.DISABLED) {\n            fromControl.disable({ emitEvent: false });\n            toControl.disable({ emitEvent: false });\n          } else {\n            fromControl.enable({ emitEvent: false });\n            toControl.enable({ emitEvent: false });\n          }\n\n          this.fieldPropsCache.set(field.name, {\n            ...field,\n            token,\n            fromControl,\n            toControl,\n            control: undefined,\n          });\n        } else {\n          const control = this.getControl(field.name);\n          if (field.state === ComponentStates.DISABLED) {\n            control.disable({ emitEvent: false });\n          } else {\n            control.enable({ emitEvent: false });\n          }\n\n          this.fieldPropsCache.set(field.name, {\n            ...field,\n            token,\n            control,\n          });\n        }\n      });\n    });\n  }\n\n  /**\n   * Actualiza el cache de actions basado en el estado actual del form.\n   */\n  private updateActionsCache() {\n    let actionState = this.props.actions.state;\n\n    if (this.props.state === ComponentStates.WORKING) {\n      actionState = ComponentStates.WORKING;\n    } else if (this.props.state === ComponentStates.DISABLED) {\n      actionState = ComponentStates.DISABLED;\n    } else if (this.props.state === ComponentStates.ENABLED || this.form?.valid) {\n      actionState = ComponentStates.ENABLED;\n    }\n\n    this.actionsCache = [{ ...this.props.actions, state: actionState }];\n  }\n\n  ngOnDestroy() {\n    // Cleanup subscriptions to avoid memory leaks\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n\n  trackSelectChanges(fieldName: string) {\n    const control = this.getControl(fieldName);\n    const subscription = control.valueChanges.subscribe(value => {\n      this.onSelectChange.emit({ field: fieldName, value });\n    });\n    this.subscriptions.push(subscription);\n  }\n\n  async submitHandler(token?: string) {\n    this.onSubmit.emit({ fields: this.form.getRawValue(), token });\n  }\n\n  getControl(field: string): FormControl {\n    return this.Form.get(field) as FormControl;\n  }\n\n  getFieldProp(field: InputMetadata): InputMetadata {\n    // Retornar del cache para evitar crear nuevos objetos en cada ciclo de change detection\n    const cached = this.fieldPropsCache.get(field.name);\n    if (cached) {\n      return cached;\n    }\n\n    // Fallback: generar y cachear si no existe (no debería ocurrir normalmente)\n    const token = field.token || `input-${field.type}-${field.name}`;\n\n    if (field.type === this.types.NUMBER_FROM_TO) {\n      const fromControl = this.getControl(`${field.name}_from`);\n      const toControl = this.getControl(`${field.name}_to`);\n\n      if (field.state === ComponentStates.DISABLED) {\n        fromControl.disable({ emitEvent: false });\n        toControl.disable({ emitEvent: false });\n      } else {\n        fromControl.enable({ emitEvent: false });\n        toControl.enable({ emitEvent: false });\n      }\n\n      const props = {\n        ...field,\n        token,\n        fromControl,\n        toControl,\n        control: undefined,\n      };\n      this.fieldPropsCache.set(field.name, props);\n      return props;\n    } else {\n      const control = this.getControl(field.name);\n      if (field.state === ComponentStates.DISABLED) {\n        control.disable({ emitEvent: false });\n      } else {\n        control.enable({ emitEvent: false });\n      }\n      const props = {\n        ...field,\n        token,\n        control,\n      };\n      this.fieldPropsCache.set(field.name, props);\n      return props;\n    }\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 FormState(): { form: FormGroup; data: FormMetadata } {\n    return {\n      form: this.Form,\n      data: this.props,\n    };\n  }\n\n  get actions(): ButtonMetadata[] {\n    // Retornar del cache para evitar crear nuevos objetos en cada ciclo de change detection\n    return this.actionsCache;\n  }\n}\n"]}
|