valtech-components 2.0.348 → 2.0.349

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, inject, Input } from '@angular/core';
2
+ import { ChangeDetectorRef, Component, inject, Input, } from '@angular/core';
3
3
  import { IonText } from '@ionic/angular/standalone';
4
4
  import { of, Subscription } from 'rxjs';
5
5
  import { LangService } from '../../../services/lang-provider/lang-provider.service';
@@ -24,10 +24,17 @@ export class DisplayComponent {
24
24
  constructor() {
25
25
  this.subscriptions = new Subscription();
26
26
  this.langService = inject(LangService);
27
+ this.cdr = inject(ChangeDetectorRef);
27
28
  }
28
29
  ngOnInit() {
29
30
  this.initializeDisplayContent();
30
31
  }
32
+ ngOnChanges(changes) {
33
+ if (changes['props']) {
34
+ this.initializeDisplayContent();
35
+ this.cdr.detectChanges();
36
+ }
37
+ }
31
38
  ngOnDestroy() {
32
39
  this.subscriptions.unsubscribe();
33
40
  }
@@ -48,7 +55,7 @@ export class DisplayComponent {
48
55
  this.displayContent$ = of('');
49
56
  }
50
57
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayComponent, isStandalone: true, selector: "val-display", inputs: { props: "props" }, ngImport: i0, template: `
58
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayComponent, isStandalone: true, selector: "val-display", inputs: { props: "props" }, usesOnChanges: true, ngImport: i0, template: `
52
59
  <ion-text [color]="props.color">
53
60
  <p [class]="props.size">
54
61
  {{ displayContent$ | async }}
@@ -124,4 +131,4 @@ export function createDisplayProps(contentConfig, styleConfig = {}) {
124
131
  size: styleConfig.size || 'medium',
125
132
  };
126
133
  }
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/display/display.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAc,EAAE,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,uDAAuD,CAAC;;;AAgBpF;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,gBAAgB;IAiB3B;QAfQ,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAanC,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAE3B,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IACnC,CAAC;IAEO,wBAAwB;QAC9B,kCAAkC;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YACrC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC9C,OAAO;QACT,CAAC;QAED,qCAAqC;QACrC,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAChD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,IAAI,SAAS,EAC/C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,EAC5B,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG;YACjE,yDAAyD;aAC1D,CAAC;YACF,OAAO;QACT,CAAC;QAED,2CAA2C;QAC3C,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;+GA/CU,gBAAgB;mGAAhB,gBAAgB,mGAxBjB;;;;;;GAMT,6kGAPS,YAAY,oFAAE,OAAO;;4FAyBpB,gBAAgB;kBA5B5B,SAAS;+BACE,aAAa,cACX,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;GAMT;wDA+BD,KAAK;sBADJ,KAAK;;AAsCR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAM,UAAU,kBAAkB,CAChC,aAAmC,EACnC,cAAgE,EAAE;IAElE,OAAO;QACL,aAAa,EAAE;YACb,GAAG,EAAE,aAAa,CAAC,GAAG;YACtB,SAAS,EAAE,aAAa,CAAC,SAAS;YAClC,QAAQ,EAAE,aAAa,CAAC,QAAQ;YAChC,aAAa,EAAE,aAAa,CAAC,aAAa;SAC3C;QACD,KAAK,EAAE,WAAW,CAAC,KAAK,IAAI,MAAM;QAClC,IAAI,EAAE,WAAW,CAAC,IAAI,IAAI,QAAQ;KACnC,CAAC;AACJ,CAAC","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, inject, Input, OnDestroy, OnInit } from '@angular/core';\nimport { IonText } from '@ionic/angular/standalone';\nimport { Observable, of, Subscription } from 'rxjs';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { DisplayContentConfig, DisplayMetadata } from './types';\n\n@Component({\n  selector: 'val-display',\n  standalone: true,\n  imports: [CommonModule, IonText],\n  template: `\n    <ion-text [color]=\"props.color\">\n      <p [class]=\"props.size\">\n        {{ displayContent$ | async }}\n      </p>\n    </ion-text>\n  `,\n  styleUrls: ['./display.component.scss'],\n})\n/**\n * val-display\n *\n * Displays prominent text or titles with custom color and size.\n * Supports both static and reactive content patterns.\n *\n * @example\n * // Static content\n * <val-display [props]=\"{ content: 'Title', color: 'dark', size: 'large' }\"></val-display>\n *\n * // Reactive content\n * <val-display [props]=\"{ contentConfig: { key: 'welcome.title' }, color: 'primary', size: 'xlarge' }\"></val-display>\n *\n * @input props: DisplayMetadata - Configuration for the display (content/contentConfig, color, size)\n */\nexport class DisplayComponent implements OnInit, OnDestroy {\n  displayContent$: Observable<string>;\n  private subscriptions = new Subscription();\n\n  /**\n   * Display configuration object.\n   * @type {DisplayMetadata}\n   * @property content - Static text to display (takes precedence over contentConfig).\n   * @property contentConfig - Reactive content configuration.\n   * @property color - The text color (Ionic color string).\n   * @property size - The text size ('small' | 'medium' | 'large' | 'xlarge').\n   */\n  @Input()\n  props: DisplayMetadata;\n\n  private langService = inject(LangService);\n\n  constructor() {}\n\n  ngOnInit() {\n    this.initializeDisplayContent();\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n\n  private initializeDisplayContent() {\n    // Static content takes precedence\n    if (this.props.content !== undefined) {\n      this.displayContent$ = of(this.props.content);\n      return;\n    }\n\n    // Use reactive content if configured\n    if (this.props.contentConfig) {\n      this.displayContent$ = this.langService.getContent(\n        this.props.contentConfig.className || '_global',\n        this.props.contentConfig.key,\n        this.props.contentConfig.fallback || this.props.contentConfig.key\n        // interpolation: this.props.contentConfig.interpolation,\n      );\n      return;\n    }\n\n    // No content configured - use empty string\n    this.displayContent$ = of('');\n  }\n}\n\n/**\n * Helper function to create reactive display props from content configuration.\n * This provides a convenient way to create val-display props with reactive content.\n *\n * @param contentConfig - Content configuration for reactive content\n * @param styleConfig - Optional style configuration (color and size)\n * @returns DisplayMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * titleProps: DisplayMetadata = createDisplayProps({\n *   key: 'title',\n *   className: 'HeaderComponent',\n *   fallback: 'Default Title'\n * }, {\n *   color: 'primary',\n *   size: 'large'\n * });\n * ```\n *\n * @example\n * ```typescript\n * // With interpolation\n * greetingProps: DisplayMetadata = createDisplayProps({\n *   key: 'greeting',\n *   className: 'UserComponent',\n *   fallback: 'Hello!',\n *   interpolation: { name: 'John', count: 5 }\n * }, {\n *   color: 'secondary',\n *   size: 'medium'\n * });\n * ```\n *\n * @example\n * ```typescript\n * // Using default style values\n * simpleProps: DisplayMetadata = createDisplayProps({\n *   key: 'welcomeMessage',\n *   className: 'HomeComponent'\n * }); // Will use default color: 'dark' and size: 'medium'\n * ```\n */\nexport function createDisplayProps(\n  contentConfig: DisplayContentConfig,\n  styleConfig: Partial<Pick<DisplayMetadata, 'color' | 'size'>> = {}\n): DisplayMetadata {\n  return {\n    contentConfig: {\n      key: contentConfig.key,\n      className: contentConfig.className,\n      fallback: contentConfig.fallback,\n      interpolation: contentConfig.interpolation,\n    },\n    color: styleConfig.color || 'dark',\n    size: styleConfig.size || 'medium',\n  };\n}\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/display/display.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,KAAK,GAKN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAc,EAAE,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,uDAAuD,CAAC;;;AAgBpF;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,gBAAgB;IAkB3B;QAhBQ,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAanC,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAEzB,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAChC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IACnC,CAAC;IAEO,wBAAwB;QAC9B,kCAAkC;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YACrC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC9C,OAAO;QACT,CAAC;QAED,qCAAqC;QACrC,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAChD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,IAAI,SAAS,EAC/C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,EAC5B,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG;YACjE,yDAAyD;aAC1D,CAAC;YACF,OAAO;QACT,CAAC;QAED,2CAA2C;QAC3C,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;+GAvDU,gBAAgB;mGAAhB,gBAAgB,wHAxBjB;;;;;;GAMT,6kGAPS,YAAY,oFAAE,OAAO;;4FAyBpB,gBAAgB;kBA5B5B,SAAS;+BACE,aAAa,cACX,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;GAMT;wDA+BD,KAAK;sBADJ,KAAK;;AA8CR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAM,UAAU,kBAAkB,CAChC,aAAmC,EACnC,cAAgE,EAAE;IAElE,OAAO;QACL,aAAa,EAAE;YACb,GAAG,EAAE,aAAa,CAAC,GAAG;YACtB,SAAS,EAAE,aAAa,CAAC,SAAS;YAClC,QAAQ,EAAE,aAAa,CAAC,QAAQ;YAChC,aAAa,EAAE,aAAa,CAAC,aAAa;SAC3C;QACD,KAAK,EAAE,WAAW,CAAC,KAAK,IAAI,MAAM;QAClC,IAAI,EAAE,WAAW,CAAC,IAAI,IAAI,QAAQ;KACnC,CAAC;AACJ,CAAC","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n} from '@angular/core';\nimport { IonText } from '@ionic/angular/standalone';\nimport { Observable, of, Subscription } from 'rxjs';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { DisplayContentConfig, DisplayMetadata } from './types';\n\n@Component({\n  selector: 'val-display',\n  standalone: true,\n  imports: [CommonModule, IonText],\n  template: `\n    <ion-text [color]=\"props.color\">\n      <p [class]=\"props.size\">\n        {{ displayContent$ | async }}\n      </p>\n    </ion-text>\n  `,\n  styleUrls: ['./display.component.scss'],\n})\n/**\n * val-display\n *\n * Displays prominent text or titles with custom color and size.\n * Supports both static and reactive content patterns.\n *\n * @example\n * // Static content\n * <val-display [props]=\"{ content: 'Title', color: 'dark', size: 'large' }\"></val-display>\n *\n * // Reactive content\n * <val-display [props]=\"{ contentConfig: { key: 'welcome.title' }, color: 'primary', size: 'xlarge' }\"></val-display>\n *\n * @input props: DisplayMetadata - Configuration for the display (content/contentConfig, color, size)\n */\nexport class DisplayComponent implements OnInit, OnChanges, OnDestroy {\n  displayContent$: Observable<string>;\n  private subscriptions = new Subscription();\n\n  /**\n   * Display configuration object.\n   * @type {DisplayMetadata}\n   * @property content - Static text to display (takes precedence over contentConfig).\n   * @property contentConfig - Reactive content configuration.\n   * @property color - The text color (Ionic color string).\n   * @property size - The text size ('small' | 'medium' | 'large' | 'xlarge').\n   */\n  @Input()\n  props: DisplayMetadata;\n\n  private langService = inject(LangService);\n  private cdr = inject(ChangeDetectorRef);\n\n  constructor() {}\n\n  ngOnInit() {\n    this.initializeDisplayContent();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['props']) {\n      this.initializeDisplayContent();\n      this.cdr.detectChanges();\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n\n  private initializeDisplayContent() {\n    // Static content takes precedence\n    if (this.props.content !== undefined) {\n      this.displayContent$ = of(this.props.content);\n      return;\n    }\n\n    // Use reactive content if configured\n    if (this.props.contentConfig) {\n      this.displayContent$ = this.langService.getContent(\n        this.props.contentConfig.className || '_global',\n        this.props.contentConfig.key,\n        this.props.contentConfig.fallback || this.props.contentConfig.key\n        // interpolation: this.props.contentConfig.interpolation,\n      );\n      return;\n    }\n\n    // No content configured - use empty string\n    this.displayContent$ = of('');\n  }\n}\n\n/**\n * Helper function to create reactive display props from content configuration.\n * This provides a convenient way to create val-display props with reactive content.\n *\n * @param contentConfig - Content configuration for reactive content\n * @param styleConfig - Optional style configuration (color and size)\n * @returns DisplayMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * titleProps: DisplayMetadata = createDisplayProps({\n *   key: 'title',\n *   className: 'HeaderComponent',\n *   fallback: 'Default Title'\n * }, {\n *   color: 'primary',\n *   size: 'large'\n * });\n * ```\n *\n * @example\n * ```typescript\n * // With interpolation\n * greetingProps: DisplayMetadata = createDisplayProps({\n *   key: 'greeting',\n *   className: 'UserComponent',\n *   fallback: 'Hello!',\n *   interpolation: { name: 'John', count: 5 }\n * }, {\n *   color: 'secondary',\n *   size: 'medium'\n * });\n * ```\n *\n * @example\n * ```typescript\n * // Using default style values\n * simpleProps: DisplayMetadata = createDisplayProps({\n *   key: 'welcomeMessage',\n *   className: 'HomeComponent'\n * }); // Will use default color: 'dark' and size: 'medium'\n * ```\n */\nexport function createDisplayProps(\n  contentConfig: DisplayContentConfig,\n  styleConfig: Partial<Pick<DisplayMetadata, 'color' | 'size'>> = {}\n): DisplayMetadata {\n  return {\n    contentConfig: {\n      key: contentConfig.key,\n      className: contentConfig.className,\n      fallback: contentConfig.fallback,\n      interpolation: contentConfig.interpolation,\n    },\n    color: styleConfig.color || 'dark',\n    size: styleConfig.size || 'medium',\n  };\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { AsyncPipe, CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, Input, inject } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, inject, } from '@angular/core';
3
3
  import { IonText } from '@ionic/angular/standalone';
4
4
  import { of } from 'rxjs';
5
5
  import { LangService } from '../../../services/lang-provider/lang-provider.service';
@@ -46,8 +46,18 @@ import * as i1 from "@angular/common";
46
46
  export class TitleComponent {
47
47
  constructor() {
48
48
  this.langService = inject(LangService);
49
+ this.cdr = inject(ChangeDetectorRef);
49
50
  }
50
51
  ngOnInit() {
52
+ this.updateContent();
53
+ }
54
+ ngOnChanges(changes) {
55
+ if (changes['props']) {
56
+ this.updateContent();
57
+ this.cdr.detectChanges();
58
+ }
59
+ }
60
+ updateContent() {
51
61
  // Always convert to Observable for consistent template handling
52
62
  if (shouldUseReactiveContent(this.props)) {
53
63
  // Use reactive content with LangService
@@ -61,7 +71,7 @@ export class TitleComponent {
61
71
  }
62
72
  }
63
73
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
64
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TitleComponent, isStandalone: true, selector: "val-title", inputs: { props: "props" }, ngImport: i0, template: `
74
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TitleComponent, isStandalone: true, selector: "val-title", inputs: { props: "props" }, usesOnChanges: true, ngImport: i0, template: `
65
75
  <ion-text [color]="props.color">
66
76
  @if (!props.bold) {
67
77
  <p [ngClass]="[props.size]" [class.thin]="props.thin">
@@ -97,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
107
  }], ctorParameters: () => [], propDecorators: { props: [{
98
108
  type: Input
99
109
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy90aXRsZS90aXRsZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BELE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHVEQUF1RCxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOzs7QUF5QnRHOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQ0c7QUFDSCxNQUFNLE9BQU8sY0FBYztJQWtCekI7UUFKUSxnQkFBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUkzQixDQUFDO0lBRWhCLFFBQVE7UUFDTixnRUFBZ0U7UUFDaEUsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN6Qyx3Q0FBd0M7WUFDeEMsTUFBTSxNQUFNLEdBQUcsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2hELElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNwRyxDQUFDO2FBQU0sQ0FBQztZQUNOLHVDQUF1QztZQUN2QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNILENBQUM7K0dBL0JVLGNBQWM7bUdBQWQsY0FBYyxpR0F2RGY7Ozs7Ozs7Ozs7Ozs7O0dBY1Qsd3NHQWZTLFlBQVksa0xBQUUsT0FBTzs7NEZBd0RwQixjQUFjO2tCQTNEMUIsU0FBUzsrQkFDRSxXQUFXLGNBQ1QsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsWUFDakM7Ozs7Ozs7Ozs7Ozs7O0dBY1QsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU07d0RBbUQvQyxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1BpcGUsIENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElvblRleHQgfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBMYW5nU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvbGFuZy1wcm92aWRlci5zZXJ2aWNlJztcbmltcG9ydCB7IGV4dHJhY3RDb250ZW50Q29uZmlnLCBzaG91bGRVc2VSZWFjdGl2ZUNvbnRlbnQgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvc2ltcGxlLWNvbnRlbnQnO1xuaW1wb3J0IHsgVGl0bGVNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtdGl0bGUnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBJb25UZXh0LCBBc3luY1BpcGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpb24tdGV4dCBbY29sb3JdPVwicHJvcHMuY29sb3JcIj5cbiAgICAgIEBpZiAoIXByb3BzLmJvbGQpIHtcbiAgICAgICAgPHAgW25nQ2xhc3NdPVwiW3Byb3BzLnNpemVdXCIgW2NsYXNzLnRoaW5dPVwicHJvcHMudGhpblwiPlxuICAgICAgICAgIHt7IGRpc3BsYXlDb250ZW50JCB8IGFzeW5jIH19XG4gICAgICAgIDwvcD5cbiAgICAgIH0gQGVsc2Uge1xuICAgICAgICA8Yj5cbiAgICAgICAgICA8cCBbY2xhc3NdPVwicHJvcHMuc2l6ZVwiPlxuICAgICAgICAgICAge3sgZGlzcGxheUNvbnRlbnQkIHwgYXN5bmMgfX1cbiAgICAgICAgICA8L3A+XG4gICAgICAgIDwvYj5cbiAgICAgIH1cbiAgICA8L2lvbi10ZXh0PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi90aXRsZS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG4vKipcbiAqIHZhbC10aXRsZVxuICpcbiAqIEEgc3R5bGVkIHRpdGxlIG9yIGhlYWRpbmcsIHdpdGggb3B0aW9ucyBmb3Igc2l6ZSwgY29sb3IsIGFuZCBib2xkbmVzcy5cbiAqIFN1cHBvcnRzIGJvdGggc3RhdGljIGNvbnRlbnQgYW5kIHJlYWN0aXZlIGNvbnRlbnQgZnJvbSB0aGUgbGFuZ3VhZ2Ugc2VydmljZS5cbiAqXG4gKiBAZXhhbXBsZSBTdGF0aWMgY29udGVudDpcbiAqIGBgYGh0bWxcbiAqIDx2YWwtdGl0bGUgW3Byb3BzXT1cInsgY29udGVudDogJ015IFRpdGxlJywgc2l6ZTogJ2xhcmdlJywgY29sb3I6ICdwcmltYXJ5JywgYm9sZDogdHJ1ZSB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZSBSZWFjdGl2ZSBjb250ZW50OlxuICogYGBgaHRtbFxuICogPHZhbC10aXRsZSBbcHJvcHNdPVwie1xuICogICBjb250ZW50Q29uZmlnOiB7IGtleTogJ3BhZ2VUaXRsZScsIGZhbGxiYWNrOiAnRGVmYXVsdCBUaXRsZScgfSxcbiAqICAgc2l6ZTogJ2xhcmdlJyxcbiAqICAgY29sb3I6ICdwcmltYXJ5JyxcbiAqICAgYm9sZDogdHJ1ZVxuICogfVwiPjwvdmFsLXRpdGxlPlxuICogYGBgXG4gKlxuICogQGV4YW1wbGUgUmVhY3RpdmUgY29udGVudCB3aXRoIGludGVycG9sYXRpb246XG4gKiBgYGBodG1sXG4gKiA8dmFsLXRpdGxlIFtwcm9wc109XCJ7XG4gKiAgIGNvbnRlbnRDb25maWc6IHtcbiAqICAgICBrZXk6ICd3ZWxjb21lVGl0bGUnLFxuICogICAgIGludGVycG9sYXRpb246IHsgbmFtZTogJ0pvaG4nIH0sXG4gKiAgICAgZmFsbGJhY2s6ICdXZWxjb21lISdcbiAqICAgfSxcbiAqICAgc2l6ZTogJ2xhcmdlJyxcbiAqICAgY29sb3I6ICdwcmltYXJ5JyxcbiAqICAgYm9sZDogdHJ1ZVxuICogfVwiPjwvdmFsLXRpdGxlPlxuICogYGBgXG4gKlxuICogQGlucHV0IHByb3BzOiBUaXRsZU1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIHRpdGxlIChjb250ZW50LCBjb2xvciwgc2l6ZSwgYm9sZCwgdGhpbilcbiAqL1xuZXhwb3J0IGNsYXNzIFRpdGxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFRpdGxlIGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICAgKiBAdHlwZSB7VGl0bGVNZXRhZGF0YX1cbiAgICogQHByb3BlcnR5IGNvbnRlbnQgLSBTdGF0aWMgdGl0bGUgdGV4dCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIHJlYWN0aXZlIGNvbnRlbnQpLlxuICAgKiBAcHJvcGVydHkgY29udGVudENvbmZpZyAtIFJlYWN0aXZlIGNvbnRlbnQgY29uZmlndXJhdGlvbi5cbiAgICogQHByb3BlcnR5IGNvbG9yIC0gVGhlIHRpdGxlIGNvbG9yIChJb25pYyBjb2xvciBzdHJpbmcpLlxuICAgKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSB0aXRsZSBzaXplICgnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnIHwgJ3hsYXJnZScpLlxuICAgKiBAcHJvcGVydHkgYm9sZCAtIFdoZXRoZXIgdGhlIHRpdGxlIGlzIGJvbGQuXG4gICAqIEBwcm9wZXJ0eSB0aGluIC0gV2hldGhlciB0aGUgdGl0bGUgaXMgdGhpbiAob3B0aW9uYWwpLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHJvcHM6IFRpdGxlTWV0YWRhdGE7XG5cbiAgcHJpdmF0ZSBsYW5nU2VydmljZSA9IGluamVjdChMYW5nU2VydmljZSk7XG5cbiAgZGlzcGxheUNvbnRlbnQkOiBPYnNlcnZhYmxlPHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIC8vIEFsd2F5cyBjb252ZXJ0IHRvIE9ic2VydmFibGUgZm9yIGNvbnNpc3RlbnQgdGVtcGxhdGUgaGFuZGxpbmdcbiAgICBpZiAoc2hvdWxkVXNlUmVhY3RpdmVDb250ZW50KHRoaXMucHJvcHMpKSB7XG4gICAgICAvLyBVc2UgcmVhY3RpdmUgY29udGVudCB3aXRoIExhbmdTZXJ2aWNlXG4gICAgICBjb25zdCBjb25maWcgPSBleHRyYWN0Q29udGVudENvbmZpZyh0aGlzLnByb3BzKTtcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gdGhpcy5sYW5nU2VydmljZS5nZXRDb250ZW50KGNvbmZpZy5jbGFzc05hbWUsIGNvbmZpZy5rZXksIGNvbmZpZy5mYWxsYmFjayk7XG4gICAgfSBlbHNlIHtcbiAgICAgIC8vIENvbnZlcnQgc3RhdGljIGNvbnRlbnQgdG8gT2JzZXJ2YWJsZVxuICAgICAgY29uc3Qgc3RhdGljQ29udGVudCA9IHRoaXMucHJvcHMuY29udGVudCB8fCAnJztcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gb2Yoc3RhdGljQ29udGVudCk7XG4gICAgfVxuICB9XG59XG4iXX0=
110
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy90aXRsZS90aXRsZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxRCxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsS0FBSyxFQUlMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDcEQsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLHdCQUF3QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7OztBQXlCdEc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9DRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBbUJ6QjtRQUxRLGdCQUFXLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xDLFFBQUcsR0FBRyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUl6QixDQUFDO0lBRWhCLFFBQVE7UUFDTixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRU8sYUFBYTtRQUNuQixnRUFBZ0U7UUFDaEUsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN6Qyx3Q0FBd0M7WUFDeEMsTUFBTSxNQUFNLEdBQUcsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2hELElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNwRyxDQUFDO2FBQU0sQ0FBQztZQUNOLHVDQUF1QztZQUN2QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNILENBQUM7K0dBM0NVLGNBQWM7bUdBQWQsY0FBYyxzSEF2RGY7Ozs7Ozs7Ozs7Ozs7O0dBY1Qsd3NHQWZTLFlBQVksa0xBQUUsT0FBTzs7NEZBd0RwQixjQUFjO2tCQTNEMUIsU0FBUzsrQkFDRSxXQUFXLGNBQ1QsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsWUFDakM7Ozs7Ozs7Ozs7Ozs7O0dBY1QsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU07d0RBbUQvQyxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1BpcGUsIENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25Jbml0LFxuICBTaW1wbGVDaGFuZ2VzLFxuICBpbmplY3QsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW9uVGV4dCB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IExhbmdTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvbGFuZy1wcm92aWRlci9sYW5nLXByb3ZpZGVyLnNlcnZpY2UnO1xuaW1wb3J0IHsgZXh0cmFjdENvbnRlbnRDb25maWcsIHNob3VsZFVzZVJlYWN0aXZlQ29udGVudCB9IGZyb20gJy4uLy4uLy4uL3NoYXJlZC91dGlscy9zaW1wbGUtY29udGVudCc7XG5pbXBvcnQgeyBUaXRsZU1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC10aXRsZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIElvblRleHQsIEFzeW5jUGlwZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGlvbi10ZXh0IFtjb2xvcl09XCJwcm9wcy5jb2xvclwiPlxuICAgICAgQGlmICghcHJvcHMuYm9sZCkge1xuICAgICAgICA8cCBbbmdDbGFzc109XCJbcHJvcHMuc2l6ZV1cIiBbY2xhc3MudGhpbl09XCJwcm9wcy50aGluXCI+XG4gICAgICAgICAge3sgZGlzcGxheUNvbnRlbnQkIHwgYXN5bmMgfX1cbiAgICAgICAgPC9wPlxuICAgICAgfSBAZWxzZSB7XG4gICAgICAgIDxiPlxuICAgICAgICAgIDxwIFtjbGFzc109XCJwcm9wcy5zaXplXCI+XG4gICAgICAgICAgICB7eyBkaXNwbGF5Q29udGVudCQgfCBhc3luYyB9fVxuICAgICAgICAgIDwvcD5cbiAgICAgICAgPC9iPlxuICAgICAgfVxuICAgIDwvaW9uLXRleHQ+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RpdGxlLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbi8qKlxuICogdmFsLXRpdGxlXG4gKlxuICogQSBzdHlsZWQgdGl0bGUgb3IgaGVhZGluZywgd2l0aCBvcHRpb25zIGZvciBzaXplLCBjb2xvciwgYW5kIGJvbGRuZXNzLlxuICogU3VwcG9ydHMgYm90aCBzdGF0aWMgY29udGVudCBhbmQgcmVhY3RpdmUgY29udGVudCBmcm9tIHRoZSBsYW5ndWFnZSBzZXJ2aWNlLlxuICpcbiAqIEBleGFtcGxlIFN0YXRpYyBjb250ZW50OlxuICogYGBgaHRtbFxuICogPHZhbC10aXRsZSBbcHJvcHNdPVwieyBjb250ZW50OiAnTXkgVGl0bGUnLCBzaXplOiAnbGFyZ2UnLCBjb2xvcjogJ3ByaW1hcnknLCBib2xkOiB0cnVlIH1cIj48L3ZhbC10aXRsZT5cbiAqIGBgYFxuICpcbiAqIEBleGFtcGxlIFJlYWN0aXZlIGNvbnRlbnQ6XG4gKiBgYGBodG1sXG4gKiA8dmFsLXRpdGxlIFtwcm9wc109XCJ7XG4gKiAgIGNvbnRlbnRDb25maWc6IHsga2V5OiAncGFnZVRpdGxlJywgZmFsbGJhY2s6ICdEZWZhdWx0IFRpdGxlJyB9LFxuICogICBzaXplOiAnbGFyZ2UnLFxuICogICBjb2xvcjogJ3ByaW1hcnknLFxuICogICBib2xkOiB0cnVlXG4gKiB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZSBSZWFjdGl2ZSBjb250ZW50IHdpdGggaW50ZXJwb2xhdGlvbjpcbiAqIGBgYGh0bWxcbiAqIDx2YWwtdGl0bGUgW3Byb3BzXT1cIntcbiAqICAgY29udGVudENvbmZpZzoge1xuICogICAgIGtleTogJ3dlbGNvbWVUaXRsZScsXG4gKiAgICAgaW50ZXJwb2xhdGlvbjogeyBuYW1lOiAnSm9obicgfSxcbiAqICAgICBmYWxsYmFjazogJ1dlbGNvbWUhJ1xuICogICB9LFxuICogICBzaXplOiAnbGFyZ2UnLFxuICogICBjb2xvcjogJ3ByaW1hcnknLFxuICogICBib2xkOiB0cnVlXG4gKiB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAaW5wdXQgcHJvcHM6IFRpdGxlTWV0YWRhdGEgLSBDb25maWd1cmF0aW9uIGZvciB0aGUgdGl0bGUgKGNvbnRlbnQsIGNvbG9yLCBzaXplLCBib2xkLCB0aGluKVxuICovXG5leHBvcnQgY2xhc3MgVGl0bGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XG4gIC8qKlxuICAgKiBUaXRsZSBjb25maWd1cmF0aW9uIG9iamVjdC5cbiAgICogQHR5cGUge1RpdGxlTWV0YWRhdGF9XG4gICAqIEBwcm9wZXJ0eSBjb250ZW50IC0gU3RhdGljIHRpdGxlIHRleHQgKHRha2VzIHByZWNlZGVuY2Ugb3ZlciByZWFjdGl2ZSBjb250ZW50KS5cbiAgICogQHByb3BlcnR5IGNvbnRlbnRDb25maWcgLSBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24uXG4gICAqIEBwcm9wZXJ0eSBjb2xvciAtIFRoZSB0aXRsZSBjb2xvciAoSW9uaWMgY29sb3Igc3RyaW5nKS5cbiAgICogQHByb3BlcnR5IHNpemUgLSBUaGUgdGl0bGUgc2l6ZSAoJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJyB8ICd4bGFyZ2UnKS5cbiAgICogQHByb3BlcnR5IGJvbGQgLSBXaGV0aGVyIHRoZSB0aXRsZSBpcyBib2xkLlxuICAgKiBAcHJvcGVydHkgdGhpbiAtIFdoZXRoZXIgdGhlIHRpdGxlIGlzIHRoaW4gKG9wdGlvbmFsKS5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHByb3BzOiBUaXRsZU1ldGFkYXRhO1xuXG4gIHByaXZhdGUgbGFuZ1NlcnZpY2UgPSBpbmplY3QoTGFuZ1NlcnZpY2UpO1xuICBwcml2YXRlIGNkciA9IGluamVjdChDaGFuZ2VEZXRlY3RvclJlZik7XG5cbiAgZGlzcGxheUNvbnRlbnQkOiBPYnNlcnZhYmxlPHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMudXBkYXRlQ29udGVudCgpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzWydwcm9wcyddKSB7XG4gICAgICB0aGlzLnVwZGF0ZUNvbnRlbnQoKTtcbiAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHVwZGF0ZUNvbnRlbnQoKSB7XG4gICAgLy8gQWx3YXlzIGNvbnZlcnQgdG8gT2JzZXJ2YWJsZSBmb3IgY29uc2lzdGVudCB0ZW1wbGF0ZSBoYW5kbGluZ1xuICAgIGlmIChzaG91bGRVc2VSZWFjdGl2ZUNvbnRlbnQodGhpcy5wcm9wcykpIHtcbiAgICAgIC8vIFVzZSByZWFjdGl2ZSBjb250ZW50IHdpdGggTGFuZ1NlcnZpY2VcbiAgICAgIGNvbnN0IGNvbmZpZyA9IGV4dHJhY3RDb250ZW50Q29uZmlnKHRoaXMucHJvcHMpO1xuICAgICAgdGhpcy5kaXNwbGF5Q29udGVudCQgPSB0aGlzLmxhbmdTZXJ2aWNlLmdldENvbnRlbnQoY29uZmlnLmNsYXNzTmFtZSwgY29uZmlnLmtleSwgY29uZmlnLmZhbGxiYWNrKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gQ29udmVydCBzdGF0aWMgY29udGVudCB0byBPYnNlcnZhYmxlXG4gICAgICBjb25zdCBzdGF0aWNDb250ZW50ID0gdGhpcy5wcm9wcy5jb250ZW50IHx8ICcnO1xuICAgICAgdGhpcy5kaXNwbGF5Q29udGVudCQgPSBvZihzdGF0aWNDb250ZW50KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -21,7 +21,11 @@ export class TitleBlockComponent {
21
21
  ngOnInit() { }
22
22
  ngOnChanges(changes) {
23
23
  if (changes['props']) {
24
+ // Forzar detección de cambios múltiple
24
25
  this.cdr.detectChanges();
26
+ setTimeout(() => {
27
+ this.cdr.detectChanges();
28
+ }, 0);
25
29
  }
26
30
  }
27
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TitleBlockComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -95,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
95
99
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
96
100
  type: Input
97
101
  }] } });
98
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtYmxvY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvdGl0bGUtYmxvY2svdGl0bGUtYmxvY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQXFCLFNBQVMsRUFBRSxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBeUNuRTs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLE9BQU8sbUJBQW1CO0lBSTlCLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQUcsQ0FBQztJQUU5QyxRQUFRLEtBQUksQ0FBQztJQUViLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDM0IsQ0FBQztJQUNILENBQUM7K0dBWlUsbUJBQW1CO21HQUFuQixtQkFBbUIsNEhBNUNwQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCVCxtcEdBaENTLFlBQVksOFJBQUUsY0FBYyx5RUFBRSxnQkFBZ0I7OzRGQTZDN0MsbUJBQW1CO2tCQWhEL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixDQUFDLFlBQy9DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBK0JUO3NGQWVELEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpc3BsYXlDb21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9kaXNwbGF5L2Rpc3BsYXkuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvdGl0bGUvdGl0bGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQmxvY2tNZXRhZGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXRpdGxlLWJsb2NrJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVGl0bGVDb21wb25lbnQsIERpc3BsYXlDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgW25nQ2xhc3NdPVwiWyd0aXRsZXMtY29udGFpbmVyJywgcHJvcHMucG9zaXRpb25dXCI+XG4gICAgICA8dmFsLXRpdGxlXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYWJvdmVUaXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMuYWJvdmVUaXRsZS5jb250ZW50IHwgdXBwZXJjYXNlLFxuICAgICAgICAgIGNvbG9yOiBwcm9wcy5hYm92ZVRpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmFib3ZlVGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgICA8dmFsLWRpc3BsYXlcbiAgICAgICAgKm5nSWY9XCJwcm9wcy50aXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMudGl0bGUuY29udGVudCxcbiAgICAgICAgICBjb2xvcjogcHJvcHMudGl0bGUuY29sb3IsXG4gICAgICAgICAgc2l6ZTogcHJvcHMudGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtZGlzcGxheT5cbiAgICAgIDx2YWwtdGl0bGVcbiAgICAgICAgc3R5bGU9XCJtYXJnaW4tdG9wOiAxNnB4O1wiXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYmVsbG93VGl0bGVcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IHByb3BzLmJlbGxvd1RpdGxlLmNvbnRlbnQsXG4gICAgICAgICAgY29sb3I6IHByb3BzLmJlbGxvd1RpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmJlbGxvd1RpdGxlLnNpemUsXG4gICAgICAgICAgdGhpbjogcHJvcHMuYmVsbG93VGl0bGUudGhpbixcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RpdGxlLWJsb2NrLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtdGl0bGUtYmxvY2tcbiAqXG4gKiBEaXNwbGF5cyBhIGJsb2NrIG9mIHRpdGxlcyAoYWJvdmUsIG1haW4sIGJlbG93KSB3aXRoIGNvbmZpZ3VyYWJsZSBzdHlsZXMgYW5kIHBvc2l0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogPHZhbC10aXRsZS1ibG9jayBbcHJvcHNdPVwieyB0aXRsZTogey4uLn0sIGFib3ZlVGl0bGU6IHsuLi59LCBiZWxsb3dUaXRsZTogey4uLn0sIHBvc2l0aW9uOiAnY2VudGVyJyB9XCI+PC92YWwtdGl0bGUtYmxvY2s+XG4gKlxuICogQGlucHV0IHByb3BzOiBUaXRsZUJsb2NrTWV0YWRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIHRpdGxlIGJsb2NrICh0aXRsZSwgYWJvdmVUaXRsZSwgYmVsbG93VGl0bGUsIHBvc2l0aW9uKVxuICovXG5leHBvcnQgY2xhc3MgVGl0bGVCbG9ja0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFRpdGxlQmxvY2tNZXRhZGE7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbJ3Byb3BzJ10pIHtcbiAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
102
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtYmxvY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvdGl0bGUtYmxvY2svdGl0bGUtYmxvY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQXFCLFNBQVMsRUFBRSxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBeUNuRTs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLE9BQU8sbUJBQW1CO0lBSTlCLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQUcsQ0FBQztJQUU5QyxRQUFRLEtBQUksQ0FBQztJQUViLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ3JCLHVDQUF1QztZQUN2QyxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3pCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMzQixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDUixDQUFDO0lBQ0gsQ0FBQzsrR0FoQlUsbUJBQW1CO21HQUFuQixtQkFBbUIsNEhBNUNwQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCVCxtcEdBaENTLFlBQVksOFJBQUUsY0FBYyx5RUFBRSxnQkFBZ0I7OzRGQTZDN0MsbUJBQW1CO2tCQWhEL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixDQUFDLFlBQy9DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBK0JUO3NGQWVELEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpc3BsYXlDb21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9kaXNwbGF5L2Rpc3BsYXkuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvdGl0bGUvdGl0bGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQmxvY2tNZXRhZGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXRpdGxlLWJsb2NrJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVGl0bGVDb21wb25lbnQsIERpc3BsYXlDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgW25nQ2xhc3NdPVwiWyd0aXRsZXMtY29udGFpbmVyJywgcHJvcHMucG9zaXRpb25dXCI+XG4gICAgICA8dmFsLXRpdGxlXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYWJvdmVUaXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMuYWJvdmVUaXRsZS5jb250ZW50IHwgdXBwZXJjYXNlLFxuICAgICAgICAgIGNvbG9yOiBwcm9wcy5hYm92ZVRpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmFib3ZlVGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgICA8dmFsLWRpc3BsYXlcbiAgICAgICAgKm5nSWY9XCJwcm9wcy50aXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMudGl0bGUuY29udGVudCxcbiAgICAgICAgICBjb2xvcjogcHJvcHMudGl0bGUuY29sb3IsXG4gICAgICAgICAgc2l6ZTogcHJvcHMudGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtZGlzcGxheT5cbiAgICAgIDx2YWwtdGl0bGVcbiAgICAgICAgc3R5bGU9XCJtYXJnaW4tdG9wOiAxNnB4O1wiXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYmVsbG93VGl0bGVcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IHByb3BzLmJlbGxvd1RpdGxlLmNvbnRlbnQsXG4gICAgICAgICAgY29sb3I6IHByb3BzLmJlbGxvd1RpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmJlbGxvd1RpdGxlLnNpemUsXG4gICAgICAgICAgdGhpbjogcHJvcHMuYmVsbG93VGl0bGUudGhpbixcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RpdGxlLWJsb2NrLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtdGl0bGUtYmxvY2tcbiAqXG4gKiBEaXNwbGF5cyBhIGJsb2NrIG9mIHRpdGxlcyAoYWJvdmUsIG1haW4sIGJlbG93KSB3aXRoIGNvbmZpZ3VyYWJsZSBzdHlsZXMgYW5kIHBvc2l0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogPHZhbC10aXRsZS1ibG9jayBbcHJvcHNdPVwieyB0aXRsZTogey4uLn0sIGFib3ZlVGl0bGU6IHsuLi59LCBiZWxsb3dUaXRsZTogey4uLn0sIHBvc2l0aW9uOiAnY2VudGVyJyB9XCI+PC92YWwtdGl0bGUtYmxvY2s+XG4gKlxuICogQGlucHV0IHByb3BzOiBUaXRsZUJsb2NrTWV0YWRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIHRpdGxlIGJsb2NrICh0aXRsZSwgYWJvdmVUaXRsZSwgYmVsbG93VGl0bGUsIHBvc2l0aW9uKVxuICovXG5leHBvcnQgY2xhc3MgVGl0bGVCbG9ja0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFRpdGxlQmxvY2tNZXRhZGE7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbJ3Byb3BzJ10pIHtcbiAgICAgIC8vIEZvcnphciBkZXRlY2Npw7NuIGRlIGNhbWJpb3MgbcO6bHRpcGxlXG4gICAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgfSwgMCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -26,7 +26,11 @@ export class BannerComponent {
26
26
  ngOnInit() { }
27
27
  ngOnChanges(changes) {
28
28
  if (changes['props']) {
29
+ // Forzar detección de cambios múltiple
29
30
  this.cdr.detectChanges();
31
+ setTimeout(() => {
32
+ this.cdr.detectChanges();
33
+ }, 0);
30
34
  }
31
35
  }
32
36
  clickHandler(token) {
@@ -104,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
104
108
  }], onClose: [{
105
109
  type: Output
106
110
  }] } });
