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.
- package/esm2022/lib/components/atoms/avatar/avatar.component.mjs +3 -3
- package/esm2022/lib/components/atoms/box/box.component.mjs +3 -3
- package/esm2022/lib/components/atoms/button/button.component.mjs +45 -12
- package/esm2022/lib/components/atoms/display/display.component.mjs +47 -11
- package/esm2022/lib/components/atoms/display/types.mjs +1 -1
- package/esm2022/lib/components/atoms/divider/divider.component.mjs +3 -3
- package/esm2022/lib/components/atoms/href/href.component.mjs +3 -3
- package/esm2022/lib/components/atoms/icon/icon.component.mjs +3 -3
- package/esm2022/lib/components/atoms/image/image.component.mjs +3 -3
- package/esm2022/lib/components/atoms/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2022/lib/components/atoms/text/text.component.mjs +3 -3
- package/esm2022/lib/components/atoms/title/title.component.mjs +77 -23
- package/esm2022/lib/components/atoms/title/types.mjs +30 -2
- package/esm2022/lib/components/molecules/alert-box/alert-box.component.mjs +57 -10
- package/esm2022/lib/components/molecules/alert-box/types.mjs +1 -1
- package/esm2022/lib/components/molecules/button-group/button-group.component.mjs +3 -3
- package/esm2022/lib/components/molecules/card/card.component.mjs +3 -3
- package/esm2022/lib/components/molecules/content-loader/content-loader.component.mjs +3 -3
- package/esm2022/lib/components/molecules/date-input/date-input.component.mjs +3 -3
- package/esm2022/lib/components/molecules/file-input/file-input.component.mjs +3 -3
- package/esm2022/lib/components/molecules/hint/hint.component.mjs +3 -3
- package/esm2022/lib/components/molecules/language-selector/language-selector.component.mjs +219 -0
- package/esm2022/lib/components/molecules/language-selector/types.mjs +2 -0
- package/esm2022/lib/components/molecules/layered-card/layered-card.component.mjs +3 -3
- package/esm2022/lib/components/molecules/link/link.component.mjs +3 -3
- package/esm2022/lib/components/molecules/links-cake/links-cake.component.mjs +3 -3
- package/esm2022/lib/components/molecules/notes-box/notes-box.component.mjs +3 -3
- package/esm2022/lib/components/molecules/password-input/password-input.component.mjs +3 -3
- package/esm2022/lib/components/molecules/pin-input/pin-input.component.mjs +3 -3
- package/esm2022/lib/components/molecules/popover-selector/popover-selector.component.mjs +170 -0
- package/esm2022/lib/components/molecules/popover-selector/types.mjs +2 -0
- package/esm2022/lib/components/molecules/progress-status/progress-status.component.mjs +3 -3
- package/esm2022/lib/components/molecules/prompter/prompter.component.mjs +3 -3
- package/esm2022/lib/components/molecules/searchbar/searchbar.component.mjs +3 -3
- package/esm2022/lib/components/molecules/text-input/text-input.component.mjs +3 -3
- package/esm2022/lib/components/molecules/title-block/title-block.component.mjs +3 -3
- package/esm2022/lib/components/organisms/banner/banner.component.mjs +3 -3
- package/esm2022/lib/components/organisms/form/form.component.mjs +3 -3
- package/esm2022/lib/components/organisms/header/header.component.mjs +3 -3
- package/esm2022/lib/components/organisms/item-list/item-list.component.mjs +3 -3
- package/esm2022/lib/components/organisms/item-list/types.mjs +1 -1
- package/esm2022/lib/components/organisms/no-content/no-content.component.mjs +3 -3
- package/esm2022/lib/components/organisms/toolbar/toolbar.component.mjs +3 -3
- package/esm2022/lib/components/organisms/wizard/wizard.component.mjs +3 -3
- package/esm2022/lib/components/templates/layout/layout.component.mjs +2 -2
- package/esm2022/lib/components/types.mjs +1 -1
- package/esm2022/lib/examples/display-demo.component.mjs +518 -0
- package/esm2022/lib/examples/display-simple-example.component.mjs +202 -0
- package/esm2022/lib/examples/selector-examples.component.mjs +208 -0
- package/esm2022/lib/services/lang-provider/components/display-demo.mjs +86 -0
- package/esm2022/lib/services/lang-provider/content.mjs +2 -1
- package/esm2022/lib/shared/utils/reactive-content.mjs +117 -0
- package/esm2022/public-api.mjs +9 -1
- package/fesm2022/valtech-components.mjs +3435 -1844
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/button/button.component.d.ts +10 -3
- package/lib/components/atoms/display/display.component.d.ts +12 -4
- package/lib/components/atoms/display/types.d.ts +13 -3
- package/lib/components/atoms/title/title.component.d.ts +6 -1
- package/lib/components/atoms/title/types.d.ts +29 -3
- package/lib/components/molecules/alert-box/alert-box.component.d.ts +17 -9
- package/lib/components/molecules/alert-box/types.d.ts +29 -0
- package/lib/components/molecules/language-selector/language-selector.component.d.ts +50 -0
- package/lib/components/molecules/language-selector/types.d.ts +52 -0
- package/lib/components/molecules/popover-selector/popover-selector.component.d.ts +29 -0
- package/lib/components/molecules/popover-selector/types.d.ts +69 -0
- package/lib/components/organisms/item-list/types.d.ts +54 -9
- package/lib/components/types.d.ts +12 -3
- package/lib/examples/display-demo.component.d.ts +62 -0
- package/lib/examples/display-simple-example.component.d.ts +23 -0
- package/lib/examples/selector-examples.component.d.ts +20 -0
- package/lib/services/lang-provider/components/display-demo.d.ts +3 -0
- package/lib/shared/utils/reactive-content.d.ts +109 -0
- package/package.json +4 -2
- package/public-api.d.ts +8 -0
- package/src/lib/components/styles/overrides.scss +583 -0
- 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,
|
|
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"]}
|