valtech-components 2.0.298 → 2.0.300

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.
@@ -0,0 +1,200 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, inject } from '@angular/core';
3
+ import { ContentService } from '../services/content.service';
4
+ import { LangService } from '../services/lang-provider/lang-provider.service';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ /**
8
+ * Test component to diagnose reactive content behavior.
9
+ * Compares fromContent vs fromMultipleContent reactivity.
10
+ */
11
+ export class ReactivityTestComponent {
12
+ constructor() {
13
+ this.contentService = inject(ContentService);
14
+ this.langService = inject(LangService);
15
+ // Observable for current language
16
+ this.currentLang$ = this.langService.currentLang$;
17
+ // Single key content observables (using fromContent)
18
+ this.singleWelcome$ = this.contentService.fromContent({
19
+ className: 'testReactivity',
20
+ key: 'welcomeMessage',
21
+ fallback: 'Welcome',
22
+ });
23
+ this.singleSave$ = this.contentService.fromContent({
24
+ className: 'testReactivity',
25
+ key: 'saveButton',
26
+ fallback: 'Save',
27
+ });
28
+ this.singleCancel$ = this.contentService.fromContent({
29
+ className: 'testReactivity',
30
+ key: 'cancelButton',
31
+ fallback: 'Cancel',
32
+ });
33
+ // Multiple keys content observable (using fromMultipleContent)
34
+ this.multipleContent$ = this.contentService.fromMultipleContent('testReactivity', [
35
+ 'welcomeMessage',
36
+ 'saveButton',
37
+ 'cancelButton',
38
+ ]);
39
+ // Direct LangService tests
40
+ this.directSingle$ = this.langService.getContent('testReactivity', 'welcomeMessage', 'Welcome');
41
+ this.directMultiple$ = this.langService.getMultipleContent('testReactivity', ['welcomeMessage']);
42
+ // Update counters
43
+ this.singleUpdateCount = 0;
44
+ this.multipleUpdateCount = 0;
45
+ this.directSingleUpdateCount = 0;
46
+ this.directMultipleUpdateCount = 0;
47
+ }
48
+ ngOnInit() {
49
+ // Subscribe to observables to count updates
50
+ this.singleWelcome$.subscribe(() => {
51
+ this.singleUpdateCount++;
52
+ console.log('Single key updated:', this.singleUpdateCount);
53
+ });
54
+ this.multipleContent$.subscribe(() => {
55
+ this.multipleUpdateCount++;
56
+ console.log('Multiple keys updated:', this.multipleUpdateCount);
57
+ });
58
+ this.directSingle$.subscribe(() => {
59
+ this.directSingleUpdateCount++;
60
+ console.log('Direct single updated:', this.directSingleUpdateCount);
61
+ });
62
+ this.directMultiple$.subscribe(() => {
63
+ this.directMultipleUpdateCount++;
64
+ console.log('Direct multiple updated:', this.directMultipleUpdateCount);
65
+ });
66
+ }
67
+ switchToSpanish() {
68
+ this.langService.setLang('es');
69
+ }
70
+ switchToEnglish() {
71
+ this.langService.setLang('en');
72
+ }
73
+ switchToFrench() {
74
+ this.langService.setLang('fr');
75
+ }
76
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactivityTestComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
77
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReactivityTestComponent, isStandalone: true, selector: "val-reactivity-test", ngImport: i0, template: `
78
+ <div style="padding: 20px; border: 1px solid #ccc; margin: 10px;">
79
+ <h3>Reactivity Test Component</h3>
80
+
81
+ <!-- Current Language -->
82
+ <div style="margin-bottom: 20px;"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>
83
+
84
+ <!-- Language Switch Buttons -->
85
+ <div style="margin-bottom: 20px;">
86
+ <button (click)="switchToSpanish()" style="margin-right: 10px;">Switch to ES</button>
87
+ <button (click)="switchToEnglish()" style="margin-right: 10px;">Switch to EN</button>
88
+ <button (click)="switchToFrench()">Switch to FR</button>
89
+ </div>
90
+
91
+ <!-- Single Key Tests -->
92
+ <div style="margin-bottom: 20px;">
93
+ <h4>Single Key Tests (fromContent)</h4>
94
+ <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>
95
+ <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>
96
+ <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>
97
+ </div>
98
+
99
+ <!-- Multiple Keys Test -->
100
+ <div style="margin-bottom: 20px;">
101
+ <h4>Multiple Keys Test (fromMultipleContent)</h4>
102
+ <div>
103
+ <strong>welcomeMessage (multiple):</strong>
104
+ {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}
105
+ </div>
106
+ <div>
107
+ <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}
108
+ </div>
109
+ <div>
110
+ <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}
111
+ </div>
112
+ </div>
113
+
114
+ <!-- Direct LangService Tests -->
115
+ <div style="margin-bottom: 20px;">
116
+ <h4>Direct LangService Tests</h4>
117
+ <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>
118
+ <div>
119
+ <strong>welcomeMessage (direct multiple):</strong>
120
+ {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}
121
+ </div>
122
+ </div>
123
+
124
+ <!-- Update Counter -->
125
+ <div>
126
+ <h4>Update Counters</h4>
127
+ <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>
128
+ <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>
129
+ <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>
130
+ <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>
131
+ </div>
132
+ </div>
133
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
134
+ }
135
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactivityTestComponent, decorators: [{
136
+ type: Component,
137
+ args: [{
138
+ selector: 'val-reactivity-test',
139
+ standalone: true,
140
+ imports: [CommonModule],
141
+ template: `
142
+ <div style="padding: 20px; border: 1px solid #ccc; margin: 10px;">
143
+ <h3>Reactivity Test Component</h3>
144
+
145
+ <!-- Current Language -->
146
+ <div style="margin-bottom: 20px;"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>
147
+
148
+ <!-- Language Switch Buttons -->
149
+ <div style="margin-bottom: 20px;">
150
+ <button (click)="switchToSpanish()" style="margin-right: 10px;">Switch to ES</button>
151
+ <button (click)="switchToEnglish()" style="margin-right: 10px;">Switch to EN</button>
152
+ <button (click)="switchToFrench()">Switch to FR</button>
153
+ </div>
154
+
155
+ <!-- Single Key Tests -->
156
+ <div style="margin-bottom: 20px;">
157
+ <h4>Single Key Tests (fromContent)</h4>
158
+ <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>
159
+ <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>
160
+ <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>
161
+ </div>
162
+
163
+ <!-- Multiple Keys Test -->
164
+ <div style="margin-bottom: 20px;">
165
+ <h4>Multiple Keys Test (fromMultipleContent)</h4>
166
+ <div>
167
+ <strong>welcomeMessage (multiple):</strong>
168
+ {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}
169
+ </div>
170
+ <div>
171
+ <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}
172
+ </div>
173
+ <div>
174
+ <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}
175
+ </div>
176
+ </div>
177
+
178
+ <!-- Direct LangService Tests -->
179
+ <div style="margin-bottom: 20px;">
180
+ <h4>Direct LangService Tests</h4>
181
+ <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>
182
+ <div>
183
+ <strong>welcomeMessage (direct multiple):</strong>
184
+ {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}
185
+ </div>
186
+ </div>
187
+
188
+ <!-- Update Counter -->
189
+ <div>
190
+ <h4>Update Counters</h4>
191
+ <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>
192
+ <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>
193
+ <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>
194
+ <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>
195
+ </div>
196
+ </div>
197
+ `,
198
+ }]
199
+ }] });
200
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reactivity-test.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/reactivity-test.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE1D,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,iDAAiD,CAAC;;;AAE9E;;;GAGG;AA+DH,MAAM,OAAO,uBAAuB;IA9DpC;QA+DU,mBAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAE1C,kCAAkC;QAClC,iBAAY,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC;QAE7C,qDAAqD;QACrD,mBAAc,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YAC/C,SAAS,EAAE,gBAAgB;YAC3B,GAAG,EAAE,gBAAgB;YACrB,QAAQ,EAAE,SAAS;SACpB,CAAC,CAAC;QAEH,gBAAW,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YAC5C,SAAS,EAAE,gBAAgB;YAC3B,GAAG,EAAE,YAAY;YACjB,QAAQ,EAAE,MAAM;SACjB,CAAC,CAAC;QAEH,kBAAa,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YAC9C,SAAS,EAAE,gBAAgB;YAC3B,GAAG,EAAE,cAAc;YACnB,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;QAEH,+DAA+D;QAC/D,qBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,gBAAgB,EAAE;YAC3E,gBAAgB;YAChB,YAAY;YACZ,cAAc;SACf,CAAC,CAAC;QAEH,2BAA2B;QAC3B,kBAAa,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,gBAAgB,EAAE,gBAAgB,EAAE,SAAS,CAAC,CAAC;QAC3F,oBAAe,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAE5F,kBAAkB;QAClB,sBAAiB,GAAG,CAAC,CAAC;QACtB,wBAAmB,GAAG,CAAC,CAAC;QACxB,4BAAuB,GAAG,CAAC,CAAC;QAC5B,8BAAyB,GAAG,CAAC,CAAC;KAoC/B;IAlCC,QAAQ;QACN,4CAA4C;QAC5C,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,GAAG,EAAE;YACjC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,EAAE;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAClE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAC/B,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,CAAC,uBAAuB,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,yBAAyB,EAAE,CAAC;YACjC,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,IAAI,CAAC,yBAAyB,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;+GA5EU,uBAAuB;mGAAvB,uBAAuB,+EA1DxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwDT,2DAzDS,YAAY;;4FA2DX,uBAAuB;kBA9DnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,YAAY,CAAC;oBACvB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwDT;iBACF","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, OnInit, inject } from '@angular/core';\n\nimport { ContentService } from '../services/content.service';\nimport { LangService } from '../services/lang-provider/lang-provider.service';\n\n/**\n * Test component to diagnose reactive content behavior.\n * Compares fromContent vs fromMultipleContent reactivity.\n */\n@Component({\n  selector: 'val-reactivity-test',\n  standalone: true,\n  imports: [CommonModule],\n  template: `\n    <div style=\"padding: 20px; border: 1px solid #ccc; margin: 10px;\">\n      <h3>Reactivity Test Component</h3>\n\n      <!-- Current Language -->\n      <div style=\"margin-bottom: 20px;\"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>\n\n      <!-- Language Switch Buttons -->\n      <div style=\"margin-bottom: 20px;\">\n        <button (click)=\"switchToSpanish()\" style=\"margin-right: 10px;\">Switch to ES</button>\n        <button (click)=\"switchToEnglish()\" style=\"margin-right: 10px;\">Switch to EN</button>\n        <button (click)=\"switchToFrench()\">Switch to FR</button>\n      </div>\n\n      <!-- Single Key Tests -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Single Key Tests (fromContent)</h4>\n        <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>\n        <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>\n        <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>\n      </div>\n\n      <!-- Multiple Keys Test -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Multiple Keys Test (fromMultipleContent)</h4>\n        <div>\n          <strong>welcomeMessage (multiple):</strong>\n          {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}\n        </div>\n        <div>\n          <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}\n        </div>\n        <div>\n          <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}\n        </div>\n      </div>\n\n      <!-- Direct LangService Tests -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Direct LangService Tests</h4>\n        <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>\n        <div>\n          <strong>welcomeMessage (direct multiple):</strong>\n          {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}\n        </div>\n      </div>\n\n      <!-- Update Counter -->\n      <div>\n        <h4>Update Counters</h4>\n        <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>\n        <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>\n        <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>\n        <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>\n      </div>\n    </div>\n  `,\n})\nexport class ReactivityTestComponent implements OnInit {\n  private contentService = inject(ContentService);\n  private langService = inject(LangService);\n\n  // Observable for current language\n  currentLang$ = this.langService.currentLang$;\n\n  // Single key content observables (using fromContent)\n  singleWelcome$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'welcomeMessage',\n    fallback: 'Welcome',\n  });\n\n  singleSave$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'saveButton',\n    fallback: 'Save',\n  });\n\n  singleCancel$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'cancelButton',\n    fallback: 'Cancel',\n  });\n\n  // Multiple keys content observable (using fromMultipleContent)\n  multipleContent$ = this.contentService.fromMultipleContent('testReactivity', [\n    'welcomeMessage',\n    'saveButton',\n    'cancelButton',\n  ]);\n\n  // Direct LangService tests\n  directSingle$ = this.langService.getContent('testReactivity', 'welcomeMessage', 'Welcome');\n  directMultiple$ = this.langService.getMultipleContent('testReactivity', ['welcomeMessage']);\n\n  // Update counters\n  singleUpdateCount = 0;\n  multipleUpdateCount = 0;\n  directSingleUpdateCount = 0;\n  directMultipleUpdateCount = 0;\n\n  ngOnInit() {\n    // Subscribe to observables to count updates\n    this.singleWelcome$.subscribe(() => {\n      this.singleUpdateCount++;\n      console.log('Single key updated:', this.singleUpdateCount);\n    });\n\n    this.multipleContent$.subscribe(() => {\n      this.multipleUpdateCount++;\n      console.log('Multiple keys updated:', this.multipleUpdateCount);\n    });\n\n    this.directSingle$.subscribe(() => {\n      this.directSingleUpdateCount++;\n      console.log('Direct single updated:', this.directSingleUpdateCount);\n    });\n\n    this.directMultiple$.subscribe(() => {\n      this.directMultipleUpdateCount++;\n      console.log('Direct multiple updated:', this.directMultipleUpdateCount);\n    });\n  }\n\n  switchToSpanish() {\n    this.langService.setLang('es');\n  }\n\n  switchToEnglish() {\n    this.langService.setLang('en');\n  }\n\n  switchToFrench() {\n    this.langService.setLang('fr');\n  }\n}\n"]}
@@ -53,7 +53,9 @@ export class SelectorExamplesComponent {
53
53
  fill: 'outline',
54
54
  showCheckmark: true,
55
55
  };