107
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL2Jhbm5lci9iYW5uZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUMzRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBc0N4Rjs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBVTFCLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBTDFDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBR3JDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBRWdCLENBQUM7SUFFOUMsUUFBUSxLQUFJLENBQUM7SUFFYixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWM7UUFDekIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7K0dBMUJVLGVBQWU7bUdBQWYsZUFBZSw0S0EzQ2hCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBNEJULHVzR0E3QlMsWUFBWSw2SEFBRSxZQUFZLDZGQUFFLG1CQUFtQiwrRUFBRSxvQkFBb0I7OzRGQTRDcEUsZUFBZTtrQkEvQzNCLFNBQVM7K0JBQ0UsWUFBWSxjQUNWLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLENBQUMsWUFDdEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E0QlQ7c0ZBaUJELEtBQUs7c0JBREosS0FBSztnQkFJTixPQUFPO3NCQUROLE1BQU07Z0JBSVAsT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFNpbXBsZUNoYW5nZXMsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQm94Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvYm94L2JveC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnV0dG9uR3JvdXBDb21wb25lbnQgfSBmcm9tICcuLi8uLi9tb2xlY3VsZXMvYnV0dG9uLWdyb3VwL2J1dHRvbi1ncm91cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGl0bGVCbG9ja0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy90aXRsZS1ibG9jay90aXRsZS1ibG9jay5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFubmVyTWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWJhbm5lcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJveENvbXBvbmVudCwgVGl0bGVCbG9ja0NvbXBvbmVudCwgQnV0dG9uR3JvdXBDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDx2YWwtYm94XG4gICAgICBbcHJvcHNdPVwie1xuICAgICAgICBpY29uOiBwcm9wcy5jbG9zYWJsZSA/ICdjbG9zZS1vdXRsaW5lJyA6ICcnLFxuICAgICAgICBib3JkZXJlZDogcHJvcHMuYm9yZGVyZWQsXG4gICAgICAgIGNvbG9yOiAnJyxcbiAgICAgICAgcGFkZGluZzogcHJvcHMucGFkZGluZyxcbiAgICAgIH1cIlxuICAgICAgKG9uQ2xpY2spPVwiY2xvc2VIYW5kbGVyKClcIlxuICAgID5cbiAgICAgIDxkaXYgW25nQ2xhc3NdPVwiWydjb250ZW50LWNvbnRhaW5lcicsIHByb3BzLm1vZGUsIHByb3BzLmFsaWdubWVudF1cIiBib2R5PlxuICAgICAgICA8dmFsLXRpdGxlLWJsb2NrXG4gICAgICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgICAgIHBvc2l0aW9uOiBwcm9wcy5jb250ZW50LnBvc2l0aW9uLFxuICAgICAgICAgICAgYWJvdmVUaXRsZTogcHJvcHMuY29udGVudC5hYm92ZVRpdGxlLFxuICAgICAgICAgICAgdGl0bGU6IHByb3BzLmNvbnRlbnQudGl0bGUsXG4gICAgICAgICAgICBiZWxsb3dUaXRsZTogcHJvcHMuY29udGVudC5iZWxsb3dUaXRsZSxcbiAgICAgICAgICB9XCJcbiAgICAgICAgPjwvdmFsLXRpdGxlLWJsb2NrPlxuICAgICAgICBAaWYgKHByb3BzLmFjdGlvbnMpIHtcbiAgICAgICAgICA8dmFsLWJ1dHRvbi1ncm91cFxuICAgICAgICAgICAgW25nQ2xhc3NdPVwiWydidXR0b25zLWNvbnRhaW5lcicsIHByb3BzLm1vZGUsIHByb3BzLmFsaWdubWVudF1cIlxuICAgICAgICAgICAgW3Byb3BzXT1cInByb3BzLmFjdGlvbnNcIlxuICAgICAgICAgICAgKG9uQ2xpY2spPVwiY2xpY2tIYW5kbGVyKCRldmVudClcIlxuICAgICAgICAgID48L3ZhbC1idXR0b24tZ3JvdXA+XG4gICAgICAgIH1cbiAgICAgIDwvZGl2PlxuICAgIDwvdmFsLWJveD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vYmFubmVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtYmFubmVyXG4gKlxuICogRGlzcGxheXMgYSBiYW5uZXIgd2l0aCB0aXRsZSBibG9jaywgYWN0aW9ucywgYW5kIG9wdGlvbmFsIGNsb3NlIGJ1dHRvbi5cbiAqXG4gKiBAZXhhbXBsZVxuICogPHZhbC1iYW5uZXIgW3Byb3BzXT1cInsgY29udGVudDogey4uLn0sIGFjdGlvbnM6IHsuLi59LCBjbG9zYWJsZTogdHJ1ZSwgYm9yZGVyZWQ6IHRydWUsIG1vZGU6ICdjZW50ZXInLCBhbGlnbm1lbnQ6ICdjZW50ZXInLCBwYWRkaW5nOiAnOHB4JyB9XCIgKG9uQ2xpY2spPVwiaGFuZGxlcigkZXZlbnQpXCIgKG9uQ2xvc2UpPVwiY2xvc2VIYW5kbGVyKClcIj48L3ZhbC1iYW5uZXI+XG4gKlxuICogQGlucHV0IHByb3BzOiBCYW5uZXJNZXRhZGF0YSAtIENvbmZpZ3VyYXRpb24gZm9yIHRoZSBiYW5uZXIgKGNvbnRlbnQsIGFjdGlvbnMsIGNsb3NhYmxlLCBib3JkZXJlZCwgbW9kZSwgYWxpZ25tZW50LCBwYWRkaW5nKVxuICogQG91dHB1dCBvbkNsaWNrIC0gRW1pdHMgd2hlbiBhbiBhY3Rpb24gaXMgY2xpY2tlZFxuICogQG91dHB1dCBvbkNsb3NlIC0gRW1pdHMgd2hlbiB0aGUgYmFubmVyIGlzIGNsb3NlZFxuICovXG5leHBvcnQgY2xhc3MgQmFubmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICBASW5wdXQoKVxuICBwcm9wczogQmFubmVyTWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBAT3V0cHV0KClcbiAgb25DbG9zZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1sncHJvcHMnXSkge1xuICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgIH1cbiAgfVxuXG4gIGNsaWNrSGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25DbGljay5lbWl0KHRva2VuKTtcbiAgfVxuXG4gIGNsb3NlSGFuZGxlcigpIHtcbiAgICB0aGlzLm9uQ2xvc2UuZW1pdCgpO1xuICB9XG59XG4iXX0=
111
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL2Jhbm5lci9iYW5uZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUMzRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBc0N4Rjs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBVTFCLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBTDFDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBR3JDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBRWdCLENBQUM7SUFFOUMsUUFBUSxLQUFJLENBQUM7SUFFYixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyQix1Q0FBdUM7WUFDdkMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN6QixVQUFVLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDM0IsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ1IsQ0FBQztJQUNILENBQUM7SUFFRCxZQUFZLENBQUMsS0FBYztRQUN6QixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQzsrR0E5QlUsZUFBZTttR0FBZixlQUFlLDRLQTNDaEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E0QlQsdXNHQTdCUyxZQUFZLDZIQUFFLFlBQVksNkZBQUUsbUJBQW1CLCtFQUFFLG9CQUFvQjs7NEZBNENwRSxlQUFlO2tCQS9DM0IsU0FBUzsrQkFDRSxZQUFZLGNBQ1YsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxvQkFBb0IsQ0FBQyxZQUN0RTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTRCVDtzRkFpQkQsS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTTtnQkFJUCxPQUFPO3NCQUROLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkluaXQsXG4gIE91dHB1dCxcbiAgU2ltcGxlQ2hhbmdlcyxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCb3hDb21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9ib3gvYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25Hcm91cENvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9idXR0b24tZ3JvdXAvYnV0dG9uLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUaXRsZUJsb2NrQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbW9sZWN1bGVzL3RpdGxlLWJsb2NrL3RpdGxlLWJsb2NrLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYW5uZXJNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtYmFubmVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQm94Q29tcG9uZW50LCBUaXRsZUJsb2NrQ29tcG9uZW50LCBCdXR0b25Hcm91cENvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPHZhbC1ib3hcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIGljb246IHByb3BzLmNsb3NhYmxlID8gJ2Nsb3NlLW91dGxpbmUnIDogJycsXG4gICAgICAgIGJvcmRlcmVkOiBwcm9wcy5ib3JkZXJlZCxcbiAgICAgICAgY29sb3I6ICcnLFxuICAgICAgICBwYWRkaW5nOiBwcm9wcy5wYWRkaW5nLFxuICAgICAgfVwiXG4gICAgICAob25DbGljayk9XCJjbG9zZUhhbmRsZXIoKVwiXG4gICAgPlxuICAgICAgPGRpdiBbbmdDbGFzc109XCJbJ2NvbnRlbnQtY29udGFpbmVyJywgcHJvcHMubW9kZSwgcHJvcHMuYWxpZ25tZW50XVwiIGJvZHk+XG4gICAgICAgIDx2YWwtdGl0bGUtYmxvY2tcbiAgICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgICAgcG9zaXRpb246IHByb3BzLmNvbnRlbnQucG9zaXRpb24sXG4gICAgICAgICAgICBhYm92ZVRpdGxlOiBwcm9wcy5jb250ZW50LmFib3ZlVGl0bGUsXG4gICAgICAgICAgICB0aXRsZTogcHJvcHMuY29udGVudC50aXRsZSxcbiAgICAgICAgICAgIGJlbGxvd1RpdGxlOiBwcm9wcy5jb250ZW50LmJlbGxvd1RpdGxlLFxuICAgICAgICAgIH1cIlxuICAgICAgICA+PC92YWwtdGl0bGUtYmxvY2s+XG4gICAgICAgIEBpZiAocHJvcHMuYWN0aW9ucykge1xuICAgICAgICAgIDx2YWwtYnV0dG9uLWdyb3VwXG4gICAgICAgICAgICBbbmdDbGFzc109XCJbJ2J1dHRvbnMtY29udGFpbmVyJywgcHJvcHMubW9kZSwgcHJvcHMuYWxpZ25tZW50XVwiXG4gICAgICAgICAgICBbcHJvcHNdPVwicHJvcHMuYWN0aW9uc1wiXG4gICAgICAgICAgICAob25DbGljayk9XCJjbGlja0hhbmRsZXIoJGV2ZW50KVwiXG4gICAgICAgICAgPjwvdmFsLWJ1dHRvbi1ncm91cD5cbiAgICAgICAgfVxuICAgICAgPC9kaXY+XG4gICAgPC92YWwtYm94PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9iYW5uZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG4vKipcbiAqIHZhbC1iYW5uZXJcbiAqXG4gKiBEaXNwbGF5cyBhIGJhbm5lciB3aXRoIHRpdGxlIGJsb2NrLCBhY3Rpb25zLCBhbmQgb3B0aW9uYWwgY2xvc2UgYnV0dG9uLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8dmFsLWJhbm5lciBbcHJvcHNdPVwieyBjb250ZW50OiB7Li4ufSwgYWN0aW9uczogey4uLn0sIGNsb3NhYmxlOiB0cnVlLCBib3JkZXJlZDogdHJ1ZSwgbW9kZTogJ2NlbnRlcicsIGFsaWdubWVudDogJ2NlbnRlcicsIHBhZGRpbmc6ICc4cHgnIH1cIiAob25DbGljayk9XCJoYW5kbGVyKCRldmVudClcIiAob25DbG9zZSk9XCJjbG9zZUhhbmRsZXIoKVwiPjwvdmFsLWJhbm5lcj5cbiAqXG4gKiBAaW5wdXQgcHJvcHM6IEJhbm5lck1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGJhbm5lciAoY29udGVudCwgYWN0aW9ucywgY2xvc2FibGUsIGJvcmRlcmVkLCBtb2RlLCBhbGlnbm1lbnQsIHBhZGRpbmcpXG4gKiBAb3V0cHV0IG9uQ2xpY2sgLSBFbWl0cyB3aGVuIGFuIGFjdGlvbiBpcyBjbGlja2VkXG4gKiBAb3V0cHV0IG9uQ2xvc2UgLSBFbWl0cyB3aGVuIHRoZSBiYW5uZXIgaXMgY2xvc2VkXG4gKi9cbmV4cG9ydCBjbGFzcyBCYW5uZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBCYW5uZXJNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzWydwcm9wcyddKSB7XG4gICAgICAvLyBGb3J6YXIgZGV0ZWNjacOzbiBkZSBjYW1iaW9zIG3Dumx0aXBsZVxuICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICAgIH0sIDApO1xuICAgIH1cbiAgfVxuXG4gIGNsaWNrSGFuZGxlcih0b2tlbj86IHN0cmluZykge1xuICAgIHRoaXMub25DbGljay5lbWl0KHRva2VuKTtcbiAgfVxuXG4gIGNsb3NlSGFuZGxlcigpIHtcbiAgICB0aGlzLm9uQ2xvc2UuZW1pdCgpO1xuICB9XG59XG4iXX0=
@@ -22,7 +22,11 @@ export class NoContentComponent {
22
22
  ngOnInit() { }
23
23
  ngOnChanges(changes) {
24
24
  if (changes['props']) {
25
+ // Forzar detección de cambios múltiple para asegurar actualización
25
26
  this.cdr.detectChanges();
27
+ setTimeout(() => {
28
+ this.cdr.detectChanges();
29
+ }, 0);
26
30
  }
27
31
  }
28
32
  onClickHandler(token) {
@@ -59,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
59
63
  }], onClick: [{
60
64
  type: Output
61
65
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm8tY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy9uby1jb250ZW50L25vLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFHTCxNQUFNLEdBRVAsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFvQjdEOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQU83QixZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUYxQyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUVRLENBQUM7SUFFOUMsUUFBUSxLQUFJLENBQUM7SUFFYixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQWE7UUFDMUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQzsrR0FuQlUsa0JBQWtCO21HQUFsQixrQkFBa0IsNEpBekJuQjs7Ozs7Ozs7OztHQVVULHVyRkFYUyxjQUFjLHlFQUFFLGVBQWU7OzRGQTBCOUIsa0JBQWtCO2tCQTdCOUIsU0FBUzsrQkFDRSxnQkFBZ0IsY0FDZCxJQUFJLFdBQ1AsQ0FBQyxjQUFjLEVBQUUsZUFBZSxDQUFDLFlBQ2hDOzs7Ozs7Ozs7O0dBVVQ7c0ZBaUJELEtBQUs7c0JBREosS0FBSztnQkFJTixPQUFPO3NCQUROLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIE9uSW5pdCxcbiAgT3V0cHV0LFxuICBTaW1wbGVDaGFuZ2VzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvaW1hZ2UvaW1hZ2UuY29tcG9uZW50JztcbmltcG9ydCB7IEJhbm5lckNvbXBvbmVudCB9IGZyb20gJy4uL2Jhbm5lci9iYW5uZXIuY29tcG9uZW50JztcbmltcG9ydCB7IE5vQ29udGVudE1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1uby1jb250ZW50JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0ltYWdlQ29tcG9uZW50LCBCYW5uZXJDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIEBpZiAocHJvcHMudG9wQ29udGVudCkge1xuICAgICAgPGRpdj5cbiAgICAgICAgPHZhbC1iYW5uZXIgW3Byb3BzXT1cInByb3BzLnRvcENvbnRlbnRcIiAob25DbGljayk9XCJvbkNsaWNrSGFuZGxlcigkZXZlbnQpXCI+PC92YWwtYmFubmVyPlxuICAgICAgPC9kaXY+XG4gICAgfVxuICAgIDx2YWwtaW1hZ2UgY2xhc3M9XCJpbWFnZS1jb250YWluZXJcIiBbcHJvcHNdPVwicHJvcHMuaW1hZ2VcIj48L3ZhbC1pbWFnZT5cbiAgICA8ZGl2PlxuICAgICAgPHZhbC1iYW5uZXIgW3Byb3BzXT1cInByb3BzLmJvdHRvbUNvbnRlbnRcIiAob25DbGljayk9XCJvbkNsaWNrSGFuZGxlcigkZXZlbnQpXCI+PC92YWwtYmFubmVyPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi9uby1jb250ZW50LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiBOb0NvbnRlbnRDb21wb25lbnRcbiAqXG4gKiBDb21wb25lbnRlIHBhcmEgbW9zdHJhciB1bmEgcGFudGFsbGEgZGUgXCJzaW4gY29udGVuaWRvXCIgY29uIGltYWdlbiB5IGJhbm5lcnMgb3BjaW9uYWxlcyBhcnJpYmEgeSBhYmFqby5cbiAqIMOadGlsIHBhcmEgZXN0YWRvcyB2YWPDrW9zLCBlcnJvcmVzIG8gbWVuc2FqZXMgaW5mb3JtYXRpdm9zLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8dmFsLW5vLWNvbnRlbnQgW3Byb3BzXT1cInsgaW1hZ2U6IHsgc3JjOiAnZW1wdHkuc3ZnJyB9LCBib3R0b21Db250ZW50OiB7IC4uLiB9IH1cIj48L3ZhbC1uby1jb250ZW50PlxuICpcbiAqIEBpbnB1dCBwcm9wcyB7Tm9Db250ZW50TWV0YWRhdGF9IC0gTWV0YWRhdG9zIGRlIGxhIGltYWdlbiB5IGJhbm5lcnMgYSBtb3N0cmFyLlxuICogQG91dHB1dCBvbkNsaWNrIC0gRW1pdGUgZWwgdG9rZW4gZGUgYWNjacOzbiBkZSBsb3MgYmFubmVycyBzaSBjb3JyZXNwb25kZS5cbiAqL1xuZXhwb3J0IGNsYXNzIE5vQ29udGVudENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KClcbiAgcHJvcHM6IE5vQ29udGVudE1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbJ3Byb3BzJ10pIHtcbiAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG4gIH1cblxuICBvbkNsaWNrSGFuZGxlcih0b2tlbjogc3RyaW5nKSB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQodG9rZW4pO1xuICB9XG59XG4iXX0=
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm8tY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy9uby1jb250ZW50L25vLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFHTCxNQUFNLEdBRVAsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFvQjdEOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxPQUFPLGtCQUFrQjtJQU83QixZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUYxQyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQUVRLENBQUM7SUFFOUMsUUFBUSxLQUFJLENBQUM7SUFFYixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyQixtRUFBbUU7WUFDbkUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUN6QixVQUFVLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDM0IsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ1IsQ0FBQztJQUNILENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYTtRQUMxQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMzQixDQUFDOytHQXZCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw0SkF6Qm5COzs7Ozs7Ozs7O0dBVVQsdXJGQVhTLGNBQWMseUVBQUUsZUFBZTs7NEZBMEI5QixrQkFBa0I7a0JBN0I5QixTQUFTOytCQUNFLGdCQUFnQixjQUNkLElBQUksV0FDUCxDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsWUFDaEM7Ozs7Ozs7Ozs7R0FVVDtzRkFpQkQsS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFNpbXBsZUNoYW5nZXMsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW1hZ2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9pbWFnZS9pbWFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFubmVyQ29tcG9uZW50IH0gZnJvbSAnLi4vYmFubmVyL2Jhbm5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTm9Db250ZW50TWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLW5vLWNvbnRlbnQnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbSW1hZ2VDb21wb25lbnQsIEJhbm5lckNvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgQGlmIChwcm9wcy50b3BDb250ZW50KSB7XG4gICAgICA8ZGl2PlxuICAgICAgICA8dmFsLWJhbm5lciBbcHJvcHNdPVwicHJvcHMudG9wQ29udGVudFwiIChvbkNsaWNrKT1cIm9uQ2xpY2tIYW5kbGVyKCRldmVudClcIj48L3ZhbC1iYW5uZXI+XG4gICAgICA8L2Rpdj5cbiAgICB9XG4gICAgPHZhbC1pbWFnZSBjbGFzcz1cImltYWdlLWNvbnRhaW5lclwiIFtwcm9wc109XCJwcm9wcy5pbWFnZVwiPjwvdmFsLWltYWdlPlxuICAgIDxkaXY+XG4gICAgICA8dmFsLWJhbm5lciBbcHJvcHNdPVwicHJvcHMuYm90dG9tQ29udGVudFwiIChvbkNsaWNrKT1cIm9uQ2xpY2tIYW5kbGVyKCRldmVudClcIj48L3ZhbC1iYW5uZXI+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL25vLWNvbnRlbnQuY29tcG9uZW50LnNjc3MnXSxcbn0pXG4vKipcbiAqIE5vQ29udGVudENvbXBvbmVudFxuICpcbiAqIENvbXBvbmVudGUgcGFyYSBtb3N0cmFyIHVuYSBwYW50YWxsYSBkZSBcInNpbiBjb250ZW5pZG9cIiBjb24gaW1hZ2VuIHkgYmFubmVycyBvcGNpb25hbGVzIGFycmliYSB5IGFiYWpvLlxuICogw5p0aWwgcGFyYSBlc3RhZG9zIHZhY8Otb3MsIGVycm9yZXMgbyBtZW5zYWplcyBpbmZvcm1hdGl2b3MuXG4gKlxuICogQGV4YW1wbGVcbiAqIDx2YWwtbm8tY29udGVudCBbcHJvcHNdPVwieyBpbWFnZTogeyBzcmM6ICdlbXB0eS5zdmcnIH0sIGJvdHRvbUNvbnRlbnQ6IHsgLi4uIH0gfVwiPjwvdmFsLW5vLWNvbnRlbnQ+XG4gKlxuICogQGlucHV0IHByb3BzIHtOb0NvbnRlbnRNZXRhZGF0YX0gLSBNZXRhZGF0b3MgZGUgbGEgaW1hZ2VuIHkgYmFubmVycyBhIG1vc3RyYXIuXG4gKiBAb3V0cHV0IG9uQ2xpY2sgLSBFbWl0ZSBlbCB0b2tlbiBkZSBhY2Npw7NuIGRlIGxvcyBiYW5uZXJzIHNpIGNvcnJlc3BvbmRlLlxuICovXG5leHBvcnQgY2xhc3MgTm9Db250ZW50Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICBASW5wdXQoKVxuICBwcm9wczogTm9Db250ZW50TWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1sncHJvcHMnXSkge1xuICAgICAgLy8gRm9yemFyIGRldGVjY2nDs24gZGUgY2FtYmlvcyBtw7psdGlwbGUgcGFyYSBhc2VndXJhciBhY3R1YWxpemFjacOzblxuICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICAgIH0sIDApO1xuICAgIH1cbiAgfVxuXG4gIG9uQ2xpY2tIYW5kbGVyKHRva2VuOiBzdHJpbmcpIHtcbiAgICB0aGlzLm9uQ2xpY2suZW1pdCh0b2tlbik7XG4gIH1cbn1cbiJdfQ==
@@ -28,7 +28,16 @@ export class WizardComponent {
28
28
  if (this.props?.steps && this.props?.current) {
29
29
  this.currentStep = this.props.steps[this.props.current];
30
30
  // Forzar nueva referencia de objeto para asegurar detección de cambios
31
- this.currentStepTitles = this.currentStep?.titles ? JSON.parse(JSON.stringify(this.currentStep.titles)) : null;
31
+ // Agregar timestamp para garantizar que es un objeto completamente nuevo
32
+ this.currentStepTitles = this.currentStep?.titles
33
+ ? {
34
+ ...JSON.parse(JSON.stringify(this.currentStep.titles)),
35
+ _timestamp: Date.now(), // Forzar nueva referencia
36
+ _step: this.props.current, // Agregar identificador del paso
37
+ }
38
+ : null;
39
+ // Forzar detección de cambios inmediatamente
40
+ this.cdr.detectChanges();
32
41
  }
33
42
  }
34
43
  working() {
@@ -64,7 +73,11 @@ export class WizardComponent {
64
73
  }
65
74
  this.props.current = newStep;
66
75
  this.updateCurrentStep();
76
+ // Forzar múltiples ciclos de detección de cambios
67
77
  this.cdr.detectChanges();
78
+ setTimeout(() => {
79
+ this.cdr.detectChanges();
80
+ }, 0);
68
81
  goToTop(this.wrapperId);
69
82
  }
70
83
  setError(error) {
@@ -93,7 +106,7 @@ export class WizardComponent {
93
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" }, usesOnChanges: true, ngImport: i0, template: `
94
107
  <div [id]="wrapperId" class="wrapper">
95
108
  <ng-container *ngIf="props.state !== 'ERROR'">
96
- <val-no-content [props]="currentStepTitles"></val-no-content>
109
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
97
110
  <div class="step">
98
111
  <div *ngIf="props.state === 'WORKING'">
99
112
  <val-content-loader
@@ -119,7 +132,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
119
132
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
120
133
  <div [id]="wrapperId" class="wrapper">
121
134
  <ng-container *ngIf="props.state !== 'ERROR'">
122
- <val-no-content [props]="currentStepTitles"></val-no-content>
135
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
123
136
  <div class="step">
124
137
  <div *ngIf="props.state === 'WORKING'">
125
138
  <val-content-loader
@@ -144,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
144
157
  }], onClick: [{
145
158
  type: Output
146
159
  }] } });
