valtech-components 2.0.279 → 2.0.281
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/_examples/custom-content-demo.component.mjs +197 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/valtech-components.mjs +191 -1
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/_examples/custom-content-demo.component.d.ts +25 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, inject } from '@angular/core';
|
|
3
|
+
import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonItem, IonLabel, } from '@ionic/angular/standalone';
|
|
4
|
+
import { ContentService } from '../../services/content.service';
|
|
5
|
+
import { LangOption } from '../../services/lang-provider/types';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class CustomContentDemoComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.content = inject(ContentService);
|
|
11
|
+
this.currentLang = 'es';
|
|
12
|
+
// Contenido global predefinido (sin className)
|
|
13
|
+
this.saveText$ = this.content.fromContent({ key: 'save' });
|
|
14
|
+
this.cancelText$ = this.content.fromContent({ key: 'cancel' });
|
|
15
|
+
this.deleteText$ = this.content.fromContent({ key: 'delete' });
|
|
16
|
+
this.loadingText$ = this.content.fromContent({ key: 'loading' });
|
|
17
|
+
// Tu contenido global personalizado (sin className)
|
|
18
|
+
this.dashboardText$ = this.content.fromContent({ key: 'dashboard' });
|
|
19
|
+
this.profileText$ = this.content.fromContent({ key: 'profile' });
|
|
20
|
+
this.settingsText$ = this.content.fromContent({ key: 'settings' });
|
|
21
|
+
this.welcomeText$ = this.content.fromContent({
|
|
22
|
+
key: 'welcome',
|
|
23
|
+
interpolation: { appName: 'Mi Aplicación' },
|
|
24
|
+
});
|
|
25
|
+
// Contenido específico del componente Language (con className)
|
|
26
|
+
this.spanishText$ = this.content.fromContent({
|
|
27
|
+
className: 'Language',
|
|
28
|
+
key: 'spanish',
|
|
29
|
+
});
|
|
30
|
+
this.englishText$ = this.content.fromContent({
|
|
31
|
+
className: 'Language',
|
|
32
|
+
key: 'english',
|
|
33
|
+
});
|
|
34
|
+
this.descriptionText$ = this.content.fromContent({
|
|
35
|
+
className: 'Language',
|
|
36
|
+
key: 'description',
|
|
37
|
+
});
|
|
38
|
+
// Para debug - texto síncrono
|
|
39
|
+
this.saveTextSync = '';
|
|
40
|
+
this.dashboardTextSync = '';
|
|
41
|
+
this.languageDescSync = '';
|
|
42
|
+
}
|
|
43
|
+
ngOnInit() {
|
|
44
|
+
// Obtener idioma actual
|
|
45
|
+
this.content.currentLang$.subscribe(lang => {
|
|
46
|
+
this.currentLang = lang;
|
|
47
|
+
});
|
|
48
|
+
// Obtener textos síncronos para debug
|
|
49
|
+
this.updateSyncTexts();
|
|
50
|
+
}
|
|
51
|
+
switchLanguage() {
|
|
52
|
+
const newLang = this.currentLang === 'es' ? LangOption.EN : LangOption.ES;
|
|
53
|
+
this.content.setLang(newLang);
|
|
54
|
+
// Actualizar textos síncronos después del cambio
|
|
55
|
+
setTimeout(() => {
|
|
56
|
+
this.updateSyncTexts();
|
|
57
|
+
}, 100);
|
|
58
|
+
}
|
|
59
|
+
updateSyncTexts() {
|
|
60
|
+
// Contenido global predefinido
|
|
61
|
+
this.saveTextSync = this.content.getText('save');
|
|
62
|
+
// Tu contenido global personalizado
|
|
63
|
+
this.dashboardTextSync = this.content.getText('dashboard');
|
|
64
|
+
// Contenido específico del componente
|
|
65
|
+
this.languageDescSync = this.content.getText('Language', 'description');
|
|
66
|
+
}
|
|
67
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
68
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CustomContentDemoComponent, isStandalone: true, selector: "app-custom-content-demo", ngImport: i0, template: `
|
|
69
|
+
<ion-card>
|
|
70
|
+
<ion-card-header>
|
|
71
|
+
<ion-card-title>Demo de Contenido Personalizado</ion-card-title>
|
|
72
|
+
</ion-card-header>
|
|
73
|
+
|
|
74
|
+
<ion-card-content>
|
|
75
|
+
<!-- Contenido global predefinido -->
|
|
76
|
+
<div style="margin-bottom: 20px;">
|
|
77
|
+
<h3>Contenido Global Predefinido:</h3>
|
|
78
|
+
<ion-button>{{ saveText$ | async }}</ion-button>
|
|
79
|
+
<ion-button color="medium">{{ cancelText$ | async }}</ion-button>
|
|
80
|
+
<ion-button color="danger">{{ deleteText$ | async }}</ion-button>
|
|
81
|
+
<p><strong>Estado:</strong> {{ loadingText$ | async }}</p>
|
|
82
|
+
</div>
|
|
83
|
+
|
|
84
|
+
<!-- Tu contenido global personalizado -->
|
|
85
|
+
<div style="margin-bottom: 20px;">
|
|
86
|
+
<h3>Tu Contenido Global Personalizado:</h3>
|
|
87
|
+
<p><strong>Sección:</strong> {{ dashboardText$ | async }}</p>
|
|
88
|
+
<p><strong>Usuario:</strong> {{ profileText$ | async }}</p>
|
|
89
|
+
<p><strong>Config:</strong> {{ settingsText$ | async }}</p>
|
|
90
|
+
<p>{{ welcomeText$ | async }}</p>
|
|
91
|
+
</div>
|
|
92
|
+
|
|
93
|
+
<!-- Contenido específico del componente Language -->
|
|
94
|
+
<div style="margin-bottom: 20px;">
|
|
95
|
+
<h3>Contenido del Componente Language:</h3>
|
|
96
|
+
<ion-item>
|
|
97
|
+
<ion-label> <strong>Español:</strong> {{ spanishText$ | async }} </ion-label>
|
|
98
|
+
</ion-item>
|
|
99
|
+
<ion-item>
|
|
100
|
+
<ion-label> <strong>Inglés:</strong> {{ englishText$ | async }} </ion-label>
|
|
101
|
+
</ion-item>
|
|
102
|
+
<p>
|
|
103
|
+
<em>{{ descriptionText$ | async }}</em>
|
|
104
|
+
</p>
|
|
105
|
+
</div>
|
|
106
|
+
|
|
107
|
+
<!-- Botón para cambiar idioma -->
|
|
108
|
+
<div>
|
|
109
|
+
<h3>Control de Idioma:</h3>
|
|
110
|
+
<ion-button (click)="switchLanguage()" color="secondary">
|
|
111
|
+
Cambiar a {{ currentLang === 'es' ? 'English' : 'Español' }}
|
|
112
|
+
</ion-button>
|
|
113
|
+
<p>
|
|
114
|
+
<small>Idioma actual: {{ currentLang }}</small>
|
|
115
|
+
</p>
|
|
116
|
+
</div>
|
|
117
|
+
|
|
118
|
+
<!-- Debug info -->
|
|
119
|
+
<div style="margin-top: 20px; padding: 10px; background: #f5f5f5; border-radius: 4px;">
|
|
120
|
+
<h4>Debug Info:</h4>
|
|
121
|
+
<p><strong>Save (sync):</strong> {{ saveTextSync }}</p>
|
|
122
|
+
<p><strong>Dashboard (sync):</strong> {{ dashboardTextSync }}</p>
|
|
123
|
+
<p><strong>Language Description (sync):</strong> {{ languageDescSync }}</p>
|
|
124
|
+
</div>
|
|
125
|
+
</ion-card-content>
|
|
126
|
+
</ion-card>
|
|
127
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }] }); }
|
|
128
|
+
}
|
|
129
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, decorators: [{
|
|
130
|
+
type: Component,
|
|
131
|
+
args: [{
|
|
132
|
+
selector: 'app-custom-content-demo',
|
|
133
|
+
standalone: true,
|
|
134
|
+
imports: [CommonModule, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonButton, IonItem, IonLabel],
|
|
135
|
+
template: `
|
|
136
|
+
<ion-card>
|
|
137
|
+
<ion-card-header>
|
|
138
|
+
<ion-card-title>Demo de Contenido Personalizado</ion-card-title>
|
|
139
|
+
</ion-card-header>
|
|
140
|
+
|
|
141
|
+
<ion-card-content>
|
|
142
|
+
<!-- Contenido global predefinido -->
|
|
143
|
+
<div style="margin-bottom: 20px;">
|
|
144
|
+
<h3>Contenido Global Predefinido:</h3>
|
|
145
|
+
<ion-button>{{ saveText$ | async }}</ion-button>
|
|
146
|
+
<ion-button color="medium">{{ cancelText$ | async }}</ion-button>
|
|
147
|
+
<ion-button color="danger">{{ deleteText$ | async }}</ion-button>
|
|
148
|
+
<p><strong>Estado:</strong> {{ loadingText$ | async }}</p>
|
|
149
|
+
</div>
|
|
150
|
+
|
|
151
|
+
<!-- Tu contenido global personalizado -->
|
|
152
|
+
<div style="margin-bottom: 20px;">
|
|
153
|
+
<h3>Tu Contenido Global Personalizado:</h3>
|
|
154
|
+
<p><strong>Sección:</strong> {{ dashboardText$ | async }}</p>
|
|
155
|
+
<p><strong>Usuario:</strong> {{ profileText$ | async }}</p>
|
|
156
|
+
<p><strong>Config:</strong> {{ settingsText$ | async }}</p>
|
|
157
|
+
<p>{{ welcomeText$ | async }}</p>
|
|
158
|
+
</div>
|
|
159
|
+
|
|
160
|
+
<!-- Contenido específico del componente Language -->
|
|
161
|
+
<div style="margin-bottom: 20px;">
|
|
162
|
+
<h3>Contenido del Componente Language:</h3>
|
|
163
|
+
<ion-item>
|
|
164
|
+
<ion-label> <strong>Español:</strong> {{ spanishText$ | async }} </ion-label>
|
|
165
|
+
</ion-item>
|
|
166
|
+
<ion-item>
|
|
167
|
+
<ion-label> <strong>Inglés:</strong> {{ englishText$ | async }} </ion-label>
|
|
168
|
+
</ion-item>
|
|
169
|
+
<p>
|
|
170
|
+
<em>{{ descriptionText$ | async }}</em>
|
|
171
|
+
</p>
|
|
172
|
+
</div>
|
|
173
|
+
|
|
174
|
+
<!-- Botón para cambiar idioma -->
|
|
175
|
+
<div>
|
|
176
|
+
<h3>Control de Idioma:</h3>
|
|
177
|
+
<ion-button (click)="switchLanguage()" color="secondary">
|
|
178
|
+
Cambiar a {{ currentLang === 'es' ? 'English' : 'Español' }}
|
|
179
|
+
</ion-button>
|
|
180
|
+
<p>
|
|
181
|
+
<small>Idioma actual: {{ currentLang }}</small>
|
|
182
|
+
</p>
|
|
183
|
+
</div>
|
|
184
|
+
|
|
185
|
+
<!-- Debug info -->
|
|
186
|
+
<div style="margin-top: 20px; padding: 10px; background: #f5f5f5; border-radius: 4px;">
|
|
187
|
+
<h4>Debug Info:</h4>
|
|
188
|
+
<p><strong>Save (sync):</strong> {{ saveTextSync }}</p>
|
|
189
|
+
<p><strong>Dashboard (sync):</strong> {{ dashboardTextSync }}</p>
|
|
190
|
+
<p><strong>Language Description (sync):</strong> {{ languageDescSync }}</p>
|
|
191
|
+
</div>
|
|
192
|
+
</ion-card-content>
|
|
193
|
+
</ion-card>
|
|
194
|
+
`,
|
|
195
|
+
}]
|
|
196
|
+
}] });
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-content-demo.component.js","sourceRoot":"","sources":["../../../../../../projects/valtech-components/src/lib/components/_examples/custom-content-demo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, inject, OnInit } from '@angular/core';\nimport {\n  IonButton,\n  IonCard,\n  IonCardContent,\n  IonCardHeader,\n  IonCardTitle,\n  IonItem,\n  IonLabel,\n} from '@ionic/angular/standalone';\nimport { ContentService } from '../../services/content.service';\nimport { LangOption } from '../../services/lang-provider/types';\n\n@Component({\n  selector: 'app-custom-content-demo',\n  standalone: true,\n  imports: [CommonModule, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonButton, IonItem, IonLabel],\n  template: `\n    <ion-card>\n      <ion-card-header>\n        <ion-card-title>Demo de Contenido Personalizado</ion-card-title>\n      </ion-card-header>\n\n      <ion-card-content>\n        <!-- Contenido global predefinido -->\n        <div style=\"margin-bottom: 20px;\">\n          <h3>Contenido Global Predefinido:</h3>\n          <ion-button>{{ saveText$ | async }}</ion-button>\n          <ion-button color=\"medium\">{{ cancelText$ | async }}</ion-button>\n          <ion-button color=\"danger\">{{ deleteText$ | async }}</ion-button>\n          <p><strong>Estado:</strong> {{ loadingText$ | async }}</p>\n        </div>\n\n        <!-- Tu contenido global personalizado -->\n        <div style=\"margin-bottom: 20px;\">\n          <h3>Tu Contenido Global Personalizado:</h3>\n          <p><strong>Sección:</strong> {{ dashboardText$ | async }}</p>\n          <p><strong>Usuario:</strong> {{ profileText$ | async }}</p>\n          <p><strong>Config:</strong> {{ settingsText$ | async }}</p>\n          <p>{{ welcomeText$ | async }}</p>\n        </div>\n\n        <!-- Contenido específico del componente Language -->\n        <div style=\"margin-bottom: 20px;\">\n          <h3>Contenido del Componente Language:</h3>\n          <ion-item>\n            <ion-label> <strong>Español:</strong> {{ spanishText$ | async }} </ion-label>\n          </ion-item>\n          <ion-item>\n            <ion-label> <strong>Inglés:</strong> {{ englishText$ | async }} </ion-label>\n          </ion-item>\n          <p>\n            <em>{{ descriptionText$ | async }}</em>\n          </p>\n        </div>\n\n        <!-- Botón para cambiar idioma -->\n        <div>\n          <h3>Control de Idioma:</h3>\n          <ion-button (click)=\"switchLanguage()\" color=\"secondary\">\n            Cambiar a {{ currentLang === 'es' ? 'English' : 'Español' }}\n          </ion-button>\n          <p>\n            <small>Idioma actual: {{ currentLang }}</small>\n          </p>\n        </div>\n\n        <!-- Debug info -->\n        <div style=\"margin-top: 20px; padding: 10px; background: #f5f5f5; border-radius: 4px;\">\n          <h4>Debug Info:</h4>\n          <p><strong>Save (sync):</strong> {{ saveTextSync }}</p>\n          <p><strong>Dashboard (sync):</strong> {{ dashboardTextSync }}</p>\n          <p><strong>Language Description (sync):</strong> {{ languageDescSync }}</p>\n        </div>\n      </ion-card-content>\n    </ion-card>\n  `,\n})\nexport class CustomContentDemoComponent implements OnInit {\n  private content = inject(ContentService);\n\n  currentLang = 'es';\n\n  // Contenido global predefinido (sin className)\n  saveText$ = this.content.fromContent({ key: 'save' });\n  cancelText$ = this.content.fromContent({ key: 'cancel' });\n  deleteText$ = this.content.fromContent({ key: 'delete' });\n  loadingText$ = this.content.fromContent({ key: 'loading' });\n\n  // Tu contenido global personalizado (sin className)\n  dashboardText$ = this.content.fromContent({ key: 'dashboard' });\n  profileText$ = this.content.fromContent({ key: 'profile' });\n  settingsText$ = this.content.fromContent({ key: 'settings' });\n  welcomeText$ = this.content.fromContent({\n    key: 'welcome',\n    interpolation: { appName: 'Mi Aplicación' },\n  });\n\n  // Contenido específico del componente Language (con className)\n  spanishText$ = this.content.fromContent({\n    className: 'Language',\n    key: 'spanish',\n  });\n  englishText$ = this.content.fromContent({\n    className: 'Language',\n    key: 'english',\n  });\n  descriptionText$ = this.content.fromContent({\n    className: 'Language',\n    key: 'description',\n  });\n\n  // Para debug - texto síncrono\n  saveTextSync = '';\n  dashboardTextSync = '';\n  languageDescSync = '';\n\n  ngOnInit() {\n    // Obtener idioma actual\n    this.content.currentLang$.subscribe(lang => {\n      this.currentLang = lang;\n    });\n\n    // Obtener textos síncronos para debug\n    this.updateSyncTexts();\n  }\n\n  switchLanguage() {\n    const newLang = this.currentLang === 'es' ? LangOption.EN : LangOption.ES;\n    this.content.setLang(newLang);\n\n    // Actualizar textos síncronos después del cambio\n    setTimeout(() => {\n      this.updateSyncTexts();\n    }, 100);\n  }\n\n  private updateSyncTexts() {\n    // Contenido global predefinido\n    this.saveTextSync = this.content.getText('save');\n\n    // Tu contenido global personalizado\n    this.dashboardTextSync = this.content.getText('dashboard');\n\n    // Contenido específico del componente\n    this.languageDescSync = this.content.getText('Language', 'description');\n  }\n}\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -86,6 +86,7 @@ export * from './lib/components/templates/layout/layout.component';
|
|
|
86
86
|
export * from './lib/components/templates/simple/simple.component';
|
|
87
87
|
export * from './lib/components/templates/simple/types';
|
|
88
88
|
// Examples
|
|
89
|
+
export * from './lib/components/_examples/custom-content-demo.component';
|
|
89
90
|
export * from './lib/components/_examples/global-content-example.component';
|
|
90
91
|
export * from './lib/components/_examples/reactive-content-example.component';
|
|
91
92
|
export * from './lib/services/content.service';
|
|
@@ -106,4 +107,4 @@ export * from './lib/shared/utils/dom';
|
|
|
106
107
|
export * from './lib/shared/utils/form-defaults';
|
|
107
108
|
export * from './lib/shared/utils/styles';
|
|
108
109
|
export * from './lib/shared/utils/text';
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/valtech-components/src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of valtech-components\n */\n\n/*\n * Public API Surface of valtech-components\n */\n\nexport * from './lib/components/atoms/avatar/avatar.component';\nexport * from './lib/components/atoms/avatar/types';\nexport * from './lib/components/atoms/box/box.component';\nexport * from './lib/components/atoms/box/types';\nexport * from './lib/components/atoms/button/button.component';\nexport * from './lib/components/atoms/button/factory';\nexport * from './lib/components/atoms/display/display.component';\nexport * from './lib/components/atoms/display/types';\nexport * from './lib/components/atoms/divider/divider.component';\nexport * from './lib/components/atoms/divider/types';\nexport * from './lib/components/atoms/href/href.component';\nexport * from './lib/components/atoms/href/types';\nexport * from './lib/components/atoms/icon/icon.component';\nexport * from './lib/components/atoms/icon/types';\nexport * from './lib/components/atoms/image/image.component';\nexport * from './lib/components/atoms/image/types';\nexport * from './lib/components/atoms/progress-bar/progress-bar.component';\nexport * from './lib/components/atoms/progress-bar/types';\nexport * from './lib/components/atoms/text/text.component';\nexport * from './lib/components/atoms/text/types';\nexport * from './lib/components/atoms/title/title.component';\nexport * from './lib/components/atoms/title/types';\n\nexport * from './lib/components/molecules/alert-box/alert-box.component';\nexport * from './lib/components/molecules/alert-box/types';\nexport * from './lib/components/molecules/button-group/button-group.component';\nexport * from './lib/components/molecules/button-group/types';\nexport * from './lib/components/molecules/card/card.component';\nexport * from './lib/components/molecules/card/types';\nexport * from './lib/components/molecules/check-input/check-input.component';\nexport * from './lib/components/molecules/comment-input/comment-input.component';\nexport * from './lib/components/molecules/content-loader/content-loader.component';\nexport * from './lib/components/molecules/content-loader/types';\nexport * from './lib/components/molecules/date-input/date-input.component';\nexport * from './lib/components/molecules/email-input/email-input.component';\nexport * from './lib/components/molecules/expandable-text/expandable-text.component';\nexport * from './lib/components/molecules/expandable-text/types';\nexport * from './lib/components/molecules/file-input/file-input.component';\nexport * from './lib/components/molecules/hint/hint.component';\nexport * from './lib/components/molecules/hour-input/hour-input.component';\nexport * from './lib/components/molecules/layered-card/layered-card.component';\nexport * from './lib/components/molecules/layered-card/types';\nexport * from './lib/components/molecules/link/link.component';\nexport * from './lib/components/molecules/link/types';\nexport * from './lib/components/molecules/links-cake/links-cake.component';\nexport * from './lib/components/molecules/links-cake/types';\nexport * from './lib/components/molecules/notes-box/notes-box.component';\nexport * from './lib/components/molecules/notes-box/types';\nexport * from './lib/components/molecules/number-input/number-input.component';\nexport * from './lib/components/molecules/password-input/password-input.component';\nexport * from './lib/components/molecules/pin-input/pin-input.component';\nexport * from './lib/components/molecules/progress-status/progress-status.component';\nexport * from './lib/components/molecules/progress-status/types';\nexport * from './lib/components/molecules/prompter/prompter.component';\nexport * from './lib/components/molecules/prompter/types';\nexport * from './lib/components/molecules/radio-input/radio-input.component';\nexport * from './lib/components/molecules/searchbar/searchbar.component';\nexport * from './lib/components/molecules/select-input/select-input.component';\nexport * from './lib/components/molecules/select-search/select-search.component';\nexport * from './lib/components/molecules/text-input/text-input.component';\nexport * from './lib/components/molecules/title-block/title-block.component';\nexport * from './lib/components/molecules/title-block/types';\n\nexport * from './lib/components/organisms/banner/banner.component';\nexport * from './lib/components/organisms/banner/types';\nexport * from './lib/components/organisms/footer/footer.component';\nexport * from './lib/components/organisms/form/factory';\nexport * from './lib/components/organisms/form/form-footer/form-footer.component';\nexport * from './lib/components/organisms/form/form.component';\nexport * from './lib/components/organisms/header/header.component';\nexport * from './lib/components/organisms/header/types';\nexport * from './lib/components/organisms/item-list/item-list.component';\nexport * from './lib/components/organisms/item-list/types';\nexport * from './lib/components/organisms/no-content/no-content.component';\nexport * from './lib/components/organisms/no-content/types';\nexport * from './lib/components/organisms/toolbar/toolbar.component';\nexport * from './lib/components/organisms/toolbar/types';\nexport * from './lib/components/organisms/wizard/types';\nexport * from './lib/components/organisms/wizard/wizard-footer/wizard-footer.component';\nexport * from './lib/components/organisms/wizard/wizard.component';\n\nexport * from './lib/components/templates/layout/layout.component';\nexport * from './lib/components/templates/simple/simple.component';\nexport * from './lib/components/templates/simple/types';\n\n// Examples\nexport * from './lib/components/_examples/global-content-example.component';\nexport * from './lib/components/_examples/reactive-content-example.component';\n\nexport * from './lib/services/content.service';\nexport * from './lib/services/download.service';\nexport * from './lib/services/icons.service';\nexport * from './lib/services/in-app-browser.service';\nexport * from './lib/services/lang-provider/content';\nexport * from './lib/services/lang-provider/lang-provider.service';\nexport * from './lib/services/lang-provider/types';\nexport * from './lib/services/local-storage.service';\nexport * from './lib/services/navigation.service';\nexport * from './lib/services/theme.service';\nexport * from './lib/services/toast.service';\nexport * from './lib/services/types';\n\nexport * from './lib/components/types';\nexport * from './lib/shared/utils/content';\nexport * from './lib/shared/utils/dom';\nexport * from './lib/shared/utils/form-defaults';\nexport * from './lib/shared/utils/styles';\nexport * from './lib/shared/utils/text';\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/valtech-components/src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of valtech-components\n */\n\n/*\n * Public API Surface of valtech-components\n */\n\nexport * from './lib/components/atoms/avatar/avatar.component';\nexport * from './lib/components/atoms/avatar/types';\nexport * from './lib/components/atoms/box/box.component';\nexport * from './lib/components/atoms/box/types';\nexport * from './lib/components/atoms/button/button.component';\nexport * from './lib/components/atoms/button/factory';\nexport * from './lib/components/atoms/display/display.component';\nexport * from './lib/components/atoms/display/types';\nexport * from './lib/components/atoms/divider/divider.component';\nexport * from './lib/components/atoms/divider/types';\nexport * from './lib/components/atoms/href/href.component';\nexport * from './lib/components/atoms/href/types';\nexport * from './lib/components/atoms/icon/icon.component';\nexport * from './lib/components/atoms/icon/types';\nexport * from './lib/components/atoms/image/image.component';\nexport * from './lib/components/atoms/image/types';\nexport * from './lib/components/atoms/progress-bar/progress-bar.component';\nexport * from './lib/components/atoms/progress-bar/types';\nexport * from './lib/components/atoms/text/text.component';\nexport * from './lib/components/atoms/text/types';\nexport * from './lib/components/atoms/title/title.component';\nexport * from './lib/components/atoms/title/types';\n\nexport * from './lib/components/molecules/alert-box/alert-box.component';\nexport * from './lib/components/molecules/alert-box/types';\nexport * from './lib/components/molecules/button-group/button-group.component';\nexport * from './lib/components/molecules/button-group/types';\nexport * from './lib/components/molecules/card/card.component';\nexport * from './lib/components/molecules/card/types';\nexport * from './lib/components/molecules/check-input/check-input.component';\nexport * from './lib/components/molecules/comment-input/comment-input.component';\nexport * from './lib/components/molecules/content-loader/content-loader.component';\nexport * from './lib/components/molecules/content-loader/types';\nexport * from './lib/components/molecules/date-input/date-input.component';\nexport * from './lib/components/molecules/email-input/email-input.component';\nexport * from './lib/components/molecules/expandable-text/expandable-text.component';\nexport * from './lib/components/molecules/expandable-text/types';\nexport * from './lib/components/molecules/file-input/file-input.component';\nexport * from './lib/components/molecules/hint/hint.component';\nexport * from './lib/components/molecules/hour-input/hour-input.component';\nexport * from './lib/components/molecules/layered-card/layered-card.component';\nexport * from './lib/components/molecules/layered-card/types';\nexport * from './lib/components/molecules/link/link.component';\nexport * from './lib/components/molecules/link/types';\nexport * from './lib/components/molecules/links-cake/links-cake.component';\nexport * from './lib/components/molecules/links-cake/types';\nexport * from './lib/components/molecules/notes-box/notes-box.component';\nexport * from './lib/components/molecules/notes-box/types';\nexport * from './lib/components/molecules/number-input/number-input.component';\nexport * from './lib/components/molecules/password-input/password-input.component';\nexport * from './lib/components/molecules/pin-input/pin-input.component';\nexport * from './lib/components/molecules/progress-status/progress-status.component';\nexport * from './lib/components/molecules/progress-status/types';\nexport * from './lib/components/molecules/prompter/prompter.component';\nexport * from './lib/components/molecules/prompter/types';\nexport * from './lib/components/molecules/radio-input/radio-input.component';\nexport * from './lib/components/molecules/searchbar/searchbar.component';\nexport * from './lib/components/molecules/select-input/select-input.component';\nexport * from './lib/components/molecules/select-search/select-search.component';\nexport * from './lib/components/molecules/text-input/text-input.component';\nexport * from './lib/components/molecules/title-block/title-block.component';\nexport * from './lib/components/molecules/title-block/types';\n\nexport * from './lib/components/organisms/banner/banner.component';\nexport * from './lib/components/organisms/banner/types';\nexport * from './lib/components/organisms/footer/footer.component';\nexport * from './lib/components/organisms/form/factory';\nexport * from './lib/components/organisms/form/form-footer/form-footer.component';\nexport * from './lib/components/organisms/form/form.component';\nexport * from './lib/components/organisms/header/header.component';\nexport * from './lib/components/organisms/header/types';\nexport * from './lib/components/organisms/item-list/item-list.component';\nexport * from './lib/components/organisms/item-list/types';\nexport * from './lib/components/organisms/no-content/no-content.component';\nexport * from './lib/components/organisms/no-content/types';\nexport * from './lib/components/organisms/toolbar/toolbar.component';\nexport * from './lib/components/organisms/toolbar/types';\nexport * from './lib/components/organisms/wizard/types';\nexport * from './lib/components/organisms/wizard/wizard-footer/wizard-footer.component';\nexport * from './lib/components/organisms/wizard/wizard.component';\n\nexport * from './lib/components/templates/layout/layout.component';\nexport * from './lib/components/templates/simple/simple.component';\nexport * from './lib/components/templates/simple/types';\n\n// Examples\nexport * from './lib/components/_examples/custom-content-demo.component';\nexport * from './lib/components/_examples/global-content-example.component';\nexport * from './lib/components/_examples/reactive-content-example.component';\n\nexport * from './lib/services/content.service';\nexport * from './lib/services/download.service';\nexport * from './lib/services/icons.service';\nexport * from './lib/services/in-app-browser.service';\nexport * from './lib/services/lang-provider/content';\nexport * from './lib/services/lang-provider/lang-provider.service';\nexport * from './lib/services/lang-provider/types';\nexport * from './lib/services/local-storage.service';\nexport * from './lib/services/navigation.service';\nexport * from './lib/services/theme.service';\nexport * from './lib/services/toast.service';\nexport * from './lib/services/types';\n\nexport * from './lib/components/types';\nexport * from './lib/shared/utils/content';\nexport * from './lib/shared/utils/dom';\nexport * from './lib/shared/utils/form-defaults';\nexport * from './lib/shared/utils/styles';\nexport * from './lib/shared/utils/text';\n"]}
|
|
@@ -5976,6 +5976,196 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
5976
5976
|
type: Output
|
|
5977
5977
|
}] } });
|
|
5978
5978
|
|
|
5979
|
+
class CustomContentDemoComponent {
|
|
5980
|
+
constructor() {
|
|
5981
|
+
this.content = inject(ContentService);
|
|
5982
|
+
this.currentLang = 'es';
|
|
5983
|
+
// Contenido global predefinido (sin className)
|
|
5984
|
+
this.saveText$ = this.content.fromContent({ key: 'save' });
|
|
5985
|
+
this.cancelText$ = this.content.fromContent({ key: 'cancel' });
|
|
5986
|
+
this.deleteText$ = this.content.fromContent({ key: 'delete' });
|
|
5987
|
+
this.loadingText$ = this.content.fromContent({ key: 'loading' });
|
|
5988
|
+
// Tu contenido global personalizado (sin className)
|
|
5989
|
+
this.dashboardText$ = this.content.fromContent({ key: 'dashboard' });
|
|
5990
|
+
this.profileText$ = this.content.fromContent({ key: 'profile' });
|
|
5991
|
+
this.settingsText$ = this.content.fromContent({ key: 'settings' });
|
|
5992
|
+
this.welcomeText$ = this.content.fromContent({
|
|
5993
|
+
key: 'welcome',
|
|
5994
|
+
interpolation: { appName: 'Mi Aplicación' },
|
|
5995
|
+
});
|
|
5996
|
+
// Contenido específico del componente Language (con className)
|
|
5997
|
+
this.spanishText$ = this.content.fromContent({
|
|
5998
|
+
className: 'Language',
|
|
5999
|
+
key: 'spanish',
|
|
6000
|
+
});
|
|
6001
|
+
this.englishText$ = this.content.fromContent({
|
|
6002
|
+
className: 'Language',
|
|
6003
|
+
key: 'english',
|
|
6004
|
+
});
|
|
6005
|
+
this.descriptionText$ = this.content.fromContent({
|
|
6006
|
+
className: 'Language',
|
|
6007
|
+
key: 'description',
|
|
6008
|
+
});
|
|
6009
|
+
// Para debug - texto síncrono
|
|
6010
|
+
this.saveTextSync = '';
|
|
6011
|
+
this.dashboardTextSync = '';
|
|
6012
|
+
this.languageDescSync = '';
|
|
6013
|
+
}
|
|
6014
|
+
ngOnInit() {
|
|
6015
|
+
// Obtener idioma actual
|
|
6016
|
+
this.content.currentLang$.subscribe(lang => {
|
|
6017
|
+
this.currentLang = lang;
|
|
6018
|
+
});
|
|
6019
|
+
// Obtener textos síncronos para debug
|
|
6020
|
+
this.updateSyncTexts();
|
|
6021
|
+
}
|
|
6022
|
+
switchLanguage() {
|
|
6023
|
+
const newLang = this.currentLang === 'es' ? LangOption.EN : LangOption.ES;
|
|
6024
|
+
this.content.setLang(newLang);
|
|
6025
|
+
// Actualizar textos síncronos después del cambio
|
|
6026
|
+
setTimeout(() => {
|
|
6027
|
+
this.updateSyncTexts();
|
|
6028
|
+
}, 100);
|
|
6029
|
+
}
|
|
6030
|
+
updateSyncTexts() {
|
|
6031
|
+
// Contenido global predefinido
|
|
6032
|
+
this.saveTextSync = this.content.getText('save');
|
|
6033
|
+
// Tu contenido global personalizado
|
|
6034
|
+
this.dashboardTextSync = this.content.getText('dashboard');
|
|
6035
|
+
// Contenido específico del componente
|
|
6036
|
+
this.languageDescSync = this.content.getText('Language', 'description');
|
|
6037
|
+
}
|
|
6038
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6039
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CustomContentDemoComponent, isStandalone: true, selector: "app-custom-content-demo", ngImport: i0, template: `
|
|
6040
|
+
<ion-card>
|
|
6041
|
+
<ion-card-header>
|
|
6042
|
+
<ion-card-title>Demo de Contenido Personalizado</ion-card-title>
|
|
6043
|
+
</ion-card-header>
|
|
6044
|
+
|
|
6045
|
+
<ion-card-content>
|
|
6046
|
+
<!-- Contenido global predefinido -->
|
|
6047
|
+
<div style="margin-bottom: 20px;">
|
|
6048
|
+
<h3>Contenido Global Predefinido:</h3>
|
|
6049
|
+
<ion-button>{{ saveText$ | async }}</ion-button>
|
|
6050
|
+
<ion-button color="medium">{{ cancelText$ | async }}</ion-button>
|
|
6051
|
+
<ion-button color="danger">{{ deleteText$ | async }}</ion-button>
|
|
6052
|
+
<p><strong>Estado:</strong> {{ loadingText$ | async }}</p>
|
|
6053
|
+
</div>
|
|
6054
|
+
|
|
6055
|
+
<!-- Tu contenido global personalizado -->
|
|
6056
|
+
<div style="margin-bottom: 20px;">
|
|
6057
|
+
<h3>Tu Contenido Global Personalizado:</h3>
|
|
6058
|
+
<p><strong>Sección:</strong> {{ dashboardText$ | async }}</p>
|
|
6059
|
+
<p><strong>Usuario:</strong> {{ profileText$ | async }}</p>
|
|
6060
|
+
<p><strong>Config:</strong> {{ settingsText$ | async }}</p>
|
|
6061
|
+
<p>{{ welcomeText$ | async }}</p>
|
|
6062
|
+
</div>
|
|
6063
|
+
|
|
6064
|
+
<!-- Contenido específico del componente Language -->
|
|
6065
|
+
<div style="margin-bottom: 20px;">
|
|
6066
|
+
<h3>Contenido del Componente Language:</h3>
|
|
6067
|
+
<ion-item>
|
|
6068
|
+
<ion-label> <strong>Español:</strong> {{ spanishText$ | async }} </ion-label>
|
|
6069
|
+
</ion-item>
|
|
6070
|
+
<ion-item>
|
|
6071
|
+
<ion-label> <strong>Inglés:</strong> {{ englishText$ | async }} </ion-label>
|
|
6072
|
+
</ion-item>
|
|
6073
|
+
<p>
|
|
6074
|
+
<em>{{ descriptionText$ | async }}</em>
|
|
6075
|
+
</p>
|
|
6076
|
+
</div>
|
|
6077
|
+
|
|
6078
|
+
<!-- Botón para cambiar idioma -->
|
|
6079
|
+
<div>
|
|
6080
|
+
<h3>Control de Idioma:</h3>
|
|
6081
|
+
<ion-button (click)="switchLanguage()" color="secondary">
|
|
6082
|
+
Cambiar a {{ currentLang === 'es' ? 'English' : 'Español' }}
|
|
6083
|
+
</ion-button>
|
|
6084
|
+
<p>
|
|
6085
|
+
<small>Idioma actual: {{ currentLang }}</small>
|
|
6086
|
+
</p>
|
|
6087
|
+
</div>
|
|
6088
|
+
|
|
6089
|
+
<!-- Debug info -->
|
|
6090
|
+
<div style="margin-top: 20px; padding: 10px; background: #f5f5f5; border-radius: 4px;">
|
|
6091
|
+
<h4>Debug Info:</h4>
|
|
6092
|
+
<p><strong>Save (sync):</strong> {{ saveTextSync }}</p>
|
|
6093
|
+
<p><strong>Dashboard (sync):</strong> {{ dashboardTextSync }}</p>
|
|
6094
|
+
<p><strong>Language Description (sync):</strong> {{ languageDescSync }}</p>
|
|
6095
|
+
</div>
|
|
6096
|
+
</ion-card-content>
|
|
6097
|
+
</ion-card>
|
|
6098
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }] }); }
|
|
6099
|
+
}
|
|
6100
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, decorators: [{
|
|
6101
|
+
type: Component,
|
|
6102
|
+
args: [{
|
|
6103
|
+
selector: 'app-custom-content-demo',
|
|
6104
|
+
standalone: true,
|
|
6105
|
+
imports: [CommonModule, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonButton, IonItem, IonLabel],
|
|
6106
|
+
template: `
|
|
6107
|
+
<ion-card>
|
|
6108
|
+
<ion-card-header>
|
|
6109
|
+
<ion-card-title>Demo de Contenido Personalizado</ion-card-title>
|
|
6110
|
+
</ion-card-header>
|
|
6111
|
+
|
|
6112
|
+
<ion-card-content>
|
|
6113
|
+
<!-- Contenido global predefinido -->
|
|
6114
|
+
<div style="margin-bottom: 20px;">
|
|
6115
|
+
<h3>Contenido Global Predefinido:</h3>
|
|
6116
|
+
<ion-button>{{ saveText$ | async }}</ion-button>
|
|
6117
|
+
<ion-button color="medium">{{ cancelText$ | async }}</ion-button>
|
|
6118
|
+
<ion-button color="danger">{{ deleteText$ | async }}</ion-button>
|
|
6119
|
+
<p><strong>Estado:</strong> {{ loadingText$ | async }}</p>
|
|
6120
|
+
</div>
|
|
6121
|
+
|
|
6122
|
+
<!-- Tu contenido global personalizado -->
|
|
6123
|
+
<div style="margin-bottom: 20px;">
|
|
6124
|
+
<h3>Tu Contenido Global Personalizado:</h3>
|
|
6125
|
+
<p><strong>Sección:</strong> {{ dashboardText$ | async }}</p>
|
|
6126
|
+
<p><strong>Usuario:</strong> {{ profileText$ | async }}</p>
|
|
6127
|
+
<p><strong>Config:</strong> {{ settingsText$ | async }}</p>
|
|
6128
|
+
<p>{{ welcomeText$ | async }}</p>
|
|
6129
|
+
</div>
|
|
6130
|
+
|
|
6131
|
+
<!-- Contenido específico del componente Language -->
|
|
6132
|
+
<div style="margin-bottom: 20px;">
|
|
6133
|
+
<h3>Contenido del Componente Language:</h3>
|
|
6134
|
+
<ion-item>
|
|
6135
|
+
<ion-label> <strong>Español:</strong> {{ spanishText$ | async }} </ion-label>
|
|
6136
|
+
</ion-item>
|
|
6137
|
+
<ion-item>
|
|
6138
|
+
<ion-label> <strong>Inglés:</strong> {{ englishText$ | async }} </ion-label>
|
|
6139
|
+
</ion-item>
|
|
6140
|
+
<p>
|
|
6141
|
+
<em>{{ descriptionText$ | async }}</em>
|
|
6142
|
+
</p>
|
|
6143
|
+
</div>
|
|
6144
|
+
|
|
6145
|
+
<!-- Botón para cambiar idioma -->
|
|
6146
|
+
<div>
|
|
6147
|
+
<h3>Control de Idioma:</h3>
|
|
6148
|
+
<ion-button (click)="switchLanguage()" color="secondary">
|
|
6149
|
+
Cambiar a {{ currentLang === 'es' ? 'English' : 'Español' }}
|
|
6150
|
+
</ion-button>
|
|
6151
|
+
<p>
|
|
6152
|
+
<small>Idioma actual: {{ currentLang }}</small>
|
|
6153
|
+
</p>
|
|
6154
|
+
</div>
|
|
6155
|
+
|
|
6156
|
+
<!-- Debug info -->
|
|
6157
|
+
<div style="margin-top: 20px; padding: 10px; background: #f5f5f5; border-radius: 4px;">
|
|
6158
|
+
<h4>Debug Info:</h4>
|
|
6159
|
+
<p><strong>Save (sync):</strong> {{ saveTextSync }}</p>
|
|
6160
|
+
<p><strong>Dashboard (sync):</strong> {{ dashboardTextSync }}</p>
|
|
6161
|
+
<p><strong>Language Description (sync):</strong> {{ languageDescSync }}</p>
|
|
6162
|
+
</div>
|
|
6163
|
+
</ion-card-content>
|
|
6164
|
+
</ion-card>
|
|
6165
|
+
`,
|
|
6166
|
+
}]
|
|
6167
|
+
}] });
|
|
6168
|
+
|
|
5979
6169
|
/**
|
|
5980
6170
|
* Comprehensive example demonstrating global content usage.
|
|
5981
6171
|
*
|
|
@@ -7093,5 +7283,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
7093
7283
|
* Generated bundle index. Do not edit.
|
|
7094
7284
|
*/
|
|
7095
7285
|
|
|
7096
|
-
export { ActionType, AlertBoxComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentStates, ContentLoaderComponent, ContentService, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, GlobalContentExampleComponent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LangOption, LangService, LayeredCardComponent, LayoutComponent, LinkComponent, LinksCakeComponent, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, ReactiveContentExampleComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, content, createContentHelper, createTextProps, fromContent, fromContentWithInterpolation, fromMultipleContent, globalContentData, goToTop, interpolateContent, isAtEnd, maxLength, replaceSpecialChars, resolveColor, resolveInputDefaultValue };
|
|
7286
|
+
export { ActionType, AlertBoxComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentStates, ContentLoaderComponent, ContentService, CustomContentDemoComponent, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, GlobalContentExampleComponent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LangOption, LangService, LayeredCardComponent, LayoutComponent, LinkComponent, LinksCakeComponent, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, ReactiveContentExampleComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, content, createContentHelper, createTextProps, fromContent, fromContentWithInterpolation, fromMultipleContent, globalContentData, goToTop, interpolateContent, isAtEnd, maxLength, replaceSpecialChars, resolveColor, resolveInputDefaultValue };
|
|
7097
7287
|
//# sourceMappingURL=valtech-components.mjs.map
|