valtech-components 2.0.302 → 2.0.305

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/esm2022/lib/components/atoms/button/button.component.mjs +103 -23
  2. package/esm2022/lib/components/types.mjs +1 -1
  3. package/esm2022/lib/services/lang-provider/content.mjs +1 -72
  4. package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +4 -9
  5. package/esm2022/lib/shared/utils/content.mjs +2 -8
  6. package/esm2022/public-api.mjs +1 -12
  7. package/fesm2022/valtech-components.mjs +124 -2824
  8. package/fesm2022/valtech-components.mjs.map +1 -1
  9. package/lib/components/atoms/button/button.component.d.ts +33 -2
  10. package/lib/components/types.d.ts +19 -7
  11. package/package.json +1 -1
  12. package/public-api.d.ts +0 -10
  13. package/esm2022/lib/examples/comprehensive-link-test.component.mjs +0 -208
  14. package/esm2022/lib/examples/custom-content-demo.component.mjs +0 -291
  15. package/esm2022/lib/examples/display-demo.component.mjs +0 -518
  16. package/esm2022/lib/examples/display-simple-example.component.mjs +0 -202
  17. package/esm2022/lib/examples/link-processing-example.component.mjs +0 -233
  18. package/esm2022/lib/examples/multi-language-demo.component.mjs +0 -304
  19. package/esm2022/lib/examples/reactive-components-demo.component.mjs +0 -303
  20. package/esm2022/lib/examples/reactivity-test.component.mjs +0 -200
  21. package/esm2022/lib/examples/selector-examples.component.mjs +0 -234
  22. package/esm2022/lib/examples/user-issue-test.component.mjs +0 -267
  23. package/lib/examples/comprehensive-link-test.component.d.ts +0 -23
  24. package/lib/examples/custom-content-demo.component.d.ts +0 -26
  25. package/lib/examples/display-demo.component.d.ts +0 -62
  26. package/lib/examples/display-simple-example.component.d.ts +0 -23
  27. package/lib/examples/link-processing-example.component.d.ts +0 -26
  28. package/lib/examples/multi-language-demo.component.d.ts +0 -34
  29. package/lib/examples/reactive-components-demo.component.d.ts +0 -45
  30. package/lib/examples/reactivity-test.component.d.ts +0 -27
  31. package/lib/examples/selector-examples.component.d.ts +0 -21
  32. package/lib/examples/user-issue-test.component.d.ts +0 -31