147
- //# 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.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      // Forzar nueva referencia de objeto para asegurar detección de cambios\n      this.currentStepTitles = this.currentStep?.titles ? JSON.parse(JSON.stringify(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\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.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"]}
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,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,aAAa,EAAE,CAAC;QAC3B,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,uEAAuE;YACvE,yEAAyE;YACzE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM;gBAC/C,CAAC,CAAC;oBACE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;oBACtD,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,0BAA0B;oBAClD,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,iCAAiC;iBAC7D;gBACH,CAAC,CAAC,IAAI,CAAC;YAET,6CAA6C;YAC7C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,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;QAED,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,kDAAkD;QAClD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAE,CAAC,CAAC,CAAC;QAEN,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;+GAnHU,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\" [attr.data-step]=\"props.current\"></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.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      // Forzar nueva referencia de objeto para asegurar detección de cambios\n      // Agregar timestamp para garantizar que es un objeto completamente nuevo\n      this.currentStepTitles = this.currentStep?.titles\n        ? {\n            ...JSON.parse(JSON.stringify(this.currentStep.titles)),\n            _timestamp: Date.now(), // Forzar nueva referencia\n            _step: this.props.current, // Agregar identificador del paso\n          }\n        : null;\n\n      // Forzar detección de cambios inmediatamente\n      this.cdr.detectChanges();\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\n    this.props.current = newStep;\n    this.updateCurrentStep();\n\n    // Forzar múltiples ciclos de detección de cambios\n    this.cdr.detectChanges();\n    setTimeout(() => {\n      this.cdr.detectChanges();\n    }, 0);\n\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"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { EventEmitter, Component, Input, Output, Injectable, inject, InjectionToken, Inject, Pipe, ChangeDetectionStrategy, ViewChild, ChangeDetectorRef } from '@angular/core';
2
+ import { EventEmitter, Component, Input, Output, Injectable, inject, InjectionToken, Inject, ChangeDetectorRef, Pipe, ChangeDetectionStrategy, ViewChild } from '@angular/core';
3
3
  import { IonAvatar, IonCard, IonIcon, IonButton, IonSpinner, IonText, IonProgressBar, IonCardContent, IonCardHeader, IonCardTitle, IonCardSubtitle, IonCheckbox, IonButtons, IonTextarea, IonDatetime, IonDatetimeButton, IonModal, IonInput, IonSelect, IonSelectOption, IonLabel, IonRadioGroup, IonRadio, IonSearchbar, IonToolbar, IonTitle, IonMenuButton, IonFooter, IonHeader, IonList, IonListHeader, IonNote, IonItem, IonContent } from '@ionic/angular/standalone';
