valtech-components 2.0.343 → 2.0.345

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,78 @@ 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
+ this.currentStepTitles = null;
17
+ }
18
+ ngOnInit() {
19
+ this.updateCurrentStep();
20
+ }
21
+ ngOnChanges(changes) {
22
+ if (changes['props']) {
23
+ this.updateCurrentStep();
24
+ this.cdr.markForCheck();
25
+ }
26
+ }
27
+ updateCurrentStep() {
28
+ if (this.props?.steps && this.props?.current) {
29
+ this.currentStep = this.props.steps[this.props.current];
30
+ this.currentStepTitles = this.currentStep?.titles || null;
31
+ }
31
32
  }
32
- ngOnInit() { }
33
- /**
34
- * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.
35
- */
36
33
  working() {
37
34
  this.props.state = ComponentStates.WORKING;
38
- this.Current.buttons.map(x => {
39
- x.state = ComponentStates.DISABLED;
40
- });
35
+ if (this.Current?.buttons) {
36
+ this.Current.buttons.forEach(button => {
37
+ button.state = ComponentStates.DISABLED;
38
+ });
39
+ }
40
+ this.cdr.markForCheck();
41
41
  }
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
42
  done() {
47
43
  if (this.props.state === ComponentStates.ENABLED) {
48
44
  return;
49
45
  }
50
46
  this.props.state = ComponentStates.ENABLED;
51
- this.Current.buttons.map(x => {
52
- x.state = ComponentStates.ENABLED;
53
- });
47
+ if (this.Current?.buttons) {
48
+ this.Current.buttons.forEach(button => {
49
+ button.state = ComponentStates.ENABLED;
50
+ });
51
+ }
52
+ this.cdr.markForCheck();
54
53
  }
55
- /**
56
- * Devuelve el paso actual del wizard.
57
- */
58
54
  get Current() {
59
- return this.props.steps[this.props.current];
55
+ if (this.props?.steps && this.props?.current) {
56
+ return this.props.steps[this.props.current];
57
+ }
58
+ return this.currentStep || { titles: null, buttons: [] };
60
59
  }
61
- /**
62
- * Cambia el paso actual del wizard y hace scroll al inicio.
63
- * @param newStep Nuevo índice de paso
64
- */
65
60
  setCurrent(newStep) {
66
61
  if (newStep === this.props.current) {
67
62
  return;
68
63
  }
69
64
  this.props.current = newStep;
65
+ this.updateCurrentStep();
66
+ this.cdr.markForCheck();
70
67
  goToTop(this.wrapperId);
71
68
  }
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
69
  setError(error) {
77
70
  if (this.props.state === ComponentStates.ERROR) {
78
71
  return;
79
72
  }
80
73
  this.props.error.titles.bottomContent.content.bellowTitle.content = error;
81
74
  this.props.state = ComponentStates.ERROR;
75
+ this.cdr.markForCheck();
82
76
  goToTop(this.wrapperId);
83
77
  }
84
- /**
85
- * Reinicia el estado de error y vuelve a estado 'ENABLED'.
86
- */
87
78
  reset() {
88
79
  this.props.error.titles.bottomContent.content.bellowTitle.content = '';
89
80
  this.done();
90
81
  }
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
82
  clickHandler(token) {
97
83
  if (!token) {
98
84
  return;
@@ -102,11 +88,11 @@ export class WizardComponent {
102
88
  }
103
89
  this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });
104
90
  }
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: `
91
+ 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 }); }
92
+ 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
93
  <div [id]="wrapperId" class="wrapper">
108
94
  <ng-container *ngIf="props.state !== 'ERROR'">
109
- <val-no-content [props]="Current.titles"></val-no-content>
95
+ <val-no-content [props]="currentStepTitles"></val-no-content>
110
96
  <div class="step">
111
97
  <div *ngIf="props.state === 'WORKING'">
112
98
  <val-content-loader
@@ -132,7 +118,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
132
118
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
133
119
  <div [id]="wrapperId" class="wrapper">
134
120
  <ng-container *ngIf="props.state !== 'ERROR'">
135
- <val-no-content [props]="Current.titles"></val-no-content>
121
+ <val-no-content [props]="currentStepTitles"></val-no-content>
136
122
  <div class="step">
137
123
  <div *ngIf="props.state === 'WORKING'">
138
124
  <val-content-loader
@@ -152,9 +138,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
152
138
  </ng-container>
153
139
  </div>
154
140
  `, 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: [{
141
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
156
142
  type: Input
157
143
  }], onClick: [{
158
144
  type: Output
159
145
  }] } });
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":"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","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"]}
146
+ //# 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,EAEL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAC;AACvB,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,MAAM,OAAO,eAAe;IAW1B,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAN1C,YAAO,GAAG,IAAI,YAAY,EAAuC,CAAC;QAElE,cAAS,GAAG,gBAAgB,CAAC;QAC7B,gBAAW,GAAgB,IAAI,CAAC;QAChC,sBAAiB,GAAQ,IAAI,CAAC;IAEe,CAAC;IAE9C,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,IAAI,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YAC7C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACxD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,IAAI,IAAI,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3C,IAAI,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACpC,MAAM,CAAC,KAAK,GAAG,eAAe,CAAC,QAAQ,CAAC;YAC1C,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,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,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACpC,MAAM,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;YACzC,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,IAAI,OAAO;QACT,IAAI,IAAI,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC9C,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC3D,CAAC;IAED,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,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC;IAED,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,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC;IAED,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,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;+GAjGU,eAAe;mGAAf,eAAe,wJAzBhB;;;;;;;;;;;;;;;;;;;;;;GAsBT,kwFAvBS,YAAY,mIAAE,kBAAkB,oGAAE,sBAAsB;;4FA0BvD,eAAe;kBA7B3B,SAAS;+BACE,YAAY,cACV,IAAI,WACP,CAAC,YAAY,EAAE,kBAAkB,EAAE,sBAAsB,CAAC,YACzD;;;;;;;;;;;;;;;;;;;;;;GAsBT;sFAKD,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,MAAM","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 [props]=\"currentStepTitles\"></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  currentStepTitles: any = 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.markForCheck();\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      this.currentStepTitles = this.currentStep?.titles || null;\n    }\n  }\n\n  working() {\n    this.props.state = ComponentStates.WORKING;\n    if (this.Current?.buttons) {\n      this.Current.buttons.forEach(button => {\n        button.state = ComponentStates.DISABLED;\n      });\n    }\n    this.cdr.markForCheck();\n  }\n\n  done() {\n    if (this.props.state === ComponentStates.ENABLED) {\n      return;\n    }\n\n    this.props.state = ComponentStates.ENABLED;\n    if (this.Current?.buttons) {\n      this.Current.buttons.forEach(button => {\n        button.state = ComponentStates.ENABLED;\n      });\n    }\n    this.cdr.markForCheck();\n  }\n\n  get Current(): Step {\n    if (this.props?.steps && this.props?.current) {\n      return this.props.steps[this.props.current];\n    }\n    return this.currentStep || { titles: null, buttons: [] };\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.markForCheck();\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.markForCheck();\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,78 @@ 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
+ this.currentStepTitles = null;
7835
+ }
7836
+ ngOnInit() {
7837
+ this.updateCurrentStep();
7838
+ }
7839
+ ngOnChanges(changes) {
7840
+ if (changes['props']) {
7841
+ this.updateCurrentStep();
7842
+ this.cdr.markForCheck();
7843
+ }
7844
+ }
7845
+ updateCurrentStep() {
7846
+ if (this.props?.steps && this.props?.current) {
7847
+ this.currentStep = this.props.steps[this.props.current];
7848
+ this.currentStepTitles = this.currentStep?.titles || null;
7849
+ }
7849
7850
  }
