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.
- package/esm2022/lib/components/molecules/language-selector/language-selector.component.mjs +24 -13
- package/esm2022/lib/components/molecules/popover-selector/popover-selector.component.mjs +3 -3
- package/esm2022/lib/examples/reactive-components-demo.component.mjs +303 -0
- package/esm2022/lib/examples/reactivity-test.component.mjs +200 -0
- package/esm2022/lib/examples/selector-examples.component.mjs +37 -11
- package/esm2022/lib/services/lang-provider/content.mjs +69 -1
- package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +2 -2
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/valtech-components.mjs +617 -26
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/examples/reactive-components-demo.component.d.ts +45 -0
- package/lib/examples/reactivity-test.component.d.ts +27 -0
- package/lib/examples/selector-examples.component.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/esm2022/lib/services/lang-provider/components/display-demo.mjs +0 -86
- package/lib/services/lang-provider/components/display-demo.d.ts +0 -3
|
@@ -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":"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","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"]}
|