valtech-components 2.0.343 → 2.0.344

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.
@@ -1,5 +1,5 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { Component, EventEmitter, Input, Output, } from '@angular/core';
3
3
  import { goToTop } from '../../../shared/utils/dom';
4
4
  import { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';
5
5
  import { ComponentStates } from '../../types';
@@ -7,92 +7,73 @@ import { NoContentComponent } from '../no-content/no-content.component';
7
7
  import { MOTION } from './types';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common";
10
- /**
11
- * WizardComponent
12
- *
13
- * Componente para flujos de pasos (wizard) reutilizable, con soporte para estados, errores y navegación entre pasos.
14
- * Permite mostrar contenido personalizado por paso y manejar acciones de navegación.
15
- *
16
- * @example
17
- * <val-wizard [props]="wizardProps" (onClick)="handleWizardNav($event)">
18
- * <div step>Contenido del paso</div>
19
- * </val-wizard>
20
- *
21
- * @input props {WizardMetadata} - Metadatos del wizard, pasos y estado.
22
- * @output onClick - Emite el paso actual y la acción de navegación (MOTION).
23
- */
24
10
  export class WizardComponent {
25
- constructor() {
26
- /**
27
- * Evento emitido al hacer click en una acción de navegación.
28
- */
11
+ constructor(cdr) {
12
+ this.cdr = cdr;
29
13
  this.onClick = new EventEmitter();
30
14
  this.wrapperId = 'wizard-wrapper';
15
+ this.currentStep = null;
16
+ }
17
+ ngOnInit() {
18
+ this.updateCurrentStep();
19
+ }
20
+ ngOnChanges(changes) {
21
+ if (changes['props']) {
22
+ this.updateCurrentStep();
23
+ this.cdr.detectChanges();
24
+ }
25
+ }
26
+ updateCurrentStep() {
27
+ if (this.props?.steps && this.props.current) {
28
+ this.currentStep = this.props.steps[this.props.current];
29
+ }
31
30
  }
32
- ngOnInit() { }
33
- /**
34
- * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.
35
- */
36
31
  working() {
37
32
  this.props.state = ComponentStates.WORKING;
38
- this.Current.buttons.map(x => {
39
- x.state = ComponentStates.DISABLED;
40
- });
33
+ if (this.currentStep?.buttons) {
34
+ this.currentStep.buttons.forEach(button => {
35
+ button.state = ComponentStates.DISABLED;
36
+ });
37
+ }
38
+ this.cdr.detectChanges();
41
39
  }
42
- /**
43
- * Cambia el estado del wizard a 'ENABLED' y habilita los botones del paso actual.
44
- * No realiza cambios si ya está en estado 'ENABLED'.
45
- */
46
40
  done() {
47
41
  if (this.props.state === ComponentStates.ENABLED) {
48
42
  return;
49
43
  }
50
44
  this.props.state = ComponentStates.ENABLED;
51
- this.Current.buttons.map(x => {
52
- x.state = ComponentStates.ENABLED;
53
- });
45
+ if (this.currentStep?.buttons) {
46
+ this.currentStep.buttons.forEach(button => {
47
+ button.state = ComponentStates.ENABLED;
48
+ });
49
+ }
50
+ this.cdr.detectChanges();
54
51
  }
55
- /**
56
- * Devuelve el paso actual del wizard.
57
- */
58
52
  get Current() {
59
- return this.props.steps[this.props.current];
53
+ return this.currentStep || this.props.steps[this.props.current];
60
54
  }
61
- /**
62
- * Cambia el paso actual del wizard y hace scroll al inicio.
63
- * @param newStep Nuevo índice de paso
64
- */
65
55
  setCurrent(newStep) {
66
56
  if (newStep === this.props.current) {
67
57
  return;
68
58
  }
69
59
  this.props.current = newStep;
60
+ this.updateCurrentStep();
61
+ this.cdr.detectChanges();
70
62
  goToTop(this.wrapperId);
71
63
  }
72
- /**
73
- * Establece el estado de error y muestra el mensaje de error en el banner inferior.
74
- * @param error Mensaje de error a mostrar
75
- */
76
64
  setError(error) {
77
65
  if (this.props.state === ComponentStates.ERROR) {
78
66
  return;
79
67
  }
80
68
  this.props.error.titles.bottomContent.content.bellowTitle.content = error;
81
69
  this.props.state = ComponentStates.ERROR;
70
+ this.cdr.detectChanges();
82
71
  goToTop(this.wrapperId);
83
72
  }
84
- /**
85
- * Reinicia el estado de error y vuelve a estado 'ENABLED'.
86
- */
87
73
  reset() {
88
74
  this.props.error.titles.bottomContent.content.bellowTitle.content = '';
89
75
  this.done();
90
76
  }
91
- /**
92
- * Maneja el click en el banner de error y emite el evento de navegación.
93
- * Si el token contiene 'retry', reinicia el wizard.
94
- * @param token Token de la acción clicada
95
- */
96
77
  clickHandler(token) {
97
78
  if (!token) {
98
79
  return;
@@ -102,11 +83,11 @@ export class WizardComponent {
102
83
  }
103
84
  this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });
104
85
  }
105
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
106
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardComponent, isStandalone: true, selector: "val-wizard", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
86
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
87
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardComponent, isStandalone: true, selector: "val-wizard", inputs: { props: "props" }, outputs: { onClick: "onClick" }, usesOnChanges: true, ngImport: i0, template: `
107
88
  <div [id]="wrapperId" class="wrapper">
108
89
  <ng-container *ngIf="props.state !== 'ERROR'">
109
- <val-no-content [props]="Current.titles"></val-no-content>
90
+ <val-no-content *ngIf="currentStep" [props]="currentStep.titles"></val-no-content>
110
91
  <div class="step">
111
92
  <div *ngIf="props.state === 'WORKING'">
112
93
  <val-content-loader
@@ -132,7 +113,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
132
113
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
133
114
  <div [id]="wrapperId" class="wrapper">
134
115
  <ng-container *ngIf="props.state !== 'ERROR'">
135
- <val-no-content [props]="Current.titles"></val-no-content>
116
+ <val-no-content *ngIf="currentStep" [props]="currentStep.titles"></val-no-content>
136
117
  <div class="step">
137
118
  <div *ngIf="props.state === 'WORKING'">
138
119
  <val-content-loader
@@ -152,9 +133,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
152
133
  </ng-container>
153
134
  </div>
154
135
  `, styles: [":root{--ion-color-primary: #7026df;--ion-color-primary-rgb: 112, 38, 223;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #6321c4;--ion-color-primary-tint: #7e3ce2;--ion-color-secondary: #e2ccff;--ion-color-secondary-rgb: 226, 204, 255;--ion-color-secondary-contrast: #000000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #c7b4e0;--ion-color-secondary-tint: #e5d1ff;--ion-color-texti: #354c69;--ion-color-texti-rgb: 53, 76, 105;--ion-color-texti-contrast: #ffffff;--ion-color-texti-contrast-rgb: 255, 255, 255;--ion-color-texti-shade: #2f435c;--ion-color-texti-tint: #495e78;--ion-color-darki: #090f1b;--ion-color-darki-rgb: 9, 15, 27;--ion-color-darki-contrast: #ffffff;--ion-color-darki-contrast-rgb: 255, 255, 255;--ion-color-darki-shade: #080d18;--ion-color-darki-tint: #222732;--ion-color-medium: #9e9e9e;--ion-color-medium-rgb: 158, 158, 158;--ion-color-medium-contrast: #000000;--ion-color-medium-contrast-rgb: 0, 0, 0;--ion-color-medium-shade: #8b8b8b;--ion-color-medium-tint: #a8a8a8;--swiper-pagination-color: var(--ion-color-primary);--swiper-navigation-color: var(--ion-color-primary);--swiper-pagination-bullet-inactive-color: var(--ion-color-medium)}@media (prefers-color-scheme: dark){:root{--ion-color-texti: #8fc1ff;--ion-color-texti-rgb: 143, 193, 255;--ion-color-texti-contrast: #000000;--ion-color-texti-contrast-rgb: 0, 0, 0;--ion-color-texti-shade: #7eaae0;--ion-color-texti-tint: #9ac7ff;--ion-color-darki: #ffffff;--ion-color-darki-rgb: 255, 255, 255;--ion-color-darki-contrast: #000000;--ion-color-darki-contrast-rgb: 0, 0, 0;--ion-color-darki-shade: #e0e0e0;--ion-color-darki-tint: #ffffff;--ion-color-primary: #8f49f8;--ion-color-primary-rgb: 143, 73, 248;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #7e40da;--ion-color-primary-tint: #9a5bf9}}.ion-color-texti{--ion-color-base: var(--ion-color-texti);--ion-color-base-rgb: var(--ion-color-texti-rgb);--ion-color-contrast: var(--ion-color-texti-contrast);--ion-color-contrast-rgb: var(--ion-color-texti-contrast-rgb);--ion-color-shade: var(--ion-color-texti-shade);--ion-color-tint: var(--ion-color-texti-tint)}.ion-color-darki{--ion-color-base: var(--ion-color-darki);--ion-color-base-rgb: var(--ion-color-darki-rgb);--ion-color-contrast: var(--ion-color-darki-contrast);--ion-color-contrast-rgb: var(--ion-color-darki-contrast-rgb);--ion-color-shade: var(--ion-color-darki-shade);--ion-color-tint: var(--ion-color-darki-tint)}.wrapper{height:auto;display:flex;flex-direction:column;justify-content:space-between;position:relative;min-height:320px}.step{min-height:9.375rem;margin:16px 0;text-align:center}\n"] }]
