valtech-components 2.0.293 → 2.0.295
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.
- package/esm2022/lib/components/molecules/language-selector/language-selector.component.mjs +219 -0
- package/esm2022/lib/components/molecules/language-selector/types.mjs +2 -0
- package/esm2022/lib/components/molecules/popover-selector/popover-selector.component.mjs +170 -0
- package/esm2022/lib/components/molecules/popover-selector/types.mjs +2 -0
- package/esm2022/lib/examples/display-demo.component.mjs +53 -53
- package/esm2022/lib/examples/selector-examples.component.mjs +208 -0
- package/esm2022/lib/services/lang-provider/components/display-demo.mjs +86 -0
- package/esm2022/lib/services/lang-provider/content.mjs +1 -1
- package/esm2022/public-api.mjs +6 -1
- package/fesm2022/valtech-components.mjs +630 -55
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/molecules/language-selector/language-selector.component.d.ts +50 -0
- package/lib/components/molecules/language-selector/types.d.ts +52 -0
- package/lib/components/molecules/popover-selector/popover-selector.component.d.ts +29 -0
- package/lib/components/molecules/popover-selector/types.d.ts +69 -0
- package/lib/examples/display-demo.component.d.ts +3 -0
- package/lib/examples/selector-examples.component.d.ts +20 -0
- package/lib/services/lang-provider/components/display-demo.d.ts +3 -0
- package/package.json +1 -1
- package/public-api.d.ts +5 -0
|
@@ -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
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
200
|
+
key: 'sectionsStatic',
|
|
187
201
|
fallback: 'Ejemplos Estáticos',
|
|
188
202
|
});
|
|
189
203
|
this.reactiveSectionTitle$ = this.contentService.fromContent({
|
|
190
204
|
className: 'displayDemo',
|
|
191
|
-
key: '
|
|
205
|
+
key: 'sectionsReactive',
|
|
192
206
|
fallback: 'Ejemplos Reactivos',
|
|
193
207
|
});
|
|
194
208
|
this.mixedSectionTitle$ = this.contentService.fromContent({
|
|
195
209
|
className: 'displayDemo',
|
|
196
|
-
key: '
|
|
210
|
+
key: 'sectionsMixed',
|
|
197
211
|
fallback: 'Ejemplos Mixtos',
|
|
198
212
|
});
|
|
199
213
|
this.dynamicSectionTitle$ = this.contentService.fromContent({
|
|
200
214
|
className: 'displayDemo',
|
|
201
|
-
key: '
|
|
215
|
+
key: 'sectionsDynamic',
|
|
202
216
|
fallback: 'Ejemplos Dinámicos',
|
|
203
217
|
});
|
|
204
218
|
this.analysisTitle$ = this.contentService.fromContent({
|
|
205
219
|
className: 'displayDemo',
|
|
206
|
-
key: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
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: '
|
|
250
|
+
key: 'buttonsUpdateCounter',
|
|
237
251
|
fallback: 'Actualizar Contador',
|
|
238
252
|
});
|
|
239
253
|
this.currentLangLabel$ = this.contentService.fromContent({
|
|
240
254
|
className: 'displayDemo',
|
|
241
|
-
key: '
|
|
255
|
+
key: 'analysisCurrentLanguage',
|
|
242
256
|
fallback: 'Idioma actual',
|
|
243
257
|
});
|
|
244
258
|
this.availableLangsLabel$ = this.contentService.fromContent({
|
|
245
259
|
className: 'displayDemo',
|
|
246
|
-
key: '
|
|
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
|
-
<
|
|
290
|
-
<
|
|
291
|
-
|
|
292
|
-
|
|
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: "
|
|
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
|
-
<
|
|
416
|
-
<
|
|
417
|
-
|
|
418
|
-
|
|
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"]}
|