valtech-components 2.0.292 → 2.0.294

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/esm2022/lib/components/atoms/avatar/avatar.component.mjs +3 -3
  2. package/esm2022/lib/components/atoms/box/box.component.mjs +3 -3
  3. package/esm2022/lib/components/atoms/button/button.component.mjs +45 -12
  4. package/esm2022/lib/components/atoms/display/display.component.mjs +47 -11
  5. package/esm2022/lib/components/atoms/display/types.mjs +1 -1
  6. package/esm2022/lib/components/atoms/divider/divider.component.mjs +3 -3
  7. package/esm2022/lib/components/atoms/href/href.component.mjs +3 -3
  8. package/esm2022/lib/components/atoms/icon/icon.component.mjs +3 -3
  9. package/esm2022/lib/components/atoms/image/image.component.mjs +3 -3
  10. package/esm2022/lib/components/atoms/progress-bar/progress-bar.component.mjs +3 -3
  11. package/esm2022/lib/components/atoms/text/text.component.mjs +3 -3
  12. package/esm2022/lib/components/atoms/title/title.component.mjs +77 -23
  13. package/esm2022/lib/components/atoms/title/types.mjs +30 -2
  14. package/esm2022/lib/components/molecules/alert-box/alert-box.component.mjs +57 -10
  15. package/esm2022/lib/components/molecules/alert-box/types.mjs +1 -1
  16. package/esm2022/lib/components/molecules/button-group/button-group.component.mjs +3 -3
  17. package/esm2022/lib/components/molecules/card/card.component.mjs +3 -3
  18. package/esm2022/lib/components/molecules/content-loader/content-loader.component.mjs +3 -3
  19. package/esm2022/lib/components/molecules/date-input/date-input.component.mjs +3 -3
  20. package/esm2022/lib/components/molecules/file-input/file-input.component.mjs +3 -3
  21. package/esm2022/lib/components/molecules/hint/hint.component.mjs +3 -3
  22. package/esm2022/lib/components/molecules/language-selector/language-selector.component.mjs +219 -0
  23. package/esm2022/lib/components/molecules/language-selector/types.mjs +2 -0
  24. package/esm2022/lib/components/molecules/layered-card/layered-card.component.mjs +3 -3
  25. package/esm2022/lib/components/molecules/link/link.component.mjs +3 -3
  26. package/esm2022/lib/components/molecules/links-cake/links-cake.component.mjs +3 -3
  27. package/esm2022/lib/components/molecules/notes-box/notes-box.component.mjs +3 -3
  28. package/esm2022/lib/components/molecules/password-input/password-input.component.mjs +3 -3
  29. package/esm2022/lib/components/molecules/pin-input/pin-input.component.mjs +3 -3
  30. package/esm2022/lib/components/molecules/popover-selector/popover-selector.component.mjs +170 -0
  31. package/esm2022/lib/components/molecules/popover-selector/types.mjs +2 -0
  32. package/esm2022/lib/components/molecules/progress-status/progress-status.component.mjs +3 -3
  33. package/esm2022/lib/components/molecules/prompter/prompter.component.mjs +3 -3
  34. package/esm2022/lib/components/molecules/searchbar/searchbar.component.mjs +3 -3
  35. package/esm2022/lib/components/molecules/text-input/text-input.component.mjs +3 -3
  36. package/esm2022/lib/components/molecules/title-block/title-block.component.mjs +3 -3
  37. package/esm2022/lib/components/organisms/banner/banner.component.mjs +3 -3
  38. package/esm2022/lib/components/organisms/form/form.component.mjs +3 -3
  39. package/esm2022/lib/components/organisms/header/header.component.mjs +3 -3
  40. package/esm2022/lib/components/organisms/item-list/item-list.component.mjs +3 -3
  41. package/esm2022/lib/components/organisms/item-list/types.mjs +1 -1
  42. package/esm2022/lib/components/organisms/no-content/no-content.component.mjs +3 -3
  43. package/esm2022/lib/components/organisms/toolbar/toolbar.component.mjs +3 -3
  44. package/esm2022/lib/components/organisms/wizard/wizard.component.mjs +3 -3
  45. package/esm2022/lib/components/templates/layout/layout.component.mjs +2 -2
  46. package/esm2022/lib/components/types.mjs +1 -1
  47. package/esm2022/lib/examples/display-demo.component.mjs +518 -0
  48. package/esm2022/lib/examples/display-simple-example.component.mjs +202 -0
  49. package/esm2022/lib/examples/selector-examples.component.mjs +208 -0
  50. package/esm2022/lib/services/lang-provider/components/display-demo.mjs +86 -0
  51. package/esm2022/lib/services/lang-provider/content.mjs +2 -1
  52. package/esm2022/lib/shared/utils/reactive-content.mjs +117 -0
  53. package/esm2022/public-api.mjs +9 -1
  54. package/fesm2022/valtech-components.mjs +3435 -1844
  55. package/fesm2022/valtech-components.mjs.map +1 -1
  56. package/lib/components/atoms/button/button.component.d.ts +10 -3
  57. package/lib/components/atoms/display/display.component.d.ts +12 -4
  58. package/lib/components/atoms/display/types.d.ts +13 -3
  59. package/lib/components/atoms/title/title.component.d.ts +6 -1
  60. package/lib/components/atoms/title/types.d.ts +29 -3
  61. package/lib/components/molecules/alert-box/alert-box.component.d.ts +17 -9
  62. package/lib/components/molecules/alert-box/types.d.ts +29 -0
  63. package/lib/components/molecules/language-selector/language-selector.component.d.ts +50 -0
  64. package/lib/components/molecules/language-selector/types.d.ts +52 -0
  65. package/lib/components/molecules/popover-selector/popover-selector.component.d.ts +29 -0
  66. package/lib/components/molecules/popover-selector/types.d.ts +69 -0
  67. package/lib/components/organisms/item-list/types.d.ts +54 -9
  68. package/lib/components/types.d.ts +12 -3
  69. package/lib/examples/display-demo.component.d.ts +62 -0
  70. package/lib/examples/display-simple-example.component.d.ts +23 -0
  71. package/lib/examples/selector-examples.component.d.ts +20 -0
  72. package/lib/services/lang-provider/components/display-demo.d.ts +3 -0
  73. package/lib/shared/utils/reactive-content.d.ts +109 -0
  74. package/package.json +4 -2
  75. package/public-api.d.ts +8 -0
  76. package/src/lib/components/styles/overrides.scss +583 -0
  77. package/src/lib/components/styles/variables.scss +7 -3