155
- }], ctorParameters: () => [], propDecorators: { props: [{
136
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
156
137
  type: Input
157
138
  }], onClick: [{
158
139
  type: Output
159
140
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/wizard/wizard.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,yDAAyD,CAAC;AACjG,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,MAAM,EAAwB,MAAM,SAAS,CAAC;;;AA+BvD;;;;;;;;;;;;;GAaG;AACH,MAAM,OAAO,eAAe;IAe1B;QARA;;WAEG;QAEH,YAAO,GAAG,IAAI,YAAY,EAAuC,CAAC;QAElE,cAAS,GAAG,gBAAgB,CAAC;IAEd,CAAC;IAEhB,QAAQ,KAAI,CAAC;IAEb;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC3B,CAAC,CAAC,KAAK,GAAG,eAAe,CAAC,QAAQ,CAAC;QACrC,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACH,IAAI;QACF,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,eAAe,CAAC,OAAO,EAAE,CAAC;YACjD,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3C,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC3B,CAAC,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QACpC,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,OAAe;QACxB,IAAI,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAC7B,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,KAAa;QACpB,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,eAAe,CAAC,KAAK,EAAE,CAAC;YAC/C,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,GAAG,KAAK,CAAC;QAC1E,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,KAAK,CAAC;QACzC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,GAAG,EAAE,CAAC;QACvE,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAC,KAAc;QACzB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO;QACT,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;IAC3E,CAAC;+GAnGU,eAAe;mGAAf,eAAe,mIAvChB;;;;;;;;;;;;;;;;;;;;;;GAsBT,kwFAvBS,YAAY,mIAAE,kBAAkB,oGAAE,sBAAsB;;4FAwCvD,eAAe;kBA3C3B,SAAS;+BACE,YAAY,cACV,IAAI,WACP,CAAC,YAAY,EAAE,kBAAkB,EAAE,sBAAsB,CAAC,YACzD;;;;;;;;;;;;;;;;;;;;;;GAsBT;wDAsBD,KAAK;sBADJ,KAAK;gBAON,OAAO;sBADN,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { goToTop } from '../../../shared/utils/dom';\nimport { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';\nimport { ComponentStates } from '../../types';\nimport { NoContentComponent } from '../no-content/no-content.component';\nimport { MOTION, Step, WizardMetadata } from './types';\n\n@Component({\n  selector: 'val-wizard',\n  standalone: true,\n  imports: [CommonModule, NoContentComponent, ContentLoaderComponent],\n  template: `\n    <div [id]=\"wrapperId\" class=\"wrapper\">\n      <ng-container *ngIf=\"props.state !== 'ERROR'\">\n        <val-no-content [props]=\"Current.titles\"></val-no-content>\n        <div class=\"step\">\n          <div *ngIf=\"props.state === 'WORKING'\">\n            <val-content-loader\n              [props]=\"{\n                name: 'circular',\n                color: 'primary',\n                size: 'large',\n                text: 'Por favor espere...',\n              }\"\n            />\n          </div>\n          <ng-content select=\"[step]\"></ng-content>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"props.state === 'ERROR'\">\n        <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n      </ng-container>\n    </div>\n  `,\n  styleUrls: ['./wizard.component.scss'],\n})\n/**\n * WizardComponent\n *\n * Componente para flujos de pasos (wizard) reutilizable, con soporte para estados, errores y navegación entre pasos.\n * Permite mostrar contenido personalizado por paso y manejar acciones de navegación.\n *\n * @example\n * <val-wizard [props]=\"wizardProps\" (onClick)=\"handleWizardNav($event)\">\n *   <div step>Contenido del paso</div>\n * </val-wizard>\n *\n * @input props {WizardMetadata} - Metadatos del wizard, pasos y estado.\n * @output onClick - Emite el paso actual y la acción de navegación (MOTION).\n */\nexport class WizardComponent implements OnInit {\n  /**\n   * Metadatos del wizard, pasos y estado.\n   */\n  @Input()\n  props: WizardMetadata;\n\n  /**\n   * Evento emitido al hacer click en una acción de navegación.\n   */\n  @Output()\n  onClick = new EventEmitter<{ current: number; motion: MOTION }>();\n\n  wrapperId = 'wizard-wrapper';\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  /**\n   * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.\n   */\n  working() {\n    this.props.state = ComponentStates.WORKING;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.DISABLED;\n    });\n  }\n\n  /**\n   * Cambia el estado del wizard a 'ENABLED' y habilita los botones del paso actual.\n   * No realiza cambios si ya está en estado 'ENABLED'.\n   */\n  done() {\n    if (this.props.state === ComponentStates.ENABLED) {\n      return;\n    }\n\n    this.props.state = ComponentStates.ENABLED;\n    this.Current.buttons.map(x => {\n      x.state = ComponentStates.ENABLED;\n    });\n  }\n\n  /**\n   * Devuelve el paso actual del wizard.\n   */\n  get Current(): Step {\n    return this.props.steps[this.props.current];\n  }\n\n  /**\n   * Cambia el paso actual del wizard y hace scroll al inicio.\n   * @param newStep Nuevo índice de paso\n   */\n  setCurrent(newStep: number) {\n    if (newStep === this.props.current) {\n      return;\n    }\n    this.props.current = newStep;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Establece el estado de error y muestra el mensaje de error en el banner inferior.\n   * @param error Mensaje de error a mostrar\n   */\n  setError(error: string) {\n    if (this.props.state === ComponentStates.ERROR) {\n      return;\n    }\n\n    this.props.error.titles.bottomContent.content.bellowTitle.content = error;\n    this.props.state = ComponentStates.ERROR;\n    goToTop(this.wrapperId);\n  }\n\n  /**\n   * Reinicia el estado de error y vuelve a estado 'ENABLED'.\n   */\n  reset() {\n    this.props.error.titles.bottomContent.content.bellowTitle.content = '';\n    this.done();\n  }\n\n  /**\n   * Maneja el click en el banner de error y emite el evento de navegación.\n   * Si el token contiene 'retry', reinicia el wizard.\n   * @param token Token de la acción clicada\n   */\n  clickHandler(token?: string) {\n    if (!token) {\n      return;\n    }\n    if (token.includes('retry')) {\n      this.reset();\n    }\n\n    this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });\n  }\n}\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/wizard/wizard.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { goToTop } from '../../../shared/utils/dom';\nimport { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';\nimport { ComponentStates } from '../../types';\nimport { NoContentComponent } from '../no-content/no-content.component';\nimport { MOTION, Step, WizardMetadata } from './types';\n\n@Component({\n  selector: 'val-wizard',\n  standalone: true,\n  imports: [CommonModule, NoContentComponent, ContentLoaderComponent],\n  template: `\n    <div [id]=\"wrapperId\" class=\"wrapper\">\n      <ng-container *ngIf=\"props.state !== 'ERROR'\">\n        <val-no-content *ngIf=\"currentStep\" [props]=\"currentStep.titles\"></val-no-content>\n        <div class=\"step\">\n          <div *ngIf=\"props.state === 'WORKING'\">\n            <val-content-loader\n              [props]=\"{\n                name: 'circular',\n                color: 'primary',\n                size: 'large',\n                text: 'Por favor espere...',\n              }\"\n            />\n          </div>\n          <ng-content select=\"[step]\"></ng-content>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"props.state === 'ERROR'\">\n        <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n      </ng-container>\n    </div>\n  `,\n  styleUrls: ['./wizard.component.scss'],\n})\nexport class WizardComponent implements OnInit, OnChanges {\n  @Input()\n  props: WizardMetadata;\n\n  @Output()\n  onClick = new EventEmitter<{ current: number; motion: MOTION }>();\n\n  wrapperId = 'wizard-wrapper';\n  currentStep: Step | null = null;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.updateCurrentStep();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['props']) {\n      this.updateCurrentStep();\n      this.cdr.detectChanges();\n    }\n  }\n\n  private updateCurrentStep(): void {\n    if (this.props?.steps && this.props.current) {\n      this.currentStep = this.props.steps[this.props.current];\n    }\n  }\n\n  working() {\n    this.props.state = ComponentStates.WORKING;\n    if (this.currentStep?.buttons) {\n      this.currentStep.buttons.forEach(button => {\n        button.state = ComponentStates.DISABLED;\n      });\n    }\n    this.cdr.detectChanges();\n  }\n\n  done() {\n    if (this.props.state === ComponentStates.ENABLED) {\n      return;\n    }\n\n    this.props.state = ComponentStates.ENABLED;\n    if (this.currentStep?.buttons) {\n      this.currentStep.buttons.forEach(button => {\n        button.state = ComponentStates.ENABLED;\n      });\n    }\n    this.cdr.detectChanges();\n  }\n\n  get Current(): Step {\n    return this.currentStep || this.props.steps[this.props.current];\n  }\n\n  setCurrent(newStep: number) {\n    if (newStep === this.props.current) {\n      return;\n    }\n    this.props.current = newStep;\n    this.updateCurrentStep();\n    this.cdr.detectChanges();\n    goToTop(this.wrapperId);\n  }\n\n  setError(error: string) {\n    if (this.props.state === ComponentStates.ERROR) {\n      return;\n    }\n\n    this.props.error.titles.bottomContent.content.bellowTitle.content = error;\n    this.props.state = ComponentStates.ERROR;\n    this.cdr.detectChanges();\n    goToTop(this.wrapperId);\n  }\n\n  reset() {\n    this.props.error.titles.bottomContent.content.bellowTitle.content = '';\n    this.done();\n  }\n\n  clickHandler(token?: string) {\n    if (!token) {\n      return;\n    }\n    if (token.includes('retry')) {\n      this.reset();\n    }\n\n    this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });\n  }\n}\n"]}
@@ -7825,92 +7825,73 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7825
7825
  type: Output
