valtech-components 2.0.372 → 2.0.374

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.
@@ -16,19 +16,44 @@ import * as i1 from "@angular/common";
16
16
  export class HintComponent {
17
17
  constructor() { }
18
18
  ngOnInit() { }
19
+ get shouldShowErrors() {
20
+ if (this.props.control) {
21
+ // Normal field with single control
22
+ return this.props.control.invalid && (this.props.control.touched || this.props.control.dirty);
23
+ }
24
+ else if (this.props.fromControl && this.props.toControl) {
25
+ // NUMBER_FROM_TO field with separate controls
26
+ const fromInvalid = this.props.fromControl.invalid && (this.props.fromControl.touched || this.props.fromControl.dirty);
27
+ const toInvalid = this.props.toControl.invalid && (this.props.toControl.touched || this.props.toControl.dirty);
28
+ return fromInvalid || toInvalid;
29
+ }
30
+ return false;
31
+ }
19
32
  get Errors() {
20
- const keys = Object.keys(this.props.errors);
33
+ const keys = Object.keys(this.props.errors || {});
21
34
  const errors = [];
22
35
  keys.map((e) => {
23
- if (this.props.control.hasError(e)) {
36
+ if (this.props.control && this.props.control.hasError(e)) {
37
+ // Normal field
24
38
  errors.push(this.props.errors[e]);
25
39
  }
40
+ else if (this.props.fromControl && this.props.toControl) {
41
+ // NUMBER_FROM_TO field - check both controls
42
+ const fromLabel = this.props.fromLabel || 'Inicial';
43
+ const toLabel = this.props.toLabel || 'Final';
44
+ if (this.props.fromControl.hasError(e)) {
45
+ errors.push(`${fromLabel}: ${this.props.errors[e]}`);
46
+ }
47
+ if (this.props.toControl.hasError(e)) {
48
+ errors.push(`${toLabel}: ${this.props.errors[e]}`);
49
+ }
50
+ }
26
51
  });
27
52
  return errors;
28
53
  }
29
54
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
55
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: HintComponent, isStandalone: true, selector: "val-hint", inputs: { props: "props" }, ngImport: i0, template: `
31
- <div class="hint-container" *ngIf="props.control.invalid && (props.control.touched || props.control.dirty)">
56
+ <div class="hint-container" *ngIf="shouldShowErrors">
32
57
  <val-text
33
58
  *ngFor="let e of Errors"
34
59
  [props]="{
@@ -44,7 +69,7 @@ export class HintComponent {
44
69
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HintComponent, decorators: [{
45
70
  type: Component,
46
71
  args: [{ selector: 'val-hint', standalone: true, imports: [CommonModule, TextComponent], template: `
47
- <div class="hint-container" *ngIf="props.control.invalid && (props.control.touched || props.control.dirty)">
72
+ <div class="hint-container" *ngIf="shouldShowErrors">
48
73
  <val-text
49
74
  *ngFor="let e of Errors"
50
75
  [props]="{
@@ -59,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
59
84
  }], ctorParameters: () => [], propDecorators: { props: [{
60
85
  type: Input
61
86
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGludC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL21vbGVjdWxlcy9oaW50L2hpbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUNBQWlDLENBQUM7OztBQXNCaEU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxPQUFPLGFBQWE7SUFTeEIsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLElBQUksTUFBTTtRQUNSLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM1QyxNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQVMsRUFBRSxFQUFFO1lBQ3JCLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ25DLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOytHQXRCVSxhQUFhO21HQUFiLGFBQWEsZ0dBekJkOzs7Ozs7Ozs7Ozs7R0FZVCxrdEZBYlMsWUFBWSxnUUFBRSxhQUFhOzs0RkEwQjFCLGFBQWE7a0JBN0J6QixTQUFTOytCQUNFLFVBQVUsY0FDUixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsYUFBYSxDQUFDLFlBQzVCOzs7Ozs7Ozs7Ozs7R0FZVDt3REFvQlEsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGV4dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL3RleHQvdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRNZXRhZGF0YSB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWhpbnQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUZXh0Q29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwiaGludC1jb250YWluZXJcIiAqbmdJZj1cInByb3BzLmNvbnRyb2wuaW52YWxpZCAmJiAocHJvcHMuY29udHJvbC50b3VjaGVkIHx8IHByb3BzLmNvbnRyb2wuZGlydHkpXCI+XG4gICAgICA8dmFsLXRleHRcbiAgICAgICAgKm5nRm9yPVwibGV0IGUgb2YgRXJyb3JzXCJcbiAgICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgICBjb250ZW50OiBlLFxuICAgICAgICAgIGNvbG9yOiAnZGFuZ2VyJyxcbiAgICAgICAgICBib2xkOiBmYWxzZSxcbiAgICAgICAgICBzaXplOiAnc21hbGwnLFxuICAgICAgICB9XCJcbiAgICAgID48L3ZhbC10ZXh0PlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9oaW50LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtaGludFxuICpcbiAqIERpc3BsYXlzIHZhbGlkYXRpb24gZXJyb3IgbWVzc2FnZXMgZm9yIGEgZm9ybSBpbnB1dCwgdXNpbmcgQW5ndWxhciBmb3Jtcy5cbiAqXG4gKiBAZXhhbXBsZVxuICogPHZhbC1oaW50IFtwcm9wc109XCJ7IGNvbnRyb2w6IG15Q29udHJvbCwgZXJyb3JzOiB7IHJlcXVpcmVkOiAnUmVxdWlyZWQgZmllbGQnIH0gfVwiPjwvdmFsLWhpbnQ+XG4gKlxuICogQGlucHV0IHByb3BzOiBJbnB1dE1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGlucHV0IChmb3JtIGNvbnRyb2wsIGVycm9ycywgZXRjLilcbiAqL1xuZXhwb3J0IGNsYXNzIEhpbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAvKipcbiAgICogSW5wdXQgY29uZmlndXJhdGlvbiBvYmplY3QuXG4gICAqIEB0eXBlIHtJbnB1dE1ldGFkYXRhfVxuICAgKiBAcHJvcGVydHkgY29udHJvbCAtIFRoZSBBbmd1bGFyIEZvcm1Db250cm9sIGZvciB0aGUgaW5wdXQuXG4gICAqIEBwcm9wZXJ0eSBlcnJvcnMgLSBUaGUgZXJyb3IgbWVzc2FnZXMgbWFwcGluZy5cbiAgICovXG4gIEBJbnB1dCgpIHByb3BzOiBJbnB1dE1ldGFkYXRhO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgZ2V0IEVycm9ycygpOiBzdHJpbmdbXSB7XG4gICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKHRoaXMucHJvcHMuZXJyb3JzKTtcbiAgICBjb25zdCBlcnJvcnMgPSBbXTtcbiAgICBrZXlzLm1hcCgoZTogc3RyaW5nKSA9PiB7XG4gICAgICBpZiAodGhpcy5wcm9wcy5jb250cm9sLmhhc0Vycm9yKGUpKSB7XG4gICAgICAgIGVycm9ycy5wdXNoKHRoaXMucHJvcHMuZXJyb3JzW2VdKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgICByZXR1cm4gZXJyb3JzO1xuICB9XG59XG4iXX0=
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGludC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL21vbGVjdWxlcy9oaW50L2hpbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUNBQWlDLENBQUM7OztBQXNCaEU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxPQUFPLGFBQWE7SUFTeEIsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLElBQUksZ0JBQWdCO1FBQ2xCLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN2QixtQ0FBbUM7WUFDbkMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEcsQ0FBQzthQUFNLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMxRCw4Q0FBOEM7WUFDOUMsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3ZILE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMvRyxPQUFPLFdBQVcsSUFBSSxTQUFTLENBQUM7UUFDbEMsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksRUFBRSxDQUFDLENBQUM7UUFDbEQsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBRWxCLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFTLEVBQUUsRUFBRTtZQUNyQixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUN6RCxlQUFlO2dCQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQyxDQUFDO2lCQUFNLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUUsQ0FBQztnQkFDMUQsNkNBQTZDO2dCQUM3QyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxTQUFTLENBQUM7Z0JBQ3BELE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxJQUFJLE9BQU8sQ0FBQztnQkFFOUMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztvQkFDdkMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLFNBQVMsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ3ZELENBQUM7Z0JBQ0QsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztvQkFDckMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ3JELENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOytHQWpEVSxhQUFhO21HQUFiLGFBQWEsZ0dBekJkOzs7Ozs7Ozs7Ozs7R0FZVCxrdEZBYlMsWUFBWSxnUUFBRSxhQUFhOzs0RkEwQjFCLGFBQWE7a0JBN0J6QixTQUFTOytCQUNFLFVBQVUsY0FDUixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsYUFBYSxDQUFDLFlBQzVCOzs7Ozs7Ozs7Ozs7R0FZVDt3REFvQlEsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGV4dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL3RleHQvdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRNZXRhZGF0YSB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWhpbnQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUZXh0Q29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwiaGludC1jb250YWluZXJcIiAqbmdJZj1cInNob3VsZFNob3dFcnJvcnNcIj5cbiAgICAgIDx2YWwtdGV4dFxuICAgICAgICAqbmdGb3I9XCJsZXQgZSBvZiBFcnJvcnNcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IGUsXG4gICAgICAgICAgY29sb3I6ICdkYW5nZXInLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6ICdzbWFsbCcsXG4gICAgICAgIH1cIlxuICAgICAgPjwvdmFsLXRleHQ+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2hpbnQuY29tcG9uZW50LnNjc3MnXSxcbn0pXG4vKipcbiAqIHZhbC1oaW50XG4gKlxuICogRGlzcGxheXMgdmFsaWRhdGlvbiBlcnJvciBtZXNzYWdlcyBmb3IgYSBmb3JtIGlucHV0LCB1c2luZyBBbmd1bGFyIGZvcm1zLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8dmFsLWhpbnQgW3Byb3BzXT1cInsgY29udHJvbDogbXlDb250cm9sLCBlcnJvcnM6IHsgcmVxdWlyZWQ6ICdSZXF1aXJlZCBmaWVsZCcgfSB9XCI+PC92YWwtaGludD5cbiAqXG4gKiBAaW5wdXQgcHJvcHM6IElucHV0TWV0YWRhdGEgLSBDb25maWd1cmF0aW9uIGZvciB0aGUgaW5wdXQgKGZvcm0gY29udHJvbCwgZXJyb3JzLCBldGMuKVxuICovXG5leHBvcnQgY2xhc3MgSGludENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIC8qKlxuICAgKiBJbnB1dCBjb25maWd1cmF0aW9uIG9iamVjdC5cbiAgICogQHR5cGUge0lucHV0TWV0YWRhdGF9XG4gICAqIEBwcm9wZXJ0eSBjb250cm9sIC0gVGhlIEFuZ3VsYXIgRm9ybUNvbnRyb2wgZm9yIHRoZSBpbnB1dC5cbiAgICogQHByb3BlcnR5IGVycm9ycyAtIFRoZSBlcnJvciBtZXNzYWdlcyBtYXBwaW5nLlxuICAgKi9cbiAgQElucHV0KCkgcHJvcHM6IElucHV0TWV0YWRhdGE7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBnZXQgc2hvdWxkU2hvd0Vycm9ycygpOiBib29sZWFuIHtcbiAgICBpZiAodGhpcy5wcm9wcy5jb250cm9sKSB7XG4gICAgICAvLyBOb3JtYWwgZmllbGQgd2l0aCBzaW5nbGUgY29udHJvbFxuICAgICAgcmV0dXJuIHRoaXMucHJvcHMuY29udHJvbC5pbnZhbGlkICYmICh0aGlzLnByb3BzLmNvbnRyb2wudG91Y2hlZCB8fCB0aGlzLnByb3BzLmNvbnRyb2wuZGlydHkpO1xuICAgIH0gZWxzZSBpZiAodGhpcy5wcm9wcy5mcm9tQ29udHJvbCAmJiB0aGlzLnByb3BzLnRvQ29udHJvbCkge1xuICAgICAgLy8gTlVNQkVSX0ZST01fVE8gZmllbGQgd2l0aCBzZXBhcmF0ZSBjb250cm9sc1xuICAgICAgY29uc3QgZnJvbUludmFsaWQgPSB0aGlzLnByb3BzLmZyb21Db250cm9sLmludmFsaWQgJiYgKHRoaXMucHJvcHMuZnJvbUNvbnRyb2wudG91Y2hlZCB8fCB0aGlzLnByb3BzLmZyb21Db250cm9sLmRpcnR5KTtcbiAgICAgIGNvbnN0IHRvSW52YWxpZCA9IHRoaXMucHJvcHMudG9Db250cm9sLmludmFsaWQgJiYgKHRoaXMucHJvcHMudG9Db250cm9sLnRvdWNoZWQgfHwgdGhpcy5wcm9wcy50b0NvbnRyb2wuZGlydHkpO1xuICAgICAgcmV0dXJuIGZyb21JbnZhbGlkIHx8IHRvSW52YWxpZDtcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgZ2V0IEVycm9ycygpOiBzdHJpbmdbXSB7XG4gICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKHRoaXMucHJvcHMuZXJyb3JzIHx8IHt9KTtcbiAgICBjb25zdCBlcnJvcnMgPSBbXTtcbiAgICBcbiAgICBrZXlzLm1hcCgoZTogc3RyaW5nKSA9PiB7XG4gICAgICBpZiAodGhpcy5wcm9wcy5jb250cm9sICYmIHRoaXMucHJvcHMuY29udHJvbC5oYXNFcnJvcihlKSkge1xuICAgICAgICAvLyBOb3JtYWwgZmllbGRcbiAgICAgICAgZXJyb3JzLnB1c2godGhpcy5wcm9wcy5lcnJvcnNbZV0pO1xuICAgICAgfSBlbHNlIGlmICh0aGlzLnByb3BzLmZyb21Db250cm9sICYmIHRoaXMucHJvcHMudG9Db250cm9sKSB7XG4gICAgICAgIC8vIE5VTUJFUl9GUk9NX1RPIGZpZWxkIC0gY2hlY2sgYm90aCBjb250cm9sc1xuICAgICAgICBjb25zdCBmcm9tTGFiZWwgPSB0aGlzLnByb3BzLmZyb21MYWJlbCB8fCAnSW5pY2lhbCc7XG4gICAgICAgIGNvbnN0IHRvTGFiZWwgPSB0aGlzLnByb3BzLnRvTGFiZWwgfHwgJ0ZpbmFsJztcbiAgICAgICAgXG4gICAgICAgIGlmICh0aGlzLnByb3BzLmZyb21Db250cm9sLmhhc0Vycm9yKGUpKSB7XG4gICAgICAgICAgZXJyb3JzLnB1c2goYCR7ZnJvbUxhYmVsfTogJHt0aGlzLnByb3BzLmVycm9yc1tlXX1gKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAodGhpcy5wcm9wcy50b0NvbnRyb2wuaGFzRXJyb3IoZSkpIHtcbiAgICAgICAgICBlcnJvcnMucHVzaChgJHt0b0xhYmVsfTogJHt0aGlzLnByb3BzLmVycm9yc1tlXX1gKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuICAgIFxuICAgIHJldHVybiBlcnJvcnM7XG4gIH1cbn1cbiJdfQ==
@@ -1,7 +1,6 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import { ReactiveFormsModule } from '@angular/forms';
3
- import { IonInput, IonItem, IonLabel } from '@ionic/angular/standalone';
4
- import { applyDefaultValueToControl } from '../../../shared/utils/form-defaults';
3
+ import { IonInput, IonLabel } from '@ionic/angular/standalone';
5
4
  import * as i0 from "@angular/core";
6
5
  import * as i1 from "@angular/forms";
7
6
  export class NumberFromToComponent {
@@ -9,7 +8,52 @@ export class NumberFromToComponent {
9
8
  ngOnInit() {
10
9
  // Apply default values if configured
11
10
  if (this.props?.withDefault || this.props?.value) {
12
- applyDefaultValueToControl(this.props);
11
+ this.applyDefaultValues();
12
+ }
13
+ }
14
+ applyDefaultValues() {
15
+ const defaultValue = this.resolveDefaultValue();
16
+ if (defaultValue !== null) {
17
+ if (typeof defaultValue === 'object' && defaultValue.from !== undefined) {
18
+ this.fromControl?.setValue(defaultValue.from);
19
+ this.toControl?.setValue(defaultValue.to);
20
+ }
21
+ else {
22
+ // Si es un valor simple, aplicarlo a ambos controles
23
+ this.fromControl?.setValue(defaultValue);
24
+ this.toControl?.setValue(defaultValue);
25
+ }
26
+ this.fromControl?.markAsPristine();
27
+ this.toControl?.markAsPristine();
28
+ this.fromControl?.updateValueAndValidity();
29
+ this.toControl?.updateValueAndValidity();
30
+ }
31
+ }
32
+ resolveDefaultValue() {
33
+ // Explicit value takes precedence
34
+ if (this.props.value !== undefined && this.props.value !== null && this.props.value !== '') {
35
+ return this.parseValue(this.props.value);
36
+ }
37
+ // No default configuration
38
+ if (!this.props.withDefault) {
39
+ return null;
40
+ }
41
+ // Custom default value
42
+ if (typeof this.props.withDefault === 'string') {
43
+ return this.parseValue(this.props.withDefault);
44
+ }
45
+ // Auto default value (withDefault === true)
46
+ return { from: 0, to: 0 };
47
+ }
48
+ parseValue(value) {
49
+ try {
50
+ // Try to parse as JSON first (for object values)
51
+ return JSON.parse(value);
52
+ }
53
+ catch {
54
+ // If not JSON, treat as number
55
+ const numValue = parseFloat(value) || 0;
56
+ return { from: numValue, to: numValue };
13
57
  }
14
58
  }
15
59
  get fromControl() {
@@ -21,7 +65,7 @@ export class NumberFromToComponent {
21
65
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NumberFromToComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
66
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NumberFromToComponent, isStandalone: true, selector: "val-number-from-to", inputs: { props: "props" }, ngImport: i0, template: `
23
67
  <div class="number-from-to-container">
24
- <ion-label position="stacked">{{ props.fromLabel || 'Desde' }}</ion-label>
68
+ <ion-label position="stacked">{{ props.fromLabel || 'Inicial' }}</ion-label>
25
69
  <ion-input
26
70
  [formControl]="fromControl"
27
71
  type="number"
@@ -31,7 +75,7 @@ export class NumberFromToComponent {
31
75
  >
32
76
  </ion-input>
33
77
 
34
- <ion-label position="stacked">{{ props.toLabel || 'Hasta' }}</ion-label>
78
+ <ion-label position="stacked">{{ props.toLabel || 'Final' }}</ion-label>
35
79
  <ion-input
36
80
  [formControl]="toControl"
37
81
  type="number"
@@ -45,9 +89,9 @@ export class NumberFromToComponent {
45
89
  }
46
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NumberFromToComponent, decorators: [{
47
91
  type: Component,
48
- args: [{ selector: 'val-number-from-to', standalone: true, imports: [ReactiveFormsModule, IonInput, IonItem, IonLabel], template: `
92
+ args: [{ selector: 'val-number-from-to', standalone: true, imports: [ReactiveFormsModule, IonInput, IonLabel], template: `
49
93
  <div class="number-from-to-container">
50
- <ion-label position="stacked">{{ props.fromLabel || 'Desde' }}</ion-label>
94
+ <ion-label position="stacked">{{ props.fromLabel || 'Inicial' }}</ion-label>
51
95
  <ion-input
52
96
  [formControl]="fromControl"
53
97
  type="number"
@@ -57,7 +101,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
57
101
  >
58
102
  </ion-input>
59
103
 
60
- <ion-label position="stacked">{{ props.toLabel || 'Hasta' }}</ion-label>
104
+ <ion-label position="stacked">{{ props.toLabel || 'Final' }}</ion-label>
61
105
  <ion-input
62
106
  [formControl]="toControl"
63
107
  type="number"
@@ -71,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
71
115
  }], ctorParameters: () => [], propDecorators: { props: [{
72
116
  type: Input
73
117
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLWZyb20tdG8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvbnVtYmVyLWZyb20tdG8vbnVtYmVyLWZyb20tdG8uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBZSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFnQ2pGLE1BQU0sT0FBTyxxQkFBcUI7SUFHaEMsZ0JBQWUsQ0FBQztJQUVoQixRQUFRO1FBQ04scUNBQXFDO1FBQ3JDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxXQUFXLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQztZQUNqRCwwQkFBMEIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDO0lBQzlCLENBQUM7K0dBbEJVLHFCQUFxQjttR0FBckIscUJBQXFCLDBHQXpCdEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQlQseUVBdkJTLG1CQUFtQiwwVEFBRSxRQUFRLDhlQUFXLFFBQVE7OzRGQTBCL0MscUJBQXFCO2tCQTdCakMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLENBQUMsbUJBQW1CLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxRQUFRLENBQUMsWUFDakQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQlQ7d0RBSVEsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IElvbklucHV0LCBJb25JdGVtLCBJb25MYWJlbCB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgYXBwbHlEZWZhdWx0VmFsdWVUb0NvbnRyb2wgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvZm9ybS1kZWZhdWx0cyc7XG5pbXBvcnQgeyBJbnB1dE1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtbnVtYmVyLWZyb20tdG8nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbUmVhY3RpdmVGb3Jtc01vZHVsZSwgSW9uSW5wdXQsIElvbkl0ZW0sIElvbkxhYmVsXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwibnVtYmVyLWZyb20tdG8tY29udGFpbmVyXCI+XG4gICAgICA8aW9uLWxhYmVsIHBvc2l0aW9uPVwic3RhY2tlZFwiPnt7IHByb3BzLmZyb21MYWJlbCB8fCAnRGVzZGUnIH19PC9pb24tbGFiZWw+XG4gICAgICA8aW9uLWlucHV0XG4gICAgICAgIFtmb3JtQ29udHJvbF09XCJmcm9tQ29udHJvbFwiXG4gICAgICAgIHR5cGU9XCJudW1iZXJcIlxuICAgICAgICBbcGxhY2Vob2xkZXJdPVwicHJvcHMuZnJvbVBsYWNlaG9sZGVyIHx8IHByb3BzLnBsYWNlaG9sZGVyXCJcbiAgICAgICAgW21pbl09XCJwcm9wcy5yYW5nZT8ubWluXCJcbiAgICAgICAgW21heF09XCJwcm9wcy5yYW5nZT8ubWF4XCJcbiAgICAgID5cbiAgICAgIDwvaW9uLWlucHV0PlxuXG4gICAgICA8aW9uLWxhYmVsIHBvc2l0aW9uPVwic3RhY2tlZFwiPnt7IHByb3BzLnRvTGFiZWwgfHwgJ0hhc3RhJyB9fTwvaW9uLWxhYmVsPlxuICAgICAgPGlvbi1pbnB1dFxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwidG9Db250cm9sXCJcbiAgICAgICAgdHlwZT1cIm51bWJlclwiXG4gICAgICAgIFtwbGFjZWhvbGRlcl09XCJwcm9wcy50b1BsYWNlaG9sZGVyIHx8IHByb3BzLnBsYWNlaG9sZGVyXCJcbiAgICAgICAgW21pbl09XCJwcm9wcy5yYW5nZT8ubWluXCJcbiAgICAgICAgW21heF09XCJwcm9wcy5yYW5nZT8ubWF4XCJcbiAgICAgID5cbiAgICAgIDwvaW9uLWlucHV0PlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9udW1iZXItZnJvbS10by5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBOdW1iZXJGcm9tVG9Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwcm9wczogSW5wdXRNZXRhZGF0YTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgLy8gQXBwbHkgZGVmYXVsdCB2YWx1ZXMgaWYgY29uZmlndXJlZFxuICAgIGlmICh0aGlzLnByb3BzPy53aXRoRGVmYXVsdCB8fCB0aGlzLnByb3BzPy52YWx1ZSkge1xuICAgICAgYXBwbHlEZWZhdWx0VmFsdWVUb0NvbnRyb2wodGhpcy5wcm9wcyk7XG4gICAgfVxuICB9XG5cbiAgZ2V0IGZyb21Db250cm9sKCk6IEZvcm1Db250cm9sIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5mcm9tQ29udHJvbDtcbiAgfVxuXG4gIGdldCB0b0NvbnRyb2woKTogRm9ybUNvbnRyb2wge1xuICAgIHJldHVybiB0aGlzLnByb3BzLnRvQ29udHJvbDtcbiAgfVxufVxuIl19
118
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLWZyb20tdG8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvbnVtYmVyLWZyb20tdG8vbnVtYmVyLWZyb20tdG8uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBZSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7OztBQWdDL0QsTUFBTSxPQUFPLHFCQUFxQjtJQUdoQyxnQkFBZSxDQUFDO0lBRWhCLFFBQVE7UUFDTixxQ0FBcUM7UUFDckMsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLFdBQVcsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDO1lBQ2pELElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDO0lBRU8sa0JBQWtCO1FBQ3hCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ2hELElBQUksWUFBWSxLQUFLLElBQUksRUFBRSxDQUFDO1lBQzFCLElBQUksT0FBTyxZQUFZLEtBQUssUUFBUSxJQUFJLFlBQVksQ0FBQyxJQUFJLEtBQUssU0FBUyxFQUFFLENBQUM7Z0JBQ3hFLElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDOUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQzVDLENBQUM7aUJBQU0sQ0FBQztnQkFDTixxREFBcUQ7Z0JBQ3JELElBQUksQ0FBQyxXQUFXLEVBQUUsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFDO2dCQUN6QyxJQUFJLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUN6QyxDQUFDO1lBQ0QsSUFBSSxDQUFDLFdBQVcsRUFBRSxjQUFjLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsU0FBUyxFQUFFLGNBQWMsRUFBRSxDQUFDO1lBQ2pDLElBQUksQ0FBQyxXQUFXLEVBQUUsc0JBQXNCLEVBQUUsQ0FBQztZQUMzQyxJQUFJLENBQUMsU0FBUyxFQUFFLHNCQUFzQixFQUFFLENBQUM7UUFDM0MsQ0FBQztJQUNILENBQUM7SUFFTyxtQkFBbUI7UUFDekIsa0NBQWtDO1FBQ2xDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUMzRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMzQyxDQUFDO1FBRUQsMkJBQTJCO1FBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzVCLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELHVCQUF1QjtRQUN2QixJQUFJLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDL0MsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDakQsQ0FBQztRQUVELDRDQUE0QztRQUM1QyxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVPLFVBQVUsQ0FBQyxLQUFhO1FBQzlCLElBQUksQ0FBQztZQUNILGlEQUFpRDtZQUNqRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsQ0FBQztRQUFDLE1BQU0sQ0FBQztZQUNQLCtCQUErQjtZQUMvQixNQUFNLFFBQVEsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3hDLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQUUsQ0FBQztRQUMxQyxDQUFDO0lBQ0gsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQUksU0FBUztRQUNYLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDOUIsQ0FBQzsrR0FuRVUscUJBQXFCO21HQUFyQixxQkFBcUIsMEdBekJ0Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXNCVCx5RUF2QlMsbUJBQW1CLDBUQUFFLFFBQVEsOGVBQUUsUUFBUTs7NEZBMEJ0QyxxQkFBcUI7a0JBN0JqQyxTQUFTOytCQUNFLG9CQUFvQixjQUNsQixJQUFJLFdBQ1AsQ0FBQyxtQkFBbUIsRUFBRSxRQUFRLEVBQUUsUUFBUSxDQUFDLFlBQ3hDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBc0JUO3dEQUlRLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBJb25JbnB1dCwgSW9uTGFiZWwgfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IElucHV0TWV0YWRhdGEgfSBmcm9tICcuLi8uLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1udW1iZXItZnJvbS10bycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtSZWFjdGl2ZUZvcm1zTW9kdWxlLCBJb25JbnB1dCwgSW9uTGFiZWxdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJudW1iZXItZnJvbS10by1jb250YWluZXJcIj5cbiAgICAgIDxpb24tbGFiZWwgcG9zaXRpb249XCJzdGFja2VkXCI+e3sgcHJvcHMuZnJvbUxhYmVsIHx8ICdJbmljaWFsJyB9fTwvaW9uLWxhYmVsPlxuICAgICAgPGlvbi1pbnB1dFxuICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZnJvbUNvbnRyb2xcIlxuICAgICAgICB0eXBlPVwibnVtYmVyXCJcbiAgICAgICAgW3BsYWNlaG9sZGVyXT1cInByb3BzLmZyb21QbGFjZWhvbGRlciB8fCBwcm9wcy5wbGFjZWhvbGRlclwiXG4gICAgICAgIFttaW5dPVwicHJvcHMucmFuZ2U/Lm1pblwiXG4gICAgICAgIFttYXhdPVwicHJvcHMucmFuZ2U/Lm1heFwiXG4gICAgICA+XG4gICAgICA8L2lvbi1pbnB1dD5cblxuICAgICAgPGlvbi1sYWJlbCBwb3NpdGlvbj1cInN0YWNrZWRcIj57eyBwcm9wcy50b0xhYmVsIHx8ICdGaW5hbCcgfX08L2lvbi1sYWJlbD5cbiAgICAgIDxpb24taW5wdXRcbiAgICAgICAgW2Zvcm1Db250cm9sXT1cInRvQ29udHJvbFwiXG4gICAgICAgIHR5cGU9XCJudW1iZXJcIlxuICAgICAgICBbcGxhY2Vob2xkZXJdPVwicHJvcHMudG9QbGFjZWhvbGRlciB8fCBwcm9wcy5wbGFjZWhvbGRlclwiXG4gICAgICAgIFttaW5dPVwicHJvcHMucmFuZ2U/Lm1pblwiXG4gICAgICAgIFttYXhdPVwicHJvcHMucmFuZ2U/Lm1heFwiXG4gICAgICA+XG4gICAgICA8L2lvbi1pbnB1dD5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vbnVtYmVyLWZyb20tdG8uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTnVtYmVyRnJvbVRvQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcHJvcHM6IElucHV0TWV0YWRhdGE7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIC8vIEFwcGx5IGRlZmF1bHQgdmFsdWVzIGlmIGNvbmZpZ3VyZWRcbiAgICBpZiAodGhpcy5wcm9wcz8ud2l0aERlZmF1bHQgfHwgdGhpcy5wcm9wcz8udmFsdWUpIHtcbiAgICAgIHRoaXMuYXBwbHlEZWZhdWx0VmFsdWVzKCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBhcHBseURlZmF1bHRWYWx1ZXMoKSB7XG4gICAgY29uc3QgZGVmYXVsdFZhbHVlID0gdGhpcy5yZXNvbHZlRGVmYXVsdFZhbHVlKCk7XG4gICAgaWYgKGRlZmF1bHRWYWx1ZSAhPT0gbnVsbCkge1xuICAgICAgaWYgKHR5cGVvZiBkZWZhdWx0VmFsdWUgPT09ICdvYmplY3QnICYmIGRlZmF1bHRWYWx1ZS5mcm9tICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgdGhpcy5mcm9tQ29udHJvbD8uc2V0VmFsdWUoZGVmYXVsdFZhbHVlLmZyb20pO1xuICAgICAgICB0aGlzLnRvQ29udHJvbD8uc2V0VmFsdWUoZGVmYXVsdFZhbHVlLnRvKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIFNpIGVzIHVuIHZhbG9yIHNpbXBsZSwgYXBsaWNhcmxvIGEgYW1ib3MgY29udHJvbGVzXG4gICAgICAgIHRoaXMuZnJvbUNvbnRyb2w/LnNldFZhbHVlKGRlZmF1bHRWYWx1ZSk7XG4gICAgICAgIHRoaXMudG9Db250cm9sPy5zZXRWYWx1ZShkZWZhdWx0VmFsdWUpO1xuICAgICAgfVxuICAgICAgdGhpcy5mcm9tQ29udHJvbD8ubWFya0FzUHJpc3RpbmUoKTtcbiAgICAgIHRoaXMudG9Db250cm9sPy5tYXJrQXNQcmlzdGluZSgpO1xuICAgICAgdGhpcy5mcm9tQ29udHJvbD8udXBkYXRlVmFsdWVBbmRWYWxpZGl0eSgpO1xuICAgICAgdGhpcy50b0NvbnRyb2w/LnVwZGF0ZVZhbHVlQW5kVmFsaWRpdHkoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHJlc29sdmVEZWZhdWx0VmFsdWUoKTogYW55IHtcbiAgICAvLyBFeHBsaWNpdCB2YWx1ZSB0YWtlcyBwcmVjZWRlbmNlXG4gICAgaWYgKHRoaXMucHJvcHMudmFsdWUgIT09IHVuZGVmaW5lZCAmJiB0aGlzLnByb3BzLnZhbHVlICE9PSBudWxsICYmIHRoaXMucHJvcHMudmFsdWUgIT09ICcnKSB7XG4gICAgICByZXR1cm4gdGhpcy5wYXJzZVZhbHVlKHRoaXMucHJvcHMudmFsdWUpO1xuICAgIH1cblxuICAgIC8vIE5vIGRlZmF1bHQgY29uZmlndXJhdGlvblxuICAgIGlmICghdGhpcy5wcm9wcy53aXRoRGVmYXVsdCkge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgLy8gQ3VzdG9tIGRlZmF1bHQgdmFsdWVcbiAgICBpZiAodHlwZW9mIHRoaXMucHJvcHMud2l0aERlZmF1bHQgPT09ICdzdHJpbmcnKSB7XG4gICAgICByZXR1cm4gdGhpcy5wYXJzZVZhbHVlKHRoaXMucHJvcHMud2l0aERlZmF1bHQpO1xuICAgIH1cblxuICAgIC8vIEF1dG8gZGVmYXVsdCB2YWx1ZSAod2l0aERlZmF1bHQgPT09IHRydWUpXG4gICAgcmV0dXJuIHsgZnJvbTogMCwgdG86IDAgfTtcbiAgfVxuXG4gIHByaXZhdGUgcGFyc2VWYWx1ZSh2YWx1ZTogc3RyaW5nKTogYW55IHtcbiAgICB0cnkge1xuICAgICAgLy8gVHJ5IHRvIHBhcnNlIGFzIEpTT04gZmlyc3QgKGZvciBvYmplY3QgdmFsdWVzKVxuICAgICAgcmV0dXJuIEpTT04ucGFyc2UodmFsdWUpO1xuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gSWYgbm90IEpTT04sIHRyZWF0IGFzIG51bWJlclxuICAgICAgY29uc3QgbnVtVmFsdWUgPSBwYXJzZUZsb2F0KHZhbHVlKSB8fCAwO1xuICAgICAgcmV0dXJuIHsgZnJvbTogbnVtVmFsdWUsIHRvOiBudW1WYWx1ZSB9O1xuICAgIH1cbiAgfVxuXG4gIGdldCBmcm9tQ29udHJvbCgpOiBGb3JtQ29udHJvbCB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMuZnJvbUNvbnRyb2w7XG4gIH1cblxuICBnZXQgdG9Db250cm9sKCk6IEZvcm1Db250cm9sIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy50b0NvbnRyb2w7XG4gIH1cbn1cbiJdfQ==
@@ -95,6 +95,7 @@ export class FormComponent {
95
95
  ...field,
96
96
  fromControl,
97
97
  toControl,
98
+ control: undefined, // Remove control for NUMBER_FROM_TO fields
98
99
  };
99
100
  }
100
101
  else {
@@ -314,4 +315,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
314
315
  }], onSelectChange: [{
315
316
  type: Output
316
317
  }] } });
317
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/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 { 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    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            <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(x => x.type === this.types.SELECT || x.type === this.types.TEXT || x.type === this.types.SEARCH_SELECT)\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      };\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"]}
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/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 { 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    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            <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(x => x.type === this.types.SELECT || x.type === this.types.TEXT || x.type === this.types.SEARCH_SELECT)\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"]}
@@ -1,6 +1,6 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { EventEmitter, Component, Input, Output, Injectable, inject, InjectionToken, Inject, ChangeDetectorRef, HostListener, Pipe, ChangeDetectionStrategy, ViewChild } from '@angular/core';
3
- import { IonAvatar, IonCard, IonIcon, IonButton, IonSpinner, IonText, IonModal, IonHeader, IonToolbar, IonContent, IonButtons, IonTitle, IonProgressBar, IonCardContent, IonCardHeader, IonCardTitle, IonCardSubtitle, IonCheckbox, IonTextarea, IonDatetime, IonDatetimeButton, IonInput, IonSelect, IonSelectOption, IonLabel, IonItem, IonRadioGroup, IonRadio, IonSearchbar, IonMenuButton, IonFooter, IonList, IonListHeader, IonNote } from '@ionic/angular/standalone';
3
+ import { IonAvatar, IonCard, IonIcon, IonButton, IonSpinner, IonText, IonModal, IonHeader, IonToolbar, IonContent, IonButtons, IonTitle, IonProgressBar, IonCardContent, IonCardHeader, IonCardTitle, IonCardSubtitle, IonCheckbox, IonTextarea, IonDatetime, IonDatetimeButton, IonInput, IonSelect, IonSelectOption, IonLabel, IonRadioGroup, IonRadio, IonSearchbar, IonMenuButton, IonFooter, IonList, IonListHeader, IonNote, IonItem } from '@ionic/angular/standalone';
4
4
  import * as i1 from '@angular/common';
5
5
  import { CommonModule, NgStyle, AsyncPipe, NgFor, NgClass } from '@angular/common';
6
6
  import { addIcons } from 'ionicons';
@@ -4048,19 +4048,44 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
4048
4048
  class HintComponent {
4049
4049
  constructor() { }
4050
4050
  ngOnInit() { }
4051
+ get shouldShowErrors() {
4052
+ if (this.props.control) {
4053
+ // Normal field with single control
4054
+ return this.props.control.invalid && (this.props.control.touched || this.props.control.dirty);
4055
+ }
4056
+ else if (this.props.fromControl && this.props.toControl) {
4057
+ // NUMBER_FROM_TO field with separate controls
4058
+ const fromInvalid = this.props.fromControl.invalid && (this.props.fromControl.touched || this.props.fromControl.dirty);
4059
+ const toInvalid = this.props.toControl.invalid && (this.props.toControl.touched || this.props.toControl.dirty);
4060
+ return fromInvalid || toInvalid;
4061
+ }
4062
+ return false;
4063
+ }
4051
4064
  get Errors() {
4052
- const keys = Object.keys(this.props.errors);
4065
+ const keys = Object.keys(this.props.errors || {});
4053
4066
  const errors = [];
4054
4067
  keys.map((e) => {
4055
- if (this.props.control.hasError(e)) {
4068
+ if (this.props.control && this.props.control.hasError(e)) {
4069
+ // Normal field
4056
4070
  errors.push(this.props.errors[e]);
4057
4071
  }
4072
+ else if (this.props.fromControl && this.props.toControl) {
4073
+ // NUMBER_FROM_TO field - check both controls
4074
+ const fromLabel = this.props.fromLabel || 'Inicial';
4075
+ const toLabel = this.props.toLabel || 'Final';
4076
+ if (this.props.fromControl.hasError(e)) {
4077
+ errors.push(`${fromLabel}: ${this.props.errors[e]}`);
4078
+ }
4079
+ if (this.props.toControl.hasError(e)) {
4080
+ errors.push(`${toLabel}: ${this.props.errors[e]}`);
4081
+ }
4082
+ }
4058
4083
  });
4059
4084
  return errors;
4060
4085
  }
4061
4086
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4062
4087
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: HintComponent, isStandalone: true, selector: "val-hint", inputs: { props: "props" }, ngImport: i0, template: `
4063
- <div class="hint-container" *ngIf="props.control.invalid && (props.control.touched || props.control.dirty)">
4088
+ <div class="hint-container" *ngIf="shouldShowErrors">
4064
4089
  <val-text
4065
4090
  *ngFor="let e of Errors"
4066
4091
  [props]="{
@@ -4076,7 +4101,7 @@ class HintComponent {
4076
4101
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: HintComponent, decorators: [{
4077
4102
  type: Component,
4078
4103
  args: [{ selector: 'val-hint', standalone: true, imports: [CommonModule, TextComponent], template: `
4079
- <div class="hint-container" *ngIf="props.control.invalid && (props.control.touched || props.control.dirty)">
4104
+ <div class="hint-container" *ngIf="shouldShowErrors">
4080
4105
  <val-text
4081
4106
  *ngFor="let e of Errors"
4082
4107
  [props]="{
@@ -5036,7 +5061,52 @@ class NumberFromToComponent {
5036
5061
  ngOnInit() {
5037
5062
  // Apply default values if configured
5038
5063
  if (this.props?.withDefault || this.props?.value) {
5039
- applyDefaultValueToControl(this.props);
5064
+ this.applyDefaultValues();
5065
+ }
5066
+ }
5067
+ applyDefaultValues() {
5068
+ const defaultValue = this.resolveDefaultValue();
5069
+ if (defaultValue !== null) {
5070
+ if (typeof defaultValue === 'object' && defaultValue.from !== undefined) {
5071
+ this.fromControl?.setValue(defaultValue.from);
5072
+ this.toControl?.setValue(defaultValue.to);
5073
+ }
5074
+ else {
5075
+ // Si es un valor simple, aplicarlo a ambos controles
5076
+ this.fromControl?.setValue(defaultValue);
5077
+ this.toControl?.setValue(defaultValue);
5078
+ }
5079
+ this.fromControl?.markAsPristine();
5080
+ this.toControl?.markAsPristine();
5081
+ this.fromControl?.updateValueAndValidity();
5082
+ this.toControl?.updateValueAndValidity();
5083
+ }
5084
+ }
5085
+ resolveDefaultValue() {
5086
+ // Explicit value takes precedence
5087
+ if (this.props.value !== undefined && this.props.value !== null && this.props.value !== '') {
5088
+ return this.parseValue(this.props.value);
5089
+ }
5090
+ // No default configuration
5091
+ if (!this.props.withDefault) {
5092
+ return null;
5093
+ }
5094
+ // Custom default value
5095
+ if (typeof this.props.withDefault === 'string') {
5096
+ return this.parseValue(this.props.withDefault);
5097
+ }
5098
+ // Auto default value (withDefault === true)
5099
+ return { from: 0, to: 0 };
5100
+ }
5101
+ parseValue(value) {
5102
+ try {
5103
+ // Try to parse as JSON first (for object values)
5104
+ return JSON.parse(value);
5105
+ }
5106
+ catch {
5107
+ // If not JSON, treat as number
5108
+ const numValue = parseFloat(value) || 0;
5109
+ return { from: numValue, to: numValue };
5040
5110
  }
5041
5111
  }
5042
5112
  get fromControl() {
@@ -5048,7 +5118,7 @@ class NumberFromToComponent {
5048
5118
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NumberFromToComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5049
5119
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NumberFromToComponent, isStandalone: true, selector: "val-number-from-to", inputs: { props: "props" }, ngImport: i0, template: `
5050
5120
  <div class="number-from-to-container">
5051
- <ion-label position="stacked">{{ props.fromLabel || 'Desde' }}</ion-label>
5121
+ <ion-label position="stacked">{{ props.fromLabel || 'Inicial' }}</ion-label>
5052
5122
  <ion-input
5053
5123
  [formControl]="fromControl"
5054
5124
  type="number"
@@ -5058,7 +5128,7 @@ class NumberFromToComponent {
5058
5128
  >
5059
5129
  </ion-input>
5060
5130
 
5061
- <ion-label position="stacked">{{ props.toLabel || 'Hasta' }}</ion-label>
5131
+ <ion-label position="stacked">{{ props.toLabel || 'Final' }}</ion-label>
5062
5132
  <ion-input
5063
5133
  [formControl]="toControl"
5064
5134
  type="number"
@@ -5072,9 +5142,9 @@ class NumberFromToComponent {
5072
5142
  }
5073
5143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NumberFromToComponent, decorators: [{
5074
5144
  type: Component,
5075
- args: [{ selector: 'val-number-from-to', standalone: true, imports: [ReactiveFormsModule, IonInput, IonItem, IonLabel], template: `
5145
+ args: [{ selector: 'val-number-from-to', standalone: true, imports: [ReactiveFormsModule, IonInput, IonLabel], template: `
5076
5146
  <div class="number-from-to-container">
5077
- <ion-label position="stacked">{{ props.fromLabel || 'Desde' }}</ion-label>
5147
+ <ion-label position="stacked">{{ props.fromLabel || 'Inicial' }}</ion-label>
5078
5148
  <ion-input
5079
5149
  [formControl]="fromControl"
5080
5150
  type="number"
@@ -5084,7 +5154,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
5084
5154
  >
5085
5155
  </ion-input>
5086
5156
 
5087
- <ion-label position="stacked">{{ props.toLabel || 'Hasta' }}</ion-label>
5157
+ <ion-label position="stacked">{{ props.toLabel || 'Final' }}</ion-label>
5088
5158
  <ion-input
5089
5159
  [formControl]="toControl"
5090
5160
  type="number"
@@ -7504,6 +7574,7 @@ class FormComponent {
7504
7574
  ...field,
7505
7575
  fromControl,
7506
7576
  toControl,
7577
+ control: undefined, // Remove control for NUMBER_FROM_TO fields
7507
7578
  };
7508
7579
  }
7509
7580
  else {