56
- // ✅ Ejemplos de Language Selector
56
+ // ✅ Ejemplos de Language Selector (con soporte multiidioma)
57
+ // Los nombres de idiomas se obtienen automáticamente del sistema de contenido
58
+ // y se muestran traducidos según el idioma actual de la aplicación
57
59
  this.basicLanguageSelector = {
58
60
  showLabel: true,
59
61
  label: 'Idioma',
@@ -61,6 +63,7 @@ export class SelectorExamplesComponent {
61
63
  size: 'default',
62
64
  fill: 'outline',
63
65
  };
66
+ // Con banderas y nombres traducidos automáticamente
64
67
  this.flagLanguageSelector = {
65
68
  showLabel: true,
66
69
  label: 'Language / Idioma',
@@ -69,6 +72,7 @@ export class SelectorExamplesComponent {
69
72
  size: 'large',
70
73
  fill: 'solid',
71
74
  };
75
+ // Con nombres personalizados (sobrescribe las traducciones automáticas)
72
76
  this.customLanguageSelector = {
73
77
  showLabel: true,
74
78
  labelConfig: {
@@ -88,6 +92,14 @@ export class SelectorExamplesComponent {
88
92
  de: 'Deutsch',
89
93
  },
90
94
  };
95
+ // Compacto sin etiqueta, solo banderas y nombres traducidos
96
+ this.compactLanguageSelector = {
97
+ showLabel: false,
98
+ showFlags: true,
99
+ color: 'tertiary',
100
+ size: 'small',
101
+ fill: 'clear',
102
+ };
91
103
  }
92
104
  // ✅ Event Handlers
93
105
  onCategoryChange(category) {
@@ -100,7 +112,9 @@ export class SelectorExamplesComponent {
100
112
  console.log('Notifications changed:', notifications);
101
113
  }
102
114
  onLanguageChange(language) {
103
- console.log('Language changed:', language);
115
+ console.log('Language changed to:', language);
116
+ // La aplicación automáticamente actualizará todos los nombres de idiomas
117
+ // según la nueva configuración de idioma seleccionada
104
118
  }
105
119
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorExamplesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
106
120
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectorExamplesComponent, isStandalone: true, selector: "app-selector-examples", ngImport: i0, template: `
@@ -132,23 +146,29 @@ export class SelectorExamplesComponent {
132
146
 
133
147
  <!-- Language Selector -->
134
148
  <div class="section">
135
- <h3>Selector de Idioma</h3>
149
+ <h3>Selector de Idioma (Multiidioma)</h3>
150
+ <p>Los nombres de idiomas se muestran traducidos según el idioma actual:</p>
136
151
 
137
152
  <div class="example-group">
138
- <h4>Selector Básico:</h4>
153
+ <h4>Selector Básico (nombres traducidos):</h4>
139
154
  <val-language-selector [props]="basicLanguageSelector"> </val-language-selector>
140
155
  </div>
141
156
 
142
157
  <div class="example-group">
143
- <h4>Selector con Banderas:</h4>
158
+ <h4>Selector con Banderas (nombres traducidos):</h4>
144
159
  <val-language-selector [props]="flagLanguageSelector"> </val-language-selector>
145
160
  </div>
146
161
 
147
162
  <div class="example-group">
148
- <h4>Selector Personalizado:</h4>
163
+ <h4>Selector Personalizado (nombres propios):</h4>
149
164
  <val-language-selector [props]="customLanguageSelector" (languageChange)="onLanguageChange($event)">
150
165
  </val-language-selector>
151
166
  </div>
167
+
168
+ <div class="example-group">
169
+ <h4>Selector Compacto:</h4>
170
+ <val-language-selector [props]="compactLanguageSelector"> </val-language-selector>
171
+ </div>
152
172
  </div>
153
173
  </div>
154
174
  `, isInline: true, styles: [".selector-examples{padding:20px;max-width:800px;margin:0 auto}.section{margin:30px 0;padding:20px;border:1px solid var(--ion-color-light);border-radius:8px;background:var(--ion-color-step-50)}.section h3{margin:0 0 20px;color:var(--ion-color-primary)}.example-group{margin:20px 0;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.example-group h4{margin:0 0 15px;color:var(--ion-color-medium)}\n"], dependencies: [{ kind: "component", type: PopoverSelectorComponent, selector: "val-popover-selector", inputs: ["props"], outputs: ["selectionChange"] }, { kind: "component", type: LanguageSelectorComponent, selector: "val-language-selector", inputs: ["props"], outputs: ["languageChange"] }] }); }
