valtech-components 2.0.99 → 2.0.101

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.
@@ -23,6 +23,8 @@ export class SearchSelectorComponent {
23
23
  [interfaceOptions]="customModalOptions"
24
24
  interface="modal"
25
25
  [placeholder]="[props.placeholder]"
26
+ cancelText="Cancelar"
27
+ okText="Ok"
26
28
  >
27
29
  <ion-select-option *ngFor="let o of props.options" [value]="o.id">{{ o.name }}</ion-select-option>
28
30
  </ion-select>
@@ -37,6 +39,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
37
39
  [interfaceOptions]="customModalOptions"
38
40
  interface="modal"
39
41
  [placeholder]="[props.placeholder]"
42
+ cancelText="Cancelar"
43
+ okText="Ok"
40
44
  >
41
45
  <ion-select-option *ngFor="let o of props.options" [value]="o.id">{{ o.name }}</ion-select-option>
42
46
  </ion-select>
@@ -44,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
44
48
  }], ctorParameters: () => [], propDecorators: { props: [{
45
49
  type: Input
46
50
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLXNlbGVjdG9yLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3NlYXJjaC1zZWxlY3Rvci1pbnB1dC9zZWFyY2gtc2VsZWN0b3ItaW5wdXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7QUFvQnZFLE1BQU0sT0FBTyx1QkFBdUI7SUFTbEM7UUFOQSx1QkFBa0IsR0FBRztZQUNuQixNQUFNLEVBQUUsWUFBWTtZQUNwQixXQUFXLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDO1lBQ3JCLGlCQUFpQixFQUFFLEdBQUc7U0FDdkIsQ0FBQztJQUVhLENBQUM7SUFFaEIsUUFBUTtRQUNOLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7SUFDcEQsQ0FBQzsrR0FiVSx1QkFBdUI7bUdBQXZCLHVCQUF1QixpSEFieEI7Ozs7Ozs7Ozs7R0FVVCwwRUFYUyxLQUFLLGtIQUFFLG1CQUFtQiwwVEFBRSxTQUFTLHVUQUFFLGVBQWU7OzRGQWNyRCx1QkFBdUI7a0JBakJuQyxTQUFTOytCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1AsQ0FBQyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsU0FBUyxFQUFFLGVBQWUsQ0FBQyxZQUN2RDs7Ozs7Ozs7OztHQVVUO3dEQUlRLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nRm9yIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IElvblNlbGVjdCwgSW9uU2VsZWN0T3B0aW9uIH0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5pbXBvcnQgeyBJbnB1dE1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtc2VhcmNoLXNlbGVjdG9yLWlucHV0JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW05nRm9yLCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBJb25TZWxlY3QsIElvblNlbGVjdE9wdGlvbl0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGlvbi1zZWxlY3RcbiAgICAgIFtmb3JtQ29udHJvbF09XCJwcm9wcy5jb250cm9sXCJcbiAgICAgIFtsYWJlbF09XCJwcm9wcy5sYWJlbFwiXG4gICAgICBbaW50ZXJmYWNlT3B0aW9uc109XCJjdXN0b21Nb2RhbE9wdGlvbnNcIlxuICAgICAgaW50ZXJmYWNlPVwibW9kYWxcIlxuICAgICAgW3BsYWNlaG9sZGVyXT1cIltwcm9wcy5wbGFjZWhvbGRlcl1cIlxuICAgID5cbiAgICAgIDxpb24tc2VsZWN0LW9wdGlvbiAqbmdGb3I9XCJsZXQgbyBvZiBwcm9wcy5vcHRpb25zXCIgW3ZhbHVlXT1cIm8uaWRcIj57eyBvLm5hbWUgfX08L2lvbi1zZWxlY3Qtb3B0aW9uPlxuICAgIDwvaW9uLXNlbGVjdD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vc2VhcmNoLXNlbGVjdG9yLWlucHV0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFNlYXJjaFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcHJvcHM6IElucHV0TWV0YWRhdGE7XG5cbiAgY3VzdG9tTW9kYWxPcHRpb25zID0ge1xuICAgIGhlYWRlcjogJ1NlbGVjY2lvbmUnLFxuICAgIGJyZWFrcG9pbnRzOiBbMCwgMC42XSxcbiAgICBpbml0aWFsQnJlYWtwb2ludDogMC42LFxuICB9O1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmN1c3RvbU1vZGFsT3B0aW9ucy5oZWFkZXIgPSB0aGlzLnByb3BzLmxhYmVsO1xuICB9XG59XG4iXX0=
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLXNlbGVjdG9yLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3NlYXJjaC1zZWxlY3Rvci1pbnB1dC9zZWFyY2gtc2VsZWN0b3ItaW5wdXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsU0FBUyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7QUFzQnZFLE1BQU0sT0FBTyx1QkFBdUI7SUFTbEM7UUFOQSx1QkFBa0IsR0FBRztZQUNuQixNQUFNLEVBQUUsWUFBWTtZQUNwQixXQUFXLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDO1lBQ3JCLGlCQUFpQixFQUFFLEdBQUc7U0FDdkIsQ0FBQztJQUVhLENBQUM7SUFFaEIsUUFBUTtRQUNOLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUM7SUFDcEQsQ0FBQzsrR0FiVSx1QkFBdUI7bUdBQXZCLHVCQUF1QixpSEFmeEI7Ozs7Ozs7Ozs7OztHQVlULDBFQWJTLEtBQUssa0hBQUUsbUJBQW1CLDBUQUFFLFNBQVMsdVRBQUUsZUFBZTs7NEZBZ0JyRCx1QkFBdUI7a0JBbkJuQyxTQUFTOytCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1AsQ0FBQyxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsU0FBUyxFQUFFLGVBQWUsQ0FBQyxZQUN2RDs7Ozs7Ozs7Ozs7O0dBWVQ7d0RBSVEsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdGb3IgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgSW9uU2VsZWN0LCBJb25TZWxlY3RPcHRpb24gfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IElucHV0TWV0YWRhdGEgfSBmcm9tICcuLi8uLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1zZWFyY2gtc2VsZWN0b3ItaW5wdXQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdGb3IsIFJlYWN0aXZlRm9ybXNNb2R1bGUsIElvblNlbGVjdCwgSW9uU2VsZWN0T3B0aW9uXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8aW9uLXNlbGVjdFxuICAgICAgW2Zvcm1Db250cm9sXT1cInByb3BzLmNvbnRyb2xcIlxuICAgICAgW2xhYmVsXT1cInByb3BzLmxhYmVsXCJcbiAgICAgIFtpbnRlcmZhY2VPcHRpb25zXT1cImN1c3RvbU1vZGFsT3B0aW9uc1wiXG4gICAgICBpbnRlcmZhY2U9XCJtb2RhbFwiXG4gICAgICBbcGxhY2Vob2xkZXJdPVwiW3Byb3BzLnBsYWNlaG9sZGVyXVwiXG4gICAgICBjYW5jZWxUZXh0PVwiQ2FuY2VsYXJcIlxuICAgICAgb2tUZXh0PVwiT2tcIlxuICAgID5cbiAgICAgIDxpb24tc2VsZWN0LW9wdGlvbiAqbmdGb3I9XCJsZXQgbyBvZiBwcm9wcy5vcHRpb25zXCIgW3ZhbHVlXT1cIm8uaWRcIj57eyBvLm5hbWUgfX08L2lvbi1zZWxlY3Qtb3B0aW9uPlxuICAgIDwvaW9uLXNlbGVjdD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vc2VhcmNoLXNlbGVjdG9yLWlucHV0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFNlYXJjaFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcHJvcHM6IElucHV0TWV0YWRhdGE7XG5cbiAgY3VzdG9tTW9kYWxPcHRpb25zID0ge1xuICAgIGhlYWRlcjogJ1NlbGVjY2lvbmUnLFxuICAgIGJyZWFrcG9pbnRzOiBbMCwgMC42XSxcbiAgICBpbml0aWFsQnJlYWtwb2ludDogMC42LFxuICB9O1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmN1c3RvbU1vZGFsT3B0aW9ucy5oZWFkZXIgPSB0aGlzLnByb3BzLmxhYmVsO1xuICB9XG59XG4iXX0=
@@ -9,19 +9,28 @@ export class FormFooterComponent {
9
9
  }
10
10
  ngOnInit() { }
11
11
  async submitHandler(token) {
12
- this.onSubmit.emit({ fields: this.form.value, token });
12
+ this.onSubmit.emit({ fields: this.props.form.value, token });
13
13
  }
14
14
  get actions() {
15
- if (!this.form) {
15
+ if (!this.props.form) {
16
16
  return [];
17
17
  }
18
- if (this.form.valid) {
19
- this.action.state = ComponentStates.ENABLED;
18
+ if (this.props.form.valid) {
19
+ this.props.data.actions.state = ComponentStates.ENABLED;
20
20
  }
21
- return [this.action];
21
+ if (this.props.data.state === ComponentStates.WORKING) {
22
+ this.props.data.actions.state = ComponentStates.WORKING;
23
+ }
24
+ if (this.props.data.state === ComponentStates.ENABLED) {
25
+ this.props.data.actions.state = ComponentStates.ENABLED;
26
+ }
27
+ if (this.props.data.state === ComponentStates.DISABLED) {
28
+ this.props.data.actions.state = ComponentStates.DISABLED;
29
+ }
30
+ return [this.props.data.actions];
22
31
  }
23
32
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
24
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFooterComponent, isStandalone: true, selector: "val-form-footer", inputs: { form: "form", action: "action" }, outputs: { onSubmit: "onSubmit" }, ngImport: i0, template: `
33
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFooterComponent, isStandalone: true, selector: "val-form-footer", inputs: { props: "props", action: "action" }, outputs: { onSubmit: "onSubmit" }, ngImport: i0, template: `
25
34
  <val-footer
26
35
  [props]="{
27
36
  bordered: false,
@@ -66,11 +75,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
66
75
  ></val-button-group>
67
76
  </val-footer>
68
77
  ` }]
69
- }], ctorParameters: () => [], propDecorators: { form: [{
78
+ }], ctorParameters: () => [], propDecorators: { props: [{
70
79
  type: Input
71
80
  }], action: [{
72
81
  type: Input
73
82
  }], onSubmit: [{
74
83
  type: Output
75
84
  }] } });
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1mb290ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9vcmdhbmlzbXMvZm9ybS9mb3JtLWZvb3Rlci9mb3JtLWZvb3Rlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUM5RixPQUFPLEVBQWtCLGVBQWUsRUFBYyxNQUFNLGdCQUFnQixDQUFDO0FBQzdFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7QUE2QmhFLE1BQU0sT0FBTyxtQkFBbUI7SUFVOUI7UUFGQSxhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztJQUUzQixDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsS0FBSyxDQUFDLGFBQWEsQ0FBQyxLQUFjO1FBQ2hDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELElBQUksT0FBTztRQUNULElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDZixPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEdBQUcsZUFBZSxDQUFDLE9BQU8sQ0FBQztRQUM5QyxDQUFDO1FBRUQsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN2QixDQUFDOytHQTVCVSxtQkFBbUI7bUdBQW5CLG1CQUFtQiwwSkF2QnBCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVCwwRUFyQlMsZUFBZSxnR0FBRSxvQkFBb0I7OzRGQXdCcEMsbUJBQW1CO2tCQTNCL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLENBQUMsWUFDdEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JUO3dEQUtELElBQUk7c0JBREgsS0FBSztnQkFJTixNQUFNO3NCQURMLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQnV0dG9uR3JvdXBDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9tb2xlY3VsZXMvYnV0dG9uLWdyb3VwL2J1dHRvbi1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnV0dG9uTWV0YWRhdGEsIENvbXBvbmVudFN0YXRlcywgRm9ybVN1Ym1pdCB9IGZyb20gJy4uLy4uLy4uL3R5cGVzJztcbmltcG9ydCB7IEZvb3RlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2Zvb3Rlci9mb290ZXIuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWZvcm0tZm9vdGVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0Zvb3RlckNvbXBvbmVudCwgQnV0dG9uR3JvdXBDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDx2YWwtZm9vdGVyXG4gICAgICBbcHJvcHNdPVwie1xuICAgICAgICBib3JkZXJlZDogZmFsc2UsXG4gICAgICAgIHRyYW5zbHVjZW50OiBmYWxzZSxcbiAgICAgICAgdG9vbGJhcjoge1xuICAgICAgICAgIHRpdGxlOiAnJyxcbiAgICAgICAgICBhY3Rpb25zOiBbXSxcbiAgICAgICAgICBjb2xvcjogJ2JhY2tncm91bmQnLFxuICAgICAgICAgIHdpdGhCYWNrOiBmYWxzZSxcbiAgICAgICAgICB3aXRoQWN0aW9uczogZmFsc2UsXG4gICAgICAgIH0sXG4gICAgICB9XCJcbiAgICA+XG4gICAgICA8dmFsLWJ1dHRvbi1ncm91cFxuICAgICAgICBleHRyYVxuICAgICAgICBbcHJvcHNdPVwieyBidXR0b25zOiBhY3Rpb25zLCBwb3NpdGlvbjogJ2NlbnRlcicsIGNvbHVtbmVkOiBmYWxzZSB9XCJcbiAgICAgICAgKG9uQ2xpY2spPVwic3VibWl0SGFuZGxlcigkZXZlbnQpXCJcbiAgICAgID48L3ZhbC1idXR0b24tZ3JvdXA+XG4gICAgPC92YWwtZm9vdGVyPlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9mb3JtLWZvb3Rlci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGb3JtRm9vdGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgZm9ybTogRm9ybUdyb3VwO1xuXG4gIEBJbnB1dCgpXG4gIGFjdGlvbjogQnV0dG9uTWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uU3VibWl0ID0gbmV3IEV2ZW50RW1pdHRlcjxGb3JtU3VibWl0PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgYXN5bmMgc3VibWl0SGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25TdWJtaXQuZW1pdCh7IGZpZWxkczogdGhpcy5mb3JtLnZhbHVlLCB0b2tlbiB9KTtcbiAgfVxuXG4gIGdldCBhY3Rpb25zKCk6IEJ1dHRvbk1ldGFkYXRhW10ge1xuICAgIGlmICghdGhpcy5mb3JtKSB7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuZm9ybS52YWxpZCkge1xuICAgICAgdGhpcy5hY3Rpb24uc3RhdGUgPSBDb21wb25lbnRTdGF0ZXMuRU5BQkxFRDtcbiAgICB9XG5cbiAgICByZXR1cm4gW3RoaXMuYWN0aW9uXTtcbiAgfVxufVxuIl19
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1mb290ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9vcmdhbmlzbXMvZm9ybS9mb3JtLWZvb3Rlci9mb3JtLWZvb3Rlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUM5RixPQUFPLEVBQWtCLGVBQWUsRUFBNEIsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBNkJoRSxNQUFNLE9BQU8sbUJBQW1CO0lBVTlCO1FBRkEsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7SUFFM0IsQ0FBQztJQUVoQixRQUFRLEtBQUksQ0FBQztJQUViLEtBQUssQ0FBQyxhQUFhLENBQUMsS0FBYztRQUNoQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDckIsT0FBTyxFQUFFLENBQUM7UUFDWixDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDMUQsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN0RCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDMUQsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN0RCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUM7UUFDMUQsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLGVBQWUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN2RCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxRQUFRLENBQUM7UUFDM0QsQ0FBQztRQUVELE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNuQyxDQUFDOytHQXhDVSxtQkFBbUI7bUdBQW5CLG1CQUFtQiw0SkF2QnBCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CVCwwRUFyQlMsZUFBZSxnR0FBRSxvQkFBb0I7OzRGQXdCcEMsbUJBQW1CO2tCQTNCL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLENBQUMsWUFDdEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JUO3dEQUtELEtBQUs7c0JBREosS0FBSztnQkFJTixNQUFNO3NCQURMLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQnV0dG9uR3JvdXBDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9tb2xlY3VsZXMvYnV0dG9uLWdyb3VwL2J1dHRvbi1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnV0dG9uTWV0YWRhdGEsIENvbXBvbmVudFN0YXRlcywgRm9ybU1ldGFkYXRhLCBGb3JtU3VibWl0IH0gZnJvbSAnLi4vLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgRm9vdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZm9vdGVyL2Zvb3Rlci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtZm9ybS1mb290ZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRm9vdGVyQ29tcG9uZW50LCBCdXR0b25Hcm91cENvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPHZhbC1mb290ZXJcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIGJvcmRlcmVkOiBmYWxzZSxcbiAgICAgICAgdHJhbnNsdWNlbnQ6IGZhbHNlLFxuICAgICAgICB0b29sYmFyOiB7XG4gICAgICAgICAgdGl0bGU6ICcnLFxuICAgICAgICAgIGFjdGlvbnM6IFtdLFxuICAgICAgICAgIGNvbG9yOiAnYmFja2dyb3VuZCcsXG4gICAgICAgICAgd2l0aEJhY2s6IGZhbHNlLFxuICAgICAgICAgIHdpdGhBY3Rpb25zOiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgIH1cIlxuICAgID5cbiAgICAgIDx2YWwtYnV0dG9uLWdyb3VwXG4gICAgICAgIGV4dHJhXG4gICAgICAgIFtwcm9wc109XCJ7IGJ1dHRvbnM6IGFjdGlvbnMsIHBvc2l0aW9uOiAnY2VudGVyJywgY29sdW1uZWQ6IGZhbHNlIH1cIlxuICAgICAgICAob25DbGljayk9XCJzdWJtaXRIYW5kbGVyKCRldmVudClcIlxuICAgICAgPjwvdmFsLWJ1dHRvbi1ncm91cD5cbiAgICA8L3ZhbC1mb290ZXI+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2Zvcm0tZm9vdGVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1Gb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwcm9wczogeyBmb3JtOiBGb3JtR3JvdXA7IGRhdGE6IEZvcm1NZXRhZGF0YSB9O1xuXG4gIEBJbnB1dCgpXG4gIGFjdGlvbjogQnV0dG9uTWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uU3VibWl0ID0gbmV3IEV2ZW50RW1pdHRlcjxGb3JtU3VibWl0PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgYXN5bmMgc3VibWl0SGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25TdWJtaXQuZW1pdCh7IGZpZWxkczogdGhpcy5wcm9wcy5mb3JtLnZhbHVlLCB0b2tlbiB9KTtcbiAgfVxuXG4gIGdldCBhY3Rpb25zKCk6IEJ1dHRvbk1ldGFkYXRhW10ge1xuICAgIGlmICghdGhpcy5wcm9wcy5mb3JtKSB7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuXG4gICAgaWYgKHRoaXMucHJvcHMuZm9ybS52YWxpZCkge1xuICAgICAgdGhpcy5wcm9wcy5kYXRhLmFjdGlvbnMuc3RhdGUgPSBDb21wb25lbnRTdGF0ZXMuRU5BQkxFRDtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wcm9wcy5kYXRhLnN0YXRlID09PSBDb21wb25lbnRTdGF0ZXMuV09SS0lORykge1xuICAgICAgdGhpcy5wcm9wcy5kYXRhLmFjdGlvbnMuc3RhdGUgPSBDb21wb25lbnRTdGF0ZXMuV09SS0lORztcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wcm9wcy5kYXRhLnN0YXRlID09PSBDb21wb25lbnRTdGF0ZXMuRU5BQkxFRCkge1xuICAgICAgdGhpcy5wcm9wcy5kYXRhLmFjdGlvbnMuc3RhdGUgPSBDb21wb25lbnRTdGF0ZXMuRU5BQkxFRDtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5wcm9wcy5kYXRhLnN0YXRlID09PSBDb21wb25lbnRTdGF0ZXMuRElTQUJMRUQpIHtcbiAgICAgIHRoaXMucHJvcHMuZGF0YS5hY3Rpb25zLnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLkRJU0FCTEVEO1xuICAgIH1cblxuICAgIHJldHVybiBbdGhpcy5wcm9wcy5kYXRhLmFjdGlvbnNdO1xuICB9XG59XG4iXX0=
@@ -38,12 +38,16 @@ export class FormComponent {
38
38
  this.props.sections.forEach(section => {
39
39
  section.fields.forEach(field => {
40
40
  formControls[field.name] = [undefined, field.validators || []];
41
- if (field.type === this.types.SELECT) {
42
- this.trackSelectChanges(field.name);
43
- }
44
41
  });
45
42
  });
46
43
  this.form = this.fb.group(formControls);
44
+ this.props.sections.forEach(section => {
45
+ section.fields
46
+ .filter(x => x.type === this.types.SELECT)
47
+ .forEach(field => {
48
+ this.trackSelectChanges(field.name);
49
+ });
50
+ });
47
51
  }
48
52
  ngOnDestroy() {
49
53
  // Cleanup subscriptions to avoid memory leaks
@@ -63,6 +67,10 @@ export class FormComponent {
63
67
  return this.Form.get(field);
64
68
  }
65
69
  getFieldProp(field) {
70
+ field.token;
71
+ if (!field.token) {
72
+ field.token = `input-${field.type}-${field.name}`;
73
+ }
66
74
  return {
67
75
  ...field,
68
76
  control: this.getControl(field.name),
@@ -74,6 +82,12 @@ export class FormComponent {
74
82
  get Form() {
75
83
  return this.form;
76
84
  }
85
+ get FormState() {
86
+ return {
87
+ form: this.Form,
88
+ data: this.props,
89
+ };
90
+ }
77
91
  get actions() {
78
92
  if (!this.form) {
79
93
  return [];
@@ -249,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
249
263
  }], onSelectChange: [{
250
264
  type: Output
251
265
  }] } });
252
- //# 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 { 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 { 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/search-selector-input/search-selector-input.component';\nimport { TextInputComponent } from '../../molecules/text-input/text-input.component';\nimport { ButtonMetadata, ComponentStates, FormMetadata, FormSubmit, InputMetadata, InputType } from '../../types';\nimport { Subscription } from 'rxjs';\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    RadioInputComponent,\n    PasswordInputComponent,\n    PinInputComponent,\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.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-search-selector-input [props]=\"getFieldProp(f)\"></val-search-selector-input>\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        </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        formControls[field.name] = [undefined, field.validators || []];\n\n        if (field.type === this.types.SELECT) {\n          this.trackSelectChanges(field.name);\n        }\n      });\n    });\n    this.form = this.fb.group(formControls);\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.value, token });\n  }\n\n  getControl(field: string): FormControl {\n    return this.Form.get(field) as FormControl;\n  }\n\n  getFieldProp(field: InputMetadata): InputMetadata {\n    return {\n      ...field,\n      control: this.getControl(field.name),\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 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"]}
266
+ //# 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 { 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/search-selector-input/search-selector-input.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    RadioInputComponent,\n    PasswordInputComponent,\n    PinInputComponent,\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.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-search-selector-input [props]=\"getFieldProp(f)\"></val-search-selector-input>\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        </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        formControls[field.name] = [undefined, field.validators || []];\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)\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.value, 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    return {\n      ...field,\n      control: this.getControl(field.name),\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"]}
@@ -2075,6 +2075,8 @@ class SearchSelectorComponent {
2075
2075
  [interfaceOptions]="customModalOptions"
2076
2076
  interface="modal"
2077
2077
  [placeholder]="[props.placeholder]"
2078
+ cancelText="Cancelar"
2079
+ okText="Ok"
2078
2080
  >
2079
2081
  <ion-select-option *ngFor="let o of props.options" [value]="o.id">{{ o.name }}</ion-select-option>
2080
2082
  </ion-select>
@@ -2089,6 +2091,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2089
2091
  [interfaceOptions]="customModalOptions"
2090
2092
  interface="modal"
2091
2093
  [placeholder]="[props.placeholder]"
2094
+ cancelText="Cancelar"
2095
+ okText="Ok"
2092
2096
  >
2093
2097
  <ion-select-option *ngFor="let o of props.options" [value]="o.id">{{ o.name }}</ion-select-option>
2094
2098
  </ion-select>
@@ -2459,19 +2463,28 @@ class FormFooterComponent {
2459
2463
  }
2460
2464
  ngOnInit() { }
2461
2465
  async submitHandler(token) {
2462
- this.onSubmit.emit({ fields: this.form.value, token });
2466
+ this.onSubmit.emit({ fields: this.props.form.value, token });
2463
2467
  }
2464
2468
  get actions() {
2465
- if (!this.form) {
2469
+ if (!this.props.form) {
2466
2470
  return [];
2467
2471
  }
2468
- if (this.form.valid) {
2469
- this.action.state = ComponentStates.ENABLED;
2472
+ if (this.props.form.valid) {
2473
+ this.props.data.actions.state = ComponentStates.ENABLED;
2474
+ }
2475
+ if (this.props.data.state === ComponentStates.WORKING) {
2476
+ this.props.data.actions.state = ComponentStates.WORKING;
2470
2477
  }
2471
- return [this.action];
2478
+ if (this.props.data.state === ComponentStates.ENABLED) {
2479
+ this.props.data.actions.state = ComponentStates.ENABLED;
2480
+ }
2481
+ if (this.props.data.state === ComponentStates.DISABLED) {
2482
+ this.props.data.actions.state = ComponentStates.DISABLED;
2483
+ }
2484
+ return [this.props.data.actions];
2472
2485
  }
2473
2486
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
2474
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFooterComponent, isStandalone: true, selector: "val-form-footer", inputs: { form: "form", action: "action" }, outputs: { onSubmit: "onSubmit" }, ngImport: i0, template: `
2487
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFooterComponent, isStandalone: true, selector: "val-form-footer", inputs: { props: "props", action: "action" }, outputs: { onSubmit: "onSubmit" }, ngImport: i0, template: `
2475
2488
  <val-footer
2476
2489
  [props]="{
2477
2490
  bordered: false,
@@ -2516,7 +2529,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
2516
2529
  ></val-button-group>
2517
2530
  </val-footer>
2518
2531
  ` }]
2519
- }], ctorParameters: () => [], propDecorators: { form: [{
2532
+ }], ctorParameters: () => [], propDecorators: { props: [{
2520
2533
  type: Input
2521
2534
  }], action: [{
2522
2535
  type: Input
@@ -2556,12 +2569,16 @@ class FormComponent {
2556
2569
  this.props.sections.forEach(section => {
2557
2570
  section.fields.forEach(field => {
2558
2571
  formControls[field.name] = [undefined, field.validators || []];
2559
- if (field.type === this.types.SELECT) {
2560
- this.trackSelectChanges(field.name);
2561
- }
2562
2572
  });
2563
2573
  });
2564
2574
  this.form = this.fb.group(formControls);
2575
+ this.props.sections.forEach(section => {
2576
+ section.fields
2577
+ .filter(x => x.type === this.types.SELECT)
2578
+ .forEach(field => {
2579
+ this.trackSelectChanges(field.name);
2580
+ });
2581
+ });
2565
2582
  }
2566
2583
  ngOnDestroy() {
2567
2584
  // Cleanup subscriptions to avoid memory leaks
@@ -2581,6 +2598,10 @@ class FormComponent {
2581
2598
  return this.Form.get(field);
2582
2599
  }
2583
2600
  getFieldProp(field) {
2601
+ field.token;
2602
+ if (!field.token) {
2603
+ field.token = `input-${field.type}-${field.name}`;
2604
+ }
2584
2605
  return {
2585
2606
  ...field,
2586
2607
  control: this.getControl(field.name),
@@ -2592,6 +2613,12 @@ class FormComponent {
2592
2613
  get Form() {
2593
2614
  return this.form;
2594
2615
  }
2616
+ get FormState() {
2617
+ return {
2618
+ form: this.Form,
2619
+ data: this.props,
2620
+ };
2621
+ }
2595
2622
  get actions() {
2596
2623
  if (!this.form) {
2597
2624
  return [];