@@ -0,0 +1,202 @@
1
+ import { Component } from '@angular/core';
2
+ import { DisplayComponent } from '../components/atoms/display/display.component';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * Ejemplo rápido de uso del componente val-display con contenido reactivo
6
+ */
7
+ export class DisplayExampleComponent {
8
+ constructor() {
9
+ // ✅ Ejemplos de contenido estático
10
+ this.staticTitle = {
11
+ content: 'Este es un título estático',
12
+ color: 'primary',
13
+ size: 'xlarge',
14
+ };
15
+ this.staticSubtitle = {
16
+ content: 'Este es un subtítulo que no cambia',
17
+ color: 'medium',
18
+ size: 'large',
19
+ };
20
+ // ✅ Ejemplos de contenido reactivo (requiere configuración de i18n)
21
+ this.reactiveWelcome = {
22
+ contentConfig: {
23
+ className: 'displayExample',
24
+ key: 'welcome.title',
25
+ fallback: 'Bienvenido a la aplicación',
26
+ },
27
+ color: 'primary',
28
+ size: 'xlarge',
29
+ };
30
+ this.reactiveDescription = {
31
+ contentConfig: {
32
+ className: 'displayExample',
33
+ key: 'welcome.description',
34
+ fallback: 'Esta descripción cambia según el idioma',
35
+ },
36
+ color: 'dark',
37
+ size: 'medium',
38
+ };
39
+ // ✅ Ejemplos con interpolación de variables
40
+ this.userGreeting = {
41
+ contentConfig: {
42
+ className: 'displayExample',
43
+ key: 'user.greeting',
44
+ fallback: 'Hola, {{name}}! Tienes {{messages}} mensajes.',
45
+ interpolation: {
46
+ name: 'María',
47
+ messages: 5,
48
+ },
49
+ },
50
+ color: 'tertiary',
51
+ size: 'large',
52
+ };
53
+ this.statusMessage = {
54
+ contentConfig: {
55
+ className: 'displayExample',
56
+ key: 'status.online',
57
+ fallback: 'Estado: {{status}} desde {{time}}',
58
+ interpolation: {
59
+ status: 'En línea',
60
+ time: '10:30 AM',
61
+ },
62
+ },
63
+ color: 'success',
64
+ size: 'small',
65
+ };
66
+ // ✅ Ejemplos de diferentes tamaños
67
+ this.smallText = {
68
+ content: 'Texto pequeño (small)',
69
+ color: 'dark',
70
+ size: 'small',
71
+ };
72
+ this.mediumText = {
73
+ content: 'Texto mediano (medium)',
74
+ color: 'dark',
75
+ size: 'medium',
76
+ };
77
+ this.largeText = {
78
+ content: 'Texto grande (large)',
79
+ color: 'dark',
80
+ size: 'large',
81
+ };
82
+ this.xlargeText = {
83
+ content: 'Texto extra grande (xlarge)',
84
+ color: 'dark',
85
+ size: 'xlarge',
86
+ };
87
+ // ✅ Ejemplos de diferentes colores
88
+ this.primaryText = {
89
+ content: 'Texto color primary',
90
+ color: 'primary',
91
+ size: 'medium',
92
+ };
93
+ this.successText = {
94
+ content: 'Texto color success',
95
+ color: 'success',
96
+ size: 'medium',
97
+ };
98
+ this.warningText = {
99
+ content: 'Texto color warning',
100
+ color: 'warning',
101
+ size: 'medium',
102
+ };
103
+ this.dangerText = {
104
+ content: 'Texto color danger',
105
+ color: 'danger',
106
+ size: 'medium',
107
+ };
108
+ }
109
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayExampleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
110
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DisplayExampleComponent, isStandalone: true, selector: "app-display-example", ngImport: i0, template: `
111
+ <div class="display-examples">
112
+ <h2>Ejemplos de val-display</h2>
113
+
114
+ <!-- Contenido estático -->
115
+ <div class="section">
116
+ <h3>Contenido Estático</h3>
117
+ <val-display [props]="staticTitle"></val-display>
118
+ <val-display [props]="staticSubtitle"></val-display>
119
+ </div>
120
+
121
+ <!-- Contenido reactivo -->
122
+ <div class="section">
123
+ <h3>Contenido Reactivo</h3>
124
+ <val-display [props]="reactiveWelcome"></val-display>
125
+ <val-display [props]="reactiveDescription"></val-display>
126
+ </div>
127
+
128
+ <!-- Contenido con interpolación -->
129
+ <div class="section">
130
+ <h3>Contenido con Variables</h3>
131
+ <val-display [props]="userGreeting"></val-display>
132
+ <val-display [props]="statusMessage"></val-display>
133
+ </div>
134
+
135
+ <!-- Diferentes tamaños -->
136
+ <div class="section">
137
+ <h3>Diferentes Tamaños</h3>
138
+ <val-display [props]="smallText"></val-display>
139
+ <val-display [props]="mediumText"></val-display>
140
+ <val-display [props]="largeText"></val-display>
141
+ <val-display [props]="xlargeText"></val-display>
142
+ </div>
143
+
144
+ <!-- Diferentes colores -->
145
+ <div class="section">
146
+ <h3>Diferentes Colores</h3>
147
+ <val-display [props]="primaryText"></val-display>
148
+ <val-display [props]="successText"></val-display>
149
+ <val-display [props]="warningText"></val-display>
150
+ <val-display [props]="dangerText"></val-display>
151
+ </div>
152
+ </div>
153
+ `, isInline: true, styles: [".display-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 15px;color:var(--ion-color-primary)}val-display{display:block;margin:10px 0}\n"], dependencies: [{ kind: "component", type: DisplayComponent, selector: "val-display", inputs: ["props"] }] }); }
154
+ }
155
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DisplayExampleComponent, decorators: [{
156
+ type: Component,
157
+ args: [{ selector: 'app-display-example', standalone: true, imports: [DisplayComponent], template: `
158
+ <div class="display-examples">
159
+ <h2>Ejemplos de val-display</h2>
160
+
161
+ <!-- Contenido estático -->
162
+ <div class="section">
163
+ <h3>Contenido Estático</h3>
164
+ <val-display [props]="staticTitle"></val-display>
165
+ <val-display [props]="staticSubtitle"></val-display>
166
+ </div>
167
+
168
+ <!-- Contenido reactivo -->
169
+ <div class="section">
170
+ <h3>Contenido Reactivo</h3>
171
+ <val-display [props]="reactiveWelcome"></val-display>
172
+ <val-display [props]="reactiveDescription"></val-display>
173
+ </div>
174
+
175
+ <!-- Contenido con interpolación -->
176
+ <div class="section">
177
+ <h3>Contenido con Variables</h3>
178
+ <val-display [props]="userGreeting"></val-display>
179
+ <val-display [props]="statusMessage"></val-display>
180
+ </div>
181
+
182
+ <!-- Diferentes tamaños -->
183
+ <div class="section">
184
+ <h3>Diferentes Tamaños</h3>
185
+ <val-display [props]="smallText"></val-display>
186
+ <val-display [props]="mediumText"></val-display>
187
+ <val-display [props]="largeText"></val-display>
188
+ <val-display [props]="xlargeText"></val-display>
189
+ </div>
190
+
191
+ <!-- Diferentes colores -->
192
+ <div class="section">
193
+ <h3>Diferentes Colores</h3>
194
+ <val-display [props]="primaryText"></val-display>
195
+ <val-display [props]="successText"></val-display>
196
+ <val-display [props]="warningText"></val-display>
197
+ <val-display [props]="dangerText"></val-display>
198
+ </div>
199
+ </div>
200
+ `, styles: [".display-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 15px;color:var(--ion-color-primary)}val-display{display:block;margin:10px 0}\n"] }]
201
+ }] });
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"display-simple-example.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/display-simple-example.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { DisplayComponent } from '../components/atoms/display/display.component';\nimport { DisplayMetadata } from '../components/atoms/display/types';\n\n/**\n * Ejemplo rápido de uso del componente val-display con contenido reactivo\n */\n@Component({\n  selector: 'app-display-example',\n  standalone: true,\n  imports: [DisplayComponent],\n  template: `\n    <div class=\"display-examples\">\n      <h2>Ejemplos de val-display</h2>\n\n      <!-- Contenido estático -->\n      <div class=\"section\">\n        <h3>Contenido Estático</h3>\n        <val-display [props]=\"staticTitle\"></val-display>\n        <val-display [props]=\"staticSubtitle\"></val-display>\n      </div>\n\n      <!-- Contenido reactivo -->\n      <div class=\"section\">\n        <h3>Contenido Reactivo</h3>\n        <val-display [props]=\"reactiveWelcome\"></val-display>\n        <val-display [props]=\"reactiveDescription\"></val-display>\n      </div>\n\n      <!-- Contenido con interpolación -->\n      <div class=\"section\">\n        <h3>Contenido con Variables</h3>\n        <val-display [props]=\"userGreeting\"></val-display>\n        <val-display [props]=\"statusMessage\"></val-display>\n      </div>\n\n      <!-- Diferentes tamaños -->\n      <div class=\"section\">\n        <h3>Diferentes Tamaños</h3>\n        <val-display [props]=\"smallText\"></val-display>\n        <val-display [props]=\"mediumText\"></val-display>\n        <val-display [props]=\"largeText\"></val-display>\n        <val-display [props]=\"xlargeText\"></val-display>\n      </div>\n\n      <!-- Diferentes colores -->\n      <div class=\"section\">\n        <h3>Diferentes Colores</h3>\n        <val-display [props]=\"primaryText\"></val-display>\n        <val-display [props]=\"successText\"></val-display>\n        <val-display [props]=\"warningText\"></val-display>\n        <val-display [props]=\"dangerText\"></val-display>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .display-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 15px 0;\n        color: var(--ion-color-primary);\n      }\n\n      val-display {\n        display: block;\n        margin: 10px 0;\n      }\n    `,\n  ],\n})\nexport class DisplayExampleComponent {\n  // ✅ Ejemplos de contenido estático\n  staticTitle: DisplayMetadata = {\n    content: 'Este es un título estático',\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  staticSubtitle: DisplayMetadata = {\n    content: 'Este es un subtítulo que no cambia',\n    color: 'medium',\n    size: 'large',\n  };\n\n  // ✅ Ejemplos de contenido reactivo (requiere configuración de i18n)\n  reactiveWelcome: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'welcome.title',\n      fallback: 'Bienvenido a la aplicación',\n    },\n    color: 'primary',\n    size: 'xlarge',\n  };\n\n  reactiveDescription: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'welcome.description',\n      fallback: 'Esta descripción cambia según el idioma',\n    },\n    color: 'dark',\n    size: 'medium',\n  };\n\n  // ✅ Ejemplos con interpolación de variables\n  userGreeting: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'user.greeting',\n      fallback: 'Hola, {{name}}! Tienes {{messages}} mensajes.',\n      interpolation: {\n        name: 'María',\n        messages: 5,\n      },\n    },\n    color: 'tertiary',\n    size: 'large',\n  };\n\n  statusMessage: DisplayMetadata = {\n    contentConfig: {\n      className: 'displayExample',\n      key: 'status.online',\n      fallback: 'Estado: {{status}} desde {{time}}',\n      interpolation: {\n        status: 'En línea',\n        time: '10:30 AM',\n      },\n    },\n    color: 'success',\n    size: 'small',\n  };\n\n  // ✅ Ejemplos de diferentes tamaños\n  smallText: DisplayMetadata = {\n    content: 'Texto pequeño (small)',\n    color: 'dark',\n    size: 'small',\n  };\n\n  mediumText: DisplayMetadata = {\n    content: 'Texto mediano (medium)',\n    color: 'dark',\n    size: 'medium',\n  };\n\n  largeText: DisplayMetadata = {\n    content: 'Texto grande (large)',\n    color: 'dark',\n    size: 'large',\n  };\n\n  xlargeText: DisplayMetadata = {\n    content: 'Texto extra grande (xlarge)',\n    color: 'dark',\n    size: 'xlarge',\n  };\n\n  // ✅ Ejemplos de diferentes colores\n  primaryText: DisplayMetadata = {\n    content: 'Texto color primary',\n    color: 'primary',\n    size: 'medium',\n  };\n\n  successText: DisplayMetadata = {\n    content: 'Texto color success',\n    color: 'success',\n    size: 'medium',\n  };\n\n  warningText: DisplayMetadata = {\n    content: 'Texto color warning',\n    color: 'warning',\n    size: 'medium',\n  };\n\n  dangerText: DisplayMetadata = {\n    content: 'Texto color danger',\n    color: 'danger',\n    size: 'medium',\n  };\n}\n"]}
@@ -0,0 +1,208 @@
1
+ import { Component } from '@angular/core';
2
+ import { LanguageSelectorComponent } from '../components/molecules/language-selector/language-selector.component';
3
+ import { PopoverSelectorComponent } from '../components/molecules/popover-selector/popover-selector.component';
4
+ import * as i0 from "@angular/core";
5
+ /**
6
+ * Ejemplo de uso de los componentes popover-selector y language-selector
7
+ */
8
+ export class SelectorExamplesComponent {
9
+ constructor() {
10
+ // ✅ Ejemplos de Popover Selector Genérico
11
+ this.categorySelector = {
12
+ options: [
13
+ { value: 'work', label: 'Trabajo', icon: 'briefcase' },
14
+ { value: 'personal', label: 'Personal', icon: 'person' },
15
+ { value: 'travel', label: 'Viajes', icon: 'airplane' },
16
+ { value: 'health', label: 'Salud', icon: 'fitness' },
17
+ ],
18
+ selectedValue: 'work',
19
+ label: 'Categoría',
20
+ icon: 'folder',
21
+ color: 'primary',
22
+ size: 'default',
23
+ fill: 'outline',
24
+ };
25
+ this.prioritySelector = {
26
+ options: [
27
+ { value: 'low', label: 'Baja', icon: 'arrow-down', disabled: false },
28
+ { value: 'medium', label: 'Media', icon: 'remove' },
29
+ { value: 'high', label: 'Alta', icon: 'arrow-up' },
30
+ { value: 'urgent', label: 'Urgente', icon: 'warning' },
31
+ ],
32
+ selectedValue: 'medium',
33
+ label: 'Prioridad',
34
+ icon: 'flag',
35
+ color: 'warning',
36
+ size: 'large',
37
+ fill: 'solid',
38
+ shape: 'round',
39
+ };
40
+ this.multipleSelector = {
41
+ options: [
42
+ { value: 'email', label: 'Email', icon: 'mail' },
43
+ { value: 'sms', label: 'SMS', icon: 'chatbox' },
44
+ { value: 'push', label: 'Push', icon: 'notifications' },
45
+ { value: 'in-app', label: 'In-App', icon: 'apps' },
46
+ ],
47
+ selectedValue: ['email', 'push'],
48
+ label: 'Notificaciones',
49
+ icon: 'notifications-circle',
50
+ multiple: true,
51
+ color: 'tertiary',
52
+ size: 'default',
53
+ fill: 'outline',
54
+ showCheckmark: true,
55
+ };
56
+ // ✅ Ejemplos de Language Selector
57
+ this.basicLanguageSelector = {
58
+ showLabel: true,
59
+ label: 'Idioma',
60
+ color: 'medium',
61
+ size: 'default',
62
+ fill: 'outline',
63
+ };
64
+ this.flagLanguageSelector = {
65
+ showLabel: true,
66
+ label: 'Language / Idioma',
67
+ showFlags: true,
68
+ color: 'primary',
69
+ size: 'large',
70
+ fill: 'solid',
71
+ };
72
+ this.customLanguageSelector = {
73
+ showLabel: true,
74
+ labelConfig: {
75
+ className: '_global',
76
+ key: 'language',
77
+ fallback: 'Idioma',
78
+ },
79
+ showFlags: true,
80
+ color: 'secondary',
81
+ size: 'default',
82
+ fill: 'outline',
83
+ shape: 'round',
84
+ customLanguageNames: {
85
+ es: 'Español (España)',
86
+ en: 'English (US)',
87
+ fr: 'Français',
88
+ de: 'Deutsch',
89
+ },
90
+ };
91
+ }
92
+ // ✅ Event Handlers
93
+ onCategoryChange(category) {
94
+ console.log('Category changed:', category);
95
+ }
96
+ onPriorityChange(priority) {
97
+ console.log('Priority changed:', priority);
98
+ }
99
+ onMultipleChange(notifications) {
100
+ console.log('Notifications changed:', notifications);
101
+ }
102
+ onLanguageChange(language) {
103
+ console.log('Language changed:', language);
104
+ }
105
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorExamplesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
106
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectorExamplesComponent, isStandalone: true, selector: "app-selector-examples", ngImport: i0, template: `
107
+ <div class="selector-examples">
108
+ <h2>Ejemplos de Selectores</h2>
109
+
110
+ <!-- Popover Selector Genérico -->
111
+ <div class="section">
112
+ <h3>Popover Selector Genérico</h3>
113
+
114
+ <div class="example-group">
115
+ <h4>Selector de Categorías:</h4>
116
+ <val-popover-selector [props]="categorySelector" (selectionChange)="onCategoryChange($event)">
117
+ </val-popover-selector>
118
+ </div>
119
+
120
+ <div class="example-group">
121
+ <h4>Selector de Prioridad:</h4>
122
+ <val-popover-selector [props]="prioritySelector" (selectionChange)="onPriorityChange($event)">
123
+ </val-popover-selector>
124
+ </div>
125
+
126
+ <div class="example-group">
127
+ <h4>Selector Múltiple:</h4>
128
+ <val-popover-selector [props]="multipleSelector" (selectionChange)="onMultipleChange($event)">
129
+ </val-popover-selector>
130
+ </div>
131
+ </div>
132
+
133
+ <!-- Language Selector -->
134
+ <div class="section">
135
+ <h3>Selector de Idioma</h3>
136
+
137
+ <div class="example-group">
138
+ <h4>Selector Básico:</h4>
139
+ <val-language-selector [props]="basicLanguageSelector"> </val-language-selector>
140
+ </div>
141
+
142
+ <div class="example-group">
143
+ <h4>Selector con Banderas:</h4>
144
+ <val-language-selector [props]="flagLanguageSelector"> </val-language-selector>
145
+ </div>
146
+
147
+ <div class="example-group">
148
+ <h4>Selector Personalizado:</h4>
149
+ <val-language-selector [props]="customLanguageSelector" (languageChange)="onLanguageChange($event)">
150
+ </val-language-selector>
151
+ </div>
152
+ </div>
153
+ </div>
154
+ `, 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"] }] }); }
155
+ }
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorExamplesComponent, decorators: [{
157
+ type: Component,
158
+ args: [{ selector: 'app-selector-examples', standalone: true, imports: [PopoverSelectorComponent, LanguageSelectorComponent], template: `
159
+ <div class="selector-examples">
160
+ <h2>Ejemplos de Selectores</h2>
161
+
162
+ <!-- Popover Selector Genérico -->
163
+ <div class="section">
164
+ <h3>Popover Selector Genérico</h3>
165
+
166
+ <div class="example-group">
167
+ <h4>Selector de Categorías:</h4>
168
+ <val-popover-selector [props]="categorySelector" (selectionChange)="onCategoryChange($event)">
169
+ </val-popover-selector>
170
+ </div>
171
+
172
+ <div class="example-group">
173
+ <h4>Selector de Prioridad:</h4>
174
+ <val-popover-selector [props]="prioritySelector" (selectionChange)="onPriorityChange($event)">
175
+ </val-popover-selector>
176
+ </div>
177
+
178
+ <div class="example-group">
179
+ <h4>Selector Múltiple:</h4>
180
+ <val-popover-selector [props]="multipleSelector" (selectionChange)="onMultipleChange($event)">
181
+ </val-popover-selector>
182
+ </div>
183
+ </div>
184
+
185
+ <!-- Language Selector -->
186
+ <div class="section">
187
+ <h3>Selector de Idioma</h3>
188
+
189
+ <div class="example-group">
190
+ <h4>Selector Básico:</h4>
191
+ <val-language-selector [props]="basicLanguageSelector"> </val-language-selector>
192
+ </div>
193
+
194
+ <div class="example-group">
195
+ <h4>Selector con Banderas:</h4>
196
+ <val-language-selector [props]="flagLanguageSelector"> </val-language-selector>
197
+ </div>
198
+
199
+ <div class="example-group">
200
+ <h4>Selector Personalizado:</h4>
201
+ <val-language-selector [props]="customLanguageSelector" (languageChange)="onLanguageChange($event)">
202
+ </val-language-selector>
203
+ </div>
204
+ </div>
205
+ </div>
206
+ `, 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
+ }] });
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"]}
@@ -0,0 +1,86 @@
1
+ import { TextContent } from '../types';
2
+ /**
3
+ * Contenido específico para el componente de demostración de Display.
4
+ * Todas las claves son planas (sin anidación) ya que el sistema no soporta claves anidadas.
5
+ */
6
+ const displayDemoContent = {
7
+ es: {
8
+ // Página principal
9
+ pageTitle: 'Demostración del Componente Display',
10
+ // Secciones
11
+ sectionsStatic: 'Ejemplos Estáticos',
12
+ sectionsReactive: 'Ejemplos Reactivos',
13
+ sectionsMixed: 'Ejemplos Mixtos',
14
+ sectionsDynamic: 'Ejemplos Dinámicos',
15
+ sectionsAnalysis: 'Análisis de Idioma',
16
+ // Subsecciones
17
+ subsectionsReactiveContent: 'Contenido reactivo básico:',
18
+ subsectionsInterpolation: 'Contenido con interpolación:',
19
+ subsectionsFallback: 'Demostración de fallbacks:',
20
+ subsectionsMixedContent: 'Contenido estático vs reactivo:',
21
+ subsectionsDynamicContent: 'Contenido que se actualiza dinámicamente:',
22
+ // Contenido de bienvenida
23
+ welcomeTitle: 'Bienvenido a la aplicación',
24
+ welcomeDescription: 'Esta es una descripción de ejemplo',
25
+ welcomeUser: 'Hola, {{userName}}!',
26
+ // Estados y mensajes
27
+ statusOnline: 'En línea',
28
+ counterCurrent: 'Contador: {{count}}',
29
+ dynamicContent: 'Clics: {{count}}',
30
+ // Contenido mixto
31
+ mixedReactive: 'Este contenido sí cambia con el idioma',
32
+ // Botones
33
+ buttonsUpdateCounter: 'Actualizar Contador',
34
+ // Análisis
35
+ analysisCurrentLanguage: 'Idioma actual',
36
+ analysisAvailableLanguages: 'Idiomas disponibles',
37
+ },
38
+ en: {
39
+ // Main page
40
+ pageTitle: 'Display Component Demo',
41
+ // Sections
42
+ sectionsStatic: 'Static Examples',
43
+ sectionsReactive: 'Reactive Examples',
44
+ sectionsMixed: 'Mixed Examples',
45
+ sectionsDynamic: 'Dynamic Examples',
46
+ sectionsAnalysis: 'Language Analysis',
47
+ // Subsections
48
+ subsectionsReactiveContent: 'Basic reactive content:',
49
+ subsectionsInterpolation: 'Content with interpolation:',
50
+ subsectionsFallback: 'Fallback demonstration:',
51
+ subsectionsMixedContent: 'Static vs reactive content:',
52
+ subsectionsDynamicContent: 'Dynamically updating content:',
53
+ // Welcome content
54
+ welcomeTitle: 'Welcome to the application',
55
+ welcomeDescription: 'This is an example description',
56
+ welcomeUser: 'Hello, {{userName}}!',
57
+ // States and messages
58
+ statusOnline: 'Online',
59
+ counterCurrent: 'Counter: {{count}}',
60
+ dynamicContent: 'Clicks: {{count}}',
61
+ // Mixed content
62
+ mixedReactive: 'This content does change with language',
63
+ // Buttons
64
+ buttonsUpdateCounter: 'Update Counter',
65
+ // Analysis
66
+ analysisCurrentLanguage: 'Current language',
67
+ analysisAvailableLanguages: 'Available languages',
68
+ },
69
+ fr: {
70
+ // Page principale
71
+ pageTitle: 'Démonstration du Composant Display',
72
+ // Sections
73
+ sectionsStatic: 'Exemples Statiques',
74
+ sectionsReactive: 'Exemples Réactifs',
75
+ // Welcome content
76
+ welcomeTitle: "Bienvenue dans l'application",
77
+ welcomeUser: 'Bonjour, {{userName}}!',
78
+ // States and messages
79
+ statusOnline: 'En ligne',
80
+ counterCurrent: 'Compteur: {{count}}',
81
+ // Buttons
82
+ buttonsUpdateCounter: 'Mettre à jour le Compteur',
83
+ },
84
+ };
85
+ export default new TextContent(displayDemoContent);
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzcGxheS1kZW1vLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGVjaC1jb21wb25lbnRzL3NyYy9saWIvc2VydmljZXMvbGFuZy1wcm92aWRlci9jb21wb25lbnRzL2Rpc3BsYXktZGVtby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUV6RDs7O0dBR0c7QUFDSCxNQUFNLGtCQUFrQixHQUFxQjtJQUMzQyxFQUFFLEVBQUU7UUFDRixtQkFBbUI7UUFDbkIsU0FBUyxFQUFFLHFDQUFxQztRQUVoRCxZQUFZO1FBQ1osY0FBYyxFQUFFLG9CQUFvQjtRQUNwQyxnQkFBZ0IsRUFBRSxvQkFBb0I7UUFDdEMsYUFBYSxFQUFFLGlCQUFpQjtRQUNoQyxlQUFlLEVBQUUsb0JBQW9CO1FBQ3JDLGdCQUFnQixFQUFFLG9CQUFvQjtRQUV0QyxlQUFlO1FBQ2YsMEJBQTBCLEVBQUUsNEJBQTRCO1FBQ3hELHdCQUF3QixFQUFFLDhCQUE4QjtRQUN4RCxtQkFBbUIsRUFBRSw0QkFBNEI7UUFDakQsdUJBQXVCLEVBQUUsaUNBQWlDO1FBQzFELHlCQUF5QixFQUFFLDJDQUEyQztRQUV0RSwwQkFBMEI7UUFDMUIsWUFBWSxFQUFFLDRCQUE0QjtRQUMxQyxrQkFBa0IsRUFBRSxvQ0FBb0M7UUFDeEQsV0FBVyxFQUFFLHFCQUFxQjtRQUVsQyxxQkFBcUI7UUFDckIsWUFBWSxFQUFFLFVBQVU7UUFDeEIsY0FBYyxFQUFFLHFCQUFxQjtRQUNyQyxjQUFjLEVBQUUsa0JBQWtCO1FBRWxDLGtCQUFrQjtRQUNsQixhQUFhLEVBQUUsd0NBQXdDO1FBRXZELFVBQVU7UUFDVixvQkFBb0IsRUFBRSxxQkFBcUI7UUFFM0MsV0FBVztRQUNYLHVCQUF1QixFQUFFLGVBQWU7UUFDeEMsMEJBQTBCLEVBQUUscUJBQXFCO0tBQ2xEO0lBQ0QsRUFBRSxFQUFFO1FBQ0YsWUFBWTtRQUNaLFNBQVMsRUFBRSx3QkFBd0I7UUFFbkMsV0FBVztRQUNYLGNBQWMsRUFBRSxpQkFBaUI7UUFDakMsZ0JBQWdCLEVBQUUsbUJBQW1CO1FBQ3JDLGFBQWEsRUFBRSxnQkFBZ0I7UUFDL0IsZUFBZSxFQUFFLGtCQUFrQjtRQUNuQyxnQkFBZ0IsRUFBRSxtQkFBbUI7UUFFckMsY0FBYztRQUNkLDBCQUEwQixFQUFFLHlCQUF5QjtRQUNyRCx3QkFBd0IsRUFBRSw2QkFBNkI7UUFDdkQsbUJBQW1CLEVBQUUseUJBQXlCO1FBQzlDLHVCQUF1QixFQUFFLDZCQUE2QjtRQUN0RCx5QkFBeUIsRUFBRSwrQkFBK0I7UUFFMUQsa0JBQWtCO1FBQ2xCLFlBQVksRUFBRSw0QkFBNEI7UUFDMUMsa0JBQWtCLEVBQUUsZ0NBQWdDO1FBQ3BELFdBQVcsRUFBRSxzQkFBc0I7UUFFbkMsc0JBQXNCO1FBQ3RCLFlBQVksRUFBRSxRQUFRO1FBQ3RCLGNBQWMsRUFBRSxvQkFBb0I7UUFDcEMsY0FBYyxFQUFFLG1CQUFtQjtRQUVuQyxnQkFBZ0I7UUFDaEIsYUFBYSxFQUFFLHdDQUF3QztRQUV2RCxVQUFVO1FBQ1Ysb0JBQW9CLEVBQUUsZ0JBQWdCO1FBRXRDLFdBQVc7UUFDWCx1QkFBdUIsRUFBRSxrQkFBa0I7UUFDM0MsMEJBQTBCLEVBQUUscUJBQXFCO0tBQ2xEO0lBQ0QsRUFBRSxFQUFFO1FBQ0Ysa0JBQWtCO1FBQ2xCLFNBQVMsRUFBRSxvQ0FBb0M7UUFFL0MsV0FBVztRQUNYLGNBQWMsRUFBRSxvQkFBb0I7UUFDcEMsZ0JBQWdCLEVBQUUsbUJBQW1CO1FBRXJDLGtCQUFrQjtRQUNsQixZQUFZLEVBQUUsOEJBQThCO1FBQzVDLFdBQVcsRUFBRSx3QkFBd0I7UUFFckMsc0JBQXNCO1FBQ3RCLFlBQVksRUFBRSxVQUFVO1FBQ3hCLGNBQWMsRUFBRSxxQkFBcUI7UUFFckMsVUFBVTtRQUNWLG9CQUFvQixFQUFFLDJCQUEyQjtLQUNsRDtDQUNGLENBQUM7QUFFRixlQUFlLElBQUksV0FBVyxDQUFDLGtCQUFrQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYW5ndWFnZXNDb250ZW50LCBUZXh0Q29udGVudCB9IGZyb20gJy4uL3R5cGVzJztcblxuLyoqXG4gKiBDb250ZW5pZG8gZXNwZWPDrWZpY28gcGFyYSBlbCBjb21wb25lbnRlIGRlIGRlbW9zdHJhY2nDs24gZGUgRGlzcGxheS5cbiAqIFRvZGFzIGxhcyBjbGF2ZXMgc29uIHBsYW5hcyAoc2luIGFuaWRhY2nDs24pIHlhIHF1ZSBlbCBzaXN0ZW1hIG5vIHNvcG9ydGEgY2xhdmVzIGFuaWRhZGFzLlxuICovXG5jb25zdCBkaXNwbGF5RGVtb0NvbnRlbnQ6IExhbmd1YWdlc0NvbnRlbnQgPSB7XG4gIGVzOiB7XG4gICAgLy8gUMOhZ2luYSBwcmluY2lwYWxcbiAgICBwYWdlVGl0bGU6ICdEZW1vc3RyYWNpw7NuIGRlbCBDb21wb25lbnRlIERpc3BsYXknLFxuXG4gICAgLy8gU2VjY2lvbmVzXG4gICAgc2VjdGlvbnNTdGF0aWM6ICdFamVtcGxvcyBFc3TDoXRpY29zJyxcbiAgICBzZWN0aW9uc1JlYWN0aXZlOiAnRWplbXBsb3MgUmVhY3Rpdm9zJyxcbiAgICBzZWN0aW9uc01peGVkOiAnRWplbXBsb3MgTWl4dG9zJyxcbiAgICBzZWN0aW9uc0R5bmFtaWM6ICdFamVtcGxvcyBEaW7DoW1pY29zJyxcbiAgICBzZWN0aW9uc0FuYWx5c2lzOiAnQW7DoWxpc2lzIGRlIElkaW9tYScsXG5cbiAgICAvLyBTdWJzZWNjaW9uZXNcbiAgICBzdWJzZWN0aW9uc1JlYWN0aXZlQ29udGVudDogJ0NvbnRlbmlkbyByZWFjdGl2byBiw6FzaWNvOicsXG4gICAgc3Vic2VjdGlvbnNJbnRlcnBvbGF0aW9uOiAnQ29udGVuaWRvIGNvbiBpbnRlcnBvbGFjacOzbjonLFxuICAgIHN1YnNlY3Rpb25zRmFsbGJhY2s6ICdEZW1vc3RyYWNpw7NuIGRlIGZhbGxiYWNrczonLFxuICAgIHN1YnNlY3Rpb25zTWl4ZWRDb250ZW50OiAnQ29udGVuaWRvIGVzdMOhdGljbyB2cyByZWFjdGl2bzonLFxuICAgIHN1YnNlY3Rpb25zRHluYW1pY0NvbnRlbnQ6ICdDb250ZW5pZG8gcXVlIHNlIGFjdHVhbGl6YSBkaW7DoW1pY2FtZW50ZTonLFxuXG4gICAgLy8gQ29udGVuaWRvIGRlIGJpZW52ZW5pZGFcbiAgICB3ZWxjb21lVGl0bGU6ICdCaWVudmVuaWRvIGEgbGEgYXBsaWNhY2nDs24nLFxuICAgIHdlbGNvbWVEZXNjcmlwdGlvbjogJ0VzdGEgZXMgdW5hIGRlc2NyaXBjacOzbiBkZSBlamVtcGxvJyxcbiAgICB3ZWxjb21lVXNlcjogJ0hvbGEsIHt7dXNlck5hbWV9fSEnLFxuXG4gICAgLy8gRXN0YWRvcyB5IG1lbnNhamVzXG4gICAgc3RhdHVzT25saW5lOiAnRW4gbMOtbmVhJyxcbiAgICBjb3VudGVyQ3VycmVudDogJ0NvbnRhZG9yOiB7e2NvdW50fX0nLFxuICAgIGR5bmFtaWNDb250ZW50OiAnQ2xpY3M6IHt7Y291bnR9fScsXG5cbiAgICAvLyBDb250ZW5pZG8gbWl4dG9cbiAgICBtaXhlZFJlYWN0aXZlOiAnRXN0ZSBjb250ZW5pZG8gc8OtIGNhbWJpYSBjb24gZWwgaWRpb21hJyxcblxuICAgIC8vIEJvdG9uZXNcbiAgICBidXR0b25zVXBkYXRlQ291bnRlcjogJ0FjdHVhbGl6YXIgQ29udGFkb3InLFxuXG4gICAgLy8gQW7DoWxpc2lzXG4gICAgYW5hbHlzaXNDdXJyZW50TGFuZ3VhZ2U6ICdJZGlvbWEgYWN0dWFsJyxcbiAgICBhbmFseXNpc0F2YWlsYWJsZUxhbmd1YWdlczogJ0lkaW9tYXMgZGlzcG9uaWJsZXMnLFxuICB9LFxuICBlbjoge1xuICAgIC8vIE1haW4gcGFnZVxuICAgIHBhZ2VUaXRsZTogJ0Rpc3BsYXkgQ29tcG9uZW50IERlbW8nLFxuXG4gICAgLy8gU2VjdGlvbnNcbiAgICBzZWN0aW9uc1N0YXRpYzogJ1N0YXRpYyBFeGFtcGxlcycsXG4gICAgc2VjdGlvbnNSZWFjdGl2ZTogJ1JlYWN0aXZlIEV4YW1wbGVzJyxcbiAgICBzZWN0aW9uc01peGVkOiAnTWl4ZWQgRXhhbXBsZXMnLFxuICAgIHNlY3Rpb25zRHluYW1pYzogJ0R5bmFtaWMgRXhhbXBsZXMnLFxuICAgIHNlY3Rpb25zQW5hbHlzaXM6ICdMYW5ndWFnZSBBbmFseXNpcycsXG5cbiAgICAvLyBTdWJzZWN0aW9uc1xuICAgIHN1YnNlY3Rpb25zUmVhY3RpdmVDb250ZW50OiAnQmFzaWMgcmVhY3RpdmUgY29udGVudDonLFxuICAgIHN1YnNlY3Rpb25zSW50ZXJwb2xhdGlvbjogJ0NvbnRlbnQgd2l0aCBpbnRlcnBvbGF0aW9uOicsXG4gICAgc3Vic2VjdGlvbnNGYWxsYmFjazogJ0ZhbGxiYWNrIGRlbW9uc3RyYXRpb246JyxcbiAgICBzdWJzZWN0aW9uc01peGVkQ29udGVudDogJ1N0YXRpYyB2cyByZWFjdGl2ZSBjb250ZW50OicsXG4gICAgc3Vic2VjdGlvbnNEeW5hbWljQ29udGVudDogJ0R5bmFtaWNhbGx5IHVwZGF0aW5nIGNvbnRlbnQ6JyxcblxuICAgIC8vIFdlbGNvbWUgY29udGVudFxuICAgIHdlbGNvbWVUaXRsZTogJ1dlbGNvbWUgdG8gdGhlIGFwcGxpY2F0aW9uJyxcbiAgICB3ZWxjb21lRGVzY3JpcHRpb246ICdUaGlzIGlzIGFuIGV4YW1wbGUgZGVzY3JpcHRpb24nLFxuICAgIHdlbGNvbWVVc2VyOiAnSGVsbG8sIHt7dXNlck5hbWV9fSEnLFxuXG4gICAgLy8gU3RhdGVzIGFuZCBtZXNzYWdlc1xuICAgIHN0YXR1c09ubGluZTogJ09ubGluZScsXG4gICAgY291bnRlckN1cnJlbnQ6ICdDb3VudGVyOiB7e2NvdW50fX0nLFxuICAgIGR5bmFtaWNDb250ZW50OiAnQ2xpY2tzOiB7e2NvdW50fX0nLFxuXG4gICAgLy8gTWl4ZWQgY29udGVudFxuICAgIG1peGVkUmVhY3RpdmU6ICdUaGlzIGNvbnRlbnQgZG9lcyBjaGFuZ2Ugd2l0aCBsYW5ndWFnZScsXG5cbiAgICAvLyBCdXR0b25zXG4gICAgYnV0dG9uc1VwZGF0ZUNvdW50ZXI6ICdVcGRhdGUgQ291bnRlcicsXG5cbiAgICAvLyBBbmFseXNpc1xuICAgIGFuYWx5c2lzQ3VycmVudExhbmd1YWdlOiAnQ3VycmVudCBsYW5ndWFnZScsXG4gICAgYW5hbHlzaXNBdmFpbGFibGVMYW5ndWFnZXM6ICdBdmFpbGFibGUgbGFuZ3VhZ2VzJyxcbiAgfSxcbiAgZnI6IHtcbiAgICAvLyBQYWdlIHByaW5jaXBhbGVcbiAgICBwYWdlVGl0bGU6ICdEw6ltb25zdHJhdGlvbiBkdSBDb21wb3NhbnQgRGlzcGxheScsXG5cbiAgICAvLyBTZWN0aW9uc1xuICAgIHNlY3Rpb25zU3RhdGljOiAnRXhlbXBsZXMgU3RhdGlxdWVzJyxcbiAgICBzZWN0aW9uc1JlYWN0aXZlOiAnRXhlbXBsZXMgUsOpYWN0aWZzJyxcblxuICAgIC8vIFdlbGNvbWUgY29udGVudFxuICAgIHdlbGNvbWVUaXRsZTogXCJCaWVudmVudWUgZGFucyBsJ2FwcGxpY2F0aW9uXCIsXG4gICAgd2VsY29tZVVzZXI6ICdCb25qb3VyLCB7e3VzZXJOYW1lfX0hJyxcblxuICAgIC8vIFN0YXRlcyBhbmQgbWVzc2FnZXNcbiAgICBzdGF0dXNPbmxpbmU6ICdFbiBsaWduZScsXG4gICAgY291bnRlckN1cnJlbnQ6ICdDb21wdGV1cjoge3tjb3VudH19JyxcblxuICAgIC8vIEJ1dHRvbnNcbiAgICBidXR0b25zVXBkYXRlQ291bnRlcjogJ01ldHRyZSDDoCBqb3VyIGxlIENvbXB0ZXVyJyxcbiAgfSxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IG5ldyBUZXh0Q29udGVudChkaXNwbGF5RGVtb0NvbnRlbnQpO1xuIl19
@@ -36,6 +36,7 @@ const globalContentData = {
36
36
  success: 'Éxito',
37
37
  warning: 'Advertencia',
38
38
  info: 'Información',
39
+ language: 'Idioma',
39
40
  // Common confirmations
40
41
  areYouSure: '¿Estás seguro?',
41
42
  deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',
@@ -114,4 +115,4 @@ const content = {
114
115
  export default content;
115
116
  // Export named exports for user convenience
116
117
  export { content, GlobalContent, globalContentData };
117
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFlBQVksTUFBTSw0QkFBNEIsQ0FBQztBQUN0RCxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQU14RDs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxpQkFBaUIsR0FBcUI7SUFDMUMsRUFBRSxFQUFFO1FBQ0YsaUJBQWlCO1FBQ2pCLEVBQUUsRUFBRSxTQUFTO1FBQ2IsTUFBTSxFQUFFLFVBQVU7UUFDbEIsSUFBSSxFQUFFLFNBQVM7UUFDZixNQUFNLEVBQUUsVUFBVTtRQUNsQixJQUFJLEVBQUUsUUFBUTtRQUNkLEtBQUssRUFBRSxRQUFRO1FBQ2YsSUFBSSxFQUFFLFFBQVE7UUFDZCxJQUFJLEVBQUUsV0FBVztRQUNqQixRQUFRLEVBQUUsVUFBVTtRQUNwQixNQUFNLEVBQUUsV0FBVztRQUNuQixRQUFRLEVBQUUsV0FBVztRQUVyQixpQkFBaUI7UUFDakIsR0FBRyxFQUFFLFNBQVM7UUFDZCxNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsU0FBUztRQUNqQixJQUFJLEVBQUUsU0FBUztRQUNmLE9BQU8sRUFBRSxZQUFZO1FBRXJCLDZCQUE2QjtRQUM3QixPQUFPLEVBQUUsYUFBYTtRQUN0QixNQUFNLEVBQUUsMEJBQTBCO1FBQ2xDLEtBQUssRUFBRSxPQUFPO1FBQ2QsT0FBTyxFQUFFLE9BQU87UUFDaEIsT0FBTyxFQUFFLGFBQWE7UUFDdEIsSUFBSSxFQUFFLGFBQWE7UUFFbkIsdUJBQXVCO1FBQ3ZCLFVBQVUsRUFBRSxnQkFBZ0I7UUFDNUIsa0JBQWtCLEVBQUUsa0RBQWtEO1FBQ3RFLGNBQWMsRUFBRSxnREFBZ0Q7UUFFaEUsc0JBQXNCO1FBQ3RCLGlCQUFpQixFQUFFLFdBQVc7S0FDL0I7SUFDRCxFQUFFLEVBQUU7UUFDRixpQkFBaUI7UUFDakIsRUFBRSxFQUFFLElBQUk7UUFDUixNQUFNLEVBQUUsUUFBUTtRQUNoQixJQUFJLEVBQUUsTUFBTTtRQUNaLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLElBQUksRUFBRSxNQUFNO1FBQ1osS0FBSyxFQUFFLE9BQU87UUFDZCxJQUFJLEVBQUUsTUFBTTtRQUNaLElBQUksRUFBRSxNQUFNO1FBQ1osUUFBUSxFQUFFLFVBQVU7UUFDcEIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsUUFBUSxFQUFFLFVBQVU7UUFFcEIsaUJBQWlCO1FBQ2pCLEdBQUcsRUFBRSxLQUFLO1FBQ1YsTUFBTSxFQUFFLFFBQVE7UUFDaEIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsSUFBSSxFQUFFLE1BQU07UUFDWixPQUFPLEVBQUUsU0FBUztRQUVsQiw2QkFBNkI7UUFDN0IsT0FBTyxFQUFFLFlBQVk7UUFDckIsTUFBTSxFQUFFLG1CQUFtQjtRQUMzQixLQUFLLEVBQUUsT0FBTztRQUNkLE9BQU8sRUFBRSxTQUFTO1FBQ2xCLE9BQU8sRUFBRSxTQUFTO1FBQ2xCLElBQUksRUFBRSxhQUFhO1FBRW5CLHVCQUF1QjtRQUN2QixVQUFVLEVBQUUsZUFBZTtRQUMzQixrQkFBa0IsRUFBRSw2Q0FBNkM7UUFDakUsY0FBYyxFQUFFLG9EQUFvRDtRQUVwRSxzQkFBc0I7UUFDdEIsaUJBQWlCLEVBQUUsV0FBVztLQUMvQjtJQUNELEVBQUUsRUFBRTtRQUNGLG9GQUFvRjtRQUNwRixFQUFFLEVBQUUsSUFBSTtRQUNSLE1BQU0sRUFBRSxTQUFTO1FBQ2pCLElBQUksRUFBRSxhQUFhO1FBQ25CLE1BQU0sRUFBRSxXQUFXO1FBQ25CLElBQUksRUFBRSxVQUFVO1FBQ2hCLEtBQUssRUFBRSxRQUFRO1FBQ2YsSUFBSSxFQUFFLFFBQVE7UUFFZCxrRkFBa0Y7UUFDbEYsT0FBTyxFQUFFLGVBQWU7UUFDeEIsS0FBSyxFQUFFLFFBQVE7UUFDZixPQUFPLEVBQUUsUUFBUTtRQUVqQix1QkFBdUI7UUFDdkIsVUFBVSxFQUFFLGdCQUFnQjtLQUM3QjtJQUNELEVBQUUsRUFBRTtRQUNGLDBEQUEwRDtRQUMxRCxFQUFFLEVBQUUsSUFBSTtRQUNSLE1BQU0sRUFBRSxXQUFXO1FBQ25CLElBQUksRUFBRSxXQUFXO1FBQ2pCLE1BQU0sRUFBRSxTQUFTO1FBRWpCLDZCQUE2QjtRQUM3QixPQUFPLEVBQUUsVUFBVTtRQUNuQixLQUFLLEVBQUUsUUFBUTtRQUVmLHVCQUF1QjtRQUN2QixVQUFVLEVBQUUsa0JBQWtCO0tBQy9CO0NBQ0YsQ0FBQztBQUVGLE1BQU0sYUFBYSxHQUFHLElBQUksV0FBVyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFFekQsTUFBTSxPQUFPLEdBQWE7SUFDeEIsT0FBTyxFQUFFLGFBQWE7SUFDdEIsWUFBWTtDQUNiLENBQUM7QUFFRixlQUFlLE9BQU8sQ0FBQztBQUV2Qiw0Q0FBNEM7QUFDNUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMYW5nU2V0dGluZ3MgZnJvbSAnLi9jb21wb25lbnRzL2xhbmctc2V0dGluZ3MnO1xuaW1wb3J0IHsgTGFuZ3VhZ2VzQ29udGVudCwgVGV4dENvbnRlbnQgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlciB7XG4gIFt4OiBzdHJpbmddOiBUZXh0Q29udGVudDtcbn1cblxuLyoqXG4gKiBHbG9iYWwgY29udGVudCB0aGF0IGNhbiBiZSB1c2VkIGFjcm9zcyBhbGwgY29tcG9uZW50cy5cbiAqIFRoZXNlIGFyZSBjb21tb24gdGV4dHMgbGlrZSBidXR0b25zLCBhY3Rpb25zLCBzdGF0ZXMsIGV0Yy5cbiAqIFN0cnVjdHVyZToge2VzOiB7a2V5MTogJ3ZhbHVlMScsIGtleTI6ICd2YWx1ZTInfSwgZW46IHtrZXkxOiAndmFsdWUxJywga2V5MjogJ3ZhbHVlMid9LCBmcjogey4uLn19XG4gKlxuICogTm90ZTogWW91IGNhbiBhZGQgYW55IGxhbmd1YWdlIGNvZGUuIFRoZSBzeXN0ZW0gd2lsbCBhdXRvbWF0aWNhbGx5IGRldGVjdCBhdmFpbGFibGUgbGFuZ3VhZ2VzXG4gKiBhbmQgcHJvdmlkZSBpbnRlbGxpZ2VudCBmYWxsYmFja3Mgd2l0aCB3YXJuaW5ncyBmb3IgbWlzc2luZyB0cmFuc2xhdGlvbnMuXG4gKi9cbmNvbnN0IGdsb2JhbENvbnRlbnREYXRhOiBMYW5ndWFnZXNDb250ZW50ID0ge1xuICBlczoge1xuICAgIC8vIENvbW1vbiBidXR0b25zXG4gICAgb2s6ICdBY2VwdGFyJyxcbiAgICBjYW5jZWw6ICdDYW5jZWxhcicsXG4gICAgc2F2ZTogJ0d1YXJkYXInLFxuICAgIGRlbGV0ZTogJ0VsaW1pbmFyJyxcbiAgICBlZGl0OiAnRWRpdGFyJyxcbiAgICBjbG9zZTogJ0NlcnJhcicsXG4gICAgYmFjazogJ1ZvbHZlcicsXG4gICAgbmV4dDogJ1NpZ3VpZW50ZScsXG4gICAgcHJldmlvdXM6ICdBbnRlcmlvcicsXG4gICAgZmluaXNoOiAnRmluYWxpemFyJyxcbiAgICBjb250aW51ZTogJ0NvbnRpbnVhcicsXG5cbiAgICAvLyBDb21tb24gYWN0aW9uc1xuICAgIGFkZDogJ0FncmVnYXInLFxuICAgIHJlbW92ZTogJ1F1aXRhcicsXG4gICAgc2VhcmNoOiAnQnVzY2FyJyxcbiAgICBmaWx0ZXI6ICdGaWx0cmFyJyxcbiAgICBzb3J0OiAnT3JkZW5hcicsXG4gICAgcmVmcmVzaDogJ0FjdHVhbGl6YXInLFxuXG4gICAgLy8gQ29tbW9uIHN0YXRlcyBhbmQgbWVzc2FnZXNcbiAgICBsb2FkaW5nOiAnQ2FyZ2FuZG8uLi4nLFxuICAgIG5vRGF0YTogJ05vIGhheSBkYXRvcyBkaXNwb25pYmxlcycsXG4gICAgZXJyb3I6ICdFcnJvcicsXG4gICAgc3VjY2VzczogJ8OJeGl0bycsXG4gICAgd2FybmluZzogJ0FkdmVydGVuY2lhJyxcbiAgICBpbmZvOiAnSW5mb3JtYWNpw7NuJyxcblxuICAgIC8vIENvbW1vbiBjb25maXJtYXRpb25zXG4gICAgYXJlWW91U3VyZTogJ8K/RXN0w6FzIHNlZ3Vybz8nLFxuICAgIGRlbGV0ZUNvbmZpcm1hdGlvbjogJ8K/RXN0w6FzIHNlZ3VybyBkZSBxdWUgZGVzZWFzIGVsaW1pbmFyIHtpdGVtTmFtZX0/JyxcbiAgICB1bnNhdmVkQ2hhbmdlczogJ1RpZW5lcyBjYW1iaW9zIHNpbiBndWFyZGFyLiDCv0Rlc2VhcyBjb250aW51YXI/JyxcblxuICAgIC8vIENvbW1vbiBwbGFjZWhvbGRlcnNcbiAgICBzZWFyY2hQbGFjZWhvbGRlcjogJ0J1c2Nhci4uLicsXG4gIH0sXG4gIGVuOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnNcbiAgICBvazogJ09LJyxcbiAgICBjYW5jZWw6ICdDYW5jZWwnLFxuICAgIHNhdmU6ICdTYXZlJyxcbiAgICBkZWxldGU6ICdEZWxldGUnLFxuICAgIGVkaXQ6ICdFZGl0JyxcbiAgICBjbG9zZTogJ0Nsb3NlJyxcbiAgICBiYWNrOiAnQmFjaycsXG4gICAgbmV4dDogJ05leHQnLFxuICAgIHByZXZpb3VzOiAnUHJldmlvdXMnLFxuICAgIGZpbmlzaDogJ0ZpbmlzaCcsXG4gICAgY29udGludWU6ICdDb250aW51ZScsXG5cbiAgICAvLyBDb21tb24gYWN0aW9uc1xuICAgIGFkZDogJ0FkZCcsXG4gICAgcmVtb3ZlOiAnUmVtb3ZlJyxcbiAgICBzZWFyY2g6ICdTZWFyY2gnLFxuICAgIGZpbHRlcjogJ0ZpbHRlcicsXG4gICAgc29ydDogJ1NvcnQnLFxuICAgIHJlZnJlc2g6ICdSZWZyZXNoJyxcblxuICAgIC8vIENvbW1vbiBzdGF0ZXMgYW5kIG1lc3NhZ2VzXG4gICAgbG9hZGluZzogJ0xvYWRpbmcuLi4nLFxuICAgIG5vRGF0YTogJ05vIGRhdGEgYXZhaWxhYmxlJyxcbiAgICBlcnJvcjogJ0Vycm9yJyxcbiAgICBzdWNjZXNzOiAnU3VjY2VzcycsXG4gICAgd2FybmluZzogJ1dhcm5pbmcnLFxuICAgIGluZm86ICdJbmZvcm1hdGlvbicsXG5cbiAgICAvLyBDb21tb24gY29uZmlybWF0aW9uc1xuICAgIGFyZVlvdVN1cmU6ICdBcmUgeW91IHN1cmU/JyxcbiAgICBkZWxldGVDb25maXJtYXRpb246ICdBcmUgeW91IHN1cmUgeW91IHdhbnQgdG8gZGVsZXRlIHtpdGVtTmFtZX0/JyxcbiAgICB1bnNhdmVkQ2hhbmdlczogJ1lvdSBoYXZlIHVuc2F2ZWQgY2hhbmdlcy4gRG8geW91IHdhbnQgdG8gY29udGludWU/JyxcblxuICAgIC8vIENvbW1vbiBwbGFjZWhvbGRlcnNcbiAgICBzZWFyY2hQbGFjZWhvbGRlcjogJ1NlYXJjaC4uLicsXG4gIH0sXG4gIGZyOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnMgLSBFeGFtcGxlIG9mIHBhcnRpYWwgdHJhbnNsYXRpb24gKG1pc3Npbmcgc29tZSBrZXlzIGludGVudGlvbmFsbHkpXG4gICAgb2s6ICdPSycsXG4gICAgY2FuY2VsOiAnQW5udWxlcicsXG4gICAgc2F2ZTogJ1NhdXZlZ2FyZGVyJyxcbiAgICBkZWxldGU6ICdTdXBwcmltZXInLFxuICAgIGVkaXQ6ICdNb2RpZmllcicsXG4gICAgY2xvc2U6ICdGZXJtZXInLFxuICAgIGJhY2s6ICdSZXRvdXInLFxuXG4gICAgLy8gQ29tbW9uIHN0YXRlcyBhbmQgbWVzc2FnZXMgKGludGVudGlvbmFsbHkgaW5jb21wbGV0ZSB0byBzaG93IGZhbGxiYWNrIGJlaGF2aW9yKVxuICAgIGxvYWRpbmc6ICdDaGFyZ2VtZW50Li4uJyxcbiAgICBlcnJvcjogJ0VycmV1cicsXG4gICAgc3VjY2VzczogJ1N1Y2PDqHMnLFxuXG4gICAgLy8gQ29tbW9uIGNvbmZpcm1hdGlvbnNcbiAgICBhcmVZb3VTdXJlOiAnw4p0ZXMtdm91cyBzw7tyPycsXG4gIH0sXG4gIGRlOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnMgLSBBbm90aGVyIGV4YW1wbGUgb2YgcGFydGlhbCB0cmFuc2xhdGlvblxuICAgIG9rOiAnT0snLFxuICAgIGNhbmNlbDogJ0FiYnJlY2hlbicsXG4gICAgc2F2ZTogJ1NwZWljaGVybicsXG4gICAgZGVsZXRlOiAnTMO2c2NoZW4nLFxuXG4gICAgLy8gQ29tbW9uIHN0YXRlcyBhbmQgbWVzc2FnZXNcbiAgICBsb2FkaW5nOiAnTGFkZW4uLi4nLFxuICAgIGVycm9yOiAnRmVobGVyJyxcblxuICAgIC8vIENvbW1vbiBjb25maXJtYXRpb25zXG4gICAgYXJlWW91U3VyZTogJ1NpbmQgU2llIHNpY2hlcj8nLFxuICB9LFxufTtcblxuY29uc3QgR2xvYmFsQ29udGVudCA9IG5ldyBUZXh0Q29udGVudChnbG9iYWxDb250ZW50RGF0YSk7XG5cbmNvbnN0IGNvbnRlbnQ6IFByb3ZpZGVyID0ge1xuICBfZ2xvYmFsOiBHbG9iYWxDb250ZW50LFxuICBMYW5nU2V0dGluZ3MsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBjb250ZW50O1xuXG4vLyBFeHBvcnQgbmFtZWQgZXhwb3J0cyBmb3IgdXNlciBjb252ZW5pZW5jZVxuZXhwb3J0IHsgY29udGVudCwgR2xvYmFsQ29udGVudCwgZ2xvYmFsQ29udGVudERhdGEgfTtcbiJdfQ==
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"]}