valtech-components 2.0.326 → 2.0.329

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.
Files changed (29) hide show
  1. package/README.md +1 -1
  2. package/esm2022/lib/components/atoms/button/button.component.mjs +18 -18
  3. package/esm2022/lib/components/atoms/display/display.component.mjs +13 -16
  4. package/esm2022/lib/components/atoms/text/text.component.mjs +19 -19
  5. package/esm2022/lib/components/atoms/title/title.component.mjs +7 -7
  6. package/esm2022/lib/components/atoms/title/types.mjs +6 -2
  7. package/esm2022/lib/components/molecules/alert-box/alert-box.component.mjs +6 -6
  8. package/esm2022/lib/components/molecules/language-selector/language-selector.component.mjs +6 -17
  9. package/esm2022/lib/components/organisms/form/form.component.mjs +1 -1
  10. package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +66 -1
  11. package/esm2022/lib/shared/utils/simple-content.mjs +119 -0
  12. package/esm2022/public-api.mjs +3 -3
  13. package/fesm2022/valtech-components.mjs +413 -680
  14. package/fesm2022/valtech-components.mjs.map +1 -1
  15. package/lib/components/atoms/button/button.component.d.ts +3 -3
  16. package/lib/components/atoms/display/display.component.d.ts +2 -3
  17. package/lib/components/atoms/text/text.component.d.ts +3 -3
  18. package/lib/components/atoms/title/title.component.d.ts +1 -2
  19. package/lib/components/atoms/title/types.d.ts +10 -4
  20. package/lib/components/molecules/alert-box/alert-box.component.d.ts +3 -3
  21. package/lib/components/molecules/language-selector/language-selector.component.d.ts +1 -3
  22. package/lib/services/lang-provider/lang-provider.service.d.ts +50 -0
  23. package/lib/shared/utils/simple-content.d.ts +120 -0
  24. package/package.json +3 -2
  25. package/public-api.d.ts +1 -2
  26. package/esm2022/lib/services/content.service.mjs +0 -327
  27. package/esm2022/lib/shared/utils/reactive-content.mjs +0 -117
  28. package/lib/services/content.service.d.ts +0 -296
  29. package/lib/shared/utils/reactive-content.d.ts +0 -109
