valtech-components 2.0.317 → 2.0.318

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.
@@ -71,4 +71,60 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
71
71
  }], ctorParameters: () => [{ type: i1.ContentService }], propDecorators: { props: [{
72
72
  type: Input
73
73
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL2Rpc3BsYXkvZGlzcGxheS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUNwRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDcEQsT0FBTyxFQUFjLFlBQVksRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7QUFpQnBEOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBQ0gsTUFBTSxPQUFPLGdCQUFnQjtJQWUzQixZQUFvQixjQUE4QjtRQUE5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFiMUMsa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBYVUsQ0FBQztJQUV0RCxRQUFRO1FBQ04sSUFBSSxDQUFDLHdCQUF3QixFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFTyx3QkFBd0I7UUFDOUIsa0NBQWtDO1FBQ2xDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDckMsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5QyxPQUFPO1FBQ1QsQ0FBQztRQUVELHFDQUFxQztRQUNyQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQztnQkFDckQsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLFNBQVMsSUFBSSxTQUFTO2dCQUMxRCxHQUFHLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsR0FBRztnQkFDakMsUUFBUSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxHQUFHO2dCQUMzRSxhQUFhLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsYUFBYTthQUN0RCxDQUFDLENBQUM7WUFDSCxPQUFPO1FBQ1QsQ0FBQztRQUVELDJDQUEyQztRQUMzQyxJQUFJLENBQUMsZUFBZSxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDOytHQTdDVSxnQkFBZ0I7bUdBQWhCLGdCQUFnQixtR0F4QmpCOzs7Ozs7R0FNVCw2a0dBUFMsWUFBWSxvRkFBRSxPQUFPOzs0RkF5QnBCLGdCQUFnQjtrQkE1QjVCLFNBQVM7K0JBQ0UsYUFBYSxjQUNYLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxPQUFPLENBQUMsWUFDdEI7Ozs7OztHQU1UO21GQStCRCxLQUFLO3NCQURKLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElvblRleHQgfSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YnNjcmlwdGlvbiwgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbnRlbnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvY29udGVudC5zZXJ2aWNlJztcbmltcG9ydCB7IERpc3BsYXlNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtZGlzcGxheScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIElvblRleHRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpb24tdGV4dCBbY29sb3JdPVwicHJvcHMuY29sb3JcIj5cbiAgICAgIDxwIFtjbGFzc109XCJwcm9wcy5zaXplXCI+XG4gICAgICAgIHt7IGRpc3BsYXlDb250ZW50JCB8IGFzeW5jIH19XG4gICAgICA8L3A+XG4gICAgPC9pb24tdGV4dD5cbiAgYCxcbiAgc3R5bGVVcmxzOiBbJy4vZGlzcGxheS5jb21wb25lbnQuc2NzcyddLFxufSlcbi8qKlxuICogdmFsLWRpc3BsYXlcbiAqXG4gKiBEaXNwbGF5cyBwcm9taW5lbnQgdGV4dCBvciB0aXRsZXMgd2l0aCBjdXN0b20gY29sb3IgYW5kIHNpemUuXG4gKiBTdXBwb3J0cyBib3RoIHN0YXRpYyBhbmQgcmVhY3RpdmUgY29udGVudCBwYXR0ZXJucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogLy8gU3RhdGljIGNvbnRlbnRcbiAqIDx2YWwtZGlzcGxheSBbcHJvcHNdPVwieyBjb250ZW50OiAnVGl0bGUnLCBjb2xvcjogJ2RhcmsnLCBzaXplOiAnbGFyZ2UnIH1cIj48L3ZhbC1kaXNwbGF5PlxuICpcbiAqIC8vIFJlYWN0aXZlIGNvbnRlbnRcbiAqIDx2YWwtZGlzcGxheSBbcHJvcHNdPVwieyBjb250ZW50Q29uZmlnOiB7IGtleTogJ3dlbGNvbWUudGl0bGUnIH0sIGNvbG9yOiAncHJpbWFyeScsIHNpemU6ICd4bGFyZ2UnIH1cIj48L3ZhbC1kaXNwbGF5PlxuICpcbiAqIEBpbnB1dCBwcm9wczogRGlzcGxheU1ldGFkYXRhIC0gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGRpc3BsYXkgKGNvbnRlbnQvY29udGVudENvbmZpZywgY29sb3IsIHNpemUpXG4gKi9cbmV4cG9ydCBjbGFzcyBEaXNwbGF5Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBkaXNwbGF5Q29udGVudCQ6IE9ic2VydmFibGU8c3RyaW5nPjtcbiAgcHJpdmF0ZSBzdWJzY3JpcHRpb25zID0gbmV3IFN1YnNjcmlwdGlvbigpO1xuXG4gIC8qKlxuICAgKiBEaXNwbGF5IGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICAgKiBAdHlwZSB7RGlzcGxheU1ldGFkYXRhfVxuICAgKiBAcHJvcGVydHkgY29udGVudCAtIFN0YXRpYyB0ZXh0IHRvIGRpc3BsYXkgKHRha2VzIHByZWNlZGVuY2Ugb3ZlciBjb250ZW50Q29uZmlnKS5cbiAgICogQHByb3BlcnR5IGNvbnRlbnRDb25maWcgLSBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24uXG4gICAqIEBwcm9wZXJ0eSBjb2xvciAtIFRoZSB0ZXh0IGNvbG9yIChJb25pYyBjb2xvciBzdHJpbmcpLlxuICAgKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSB0ZXh0IHNpemUgKCdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJykuXG4gICAqL1xuICBASW5wdXQoKVxuICBwcm9wczogRGlzcGxheU1ldGFkYXRhO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY29udGVudFNlcnZpY2U6IENvbnRlbnRTZXJ2aWNlKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuaW5pdGlhbGl6ZURpc3BsYXlDb250ZW50KCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMudW5zdWJzY3JpYmUoKTtcbiAgfVxuXG4gIHByaXZhdGUgaW5pdGlhbGl6ZURpc3BsYXlDb250ZW50KCkge1xuICAgIC8vIFN0YXRpYyBjb250ZW50IHRha2VzIHByZWNlZGVuY2VcbiAgICBpZiAodGhpcy5wcm9wcy5jb250ZW50ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gb2YodGhpcy5wcm9wcy5jb250ZW50KTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBVc2UgcmVhY3RpdmUgY29udGVudCBpZiBjb25maWd1cmVkXG4gICAgaWYgKHRoaXMucHJvcHMuY29udGVudENvbmZpZykge1xuICAgICAgdGhpcy5kaXNwbGF5Q29udGVudCQgPSB0aGlzLmNvbnRlbnRTZXJ2aWNlLmZyb21Db250ZW50KHtcbiAgICAgICAgY2xhc3NOYW1lOiB0aGlzLnByb3BzLmNvbnRlbnRDb25maWcuY2xhc3NOYW1lIHx8ICdfZ2xvYmFsJyxcbiAgICAgICAga2V5OiB0aGlzLnByb3BzLmNvbnRlbnRDb25maWcua2V5LFxuICAgICAgICBmYWxsYmFjazogdGhpcy5wcm9wcy5jb250ZW50Q29uZmlnLmZhbGxiYWNrIHx8IHRoaXMucHJvcHMuY29udGVudENvbmZpZy5rZXksXG4gICAgICAgIGludGVycG9sYXRpb246IHRoaXMucHJvcHMuY29udGVudENvbmZpZy5pbnRlcnBvbGF0aW9uLFxuICAgICAgfSk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gTm8gY29udGVudCBjb25maWd1cmVkIC0gdXNlIGVtcHR5IHN0cmluZ1xuICAgIHRoaXMuZGlzcGxheUNvbnRlbnQkID0gb2YoJycpO1xuICB9XG59XG4iXX0=
74
+ /**
75
+ * Helper function to create reactive display props from content configuration.
76
+ * This provides a convenient way to create val-display props with reactive content.
77
+ *
78
+ * @param contentConfig - Content configuration for reactive content
79
+ * @param styleConfig - Optional style configuration (color and size)
80
+ * @returns DisplayMetadata with content properties set
81
+ *
82
+ * @example
83
+ * ```typescript
84
+ * // In component
85
+ * titleProps: DisplayMetadata = createDisplayProps({
86
+ * key: 'title',
87
+ * className: 'HeaderComponent',
88
+ * fallback: 'Default Title'
89
+ * }, {
90
+ * color: 'primary',
91
+ * size: 'large'
92
+ * });
93
+ * ```
94
+ *
95
+ * @example
96
+ * ```typescript
97
+ * // With interpolation
98
+ * greetingProps: DisplayMetadata = createDisplayProps({
99
+ * key: 'greeting',
100
+ * className: 'UserComponent',
101
+ * fallback: 'Hello!',
102
+ * interpolation: { name: 'John', count: 5 }
103
+ * }, {
104
+ * color: 'secondary',
105
+ * size: 'medium'
106
+ * });
107
+ * ```
108
+ *
109
+ * @example
110
+ * ```typescript
111
+ * // Using default style values
112
+ * simpleProps: DisplayMetadata = createDisplayProps({
113
+ * key: 'welcomeMessage',
114
+ * className: 'HomeComponent'
115
+ * }); // Will use default color: 'dark' and size: 'medium'
116
+ * ```
117
+ */
118
+ export function createDisplayProps(contentConfig, styleConfig = {}) {
119
+ return {
120
+ contentConfig: {
121
+ key: contentConfig.key,
122
+ className: contentConfig.className,
123
+ fallback: contentConfig.fallback,
124
+ interpolation: contentConfig.interpolation,
125
+ },
126
+ color: styleConfig.color || 'dark',
127
+ size: styleConfig.size || 'medium',
128
+ };
129
+ }
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"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL2Rpc3BsYXkvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yIH0gZnJvbSAnQGlvbmljL2NvcmUnO1xuXG4vKipcbiAqIFByb3BzIGZvciB2YWwtZGlzcGxheSBjb21wb25lbnQgd2l0aCByZWFjdGl2ZSBjb250ZW50IHN1cHBvcnQuXG4gKiBTdXBwb3J0cyBib3RoIHN0YXRpYyBhbmQgcmVhY3RpdmUgY29udGVudCBwYXR0ZXJucy5cbiAqXG4gKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSB0ZXh0IHNpemUgKCdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJykuXG4gKiBAcHJvcGVydHkgY29sb3IgLSBUaGUgdGV4dCBjb2xvciAoSW9uaWMgY29sb3Igc3RyaW5nKS5cbiAqIEBwcm9wZXJ0eSBjb250ZW50IC0gU3RhdGljIGNvbnRlbnQgdGV4dCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIGNvbnRlbnRDb25maWcpLlxuICogQHByb3BlcnR5IGNvbnRlbnRDb25maWcgLSBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzcGxheU1ldGFkYXRhIHtcbiAgc2l6ZTogJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJyB8ICd4bGFyZ2UnO1xuICBjb2xvcjogQ29sb3I7XG4gIC8qKiBTdGF0aWMgY29udGVudCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIGNvbnRlbnRDb25maWcpICovXG4gIGNvbnRlbnQ/OiBzdHJpbmc7XG4gIC8qKiBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24gKi9cbiAgY29udGVudENvbmZpZz86IHtcbiAgICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gICAga2V5OiBzdHJpbmc7XG4gICAgZmFsbGJhY2s/OiBzdHJpbmc7XG4gICAgaW50ZXJwb2xhdGlvbj86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIH07XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2F0b21zL2Rpc3BsYXkvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbG9yIH0gZnJvbSAnQGlvbmljL2NvcmUnO1xuXG4vKipcbiAqIFByb3BzIGZvciB2YWwtZGlzcGxheSBjb21wb25lbnQgd2l0aCByZWFjdGl2ZSBjb250ZW50IHN1cHBvcnQuXG4gKiBTdXBwb3J0cyBib3RoIHN0YXRpYyBhbmQgcmVhY3RpdmUgY29udGVudCBwYXR0ZXJucy5cbiAqXG4gKiBAcHJvcGVydHkgc2l6ZSAtIFRoZSB0ZXh0IHNpemUgKCdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZScgfCAneGxhcmdlJykuXG4gKiBAcHJvcGVydHkgY29sb3IgLSBUaGUgdGV4dCBjb2xvciAoSW9uaWMgY29sb3Igc3RyaW5nKS5cbiAqIEBwcm9wZXJ0eSBjb250ZW50IC0gU3RhdGljIGNvbnRlbnQgdGV4dCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIGNvbnRlbnRDb25maWcpLlxuICogQHByb3BlcnR5IGNvbnRlbnRDb25maWcgLSBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzcGxheU1ldGFkYXRhIHtcbiAgc2l6ZTogJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJyB8ICd4bGFyZ2UnO1xuICBjb2xvcjogQ29sb3I7XG4gIC8qKiBTdGF0aWMgY29udGVudCAodGFrZXMgcHJlY2VkZW5jZSBvdmVyIGNvbnRlbnRDb25maWcpICovXG4gIGNvbnRlbnQ/OiBzdHJpbmc7XG4gIC8qKiBSZWFjdGl2ZSBjb250ZW50IGNvbmZpZ3VyYXRpb24gKi9cbiAgY29udGVudENvbmZpZz86IHtcbiAgICBjbGFzc05hbWU/OiBzdHJpbmc7XG4gICAga2V5OiBzdHJpbmc7XG4gICAgZmFsbGJhY2s/OiBzdHJpbmc7XG4gICAgaW50ZXJwb2xhdGlvbj86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gIH07XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgcmVhY3RpdmUgY29udGVudCBpbiB2YWwtZGlzcGxheSBjb21wb25lbnQuXG4gKiBVc2UgdGhpcyBpbnRlcmZhY2Ugd2hlbiB5b3Ugb25seSBuZWVkIHRvIHNwZWNpZnkgY29udGVudC1yZWxhdGVkIHByb3BlcnRpZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGlzcGxheUNvbnRlbnRDb25maWcge1xuICBrZXk6IHN0cmluZztcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBmYWxsYmFjaz86IHN0cmluZztcbiAgaW50ZXJwb2xhdGlvbj86IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IG51bWJlcj47XG59XG4iXX0=
@@ -1813,6 +1813,62 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1813
1813
  }], ctorParameters: () => [{ type: ContentService }], propDecorators: { props: [{
1814
1814
  type: Input
1815
1815
  }] } });
