valtech-components 2.0.293 → 2.0.294

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,9 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { Component } from '@angular/core';
3
- import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonItem, IonLabel, IonSelect, IonSelectOption, } from '@ionic/angular/standalone';
3
+ import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle } from '@ionic/angular/standalone';
4
4
  import { map } from 'rxjs/operators';
5
5
  import { DisplayComponent } from '../components/atoms/display/display.component';
6
+ import { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../services/content.service";
8
9
  import * as i2 from "../services/lang-provider/lang-provider.service";
@@ -17,6 +18,19 @@ export class DisplayDemoComponent {
17
18
  this.langService = langService;
18
19
  // Contador para ejemplos dinámicos
19
20
  this.counter = 0;
21
+ // Configuración del selector de idioma
22
+ this.languageSelectorProps = {
23
+ showLabel: true,
24
+ labelConfig: {
25
+ className: '_global',
26
+ key: 'language',
27
+ fallback: 'Idioma',
28
+ },
29
+ showFlags: true,
30
+ color: 'primary',
31
+ size: 'default',
32
+ fill: 'outline',
33
+ };
20
34
  // Configuraciones de ejemplo - ESTÁTICAS
21
35
  this.smallStaticDisplay = {
22
36
  content: 'Texto pequeño estático',
@@ -68,7 +82,7 @@ export class DisplayDemoComponent {
68
82
  this.welcomeDisplay = {
69
83
  contentConfig: {
70
84
  className: 'displayDemo',
71
- key: 'welcome.title',
85
+ key: 'welcomeTitle',
72
86
  fallback: 'Bienvenido a la aplicación',
73
87
  },
74
88
  color: 'primary',
@@ -77,7 +91,7 @@ export class DisplayDemoComponent {
77
91
  this.descriptionDisplay = {
78
92
  contentConfig: {
79
93
  className: 'displayDemo',
80
- key: 'welcome.description',
94
+ key: 'welcomeDescription',
81
95
  fallback: 'Esta es una descripción de ejemplo',
82
96
  },
83
97
  color: 'medium',
@@ -86,7 +100,7 @@ export class DisplayDemoComponent {
86
100
  this.statusDisplay = {
87
101
  contentConfig: {
88
102
  className: 'displayDemo',
89
- key: 'status.online',
103
+ key: 'statusOnline',
90
104
  fallback: 'En línea',
91
105
  },
92
106
  color: 'success',
@@ -96,7 +110,7 @@ export class DisplayDemoComponent {
96
110
  this.userWelcomeDisplay = {
97
111
  contentConfig: {
98
112
  className: 'displayDemo',
99
- key: 'welcome.user',
113
+ key: 'welcomeUser',
100
114
  fallback: 'Hola, {{userName}}!',
101
115
  interpolation: {
102
116
  userName: 'Juan Pérez',
@@ -108,7 +122,7 @@ export class DisplayDemoComponent {
108
122
  this.counterDisplay = {
109
123
  contentConfig: {
110
124
  className: 'displayDemo',
111
- key: 'counter.current',
125
+ key: 'counterCurrent',
112
126
  fallback: 'Contador: {{count}}',
113
127
  interpolation: {
114
128
  count: this.counter,
@@ -145,7 +159,7 @@ export class DisplayDemoComponent {
145
159
  this.reactiveMixedDisplay = {
146
160
  contentConfig: {
147
161
  className: 'displayDemo',
148
- key: 'mixed.reactive',
162
+ key: 'mixedReactive',
149
163
  fallback: 'Este contenido sí cambia con el idioma',
150
164
  },
151
165
  color: 'primary',
@@ -155,7 +169,7 @@ export class DisplayDemoComponent {
155
169
  this.dynamicCounterDisplay = {
156
170
  contentConfig: {
157
171
  className: 'displayDemo',
158
- key: 'dynamic.counter',
172
+ key: 'dynamicContent',
159
173
  fallback: 'Clics: {{count}}',
160
174
  interpolation: {
161
175
  count: this.counter,
@@ -173,7 +187,7 @@ export class DisplayDemoComponent {
173
187
  // Contenido de la página
174
188
  this.demoTitle$ = this.contentService.fromContent({
175
189
  className: 'displayDemo',
176
- key: 'page.title',
190
+ key: 'pageTitle',
177
191
  fallback: 'Demostración del Componente Display',
178
192
  });
179
193
  this.languageLabel$ = this.contentService.fromContent({
@@ -183,67 +197,67 @@ export class DisplayDemoComponent {
183
197
  });
184
198
  this.staticSectionTitle$ = this.contentService.fromContent({
185
199
  className: 'displayDemo',
186
- key: 'sections.static',
200
+ key: 'sectionsStatic',
187
201
  fallback: 'Ejemplos Estáticos',
188
202
  });
189
203
  this.reactiveSectionTitle$ = this.contentService.fromContent({
190
204
  className: 'displayDemo',
191
- key: 'sections.reactive',
205
+ key: 'sectionsReactive',
192
206
  fallback: 'Ejemplos Reactivos',
193
207
  });
194
208
  this.mixedSectionTitle$ = this.contentService.fromContent({
195
209
  className: 'displayDemo',
196
- key: 'sections.mixed',
210
+ key: 'sectionsMixed',
197
211
  fallback: 'Ejemplos Mixtos',
198
212
  });
199
213
  this.dynamicSectionTitle$ = this.contentService.fromContent({
200
214
  className: 'displayDemo',
201
- key: 'sections.dynamic',
215
+ key: 'sectionsDynamic',
202
216
  fallback: 'Ejemplos Dinámicos',
203
217
  });
204
218
  this.analysisTitle$ = this.contentService.fromContent({
205
219
  className: 'displayDemo',
206
- key: 'sections.analysis',
220
+ key: 'sectionsAnalysis',
207
221
  fallback: 'Análisis de Idioma',
208
222
  });
209
223
  this.reactiveContentTitle$ = this.contentService.fromContent({
210
224
  className: 'displayDemo',
211
- key: 'subsections.reactiveContent',
225
+ key: 'subsectionsReactiveContent',
212
226
  fallback: 'Contenido reactivo básico:',
213
227
  });
214
228
  this.interpolationTitle$ = this.contentService.fromContent({
215
229
  className: 'displayDemo',
216
- key: 'subsections.interpolation',
230
+ key: 'subsectionsInterpolation',
217
231
  fallback: 'Contenido con interpolación:',
218
232
  });
219
233
  this.fallbackTitle$ = this.contentService.fromContent({
220
234
  className: 'displayDemo',
221
- key: 'subsections.fallback',
235
+ key: 'subsectionsFallback',
222
236
  fallback: 'Demostración de fallbacks:',
223
237
  });
224
238
  this.mixedContentTitle$ = this.contentService.fromContent({
225
239
  className: 'displayDemo',
226
- key: 'subsections.mixedContent',
240
+ key: 'subsectionsMixedContent',
227
241
  fallback: 'Contenido estático vs reactivo:',
228
242
  });
229
243
  this.dynamicContentTitle$ = this.contentService.fromContent({
230
244
  className: 'displayDemo',
231
- key: 'subsections.dynamicContent',
245
+ key: 'subsectionsDynamicContent',
232
246
  fallback: 'Contenido que se actualiza dinámicamente:',
233
247
  });
234
248
  this.updateButtonText$ = this.contentService.fromContent({
235
249
  className: 'displayDemo',
236
- key: 'buttons.updateCounter',
250
+ key: 'buttonsUpdateCounter',
237
251
  fallback: 'Actualizar Contador',
238
252
  });
239
253
  this.currentLangLabel$ = this.contentService.fromContent({
240
254
  className: 'displayDemo',
241
- key: 'analysis.currentLanguage',
255
+ key: 'analysisCurrentLanguage',
242
256
  fallback: 'Idioma actual',
243
257
  });
244
258
  this.availableLangsLabel$ = this.contentService.fromContent({
245
259
  className: 'displayDemo',
246
- key: 'analysis.availableLanguages',
260
+ key: 'analysisAvailableLanguages',
247
261
  fallback: 'Idiomas disponibles',
248
262
  });
249
263
  }
@@ -254,6 +268,11 @@ export class DisplayDemoComponent {
254
268
  changeLanguage(language) {
255
269
  this.langService.setLang(language);
256
270
  }
271
+ onLanguageChange(language) {
272
+ console.log('Language changed to:', language);
273
+ // El language selector ya maneja el cambio de idioma internamente
274
+ // pero podemos agregar lógica adicional aquí si es necesario
275
+ }
257
276
  updateCounter() {
258
277
  this.counter++;
259
278
  // Actualizar los displays que usan el contador
@@ -286,18 +305,10 @@ export class DisplayDemoComponent {
286
305
 
287
306
  <ion-card-content>
288
307
  <!-- Selector de idioma -->
289
- <ion-item>
290
- <ion-label>{{ languageLabel$ | async }}</ion-label>
291
- <ion-select
292
- interface="popover"
293
- [value]="currentLanguage$ | async"
294
- (ionChange)="changeLanguage($event.detail.value)"
295
- >
296
- <ion-select-option *ngFor="let lang of availableLanguages$ | async" [value]="lang">
297
- {{ lang | uppercase }}
298
- </ion-select-option>
299
- </ion-select>
300
- </ion-item>
308
+ <div class="language-selector-container">
309
+ <val-language-selector [props]="languageSelectorProps" (languageChange)="onLanguageChange($event)">
310
+ </val-language-selector>
311
+ </div>
301
312
 
302
313
  <!-- Ejemplos estáticos -->
303
314
  <div class="section">
@@ -387,7 +398,7 @@ export class DisplayDemoComponent {
387
398
  </ion-card-content>
388
399
  </ion-card>
389
400
  </div>
390
- `, isInline: true, styles: [".display-demo{padding:16px}.section{margin:24px 0;border-bottom:1px solid var(--ion-color-light);padding-bottom:16px}.example-group{margin:16px 0;padding:12px;background:var(--ion-color-light);border-radius:8px}.example-group h4{margin:0 0 12px;color:var(--ion-color-medium)}.mixed-examples{display:flex;flex-direction:column;gap:8px}.analysis-info{background:var(--ion-color-step-50);padding:16px;border-radius:8px;margin-top:16px}val-display{display:block;margin:8px 0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: IonSelect, selector: "ion-select", inputs: ["cancelText", "color", "compareWith", "disabled", "expandedIcon", "fill", "interface", "interfaceOptions", "justify", "label", "labelPlacement", "mode", "multiple", "name", "okText", "placeholder", "selectedText", "shape", "toggleIcon", "value"] }, { kind: "component", type: IonSelectOption, selector: "ion-select-option", inputs: ["disabled", "value"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: DisplayComponent, selector: "val-display", inputs: ["props"] }] }); }
401
+ `, isInline: true, styles: [".display-demo{padding:16px}.language-selector-container{margin:16px 0;padding:12px;background:var(--ion-color-step-50);border-radius:8px}.section{margin:24px 0;border-bottom:1px solid var(--ion-color-light);padding-bottom:16px}.example-group{margin:16px 0;padding:12px;background:var(--ion-color-light);border-radius:8px}.example-group h4{margin:0 0 12px;color:var(--ion-color-medium)}.mixed-examples{display:flex;flex-direction:column;gap:8px}.analysis-info{background:var(--ion-color-step-50);padding:16px;border-radius:8px;margin-top:16px}val-display{display:block;margin:8px 0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: DisplayComponent, selector: "val-display", inputs: ["props"] }, { kind: "component", type: LanguageSelectorComponent, selector: "val-language-selector", inputs: ["props"], outputs: ["languageChange"] }] }); }
391
402
  }
392
403
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayDemoComponent, decorators: [{
393
404
  type: Component,
@@ -397,12 +408,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
397
408
  IonCardContent,
398
409
  IonCardHeader,
399
410
  IonCardTitle,
400
- IonSelect,
401
- IonSelectOption,
402
- IonItem,
403
- IonLabel,
404
411
  IonButton,
405
412
  DisplayComponent,
413
+ LanguageSelectorComponent,
406
414
  ], template: `
407
415
  <div class="display-demo">
408
416
  <ion-card>
@@ -412,18 +420,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
412
420
 
413
421
  <ion-card-content>
414
422
  <!-- Selector de idioma -->
415
- <ion-item>
416
- <ion-label>{{ languageLabel$ | async }}</ion-label>
417
- <ion-select
418
- interface="popover"
419
- [value]="currentLanguage$ | async"
420
- (ionChange)="changeLanguage($event.detail.value)"
421
- >
422
- <ion-select-option *ngFor="let lang of availableLanguages$ | async" [value]="lang">
423
- {{ lang | uppercase }}
424
- </ion-select-option>
425
- </ion-select>
426
- </ion-item>
423
+ <div class="language-selector-container">
424
+ <val-language-selector [props]="languageSelectorProps" (languageChange)="onLanguageChange($event)">
425
+ </val-language-selector>
426
+ </div>
427
427
 
428
428
  <!-- Ejemplos estáticos -->
429
429
  <div class="section">
@@ -513,6 +513,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
513
513
  </ion-card-content>
514
514
  </ion-card>
515
515
  </div>
516
- `, styles: [".display-demo{padding:16px}.section{margin:24px 0;border-bottom:1px solid var(--ion-color-light);padding-bottom:16px}.example-group{margin:16px 0;padding:12px;background:var(--ion-color-light);border-radius:8px}.example-group h4{margin:0 0 12px;color:var(--ion-color-medium)}.mixed-examples{display:flex;flex-direction:column;gap:8px}.analysis-info{background:var(--ion-color-step-50);padding:16px;border-radius:8px;margin-top:16px}val-display{display:block;margin:8px 0}\n"] }]
516
+ `, styles: [".display-demo{padding:16px}.language-selector-container{margin:16px 0;padding:12px;background:var(--ion-color-step-50);border-radius:8px}.section{margin:24px 0;border-bottom:1px solid var(--ion-color-light);padding-bottom:16px}.example-group{margin:16px 0;padding:12px;background:var(--ion-color-light);border-radius:8px}.example-group h4{margin:0 0 12px;color:var(--ion-color-medium)}.mixed-examples{display:flex;flex-direction:column;gap:8px}.analysis-info{background:var(--ion-color-step-50);padding:16px;border-radius:8px;margin-top:16px}val-display{display:block;margin:8px 0}\n"] }]
517
517
  }], ctorParameters: () => [{ type: i1.ContentService }, { type: i2.LangService }] });
518
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-demo.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/display-demo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, OnInit } from '@angular/core';\nimport {\n  IonButton,\n  IonCard,\n  IonCardContent,\n  IonCardHeader,\n  IonCardTitle,\n  IonItem,\n  IonLabel,\n  IonSelect,\n  IonSelectOption,\n} from '@ionic/angular/standalone';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { DisplayComponent } from '../components/atoms/display/display.component';\nimport { DisplayMetadata } from '../components/atoms/display/types';\nimport { ContentService } from '../services/content.service';\nimport { LangService } from '../services/lang-provider/lang-provider.service';\n\n/**\n * Componente de demostración para val-display con contenido reactivo.\n * Muestra diferentes patrones de uso y casos de ejemplo.\n */\n@Component({\n  selector: 'val-display-demo',\n  standalone: true,\n  imports: [\n    CommonModule,\n    IonCard,\n    IonCardContent,\n    IonCardHeader,\n    IonCardTitle,\n    IonSelect,\n    IonSelectOption,\n    IonItem,\n    IonLabel,\n    IonButton,\n    DisplayComponent,\n  ],\n  template: `\n    <div class=\"display-demo\">\n      <ion-card>\n        <ion-card-header>\n          <ion-card-title>{{ demoTitle$ | async }}</ion-card-title>\n        </ion-card-header>\n\n        <ion-card-content>\n          <!-- Selector de idioma -->\n          <ion-item>\n            <ion-label>{{ languageLabel$ | async }}</ion-label>\n            <ion-select\n              interface=\"popover\"\n              [value]=\"currentLanguage$ | async\"\n              (ionChange)=\"changeLanguage($event.detail.value)\"\n            >\n              <ion-select-option *ngFor=\"let lang of availableLanguages$ | async\" [value]=\"lang\">\n                {{ lang | uppercase }}\n              </ion-select-option>\n            </ion-select>\n          </ion-item>\n\n          <!-- Ejemplos estáticos -->\n          <div class=\"section\">\n            <h3>{{ staticSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>Diferentes tamaños:</h4>\n              <val-display [props]=\"smallStaticDisplay\"></val-display>\n              <val-display [props]=\"mediumStaticDisplay\"></val-display>\n              <val-display [props]=\"largeStaticDisplay\"></val-display>\n              <val-display [props]=\"xlargeStaticDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>Diferentes colores:</h4>\n              <val-display [props]=\"primaryDisplay\"></val-display>\n              <val-display [props]=\"secondaryDisplay\"></val-display>\n              <val-display [props]=\"successDisplay\"></val-display>\n              <val-display [props]=\"warningDisplay\"></val-display>\n              <val-display [props]=\"dangerDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Ejemplos reactivos -->\n          <div class=\"section\">\n            <h3>{{ reactiveSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ reactiveContentTitle$ | async }}</h4>\n              <val-display [props]=\"welcomeDisplay\"></val-display>\n              <val-display [props]=\"descriptionDisplay\"></val-display>\n              <val-display [props]=\"statusDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>{{ interpolationTitle$ | async }}</h4>\n              <val-display [props]=\"userWelcomeDisplay\"></val-display>\n              <val-display [props]=\"counterDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>{{ fallbackTitle$ | async }}</h4>\n              <val-display [props]=\"missingKeyDisplay\"></val-display>\n              <val-display [props]=\"noFallbackDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Ejemplos mixtos -->\n          <div class=\"section\">\n            <h3>{{ mixedSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ mixedContentTitle$ | async }}</h4>\n              <div class=\"mixed-examples\">\n                <val-display [props]=\"staticMixedDisplay\"></val-display>\n                <val-display [props]=\"reactiveMixedDisplay\"></val-display>\n              </div>\n            </div>\n          </div>\n\n          <!-- Ejemplos dinámicos -->\n          <div class=\"section\">\n            <h3>{{ dynamicSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ dynamicContentTitle$ | async }}</h4>\n              <ion-button (click)=\"updateCounter()\" color=\"primary\">\n                {{ updateButtonText$ | async }}\n              </ion-button>\n              <val-display [props]=\"dynamicCounterDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Análisis de contenido -->\n          <div class=\"section\">\n            <h3>{{ analysisTitle$ | async }}</h3>\n            <div class=\"analysis-info\">\n              <p>\n                <strong>{{ currentLangLabel$ | async }}:</strong> {{ currentLanguage$ | async | uppercase }}\n              </p>\n              <p>\n                <strong>{{ availableLangsLabel$ | async }}:</strong>\n                {{ (availableLanguages$ | async)?.join(', ') | uppercase }}\n              </p>\n            </div>\n          </div>\n        </ion-card-content>\n      </ion-card>\n    </div>\n  `,\n  styles: [\n    `\n      .display-demo {\n        padding: 16px;\n      }\n      .section {\n        margin: 24px 0;\n        border-bottom: 1px solid var(--ion-color-light);\n        padding-bottom: 16px;\n      }\n      .example-group {\n        margin: 16px 0;\n        padding: 12px;\n        background: var(--ion-color-light);\n        border-radius: 8px;\n      }\n      .example-group h4 {\n        margin: 0 0 12px 0;\n        color: var(--ion-color-medium);\n      }\n      .mixed-examples {\n        display: flex;\n        flex-direction: column;\n        gap: 8px;\n      }\n      .analysis-info {\n        background: var(--ion-color-step-50);\n        padding: 16px;\n        border-radius: 8px;\n        margin-top: 16px;\n      }\n      val-display {\n        display: block;\n        margin: 8px 0;\n      }\n    `,\n  ],\n})\nexport class DisplayDemoComponent implements OnInit {\n  // Observables para contenido reactivo de la página\n  demoTitle$: Observable<string>;\n  languageLabel$: Observable<string>;\n  staticSectionTitle$: Observable<string>;\n  reactiveSectionTitle$: Observable<string>;\n  mixedSectionTitle$: Observable<string>;\n  dynamicSectionTitle$: Observable<string>;\n  analysisTitle$: Observable<string>;\n  reactiveContentTitle$: Observable<string>;\n  interpolationTitle$: Observable<string>;\n  fallbackTitle$: Observable<string>;\n  mixedContentTitle$: Observable<string>;\n  dynamicContentTitle$: Observable<string>;\n  updateButtonText$: Observable<string>;\n  currentLangLabel$: Observable<string>;\n  availableLangsLabel$: Observable<string>;\n\n  // Estado del idioma\n  currentLanguage$: Observable<string>;\n  availableLanguages$: Observable<string[]>;\n\n  // Contador para ejemplos dinámicos\n  private counter = 0;\n\n  // Configuraciones de ejemplo - ESTÁTICAS\n  smallStaticDisplay: DisplayMetadata = {\n    content: 'Texto pequeño estático',\n    color: 'dark',\n    size: 'small',\n  };\n\n  mediumStaticDisplay: DisplayMetadata = {\n    content: 'Texto mediano estático',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  largeStaticDisplay: DisplayMetadata = {\n    content: 'Texto grande estático',\n    color: 'dark',\n    size: 'large',\n  };\n\n  xlargeStaticDisplay: DisplayMetadata = {\n    content: 'Texto extra grande estático',\n    color: 'dark',\n    size: 'xlarge',\n  };\n\n  // Ejemplos de colores estáticos\n  primaryDisplay: DisplayMetadata = {\n    content: 'Texto primario',\n    color: 'primary',\n    size: 'medium',\n  };\n\n  secondaryDisplay: DisplayMetadata = {\n    content: 'Texto secundario',\n    color: 'secondary',\n    size: 'medium',\n  };\n\n  successDisplay: DisplayMetadata = {\n    content: 'Texto de éxito',\n    color: 'success',\n    size: 'medium',\n  };\n\n  warningDisplay: DisplayMetadata = {\n    content: 'Texto de advertencia',\n    color: 'warning',\n    size: 'medium',\n  };\n\n  dangerDisplay: DisplayMetadata = {\n    content: 'Texto de peligro',\n    color: 'danger',\n    size: 'medium',\n  };\n\n  // Configuraciones de ejemplo - REACTIVAS\n  welcomeDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcome.title',\n      fallback: 'Bienvenido a la aplicación',\n    },\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  descriptionDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcome.description',\n      fallback: 'Esta es una descripción de ejemplo',\n    },\n    color: 'medium',\n    size: 'medium',\n  };\n\n  statusDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'status.online',\n      fallback: 'En línea',\n    },\n    color: 'success',\n    size: 'small',\n  };\n\n  // Ejemplos con interpolación\n  userWelcomeDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcome.user',\n      fallback: 'Hola, {{userName}}!',\n      interpolation: {\n        userName: 'Juan Pérez',\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  counterDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'counter.current',\n      fallback: 'Contador: {{count}}',\n      interpolation: {\n        count: this.counter,\n      },\n    },\n    color: 'secondary',\n    size: 'medium',\n  };\n\n  // Ejemplos con claves faltantes para demostrar fallbacks\n  missingKeyDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'this.key.does.not.exist',\n      fallback: 'Esta clave no existe, pero tengo fallback',\n    },\n    color: 'warning',\n    size: 'medium',\n  };\n\n  noFallbackDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'another.missing.key',\n      // Sin fallback - usará la clave como fallback\n    },\n    color: 'danger',\n    size: 'small',\n  };\n\n  // Ejemplos mixtos\n  staticMixedDisplay: DisplayMetadata = {\n    content: 'Este es contenido estático (no cambia con el idioma)',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  reactiveMixedDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'mixed.reactive',\n      fallback: 'Este contenido sí cambia con el idioma',\n    },\n    color: 'primary',\n    size: 'medium',\n  };\n\n  // Ejemplo dinámico que se actualiza\n  dynamicCounterDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'dynamic.counter',\n      fallback: 'Clics: {{count}}',\n      interpolation: {\n        count: this.counter,\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  constructor(\n    private contentService: ContentService,\n    private langService: LangService\n  ) {}\n\n  ngOnInit() {\n    this.initializeContent();\n    this.initializeLanguageState();\n  }\n\n  private initializeContent() {\n    // Contenido de la página\n    this.demoTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'page.title',\n      fallback: 'Demostración del Componente Display',\n    });\n\n    this.languageLabel$ = this.contentService.fromContent({\n      className: '_global',\n      key: 'language',\n      fallback: 'Idioma',\n    });\n\n    this.staticSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sections.static',\n      fallback: 'Ejemplos Estáticos',\n    });\n\n    this.reactiveSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sections.reactive',\n      fallback: 'Ejemplos Reactivos',\n    });\n\n    this.mixedSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sections.mixed',\n      fallback: 'Ejemplos Mixtos',\n    });\n\n    this.dynamicSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sections.dynamic',\n      fallback: 'Ejemplos Dinámicos',\n    });\n\n    this.analysisTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sections.analysis',\n      fallback: 'Análisis de Idioma',\n    });\n\n    this.reactiveContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsections.reactiveContent',\n      fallback: 'Contenido reactivo básico:',\n    });\n\n    this.interpolationTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsections.interpolation',\n      fallback: 'Contenido con interpolación:',\n    });\n\n    this.fallbackTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsections.fallback',\n      fallback: 'Demostración de fallbacks:',\n    });\n\n    this.mixedContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsections.mixedContent',\n      fallback: 'Contenido estático vs reactivo:',\n    });\n\n    this.dynamicContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsections.dynamicContent',\n      fallback: 'Contenido que se actualiza dinámicamente:',\n    });\n\n    this.updateButtonText$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'buttons.updateCounter',\n      fallback: 'Actualizar Contador',\n    });\n\n    this.currentLangLabel$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'analysis.currentLanguage',\n      fallback: 'Idioma actual',\n    });\n\n    this.availableLangsLabel$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'analysis.availableLanguages',\n      fallback: 'Idiomas disponibles',\n    });\n  }\n\n  private initializeLanguageState() {\n    this.currentLanguage$ = this.langService.currentLang$;\n    this.availableLanguages$ = this.langService.currentLang$.pipe(map(() => this.langService.availableLangs));\n  }\n\n  changeLanguage(language: string) {\n    this.langService.setLang(language);\n  }\n\n  updateCounter() {\n    this.counter++;\n\n    // Actualizar los displays que usan el contador\n    this.counterDisplay = {\n      ...this.counterDisplay,\n      contentConfig: {\n        ...this.counterDisplay.contentConfig!,\n        interpolation: {\n          count: this.counter,\n        },\n      },\n    };\n\n    this.dynamicCounterDisplay = {\n      ...this.dynamicCounterDisplay,\n      contentConfig: {\n        ...this.dynamicCounterDisplay.contentConfig!,\n        interpolation: {\n          count: this.counter,\n        },\n      },\n    };\n  }\n}\n"]}
518
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-demo.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/display-demo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, OnInit } from '@angular/core';\nimport { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle } from '@ionic/angular/standalone';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { DisplayComponent } from '../components/atoms/display/display.component';\nimport { DisplayMetadata } from '../components/atoms/display/types';\nimport { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';\nimport { LanguageSelectorMetadata } from '../components/molecules/language-selector/types';\nimport { ContentService } from '../services/content.service';\nimport { LangService } from '../services/lang-provider/lang-provider.service';\n\n/**\n * Componente de demostración para val-display con contenido reactivo.\n * Muestra diferentes patrones de uso y casos de ejemplo.\n */\n@Component({\n  selector: 'val-display-demo',\n  standalone: true,\n  imports: [\n    CommonModule,\n    IonCard,\n    IonCardContent,\n    IonCardHeader,\n    IonCardTitle,\n    IonButton,\n    DisplayComponent,\n    LanguageSelectorComponent,\n  ],\n  template: `\n    <div class=\"display-demo\">\n      <ion-card>\n        <ion-card-header>\n          <ion-card-title>{{ demoTitle$ | async }}</ion-card-title>\n        </ion-card-header>\n\n        <ion-card-content>\n          <!-- Selector de idioma -->\n          <div class=\"language-selector-container\">\n            <val-language-selector [props]=\"languageSelectorProps\" (languageChange)=\"onLanguageChange($event)\">\n            </val-language-selector>\n          </div>\n\n          <!-- Ejemplos estáticos -->\n          <div class=\"section\">\n            <h3>{{ staticSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>Diferentes tamaños:</h4>\n              <val-display [props]=\"smallStaticDisplay\"></val-display>\n              <val-display [props]=\"mediumStaticDisplay\"></val-display>\n              <val-display [props]=\"largeStaticDisplay\"></val-display>\n              <val-display [props]=\"xlargeStaticDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>Diferentes colores:</h4>\n              <val-display [props]=\"primaryDisplay\"></val-display>\n              <val-display [props]=\"secondaryDisplay\"></val-display>\n              <val-display [props]=\"successDisplay\"></val-display>\n              <val-display [props]=\"warningDisplay\"></val-display>\n              <val-display [props]=\"dangerDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Ejemplos reactivos -->\n          <div class=\"section\">\n            <h3>{{ reactiveSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ reactiveContentTitle$ | async }}</h4>\n              <val-display [props]=\"welcomeDisplay\"></val-display>\n              <val-display [props]=\"descriptionDisplay\"></val-display>\n              <val-display [props]=\"statusDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>{{ interpolationTitle$ | async }}</h4>\n              <val-display [props]=\"userWelcomeDisplay\"></val-display>\n              <val-display [props]=\"counterDisplay\"></val-display>\n            </div>\n\n            <div class=\"example-group\">\n              <h4>{{ fallbackTitle$ | async }}</h4>\n              <val-display [props]=\"missingKeyDisplay\"></val-display>\n              <val-display [props]=\"noFallbackDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Ejemplos mixtos -->\n          <div class=\"section\">\n            <h3>{{ mixedSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ mixedContentTitle$ | async }}</h4>\n              <div class=\"mixed-examples\">\n                <val-display [props]=\"staticMixedDisplay\"></val-display>\n                <val-display [props]=\"reactiveMixedDisplay\"></val-display>\n              </div>\n            </div>\n          </div>\n\n          <!-- Ejemplos dinámicos -->\n          <div class=\"section\">\n            <h3>{{ dynamicSectionTitle$ | async }}</h3>\n\n            <div class=\"example-group\">\n              <h4>{{ dynamicContentTitle$ | async }}</h4>\n              <ion-button (click)=\"updateCounter()\" color=\"primary\">\n                {{ updateButtonText$ | async }}\n              </ion-button>\n              <val-display [props]=\"dynamicCounterDisplay\"></val-display>\n            </div>\n          </div>\n\n          <!-- Análisis de contenido -->\n          <div class=\"section\">\n            <h3>{{ analysisTitle$ | async }}</h3>\n            <div class=\"analysis-info\">\n              <p>\n                <strong>{{ currentLangLabel$ | async }}:</strong> {{ currentLanguage$ | async | uppercase }}\n              </p>\n              <p>\n                <strong>{{ availableLangsLabel$ | async }}:</strong>\n                {{ (availableLanguages$ | async)?.join(', ') | uppercase }}\n              </p>\n            </div>\n          </div>\n        </ion-card-content>\n      </ion-card>\n    </div>\n  `,\n  styles: [\n    `\n      .display-demo {\n        padding: 16px;\n      }\n      .language-selector-container {\n        margin: 16px 0;\n        padding: 12px;\n        background: var(--ion-color-step-50);\n        border-radius: 8px;\n      }\n      .section {\n        margin: 24px 0;\n        border-bottom: 1px solid var(--ion-color-light);\n        padding-bottom: 16px;\n      }\n      .example-group {\n        margin: 16px 0;\n        padding: 12px;\n        background: var(--ion-color-light);\n        border-radius: 8px;\n      }\n      .example-group h4 {\n        margin: 0 0 12px 0;\n        color: var(--ion-color-medium);\n      }\n      .mixed-examples {\n        display: flex;\n        flex-direction: column;\n        gap: 8px;\n      }\n      .analysis-info {\n        background: var(--ion-color-step-50);\n        padding: 16px;\n        border-radius: 8px;\n        margin-top: 16px;\n      }\n      val-display {\n        display: block;\n        margin: 8px 0;\n      }\n    `,\n  ],\n})\nexport class DisplayDemoComponent implements OnInit {\n  // Observables para contenido reactivo de la página\n  demoTitle$: Observable<string>;\n  languageLabel$: Observable<string>;\n  staticSectionTitle$: Observable<string>;\n  reactiveSectionTitle$: Observable<string>;\n  mixedSectionTitle$: Observable<string>;\n  dynamicSectionTitle$: Observable<string>;\n  analysisTitle$: Observable<string>;\n  reactiveContentTitle$: Observable<string>;\n  interpolationTitle$: Observable<string>;\n  fallbackTitle$: Observable<string>;\n  mixedContentTitle$: Observable<string>;\n  dynamicContentTitle$: Observable<string>;\n  updateButtonText$: Observable<string>;\n  currentLangLabel$: Observable<string>;\n  availableLangsLabel$: Observable<string>;\n\n  // Estado del idioma\n  currentLanguage$: Observable<string>;\n  availableLanguages$: Observable<string[]>;\n\n  // Contador para ejemplos dinámicos\n  private counter = 0;\n\n  // Configuración del selector de idioma\n  languageSelectorProps: LanguageSelectorMetadata = {\n    showLabel: true,\n    labelConfig: {\n      className: '_global',\n      key: 'language',\n      fallback: 'Idioma',\n    },\n    showFlags: true,\n    color: 'primary',\n    size: 'default',\n    fill: 'outline',\n  };\n\n  // Configuraciones de ejemplo - ESTÁTICAS\n  smallStaticDisplay: DisplayMetadata = {\n    content: 'Texto pequeño estático',\n    color: 'dark',\n    size: 'small',\n  };\n\n  mediumStaticDisplay: DisplayMetadata = {\n    content: 'Texto mediano estático',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  largeStaticDisplay: DisplayMetadata = {\n    content: 'Texto grande estático',\n    color: 'dark',\n    size: 'large',\n  };\n\n  xlargeStaticDisplay: DisplayMetadata = {\n    content: 'Texto extra grande estático',\n    color: 'dark',\n    size: 'xlarge',\n  };\n\n  // Ejemplos de colores estáticos\n  primaryDisplay: DisplayMetadata = {\n    content: 'Texto primario',\n    color: 'primary',\n    size: 'medium',\n  };\n\n  secondaryDisplay: DisplayMetadata = {\n    content: 'Texto secundario',\n    color: 'secondary',\n    size: 'medium',\n  };\n\n  successDisplay: DisplayMetadata = {\n    content: 'Texto de éxito',\n    color: 'success',\n    size: 'medium',\n  };\n\n  warningDisplay: DisplayMetadata = {\n    content: 'Texto de advertencia',\n    color: 'warning',\n    size: 'medium',\n  };\n\n  dangerDisplay: DisplayMetadata = {\n    content: 'Texto de peligro',\n    color: 'danger',\n    size: 'medium',\n  };\n\n  // Configuraciones de ejemplo - REACTIVAS\n  welcomeDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcomeTitle',\n      fallback: 'Bienvenido a la aplicación',\n    },\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  descriptionDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcomeDescription',\n      fallback: 'Esta es una descripción de ejemplo',\n    },\n    color: 'medium',\n    size: 'medium',\n  };\n\n  statusDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'statusOnline',\n      fallback: 'En línea',\n    },\n    color: 'success',\n    size: 'small',\n  };\n\n  // Ejemplos con interpolación\n  userWelcomeDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'welcomeUser',\n      fallback: 'Hola, {{userName}}!',\n      interpolation: {\n        userName: 'Juan Pérez',\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  counterDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'counterCurrent',\n      fallback: 'Contador: {{count}}',\n      interpolation: {\n        count: this.counter,\n      },\n    },\n    color: 'secondary',\n    size: 'medium',\n  };\n\n  // Ejemplos con claves faltantes para demostrar fallbacks\n  missingKeyDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'this.key.does.not.exist',\n      fallback: 'Esta clave no existe, pero tengo fallback',\n    },\n    color: 'warning',\n    size: 'medium',\n  };\n\n  noFallbackDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'another.missing.key',\n      // Sin fallback - usará la clave como fallback\n    },\n    color: 'danger',\n    size: 'small',\n  };\n\n  // Ejemplos mixtos\n  staticMixedDisplay: DisplayMetadata = {\n    content: 'Este es contenido estático (no cambia con el idioma)',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  reactiveMixedDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'mixedReactive',\n      fallback: 'Este contenido sí cambia con el idioma',\n    },\n    color: 'primary',\n    size: 'medium',\n  };\n\n  // Ejemplo dinámico que se actualiza\n  dynamicCounterDisplay: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayDemo',\n      key: 'dynamicContent',\n      fallback: 'Clics: {{count}}',\n      interpolation: {\n        count: this.counter,\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  constructor(\n    private contentService: ContentService,\n    private langService: LangService\n  ) {}\n\n  ngOnInit() {\n    this.initializeContent();\n    this.initializeLanguageState();\n  }\n\n  private initializeContent() {\n    // Contenido de la página\n    this.demoTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'pageTitle',\n      fallback: 'Demostración del Componente Display',\n    });\n\n    this.languageLabel$ = this.contentService.fromContent({\n      className: '_global',\n      key: 'language',\n      fallback: 'Idioma',\n    });\n\n    this.staticSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sectionsStatic',\n      fallback: 'Ejemplos Estáticos',\n    });\n\n    this.reactiveSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sectionsReactive',\n      fallback: 'Ejemplos Reactivos',\n    });\n\n    this.mixedSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sectionsMixed',\n      fallback: 'Ejemplos Mixtos',\n    });\n\n    this.dynamicSectionTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sectionsDynamic',\n      fallback: 'Ejemplos Dinámicos',\n    });\n\n    this.analysisTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'sectionsAnalysis',\n      fallback: 'Análisis de Idioma',\n    });\n\n    this.reactiveContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsectionsReactiveContent',\n      fallback: 'Contenido reactivo básico:',\n    });\n\n    this.interpolationTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsectionsInterpolation',\n      fallback: 'Contenido con interpolación:',\n    });\n\n    this.fallbackTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsectionsFallback',\n      fallback: 'Demostración de fallbacks:',\n    });\n\n    this.mixedContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsectionsMixedContent',\n      fallback: 'Contenido estático vs reactivo:',\n    });\n\n    this.dynamicContentTitle$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'subsectionsDynamicContent',\n      fallback: 'Contenido que se actualiza dinámicamente:',\n    });\n\n    this.updateButtonText$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'buttonsUpdateCounter',\n      fallback: 'Actualizar Contador',\n    });\n\n    this.currentLangLabel$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'analysisCurrentLanguage',\n      fallback: 'Idioma actual',\n    });\n\n    this.availableLangsLabel$ = this.contentService.fromContent({\n      className: 'displayDemo',\n      key: 'analysisAvailableLanguages',\n      fallback: 'Idiomas disponibles',\n    });\n  }\n\n  private initializeLanguageState() {\n    this.currentLanguage$ = this.langService.currentLang$;\n    this.availableLanguages$ = this.langService.currentLang$.pipe(map(() => this.langService.availableLangs));\n  }\n\n  changeLanguage(language: string) {\n    this.langService.setLang(language);\n  }\n\n  onLanguageChange(language: string) {\n    console.log('Language changed to:', language);\n    // El language selector ya maneja el cambio de idioma internamente\n    // pero podemos agregar lógica adicional aquí si es necesario\n  }\n\n  updateCounter() {\n    this.counter++;\n\n    // Actualizar los displays que usan el contador\n    this.counterDisplay = {\n      ...this.counterDisplay,\n      contentConfig: {\n        ...this.counterDisplay.contentConfig!,\n        interpolation: {\n          count: this.counter,\n        },\n      },\n    };\n\n    this.dynamicCounterDisplay = {\n      ...this.dynamicCounterDisplay,\n      contentConfig: {\n        ...this.dynamicCounterDisplay.contentConfig!,\n        interpolation: {\n          count: this.counter,\n        },\n      },\n    };\n  }\n}\n"]}