package/README.md CHANGED
@@ -59,7 +59,7 @@ export class YourComponent {
59
59
 
60
60
  ## 🌍 Reactive Internationalization (i18n)
61
61
 
62
- The library includes a powerful reactive internationalization system with **ContentService** that automatically updates content when the language changes. It supports both **global content** (reusable across components) and **component-specific content**.
62
+ The library includes a powerful reactive internationalization system with **LangService** that automatically updates content when the language changes. It supports both **global content** (reusable across components) and **component-specific content**.
63
63
 
64
64
  ### Key Features
65
65
 
@@ -2,12 +2,13 @@ import { CommonModule } from '@angular/common';
2
2
  import { Component, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { IonButton, IonIcon, IonSpinner, IonText } from '@ionic/angular/standalone';
4
4
  import { Subscription, of } from 'rxjs';
5
+ import { interpolateStaticContent } from '../../../shared/utils/simple-content';
5
6
  import { ActionType, ComponentStates } from '../../types';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../../../services/download.service";
8
9
  import * as i2 from "../../../services/icons.service";
9
10
  import * as i3 from "../../../services/navigation.service";
10
- import * as i4 from "../../../services/content.service";
11
+ import * as i4 from "../../../services/lang-provider/lang-provider.service";
11
12
  import * as i5 from "@angular/common";
12
13
  /**
13
14
  * val-button
@@ -51,10 +52,10 @@ import * as i5 from "@angular/common";
51
52
  * @output onClick - Emits when the button is clicked
52
53
  */
53
54
  export class ButtonComponent {
54
- constructor(download, icon, navigation, contentService) {
55
+ constructor(download, icon, navigation, langService) {
55
56
  this.download = download;
56
57
  this.navigation = navigation;
57
- this.contentService = contentService;
58
+ this.langService = langService;
58
59
  this.states = ComponentStates;
59
60
  this.subscriptions = new Subscription();
60
61
  /**
@@ -76,26 +77,25 @@ export class ButtonComponent {
76
77
  setupDisplayText() {
77
78
  if (this.props.text) {
78
79
  // Static text takes precedence
79
- this.displayText$ = of(this.props.text);
80
+ if (this.props.contentInterpolation) {
81
+ // Static text with interpolation
82
+ const interpolatedText = interpolateStaticContent(this.props.text, this.props.contentInterpolation);
83
+ this.displayText$ = of(interpolatedText);
84
+ }
85
+ else {
86
+ // Simple static text
87
+ this.displayText$ = of(this.props.text);
88
+ }
80
89
  }
81
90
  else if (this.props.contentKey && this.props.contentClass) {
82
91
  // Reactive content from language service
83
92
  if (this.props.contentInterpolation) {
84
93
  // With interpolation
85
- this.displayText$ = this.contentService.fromContentWithInterpolation({
86
- className: this.props.contentClass,
87
- key: this.props.contentKey,
88
- fallback: this.props.contentFallback,
89
- interpolation: this.props.contentInterpolation,
90
- });
94
+ this.displayText$ = this.langService.getContentWithInterpolation(this.props.contentClass, this.props.contentKey, this.props.contentInterpolation, this.props.contentFallback);
91
95
  }
92
96
  else {
93
97
  // Simple reactive content
94
- this.displayText$ = this.contentService.fromContent({
95
- className: this.props.contentClass,
96
- key: this.props.contentKey,
97
- fallback: this.props.contentFallback,
98
- });
98
+ this.displayText$ = this.langService.getContent(this.props.contentClass, this.props.contentKey, this.props.contentFallback);
99
99
  }
100
100
  }
101
101
  else {
@@ -119,7 +119,7 @@ export class ButtonComponent {
119
119
  }
120
120
  this.onClick.emit(this.props.token);
121
121
  }
122
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.DownloadService }, { token: i2.IconService }, { token: i3.NavigationService }, { token: i4.ContentService }], target: i0.ɵɵFactoryTarget.Component }); }
122
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.DownloadService }, { token: i2.IconService }, { token: i3.NavigationService }, { token: i4.LangService }], target: i0.ɵɵFactoryTarget.Component }); }
123
123
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ButtonComponent, isStandalone: true, selector: "val-button", inputs: { props: "props" }, outputs: { onClick: "onClick" }, ngImport: i0, template: `
124
124
  <ion-button
125
125
  [type]="props.type"
@@ -161,7 +161,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
161
161
  <ion-text *ngIf="props.state !== states.WORKING">{{ displayText$ | async }}</ion-text>
162
162
  </ion-button>
163
163
  `, 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)}ion-button{font-family:var(--ion-default-font),Arial,sans-serif;min-width:6.25rem;margin:0}ion-button.small{--padding-bottom: 12px;--padding-end: 14px;--padding-start: 14px;--padding-top: 12px}ion-button.button-clear{padding:0;margin:0}\n"] }]
164
- }], ctorParameters: () => [{ type: i1.DownloadService }, { type: i2.IconService }, { type: i3.NavigationService }, { type: i4.ContentService }], propDecorators: { props: [{
164
+ }], ctorParameters: () => [{ type: i1.DownloadService }, { type: i2.IconService }, { type: i3.NavigationService }, { type: i4.LangService }], propDecorators: { props: [{
165
165
  type: Input
166
166
  }], onClick: [{
167
167
  type: Output
@@ -204,4 +204,4 @@ export function createButtonProps(contentConfig, styleConfig = {}) {
204
204
  handler: styleConfig.handler,
205
205
  };
206
206
  }
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { IonButton, IonIcon, IonSpinner, IonText } from '@ionic/angular/standalone';\nimport { Observable, Subscription, of } from 'rxjs';\nimport { ContentService } from '../../../services/content.service';\nimport { DownloadService } from '../../../services/download.service';\nimport { IconService } from '../../../services/icons.service';\nimport { NavigationService } from '../../../services/navigation.service';\nimport { ActionType, ButtonContentConfig, ButtonMetadata, ComponentStates } from '../../types';\n\n@Component({\n  selector: 'val-button',\n  standalone: true,\n  imports: [CommonModule, IonButton, IonIcon, IonSpinner, IonText],\n  template: `\n    <ion-button\n      [type]=\"props.type\"\n      [color]=\"props.color\"\n      [expand]=\"props.expand\"\n      [fill]=\"props.fill\"\n      [size]=\"props.size\"\n      [href]=\"props.href\"\n      [target]=\"props.target\"\n      [shape]=\"props.shape\"\n      (click)=\"clickHandler()\"\n      [disabled]=\"props.state === states.DISABLED\"\n      [ngClass]=\"[props.size]\"\n    >\n      <ion-icon *ngIf=\"props.icon\" [slot]=\"props.icon.slot\" [name]=\"props.icon.name\"></ion-icon>\n      <ion-spinner *ngIf=\"props.state === states.WORKING\" name=\"circular\"></ion-spinner>\n      <ion-text *ngIf=\"props.state !== states.WORKING\">{{ displayText$ | async }}</ion-text>\n    </ion-button>\n  `,\n  styleUrls: ['./button.component.scss'],\n})\n/**\n * val-button\n *\n * A customizable button supporting icons, loading state, navigation, and reactive content.\n * Supports both static text and reactive content from the content service.\n * Follows the same content pattern as val-text for consistency.\n *\n * @example Static text:\n * <val-button [props]=\"{\n *   text: 'Save',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED',\n *   icon: { name: 'save', slot: 'start' }\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @example Reactive content:\n * <val-button [props]=\"{\n *   contentKey: 'save',\n *   contentClass: 'MyComponent',\n *   contentFallback: 'Save',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED',\n *   icon: { name: 'save', slot: 'start' }\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @example Reactive content with interpolation:\n * <val-button [props]=\"{\n *   contentKey: 'saveCount',\n *   contentClass: 'MyComponent',\n *   contentInterpolation: { count: 5 },\n *   contentFallback: 'Save Items',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED'\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @input props: ButtonMetadata - Configuration for the button (text/content, color, icon, state, etc.)\n * @output onClick - Emits when the button is clicked\n */\nexport class ButtonComponent implements OnInit, OnDestroy {\n  states = ComponentStates;\n\n  /**\n   * Observable that provides the text content to display.\n   * This will be either static text or reactive content from the language service.\n   */\n  displayText$: Observable<string>;\n\n  private subscriptions = new Subscription();\n\n  @Input()\n  props!: ButtonMetadata;\n\n  /**\n   * Event emitted when the button is clicked.\n   */\n  @Output()\n  onClick = new EventEmitter<string>();\n\n  constructor(\n    private download: DownloadService,\n    icon: IconService,\n    private navigation: NavigationService,\n    private contentService: ContentService\n  ) {}\n\n  ngOnInit() {\n    this.setupDisplayText();\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n\n  /**\n   * Set up the text content observable based on the props configuration.\n   * Priority: static text > reactive content with interpolation > reactive content\n   * This follows the same pattern as val-text component.\n   */\n  private setupDisplayText(): void {\n    if (this.props.text) {\n      // Static text takes precedence\n      this.displayText$ = of(this.props.text);\n    } else if (this.props.contentKey && this.props.contentClass) {\n      // Reactive content from language service\n      if (this.props.contentInterpolation) {\n        // With interpolation\n        this.displayText$ = this.contentService.fromContentWithInterpolation({\n          className: this.props.contentClass,\n          key: this.props.contentKey,\n          fallback: this.props.contentFallback,\n          interpolation: this.props.contentInterpolation,\n        });\n      } else {\n        // Simple reactive content\n        this.displayText$ = this.contentService.fromContent({\n          className: this.props.contentClass,\n          key: this.props.contentKey,\n          fallback: this.props.contentFallback,\n        });\n      }\n    } else {\n      // Fallback to empty string if no valid content configuration\n      console.warn(\n        'val-button: No valid content configuration provided. Use either \"text\" for static text or \"contentKey\" + \"contentClass\" for reactive content.'\n      );\n      this.displayText$ = of(this.props.contentFallback || '');\n    }\n  }\n\n  clickHandler() {\n    if (this.props.state === this.states.DISABLED) {\n      return;\n    }\n\n    if (this.props.actionType === ActionType.APP_NAVIGATION) {\n      this.navigation.navigateByUrl(this.props.link);\n    }\n\n    if (this.props.download) {\n      this.download.downloadLinkFromBrowser(this.props.download);\n    }\n\n    if (this.props.handler) {\n      this.props.handler(this.props.ref);\n    }\n\n    this.onClick.emit(this.props.token);\n  }\n}\n\n/**\n * Helper function to create reactive button props from content configuration.\n * This provides a convenient way to create val-button props with reactive content.\n * Follows the same pattern as createTextProps for consistency.\n *\n * @param contentConfig - Content configuration\n * @param styleConfig - Optional style and behavior configuration\n * @returns ButtonMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * saveButtonProps: ButtonMetadata = createButtonProps({\n *   contentKey: 'save',\n *   contentClass: 'MyComponent'\n * }, {\n *   color: 'primary',\n *   icon: { name: 'save', slot: 'start' }\n * });\n * ```\n */\nexport function createButtonProps(\n  contentConfig: ButtonContentConfig,\n  styleConfig: Partial<\n    Pick<ButtonMetadata, 'color' | 'type' | 'state' | 'size' | 'fill' | 'icon' | 'expand' | 'shape' | 'handler'>\n  > = {}\n): ButtonMetadata {\n  return {\n    contentKey: contentConfig.contentKey,\n    contentClass: contentConfig.contentClass,\n    contentFallback: contentConfig.contentFallback,\n    contentInterpolation: contentConfig.contentInterpolation,\n    color: styleConfig.color || 'primary',\n    type: styleConfig.type || 'button',\n    state: styleConfig.state || ComponentStates.ENABLED,\n    size: styleConfig.size,\n    fill: styleConfig.fill,\n    icon: styleConfig.icon,\n    expand: styleConfig.expand,\n    shape: styleConfig.shape,\n    handler: styleConfig.handler,\n  };\n}\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { IonButton, IonIcon, IonSpinner, IonText } from '@ionic/angular/standalone';\nimport { Observable, Subscription, of } from 'rxjs';\nimport { DownloadService } from '../../../services/download.service';\nimport { IconService } from '../../../services/icons.service';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { NavigationService } from '../../../services/navigation.service';\nimport { interpolateStaticContent } from '../../../shared/utils/simple-content';\nimport { ActionType, ButtonContentConfig, ButtonMetadata, ComponentStates } from '../../types';\n\n@Component({\n  selector: 'val-button',\n  standalone: true,\n  imports: [CommonModule, IonButton, IonIcon, IonSpinner, IonText],\n  template: `\n    <ion-button\n      [type]=\"props.type\"\n      [color]=\"props.color\"\n      [expand]=\"props.expand\"\n      [fill]=\"props.fill\"\n      [size]=\"props.size\"\n      [href]=\"props.href\"\n      [target]=\"props.target\"\n      [shape]=\"props.shape\"\n      (click)=\"clickHandler()\"\n      [disabled]=\"props.state === states.DISABLED\"\n      [ngClass]=\"[props.size]\"\n    >\n      <ion-icon *ngIf=\"props.icon\" [slot]=\"props.icon.slot\" [name]=\"props.icon.name\"></ion-icon>\n      <ion-spinner *ngIf=\"props.state === states.WORKING\" name=\"circular\"></ion-spinner>\n      <ion-text *ngIf=\"props.state !== states.WORKING\">{{ displayText$ | async }}</ion-text>\n    </ion-button>\n  `,\n  styleUrls: ['./button.component.scss'],\n})\n/**\n * val-button\n *\n * A customizable button supporting icons, loading state, navigation, and reactive content.\n * Supports both static text and reactive content from the content service.\n * Follows the same content pattern as val-text for consistency.\n *\n * @example Static text:\n * <val-button [props]=\"{\n *   text: 'Save',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED',\n *   icon: { name: 'save', slot: 'start' }\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @example Reactive content:\n * <val-button [props]=\"{\n *   contentKey: 'save',\n *   contentClass: 'MyComponent',\n *   contentFallback: 'Save',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED',\n *   icon: { name: 'save', slot: 'start' }\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @example Reactive content with interpolation:\n * <val-button [props]=\"{\n *   contentKey: 'saveCount',\n *   contentClass: 'MyComponent',\n *   contentInterpolation: { count: 5 },\n *   contentFallback: 'Save Items',\n *   color: 'primary',\n *   type: 'button',\n *   state: 'ENABLED'\n * }\" (onClick)=\"handler()\"></val-button>\n *\n * @input props: ButtonMetadata - Configuration for the button (text/content, color, icon, state, etc.)\n * @output onClick - Emits when the button is clicked\n */\nexport class ButtonComponent implements OnInit, OnDestroy {\n  states = ComponentStates;\n\n  /**\n   * Observable that provides the text content to display.\n   * This will be either static text or reactive content from the language service.\n   */\n  displayText$: Observable<string>;\n\n  private subscriptions = new Subscription();\n\n  @Input()\n  props!: ButtonMetadata;\n\n  /**\n   * Event emitted when the button is clicked.\n   */\n  @Output()\n  onClick = new EventEmitter<string>();\n\n  constructor(\n    private download: DownloadService,\n    icon: IconService,\n    private navigation: NavigationService,\n    private langService: LangService\n  ) {}\n\n  ngOnInit() {\n    this.setupDisplayText();\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n\n  /**\n   * Set up the text content observable based on the props configuration.\n   * Priority: static text > reactive content with interpolation > reactive content\n   * This follows the same pattern as val-text component.\n   */\n  private setupDisplayText(): void {\n    if (this.props.text) {\n      // Static text takes precedence\n      if (this.props.contentInterpolation) {\n        // Static text with interpolation\n        const interpolatedText = interpolateStaticContent(this.props.text, this.props.contentInterpolation);\n        this.displayText$ = of(interpolatedText);\n      } else {\n        // Simple static text\n        this.displayText$ = of(this.props.text);\n      }\n    } else if (this.props.contentKey && this.props.contentClass) {\n      // Reactive content from language service\n      if (this.props.contentInterpolation) {\n        // With interpolation\n        this.displayText$ = this.langService.getContentWithInterpolation(\n          this.props.contentClass,\n          this.props.contentKey,\n          this.props.contentInterpolation,\n          this.props.contentFallback\n        );\n      } else {\n        // Simple reactive content\n        this.displayText$ = this.langService.getContent(\n          this.props.contentClass,\n          this.props.contentKey,\n          this.props.contentFallback\n        );\n      }\n    } else {\n      // Fallback to empty string if no valid content configuration\n      console.warn(\n        'val-button: No valid content configuration provided. Use either \"text\" for static text or \"contentKey\" + \"contentClass\" for reactive content.'\n      );\n      this.displayText$ = of(this.props.contentFallback || '');\n    }\n  }\n\n  clickHandler() {\n    if (this.props.state === this.states.DISABLED) {\n      return;\n    }\n\n    if (this.props.actionType === ActionType.APP_NAVIGATION) {\n      this.navigation.navigateByUrl(this.props.link);\n    }\n\n    if (this.props.download) {\n      this.download.downloadLinkFromBrowser(this.props.download);\n    }\n\n    if (this.props.handler) {\n      this.props.handler(this.props.ref);\n    }\n\n    this.onClick.emit(this.props.token);\n  }\n}\n\n/**\n * Helper function to create reactive button props from content configuration.\n * This provides a convenient way to create val-button props with reactive content.\n * Follows the same pattern as createTextProps for consistency.\n *\n * @param contentConfig - Content configuration\n * @param styleConfig - Optional style and behavior configuration\n * @returns ButtonMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * saveButtonProps: ButtonMetadata = createButtonProps({\n *   contentKey: 'save',\n *   contentClass: 'MyComponent'\n * }, {\n *   color: 'primary',\n *   icon: { name: 'save', slot: 'start' }\n * });\n * ```\n */\nexport function createButtonProps(\n  contentConfig: ButtonContentConfig,\n  styleConfig: Partial<\n    Pick<ButtonMetadata, 'color' | 'type' | 'state' | 'size' | 'fill' | 'icon' | 'expand' | 'shape' | 'handler'>\n  > = {}\n): ButtonMetadata {\n  return {\n    contentKey: contentConfig.contentKey,\n    contentClass: contentConfig.contentClass,\n    contentFallback: contentConfig.contentFallback,\n    contentInterpolation: contentConfig.contentInterpolation,\n    color: styleConfig.color || 'primary',\n    type: styleConfig.type || 'button',\n    state: styleConfig.state || ComponentStates.ENABLED,\n    size: styleConfig.size,\n    fill: styleConfig.fill,\n    icon: styleConfig.icon,\n    expand: styleConfig.expand,\n    shape: styleConfig.shape,\n    handler: styleConfig.handler,\n  };\n}\n"]}
@@ -1,10 +1,10 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, Input } from '@angular/core';
2
+ import { Component, inject, Input } from '@angular/core';
3
3
  import { IonText } from '@ionic/angular/standalone';
4
- import { Subscription, of } from 'rxjs';
4
+ import { of, Subscription } from 'rxjs';
5
+ import { LangService } from '../../../services/lang-provider/lang-provider.service';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "../../../services/content.service";
7
- import * as i2 from "@angular/common";
7
+ import * as i1 from "@angular/common";
8
8
  /**
9
9
  * val-display
10
10
  *
@@ -21,9 +21,9 @@ import * as i2 from "@angular/common";
21
21
  * @input props: DisplayMetadata - Configuration for the display (content/contentConfig, color, size)
22
22
  */
23
23
  export class DisplayComponent {
24
- constructor(contentService) {
25
- this.contentService = contentService;
24
+ constructor() {
26
25
  this.subscriptions = new Subscription();
26
+ this.langService = inject(LangService);
27
27
  }
28
28
  ngOnInit() {
29
29
  this.initializeDisplayContent();
@@ -39,25 +39,22 @@ export class DisplayComponent {
39
39
  }
40
40
  // Use reactive content if configured
41
41
  if (this.props.contentConfig) {
42
- this.displayContent$ = this.contentService.fromContent({
43
- className: this.props.contentConfig.className || '_global',
44
- key: this.props.contentConfig.key,
45
- fallback: this.props.contentConfig.fallback || this.props.contentConfig.key,
46
- interpolation: this.props.contentConfig.interpolation,
47
- });
42
+ this.displayContent$ = this.langService.getContent(this.props.contentConfig.className || '_global', this.props.contentConfig.key, this.props.contentConfig.fallback || this.props.contentConfig.key
43
+ // interpolation: this.props.contentConfig.interpolation,
44
+ );
48
45
  return;
49
46
  }
50
47
  // No content configured - use empty string
51
48
  this.displayContent$ = of('');
52
49
  }
53
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayComponent, deps: [{ token: i1.ContentService }], target: i0.ɵɵFactoryTarget.Component }); }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
54
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: `
55
52
  <ion-text [color]="props.color">
56
53
  <p [class]="props.size">
57
54
  {{ displayContent$ | async }}
58
55
  </p>
59
56
  </ion-text>
60
- `, isInline: true, 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)}.small{font-size:1.5rem;line-height:2rem;font-weight:800}@media (min-width: 768px){.small{font-size:2rem;line-height:2.5rem}}.medium{font-size:2rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.medium{font-size:2.5rem;line-height:3rem}}.large{font-size:2.5rem;line-height:3rem;font-weight:800}@media (min-width: 768px){.large{font-size:3rem;line-height:3.5rem}}.xlarge{font-size:3rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.xlarge{font-size:4.375rem;line-height:4.125rem}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "component", type: IonText, selector: "ion-text", inputs: ["color", "mode"] }] }); }
57
+ `, isInline: true, 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)}.small{font-size:1.5rem;line-height:2rem;font-weight:800}@media (min-width: 768px){.small{font-size:2rem;line-height:2.5rem}}.medium{font-size:2rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.medium{font-size:2.5rem;line-height:3rem}}.large{font-size:2.5rem;line-height:3rem;font-weight:800}@media (min-width: 768px){.large{font-size:3rem;line-height:3.5rem}}.xlarge{font-size:3rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.xlarge{font-size:4.375rem;line-height:4.125rem}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "component", type: IonText, selector: "ion-text", inputs: ["color", "mode"] }] }); }
61
58
  }
62
59
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayComponent, decorators: [{
63
60
  type: Component,
@@ -68,7 +65,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
68
65
  </p>
69
66
  </ion-text>
70
67
  `, 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)}.small{font-size:1.5rem;line-height:2rem;font-weight:800}@media (min-width: 768px){.small{font-size:2rem;line-height:2.5rem}}.medium{font-size:2rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.medium{font-size:2.5rem;line-height:3rem}}.large{font-size:2.5rem;line-height:3rem;font-weight:800}@media (min-width: 768px){.large{font-size:3rem;line-height:3.5rem}}.xlarge{font-size:3rem;line-height:2.5rem;font-weight:800}@media (min-width: 768px){.xlarge{font-size:4.375rem;line-height:4.125rem}}\n"] }]