4
4
  import * as i1 from '@angular/common';
5
5
  import { CommonModule, NgStyle, AsyncPipe, NgFor, NgClass } from '@angular/common';
@@ -1579,10 +1579,17 @@ class DisplayComponent {
1579
1579
  constructor() {
1580
1580
  this.subscriptions = new Subscription();
1581
1581
  this.langService = inject(LangService);
1582
+ this.cdr = inject(ChangeDetectorRef);
1582
1583
  }
1583
1584
  ngOnInit() {
1584
1585
  this.initializeDisplayContent();
1585
1586
  }
1587
+ ngOnChanges(changes) {
1588
+ if (changes['props']) {
1589
+ this.initializeDisplayContent();
1590
+ this.cdr.detectChanges();
1591
+ }
1592
+ }
1586
1593
  ngOnDestroy() {
1587
1594
  this.subscriptions.unsubscribe();
1588
1595
  }
@@ -1603,7 +1610,7 @@ class DisplayComponent {
1603
1610
  this.displayContent$ = of('');
1604
1611
  }
1605
1612
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1606
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayComponent, isStandalone: true, selector: "val-display", inputs: { props: "props" }, ngImport: i0, template: `
1613
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayComponent, isStandalone: true, selector: "val-display", inputs: { props: "props" }, usesOnChanges: true, ngImport: i0, template: `
1607
1614
  <ion-text [color]="props.color">
1608
1615
  <p [class]="props.size">
1609
1616
  {{ displayContent$ | async }}
@@ -2599,8 +2606,18 @@ function createTextProps(contentConfig, styleConfig = {}) {
2599
2606
  class TitleComponent {
2600
2607
  constructor() {
2601
2608
  this.langService = inject(LangService);
2609
+ this.cdr = inject(ChangeDetectorRef);
2602
2610
  }
2603
2611
  ngOnInit() {
2612
+ this.updateContent();
2613
+ }
2614
+ ngOnChanges(changes) {
2615
+ if (changes['props']) {
2616
+ this.updateContent();
2617
+ this.cdr.detectChanges();
2618
+ }
2619
+ }
2620
+ updateContent() {
2604
2621
  // Always convert to Observable for consistent template handling
2605
2622
  if (shouldUseReactiveContent(this.props)) {
2606
2623
  // Use reactive content with LangService
@@ -2614,7 +2631,7 @@ class TitleComponent {
2614
2631
  }
2615
2632
  }
2616
2633
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
2617
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TitleComponent, isStandalone: true, selector: "val-title", inputs: { props: "props" }, ngImport: i0, template: `
2634
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TitleComponent, isStandalone: true, selector: "val-title", inputs: { props: "props" }, usesOnChanges: true, ngImport: i0, template: `
2618
2635
  <ion-text [color]="props.color">
2619
2636
  @if (!props.bold) {
2620
2637
  <p [ngClass]="[props.size]" [class.thin]="props.thin">
@@ -4289,7 +4306,11 @@ class TitleBlockComponent {
4289
4306
  ngOnInit() { }
4290
4307
  ngOnChanges(changes) {
4291
4308
  if (changes['props']) {
4309
+ // Forzar detección de cambios múltiple
4292
4310
  this.cdr.detectChanges();
4311
+ setTimeout(() => {
4312
+ this.cdr.detectChanges();
4313
+ }, 0);
4293
4314
  }
4294
4315
  }
4295
4316
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TitleBlockComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -6492,7 +6513,11 @@ class BannerComponent {
6492
6513
  ngOnInit() { }
6493
6514
  ngOnChanges(changes) {
6494
6515
  if (changes['props']) {
6516
+ // Forzar detección de cambios múltiple
6495
6517
  this.cdr.detectChanges();
6518
+ setTimeout(() => {
6519
+ this.cdr.detectChanges();
6520
+ }, 0);
6496
6521
  }
6497
6522
  }
6498
6523
  clickHandler(token) {
@@ -7691,7 +7716,11 @@ class NoContentComponent {
7691
7716
  ngOnInit() { }
7692
7717
  ngOnChanges(changes) {
7693
7718
  if (changes['props']) {
7719
+ // Forzar detección de cambios múltiple para asegurar actualización
7694
7720
  this.cdr.detectChanges();
7721
+ setTimeout(() => {
7722
+ this.cdr.detectChanges();
7723
+ }, 0);
7695
7724
  }
7696
7725
  }
7697
7726
  onClickHandler(token) {
@@ -7864,7 +7893,16 @@ class WizardComponent {
7864
7893
  if (this.props?.steps && this.props?.current) {
7865
7894
  this.currentStep = this.props.steps[this.props.current];
7866
7895
  // Forzar nueva referencia de objeto para asegurar detección de cambios
7867
- this.currentStepTitles = this.currentStep?.titles ? JSON.parse(JSON.stringify(this.currentStep.titles)) : null;
7896
+ // Agregar timestamp para garantizar que es un objeto completamente nuevo
7897
+ this.currentStepTitles = this.currentStep?.titles
7898
+ ? {
7899
+ ...JSON.parse(JSON.stringify(this.currentStep.titles)),
7900
+ _timestamp: Date.now(), // Forzar nueva referencia
7901
+ _step: this.props.current, // Agregar identificador del paso
7902
+ }
7903
+ : null;
7904
+ // Forzar detección de cambios inmediatamente
7905
+ this.cdr.detectChanges();
7868
7906
  }
7869
7907
  }
7870
7908
  working() {
@@ -7900,7 +7938,11 @@ class WizardComponent {
7900
7938
  }
7901
7939
  this.props.current = newStep;
7902
7940
  this.updateCurrentStep();
7941
+ // Forzar múltiples ciclos de detección de cambios
7903
7942
  this.cdr.detectChanges();
7943
+ setTimeout(() => {
7944
+ this.cdr.detectChanges();
7945
+ }, 0);
7904
7946
  goToTop(this.wrapperId);
7905
7947
  }
7906
7948
  setError(error) {
@@ -7929,7 +7971,7 @@ class WizardComponent {
7929
7971
  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: `
7930
7972
  <div [id]="wrapperId" class="wrapper">
7931
7973
  <ng-container *ngIf="props.state !== 'ERROR'">
7932
- <val-no-content [props]="currentStepTitles"></val-no-content>
7974
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
7933
7975
  <div class="step">
7934
7976
  <div *ngIf="props.state === 'WORKING'">
7935
7977
  <val-content-loader
@@ -7955,7 +7997,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7955
7997
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
7956
7998
  <div [id]="wrapperId" class="wrapper">
7957
7999
  <ng-container *ngIf="props.state !== 'ERROR'">
7958
- <val-no-content [props]="currentStepTitles"></val-no-content>
8000
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
7959
8001
  <div class="step">
7960
8002
  <div *ngIf="props.state === 'WORKING'">
7961
8003
  <val-content-loader