7826
7826
  }] } });
7827
7827
 
7828
- /**
7829
- * WizardComponent
7830
- *
7831
- * Componente para flujos de pasos (wizard) reutilizable, con soporte para estados, errores y navegación entre pasos.
7832
- * Permite mostrar contenido personalizado por paso y manejar acciones de navegación.
7833
- *
7834
- * @example
7835
- * <val-wizard [props]="wizardProps" (onClick)="handleWizardNav($event)">
7836
- * <div step>Contenido del paso</div>
7837
- * </val-wizard>
7838
- *
7839
- * @input props {WizardMetadata} - Metadatos del wizard, pasos y estado.
7840
- * @output onClick - Emite el paso actual y la acción de navegación (MOTION).
7841
- */
7842
7828
  class WizardComponent {
7843
- constructor() {
7844
- /**
7845
- * Evento emitido al hacer click en una acción de navegación.
7846
- */
7829
+ constructor(cdr) {
7830
+ this.cdr = cdr;
7847
7831
  this.onClick = new EventEmitter();
7848
7832
  this.wrapperId = 'wizard-wrapper';
7833
+ this.currentStep = null;
7834
+ }
7835
+ ngOnInit() {
7836
+ this.updateCurrentStep();
7837
+ }
7838
+ ngOnChanges(changes) {
7839
+ if (changes['props']) {
7840
+ this.updateCurrentStep();
7841
+ this.cdr.detectChanges();
7842
+ }
7843
+ }
7844
+ updateCurrentStep() {
7845
+ if (this.props?.steps && this.props.current) {
7846
+ this.currentStep = this.props.steps[this.props.current];
7847
+ }
7849
7848
  }
7850
- ngOnInit() { }
7851
- /**
7852
- * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.
7853
- */
7854
7849
  working() {
7855
7850
  this.props.state = ComponentStates.WORKING;
7856
- this.Current.buttons.map(x => {
7857
- x.state = ComponentStates.DISABLED;
7858
- });
7851
+ if (this.currentStep?.buttons) {
7852
+ this.currentStep.buttons.forEach(button => {
7853
+ button.state = ComponentStates.DISABLED;
7854
+ });
7855
+ }
7856
+ this.cdr.detectChanges();
7859
7857
  }
7860
- /**
7861
- * Cambia el estado del wizard a 'ENABLED' y habilita los botones del paso actual.
7862
- * No realiza cambios si ya está en estado 'ENABLED'.
7863
- */
7864
7858
  done() {
7865
7859
  if (this.props.state === ComponentStates.ENABLED) {
7866
7860
  return;
7867
7861
  }
7868
7862
  this.props.state = ComponentStates.ENABLED;
7869
- this.Current.buttons.map(x => {
7870
- x.state = ComponentStates.ENABLED;
7871
- });
7863
+ if (this.currentStep?.buttons) {
7864
+ this.currentStep.buttons.forEach(button => {
7865
+ button.state = ComponentStates.ENABLED;
7866
+ });
7867
+ }
7868
+ this.cdr.detectChanges();
7872
7869
  }
7873
- /**
7874
- * Devuelve el paso actual del wizard.
7875
- */
7876
7870
  get Current() {
7877
- return this.props.steps[this.props.current];
7871
+ return this.currentStep || this.props.steps[this.props.current];
7878
7872
  }
7879
- /**
7880
- * Cambia el paso actual del wizard y hace scroll al inicio.
7881
- * @param newStep Nuevo índice de paso
7882
- */
7883
7873
  setCurrent(newStep) {
7884
7874
  if (newStep === this.props.current) {
7885
7875
  return;
7886
7876
  }
7887
7877
  this.props.current = newStep;
7878
+ this.updateCurrentStep();
7879
+ this.cdr.detectChanges();
7888
7880
  goToTop(this.wrapperId);
7889
7881
  }
7890
- /**
7891
- * Establece el estado de error y muestra el mensaje de error en el banner inferior.
7892
- * @param error Mensaje de error a mostrar
7893
- */
7894
7882
  setError(error) {
7895
7883
  if (this.props.state === ComponentStates.ERROR) {
7896
7884
  return;
7897
7885
  }
7898
7886
  this.props.error.titles.bottomContent.content.bellowTitle.content = error;
7899
7887
  this.props.state = ComponentStates.ERROR;
7888
+ this.cdr.detectChanges();
7900
7889
  goToTop(this.wrapperId);
7901
7890
  }
7902
- /**
7903
- * Reinicia el estado de error y vuelve a estado 'ENABLED'.
7904
- */
7905
7891
  reset() {
7906
7892
  this.props.error.titles.bottomContent.content.bellowTitle.content = '';
7907
7893
  this.done();
7908
7894
  }
7909
- /**
7910
- * Maneja el click en el banner de error y emite el evento de navegación.
7911
- * Si el token contiene 'retry', reinicia el wizard.
7912
- * @param token Token de la acción clicada
7913
- */
7914
7895
  clickHandler(token) {
7915
7896
  if (!token) {
7916
7897
  return;
@@ -7920,11 +7901,11 @@ class WizardComponent {
7920
7901
  }
7921
7902
  this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });
7922
7903
  }
7923
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7924
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardComponent, isStandalone: true, selector: "val-wizard", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
7904
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
7905
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardComponent, isStandalone: true, selector: "val-wizard", inputs: { props: "props" }, outputs: { onClick: "onClick" }, usesOnChanges: true, ngImport: i0, template: `
7925
7906
  <div [id]="wrapperId" class="wrapper">
7926
7907
  <ng-container *ngIf="props.state !== 'ERROR'">
7927
- <val-no-content [props]="Current.titles"></val-no-content>
7908
+ <val-no-content *ngIf="currentStep" [props]="currentStep.titles"></val-no-content>
7928
7909
  <div class="step">
7929
7910
  <div *ngIf="props.state === 'WORKING'">
7930
7911
  <val-content-loader
@@ -7950,7 +7931,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7950
7931
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
7951
7932
  <div [id]="wrapperId" class="wrapper">
7952
7933
  <ng-container *ngIf="props.state !== 'ERROR'">
7953
- <val-no-content [props]="Current.titles"></val-no-content>
7934
+ <val-no-content *ngIf="currentStep" [props]="currentStep.titles"></val-no-content>
7954
7935
  <div class="step">
7955
7936
  <div *ngIf="props.state === 'WORKING'">
7956
7937
  <val-content-loader
@@ -7970,7 +7951,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7970
7951
  </ng-container>
7971
7952
  </div>
7972
7953
  `, styles: [":root{--ion-color-primary: #7026df;--ion-color-primary-rgb: 112, 38, 223;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #6321c4;--ion-color-primary-tint: #7e3ce2;--ion-color-secondary: #e2ccff;--ion-color-secondary-rgb: 226, 204, 255;--ion-color-secondary-contrast: #000000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #c7b4e0;--ion-color-secondary-tint: #e5d1ff;--ion-color-texti: #354c69;--ion-color-texti-rgb: 53, 76, 105;--ion-color-texti-contrast: #ffffff;--ion-color-texti-contrast-rgb: 255, 255, 255;--ion-color-texti-shade: #2f435c;--ion-color-texti-tint: #495e78;--ion-color-darki: #090f1b;--ion-color-darki-rgb: 9, 15, 27;--ion-color-darki-contrast: #ffffff;--ion-color-darki-contrast-rgb: 255, 255, 255;--ion-color-darki-shade: #080d18;--ion-color-darki-tint: #222732;--ion-color-medium: #9e9e9e;--ion-color-medium-rgb: 158, 158, 158;--ion-color-medium-contrast: #000000;--ion-color-medium-contrast-rgb: 0, 0, 0;--ion-color-medium-shade: #8b8b8b;--ion-color-medium-tint: #a8a8a8;--swiper-pagination-color: var(--ion-color-primary);--swiper-navigation-color: var(--ion-color-primary);--swiper-pagination-bullet-inactive-color: var(--ion-color-medium)}@media (prefers-color-scheme: dark){:root{--ion-color-texti: #8fc1ff;--ion-color-texti-rgb: 143, 193, 255;--ion-color-texti-contrast: #000000;--ion-color-texti-contrast-rgb: 0, 0, 0;--ion-color-texti-shade: #7eaae0;--ion-color-texti-tint: #9ac7ff;--ion-color-darki: #ffffff;--ion-color-darki-rgb: 255, 255, 255;--ion-color-darki-contrast: #000000;--ion-color-darki-contrast-rgb: 0, 0, 0;--ion-color-darki-shade: #e0e0e0;--ion-color-darki-tint: #ffffff;--ion-color-primary: #8f49f8;--ion-color-primary-rgb: 143, 73, 248;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #7e40da;--ion-color-primary-tint: #9a5bf9}}.ion-color-texti{--ion-color-base: var(--ion-color-texti);--ion-color-base-rgb: var(--ion-color-texti-rgb);--ion-color-contrast: var(--ion-color-texti-contrast);--ion-color-contrast-rgb: var(--ion-color-texti-contrast-rgb);--ion-color-shade: var(--ion-color-texti-shade);--ion-color-tint: var(--ion-color-texti-tint)}.ion-color-darki{--ion-color-base: var(--ion-color-darki);--ion-color-base-rgb: var(--ion-color-darki-rgb);--ion-color-contrast: var(--ion-color-darki-contrast);--ion-color-contrast-rgb: var(--ion-color-darki-contrast-rgb);--ion-color-shade: var(--ion-color-darki-shade);--ion-color-tint: var(--ion-color-darki-tint)}.wrapper{height:auto;display:flex;flex-direction:column;justify-content:space-between;position:relative;min-height:320px}.step{min-height:9.375rem;margin:16px 0;text-align:center}\n"] }]
7973
- }], ctorParameters: () => [], propDecorators: { props: [{
7954
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
7974
7955
  type: Input
7975
7956
  }], onClick: [{
7976
7957
  type: Output