valtech-components 2.0.347 → 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==
@@ -15,10 +15,21 @@ import * as i1 from "@angular/common";
15
15
  * @input props: TitleBlockMetada - Configuration for the title block (title, aboveTitle, bellowTitle, position)
16
16
  */
17
17
  export class TitleBlockComponent {
18
- constructor() { }
18
+ constructor(cdr) {
19
+ this.cdr = cdr;
20
+ }
19
21
  ngOnInit() { }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TitleBlockComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
21
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TitleBlockComponent, isStandalone: true, selector: "val-title-block", inputs: { props: "props" }, ngImport: i0, template: `
22
+ ngOnChanges(changes) {
23
+ if (changes['props']) {
24
+ // Forzar detección de cambios múltiple
25
+ this.cdr.detectChanges();
26
+ setTimeout(() => {
27
+ this.cdr.detectChanges();
28
+ }, 0);
29
+ }
30
+ }
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 }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TitleBlockComponent, isStandalone: true, selector: "val-title-block", inputs: { props: "props" }, usesOnChanges: true, ngImport: i0, template: `
22
33
  <div [ngClass]="['titles-container', props.position]">
23
34
  <val-title
24
35
  *ngIf="props.aboveTitle"
@@ -85,7 +96,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
85
96
  ></val-title>
86
97
  </div>
87
98
  `, 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)}val-button,val-title,val-display{display:inline-block}.titles-container{width:100%;display:flex;flex-direction:column;flex-wrap:wrap}.titles-container.left{align-content:flex-start;align-items:start;text-align:left}.titles-container.center{align-content:center;align-items:center;text-align:center}.titles-container.right{align-content:flex-end;align-items:end;text-align:end}.titles-container.leftocenter{align-content:flex-start;align-items:start;text-align:left}@media (min-width: 768px){.titles-container.leftocenter{align-content:center;align-items:center;text-align:center}}\n"] }]
88
- }], ctorParameters: () => [], propDecorators: { props: [{
99
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
89
100
  type: Input
90
101
  }] } });
91
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtYmxvY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvdGl0bGUtYmxvY2svdGl0bGUtYmxvY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUN6RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7OztBQXlDbkU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxPQUFPLG1CQUFtQjtJQUk5QixnQkFBZSxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDOytHQU5GLG1CQUFtQjttR0FBbkIsbUJBQW1CLHVHQTVDcEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0ErQlQsbXBHQWhDUyxZQUFZLDhSQUFFLGNBQWMseUVBQUUsZ0JBQWdCOzs0RkE2QzdDLG1CQUFtQjtrQkFoRC9CLFNBQVM7K0JBQ0UsaUJBQWlCLGNBQ2YsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxZQUMvQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCVDt3REFlRCxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaXNwbGF5Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvZGlzcGxheS9kaXNwbGF5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUaXRsZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL3RpdGxlL3RpdGxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUaXRsZUJsb2NrTWV0YWRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC10aXRsZS1ibG9jaycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRpdGxlQ29tcG9uZW50LCBEaXNwbGF5Q29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IFtuZ0NsYXNzXT1cIlsndGl0bGVzLWNvbnRhaW5lcicsIHByb3BzLnBvc2l0aW9uXVwiPlxuICAgICAgPHZhbC10aXRsZVxuICAgICAgICAqbmdJZj1cInByb3BzLmFib3ZlVGl0bGVcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IHByb3BzLmFib3ZlVGl0bGUuY29udGVudCB8IHVwcGVyY2FzZSxcbiAgICAgICAgICBjb2xvcjogcHJvcHMuYWJvdmVUaXRsZS5jb2xvcixcbiAgICAgICAgICBib2xkOiBmYWxzZSxcbiAgICAgICAgICBzaXplOiBwcm9wcy5hYm92ZVRpdGxlLnNpemUsXG4gICAgICAgIH1cIlxuICAgICAgPjwvdmFsLXRpdGxlPlxuICAgICAgPHZhbC1kaXNwbGF5XG4gICAgICAgICpuZ0lmPVwicHJvcHMudGl0bGVcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IHByb3BzLnRpdGxlLmNvbnRlbnQsXG4gICAgICAgICAgY29sb3I6IHByb3BzLnRpdGxlLmNvbG9yLFxuICAgICAgICAgIHNpemU6IHByb3BzLnRpdGxlLnNpemUsXG4gICAgICAgIH1cIlxuICAgICAgPjwvdmFsLWRpc3BsYXk+XG4gICAgICA8dmFsLXRpdGxlXG4gICAgICAgIHN0eWxlPVwibWFyZ2luLXRvcDogMTZweDtcIlxuICAgICAgICAqbmdJZj1cInByb3BzLmJlbGxvd1RpdGxlXCJcbiAgICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgICBjb250ZW50OiBwcm9wcy5iZWxsb3dUaXRsZS5jb250ZW50LFxuICAgICAgICAgIGNvbG9yOiBwcm9wcy5iZWxsb3dUaXRsZS5jb2xvcixcbiAgICAgICAgICBib2xkOiBmYWxzZSxcbiAgICAgICAgICBzaXplOiBwcm9wcy5iZWxsb3dUaXRsZS5zaXplLFxuICAgICAgICAgIHRoaW46IHByb3BzLmJlbGxvd1RpdGxlLnRoaW4sXG4gICAgICAgIH1cIlxuICAgICAgPjwvdmFsLXRpdGxlPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi90aXRsZS1ibG9jay5jb21wb25lbnQuc2NzcyddLFxufSlcbi8qKlxuICogdmFsLXRpdGxlLWJsb2NrXG4gKlxuICogRGlzcGxheXMgYSBibG9jayBvZiB0aXRsZXMgKGFib3ZlLCBtYWluLCBiZWxvdykgd2l0aCBjb25maWd1cmFibGUgc3R5bGVzIGFuZCBwb3NpdGlvbnMuXG4gKlxuICogQGV4YW1wbGVcbiAqIDx2YWwtdGl0bGUtYmxvY2sgW3Byb3BzXT1cInsgdGl0bGU6IHsuLi59LCBhYm92ZVRpdGxlOiB7Li4ufSwgYmVsbG93VGl0bGU6IHsuLi59LCBwb3NpdGlvbjogJ2NlbnRlcicgfVwiPjwvdmFsLXRpdGxlLWJsb2NrPlxuICpcbiAqIEBpbnB1dCBwcm9wczogVGl0bGVCbG9ja01ldGFkYSAtIENvbmZpZ3VyYXRpb24gZm9yIHRoZSB0aXRsZSBibG9jayAodGl0bGUsIGFib3ZlVGl0bGUsIGJlbGxvd1RpdGxlLCBwb3NpdGlvbilcbiAqL1xuZXhwb3J0IGNsYXNzIFRpdGxlQmxvY2tDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwcm9wczogVGl0bGVCbG9ja01ldGFkYTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgbmdPbkluaXQoKSB7fVxufVxuIl19
102
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtYmxvY2suY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvdGl0bGUtYmxvY2svdGl0bGUtYmxvY2suY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQXFCLFNBQVMsRUFBRSxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBeUNuRTs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLE9BQU8sbUJBQW1CO0lBSTlCLFlBQW9CLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO0lBQUcsQ0FBQztJQUU5QyxRQUFRLEtBQUksQ0FBQztJQUViLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQ3JCLHVDQUF1QztZQUN2QyxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ3pCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMzQixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDUixDQUFDO0lBQ0gsQ0FBQzsrR0FoQlUsbUJBQW1CO21HQUFuQixtQkFBbUIsNEhBNUNwQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQStCVCxtcEdBaENTLFlBQVksOFJBQUUsY0FBYyx5RUFBRSxnQkFBZ0I7OzRGQTZDN0MsbUJBQW1CO2tCQWhEL0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixDQUFDLFlBQy9DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBK0JUO3NGQWVELEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpc3BsYXlDb21wb25lbnQgfSBmcm9tICcuLi8uLi9hdG9tcy9kaXNwbGF5L2Rpc3BsYXkuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvdGl0bGUvdGl0bGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQmxvY2tNZXRhZGEgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXRpdGxlLWJsb2NrJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVGl0bGVDb21wb25lbnQsIERpc3BsYXlDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgW25nQ2xhc3NdPVwiWyd0aXRsZXMtY29udGFpbmVyJywgcHJvcHMucG9zaXRpb25dXCI+XG4gICAgICA8dmFsLXRpdGxlXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYWJvdmVUaXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMuYWJvdmVUaXRsZS5jb250ZW50IHwgdXBwZXJjYXNlLFxuICAgICAgICAgIGNvbG9yOiBwcm9wcy5hYm92ZVRpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmFib3ZlVGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgICA8dmFsLWRpc3BsYXlcbiAgICAgICAgKm5nSWY9XCJwcm9wcy50aXRsZVwiXG4gICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgY29udGVudDogcHJvcHMudGl0bGUuY29udGVudCxcbiAgICAgICAgICBjb2xvcjogcHJvcHMudGl0bGUuY29sb3IsXG4gICAgICAgICAgc2l6ZTogcHJvcHMudGl0bGUuc2l6ZSxcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtZGlzcGxheT5cbiAgICAgIDx2YWwtdGl0bGVcbiAgICAgICAgc3R5bGU9XCJtYXJnaW4tdG9wOiAxNnB4O1wiXG4gICAgICAgICpuZ0lmPVwicHJvcHMuYmVsbG93VGl0bGVcIlxuICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgIGNvbnRlbnQ6IHByb3BzLmJlbGxvd1RpdGxlLmNvbnRlbnQsXG4gICAgICAgICAgY29sb3I6IHByb3BzLmJlbGxvd1RpdGxlLmNvbG9yLFxuICAgICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgICAgIHNpemU6IHByb3BzLmJlbGxvd1RpdGxlLnNpemUsXG4gICAgICAgICAgdGhpbjogcHJvcHMuYmVsbG93VGl0bGUudGhpbixcbiAgICAgICAgfVwiXG4gICAgICA+PC92YWwtdGl0bGU+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RpdGxlLWJsb2NrLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyoqXG4gKiB2YWwtdGl0bGUtYmxvY2tcbiAqXG4gKiBEaXNwbGF5cyBhIGJsb2NrIG9mIHRpdGxlcyAoYWJvdmUsIG1haW4sIGJlbG93KSB3aXRoIGNvbmZpZ3VyYWJsZSBzdHlsZXMgYW5kIHBvc2l0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogPHZhbC10aXRsZS1ibG9jayBbcHJvcHNdPVwieyB0aXRsZTogey4uLn0sIGFib3ZlVGl0bGU6IHsuLi59LCBiZWxsb3dUaXRsZTogey4uLn0sIHBvc2l0aW9uOiAnY2VudGVyJyB9XCI+PC92YWwtdGl0bGUtYmxvY2s+XG4gKlxuICogQGlucHV0IHByb3BzOiBUaXRsZUJsb2NrTWV0YWRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIHRpdGxlIGJsb2NrICh0aXRsZSwgYWJvdmVUaXRsZSwgYmVsbG93VGl0bGUsIHBvc2l0aW9uKVxuICovXG5leHBvcnQgY2xhc3MgVGl0bGVCbG9ja0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFRpdGxlQmxvY2tNZXRhZGE7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbJ3Byb3BzJ10pIHtcbiAgICAgIC8vIEZvcnphciBkZXRlY2Npw7NuIGRlIGNhbWJpb3MgbcO6bHRpcGxlXG4gICAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICAgICAgfSwgMCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -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 { BoxComponent } from '../../atoms/box/box.component';
4
4
  import { ButtonGroupComponent } from '../../molecules/button-group/button-group.component';
5
5
  import { TitleBlockComponent } from '../../molecules/title-block/title-block.component';
@@ -18,19 +18,29 @@ import * as i1 from "@angular/common";
18
18
  * @output onClose - Emits when the banner is closed
19
19
  */
20
20
  export class BannerComponent {
21
- constructor() {
21
+ constructor(cdr) {
22
+ this.cdr = cdr;
22
23
  this.onClick = new EventEmitter();
23
24
  this.onClose = new EventEmitter();
24
25
  }
25
26
  ngOnInit() { }
27
+ ngOnChanges(changes) {
28
+ if (changes['props']) {
29
+ // Forzar detección de cambios múltiple
30
+ this.cdr.detectChanges();
31
+ setTimeout(() => {
32
+ this.cdr.detectChanges();
33
+ }, 0);
34
+ }
35
+ }
26
36
  clickHandler(token) {
27
37
  this.onClick.emit(token);
28
38
  }
29
39
  closeHandler() {
30
40
  this.onClose.emit();
31
41
  }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BannerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BannerComponent, isStandalone: true, selector: "val-banner", inputs: { props: "props" }, outputs: { onClick: "onClick", onClose: "onClose" }, ngImport: i0, template: `
42
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BannerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
43
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BannerComponent, isStandalone: true, selector: "val-banner", inputs: { props: "props" }, outputs: { onClick: "onClick", onClose: "onClose" }, usesOnChanges: true, ngImport: i0, template: `
34
44
  <val-box
35
45
  [props]="{
36
46
  icon: props.closable ? 'close-outline' : '',
@@ -91,11 +101,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
91
101
  </div>
92
102
  </val-box>
93
103
  `, 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)}.content-container{display:flex;justify-content:space-between}.content-container.center{flex-direction:column}.content-container.column{flex-direction:row}.content-container.row{flex-direction:column}.content-container.middle{align-items:center}.content-container.top{align-items:flex-start}.content-container.bottom{align-items:flex-end}.content-container.hybrid{flex-direction:column;align-items:flex-start}@media (min-width: 768px){.content-container.hybrid{flex-direction:row;align-items:center}}.buttons-container{align-items:center;display:flex;margin-top:1rem;margin-bottom:.0625rem}.buttons-container.column{margin-top:0rem}\n"] }]