7850
- ngOnInit() { }
7851
- /**
7852
- * Cambia el estado del wizard a 'WORKING' y deshabilita los botones del paso actual.
7853
- */
7854
7851
  working() {
7855
7852
  this.props.state = ComponentStates.WORKING;
7856
- this.Current.buttons.map(x => {
7857
- x.state = ComponentStates.DISABLED;
7858
- });
7853
+ if (this.Current?.buttons) {
7854
+ this.Current.buttons.forEach(button => {
7855
+ button.state = ComponentStates.DISABLED;
7856
+ });
7857
+ }
7858
+ this.cdr.markForCheck();
7859
7859
  }
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
7860
  done() {
7865
7861
  if (this.props.state === ComponentStates.ENABLED) {
7866
7862
  return;
7867
7863
  }
7868
7864
  this.props.state = ComponentStates.ENABLED;
7869
- this.Current.buttons.map(x => {
7870
- x.state = ComponentStates.ENABLED;
7871
- });
7865
+ if (this.Current?.buttons) {
7866
+ this.Current.buttons.forEach(button => {
7867
+ button.state = ComponentStates.ENABLED;
7868
+ });
7869
+ }
7870
+ this.cdr.markForCheck();
7872
7871
  }
7873
- /**
7874
- * Devuelve el paso actual del wizard.
7875
- */
7876
7872
  get Current() {
7877
- return this.props.steps[this.props.current];
7873
+ if (this.props?.steps && this.props?.current) {
7874
+ return this.props.steps[this.props.current];
7875
+ }
7876
+ return this.currentStep || { titles: null, buttons: [] };
7878
7877
  }
7879
- /**
7880
- * Cambia el paso actual del wizard y hace scroll al inicio.
7881
- * @param newStep Nuevo índice de paso
7882
- */
7883
7878
  setCurrent(newStep) {
7884
7879
  if (newStep === this.props.current) {
7885
7880
  return;
7886
7881
  }
7887
7882
  this.props.current = newStep;
7883
+ this.updateCurrentStep();
7884
+ this.cdr.markForCheck();
7888
7885
  goToTop(this.wrapperId);
7889
7886
  }
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
7887
  setError(error) {
7895
7888
  if (this.props.state === ComponentStates.ERROR) {
7896
7889
  return;
7897
7890
  }
7898
7891
  this.props.error.titles.bottomContent.content.bellowTitle.content = error;
7899
7892
  this.props.state = ComponentStates.ERROR;
7893
+ this.cdr.markForCheck();
7900
7894
  goToTop(this.wrapperId);
7901
7895
  }
7902
- /**
7903
- * Reinicia el estado de error y vuelve a estado 'ENABLED'.
7904
- */
7905
7896
  reset() {
7906
7897
  this.props.error.titles.bottomContent.content.bellowTitle.content = '';
7907
7898
  this.done();
7908
7899
  }
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
7900
  clickHandler(token) {
7915
7901
  if (!token) {
7916
7902
  return;
@@ -7920,11 +7906,11 @@ class WizardComponent {
7920
7906
  }
7921
7907
  this.onClick.emit({ current: this.props.current, motion: MOTION.RETRY });
7922
7908
  }
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: `
7909
+ 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 }); }
7910
+ 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
7911
  <div [id]="wrapperId" class="wrapper">
7926
7912
  <ng-container *ngIf="props.state !== 'ERROR'">
7927
- <val-no-content [props]="Current.titles"></val-no-content>
7913
+ <val-no-content [props]="currentStepTitles"></val-no-content>
7928
7914
  <div class="step">
7929
7915
  <div *ngIf="props.state === 'WORKING'">
7930
7916
  <val-content-loader
@@ -7950,7 +7936,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7950
7936
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
7951
7937
  <div [id]="wrapperId" class="wrapper">
7952
7938
  <ng-container *ngIf="props.state !== 'ERROR'">
7953
- <val-no-content [props]="Current.titles"></val-no-content>
7939
+ <val-no-content [props]="currentStepTitles"></val-no-content>
7954
7940
  <div class="step">
7955
7941
  <div *ngIf="props.state === 'WORKING'">
7956
7942
  <val-content-loader
@@ -7970,7 +7956,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7970
7956
  </ng-container>
7971
7957
  </div>
7972
7958
  `, 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: [{
7959
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
7974
7960
  type: Input
7975
7961
  }], onClick: [{
7976
7962
  type: Output