@@ -1,518 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component } from '@angular/core';
3
- import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle } from '@ionic/angular/standalone';
4
- import { map } from 'rxjs/operators';
5
- import { DisplayComponent } from '../components/atoms/display/display.component';
6
- import { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../services/content.service";
9
- import * as i2 from "../services/lang-provider/lang-provider.service";
10
- import * as i3 from "@angular/common";
11
- /**
12
- * Componente de demostración para val-display con contenido reactivo.
13
- * Muestra diferentes patrones de uso y casos de ejemplo.
14
- */
15
- export class DisplayDemoComponent {
16
- constructor(contentService, langService) {
17
- this.contentService = contentService;
18
- this.langService = langService;
19
- // Contador para ejemplos dinámicos
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
- };
34
- // Configuraciones de ejemplo - ESTÁTICAS
35
- this.smallStaticDisplay = {
36
- content: 'Texto pequeño estático',
37
- color: 'dark',
38
- size: 'small',
39
- };
40
- this.mediumStaticDisplay = {
41
- content: 'Texto mediano estático',
42
- color: 'dark',
43
- size: 'medium',
44
- };
45
- this.largeStaticDisplay = {
46
- content: 'Texto grande estático',
47
- color: 'dark',
48
- size: 'large',
49
- };
50
- this.xlargeStaticDisplay = {
51
- content: 'Texto extra grande estático',
52
- color: 'dark',
53
- size: 'xlarge',
54
- };
55
- // Ejemplos de colores estáticos
56
- this.primaryDisplay = {
57
- content: 'Texto primario',
58
- color: 'primary',
59
- size: 'medium',
60
- };
61
- this.secondaryDisplay = {
62
- content: 'Texto secundario',
63
- color: 'secondary',
64
- size: 'medium',
65
- };
66
- this.successDisplay = {
67
- content: 'Texto de éxito',
68
- color: 'success',
69
- size: 'medium',
70
- };
71
- this.warningDisplay = {
72
- content: 'Texto de advertencia',
73
- color: 'warning',
74
- size: 'medium',
75
- };
76
- this.dangerDisplay = {
77
- content: 'Texto de peligro',
78
- color: 'danger',
79
- size: 'medium',
80
- };
81
- // Configuraciones de ejemplo - REACTIVAS
82
- this.welcomeDisplay = {
83
- contentConfig: {
84
- className: 'displayDemo',
85
- key: 'welcomeTitle',
86
- fallback: 'Bienvenido a la aplicación',
87
- },
88
- color: 'primary',
89
- size: 'xlarge',
90
- };
91
- this.descriptionDisplay = {
92
- contentConfig: {
93
- className: 'displayDemo',
94
- key: 'welcomeDescription',
95
- fallback: 'Esta es una descripción de ejemplo',
96
- },
97
- color: 'medium',
98
- size: 'medium',
99
- };
100
- this.statusDisplay = {
101
- contentConfig: {
102
- className: 'displayDemo',
103
- key: 'statusOnline',
104
- fallback: 'En línea',
105
- },
106
- color: 'success',
107
- size: 'small',
108
- };
109
- // Ejemplos con interpolación
110
- this.userWelcomeDisplay = {
111
- contentConfig: {
112
- className: 'displayDemo',
113
- key: 'welcomeUser',
114
- fallback: 'Hola, {{userName}}!',
115
- interpolation: {
116
- userName: 'Juan Pérez',
117
- },
118
- },
119
- color: 'tertiary',
120
- size: 'large',
121
- };
122
- this.counterDisplay = {
123
- contentConfig: {
124
- className: 'displayDemo',
125
- key: 'counterCurrent',
126
- fallback: 'Contador: {{count}}',
127
- interpolation: {
128
- count: this.counter,
129
- },
130
- },
131
- color: 'secondary',
132
- size: 'medium',
133
- };
134
- // Ejemplos con claves faltantes para demostrar fallbacks
135
- this.missingKeyDisplay = {
136
- contentConfig: {
137
- className: 'displayDemo',
138
- key: 'this.key.does.not.exist',
139
- fallback: 'Esta clave no existe, pero tengo fallback',
140
- },
141
- color: 'warning',
142
- size: 'medium',
143
- };
144
- this.noFallbackDisplay = {
145
- contentConfig: {
146
- className: 'displayDemo',
147
- key: 'another.missing.key',
148
- // Sin fallback - usará la clave como fallback
149
- },
150
- color: 'danger',
151
- size: 'small',
152
- };
153
- // Ejemplos mixtos
154
- this.staticMixedDisplay = {
155
- content: 'Este es contenido estático (no cambia con el idioma)',
156
- color: 'dark',
157
- size: 'medium',
158
- };
159
- this.reactiveMixedDisplay = {
160
- contentConfig: {
161
- className: 'displayDemo',
162
- key: 'mixedReactive',
163
- fallback: 'Este contenido sí cambia con el idioma',
164
- },
165
- color: 'primary',
166
- size: 'medium',
167
- };
168
- // Ejemplo dinámico que se actualiza
169
- this.dynamicCounterDisplay = {
170
- contentConfig: {
171
- className: 'displayDemo',
172
- key: 'dynamicContent',
173
- fallback: 'Clics: {{count}}',
174
- interpolation: {
175
- count: this.counter,
176
- },
177
- },
178
- color: 'tertiary',
179
- size: 'large',
180
- };
181
- }
182
- ngOnInit() {
183
- this.initializeContent();
184
- this.initializeLanguageState();
185
- }
186
- initializeContent() {
187
- // Contenido de la página
188
- this.demoTitle$ = this.contentService.fromContent({
189
- className: 'displayDemo',
190
- key: 'pageTitle',
191
- fallback: 'Demostración del Componente Display',
192
- });
193
- this.languageLabel$ = this.contentService.fromContent({
194
- className: '_global',
195
- key: 'language',
196
- fallback: 'Idioma',
197
- });
198
- this.staticSectionTitle$ = this.contentService.fromContent({
199
- className: 'displayDemo',
200
- key: 'sectionsStatic',
201
- fallback: 'Ejemplos Estáticos',
202
- });
203
- this.reactiveSectionTitle$ = this.contentService.fromContent({
204
- className: 'displayDemo',
205
- key: 'sectionsReactive',
206
- fallback: 'Ejemplos Reactivos',
207
- });
208
- this.mixedSectionTitle$ = this.contentService.fromContent({
209
- className: 'displayDemo',
210
- key: 'sectionsMixed',
211
- fallback: 'Ejemplos Mixtos',
212
- });
213
- this.dynamicSectionTitle$ = this.contentService.fromContent({
214
- className: 'displayDemo',
215
- key: 'sectionsDynamic',
216
- fallback: 'Ejemplos Dinámicos',
217
- });
218
- this.analysisTitle$ = this.contentService.fromContent({
219
- className: 'displayDemo',
220
- key: 'sectionsAnalysis',
221
- fallback: 'Análisis de Idioma',
222
- });
223
- this.reactiveContentTitle$ = this.contentService.fromContent({
224
- className: 'displayDemo',
225
- key: 'subsectionsReactiveContent',
226
- fallback: 'Contenido reactivo básico:',
227
- });
228
- this.interpolationTitle$ = this.contentService.fromContent({
229
- className: 'displayDemo',
230
- key: 'subsectionsInterpolation',
231
- fallback: 'Contenido con interpolación:',
232
- });
233
- this.fallbackTitle$ = this.contentService.fromContent({
234
- className: 'displayDemo',
235
- key: 'subsectionsFallback',
236
- fallback: 'Demostración de fallbacks:',
237
- });
238
- this.mixedContentTitle$ = this.contentService.fromContent({
239
- className: 'displayDemo',
240
- key: 'subsectionsMixedContent',
241
- fallback: 'Contenido estático vs reactivo:',
242
- });
243
- this.dynamicContentTitle$ = this.contentService.fromContent({
244
- className: 'displayDemo',
245
- key: 'subsectionsDynamicContent',
246
- fallback: 'Contenido que se actualiza dinámicamente:',
247
- });
248
- this.updateButtonText$ = this.contentService.fromContent({
249
- className: 'displayDemo',
250
- key: 'buttonsUpdateCounter',
251
- fallback: 'Actualizar Contador',
252
- });
253
- this.currentLangLabel$ = this.contentService.fromContent({
254
- className: 'displayDemo',
255
- key: 'analysisCurrentLanguage',
256
- fallback: 'Idioma actual',
257
- });
258
- this.availableLangsLabel$ = this.contentService.fromContent({
259
- className: 'displayDemo',
260
- key: 'analysisAvailableLanguages',
261
- fallback: 'Idiomas disponibles',
262
- });
263
- }
264
- initializeLanguageState() {
265
- this.currentLanguage$ = this.langService.currentLang$;
266
- this.availableLanguages$ = this.langService.currentLang$.pipe(map(() => this.langService.availableLangs));
267
- }
268
- changeLanguage(language) {
269
- this.langService.setLang(language);
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
- }
276
- updateCounter() {
277
- this.counter++;
278
- // Actualizar los displays que usan el contador
279
- this.counterDisplay = {
280
- ...this.counterDisplay,
281
- contentConfig: {
282
- ...this.counterDisplay.contentConfig,
283
- interpolation: {
284
- count: this.counter,
285
- },
286
- },
287
- };
288
- this.dynamicCounterDisplay = {
289
- ...this.dynamicCounterDisplay,
290
- contentConfig: {
291
- ...this.dynamicCounterDisplay.contentConfig,
292
- interpolation: {
293
- count: this.counter,
294
- },
295
- },
296
- };
297
- }
298
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayDemoComponent, deps: [{ token: i1.ContentService }, { token: i2.LangService }], target: i0.ɵɵFactoryTarget.Component }); }
299
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayDemoComponent, isStandalone: true, selector: "val-display-demo", ngImport: i0, template: `
300
- <div class="display-demo">
301
- <ion-card>
302
- <ion-card-header>
303
- <ion-card-title>{{ demoTitle$ | async }}</ion-card-title>
304
- </ion-card-header>
305
-
306
- <ion-card-content>
307
- <!-- Selector de idioma -->
308
- <div class="language-selector-container">
309
- <val-language-selector [props]="languageSelectorProps" (languageChange)="onLanguageChange($event)">
310
- </val-language-selector>
311
- </div>
312
-
313
- <!-- Ejemplos estáticos -->
314
- <div class="section">
315
- <h3>{{ staticSectionTitle$ | async }}</h3>
316
-
317
- <div class="example-group">
318
- <h4>Diferentes tamaños:</h4>
319
- <val-display [props]="smallStaticDisplay"></val-display>
320
- <val-display [props]="mediumStaticDisplay"></val-display>
321
- <val-display [props]="largeStaticDisplay"></val-display>
322
- <val-display [props]="xlargeStaticDisplay"></val-display>
323
- </div>
324
-
325
- <div class="example-group">
326
- <h4>Diferentes colores:</h4>
327
- <val-display [props]="primaryDisplay"></val-display>
328
- <val-display [props]="secondaryDisplay"></val-display>
329
- <val-display [props]="successDisplay"></val-display>
330
- <val-display [props]="warningDisplay"></val-display>
331
- <val-display [props]="dangerDisplay"></val-display>
332
- </div>
333
- </div>
334
-
335
- <!-- Ejemplos reactivos -->
336
- <div class="section">
337
- <h3>{{ reactiveSectionTitle$ | async }}</h3>
338
-
339
- <div class="example-group">
340
- <h4>{{ reactiveContentTitle$ | async }}</h4>
341
- <val-display [props]="welcomeDisplay"></val-display>
342
- <val-display [props]="descriptionDisplay"></val-display>
343
- <val-display [props]="statusDisplay"></val-display>
344
- </div>
345
-
346
- <div class="example-group">
347
- <h4>{{ interpolationTitle$ | async }}</h4>
348
- <val-display [props]="userWelcomeDisplay"></val-display>
349
- <val-display [props]="counterDisplay"></val-display>
350
- </div>
351
-
352
- <div class="example-group">
353
- <h4>{{ fallbackTitle$ | async }}</h4>
354
- <val-display [props]="missingKeyDisplay"></val-display>
355
- <val-display [props]="noFallbackDisplay"></val-display>
356
- </div>
357
- </div>
358
-
359
- <!-- Ejemplos mixtos -->
360
- <div class="section">
361
- <h3>{{ mixedSectionTitle$ | async }}</h3>
362
-
363
- <div class="example-group">
364
- <h4>{{ mixedContentTitle$ | async }}</h4>
365
- <div class="mixed-examples">
366
- <val-display [props]="staticMixedDisplay"></val-display>
367
- <val-display [props]="reactiveMixedDisplay"></val-display>
368
- </div>
369
- </div>
370
- </div>
371
-
372
- <!-- Ejemplos dinámicos -->
373
- <div class="section">
374
- <h3>{{ dynamicSectionTitle$ | async }}</h3>
375
-
376
- <div class="example-group">
377
- <h4>{{ dynamicContentTitle$ | async }}</h4>
378
- <ion-button (click)="updateCounter()" color="primary">
379
- {{ updateButtonText$ | async }}
380
- </ion-button>
381
- <val-display [props]="dynamicCounterDisplay"></val-display>
382
- </div>
383
- </div>
384
-
385
- <!-- Análisis de contenido -->
386
- <div class="section">
387
- <h3>{{ analysisTitle$ | async }}</h3>
388
- <div class="analysis-info">
389
- <p>
390
- <strong>{{ currentLangLabel$ | async }}:</strong> {{ currentLanguage$ | async | uppercase }}
391
- </p>
392
- <p>
393
- <strong>{{ availableLangsLabel$ | async }}:</strong>
394
- {{ (availableLanguages$ | async)?.join(', ') | uppercase }}
395
- </p>
396
- </div>
397
- </div>
398
- </ion-card-content>
399
- </ion-card>
400
- </div>
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"] }] }); }
402
- }
403
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayDemoComponent, decorators: [{
404
- type: Component,
405
- args: [{ selector: 'val-display-demo', standalone: true, imports: [
406
- CommonModule,
407
- IonCard,
408
- IonCardContent,
409
- IonCardHeader,
410
- IonCardTitle,
411
- IonButton,
412
- DisplayComponent,
413
- LanguageSelectorComponent,
414
- ], template: `
415
- <div class="display-demo">
416
- <ion-card>
417
- <ion-card-header>
418
- <ion-card-title>{{ demoTitle$ | async }}</ion-card-title>
419
- </ion-card-header>
420
-
421
- <ion-card-content>
422
- <!-- Selector de idioma -->
423
- <div class="language-selector-container">
424
- <val-language-selector [props]="languageSelectorProps" (languageChange)="onLanguageChange($event)">
425
- </val-language-selector>
426
- </div>
427
-
428
- <!-- Ejemplos estáticos -->
429
- <div class="section">
430
- <h3>{{ staticSectionTitle$ | async }}</h3>
431
-
432
- <div class="example-group">
433
- <h4>Diferentes tamaños:</h4>
434
- <val-display [props]="smallStaticDisplay"></val-display>
435
- <val-display [props]="mediumStaticDisplay"></val-display>
436
- <val-display [props]="largeStaticDisplay"></val-display>
437
- <val-display [props]="xlargeStaticDisplay"></val-display>
438
- </div>
439
-
440
- <div class="example-group">
441
- <h4>Diferentes colores:</h4>
442
- <val-display [props]="primaryDisplay"></val-display>
443
- <val-display [props]="secondaryDisplay"></val-display>
444
- <val-display [props]="successDisplay"></val-display>
445
- <val-display [props]="warningDisplay"></val-display>
446
- <val-display [props]="dangerDisplay"></val-display>
447
- </div>
448
- </div>
449
-
450
- <!-- Ejemplos reactivos -->
451
- <div class="section">
452
- <h3>{{ reactiveSectionTitle$ | async }}</h3>
453
-
454
- <div class="example-group">
455
- <h4>{{ reactiveContentTitle$ | async }}</h4>
456
- <val-display [props]="welcomeDisplay"></val-display>
457
- <val-display [props]="descriptionDisplay"></val-display>
458
- <val-display [props]="statusDisplay"></val-display>
459
- </div>
460
-
461
- <div class="example-group">
462
- <h4>{{ interpolationTitle$ | async }}</h4>
463
- <val-display [props]="userWelcomeDisplay"></val-display>
464
- <val-display [props]="counterDisplay"></val-display>
465
- </div>
466
-
467
- <div class="example-group">
468
- <h4>{{ fallbackTitle$ | async }}</h4>
469
- <val-display [props]="missingKeyDisplay"></val-display>
470
- <val-display [props]="noFallbackDisplay"></val-display>
471
- </div>
472
- </div>
473
-
474
- <!-- Ejemplos mixtos -->
475
- <div class="section">
476
- <h3>{{ mixedSectionTitle$ | async }}</h3>
477
-
478
- <div class="example-group">
479
- <h4>{{ mixedContentTitle$ | async }}</h4>
480
- <div class="mixed-examples">
481
- <val-display [props]="staticMixedDisplay"></val-display>
482
- <val-display [props]="reactiveMixedDisplay"></val-display>
483
- </div>
484
- </div>
485
- </div>
486
-
487
- <!-- Ejemplos dinámicos -->
488
- <div class="section">
489
- <h3>{{ dynamicSectionTitle$ | async }}</h3>
490
-
491
- <div class="example-group">
492
- <h4>{{ dynamicContentTitle$ | async }}</h4>
493
- <ion-button (click)="updateCounter()" color="primary">
494
- {{ updateButtonText$ | async }}
495
- </ion-button>
496
- <val-display [props]="dynamicCounterDisplay"></val-display>
497
- </div>
498
- </div>
499
-
500
- <!-- Análisis de contenido -->
501
- <div class="section">
502
- <h3>{{ analysisTitle$ | async }}</h3>
503
- <div class="analysis-info">
504
- <p>
505
- <strong>{{ currentLangLabel$ | async }}:</strong> {{ currentLanguage$ | async | uppercase }}
506
- </p>
507
- <p>
508
- <strong>{{ availableLangsLabel$ | async }}:</strong>
509
- {{ (availableLanguages$ | async)?.join(', ') | uppercase }}
510
- </p>
511
- </div>
512
- </div>
513
- </ion-card-content>
514
- </ion-card>
515
- </div>
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
- }], 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 { 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"]}