94
- }], ctorParameters: () => [], propDecorators: { props: [{
104
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
95
105
  type: Input
96
106
  }], onClick: [{
97
107
  type: Output
98
108
  }], onClose: [{
99
109
  type: Output
100
110
  }] } });
101
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL2Jhbm5lci9iYW5uZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxREFBcUQsQ0FBQztBQUMzRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBc0N4Rjs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBVTFCO1FBTEEsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFHckMsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFFZCxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsWUFBWSxDQUFDLEtBQWM7UUFDekIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELFlBQVk7UUFDVixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7K0dBcEJVLGVBQWU7bUdBQWYsZUFBZSx1SkEzQ2hCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBNEJULHVzR0E3QlMsWUFBWSw2SEFBRSxZQUFZLDZGQUFFLG1CQUFtQiwrRUFBRSxvQkFBb0I7OzRGQTRDcEUsZUFBZTtrQkEvQzNCLFNBQVM7K0JBQ0UsWUFBWSxjQUNWLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLENBQUMsWUFDdEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E0QlQ7d0RBaUJELEtBQUs7c0JBREosS0FBSztnQkFJTixPQUFPO3NCQUROLE1BQU07Z0JBSVAsT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJveENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2JveC9ib3guY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbW9sZWN1bGVzL2J1dHRvbi1ncm91cC9idXR0b24tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IFRpdGxlQmxvY2tDb21wb25lbnQgfSBmcm9tICcuLi8uLi9tb2xlY3VsZXMvdGl0bGUtYmxvY2svdGl0bGUtYmxvY2suY29tcG9uZW50JztcbmltcG9ydCB7IEJhbm5lck1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1iYW5uZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCb3hDb21wb25lbnQsIFRpdGxlQmxvY2tDb21wb25lbnQsIEJ1dHRvbkdyb3VwQ29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8dmFsLWJveFxuICAgICAgW3Byb3BzXT1cIntcbiAgICAgICAgaWNvbjogcHJvcHMuY2xvc2FibGUgPyAnY2xvc2Utb3V0bGluZScgOiAnJyxcbiAgICAgICAgYm9yZGVyZWQ6IHByb3BzLmJvcmRlcmVkLFxuICAgICAgICBjb2xvcjogJycsXG4gICAgICAgIHBhZGRpbmc6IHByb3BzLnBhZGRpbmcsXG4gICAgICB9XCJcbiAgICAgIChvbkNsaWNrKT1cImNsb3NlSGFuZGxlcigpXCJcbiAgICA+XG4gICAgICA8ZGl2IFtuZ0NsYXNzXT1cIlsnY29udGVudC1jb250YWluZXInLCBwcm9wcy5tb2RlLCBwcm9wcy5hbGlnbm1lbnRdXCIgYm9keT5cbiAgICAgICAgPHZhbC10aXRsZS1ibG9ja1xuICAgICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgICBwb3NpdGlvbjogcHJvcHMuY29udGVudC5wb3NpdGlvbixcbiAgICAgICAgICAgIGFib3ZlVGl0bGU6IHByb3BzLmNvbnRlbnQuYWJvdmVUaXRsZSxcbiAgICAgICAgICAgIHRpdGxlOiBwcm9wcy5jb250ZW50LnRpdGxlLFxuICAgICAgICAgICAgYmVsbG93VGl0bGU6IHByb3BzLmNvbnRlbnQuYmVsbG93VGl0bGUsXG4gICAgICAgICAgfVwiXG4gICAgICAgID48L3ZhbC10aXRsZS1ibG9jaz5cbiAgICAgICAgQGlmIChwcm9wcy5hY3Rpb25zKSB7XG4gICAgICAgICAgPHZhbC1idXR0b24tZ3JvdXBcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cIlsnYnV0dG9ucy1jb250YWluZXInLCBwcm9wcy5tb2RlLCBwcm9wcy5hbGlnbm1lbnRdXCJcbiAgICAgICAgICAgIFtwcm9wc109XCJwcm9wcy5hY3Rpb25zXCJcbiAgICAgICAgICAgIChvbkNsaWNrKT1cImNsaWNrSGFuZGxlcigkZXZlbnQpXCJcbiAgICAgICAgICA+PC92YWwtYnV0dG9uLWdyb3VwPlxuICAgICAgICB9XG4gICAgICA8L2Rpdj5cbiAgICA8L3ZhbC1ib3g+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2Jhbm5lci5jb21wb25lbnQuc2NzcyddLFxufSlcbi8qKlxuICogdmFsLWJhbm5lclxuICpcbiAqIERpc3BsYXlzIGEgYmFubmVyIHdpdGggdGl0bGUgYmxvY2ssIGFjdGlvbnMsIGFuZCBvcHRpb25hbCBjbG9zZSBidXR0b24uXG4gKlxuICogQGV4YW1wbGVcbiAqIDx2YWwtYmFubmVyIFtwcm9wc109XCJ7IGNvbnRlbnQ6IHsuLi59LCBhY3Rpb25zOiB7Li4ufSwgY2xvc2FibGU6IHRydWUsIGJvcmRlcmVkOiB0cnVlLCBtb2RlOiAnY2VudGVyJywgYWxpZ25tZW50OiAnY2VudGVyJywgcGFkZGluZzogJzhweCcgfVwiIChvbkNsaWNrKT1cImhhbmRsZXIoJGV2ZW50KVwiIChvbkNsb3NlKT1cImNsb3NlSGFuZGxlcigpXCI+PC92YWwtYmFubmVyPlxuICpcbiAqIEBpbnB1dCBwcm9wczogQmFubmVyTWV0YWRhdGEgLSBDb25maWd1cmF0aW9uIGZvciB0aGUgYmFubmVyIChjb250ZW50LCBhY3Rpb25zLCBjbG9zYWJsZSwgYm9yZGVyZWQsIG1vZGUsIGFsaWdubWVudCwgcGFkZGluZylcbiAqIEBvdXRwdXQgb25DbGljayAtIEVtaXRzIHdoZW4gYW4gYWN0aW9uIGlzIGNsaWNrZWRcbiAqIEBvdXRwdXQgb25DbG9zZSAtIEVtaXRzIHdoZW4gdGhlIGJhbm5lciBpcyBjbG9zZWRcbiAqL1xuZXhwb3J0IGNsYXNzIEJhbm5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIHByb3BzOiBCYW5uZXJNZXRhZGF0YTtcblxuICBAT3V0cHV0KClcbiAgb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgY2xpY2tIYW5kbGVyKHRva2VuPzogc3RyaW5nKSB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQodG9rZW4pO1xuICB9XG5cbiAgY2xvc2VIYW5kbGVyKCkge1xuICAgIHRoaXMub25DbG9zZS5lbWl0KCk7XG4gIH1cbn1cbiJdfQ==
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==
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, } from '@angular/core';
2
2
  import { ProgressBarComponent } from '../../../atoms/progress-bar/progress-bar.component';