@@ -184,25 +204,31 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
184
204
 
185
205
  <!-- Language Selector -->
186
206
  <div class="section">
187
- <h3>Selector de Idioma</h3>
207
+ <h3>Selector de Idioma (Multiidioma)</h3>
208
+ <p>Los nombres de idiomas se muestran traducidos según el idioma actual:</p>
188
209
 
189
210
  <div class="example-group">
190
- <h4>Selector Básico:</h4>
211
+ <h4>Selector Básico (nombres traducidos):</h4>
191
212
  <val-language-selector [props]="basicLanguageSelector"> </val-language-selector>
192
213
  </div>
193
214
 
194
215
  <div class="example-group">
195
- <h4>Selector con Banderas:</h4>
216
+ <h4>Selector con Banderas (nombres traducidos):</h4>
196
217
  <val-language-selector [props]="flagLanguageSelector"> </val-language-selector>
197
218
  </div>
198
219
 
199
220
  <div class="example-group">
200
- <h4>Selector Personalizado:</h4>
221
+ <h4>Selector Personalizado (nombres propios):</h4>
201
222
  <val-language-selector [props]="customLanguageSelector" (languageChange)="onLanguageChange($event)">
202
223
  </val-language-selector>
203
224
  </div>
225
+
226
+ <div class="example-group">
227
+ <h4>Selector Compacto:</h4>
228
+ <val-language-selector [props]="compactLanguageSelector"> </val-language-selector>
229
+ </div>
204
230
  </div>