1816
+ /**
1817
+ * Helper function to create reactive display props from content configuration.
1818
+ * This provides a convenient way to create val-display props with reactive content.
1819
+ *
1820
+ * @param contentConfig - Content configuration for reactive content
1821
+ * @param styleConfig - Optional style configuration (color and size)
1822
+ * @returns DisplayMetadata with content properties set
1823
+ *
1824
+ * @example
1825
+ * ```typescript
1826
+ * // In component
1827
+ * titleProps: DisplayMetadata = createDisplayProps({
1828
+ * key: 'title',
1829
+ * className: 'HeaderComponent',
1830
+ * fallback: 'Default Title'
1831
+ * }, {
1832
+ * color: 'primary',
1833
+ * size: 'large'
1834
+ * });
1835
+ * ```
1836
+ *
1837
+ * @example
1838
+ * ```typescript
1839
+ * // With interpolation
1840
+ * greetingProps: DisplayMetadata = createDisplayProps({
1841
+ * key: 'greeting',
1842
+ * className: 'UserComponent',
1843
+ * fallback: 'Hello!',
1844
+ * interpolation: { name: 'John', count: 5 }
1845
+ * }, {
1846
+ * color: 'secondary',
1847
+ * size: 'medium'
1848
+ * });
1849
+ * ```
1850
+ *
1851
+ * @example
1852
+ * ```typescript
1853
+ * // Using default style values
1854
+ * simpleProps: DisplayMetadata = createDisplayProps({
1855
+ * key: 'welcomeMessage',
1856
+ * className: 'HomeComponent'
1857
+ * }); // Will use default color: 'dark' and size: 'medium'
1858
+ * ```
1859
+ */
1860
+ function createDisplayProps(contentConfig, styleConfig = {}) {
1861
+ return {
1862
+ contentConfig: {
1863
+ key: contentConfig.key,
1864
+ className: contentConfig.className,
1865
+ fallback: contentConfig.fallback,
1866
+ interpolation: contentConfig.interpolation,
1867
+ },
1868
+ color: styleConfig.color || 'dark',
1869
+ size: styleConfig.size || 'medium',
1870
+ };
1871
+ }
1816
1872
 