3
3
  import { ButtonGroupComponent } from '../../../molecules/button-group/button-group.component';
4
4
  import { ComponentStates } from '../../../types';
@@ -6,11 +6,17 @@ import { FooterComponent } from '../../footer/footer.component';
6
6
  import { MOTION } from '../types';
7
7
  import * as i0 from "@angular/core";
8
8
  export class WizardFooterComponent {
9
- constructor() {
9
+ constructor(cdr) {
10
+ this.cdr = cdr;
10
11
  this.onClick = new EventEmitter();
11
12
  this.wrapperId = 'wizard-wrapper';
12
13
  }
13
14
  ngOnInit() { }
15
+ ngOnChanges(changes) {
16
+ if (changes['props']) {
17
+ this.cdr.detectChanges();
18
+ }
19
+ }
14
20
  clickHandler(token) {
15
21
  if (!token) {
16
22
  return;
@@ -43,8 +49,8 @@ export class WizardFooterComponent {
43
49
  tryToStep(motion) {
44
50
  this.onClick.emit({ current: this.props.current, motion });
45
51
  }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardFooterComponent, isStandalone: true, selector: "val-wizard-footer", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
52
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WizardFooterComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: WizardFooterComponent, isStandalone: true, selector: "val-wizard-footer", inputs: { props: "props" }, outputs: { onClick: "onClick" }, usesOnChanges: true, ngImport: i0, template: `
48
54
  <val-footer
49
55
  [props]="{
50
56
  bordered: false,
@@ -97,9 +103,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
103
  ></val-button-group>
98
104
  </val-footer>
99
105
  ` }]
100
- }], ctorParameters: () => [], propDecorators: { props: [{
106
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { props: [{
101
107
  type: Input
102
108
  }], onClick: [{
103
109
  type: Output
104
110
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLWZvb3Rlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy93aXphcmQvd2l6YXJkLWZvb3Rlci93aXphcmQtZm9vdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzFGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQzlGLE9BQU8sRUFBa0IsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxNQUFNLEVBQXdCLE1BQU0sVUFBVSxDQUFDOztBQWlDeEQsTUFBTSxPQUFPLHFCQUFxQjtJQVNoQztRQUpBLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBdUMsQ0FBQztRQUVsRSxjQUFTLEdBQUcsZ0JBQWdCLENBQUM7SUFFZCxDQUFDO0lBRWhCLFFBQVEsS0FBSSxDQUFDO0lBRWIsWUFBWSxDQUFDLEtBQWM7UUFDekIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1gsT0FBTztRQUNULENBQUM7UUFDRCxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNqQyxDQUFDO1FBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLE9BQU87UUFDVCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELElBQUksUUFBUTtRQUNWLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUMzQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDbkUsQ0FBQztRQUNELE9BQU8sQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELElBQUksT0FBTztRQUNULElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEtBQUssZUFBZSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDbEYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxRQUFRLENBQUM7UUFDM0QsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNoRSxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuQyxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztJQUM5QixDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQWM7UUFDdEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDOytHQWpEVSxxQkFBcUI7bUdBQXJCLHFCQUFxQiwwSUEzQnRCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F3QlQsMEVBekJTLGVBQWUsZ0dBQUUsb0JBQW9CLGdGQUFFLG9CQUFvQjs7NEZBNEIxRCxxQkFBcUI7a0JBL0JqQyxTQUFTOytCQUNFLG1CQUFtQixjQUNqQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLEVBQUUsb0JBQW9CLENBQUMsWUFDNUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXdCVDt3REFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUHJvZ3Jlc3NCYXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9hdG9tcy9wcm9ncmVzcy1iYXIvcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25Hcm91cENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL21vbGVjdWxlcy9idXR0b24tZ3JvdXAvYnV0dG9uLWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCdXR0b25NZXRhZGF0YSwgQ29tcG9uZW50U3RhdGVzIH0gZnJvbSAnLi4vLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgRm9vdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZm9vdGVyL2Zvb3Rlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTU9USU9OLCBTdGVwLCBXaXphcmRNZXRhZGF0YSB9IGZyb20gJy4uL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXdpemFyZC1mb290ZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRm9vdGVyQ29tcG9uZW50LCBQcm9ncmVzc0JhckNvbXBvbmVudCwgQnV0dG9uR3JvdXBDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDx2YWwtZm9vdGVyXG4gICAgICBbcHJvcHNdPVwie1xuICAgICAgICBib3JkZXJlZDogZmFsc2UsXG4gICAgICAgIHRyYW5zbHVjZW50OiBmYWxzZSxcbiAgICAgICAgdG9vbGJhcjoge1xuICAgICAgICAgIHRpdGxlOiAnJyxcbiAgICAgICAgICBhY3Rpb25zOiBbXSxcbiAgICAgICAgICBjb2xvcjogJycsXG4gICAgICAgICAgd2l0aEJhY2s6IGZhbHNlLFxuICAgICAgICAgIHdpdGhBY3Rpb25zOiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgIH1cIlxuICAgID5cbiAgICAgIDx2YWwtcHJvZ3Jlc3MtYmFyXG4gICAgICAgIGV4dHJhXG4gICAgICAgIFtwcm9wc109XCJ7IHByb2dyZXNzOiBQcm9ncmVzcywgY29sb3I6ICcnLCB0eXBlOiAnZGV0ZXJtaW5hdGUnLCBidWZmZXI6IDEsIHNpemU6ICdzbWFsbCcsIHJvdW5kZWQ6IGZhbHNlIH1cIlxuICAgICAgPjwvdmFsLXByb2dyZXNzLWJhcj5cbiAgICAgIDx2YWwtYnV0dG9uLWdyb3VwXG4gICAgICAgIGV4dHJhXG4gICAgICAgIFtwcm9wc109XCJ7IGJ1dHRvbnM6IGFjdGlvbnMsIHBvc2l0aW9uOiAnc3BhY2VkJywgY29sdW1uZWQ6IGZhbHNlIH1cIlxuICAgICAgICAob25DbGljayk9XCJjbGlja0hhbmRsZXIoJGV2ZW50KVwiXG4gICAgICA+PC92YWwtYnV0dG9uLWdyb3VwPlxuICAgIDwvdmFsLWZvb3Rlcj5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vd2l6YXJkLWZvb3Rlci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBXaXphcmRGb290ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwcm9wczogV2l6YXJkTWV0YWRhdGE7XG5cbiAgQE91dHB1dCgpXG4gIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPHsgY3VycmVudDogbnVtYmVyOyBtb3Rpb246IE1PVElPTiB9PigpO1xuXG4gIHdyYXBwZXJJZCA9ICd3aXphcmQtd3JhcHBlcic7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge31cblxuICBjbGlja0hhbmRsZXIodG9rZW4/OiBzdHJpbmcpIHtcbiAgICBpZiAoIXRva2VuKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICh0b2tlbi5pbmNsdWRlcygncmlnaHQnKSkge1xuICAgICAgdGhpcy50cnlUb1N0ZXAoTU9USU9OLkZPUldBUkQpO1xuICAgIH1cbiAgICBpZiAodG9rZW4uaW5jbHVkZXMoJ2xlZnQnKSkge1xuICAgICAgdGhpcy50cnlUb1N0ZXAoTU9USU9OLkJBQ0tXQVJEKTtcbiAgICB9XG4gIH1cblxuICBnZXQgQ3VycmVudCgpOiBTdGVwIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5zdGVwc1t0aGlzLnByb3BzLmN1cnJlbnRdO1xuICB9XG5cbiAgZ2V0IFByb2dyZXNzKCk6IG51bWJlciB7XG4gICAgaWYgKHRoaXMucHJvcHMuc3RlcHMgJiYgdGhpcy5wcm9wcy5jdXJyZW50KSB7XG4gICAgICByZXR1cm4gdGhpcy5wcm9wcy5jdXJyZW50IC8gT2JqZWN0LmtleXModGhpcy5wcm9wcy5zdGVwcykubGVuZ3RoO1xuICAgIH1cbiAgICByZXR1cm4gMDtcbiAgfVxuXG4gIGdldCBhY3Rpb25zKCk6IEJ1dHRvbk1ldGFkYXRhW10ge1xuICAgIGlmICh0aGlzLnByb3BzLnN0YXRlID09PSBDb21wb25lbnRTdGF0ZXMuRVJST1IgJiYgdGhpcy5DdXJyZW50LmJ1dHRvbnMubGVuZ3RoID4gMSkge1xuICAgICAgdGhpcy5DdXJyZW50LmJ1dHRvbnNbMV0uc3RhdGUgPSBDb21wb25lbnRTdGF0ZXMuRElTQUJMRUQ7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMucHJvcHMuY3VycmVudCA9PT0gMSAmJiB0aGlzLkN1cnJlbnQuYnV0dG9ucy5sZW5ndGggPiAxKSB7XG4gICAgICByZXR1cm4gW3RoaXMuQ3VycmVudC5idXR0b25zWzFdXTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuQ3VycmVudC5idXR0b25zO1xuICB9XG5cbiAgdHJ5VG9TdGVwKG1vdGlvbjogTU9USU9OKTogdm9pZCB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQoeyBjdXJyZW50OiB0aGlzLnByb3BzLmN1cnJlbnQsIG1vdGlvbiB9KTtcbiAgfVxufVxuIl19
111
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLWZvb3Rlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL29yZ2FuaXNtcy93aXphcmQvd2l6YXJkLWZvb3Rlci93aXphcmQtZm9vdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzFGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQzlGLE9BQU8sRUFBa0IsZUFBZSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxNQUFNLEVBQXdCLE1BQU0sVUFBVSxDQUFDOztBQWlDeEQsTUFBTSxPQUFPLHFCQUFxQjtJQVNoQyxZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUoxQyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQXVDLENBQUM7UUFFbEUsY0FBUyxHQUFHLGdCQUFnQixDQUFDO0lBRWdCLENBQUM7SUFFOUMsUUFBUSxLQUFJLENBQUM7SUFFYixXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWM7UUFDekIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1gsT0FBTztRQUNULENBQUM7UUFDRCxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUM1QixJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNqQyxDQUFDO1FBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7SUFFRCxJQUFJLE9BQU87UUFDVCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELElBQUksUUFBUTtRQUNWLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUMzQyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDbkUsQ0FBQztRQUNELE9BQU8sQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELElBQUksT0FBTztRQUNULElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEtBQUssZUFBZSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDbEYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLGVBQWUsQ0FBQyxRQUFRLENBQUM7UUFDM0QsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNoRSxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuQyxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQztJQUM5QixDQUFDO0lBRUQsU0FBUyxDQUFDLE1BQWM7UUFDdEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDOytHQXZEVSxxQkFBcUI7bUdBQXJCLHFCQUFxQiwrSkEzQnRCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F3QlQsMEVBekJTLGVBQWUsZ0dBQUUsb0JBQW9CLGdGQUFFLG9CQUFvQjs7NEZBNEIxRCxxQkFBcUI7a0JBL0JqQyxTQUFTOytCQUNFLG1CQUFtQixjQUNqQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLEVBQUUsb0JBQW9CLENBQUMsWUFDNUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXdCVDtzRkFLRCxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkluaXQsXG4gIE91dHB1dCxcbiAgU2ltcGxlQ2hhbmdlcyxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc0JhckNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL2F0b21zL3Byb2dyZXNzLWJhci9wcm9ncmVzcy1iYXIuY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vbW9sZWN1bGVzL2J1dHRvbi1ncm91cC9idXR0b24tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbk1ldGFkYXRhLCBDb21wb25lbnRTdGF0ZXMgfSBmcm9tICcuLi8uLi8uLi90eXBlcyc7XG5pbXBvcnQgeyBGb290ZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi9mb290ZXIvZm9vdGVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNT1RJT04sIFN0ZXAsIFdpemFyZE1ldGFkYXRhIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtd2l6YXJkLWZvb3RlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtGb290ZXJDb21wb25lbnQsIFByb2dyZXNzQmFyQ29tcG9uZW50LCBCdXR0b25Hcm91cENvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPHZhbC1mb290ZXJcbiAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgIGJvcmRlcmVkOiBmYWxzZSxcbiAgICAgICAgdHJhbnNsdWNlbnQ6IGZhbHNlLFxuICAgICAgICB0b29sYmFyOiB7XG4gICAgICAgICAgdGl0bGU6ICcnLFxuICAgICAgICAgIGFjdGlvbnM6IFtdLFxuICAgICAgICAgIGNvbG9yOiAnJyxcbiAgICAgICAgICB3aXRoQmFjazogZmFsc2UsXG4gICAgICAgICAgd2l0aEFjdGlvbnM6IGZhbHNlLFxuICAgICAgICB9LFxuICAgICAgfVwiXG4gICAgPlxuICAgICAgPHZhbC1wcm9ncmVzcy1iYXJcbiAgICAgICAgZXh0cmFcbiAgICAgICAgW3Byb3BzXT1cInsgcHJvZ3Jlc3M6IFByb2dyZXNzLCBjb2xvcjogJycsIHR5cGU6ICdkZXRlcm1pbmF0ZScsIGJ1ZmZlcjogMSwgc2l6ZTogJ3NtYWxsJywgcm91bmRlZDogZmFsc2UgfVwiXG4gICAgICA+PC92YWwtcHJvZ3Jlc3MtYmFyPlxuICAgICAgPHZhbC1idXR0b24tZ3JvdXBcbiAgICAgICAgZXh0cmFcbiAgICAgICAgW3Byb3BzXT1cInsgYnV0dG9uczogYWN0aW9ucywgcG9zaXRpb246ICdzcGFjZWQnLCBjb2x1bW5lZDogZmFsc2UgfVwiXG4gICAgICAgIChvbkNsaWNrKT1cImNsaWNrSGFuZGxlcigkZXZlbnQpXCJcbiAgICAgID48L3ZhbC1idXR0b24tZ3JvdXA+XG4gICAgPC92YWwtZm9vdGVyPlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi93aXphcmQtZm9vdGVyLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFdpemFyZEZvb3RlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KClcbiAgcHJvcHM6IFdpemFyZE1ldGFkYXRhO1xuXG4gIEBPdXRwdXQoKVxuICBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjx7IGN1cnJlbnQ6IG51bWJlcjsgbW90aW9uOiBNT1RJT04gfT4oKTtcblxuICB3cmFwcGVySWQgPSAnd2l6YXJkLXdyYXBwZXInO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICBuZ09uSW5pdCgpIHt9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmIChjaGFuZ2VzWydwcm9wcyddKSB7XG4gICAgICB0aGlzLmNkci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgfVxuICB9XG5cbiAgY2xpY2tIYW5kbGVyKHRva2VuPzogc3RyaW5nKSB7XG4gICAgaWYgKCF0b2tlbikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBpZiAodG9rZW4uaW5jbHVkZXMoJ3JpZ2h0JykpIHtcbiAgICAgIHRoaXMudHJ5VG9TdGVwKE1PVElPTi5GT1JXQVJEKTtcbiAgICB9XG4gICAgaWYgKHRva2VuLmluY2x1ZGVzKCdsZWZ0JykpIHtcbiAgICAgIHRoaXMudHJ5VG9TdGVwKE1PVElPTi5CQUNLV0FSRCk7XG4gICAgfVxuICB9XG5cbiAgZ2V0IEN1cnJlbnQoKTogU3RlcCB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMuc3RlcHNbdGhpcy5wcm9wcy5jdXJyZW50XTtcbiAgfVxuXG4gIGdldCBQcm9ncmVzcygpOiBudW1iZXIge1xuICAgIGlmICh0aGlzLnByb3BzLnN0ZXBzICYmIHRoaXMucHJvcHMuY3VycmVudCkge1xuICAgICAgcmV0dXJuIHRoaXMucHJvcHMuY3VycmVudCAvIE9iamVjdC5rZXlzKHRoaXMucHJvcHMuc3RlcHMpLmxlbmd0aDtcbiAgICB9XG4gICAgcmV0dXJuIDA7XG4gIH1cblxuICBnZXQgYWN0aW9ucygpOiBCdXR0b25NZXRhZGF0YVtdIHtcbiAgICBpZiAodGhpcy5wcm9wcy5zdGF0ZSA9PT0gQ29tcG9uZW50U3RhdGVzLkVSUk9SICYmIHRoaXMuQ3VycmVudC5idXR0b25zLmxlbmd0aCA+IDEpIHtcbiAgICAgIHRoaXMuQ3VycmVudC5idXR0b25zWzFdLnN0YXRlID0gQ29tcG9uZW50U3RhdGVzLkRJU0FCTEVEO1xuICAgIH1cblxuICAgIGlmICh0aGlzLnByb3BzLmN1cnJlbnQgPT09IDEgJiYgdGhpcy5DdXJyZW50LmJ1dHRvbnMubGVuZ3RoID4gMSkge1xuICAgICAgcmV0dXJuIFt0aGlzLkN1cnJlbnQuYnV0dG9uc1sxXV07XG4gICAgfVxuICAgIHJldHVybiB0aGlzLkN1cnJlbnQuYnV0dG9ucztcbiAgfVxuXG4gIHRyeVRvU3RlcChtb3Rpb246IE1PVElPTik6IHZvaWQge1xuICAgIHRoaXMub25DbGljay5lbWl0KHsgY3VycmVudDogdGhpcy5wcm9wcy5jdXJyZW50LCBtb3Rpb24gfSk7XG4gIH1cbn1cbiJdfQ==
@@ -27,7 +27,17 @@ export class WizardComponent {
27
27
  updateCurrentStep() {
28
28
  if (this.props?.steps && this.props?.current) {
29
29
  this.currentStep = this.props.steps[this.props.current];
30
- this.currentStepTitles = this.currentStep?.titles ? JSON.parse(JSON.stringify(this.currentStep.titles)) : null;
30
+ // Forzar nueva referencia de objeto para asegurar detección de cambios
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();
31
41
  }
32
42
  }
33
43
  working() {
@@ -63,7 +73,11 @@ export class WizardComponent {
63
73
  }
64
74
  this.props.current = newStep;
65
75
  this.updateCurrentStep();
76
+ // Forzar múltiples ciclos de detección de cambios
66
77
  this.cdr.detectChanges();
78
+ setTimeout(() => {
79
+ this.cdr.detectChanges();
80
+ }, 0);
67
81
  goToTop(this.wrapperId);
68
82
  }
69
83
  setError(error) {
@@ -92,7 +106,7 @@ export class WizardComponent {
92
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: `
93
107
  <div [id]="wrapperId" class="wrapper">
94
108
  <ng-container *ngIf="props.state !== 'ERROR'">
95
- <val-no-content [props]="currentStepTitles"></val-no-content>
109
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
96
110
  <div class="step">
97
111
  <div *ngIf="props.state === 'WORKING'">
98
112
  <val-content-loader
@@ -118,7 +132,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
118
132
  args: [{ selector: 'val-wizard', standalone: true, imports: [CommonModule, NoContentComponent, ContentLoaderComponent], template: `
119
133
  <div [id]="wrapperId" class="wrapper">
120
134
  <ng-container *ngIf="props.state !== 'ERROR'">
121
- <val-no-content [props]="currentStepTitles"></val-no-content>
135
+ <val-no-content [props]="currentStepTitles" [attr.data-step]="props.current"></val-no-content>
122
136
  <div class="step">
123
137
  <div *ngIf="props.state === 'WORKING'">
124
138
  <val-content-loader
@@ -143,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
143
157
  }], onClick: [{
144
158
  type: Output
145
159
  }] } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wizard.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/organisms/wizard/wizard.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,yDAAyD,CAAC;AACjG,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,MAAM,EAAwB,MAAM,SAAS,CAAC;;;AA+BvD,MAAM,OAAO,eAAe;IAW1B,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAN1C,YAAO,GAAG,IAAI,YAAY,EAAuC,CAAC;QAElE,cAAS,GAAG,gBAAgB,CAAC;QAC7B,gBAAW,GAAgB,IAAI,CAAC;QAChC,sBAAiB,GAAQ,IAAI,CAAC;IAEe,CAAC;IAE9C,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IACO,iBAAiB;QACvB,IAAI,IAAI,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YAC7C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACxD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACjH,CAAC;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3C,IAAI,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACpC,MAAM,CAAC,KAAK,GAAG,eAAe,CAAC,QAAQ,CAAC;YAC1C,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,eAAe,CAAC,OAAO,EAAE,CAAC;YACjD,OAAO;QACT,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;QAC3C,IAAI,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBACpC,MAAM,CAAC,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC;YACzC,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,IAAI,OAAO;QACT,IAAI,IAAI,CAAC,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC9C,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAC3D,CAAC;IAED,UAAU,CAAC,OAAe;QACxB,IAAI,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,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;+GAhGU,eAAe;mGAAf,eAAe,wJAzBhB;;;;;;;;;;;;;;;;;;;;;;GAsBT,kwFAvBS,YAAY,mIAAE,kBAAkB,oGAAE,sBAAsB;;4FA0BvD,eAAe;kBA7B3B,SAAS;+BACE,YAAY,cACV,IAAI,WACP,CAAC,YAAY,EAAE,kBAAkB,EAAE,sBAAsB,CAAC,YACzD;;;;;;;;;;;;;;;;;;;;;;GAsBT;sFAKD,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { goToTop } from '../../../shared/utils/dom';\nimport { ContentLoaderComponent } from '../../molecules/content-loader/content-loader.component';\nimport { ComponentStates } from '../../types';\nimport { NoContentComponent } from '../no-content/no-content.component';\nimport { MOTION, Step, WizardMetadata } from './types';\n\n@Component({\n  selector: 'val-wizard',\n  standalone: true,\n  imports: [CommonModule, NoContentComponent, ContentLoaderComponent],\n  template: `\n    <div [id]=\"wrapperId\" class=\"wrapper\">\n      <ng-container *ngIf=\"props.state !== 'ERROR'\">\n        <val-no-content [props]=\"currentStepTitles\"></val-no-content>\n        <div class=\"step\">\n          <div *ngIf=\"props.state === 'WORKING'\">\n            <val-content-loader\n              [props]=\"{\n                name: 'circular',\n                color: 'primary',\n                size: 'large',\n                text: 'Por favor espere...',\n              }\"\n            />\n          </div>\n          <ng-content select=\"[step]\"></ng-content>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"props.state === 'ERROR'\">\n        <val-no-content [props]=\"props.error.titles\" (onClick)=\"clickHandler($event)\"></val-no-content>\n      </ng-container>\n    </div>\n  `,\n  styleUrls: ['./wizard.component.scss'],\n})\nexport class WizardComponent implements OnInit, OnChanges {\n  @Input()\n  props: WizardMetadata;\n\n  @Output()\n  onClick = new EventEmitter<{ current: number; motion: MOTION }>();\n\n  wrapperId = 'wizard-wrapper';\n  currentStep: Step | null = null;\n  currentStepTitles: any = null;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.updateCurrentStep();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['props']) {\n      this.updateCurrentStep();\n      this.cdr.detectChanges();\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 ? 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    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":"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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\" [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"]}