71
- }], ctorParameters: () => [{ type: i1.ContentService }], propDecorators: { props: [{
68
+ }], ctorParameters: () => [], propDecorators: { props: [{
72
69
  type: Input
73
70
  }] } });
74
71
  /**
@@ -127,4 +124,4 @@ export function createDisplayProps(contentConfig, styleConfig = {}) {
127
124
  size: styleConfig.size || 'medium',
128
125
  };
129
126
  }
130
- //# 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,KAAK,EAAqB,MAAM,eAAe,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAc,YAAY,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;;;;AAiBpD;;;;;;;;;;;;;;GAcG;AACH,MAAM,OAAO,gBAAgB;IAe3B,YAAoB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QAb1C,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAaU,CAAC;IAEtD,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,cAAc,CAAC,WAAW,CAAC;gBACrD,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,IAAI,SAAS;gBAC1D,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG;gBACjC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG;gBAC3E,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa;aACtD,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,2CAA2C;QAC3C,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;+GA7CU,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;mFA+BD,KAAK;sBADJ,KAAK;;AAoCR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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, Input, OnDestroy, OnInit } from '@angular/core';\nimport { IonText } from '@ionic/angular/standalone';\nimport { Observable, Subscription, of } from 'rxjs';\nimport { ContentService } from '../../../services/content.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  constructor(private contentService: ContentService) {}\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.contentService.fromContent({\n        className: this.props.contentConfig.className || '_global',\n        key: this.props.contentConfig.key,\n        fallback: 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"]}
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"]}
@@ -3,8 +3,9 @@ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
3
3
  import { IonText } from '@ionic/angular/standalone';
4
4
  import { of, Subscription } from 'rxjs';
5
5
  import { ProcessLinksPipe } from '../../../shared/pipes/process-links.pipe';
6
+ import { interpolateStaticContent, shouldUseReactiveContent } from '../../../shared/utils/simple-content';
6
7
  import * as i0 from "@angular/core";
7
- import * as i1 from "../../../services/content.service";
8
+ import * as i1 from "../../../services/lang-provider/lang-provider.service";
8
9
  import * as i2 from "../../../services/link-processor.service";
9
10
  /**
10
11
  * val-text
@@ -106,8 +107,8 @@ import * as i2 from "../../../services/link-processor.service";
106
107
  * @input props: TextMetadata - Configuration for the text (content, styling, and reactive content options)
107
108
  */
108
109
  export class TextComponent {
109
- constructor(contentService, linkProcessor) {
110
- this.contentService = contentService;
110
+ constructor(langService, linkProcessor) {
111
+ this.langService = langService;
111
112
  this.linkProcessor = linkProcessor;
112
113
  this.subscription = new Subscription();
113
114
  }
@@ -124,26 +125,25 @@ export class TextComponent {
124
125
  setupDisplayContent() {
125
126
  if (this.props.content) {
126
127
  // Static content takes precedence
127
- this.displayContent$ = of(this.props.content);
128
+ if (this.props.contentInterpolation) {
129
+ // Static content with interpolation
130
+ const interpolatedContent = interpolateStaticContent(this.props.content, this.props.contentInterpolation);
131
+ this.displayContent$ = of(interpolatedContent);
132
+ }
133
+ else {
134
+ // Simple static content
135
+ this.displayContent$ = of(this.props.content);
136
+ }
128
137
  }
129
- else if (this.props.contentKey && this.props.contentClass) {
138
+ else if (shouldUseReactiveContent(this.props)) {
130
139
  // Reactive content from language service
131
140
  if (this.props.contentInterpolation) {
132
141
  // With interpolation
133
- this.displayContent$ = this.contentService.fromContentWithInterpolation({
134
- className: this.props.contentClass,
135
- key: this.props.contentKey,
136
- fallback: this.props.contentFallback,
137
- interpolation: this.props.contentInterpolation,
138
- });
142
+ this.displayContent$ = this.langService.getContentWithInterpolation(this.props.contentClass, this.props.contentKey, this.props.contentInterpolation, this.props.contentFallback);
139
143
  }
140
144
  else {
141
145
  // Simple reactive content
142
- this.displayContent$ = this.contentService.fromContent({
143
- className: this.props.contentClass,
144
- key: this.props.contentKey,
145
- fallback: this.props.contentFallback,
146
- });
146
+ this.displayContent$ = this.langService.getContent(this.props.contentClass, this.props.contentKey, this.props.contentFallback);
147
147
  }
148
148
  }
149
149
  else {
@@ -168,7 +168,7 @@ export class TextComponent {
168
168
  processedContent = processedContent.replace(/<strong>(.*?)<\/strong>/gi, '<span class="partial-bold">$1</span>');
169
169
  return processedContent;
170
170
  }
171
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TextComponent, deps: [{ token: i1.ContentService }, { token: i2.LinkProcessorService }], target: i0.ɵɵFactoryTarget.Component }); }
171
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TextComponent, deps: [{ token: i1.LangService }, { token: i2.LinkProcessorService }], target: i0.ɵɵFactoryTarget.Component }); }
172
172
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TextComponent, isStandalone: true, selector: "val-text", inputs: { props: "props" }, ngImport: i0, template: `
173
173
  <ion-text [color]="props.color">
174
174
  @if (props.processLinks) {
@@ -208,7 +208,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
208
208
  }
209
209
  </ion-text>
210
210
  `, changeDetection: ChangeDetectionStrategy.OnPush, 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)}.small{font-size:.75rem;line-height:1.25rem;font-weight:400}.small.bold{font-size:.75rem;line-height:1.25rem;font-weight:700}.medium{font-size:.875rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.medium{font-size:1rem;line-height:1.5rem}}.medium.bold{font-size:.875rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.medium.bold{font-size:1rem;line-height:1.5rem}}.large{font-size:1rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.large{font-size:1.125rem;line-height:1.5rem}}.large.bold{font-size:1rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.large.bold{font-size:1.125rem;line-height:1.5rem}}.xlarge{font-size:1.125rem;line-height:1.5rem;font-weight:400}@media (min-width: 768px){.xlarge{font-size:1.5rem;line-height:2rem}}.xlarge.bold{font-size:1.125rem;line-height:1.5rem;font-weight:700}@media (min-width: 768px){.xlarge.bold{font-size:1.5rem;line-height:2rem}}:host ::ng-deep .partial-bold{font-weight:700}\n"] }]