205
231
  </div>
206
232
  `, styles: [".selector-examples{padding:20px;max-width:800px;margin:0 auto}.section{margin:30px 0;padding:20px;border:1px solid var(--ion-color-light);border-radius:8px;background:var(--ion-color-step-50)}.section h3{margin:0 0 20px;color:var(--ion-color-primary)}.example-group{margin:20px 0;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.example-group h4{margin:0 0 15px;color:var(--ion-color-medium)}\n"] }]
207
233
  }] });
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selector-examples.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/selector-examples.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';\nimport { LanguageSelectorMetadata } from '../components/molecules/language-selector/types';\nimport { PopoverSelectorComponent } from '../components/molecules/popover-selector/popover-selector.component';\nimport { PopoverSelectorMetadata } from '../components/molecules/popover-selector/types';\n\n/**\n * Ejemplo de uso de los componentes popover-selector y language-selector\n */\n@Component({\n  selector: 'app-selector-examples',\n  standalone: true,\n  imports: [PopoverSelectorComponent, LanguageSelectorComponent],\n  template: `\n    <div class=\"selector-examples\">\n      <h2>Ejemplos de Selectores</h2>\n\n      <!-- Popover Selector Genérico -->\n      <div class=\"section\">\n        <h3>Popover Selector Genérico</h3>\n\n        <div class=\"example-group\">\n          <h4>Selector de Categorías:</h4>\n          <val-popover-selector [props]=\"categorySelector\" (selectionChange)=\"onCategoryChange($event)\">\n          </val-popover-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector de Prioridad:</h4>\n          <val-popover-selector [props]=\"prioritySelector\" (selectionChange)=\"onPriorityChange($event)\">\n          </val-popover-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector Múltiple:</h4>\n          <val-popover-selector [props]=\"multipleSelector\" (selectionChange)=\"onMultipleChange($event)\">\n          </val-popover-selector>\n        </div>\n      </div>\n\n      <!-- Language Selector -->\n      <div class=\"section\">\n        <h3>Selector de Idioma</h3>\n\n        <div class=\"example-group\">\n          <h4>Selector Básico:</h4>\n          <val-language-selector [props]=\"basicLanguageSelector\"> </val-language-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector con Banderas:</h4>\n          <val-language-selector [props]=\"flagLanguageSelector\"> </val-language-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector Personalizado:</h4>\n          <val-language-selector [props]=\"customLanguageSelector\" (languageChange)=\"onLanguageChange($event)\">\n          </val-language-selector>\n        </div>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .selector-examples {\n        padding: 20px;\n        max-width: 800px;\n        margin: 0 auto;\n      }\n\n      .section {\n        margin: 30px 0;\n        padding: 20px;\n        border: 1px solid var(--ion-color-light);\n        border-radius: 8px;\n        background: var(--ion-color-step-50);\n      }\n\n      .section h3 {\n        margin: 0 0 20px 0;\n        color: var(--ion-color-primary);\n      }\n\n      .example-group {\n        margin: 20px 0;\n        padding: 15px;\n        background: white;\n        border-radius: 8px;\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n      }\n\n      .example-group h4 {\n        margin: 0 0 15px 0;\n        color: var(--ion-color-medium);\n      }\n    `,\n  ],\n})\nexport class SelectorExamplesComponent {\n  // ✅ Ejemplos de Popover Selector Genérico\n\n  categorySelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'work', label: 'Trabajo', icon: 'briefcase' },\n      { value: 'personal', label: 'Personal', icon: 'person' },\n      { value: 'travel', label: 'Viajes', icon: 'airplane' },\n      { value: 'health', label: 'Salud', icon: 'fitness' },\n    ],\n    selectedValue: 'work',\n    label: 'Categoría',\n    icon: 'folder',\n    color: 'primary',\n    size: 'default',\n    fill: 'outline',\n  };\n\n  prioritySelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'low', label: 'Baja', icon: 'arrow-down', disabled: false },\n      { value: 'medium', label: 'Media', icon: 'remove' },\n      { value: 'high', label: 'Alta', icon: 'arrow-up' },\n      { value: 'urgent', label: 'Urgente', icon: 'warning' },\n    ],\n    selectedValue: 'medium',\n    label: 'Prioridad',\n    icon: 'flag',\n    color: 'warning',\n    size: 'large',\n    fill: 'solid',\n    shape: 'round',\n  };\n\n  multipleSelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'email', label: 'Email', icon: 'mail' },\n      { value: 'sms', label: 'SMS', icon: 'chatbox' },\n      { value: 'push', label: 'Push', icon: 'notifications' },\n      { value: 'in-app', label: 'In-App', icon: 'apps' },\n    ],\n    selectedValue: ['email', 'push'],\n    label: 'Notificaciones',\n    icon: 'notifications-circle',\n    multiple: true,\n    color: 'tertiary',\n    size: 'default',\n    fill: 'outline',\n    showCheckmark: true,\n  };\n\n  // ✅ Ejemplos de Language Selector\n\n  basicLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    label: 'Idioma',\n    color: 'medium',\n    size: 'default',\n    fill: 'outline',\n  };\n\n  flagLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    label: 'Language / Idioma',\n    showFlags: true,\n    color: 'primary',\n    size: 'large',\n    fill: 'solid',\n  };\n\n  customLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    labelConfig: {\n      className: '_global',\n      key: 'language',\n      fallback: 'Idioma',\n    },\n    showFlags: true,\n    color: 'secondary',\n    size: 'default',\n    fill: 'outline',\n    shape: 'round',\n    customLanguageNames: {\n      es: 'Español (España)',\n      en: 'English (US)',\n      fr: 'Français',\n      de: 'Deutsch',\n    },\n  };\n\n  // ✅ Event Handlers\n\n  onCategoryChange(category: string | string[]) {\n    console.log('Category changed:', category);\n  }\n\n  onPriorityChange(priority: string | string[]) {\n    console.log('Priority changed:', priority);\n  }\n\n  onMultipleChange(notifications: string | string[]) {\n    console.log('Notifications changed:', notifications);\n  }\n\n  onLanguageChange(language: string) {\n    console.log('Language changed:', language);\n  }\n}\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selector-examples.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/selector-examples.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';\nimport { LanguageSelectorMetadata } from '../components/molecules/language-selector/types';\nimport { PopoverSelectorComponent } from '../components/molecules/popover-selector/popover-selector.component';\nimport { PopoverSelectorMetadata } from '../components/molecules/popover-selector/types';\n\n/**\n * Ejemplo de uso de los componentes popover-selector y language-selector\n */\n@Component({\n  selector: 'app-selector-examples',\n  standalone: true,\n  imports: [PopoverSelectorComponent, LanguageSelectorComponent],\n  template: `\n    <div class=\"selector-examples\">\n      <h2>Ejemplos de Selectores</h2>\n\n      <!-- Popover Selector Genérico -->\n      <div class=\"section\">\n        <h3>Popover Selector Genérico</h3>\n\n        <div class=\"example-group\">\n          <h4>Selector de Categorías:</h4>\n          <val-popover-selector [props]=\"categorySelector\" (selectionChange)=\"onCategoryChange($event)\">\n          </val-popover-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector de Prioridad:</h4>\n          <val-popover-selector [props]=\"prioritySelector\" (selectionChange)=\"onPriorityChange($event)\">\n          </val-popover-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector Múltiple:</h4>\n          <val-popover-selector [props]=\"multipleSelector\" (selectionChange)=\"onMultipleChange($event)\">\n          </val-popover-selector>\n        </div>\n      </div>\n\n      <!-- Language Selector -->\n      <div class=\"section\">\n        <h3>Selector de Idioma (Multiidioma)</h3>\n        <p>Los nombres de idiomas se muestran traducidos según el idioma actual:</p>\n\n        <div class=\"example-group\">\n          <h4>Selector Básico (nombres traducidos):</h4>\n          <val-language-selector [props]=\"basicLanguageSelector\"> </val-language-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector con Banderas (nombres traducidos):</h4>\n          <val-language-selector [props]=\"flagLanguageSelector\"> </val-language-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector Personalizado (nombres propios):</h4>\n          <val-language-selector [props]=\"customLanguageSelector\" (languageChange)=\"onLanguageChange($event)\">\n          </val-language-selector>\n        </div>\n\n        <div class=\"example-group\">\n          <h4>Selector Compacto:</h4>\n          <val-language-selector [props]=\"compactLanguageSelector\"> </val-language-selector>\n        </div>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .selector-examples {\n        padding: 20px;\n        max-width: 800px;\n        margin: 0 auto;\n      }\n\n      .section {\n        margin: 30px 0;\n        padding: 20px;\n        border: 1px solid var(--ion-color-light);\n        border-radius: 8px;\n        background: var(--ion-color-step-50);\n      }\n\n      .section h3 {\n        margin: 0 0 20px 0;\n        color: var(--ion-color-primary);\n      }\n\n      .example-group {\n        margin: 20px 0;\n        padding: 15px;\n        background: white;\n        border-radius: 8px;\n        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n      }\n\n      .example-group h4 {\n        margin: 0 0 15px 0;\n        color: var(--ion-color-medium);\n      }\n    `,\n  ],\n})\nexport class SelectorExamplesComponent {\n  // ✅ Ejemplos de Popover Selector Genérico\n\n  categorySelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'work', label: 'Trabajo', icon: 'briefcase' },\n      { value: 'personal', label: 'Personal', icon: 'person' },\n      { value: 'travel', label: 'Viajes', icon: 'airplane' },\n      { value: 'health', label: 'Salud', icon: 'fitness' },\n    ],\n    selectedValue: 'work',\n    label: 'Categoría',\n    icon: 'folder',\n    color: 'primary',\n    size: 'default',\n    fill: 'outline',\n  };\n\n  prioritySelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'low', label: 'Baja', icon: 'arrow-down', disabled: false },\n      { value: 'medium', label: 'Media', icon: 'remove' },\n      { value: 'high', label: 'Alta', icon: 'arrow-up' },\n      { value: 'urgent', label: 'Urgente', icon: 'warning' },\n    ],\n    selectedValue: 'medium',\n    label: 'Prioridad',\n    icon: 'flag',\n    color: 'warning',\n    size: 'large',\n    fill: 'solid',\n    shape: 'round',\n  };\n\n  multipleSelector: PopoverSelectorMetadata = {\n    options: [\n      { value: 'email', label: 'Email', icon: 'mail' },\n      { value: 'sms', label: 'SMS', icon: 'chatbox' },\n      { value: 'push', label: 'Push', icon: 'notifications' },\n      { value: 'in-app', label: 'In-App', icon: 'apps' },\n    ],\n    selectedValue: ['email', 'push'],\n    label: 'Notificaciones',\n    icon: 'notifications-circle',\n    multiple: true,\n    color: 'tertiary',\n    size: 'default',\n    fill: 'outline',\n    showCheckmark: true,\n  };\n\n  // ✅ Ejemplos de Language Selector (con soporte multiidioma)\n\n  // Los nombres de idiomas se obtienen automáticamente del sistema de contenido\n  // y se muestran traducidos según el idioma actual de la aplicación\n  basicLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    label: 'Idioma',\n    color: 'medium',\n    size: 'default',\n    fill: 'outline',\n  };\n\n  // Con banderas y nombres traducidos automáticamente\n  flagLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    label: 'Language / Idioma',\n    showFlags: true,\n    color: 'primary',\n    size: 'large',\n    fill: 'solid',\n  };\n\n  // Con nombres personalizados (sobrescribe las traducciones automáticas)\n  customLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: true,\n    labelConfig: {\n      className: '_global',\n      key: 'language',\n      fallback: 'Idioma',\n    },\n    showFlags: true,\n    color: 'secondary',\n    size: 'default',\n    fill: 'outline',\n    shape: 'round',\n    customLanguageNames: {\n      es: 'Español (España)',\n      en: 'English (US)',\n      fr: 'Français',\n      de: 'Deutsch',\n    },\n  };\n\n  // Compacto sin etiqueta, solo banderas y nombres traducidos\n  compactLanguageSelector: LanguageSelectorMetadata = {\n    showLabel: false,\n    showFlags: true,\n    color: 'tertiary',\n    size: 'small',\n    fill: 'clear',\n  };\n\n  // ✅ Event Handlers\n\n  onCategoryChange(category: string | string[]) {\n    console.log('Category changed:', category);\n  }\n\n  onPriorityChange(priority: string | string[]) {\n    console.log('Priority changed:', priority);\n  }\n\n  onMultipleChange(notifications: string | string[]) {\n    console.log('Notifications changed:', notifications);\n  }\n\n  onLanguageChange(language: string) {\n    console.log('Language changed to:', language);\n    // La aplicación automáticamente actualizará todos los nombres de idiomas\n    // según la nueva configuración de idioma seleccionada\n  }\n}\n"]}
@@ -39,6 +39,18 @@ const globalContentData = {
39
39
  language: 'Idioma',
40
40
  // Common confirmations
41
41
  areYouSure: '¿Estás seguro?',
42
+ // Language names (translated) - flat keys for type compatibility
43
+ languageName_es: 'Español',
44
+ languageName_en: 'Inglés',
45
+ languageName_fr: 'Francés',
46
+ languageName_de: 'Alemán',
47
+ languageName_pt: 'Portugués',
48
+ languageName_it: 'Italiano',
49
+ languageName_zh: 'Chino',
50
+ languageName_ja: 'Japonés',
51
+ languageName_ko: 'Coreano',
52
+ languageName_ru: 'Ruso',
53
+ languageName_ar: 'Árabe',
42
54
  deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',
43
55
  unsavedChanges: 'Tienes cambios sin guardar. ¿Deseas continuar?',
44
56
  // Common placeholders
@@ -71,8 +83,21 @@ const globalContentData = {
71
83
  success: 'Success',
72
84
  warning: 'Warning',
73
85
  info: 'Information',
86
+ language: 'Language',
74
87
  // Common confirmations
75
88
  areYouSure: 'Are you sure?',
89
+ // Language names (translated) - flat keys for type compatibility
90
+ languageName_es: 'Spanish',
91
+ languageName_en: 'English',
92
+ languageName_fr: 'French',
93
+ languageName_de: 'German',
94
+ languageName_pt: 'Portuguese',
95
+ languageName_it: 'Italian',
96
+ languageName_zh: 'Chinese',
97
+ languageName_ja: 'Japanese',
98
+ languageName_ko: 'Korean',
99
+ languageName_ru: 'Russian',
100
+ languageName_ar: 'Arabic',
76
101
  deleteConfirmation: 'Are you sure you want to delete {itemName}?',
77
102
  unsavedChanges: 'You have unsaved changes. Do you want to continue?',
78
103
  // Common placeholders
@@ -93,6 +118,19 @@ const globalContentData = {
93
118
  success: 'Succès',
94
119
  // Common confirmations
95
120
  areYouSure: 'Êtes-vous sûr?',
121
+ // Language names (translated) - flat keys for type compatibility
122
+ languageName_es: 'Espagnol',
123
+ languageName_en: 'Anglais',
124
+ languageName_fr: 'Français',
125
+ languageName_de: 'Allemand',
126
+ languageName_pt: 'Portugais',
127
+ languageName_it: 'Italien',
128
+ languageName_zh: 'Chinois',
129
+ languageName_ja: 'Japonais',
130
+ languageName_ko: 'Coréen',
131
+ languageName_ru: 'Russe',
132
+ languageName_ar: 'Arabe',
133
+ language: 'Langue',
96
134
  },
97
135
  de: {
98
136
  // Common buttons - Another example of partial translation
@@ -105,14 +143,44 @@ const globalContentData = {
105
143
  error: 'Fehler',
106
144
  // Common confirmations
107
145
  areYouSure: 'Sind Sie sicher?',
146
+ // Language names (translated) - flat keys for type compatibility
147
+ languageName_es: 'Spanisch',
148
+ languageName_en: 'Englisch',
149
+ languageName_fr: 'Französisch',
150
+ languageName_de: 'Deutsch',
151
+ languageName_pt: 'Portugiesisch',
152
+ languageName_it: 'Italienisch',
153
+ languageName_zh: 'Chinesisch',
154
+ languageName_ja: 'Japanisch',
155
+ languageName_ko: 'Koreanisch',
156
+ languageName_ru: 'Russisch',
157
+ languageName_ar: 'Arabisch',
158
+ language: 'Sprache',
108
159
  },
109
160
  };
110
161
  const GlobalContent = new TextContent(globalContentData);
111
162
  const content = {
112
163
  _global: GlobalContent,
113
164
  LangSettings,
165
+ testReactivity: new TextContent({
166
+ es: {
167
+ welcomeMessage: '¡Bienvenido!',
168
+ saveButton: 'Guardar',
169
+ cancelButton: 'Cancelar',
170
+ },
171
+ en: {
172
+ welcomeMessage: 'Welcome!',
173
+ saveButton: 'Save',
174
+ cancelButton: 'Cancel',
175
+ },
176
+ fr: {
177
+ welcomeMessage: 'Bienvenue!',
178
+ saveButton: 'Enregistrer',
179
+ cancelButton: 'Annuler',
180
+ },
181
+ }),
114
182
  };
115
183
  export default content;
116
184
  // Export named exports for user convenience
117
185
  export { content, GlobalContent, globalContentData };
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../../../../projects/valtech-components/src/lib/services/lang-provider/content.ts"],"names":[],"mappings":"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","sourcesContent":["import DisplayDemo from './components/display-demo';\nimport LangSettings from './components/lang-settings';\nimport { LanguagesContent, TextContent } from './types';\n\nexport interface Provider {\n  [x: string]: TextContent;\n}\n\n/**\n * Global content that can be used across all components.\n * These are common texts like buttons, actions, states, etc.\n * Structure: {es: {key1: 'value1', key2: 'value2'}, en: {key1: 'value1', key2: 'value2'}, fr: {...}}\n *\n * Note: You can add any language code. The system will automatically detect available languages\n * and provide intelligent fallbacks with warnings for missing translations.\n */\nconst globalContentData: LanguagesContent = {\n  es: {\n    // Common buttons\n    ok: 'Aceptar',\n    cancel: 'Cancelar',\n    save: 'Guardar',\n    delete: 'Eliminar',\n    edit: 'Editar',\n    close: 'Cerrar',\n    back: 'Volver',\n    next: 'Siguiente',\n    previous: 'Anterior',\n    finish: 'Finalizar',\n    continue: 'Continuar',\n\n    // Common actions\n    add: 'Agregar',\n    remove: 'Quitar',\n    search: 'Buscar',\n    filter: 'Filtrar',\n    sort: 'Ordenar',\n    refresh: 'Actualizar',\n\n    // Common states and messages\n    loading: 'Cargando...',\n    noData: 'No hay datos disponibles',\n    error: 'Error',\n    success: 'Éxito',\n    warning: 'Advertencia',\n    info: 'Información',\n    language: 'Idioma',\n\n    // Common confirmations\n    areYouSure: '¿Estás seguro?',\n    deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',\n    unsavedChanges: 'Tienes cambios sin guardar. ¿Deseas continuar?',\n\n    // Common placeholders\n    searchPlaceholder: 'Buscar...',\n  },\n  en: {\n    // Common buttons\n    ok: 'OK',\n    cancel: 'Cancel',\n    save: 'Save',\n    delete: 'Delete',\n    edit: 'Edit',\n    close: 'Close',\n    back: 'Back',\n    next: 'Next',\n    previous: 'Previous',\n    finish: 'Finish',\n    continue: 'Continue',\n\n    // Common actions\n    add: 'Add',\n    remove: 'Remove',\n    search: 'Search',\n    filter: 'Filter',\n    sort: 'Sort',\n    refresh: 'Refresh',\n\n    // Common states and messages\n    loading: 'Loading...',\n    noData: 'No data available',\n    error: 'Error',\n    success: 'Success',\n    warning: 'Warning',\n    info: 'Information',\n\n    // Common confirmations\n    areYouSure: 'Are you sure?',\n    deleteConfirmation: 'Are you sure you want to delete {itemName}?',\n    unsavedChanges: 'You have unsaved changes. Do you want to continue?',\n\n    // Common placeholders\n    searchPlaceholder: 'Search...',\n  },\n  fr: {\n    // Common buttons - Example of partial translation (missing some keys intentionally)\n    ok: 'OK',\n    cancel: 'Annuler',\n    save: 'Sauvegarder',\n    delete: 'Supprimer',\n    edit: 'Modifier',\n    close: 'Fermer',\n    back: 'Retour',\n\n    // Common states and messages (intentionally incomplete to show fallback behavior)\n    loading: 'Chargement...',\n    error: 'Erreur',\n    success: 'Succès',\n\n    // Common confirmations\n    areYouSure: 'Êtes-vous sûr?',\n  },\n  de: {\n    // Common buttons - Another example of partial translation\n    ok: 'OK',\n    cancel: 'Abbrechen',\n    save: 'Speichern',\n    delete: 'Löschen',\n\n    // Common states and messages\n    loading: 'Laden...',\n    error: 'Fehler',\n\n    // Common confirmations\n    areYouSure: 'Sind Sie sicher?',\n  },\n};\n\nconst GlobalContent = new TextContent(globalContentData);\n\nconst content: Provider = {\n  _global: GlobalContent,\n  LangSettings,\n};\n\nexport default content;\n\n// Export named exports for user convenience\nexport { content, GlobalContent, globalContentData };\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../../../../projects/valtech-components/src/lib/services/lang-provider/content.ts"],"names":[],"mappings":"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","sourcesContent":["import LangSettings from './components/lang-settings';\nimport { LanguagesContent, TextContent } from './types';\n\nexport interface Provider {\n  [x: string]: TextContent;\n}\n\n/**\n * Global content that can be used across all components.\n * These are common texts like buttons, actions, states, etc.\n * Structure: {es: {key1: 'value1', key2: 'value2'}, en: {key1: 'value1', key2: 'value2'}, fr: {...}}\n *\n * Note: You can add any language code. The system will automatically detect available languages\n * and provide intelligent fallbacks with warnings for missing translations.\n */\nconst globalContentData: LanguagesContent = {\n  es: {\n    // Common buttons\n    ok: 'Aceptar',\n    cancel: 'Cancelar',\n    save: 'Guardar',\n    delete: 'Eliminar',\n    edit: 'Editar',\n    close: 'Cerrar',\n    back: 'Volver',\n    next: 'Siguiente',\n    previous: 'Anterior',\n    finish: 'Finalizar',\n    continue: 'Continuar',\n\n    // Common actions\n    add: 'Agregar',\n    remove: 'Quitar',\n    search: 'Buscar',\n    filter: 'Filtrar',\n    sort: 'Ordenar',\n    refresh: 'Actualizar',\n\n    // Common states and messages\n    loading: 'Cargando...',\n    noData: 'No hay datos disponibles',\n    error: 'Error',\n    success: 'Éxito',\n    warning: 'Advertencia',\n    info: 'Información',\n    language: 'Idioma',\n\n    // Common confirmations\n    areYouSure: '¿Estás seguro?',\n\n    // Language names (translated) - flat keys for type compatibility\n    languageName_es: 'Español',\n    languageName_en: 'Inglés',\n    languageName_fr: 'Francés',\n    languageName_de: 'Alemán',\n    languageName_pt: 'Portugués',\n    languageName_it: 'Italiano',\n    languageName_zh: 'Chino',\n    languageName_ja: 'Japonés',\n    languageName_ko: 'Coreano',\n    languageName_ru: 'Ruso',\n    languageName_ar: 'Árabe',\n    deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',\n    unsavedChanges: 'Tienes cambios sin guardar. ¿Deseas continuar?',\n\n    // Common placeholders\n    searchPlaceholder: 'Buscar...',\n  },\n  en: {\n    // Common buttons\n    ok: 'OK',\n    cancel: 'Cancel',\n    save: 'Save',\n    delete: 'Delete',\n    edit: 'Edit',\n    close: 'Close',\n    back: 'Back',\n    next: 'Next',\n    previous: 'Previous',\n    finish: 'Finish',\n    continue: 'Continue',\n\n    // Common actions\n    add: 'Add',\n    remove: 'Remove',\n    search: 'Search',\n    filter: 'Filter',\n    sort: 'Sort',\n    refresh: 'Refresh',\n\n    // Common states and messages\n    loading: 'Loading...',\n    noData: 'No data available',\n    error: 'Error',\n    success: 'Success',\n    warning: 'Warning',\n    info: 'Information',\n    language: 'Language',\n\n    // Common confirmations\n    areYouSure: 'Are you sure?',\n\n    // Language names (translated) - flat keys for type compatibility\n    languageName_es: 'Spanish',\n    languageName_en: 'English',\n    languageName_fr: 'French',\n    languageName_de: 'German',\n    languageName_pt: 'Portuguese',\n    languageName_it: 'Italian',\n    languageName_zh: 'Chinese',\n    languageName_ja: 'Japanese',\n    languageName_ko: 'Korean',\n    languageName_ru: 'Russian',\n    languageName_ar: 'Arabic',\n    deleteConfirmation: 'Are you sure you want to delete {itemName}?',\n    unsavedChanges: 'You have unsaved changes. Do you want to continue?',\n\n    // Common placeholders\n    searchPlaceholder: 'Search...',\n  },\n  fr: {\n    // Common buttons - Example of partial translation (missing some keys intentionally)\n    ok: 'OK',\n    cancel: 'Annuler',\n    save: 'Sauvegarder',\n    delete: 'Supprimer',\n    edit: 'Modifier',\n    close: 'Fermer',\n    back: 'Retour',\n\n    // Common states and messages (intentionally incomplete to show fallback behavior)\n    loading: 'Chargement...',\n    error: 'Erreur',\n    success: 'Succès',\n\n    // Common confirmations\n    areYouSure: 'Êtes-vous sûr?',\n\n    // Language names (translated) - flat keys for type compatibility\n    languageName_es: 'Espagnol',\n    languageName_en: 'Anglais',\n    languageName_fr: 'Français',\n    languageName_de: 'Allemand',\n    languageName_pt: 'Portugais',\n    languageName_it: 'Italien',\n    languageName_zh: 'Chinois',\n    languageName_ja: 'Japonais',\n    languageName_ko: 'Coréen',\n    languageName_ru: 'Russe',\n    languageName_ar: 'Arabe',\n    language: 'Langue',\n  },\n  de: {\n    // Common buttons - Another example of partial translation\n    ok: 'OK',\n    cancel: 'Abbrechen',\n    save: 'Speichern',\n    delete: 'Löschen',\n\n    // Common states and messages\n    loading: 'Laden...',\n    error: 'Fehler',\n\n    // Common confirmations\n    areYouSure: 'Sind Sie sicher?',\n\n    // Language names (translated) - flat keys for type compatibility\n    languageName_es: 'Spanisch',\n    languageName_en: 'Englisch',\n    languageName_fr: 'Französisch',\n    languageName_de: 'Deutsch',\n    languageName_pt: 'Portugiesisch',\n    languageName_it: 'Italienisch',\n    languageName_zh: 'Chinesisch',\n    languageName_ja: 'Japanisch',\n    languageName_ko: 'Koreanisch',\n    languageName_ru: 'Russisch',\n    languageName_ar: 'Arabisch',\n    language: 'Sprache',\n  },\n};\n\nconst GlobalContent = new TextContent(globalContentData);\n\nconst content: Provider = {\n  _global: GlobalContent,\n  LangSettings,\n  testReactivity: new TextContent({\n    es: {\n      welcomeMessage: '¡Bienvenido!',\n      saveButton: 'Guardar',\n      cancelButton: 'Cancelar',\n    },\n    en: {\n      welcomeMessage: 'Welcome!',\n      saveButton: 'Save',\n      cancelButton: 'Cancel',\n    },\n    fr: {\n      welcomeMessage: 'Bienvenue!',\n      saveButton: 'Enregistrer',\n      cancelButton: 'Annuler',\n    },\n  }),\n};\n\nexport default content;\n\n// Export named exports for user convenience\nexport { content, GlobalContent, globalContentData };\n"]}