1817
1873
  /**
1818
1874
  * val-divider
@@ -8150,5 +8206,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
8150
8206
  * Generated bundle index. Do not edit.
8151
8207
  */
8152
8208
 
8153
- export { ARTICLE_SPACING, ActionType, AlertBoxComponent, ArticleBuilder, ArticleComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentContentHelper, ComponentStates, ContentLoaderComponent, ContentService, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LANGUAGES, LangService, LanguageSelectorComponent, LayeredCardComponent, LayoutComponent, LinkComponent, LinkProcessorService, LinksCakeComponent, ListContentHelper, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PopoverSelectorComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProcessLinksPipe, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, content, createButtonProps, createComponentContentHelper, createContentHelper, createReactiveProps, createTextProps, createTitleProps, fromContent, fromContentWithInterpolation, fromMultipleContent, globalContentData, goToTop, interpolateContent, isAtEnd, maxLength, replaceSpecialChars, resolveColor, resolveInputDefaultValue, shouldUseReactiveContent };
8209
+ export { ARTICLE_SPACING, ActionType, AlertBoxComponent, ArticleBuilder, ArticleComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentContentHelper, ComponentStates, ContentLoaderComponent, ContentService, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LANGUAGES, LangService, LanguageSelectorComponent, LayeredCardComponent, LayoutComponent, LinkComponent, LinkProcessorService, LinksCakeComponent, ListContentHelper, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PopoverSelectorComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProcessLinksPipe, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, content, createButtonProps, createComponentContentHelper, createContentHelper, createDisplayProps, createReactiveProps, createTextProps, createTitleProps, fromContent, fromContentWithInterpolation, fromMultipleContent, globalContentData, goToTop, interpolateContent, isAtEnd, maxLength, replaceSpecialChars, resolveColor, resolveInputDefaultValue, shouldUseReactiveContent };
8154
8210
  //# sourceMappingURL=valtech-components.mjs.map