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.
- package/esm2022/lib/components/organisms/wizard/wizard.component.mjs +45 -59
- package/fesm2022/valtech-components.mjs +43 -57
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/organisms/article/article.component.d.ts +2 -2
- package/lib/components/organisms/wizard/wizard.component.d.ts +8 -35
- package/package.json +1 -1
|
@@ -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
|
|
39
|
-
|
|
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
|
|
52
|
-
|
|
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
|
-
|
|
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]="
|
|
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]="
|
|
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":"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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 [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
|
|
7857
|
-
|
|
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
|
|
7870
|
-
|
|
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
|
-
|
|
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]="
|
|
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]="
|
|
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
|