211
- }], ctorParameters: () => [{ type: i1.ContentService }, { type: i2.LinkProcessorService }], propDecorators: { props: [{
211
+ }], ctorParameters: () => [{ type: i1.LangService }, { type: i2.LinkProcessorService }], propDecorators: { props: [{
212
212
  type: Input
213
213
  }] } });
214
214
  /**
@@ -263,4 +263,4 @@ export function createTextProps(contentConfig, styleConfig = {}) {
263
263
  allowPartialBold: styleConfig.allowPartialBold || false,
264
264
  };
265
265
  }
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/text/text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { IonText } from '@ionic/angular/standalone';\nimport { Observable, of, Subscription } from 'rxjs';\nimport { ContentService } from '../../../services/content.service';\nimport { LinkProcessorService } from '../../../services/link-processor.service';\nimport { ProcessLinksPipe } from '../../../shared/pipes/process-links.pipe';\nimport { TextContentConfig, TextMetadata } from './types';\n\n@Component({\n  selector: 'val-text',\n  standalone: true,\n  imports: [IonText, AsyncPipe, ProcessLinksPipe],\n  template: `\n    <ion-text [color]=\"props.color\">\n      @if (props.processLinks) {\n        <p\n          [class]=\"props.size\"\n          [class.bold]=\"props.bold\"\n          [innerHTML]=\"displayContent$ | async | processLinks: props.linkConfig\"\n        ></p>\n      } @else if (\n        (props.allowPartialBold && (displayContent$ | async)?.includes('<b>')) ||\n        (displayContent$ | async)?.includes('<strong>')\n      ) {\n        <p [class]=\"props.size\" [class.bold]=\"props.bold\" [innerHTML]=\"processPartialBold(displayContent$ | async)\"></p>\n      } @else {\n        <p [class]=\"props.size\" [class.bold]=\"props.bold\">{{ displayContent$ | async }}</p>\n      }\n    </ion-text>\n  `,\n  styleUrls: ['./text.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n/**\n * val-text\n *\n * Enhanced text component that supports both static content and reactive content from the language service.\n * The component automatically updates when the language changes if using reactive content.\n *\n * @example Static content:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Static text',\n *   color: 'primary',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Reactive content:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'welcomeMessage',\n *   contentClass: 'HomeComponent',\n *   contentFallback: 'Welcome!',\n *   color: 'primary',\n *   size: 'large',\n *   bold: true\n * }\"></val-text>\n * ```\n *\n * @example Reactive content with interpolation:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'greeting',\n *   contentClass: 'UserComponent',\n *   contentInterpolation: { name: 'John', count: 5 },\n *   color: 'secondary',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example With automatic link processing:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Visit https://example.com or go to /profile for more info',\n *   processLinks: true,\n *   linkConfig: {\n *     openExternalInNewTab: true,\n *     openInternalInNewTab: false,\n *     linkClass: 'custom-link',\n *     externalLinkClass: 'external',\n *     internalLinkClass: 'internal'\n *   },\n *   color: 'primary',\n *   size: 'medium'\n * }\"></val-text>\n * ```\n *\n * @example With partial bold support:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Hola <b>Victor</b>, cómo estás? También puedes usar <strong>strong</strong>',\n *   allowPartialBold: true,\n *   color: 'dark',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Reactive content with partial bold:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'welcomeWithName',\n *   contentClass: 'UserComponent',\n *   contentInterpolation: { name: '<b>Juan</b>' },\n *   allowPartialBold: true,\n *   color: 'primary',\n *   size: 'large',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Using ContentService helper:\n * ```typescript\n * // In component\n * content = inject(ContentService);\n * componentContent = this.content.forComponent('MyComponent');\n *\n * textProps = {\n *   content: this.componentContent.getText('title'), // sync\n *   color: 'primary',\n *   size: 'large',\n *   bold: true\n * };\n * // Or with reactive binding:\n * title$ = this.componentContent.get('title');\n * ```\n *\n * @input props: TextMetadata - Configuration for the text (content, styling, and reactive content options)\n */\nexport class TextComponent implements OnInit, OnDestroy {\n  /**\n   * Text configuration object.\n   * @type {TextMetadata}\n   *\n   * For static content:\n   * @property content - The text to display (takes precedence over reactive content)\n   *\n   * For reactive content:\n   * @property contentKey - The content key to retrieve from language service\n   * @property contentClass - The component class name for content lookup\n   * @property contentFallback - Optional fallback text if content is not found\n   * @property contentInterpolation - Optional values to interpolate into content\n   *\n   * For styling:\n   * @property color - The text color (Ionic color string)\n   * @property size - The text size ('small' | 'medium' | 'large' | 'xlarge')\n   * @property bold - Whether the text is bold\n   * @property processLinks - Whether to automatically process and convert links in text (default: false)\n   * @property linkConfig - Configuration for link processing (colors, target behavior, etc.)\n   * @property allowPartialBold - Whether to allow partial bold using <b> or <strong> tags (default: false)\n   */\n  @Input()\n  props: TextMetadata;\n\n  /**\n   * Observable that provides the content to display.\n   * This will be either static content or reactive content from the language service.\n   */\n  displayContent$: Observable<string>;\n\n  private subscription = new Subscription();\n\n  constructor(\n    private contentService: ContentService,\n    private linkProcessor: LinkProcessorService\n  ) {}\n\n  ngOnInit() {\n    this.setupDisplayContent();\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  /**\n   * Set up the content observable based on the props configuration.\n   * Priority: static content > reactive content with interpolation > reactive content\n   */\n  private setupDisplayContent(): void {\n    if (this.props.content) {\n      // Static content takes precedence\n      this.displayContent$ = of(this.props.content);\n    } else if (this.props.contentKey && this.props.contentClass) {\n      // Reactive content from language service\n      if (this.props.contentInterpolation) {\n        // With interpolation\n        this.displayContent$ = this.contentService.fromContentWithInterpolation({\n          className: this.props.contentClass,\n          key: this.props.contentKey,\n          fallback: this.props.contentFallback,\n          interpolation: this.props.contentInterpolation,\n        });\n      } else {\n        // Simple reactive content\n        this.displayContent$ = this.contentService.fromContent({\n          className: this.props.contentClass,\n          key: this.props.contentKey,\n          fallback: this.props.contentFallback,\n        });\n      }\n    } else {\n      // Fallback to empty string if no valid content configuration\n      console.warn(\n        'val-text: No valid content configuration provided. Use either \"content\" for static text or \"contentKey\" + \"contentClass\" for reactive content.'\n      );\n      this.displayContent$ = of(this.props.contentFallback || '');\n    }\n  }\n\n  /**\n   * Process partial bold tags in the content.\n   * Converts <b> and <strong> tags to properly styled bold spans.\n   *\n   * @param content - The content string to process\n   * @returns Processed content with bold styling\n   */\n  processPartialBold(content: string | null): string {\n    if (!content) return '';\n\n    // Process <b> tags\n    let processedContent = content.replace(/<b>(.*?)<\\/b>/gi, '<span class=\"partial-bold\">$1</span>');\n\n    // Process <strong> tags\n    processedContent = processedContent.replace(/<strong>(.*?)<\\/strong>/gi, '<span class=\"partial-bold\">$1</span>');\n\n    return processedContent;\n  }\n}\n\n/**\n * Helper function to create reactive text props from content configuration.\n * This provides a convenient way to create val-text props with reactive content.\n *\n * @param contentConfig - Content configuration\n * @param styleConfig - Optional style configuration\n * @returns Partial TextMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * titleProps: TextMetadata = {\n *   ...createTextProps({\n *     contentKey: 'title',\n *     contentClass: 'HeaderComponent'\n *   }, {\n *     color: 'primary',\n *     size: 'large',\n *     bold: true\n *   })\n * };\n * ```\n *\n * @example With partial bold support:\n * ```typescript\n * // In component\n * greetingProps: TextMetadata = {\n *   ...createTextProps({\n *     contentKey: 'greeting',\n *     contentClass: 'UserComponent',\n *     contentInterpolation: { name: '<b>Juan</b>' }\n *   }, {\n *     color: 'primary',\n *     size: 'medium',\n *     bold: false,\n *     allowPartialBold: true\n *   })\n * };\n * ```\n */\nexport function createTextProps(\n  contentConfig: TextContentConfig,\n  styleConfig: Partial<Pick<TextMetadata, 'color' | 'size' | 'bold' | 'allowPartialBold'>> = {}\n): Partial<TextMetadata> {\n  return {\n    contentKey: contentConfig.contentKey,\n    contentClass: contentConfig.contentClass,\n    contentFallback: contentConfig.contentFallback,\n    contentInterpolation: contentConfig.contentInterpolation,\n    color: styleConfig.color || 'dark',\n    size: styleConfig.size || 'medium',\n    bold: styleConfig.bold || false,\n    allowPartialBold: styleConfig.allowPartialBold || false,\n  };\n}\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/atoms/text/text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, 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 { LinkProcessorService } from '../../../services/link-processor.service';\nimport { ProcessLinksPipe } from '../../../shared/pipes/process-links.pipe';\nimport { interpolateStaticContent, shouldUseReactiveContent } from '../../../shared/utils/simple-content';\nimport { TextContentConfig, TextMetadata } from './types';\n\n@Component({\n  selector: 'val-text',\n  standalone: true,\n  imports: [IonText, AsyncPipe, ProcessLinksPipe],\n  template: `\n    <ion-text [color]=\"props.color\">\n      @if (props.processLinks) {\n        <p\n          [class]=\"props.size\"\n          [class.bold]=\"props.bold\"\n          [innerHTML]=\"displayContent$ | async | processLinks: props.linkConfig\"\n        ></p>\n      } @else if (\n        (props.allowPartialBold && (displayContent$ | async)?.includes('<b>')) ||\n        (displayContent$ | async)?.includes('<strong>')\n      ) {\n        <p [class]=\"props.size\" [class.bold]=\"props.bold\" [innerHTML]=\"processPartialBold(displayContent$ | async)\"></p>\n      } @else {\n        <p [class]=\"props.size\" [class.bold]=\"props.bold\">{{ displayContent$ | async }}</p>\n      }\n    </ion-text>\n  `,\n  styleUrls: ['./text.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n/**\n * val-text\n *\n * Enhanced text component that supports both static content and reactive content from the language service.\n * The component automatically updates when the language changes if using reactive content.\n *\n * @example Static content:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Static text',\n *   color: 'primary',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Reactive content:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'welcomeMessage',\n *   contentClass: 'HomeComponent',\n *   contentFallback: 'Welcome!',\n *   color: 'primary',\n *   size: 'large',\n *   bold: true\n * }\"></val-text>\n * ```\n *\n * @example Reactive content with interpolation:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'greeting',\n *   contentClass: 'UserComponent',\n *   contentInterpolation: { name: 'John', count: 5 },\n *   color: 'secondary',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example With automatic link processing:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Visit https://example.com or go to /profile for more info',\n *   processLinks: true,\n *   linkConfig: {\n *     openExternalInNewTab: true,\n *     openInternalInNewTab: false,\n *     linkClass: 'custom-link',\n *     externalLinkClass: 'external',\n *     internalLinkClass: 'internal'\n *   },\n *   color: 'primary',\n *   size: 'medium'\n * }\"></val-text>\n * ```\n *\n * @example With partial bold support:\n * ```html\n * <val-text [props]=\"{\n *   content: 'Hola <b>Victor</b>, cómo estás? También puedes usar <strong>strong</strong>',\n *   allowPartialBold: true,\n *   color: 'dark',\n *   size: 'medium',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Reactive content with partial bold:\n * ```html\n * <val-text [props]=\"{\n *   contentKey: 'welcomeWithName',\n *   contentClass: 'UserComponent',\n *   contentInterpolation: { name: '<b>Juan</b>' },\n *   allowPartialBold: true,\n *   color: 'primary',\n *   size: 'large',\n *   bold: false\n * }\"></val-text>\n * ```\n *\n * @example Using ContentService helper:\n * ```typescript\n * // In component\n * content = inject(ContentService);\n * componentContent = this.content.forComponent('MyComponent');\n *\n * textProps = {\n *   content: this.componentContent.getText('title'), // sync\n *   color: 'primary',\n *   size: 'large',\n *   bold: true\n * };\n * // Or with reactive binding:\n * title$ = this.componentContent.get('title');\n * ```\n *\n * @input props: TextMetadata - Configuration for the text (content, styling, and reactive content options)\n */\nexport class TextComponent implements OnInit, OnDestroy {\n  /**\n   * Text configuration object.\n   * @type {TextMetadata}\n   *\n   * For static content:\n   * @property content - The text to display (takes precedence over reactive content)\n   *\n   * For reactive content:\n   * @property contentKey - The content key to retrieve from language service\n   * @property contentClass - The component class name for content lookup\n   * @property contentFallback - Optional fallback text if content is not found\n   * @property contentInterpolation - Optional values to interpolate into content\n   *\n   * For styling:\n   * @property color - The text color (Ionic color string)\n   * @property size - The text size ('small' | 'medium' | 'large' | 'xlarge')\n   * @property bold - Whether the text is bold\n   * @property processLinks - Whether to automatically process and convert links in text (default: false)\n   * @property linkConfig - Configuration for link processing (colors, target behavior, etc.)\n   * @property allowPartialBold - Whether to allow partial bold using <b> or <strong> tags (default: false)\n   */\n  @Input()\n  props: TextMetadata;\n\n  /**\n   * Observable that provides the content to display.\n   * This will be either static content or reactive content from the language service.\n   */\n  displayContent$: Observable<string>;\n\n  private subscription = new Subscription();\n\n  constructor(\n    private langService: LangService,\n    private linkProcessor: LinkProcessorService\n  ) {}\n\n  ngOnInit() {\n    this.setupDisplayContent();\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  /**\n   * Set up the content observable based on the props configuration.\n   * Priority: static content > reactive content with interpolation > reactive content\n   */\n  private setupDisplayContent(): void {\n    if (this.props.content) {\n      // Static content takes precedence\n      if (this.props.contentInterpolation) {\n        // Static content with interpolation\n        const interpolatedContent = interpolateStaticContent(this.props.content, this.props.contentInterpolation);\n        this.displayContent$ = of(interpolatedContent);\n      } else {\n        // Simple static content\n        this.displayContent$ = of(this.props.content);\n      }\n    } else if (shouldUseReactiveContent(this.props)) {\n      // Reactive content from language service\n      if (this.props.contentInterpolation) {\n        // With interpolation\n        this.displayContent$ = this.langService.getContentWithInterpolation(\n          this.props.contentClass!,\n          this.props.contentKey!,\n          this.props.contentInterpolation,\n          this.props.contentFallback\n        );\n      } else {\n        // Simple reactive content\n        this.displayContent$ = this.langService.getContent(\n          this.props.contentClass!,\n          this.props.contentKey!,\n          this.props.contentFallback\n        );\n      }\n    } else {\n      // Fallback to empty string if no valid content configuration\n      console.warn(\n        'val-text: No valid content configuration provided. Use either \"content\" for static text or \"contentKey\" + \"contentClass\" for reactive content.'\n      );\n      this.displayContent$ = of(this.props.contentFallback || '');\n    }\n  }\n\n  /**\n   * Process partial bold tags in the content.\n   * Converts <b> and <strong> tags to properly styled bold spans.\n   *\n   * @param content - The content string to process\n   * @returns Processed content with bold styling\n   */\n  processPartialBold(content: string | null): string {\n    if (!content) return '';\n\n    // Process <b> tags\n    let processedContent = content.replace(/<b>(.*?)<\\/b>/gi, '<span class=\"partial-bold\">$1</span>');\n\n    // Process <strong> tags\n    processedContent = processedContent.replace(/<strong>(.*?)<\\/strong>/gi, '<span class=\"partial-bold\">$1</span>');\n\n    return processedContent;\n  }\n}\n\n/**\n * Helper function to create reactive text props from content configuration.\n * This provides a convenient way to create val-text props with reactive content.\n *\n * @param contentConfig - Content configuration\n * @param styleConfig - Optional style configuration\n * @returns Partial TextMetadata with content properties set\n *\n * @example\n * ```typescript\n * // In component\n * titleProps: TextMetadata = {\n *   ...createTextProps({\n *     contentKey: 'title',\n *     contentClass: 'HeaderComponent'\n *   }, {\n *     color: 'primary',\n *     size: 'large',\n *     bold: true\n *   })\n * };\n * ```\n *\n * @example With partial bold support:\n * ```typescript\n * // In component\n * greetingProps: TextMetadata = {\n *   ...createTextProps({\n *     contentKey: 'greeting',\n *     contentClass: 'UserComponent',\n *     contentInterpolation: { name: '<b>Juan</b>' }\n *   }, {\n *     color: 'primary',\n *     size: 'medium',\n *     bold: false,\n *     allowPartialBold: true\n *   })\n * };\n * ```\n */\nexport function createTextProps(\n  contentConfig: TextContentConfig,\n  styleConfig: Partial<Pick<TextMetadata, 'color' | 'size' | 'bold' | 'allowPartialBold'>> = {}\n): Partial<TextMetadata> {\n  return {\n    contentKey: contentConfig.contentKey,\n    contentClass: contentConfig.contentClass,\n    contentFallback: contentConfig.contentFallback,\n    contentInterpolation: contentConfig.contentInterpolation,\n    color: styleConfig.color || 'dark',\n    size: styleConfig.size || 'medium',\n    bold: styleConfig.bold || false,\n    allowPartialBold: styleConfig.allowPartialBold || false,\n  };\n}\n"]}
@@ -2,8 +2,8 @@ import { AsyncPipe, CommonModule } from '@angular/common';
2
2
  import { ChangeDetectionStrategy, Component, Input, inject } from '@angular/core';
3
3
  import { IonText } from '@ionic/angular/standalone';
4
4
  import { of } from 'rxjs';
5
- import { ContentService } from '../../../services/content.service';
6
- import { createComponentContentHelper, shouldUseReactiveContent, } from '../../../shared/utils/reactive-content';
5
+ import { LangService } from '../../../services/lang-provider/lang-provider.service';
6
+ import { extractContentConfig, shouldUseReactiveContent } from '../../../shared/utils/simple-content';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/common";
9
9
  /**
@@ -45,14 +45,14 @@ import * as i1 from "@angular/common";
45
45
  */
46
46
  export class TitleComponent {
47
47
  constructor() {
48
- this.contentService = inject(ContentService);
48
+ this.langService = inject(LangService);
49
49
  }
50
50
  ngOnInit() {
51
- this.contentHelper = createComponentContentHelper(this.contentService);
52
51
  // Always convert to Observable for consistent template handling
53
52
  if (shouldUseReactiveContent(this.props)) {
54
- // Use reactive content
55
- this.displayContent$ = this.contentHelper.resolveContent(this.props);
53
+ // Use reactive content with LangService
54
+ const config = extractContentConfig(this.props);
55
+ this.displayContent$ = this.langService.getContent(config.className, config.key, config.fallback);
56
56
  }
57
57
  else {
58
58
  // Convert static content to Observable
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
97
  }], ctorParameters: () => [], propDecorators: { props: [{
98
98
  type: Input
99
99
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy90aXRsZS90aXRsZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BELE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25FLE9BQU8sRUFFTCw0QkFBNEIsRUFDNUIsd0JBQXdCLEdBQ3pCLE1BQU0sd0NBQXdDLENBQUM7OztBQXlCaEQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9DRztBQUNILE1BQU0sT0FBTyxjQUFjO0lBbUJ6QjtRQUxRLG1CQUFjLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBS2pDLENBQUM7SUFFaEIsUUFBUTtRQUNOLElBQUksQ0FBQyxhQUFhLEdBQUcsNEJBQTRCLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRXZFLGdFQUFnRTtRQUNoRSxJQUFJLHdCQUF3QixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3pDLHVCQUF1QjtZQUN2QixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQXVCLENBQUM7UUFDN0YsQ0FBQzthQUFNLENBQUM7WUFDTix1Q0FBdUM7WUFDdkMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1lBQy9DLElBQUksQ0FBQyxlQUFlLEdBQUcsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzNDLENBQUM7SUFDSCxDQUFDOytHQWpDVSxjQUFjO21HQUFkLGNBQWMsaUdBdkRmOzs7Ozs7Ozs7Ozs7OztHQWNULHdzR0FmUyxZQUFZLGtMQUFFLE9BQU87OzRGQXdEcEIsY0FBYztrQkEzRDFCLFNBQVM7K0JBQ0UsV0FBVyxjQUNULElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxPQUFPLEVBQUUsU0FBUyxDQUFDLFlBQ2pDOzs7Ozs7Ozs7Ozs7OztHQWNULG1CQUVnQix1QkFBdUIsQ0FBQyxNQUFNO3dEQW1EL0MsS0FBSztzQkFESixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlLCBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJb25UZXh0IH0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ29udGVudFNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy9jb250ZW50LnNlcnZpY2UnO1xuaW1wb3J0IHtcbiAgQ29tcG9uZW50Q29udGVudEhlbHBlcixcbiAgY3JlYXRlQ29tcG9uZW50Q29udGVudEhlbHBlcixcbiAgc2hvdWxkVXNlUmVhY3RpdmVDb250ZW50LFxufSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvcmVhY3RpdmUtY29udGVudCc7XG5pbXBvcnQgeyBUaXRsZU1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC10aXRsZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIElvblRleHQsIEFzeW5jUGlwZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGlvbi10ZXh0IFtjb2xvcl09XCJwcm9wcy5jb2xvclwiPlxuICAgICAgQGlmICghcHJvcHMuYm9sZCkge1xuICAgICAgICA8cCBbbmdDbGFzc109XCJbcHJvcHMuc2l6ZV1cIiBbY2xhc3MudGhpbl09XCJwcm9wcy50aGluXCI+XG4gICAgICAgICAge3sgZGlzcGxheUNvbnRlbnQkIHwgYXN5bmMgfX1cbiAgICAgICAgPC9wPlxuICAgICAgfSBAZWxzZSB7XG4gICAgICAgIDxiPlxuICAgICAgICAgIDxwIFtjbGFzc109XCJwcm9wcy5zaXplXCI+XG4gICAgICAgICAgICB7eyBkaXNwbGF5Q29udGVudCQgfCBhc3luYyB9fVxuICAgICAgICAgIDwvcD5cbiAgICAgICAgPC9iPlxuICAgICAgfVxuICAgIDwvaW9uLXRleHQ+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3RpdGxlLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbi8qKlxuICogdmFsLXRpdGxlXG4gKlxuICogQSBzdHlsZWQgdGl0bGUgb3IgaGVhZGluZywgd2l0aCBvcHRpb25zIGZvciBzaXplLCBjb2xvciwgYW5kIGJvbGRuZXNzLlxuICogU3VwcG9ydHMgYm90aCBzdGF0aWMgY29udGVudCBhbmQgcmVhY3RpdmUgY29udGVudCBmcm9tIHRoZSBsYW5ndWFnZSBzZXJ2aWNlLlxuICpcbiAqIEBleGFtcGxlIFN0YXRpYyBjb250ZW50OlxuICogYGBgaHRtbFxuICogPHZhbC10aXRsZSBbcHJvcHNdPVwieyBjb250ZW50OiAnTXkgVGl0bGUnLCBzaXplOiAnbGFyZ2UnLCBjb2xvcjogJ3ByaW1hcnknLCBib2xkOiB0cnVlIH1cIj48L3ZhbC10aXRsZT5cbiAqIGBgYFxuICpcbiAqIEBleGFtcGxlIFJlYWN0aXZlIGNvbnRlbnQ6XG4gKiBgYGBodG1sXG4gKiA8dmFsLXRpdGxlIFtwcm9wc109XCJ7XG4gKiAgIGNvbnRlbnRDb25maWc6IHsga2V5OiAncGFnZVRpdGxlJywgZmFsbGJhY2s6ICdEZWZhdWx0IFRpdGxlJyB9LFxuICogICBzaXplOiAnbGFyZ2UnLFxuICogICBjb2xvcjogJ3ByaW1hcnknLFxuICogICBib2xkOiB0cnVlXG4gKiB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZSBSZWFjdGl2ZSBjb250ZW50IHdpdGggaW50ZXJwb2xhdGlvbjpcbiAqIGBgYGh0bWxcbiAqIDx2YWwtdGl0bGUgW3Byb3BzXT1cIntcbiAqICAgY29udGVudENvbmZpZzoge1xuICogICAgIGtleTogJ3dlbGNvbWVUaXRsZScsXG4gKiAgICAgaW50ZXJwb2xhdGlvbjogeyBuYW1lOiAnSm9obicgfSxcbiAqICAgICBmYWxsYmFjazogJ1dlbGNvbWUhJ1xuICogICB9LFxuICogICBzaXplOiAnbGFyZ2UnLFxuICogICBjb2xvcjogJ3ByaW1hcnknLFxuICogICBib2xkOiB0cnVlXG4gKiB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAaW5wdXQgcHJvcHM6IFRpdGxlTWV0YWRhdGEgLSBDb25maWd1cmF0aW9uIGZvciB0aGUgdGl0bGUgKGNvbnRlbnQsIGNvbG9yLCBzaXplLCBib2xkLCB0aGluKVxuICovXG5leHBvcnQgY2xhc3MgVGl0bGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAvKipcbiAgICogVGl0bGUgY29uZmlndXJhdGlvbiBvYmplY3QuXG4gICAqIEB0eXBlIHtUaXRsZU1ldGFkYXRhfVxuICAgKiBAcHJvcGVydHkgY29udGVudCAtIFN0YXRpYyB0aXRsZSB0ZXh0ICh0YWtlcyBwcmVjZWRlbmNlIG92ZXIgcmVhY3RpdmUgY29udGVudCkuXG4gICAqIEBwcm9wZXJ0eSBjb250ZW50Q29uZmlnIC0gUmVhY3RpdmUgY29udGVudCBjb25maWd1cmF0aW9uLlxuICAgKiBAcHJvcGVydHkgY29sb3IgLSBUaGUgdGl0bGUgY29sb3IgKElvbmljIGNvbG9yIHN0cmluZykuXG4gICAqIEBwcm9wZXJ0eSBzaXplIC0gVGhlIHRpdGxlIHNpemUgKCdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJykuXG4gICAqIEBwcm9wZXJ0eSBib2xkIC0gV2hldGhlciB0aGUgdGl0bGUgaXMgYm9sZC5cbiAgICogQHByb3BlcnR5IHRoaW4gLSBXaGV0aGVyIHRoZSB0aXRsZSBpcyB0aGluIChvcHRpb25hbCkuXG4gICAqL1xuICBASW5wdXQoKVxuICBwcm9wczogVGl0bGVNZXRhZGF0YTtcblxuICBwcml2YXRlIGNvbnRlbnRTZXJ2aWNlID0gaW5qZWN0KENvbnRlbnRTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBjb250ZW50SGVscGVyOiBDb21wb25lbnRDb250ZW50SGVscGVyO1xuXG4gIGRpc3BsYXlDb250ZW50JDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmNvbnRlbnRIZWxwZXIgPSBjcmVhdGVDb21wb25lbnRDb250ZW50SGVscGVyKHRoaXMuY29udGVudFNlcnZpY2UpO1xuXG4gICAgLy8gQWx3YXlzIGNvbnZlcnQgdG8gT2JzZXJ2YWJsZSBmb3IgY29uc2lzdGVudCB0ZW1wbGF0ZSBoYW5kbGluZ1xuICAgIGlmIChzaG91bGRVc2VSZWFjdGl2ZUNvbnRlbnQodGhpcy5wcm9wcykpIHtcbiAgICAgIC8vIFVzZSByZWFjdGl2ZSBjb250ZW50XG4gICAgICB0aGlzLmRpc3BsYXlDb250ZW50JCA9IHRoaXMuY29udGVudEhlbHBlci5yZXNvbHZlQ29udGVudCh0aGlzLnByb3BzKSBhcyBPYnNlcnZhYmxlPHN0cmluZz47XG4gICAgfSBlbHNlIHtcbiAgICAgIC8vIENvbnZlcnQgc3RhdGljIGNvbnRlbnQgdG8gT2JzZXJ2YWJsZVxuICAgICAgY29uc3Qgc3RhdGljQ29udGVudCA9IHRoaXMucHJvcHMuY29udGVudCB8fCAnJztcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gb2Yoc3RhdGljQ29udGVudCk7XG4gICAgfVxuICB9XG59XG4iXX0=
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9hdG9tcy90aXRsZS90aXRsZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BELE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHVEQUF1RCxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOzs7QUF5QnRHOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQ0c7QUFDSCxNQUFNLE9BQU8sY0FBYztJQWtCekI7UUFKUSxnQkFBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUkzQixDQUFDO0lBRWhCLFFBQVE7UUFDTixnRUFBZ0U7UUFDaEUsSUFBSSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN6Qyx3Q0FBd0M7WUFDeEMsTUFBTSxNQUFNLEdBQUcsb0JBQW9CLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2hELElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNwRyxDQUFDO2FBQU0sQ0FBQztZQUNOLHVDQUF1QztZQUN2QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNILENBQUM7K0dBL0JVLGNBQWM7bUdBQWQsY0FBYyxpR0F2RGY7Ozs7Ozs7Ozs7Ozs7O0dBY1Qsd3NHQWZTLFlBQVksa0xBQUUsT0FBTzs7NEZBd0RwQixjQUFjO2tCQTNEMUIsU0FBUzsrQkFDRSxXQUFXLGNBQ1QsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE9BQU8sRUFBRSxTQUFTLENBQUMsWUFDakM7Ozs7Ozs7Ozs7Ozs7O0dBY1QsbUJBRWdCLHVCQUF1QixDQUFDLE1BQU07d0RBbUQvQyxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1BpcGUsIENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElvblRleHQgfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBMYW5nU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvbGFuZy1wcm92aWRlci5zZXJ2aWNlJztcbmltcG9ydCB7IGV4dHJhY3RDb250ZW50Q29uZmlnLCBzaG91bGRVc2VSZWFjdGl2ZUNvbnRlbnQgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvc2ltcGxlLWNvbnRlbnQnO1xuaW1wb3J0IHsgVGl0bGVNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtdGl0bGUnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBJb25UZXh0LCBBc3luY1BpcGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpb24tdGV4dCBbY29sb3JdPVwicHJvcHMuY29sb3JcIj5cbiAgICAgIEBpZiAoIXByb3BzLmJvbGQpIHtcbiAgICAgICAgPHAgW25nQ2xhc3NdPVwiW3Byb3BzLnNpemVdXCIgW2NsYXNzLnRoaW5dPVwicHJvcHMudGhpblwiPlxuICAgICAgICAgIHt7IGRpc3BsYXlDb250ZW50JCB8IGFzeW5jIH19XG4gICAgICAgIDwvcD5cbiAgICAgIH0gQGVsc2Uge1xuICAgICAgICA8Yj5cbiAgICAgICAgICA8cCBbY2xhc3NdPVwicHJvcHMuc2l6ZVwiPlxuICAgICAgICAgICAge3sgZGlzcGxheUNvbnRlbnQkIHwgYXN5bmMgfX1cbiAgICAgICAgICA8L3A+XG4gICAgICAgIDwvYj5cbiAgICAgIH1cbiAgICA8L2lvbi10ZXh0PlxuICBgLFxuICBzdHlsZVVybHM6IFsnLi90aXRsZS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG4vKipcbiAqIHZhbC10aXRsZVxuICpcbiAqIEEgc3R5bGVkIHRpdGxlIG9yIGhlYWRpbmcsIHdpdGggb3B0aW9ucyBmb3Igc2l6ZSwgY29sb3IsIGFuZCBib2xkbmVzcy5cbiAqIFN1cHBvcnRzIGJvdGggc3RhdGljIGNvbnRlbnQgYW5kIHJlYWN0aXZlIGNvbnRlbnQgZnJvbSB0aGUgbGFuZ3VhZ2Ugc2VydmljZS5cbiAqXG4gKiBAZXhhbXBsZSBTdGF0aWMgY29udGVudDpcbiAqIGBgYGh0bWxcbiAqIDx2YWwtdGl0bGUgW3Byb3BzXT1cInsgY29udGVudDogJ015IFRpdGxlJywgc2l6ZTogJ2xhcmdlJywgY29sb3I6ICdwcmltYXJ5JywgYm9sZDogdHJ1ZSB9XCI+PC92YWwtdGl0bGU+XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZSBSZWFjdGl2ZSBjb250ZW50OlxuICogYGBgaHRtbFxuICogPHZhbC10aXRsZSBbcHJvcHNdPVwie1xuICogICBjb250ZW50Q29uZmlnOiB7IGtleTogJ3BhZ2VUaXRsZScsIGZhbGxiYWNrOiAnRGVmYXVsdCBUaXRsZScgfSxcbiAqICAgc2l6ZTogJ2xhcmdlJyxcbiAqICAgY29sb3I6ICdwcmltYXJ5JyxcbiAqICAgYm9sZDogdHJ1ZVxuICogfVwiPjwvdmFsLXRpdGxlPlxuICogYGBgXG4gKlxuICogQGV4YW1wbGUgUmVhY3RpdmUgY29udGVudCB3aXRoIGludGVycG9sYXRpb246XG4gKiBgYGBodG1sXG4gKiA8dmFsLXRpdGxlIFtwcm9wc109XCJ7XG4gKiAgIGNvbnRlbnRDb25maWc6IHtcbiAqICAgICBrZXk6ICd3ZWxjb21lVGl0bGUnLFxuICogICAgIGludGVycG9sYXRpb246IHsgbmFtZTogJ0pvaG4nIH0sXG4gKiAgICAgZmFsbGJhY2s6ICdXZWxjb21lISdcbiAqICAgfSxcbiAqICAgc2l6ZTogJ2xhcmdlJyxcbiAqICAgY29sb3I6ICdwcmltYXJ5JyxcbiAqICAgYm9sZDogdHJ1ZVxuICogfVwiPjwvdmFsLXRpdGxlPlxuICogYGBgXG4gKlxuICogQGlucHV0IHByb3BzOiBUaXRsZU1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIHRpdGxlIChjb250ZW50LCBjb2xvciwgc2l6ZSwgYm9sZCwgdGhpbilcbiAqL1xuZXhwb3J0IGNsYXNzIFRpdGxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqXG4gICAqIFRpdGxlIGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICAgKiBAdHlwZSB7VGl0bGVNZXRhZGF0YX1cbiAgICogQHByb3BlcnR5IGNvbnRlbnQgLSBTdGF0aWMgdGl0bGUgdGV4dCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIHJlYWN0aXZlIGNvbnRlbnQpLlxuICAgKiBAcHJvcGVydHkgY29udGVudENvbmZpZyAtIFJlYWN0aXZlIGNvbnRlbnQgY29uZmlndXJhdGlvbi5cbiAgICogQHByb3BlcnR5IGNvbG9yIC0gVGhlIHRpdGxlIGNvbG9yIChJb25pYyBjb2xvciBzdHJpbmcpLlxuICAgKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSB0aXRsZSBzaXplICgnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnIHwgJ3hsYXJnZScpLlxuICAgKiBAcHJvcGVydHkgYm9sZCAtIFdoZXRoZXIgdGhlIHRpdGxlIGlzIGJvbGQuXG4gICAqIEBwcm9wZXJ0eSB0aGluIC0gV2hldGhlciB0aGUgdGl0bGUgaXMgdGhpbiAob3B0aW9uYWwpLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHJvcHM6IFRpdGxlTWV0YWRhdGE7XG5cbiAgcHJpdmF0ZSBsYW5nU2VydmljZSA9IGluamVjdChMYW5nU2VydmljZSk7XG5cbiAgZGlzcGxheUNvbnRlbnQkOiBPYnNlcnZhYmxlPHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIC8vIEFsd2F5cyBjb252ZXJ0IHRvIE9ic2VydmFibGUgZm9yIGNvbnNpc3RlbnQgdGVtcGxhdGUgaGFuZGxpbmdcbiAgICBpZiAoc2hvdWxkVXNlUmVhY3RpdmVDb250ZW50KHRoaXMucHJvcHMpKSB7XG4gICAgICAvLyBVc2UgcmVhY3RpdmUgY29udGVudCB3aXRoIExhbmdTZXJ2aWNlXG4gICAgICBjb25zdCBjb25maWcgPSBleHRyYWN0Q29udGVudENvbmZpZyh0aGlzLnByb3BzKTtcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gdGhpcy5sYW5nU2VydmljZS5nZXRDb250ZW50KGNvbmZpZy5jbGFzc05hbWUsIGNvbmZpZy5rZXksIGNvbmZpZy5mYWxsYmFjayk7XG4gICAgfSBlbHNlIHtcbiAgICAgIC8vIENvbnZlcnQgc3RhdGljIGNvbnRlbnQgdG8gT2JzZXJ2YWJsZVxuICAgICAgY29uc3Qgc3RhdGljQ29udGVudCA9IHRoaXMucHJvcHMuY29udGVudCB8fCAnJztcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gb2Yoc3RhdGljQ29udGVudCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -17,7 +17,11 @@
17
17
  * ```typescript
18
18
  * const props = createTitleProps(
19
19
  * { size: 'large', color: 'primary', bold: true },
20
- * { contentConfig: { key: 'pageTitle', fallback: 'Default Title' } }
20
+ * {
21
+ * contentKey: 'pageTitle',
22
+ * contentClass: 'MyComponent',
23
+ * contentFallback: 'Default Title'
24
+ * }
21
25
  * );
22
26
  * ```
23
27
  */
@@ -27,4 +31,4 @@ export function createTitleProps(styleConfig, contentConfig) {
27
31
  ...contentConfig,
28
32
  };
29
33
  }
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL3RpdGxlL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXNCRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FDOUIsV0FBb0UsRUFDcEUsYUFBK0Q7SUFFL0QsT0FBTztRQUNMLEdBQUcsV0FBVztRQUNkLEdBQUcsYUFBYTtLQUNqQixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yIH0gZnJvbSAnQGlvbmljL2NvcmUnO1xuaW1wb3J0IHsgUmVhY3RpdmVUZXh0TWV0YWRhdGEgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvdXRpbHMvcmVhY3RpdmUtY29udGVudCc7XG5cbi8qKlxuICogUHJvcHMgZm9yIHZhbC10aXRsZSBjb21wb25lbnQuXG4gKiBTdXBwb3J0cyBib3RoIHN0YXRpYyBjb250ZW50IGFuZCByZWFjdGl2ZSBjb250ZW50IGZyb20gdGhlIGxhbmd1YWdlIHNlcnZpY2UuXG4gKlxuICogQHByb3BlcnR5IGNvbnRlbnQgLSBTdGF0aWMgdGl0bGUgdGV4dCB0byBkaXNwbGF5ICh0YWtlcyBwcmVjZWRlbmNlIG92ZXIgcmVhY3RpdmUgY29udGVudCkuXG4gKiBAcHJvcGVydHkgY29udGVudENvbmZpZyAtIFJlYWN0aXZlIGNvbnRlbnQgY29uZmlndXJhdGlvbiAodXNlZCB3aGVuIGNvbnRlbnQgaXMgbm90IHByb3ZpZGVkKS5cbiAqIEBwcm9wZXJ0eSBjb2xvciAtIFRoZSB0aXRsZSBjb2xvciAoSW9uaWMgY29sb3Igc3RyaW5nKS5cbiAqIEBwcm9wZXJ0eSBzaXplIC0gVGhlIHRpdGxlIHNpemUgKCdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJykuXG4gKiBAcHJvcGVydHkgYm9sZCAtIFdoZXRoZXIgdGhlIHRpdGxlIGlzIGJvbGQuXG4gKiBAcHJvcGVydHkgdGhpbiAtIFdoZXRoZXIgdGhlIHRpdGxlIGlzIHRoaW4gKG9wdGlvbmFsKS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUaXRsZU1ldGFkYXRhIGV4dGVuZHMgUmVhY3RpdmVUZXh0TWV0YWRhdGEge1xuICBzaXplOiAnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnIHwgJ3hsYXJnZSc7XG4gIGNvbG9yOiBDb2xvcjtcbiAgYm9sZDogYm9vbGVhbjtcbiAgdGhpbj86IGJvb2xlYW47XG59XG5cbi8qKlxuICogRmFjdG9yeSBmdW5jdGlvbiB0byBjcmVhdGUgdGl0bGUgcHJvcHMgd2l0aCByZWFjdGl2ZSBjb250ZW50IHN1cHBvcnQuXG4gKlxuICogQHBhcmFtIHN0eWxlQ29uZmlnIC0gVGl0bGUgc3R5bGluZyBjb25maWd1cmF0aW9uXG4gKiBAcGFyYW0gY29udGVudENvbmZpZyAtIENvbnRlbnQgY29uZmlndXJhdGlvbiAoc3RhdGljIG9yIHJlYWN0aXZlKVxuICogQHJldHVybnMgQ29tcGxldGUgVGl0bGVNZXRhZGF0YSBvYmplY3RcbiAqXG4gKiBAZXhhbXBsZSBTdGF0aWMgY29udGVudDpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0IHByb3BzID0gY3JlYXRlVGl0bGVQcm9wcyhcbiAqICAgeyBzaXplOiAnbGFyZ2UnLCBjb2xvcjogJ3ByaW1hcnknLCBib2xkOiB0cnVlIH0sXG4gKiAgIHsgY29udGVudDogJ1N0YXRpYyBUaXRsZScgfVxuICogKTtcbiAqIGBgYFxuICpcbiAqIEBleGFtcGxlIFJlYWN0aXZlIGNvbnRlbnQ6XG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBjb25zdCBwcm9wcyA9IGNyZWF0ZVRpdGxlUHJvcHMoXG4gKiAgIHsgc2l6ZTogJ2xhcmdlJywgY29sb3I6ICdwcmltYXJ5JywgYm9sZDogdHJ1ZSB9LFxuICogICB7IGNvbnRlbnRDb25maWc6IHsga2V5OiAncGFnZVRpdGxlJywgZmFsbGJhY2s6ICdEZWZhdWx0IFRpdGxlJyB9IH1cbiAqICk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRpdGxlUHJvcHMoXG4gIHN0eWxlQ29uZmlnOiBQaWNrPFRpdGxlTWV0YWRhdGEsICdzaXplJyB8ICdjb2xvcicgfCAnYm9sZCcgfCAndGhpbic+LFxuICBjb250ZW50Q29uZmlnOiBQaWNrPFRpdGxlTWV0YWRhdGEsICdjb250ZW50JyB8ICdjb250ZW50Q29uZmlnJz5cbik6IFRpdGxlTWV0YWRhdGEge1xuICByZXR1cm4ge1xuICAgIC4uLnN0eWxlQ29uZmlnLFxuICAgIC4uLmNvbnRlbnRDb25maWcsXG4gIH07XG59XG4iXX0=
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL3RpdGxlL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVCQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQkc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQzlCLFdBQW9FLEVBQ3BFLGFBQWlHO0lBRWpHLE9BQU87UUFDTCxHQUFHLFdBQVc7UUFDZCxHQUFHLGFBQWE7S0FDakIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb2xvciB9IGZyb20gJ0Bpb25pYy9jb3JlJztcbmltcG9ydCB7IFJlYWN0aXZlVGV4dE1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vLi4vc2hhcmVkL3V0aWxzL3NpbXBsZS1jb250ZW50JztcblxuLyoqXG4gKiBQcm9wcyBmb3IgdmFsLXRpdGxlIGNvbXBvbmVudC5cbiAqIFN1cHBvcnRzIGJvdGggc3RhdGljIGNvbnRlbnQgYW5kIHJlYWN0aXZlIGNvbnRlbnQgZnJvbSB0aGUgbGFuZ3VhZ2Ugc2VydmljZS5cbiAqXG4gKiBAcHJvcGVydHkgY29udGVudCAtIFN0YXRpYyB0aXRsZSB0ZXh0IHRvIGRpc3BsYXkgKHRha2VzIHByZWNlZGVuY2Ugb3ZlciByZWFjdGl2ZSBjb250ZW50KS5cbiAqIEBwcm9wZXJ0eSBjb250ZW50S2V5IC0gQ29udGVudCBrZXkgZm9yIHJlYWN0aXZlIGNvbnRlbnQgbG9va3VwLlxuICogQHByb3BlcnR5IGNvbnRlbnRDbGFzcyAtIENvbXBvbmVudCBjbGFzcyBuYW1lIGZvciBjb250ZW50IGxvb2t1cC5cbiAqIEBwcm9wZXJ0eSBjb250ZW50RmFsbGJhY2sgLSBGYWxsYmFjayB0ZXh0IGlmIGNvbnRlbnQgaXMgbm90IGZvdW5kLlxuICogQHByb3BlcnR5IGNvbG9yIC0gVGhlIHRpdGxlIGNvbG9yIChJb25pYyBjb2xvciBzdHJpbmcpLlxuICogQHByb3BlcnR5IHNpemUgLSBUaGUgdGl0bGUgc2l6ZSAoJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJyB8ICd4bGFyZ2UnKS5cbiAqIEBwcm9wZXJ0eSBib2xkIC0gV2hldGhlciB0aGUgdGl0bGUgaXMgYm9sZC5cbiAqIEBwcm9wZXJ0eSB0aGluIC0gV2hldGhlciB0aGUgdGl0bGUgaXMgdGhpbiAob3B0aW9uYWwpLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRpdGxlTWV0YWRhdGEgZXh0ZW5kcyBSZWFjdGl2ZVRleHRNZXRhZGF0YSB7XG4gIHNpemU6ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJztcbiAgY29sb3I6IENvbG9yO1xuICBib2xkOiBib29sZWFuO1xuICB0aGluPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBGYWN0b3J5IGZ1bmN0aW9uIHRvIGNyZWF0ZSB0aXRsZSBwcm9wcyB3aXRoIHJlYWN0aXZlIGNvbnRlbnQgc3VwcG9ydC5cbiAqXG4gKiBAcGFyYW0gc3R5bGVDb25maWcgLSBUaXRsZSBzdHlsaW5nIGNvbmZpZ3VyYXRpb25cbiAqIEBwYXJhbSBjb250ZW50Q29uZmlnIC0gQ29udGVudCBjb25maWd1cmF0aW9uIChzdGF0aWMgb3IgcmVhY3RpdmUpXG4gKiBAcmV0dXJucyBDb21wbGV0ZSBUaXRsZU1ldGFkYXRhIG9iamVjdFxuICpcbiAqIEBleGFtcGxlIFN0YXRpYyBjb250ZW50OlxuICogYGBgdHlwZXNjcmlwdFxuICogY29uc3QgcHJvcHMgPSBjcmVhdGVUaXRsZVByb3BzKFxuICogICB7IHNpemU6ICdsYXJnZScsIGNvbG9yOiAncHJpbWFyeScsIGJvbGQ6IHRydWUgfSxcbiAqICAgeyBjb250ZW50OiAnU3RhdGljIFRpdGxlJyB9XG4gKiApO1xuICogYGBgXG4gKlxuICogQGV4YW1wbGUgUmVhY3RpdmUgY29udGVudDpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0IHByb3BzID0gY3JlYXRlVGl0bGVQcm9wcyhcbiAqICAgeyBzaXplOiAnbGFyZ2UnLCBjb2xvcjogJ3ByaW1hcnknLCBib2xkOiB0cnVlIH0sXG4gKiAgIHtcbiAqICAgICBjb250ZW50S2V5OiAncGFnZVRpdGxlJyxcbiAqICAgICBjb250ZW50Q2xhc3M6ICdNeUNvbXBvbmVudCcsXG4gKiAgICAgY29udGVudEZhbGxiYWNrOiAnRGVmYXVsdCBUaXRsZSdcbiAqICAgfVxuICogKTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVGl0bGVQcm9wcyhcbiAgc3R5bGVDb25maWc6IFBpY2s8VGl0bGVNZXRhZGF0YSwgJ3NpemUnIHwgJ2NvbG9yJyB8ICdib2xkJyB8ICd0aGluJz4sXG4gIGNvbnRlbnRDb25maWc6IFBpY2s8VGl0bGVNZXRhZGF0YSwgJ2NvbnRlbnQnIHwgJ2NvbnRlbnRLZXknIHwgJ2NvbnRlbnRDbGFzcycgfCAnY29udGVudEZhbGxiYWNrJz5cbik6IFRpdGxlTWV0YWRhdGEge1xuICByZXR1cm4ge1xuICAgIC4uLnN0eWxlQ29uZmlnLFxuICAgIC4uLmNvbnRlbnRDb25maWcsXG4gIH07XG59XG4iXX0=