valtech-components 2.0.281 → 2.0.283
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 +41 -1
- package/esm2022/lib/services/lang-provider/content.mjs +75 -122
- package/fesm2022/valtech-components.mjs +113 -120
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/_examples/custom-content-demo.component.d.ts +1 -0
- package/lib/services/lang-provider/content.d.ts +1 -0
- package/package.json +1 -1
|
@@ -47,6 +47,8 @@ export class CustomContentDemoComponent {
|
|
|
47
47
|
});
|
|
48
48
|
// Obtener textos síncronos para debug
|
|
49
49
|
this.updateSyncTexts();
|
|
50
|
+
// 🔍 DIAGNÓSTICO: Verificar configuración
|
|
51
|
+
this.diagnoseConfiguration();
|
|
50
52
|
}
|
|
51
53
|
switchLanguage() {
|
|
52
54
|
const newLang = this.currentLang === 'es' ? LangOption.EN : LangOption.ES;
|
|
@@ -64,6 +66,44 @@ export class CustomContentDemoComponent {
|
|
|
64
66
|
// Contenido específico del componente
|
|
65
67
|
this.languageDescSync = this.content.getText('Language', 'description');
|
|
66
68
|
}
|
|
69
|
+
diagnoseConfiguration() {
|
|
70
|
+
console.log('=== DIAGNÓSTICO DE CONFIGURACIÓN ===');
|
|
71
|
+
// Verificar acceso directo al servicio
|
|
72
|
+
console.log('ContentService available:', !!this.content);
|
|
73
|
+
console.log('Current language:', this.content.currentLang);
|
|
74
|
+
// Intentar acceso síncrono a contenido global predefinido
|
|
75
|
+
try {
|
|
76
|
+
const saveText = this.content.getText('save');
|
|
77
|
+
console.log('✅ Global predefinido (save):', saveText);
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
console.log('❌ Error global predefinido (save):', error);
|
|
81
|
+
}
|
|
82
|
+
// Intentar acceso síncrono a contenido global personalizado
|
|
83
|
+
try {
|
|
84
|
+
const dashboardText = this.content.getText('dashboard');
|
|
85
|
+
console.log('✅ Global personalizado (dashboard):', dashboardText);
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
console.log('❌ Error global personalizado (dashboard):', error);
|
|
89
|
+
}
|
|
90
|
+
// Intentar acceso síncrono a contenido de componente
|
|
91
|
+
try {
|
|
92
|
+
const spanishText = this.content.getText('Language', 'spanish');
|
|
93
|
+
console.log('✅ Componente Language (spanish):', spanishText);
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
console.log('❌ Error componente Language (spanish):', error);
|
|
97
|
+
}
|
|
98
|
+
// Intentar acceso síncrono a contenido de componente
|
|
99
|
+
try {
|
|
100
|
+
const descriptionText = this.content.getText('Language', 'description');
|
|
101
|
+
console.log('✅ Componente Language (description):', descriptionText);
|
|
102
|
+
}
|
|
103
|
+
catch (error) {
|
|
104
|
+
console.log('❌ Error componente Language (description):', error);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
67
107
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
68
108
|
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
109
|
<ion-card>
|
|
@@ -194,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
194
234
|
`,
|
|
195
235
|
}]
|
|
196
236
|
}] });
|
|
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"]}
|
|
237
|
+
//# 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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AAC1D,OAAO,EACL,SAAS,EACT,OAAO,EACP,cAAc,EACd,aAAa,EACb,YAAY,EACZ,OAAO,EACP,QAAQ,GACT,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;;;AAmEhE,MAAM,OAAO,0BAA0B;IAjEvC;QAkEU,YAAO,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAEzC,gBAAW,GAAG,IAAI,CAAC;QAEnB,+CAA+C;QAC/C,cAAS,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC;QACtD,gBAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC1D,gBAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC1D,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;QAE5D,oDAAoD;QACpD,mBAAc,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,CAAC,CAAC;QAChE,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;QAC5D,kBAAa,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;QAC9D,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YACtC,GAAG,EAAE,SAAS;YACd,aAAa,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE;SAC5C,CAAC,CAAC;QAEH,+DAA+D;QAC/D,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YACtC,SAAS,EAAE,UAAU;YACrB,GAAG,EAAE,SAAS;SACf,CAAC,CAAC;QACH,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YACtC,SAAS,EAAE,UAAU;YACrB,GAAG,EAAE,SAAS;SACf,CAAC,CAAC;QACH,qBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YAC1C,SAAS,EAAE,UAAU;YACrB,GAAG,EAAE,aAAa;SACnB,CAAC,CAAC;QAEH,8BAA8B;QAC9B,iBAAY,GAAG,EAAE,CAAC;QAClB,sBAAiB,GAAG,EAAE,CAAC;QACvB,qBAAgB,GAAG,EAAE,CAAC;KA2EvB;IAzEC,QAAQ;QACN,wBAAwB;QACxB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YACzC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,sCAAsC;QACtC,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,0CAA0C;QAC1C,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,cAAc;QACZ,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC;QAC1E,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE9B,iDAAiD;QACjD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEO,eAAe;QACrB,+BAA+B;QAC/B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEjD,oCAAoC;QACpC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAE3D,sCAAsC;QACtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;IAC1E,CAAC;IAEO,qBAAqB;QAC3B,OAAO,CAAC,GAAG,CAAC,sCAAsC,CAAC,CAAC;QAEpD,uCAAuC;QACvC,OAAO,CAAC,GAAG,CAAC,2BAA2B,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAE3D,0DAA0D;QAC1D,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAC9C,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,QAAQ,CAAC,CAAC;QACxD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;QAC3D,CAAC;QAED,4DAA4D;QAC5D,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YACxD,OAAO,CAAC,GAAG,CAAC,qCAAqC,EAAE,aAAa,CAAC,CAAC;QACpE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,2CAA2C,EAAE,KAAK,CAAC,CAAC;QAClE,CAAC;QAED,qDAAqD;QACrD,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;YAChE,OAAO,CAAC,GAAG,CAAC,kCAAkC,EAAE,WAAW,CAAC,CAAC;QAC/D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,wCAAwC,EAAE,KAAK,CAAC,CAAC;QAC/D,CAAC;QAED,qDAAqD;QACrD,IAAI,CAAC;YACH,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;YACxE,OAAO,CAAC,GAAG,CAAC,sCAAsC,EAAE,eAAe,CAAC,CAAC;QACvE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,4CAA4C,EAAE,KAAK,CAAC,CAAC;QACnE,CAAC;IACH,CAAC;+GA/GU,0BAA0B;mGAA1B,0BAA0B,mFA7D3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT,2DA5DS,YAAY,oFAAE,OAAO,yLAAE,cAAc,+EAAE,aAAa,sGAAE,YAAY,sFAAE,SAAS,oPAAE,OAAO,0NAAE,QAAQ;;4FA8D/F,0BAA0B;kBAjEtC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC;oBAC3G,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT;iBACF","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    // 🔍 DIAGNÓSTICO: Verificar configuración\n    this.diagnoseConfiguration();\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  private diagnoseConfiguration() {\n    console.log('=== DIAGNÓSTICO DE CONFIGURACIÓN ===');\n\n    // Verificar acceso directo al servicio\n    console.log('ContentService available:', !!this.content);\n    console.log('Current language:', this.content.currentLang);\n\n    // Intentar acceso síncrono a contenido global predefinido\n    try {\n      const saveText = this.content.getText('save');\n      console.log('✅ Global predefinido (save):', saveText);\n    } catch (error) {\n      console.log('❌ Error global predefinido (save):', error);\n    }\n\n    // Intentar acceso síncrono a contenido global personalizado\n    try {\n      const dashboardText = this.content.getText('dashboard');\n      console.log('✅ Global personalizado (dashboard):', dashboardText);\n    } catch (error) {\n      console.log('❌ Error global personalizado (dashboard):', error);\n    }\n\n    // Intentar acceso síncrono a contenido de componente\n    try {\n      const spanishText = this.content.getText('Language', 'spanish');\n      console.log('✅ Componente Language (spanish):', spanishText);\n    } catch (error) {\n      console.log('❌ Error componente Language (spanish):', error);\n    }\n\n    // Intentar acceso síncrono a contenido de componente\n    try {\n      const descriptionText = this.content.getText('Language', 'description');\n      console.log('✅ Componente Language (description):', descriptionText);\n    } catch (error) {\n      console.log('❌ Error componente Language (description):', error);\n    }\n  }\n}\n"]}
|
|
@@ -6,129 +6,82 @@ import { TextContent } from './types';
|
|
|
6
6
|
/**
|
|
7
7
|
* Global content that can be used across all components.
|
|
8
8
|
* These are common texts like buttons, actions, states, etc.
|
|
9
|
+
* Structure: {es: {key1: 'value1', key2: 'value2'}, en: {key1: 'value1', key2: 'value2'}}
|
|
9
10
|
*/
|
|
10
11
|
const globalContentData = {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
},
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
en: 'Loading...',
|
|
85
|
-
},
|
|
86
|
-
noData: {
|
|
87
|
-
es: 'No hay datos disponibles',
|
|
88
|
-
en: 'No data available',
|
|
89
|
-
},
|
|
90
|
-
error: {
|
|
91
|
-
es: 'Error',
|
|
92
|
-
en: 'Error',
|
|
93
|
-
},
|
|
94
|
-
success: {
|
|
95
|
-
es: 'Éxito',
|
|
96
|
-
en: 'Success',
|
|
97
|
-
},
|
|
98
|
-
warning: {
|
|
99
|
-
es: 'Advertencia',
|
|
100
|
-
en: 'Warning',
|
|
101
|
-
},
|
|
102
|
-
info: {
|
|
103
|
-
es: 'Información',
|
|
104
|
-
en: 'Information',
|
|
105
|
-
},
|
|
106
|
-
// Common confirmations
|
|
107
|
-
areYouSure: {
|
|
108
|
-
es: '¿Estás seguro?',
|
|
109
|
-
en: 'Are you sure?',
|
|
110
|
-
},
|
|
111
|
-
deleteConfirmation: {
|
|
112
|
-
es: '¿Estás seguro de que deseas eliminar {itemName}?',
|
|
113
|
-
en: 'Are you sure you want to delete {itemName}?',
|
|
114
|
-
},
|
|
115
|
-
unsavedChanges: {
|
|
116
|
-
es: 'Tienes cambios sin guardar. ¿Deseas continuar?',
|
|
117
|
-
en: 'You have unsaved changes. Do you want to continue?',
|
|
118
|
-
},
|
|
119
|
-
// Common form labels
|
|
120
|
-
required: {
|
|
121
|
-
es: 'Requerido',
|
|
122
|
-
en: 'Required',
|
|
123
|
-
},
|
|
124
|
-
optional: {
|
|
125
|
-
es: 'Opcional',
|
|
126
|
-
en: 'Optional',
|
|
127
|
-
},
|
|
128
|
-
// Common placeholders
|
|
129
|
-
searchPlaceholder: {
|
|
130
|
-
es: 'Buscar...',
|
|
131
|
-
en: 'Search...',
|
|
12
|
+
es: {
|
|
13
|
+
// Common buttons
|
|
14
|
+
ok: 'Aceptar',
|
|
15
|
+
cancel: 'Cancelar',
|
|
16
|
+
save: 'Guardar',
|
|
17
|
+
delete: 'Eliminar',
|
|
18
|
+
edit: 'Editar',
|
|
19
|
+
close: 'Cerrar',
|
|
20
|
+
back: 'Volver',
|
|
21
|
+
next: 'Siguiente',
|
|
22
|
+
previous: 'Anterior',
|
|
23
|
+
finish: 'Finalizar',
|
|
24
|
+
continue: 'Continuar',
|
|
25
|
+
// Common actions
|
|
26
|
+
add: 'Agregar',
|
|
27
|
+
remove: 'Quitar',
|
|
28
|
+
search: 'Buscar',
|
|
29
|
+
filter: 'Filtrar',
|
|
30
|
+
sort: 'Ordenar',
|
|
31
|
+
refresh: 'Actualizar',
|
|
32
|
+
// Common states and messages
|
|
33
|
+
loading: 'Cargando...',
|
|
34
|
+
noData: 'No hay datos disponibles',
|
|
35
|
+
error: 'Error',
|
|
36
|
+
success: 'Éxito',
|
|
37
|
+
warning: 'Advertencia',
|
|
38
|
+
info: 'Información',
|
|
39
|
+
// Common confirmations
|
|
40
|
+
areYouSure: '¿Estás seguro?',
|
|
41
|
+
deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',
|
|
42
|
+
unsavedChanges: 'Tienes cambios sin guardar. ¿Deseas continuar?',
|
|
43
|
+
// Common form labels
|
|
44
|
+
required: 'Requerido',
|
|
45
|
+
optional: 'Opcional',
|
|
46
|
+
// Common placeholders
|
|
47
|
+
searchPlaceholder: 'Buscar...',
|
|
48
|
+
},
|
|
49
|
+
en: {
|
|
50
|
+
// Common buttons
|
|
51
|
+
ok: 'OK',
|
|
52
|
+
cancel: 'Cancel',
|
|
53
|
+
save: 'Save',
|
|
54
|
+
delete: 'Delete',
|
|
55
|
+
edit: 'Edit',
|
|
56
|
+
close: 'Close',
|
|
57
|
+
back: 'Back',
|
|
58
|
+
next: 'Next',
|
|
59
|
+
previous: 'Previous',
|
|
60
|
+
finish: 'Finish',
|
|
61
|
+
continue: 'Continue',
|
|
62
|
+
// Common actions
|
|
63
|
+
add: 'Add',
|
|
64
|
+
remove: 'Remove',
|
|
65
|
+
search: 'Search',
|
|
66
|
+
filter: 'Filter',
|
|
67
|
+
sort: 'Sort',
|
|
68
|
+
refresh: 'Refresh',
|
|
69
|
+
// Common states and messages
|
|
70
|
+
loading: 'Loading...',
|
|
71
|
+
noData: 'No data available',
|
|
72
|
+
error: 'Error',
|
|
73
|
+
success: 'Success',
|
|
74
|
+
warning: 'Warning',
|
|
75
|
+
info: 'Information',
|
|
76
|
+
// Common confirmations
|
|
77
|
+
areYouSure: 'Are you sure?',
|
|
78
|
+
deleteConfirmation: 'Are you sure you want to delete {itemName}?',
|
|
79
|
+
unsavedChanges: 'You have unsaved changes. Do you want to continue?',
|
|
80
|
+
// Common form labels
|
|
81
|
+
required: 'Required',
|
|
82
|
+
optional: 'Optional',
|
|
83
|
+
// Common placeholders
|
|
84
|
+
searchPlaceholder: 'Search...',
|
|
132
85
|
},
|
|
133
86
|
};
|
|
134
87
|
const GlobalContent = new TextContent(globalContentData);
|
|
@@ -142,4 +95,4 @@ const content = {
|
|
|
142
95
|
export default content;
|
|
143
96
|
// Export named exports for user convenience
|
|
144
97
|
export { content, GlobalContent, globalContentData };
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLG9CQUFvQixNQUFNLDJEQUEyRCxDQUFDO0FBQzdGLE9BQU8sc0JBQXNCLE1BQU0sNkRBQTZELENBQUM7QUFDakcsT0FBTyxZQUFZLE1BQU0sNEJBQTRCLENBQUM7QUFDdEQsT0FBTyxhQUFhLE1BQU0sNkJBQTZCLENBQUM7QUFDeEQsT0FBTyxFQUFvQixXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFNeEQ7Ozs7R0FJRztBQUNILE1BQU0saUJBQWlCLEdBQXFCO0lBQzFDLEVBQUUsRUFBRTtRQUNGLGlCQUFpQjtRQUNqQixFQUFFLEVBQUUsU0FBUztRQUNiLE1BQU0sRUFBRSxVQUFVO1FBQ2xCLElBQUksRUFBRSxTQUFTO1FBQ2YsTUFBTSxFQUFFLFVBQVU7UUFDbEIsSUFBSSxFQUFFLFFBQVE7UUFDZCxLQUFLLEVBQUUsUUFBUTtRQUNmLElBQUksRUFBRSxRQUFRO1FBQ2QsSUFBSSxFQUFFLFdBQVc7UUFDakIsUUFBUSxFQUFFLFVBQVU7UUFDcEIsTUFBTSxFQUFFLFdBQVc7UUFDbkIsUUFBUSxFQUFFLFdBQVc7UUFFckIsaUJBQWlCO1FBQ2pCLEdBQUcsRUFBRSxTQUFTO1FBQ2QsTUFBTSxFQUFFLFFBQVE7UUFDaEIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsTUFBTSxFQUFFLFNBQVM7UUFDakIsSUFBSSxFQUFFLFNBQVM7UUFDZixPQUFPLEVBQUUsWUFBWTtRQUVyQiw2QkFBNkI7UUFDN0IsT0FBTyxFQUFFLGFBQWE7UUFDdEIsTUFBTSxFQUFFLDBCQUEwQjtRQUNsQyxLQUFLLEVBQUUsT0FBTztRQUNkLE9BQU8sRUFBRSxPQUFPO1FBQ2hCLE9BQU8sRUFBRSxhQUFhO1FBQ3RCLElBQUksRUFBRSxhQUFhO1FBRW5CLHVCQUF1QjtRQUN2QixVQUFVLEVBQUUsZ0JBQWdCO1FBQzVCLGtCQUFrQixFQUFFLGtEQUFrRDtRQUN0RSxjQUFjLEVBQUUsZ0RBQWdEO1FBRWhFLHFCQUFxQjtRQUNyQixRQUFRLEVBQUUsV0FBVztRQUNyQixRQUFRLEVBQUUsVUFBVTtRQUVwQixzQkFBc0I7UUFDdEIsaUJBQWlCLEVBQUUsV0FBVztLQUMvQjtJQUNELEVBQUUsRUFBRTtRQUNGLGlCQUFpQjtRQUNqQixFQUFFLEVBQUUsSUFBSTtRQUNSLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLElBQUksRUFBRSxNQUFNO1FBQ1osTUFBTSxFQUFFLFFBQVE7UUFDaEIsSUFBSSxFQUFFLE1BQU07UUFDWixLQUFLLEVBQUUsT0FBTztRQUNkLElBQUksRUFBRSxNQUFNO1FBQ1osSUFBSSxFQUFFLE1BQU07UUFDWixRQUFRLEVBQUUsVUFBVTtRQUNwQixNQUFNLEVBQUUsUUFBUTtRQUNoQixRQUFRLEVBQUUsVUFBVTtRQUVwQixpQkFBaUI7UUFDakIsR0FBRyxFQUFFLEtBQUs7UUFDVixNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsUUFBUTtRQUNoQixJQUFJLEVBQUUsTUFBTTtRQUNaLE9BQU8sRUFBRSxTQUFTO1FBRWxCLDZCQUE2QjtRQUM3QixPQUFPLEVBQUUsWUFBWTtRQUNyQixNQUFNLEVBQUUsbUJBQW1CO1FBQzNCLEtBQUssRUFBRSxPQUFPO1FBQ2QsT0FBTyxFQUFFLFNBQVM7UUFDbEIsT0FBTyxFQUFFLFNBQVM7UUFDbEIsSUFBSSxFQUFFLGFBQWE7UUFFbkIsdUJBQXVCO1FBQ3ZCLFVBQVUsRUFBRSxlQUFlO1FBQzNCLGtCQUFrQixFQUFFLDZDQUE2QztRQUNqRSxjQUFjLEVBQUUsb0RBQW9EO1FBRXBFLHFCQUFxQjtRQUNyQixRQUFRLEVBQUUsVUFBVTtRQUNwQixRQUFRLEVBQUUsVUFBVTtRQUVwQixzQkFBc0I7UUFDdEIsaUJBQWlCLEVBQUUsV0FBVztLQUMvQjtDQUNGLENBQUM7QUFFRixNQUFNLGFBQWEsR0FBRyxJQUFJLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBRXpELE1BQU0sT0FBTyxHQUFhO0lBQ3hCLE9BQU8sRUFBRSxhQUFhO0lBQ3RCLFlBQVk7SUFDWixhQUFhO0lBQ2Isc0JBQXNCO0lBQ3RCLG9CQUFvQjtDQUNyQixDQUFDO0FBRUYsZUFBZSxPQUFPLENBQUM7QUFFdkIsNENBQTRDO0FBQzVDLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgR2xvYmFsQ29udGVudEV4YW1wbGUgZnJvbSAnLi4vLi4vY29tcG9uZW50cy9fZXhhbXBsZXMvZ2xvYmFsLWNvbnRlbnQtZXhhbXBsZS1jb250ZW50JztcbmltcG9ydCBSZWFjdGl2ZUNvbnRlbnRFeGFtcGxlIGZyb20gJy4uLy4uL2NvbXBvbmVudHMvX2V4YW1wbGVzL3JlYWN0aXZlLWNvbnRlbnQtZXhhbXBsZS1jb250ZW50JztcbmltcG9ydCBMYW5nU2V0dGluZ3MgZnJvbSAnLi9jb21wb25lbnRzL2xhbmctc2V0dGluZ3MnO1xuaW1wb3J0IFRoZW1lU2V0dGluZ3MgZnJvbSAnLi9jb21wb25lbnRzL3RoZW1lLXNldHRpbmdzJztcbmltcG9ydCB7IExhbmd1YWdlc0NvbnRlbnQsIFRleHRDb250ZW50IH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvdmlkZXIge1xuICBbeDogc3RyaW5nXTogVGV4dENvbnRlbnQ7XG59XG5cbi8qKlxuICogR2xvYmFsIGNvbnRlbnQgdGhhdCBjYW4gYmUgdXNlZCBhY3Jvc3MgYWxsIGNvbXBvbmVudHMuXG4gKiBUaGVzZSBhcmUgY29tbW9uIHRleHRzIGxpa2UgYnV0dG9ucywgYWN0aW9ucywgc3RhdGVzLCBldGMuXG4gKiBTdHJ1Y3R1cmU6IHtlczoge2tleTE6ICd2YWx1ZTEnLCBrZXkyOiAndmFsdWUyJ30sIGVuOiB7a2V5MTogJ3ZhbHVlMScsIGtleTI6ICd2YWx1ZTInfX1cbiAqL1xuY29uc3QgZ2xvYmFsQ29udGVudERhdGE6IExhbmd1YWdlc0NvbnRlbnQgPSB7XG4gIGVzOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnNcbiAgICBvazogJ0FjZXB0YXInLFxuICAgIGNhbmNlbDogJ0NhbmNlbGFyJyxcbiAgICBzYXZlOiAnR3VhcmRhcicsXG4gICAgZGVsZXRlOiAnRWxpbWluYXInLFxuICAgIGVkaXQ6ICdFZGl0YXInLFxuICAgIGNsb3NlOiAnQ2VycmFyJyxcbiAgICBiYWNrOiAnVm9sdmVyJyxcbiAgICBuZXh0OiAnU2lndWllbnRlJyxcbiAgICBwcmV2aW91czogJ0FudGVyaW9yJyxcbiAgICBmaW5pc2g6ICdGaW5hbGl6YXInLFxuICAgIGNvbnRpbnVlOiAnQ29udGludWFyJyxcblxuICAgIC8vIENvbW1vbiBhY3Rpb25zXG4gICAgYWRkOiAnQWdyZWdhcicsXG4gICAgcmVtb3ZlOiAnUXVpdGFyJyxcbiAgICBzZWFyY2g6ICdCdXNjYXInLFxuICAgIGZpbHRlcjogJ0ZpbHRyYXInLFxuICAgIHNvcnQ6ICdPcmRlbmFyJyxcbiAgICByZWZyZXNoOiAnQWN0dWFsaXphcicsXG5cbiAgICAvLyBDb21tb24gc3RhdGVzIGFuZCBtZXNzYWdlc1xuICAgIGxvYWRpbmc6ICdDYXJnYW5kby4uLicsXG4gICAgbm9EYXRhOiAnTm8gaGF5IGRhdG9zIGRpc3BvbmlibGVzJyxcbiAgICBlcnJvcjogJ0Vycm9yJyxcbiAgICBzdWNjZXNzOiAnw4l4aXRvJyxcbiAgICB3YXJuaW5nOiAnQWR2ZXJ0ZW5jaWEnLFxuICAgIGluZm86ICdJbmZvcm1hY2nDs24nLFxuXG4gICAgLy8gQ29tbW9uIGNvbmZpcm1hdGlvbnNcbiAgICBhcmVZb3VTdXJlOiAnwr9Fc3TDoXMgc2VndXJvPycsXG4gICAgZGVsZXRlQ29uZmlybWF0aW9uOiAnwr9Fc3TDoXMgc2VndXJvIGRlIHF1ZSBkZXNlYXMgZWxpbWluYXIge2l0ZW1OYW1lfT8nLFxuICAgIHVuc2F2ZWRDaGFuZ2VzOiAnVGllbmVzIGNhbWJpb3Mgc2luIGd1YXJkYXIuIMK/RGVzZWFzIGNvbnRpbnVhcj8nLFxuXG4gICAgLy8gQ29tbW9uIGZvcm0gbGFiZWxzXG4gICAgcmVxdWlyZWQ6ICdSZXF1ZXJpZG8nLFxuICAgIG9wdGlvbmFsOiAnT3BjaW9uYWwnLFxuXG4gICAgLy8gQ29tbW9uIHBsYWNlaG9sZGVyc1xuICAgIHNlYXJjaFBsYWNlaG9sZGVyOiAnQnVzY2FyLi4uJyxcbiAgfSxcbiAgZW46IHtcbiAgICAvLyBDb21tb24gYnV0dG9uc1xuICAgIG9rOiAnT0snLFxuICAgIGNhbmNlbDogJ0NhbmNlbCcsXG4gICAgc2F2ZTogJ1NhdmUnLFxuICAgIGRlbGV0ZTogJ0RlbGV0ZScsXG4gICAgZWRpdDogJ0VkaXQnLFxuICAgIGNsb3NlOiAnQ2xvc2UnLFxuICAgIGJhY2s6ICdCYWNrJyxcbiAgICBuZXh0OiAnTmV4dCcsXG4gICAgcHJldmlvdXM6ICdQcmV2aW91cycsXG4gICAgZmluaXNoOiAnRmluaXNoJyxcbiAgICBjb250aW51ZTogJ0NvbnRpbnVlJyxcblxuICAgIC8vIENvbW1vbiBhY3Rpb25zXG4gICAgYWRkOiAnQWRkJyxcbiAgICByZW1vdmU6ICdSZW1vdmUnLFxuICAgIHNlYXJjaDogJ1NlYXJjaCcsXG4gICAgZmlsdGVyOiAnRmlsdGVyJyxcbiAgICBzb3J0OiAnU29ydCcsXG4gICAgcmVmcmVzaDogJ1JlZnJlc2gnLFxuXG4gICAgLy8gQ29tbW9uIHN0YXRlcyBhbmQgbWVzc2FnZXNcbiAgICBsb2FkaW5nOiAnTG9hZGluZy4uLicsXG4gICAgbm9EYXRhOiAnTm8gZGF0YSBhdmFpbGFibGUnLFxuICAgIGVycm9yOiAnRXJyb3InLFxuICAgIHN1Y2Nlc3M6ICdTdWNjZXNzJyxcbiAgICB3YXJuaW5nOiAnV2FybmluZycsXG4gICAgaW5mbzogJ0luZm9ybWF0aW9uJyxcblxuICAgIC8vIENvbW1vbiBjb25maXJtYXRpb25zXG4gICAgYXJlWW91U3VyZTogJ0FyZSB5b3Ugc3VyZT8nLFxuICAgIGRlbGV0ZUNvbmZpcm1hdGlvbjogJ0FyZSB5b3Ugc3VyZSB5b3Ugd2FudCB0byBkZWxldGUge2l0ZW1OYW1lfT8nLFxuICAgIHVuc2F2ZWRDaGFuZ2VzOiAnWW91IGhhdmUgdW5zYXZlZCBjaGFuZ2VzLiBEbyB5b3Ugd2FudCB0byBjb250aW51ZT8nLFxuXG4gICAgLy8gQ29tbW9uIGZvcm0gbGFiZWxzXG4gICAgcmVxdWlyZWQ6ICdSZXF1aXJlZCcsXG4gICAgb3B0aW9uYWw6ICdPcHRpb25hbCcsXG5cbiAgICAvLyBDb21tb24gcGxhY2Vob2xkZXJzXG4gICAgc2VhcmNoUGxhY2Vob2xkZXI6ICdTZWFyY2guLi4nLFxuICB9LFxufTtcblxuY29uc3QgR2xvYmFsQ29udGVudCA9IG5ldyBUZXh0Q29udGVudChnbG9iYWxDb250ZW50RGF0YSk7XG5cbmNvbnN0IGNvbnRlbnQ6IFByb3ZpZGVyID0ge1xuICBfZ2xvYmFsOiBHbG9iYWxDb250ZW50LFxuICBMYW5nU2V0dGluZ3MsXG4gIFRoZW1lU2V0dGluZ3MsXG4gIFJlYWN0aXZlQ29udGVudEV4YW1wbGUsXG4gIEdsb2JhbENvbnRlbnRFeGFtcGxlLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgY29udGVudDtcblxuLy8gRXhwb3J0IG5hbWVkIGV4cG9ydHMgZm9yIHVzZXIgY29udmVuaWVuY2VcbmV4cG9ydCB7IGNvbnRlbnQsIEdsb2JhbENvbnRlbnQsIGdsb2JhbENvbnRlbnREYXRhIH07XG4iXX0=
|
|
@@ -6018,6 +6018,8 @@ class CustomContentDemoComponent {
|
|
|
6018
6018
|
});
|
|
6019
6019
|
// Obtener textos síncronos para debug
|
|
6020
6020
|
this.updateSyncTexts();
|
|
6021
|
+
// 🔍 DIAGNÓSTICO: Verificar configuración
|
|
6022
|
+
this.diagnoseConfiguration();
|
|
6021
6023
|
}
|
|
6022
6024
|
switchLanguage() {
|
|
6023
6025
|
const newLang = this.currentLang === 'es' ? LangOption.EN : LangOption.ES;
|
|
@@ -6035,6 +6037,44 @@ class CustomContentDemoComponent {
|
|
|
6035
6037
|
// Contenido específico del componente
|
|
6036
6038
|
this.languageDescSync = this.content.getText('Language', 'description');
|
|
6037
6039
|
}
|
|
6040
|
+
diagnoseConfiguration() {
|
|
6041
|
+
console.log('=== DIAGNÓSTICO DE CONFIGURACIÓN ===');
|
|
6042
|
+
// Verificar acceso directo al servicio
|
|
6043
|
+
console.log('ContentService available:', !!this.content);
|
|
6044
|
+
console.log('Current language:', this.content.currentLang);
|
|
6045
|
+
// Intentar acceso síncrono a contenido global predefinido
|
|
6046
|
+
try {
|
|
6047
|
+
const saveText = this.content.getText('save');
|
|
6048
|
+
console.log('✅ Global predefinido (save):', saveText);
|
|
6049
|
+
}
|
|
6050
|
+
catch (error) {
|
|
6051
|
+
console.log('❌ Error global predefinido (save):', error);
|
|
6052
|
+
}
|
|
6053
|
+
// Intentar acceso síncrono a contenido global personalizado
|
|
6054
|
+
try {
|
|
6055
|
+
const dashboardText = this.content.getText('dashboard');
|
|
6056
|
+
console.log('✅ Global personalizado (dashboard):', dashboardText);
|
|
6057
|
+
}
|
|
6058
|
+
catch (error) {
|
|
6059
|
+
console.log('❌ Error global personalizado (dashboard):', error);
|
|
6060
|
+
}
|
|
6061
|
+
// Intentar acceso síncrono a contenido de componente
|
|
6062
|
+
try {
|
|
6063
|
+
const spanishText = this.content.getText('Language', 'spanish');
|
|
6064
|
+
console.log('✅ Componente Language (spanish):', spanishText);
|
|
6065
|
+
}
|
|
6066
|
+
catch (error) {
|
|
6067
|
+
console.log('❌ Error componente Language (spanish):', error);
|
|
6068
|
+
}
|
|
6069
|
+
// Intentar acceso síncrono a contenido de componente
|
|
6070
|
+
try {
|
|
6071
|
+
const descriptionText = this.content.getText('Language', 'description');
|
|
6072
|
+
console.log('✅ Componente Language (description):', descriptionText);
|
|
6073
|
+
}
|
|
6074
|
+
catch (error) {
|
|
6075
|
+
console.log('❌ Error componente Language (description):', error);
|
|
6076
|
+
}
|
|
6077
|
+
}
|
|
6038
6078
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomContentDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6039
6079
|
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
6080
|
<ion-card>
|
|
@@ -7094,129 +7134,82 @@ var ThemeSettings = new TextContent(text);
|
|
|
7094
7134
|
/**
|
|
7095
7135
|
* Global content that can be used across all components.
|
|
7096
7136
|
* These are common texts like buttons, actions, states, etc.
|
|
7137
|
+
* Structure: {es: {key1: 'value1', key2: 'value2'}, en: {key1: 'value1', key2: 'value2'}}
|
|
7097
7138
|
*/
|
|
7098
7139
|
const globalContentData = {
|
|
7099
|
-
|
|
7100
|
-
|
|
7101
|
-
|
|
7102
|
-
|
|
7103
|
-
|
|
7104
|
-
|
|
7105
|
-
|
|
7106
|
-
|
|
7107
|
-
|
|
7108
|
-
|
|
7109
|
-
|
|
7110
|
-
|
|
7111
|
-
|
|
7112
|
-
|
|
7113
|
-
|
|
7114
|
-
|
|
7115
|
-
|
|
7116
|
-
|
|
7117
|
-
|
|
7118
|
-
|
|
7119
|
-
|
|
7120
|
-
|
|
7121
|
-
|
|
7122
|
-
|
|
7123
|
-
|
|
7124
|
-
|
|
7125
|
-
|
|
7126
|
-
|
|
7127
|
-
|
|
7128
|
-
|
|
7129
|
-
|
|
7130
|
-
|
|
7131
|
-
|
|
7132
|
-
|
|
7133
|
-
|
|
7134
|
-
|
|
7135
|
-
},
|
|
7136
|
-
finish: {
|
|
7137
|
-
es: 'Finalizar',
|
|
7138
|
-
en: 'Finish',
|
|
7139
|
-
},
|
|
7140
|
-
continue: {
|
|
7141
|
-
es: 'Continuar',
|
|
7142
|
-
en: 'Continue',
|
|
7143
|
-
},
|
|
7144
|
-
// Common actions
|
|
7145
|
-
add: {
|
|
7146
|
-
es: 'Agregar',
|
|
7147
|
-
en: 'Add',
|
|
7148
|
-
},
|
|
7149
|
-
remove: {
|
|
7150
|
-
es: 'Quitar',
|
|
7151
|
-
en: 'Remove',
|
|
7152
|
-
},
|
|
7153
|
-
search: {
|
|
7154
|
-
es: 'Buscar',
|
|
7155
|
-
en: 'Search',
|
|
7156
|
-
},
|
|
7157
|
-
filter: {
|
|
7158
|
-
es: 'Filtrar',
|
|
7159
|
-
en: 'Filter',
|
|
7160
|
-
},
|
|
7161
|
-
sort: {
|
|
7162
|
-
es: 'Ordenar',
|
|
7163
|
-
en: 'Sort',
|
|
7164
|
-
},
|
|
7165
|
-
refresh: {
|
|
7166
|
-
es: 'Actualizar',
|
|
7167
|
-
en: 'Refresh',
|
|
7168
|
-
},
|
|
7169
|
-
// Common states and messages
|
|
7170
|
-
loading: {
|
|
7171
|
-
es: 'Cargando...',
|
|
7172
|
-
en: 'Loading...',
|
|
7173
|
-
},
|
|
7174
|
-
noData: {
|
|
7175
|
-
es: 'No hay datos disponibles',
|
|
7176
|
-
en: 'No data available',
|
|
7177
|
-
},
|
|
7178
|
-
error: {
|
|
7179
|
-
es: 'Error',
|
|
7180
|
-
en: 'Error',
|
|
7181
|
-
},
|
|
7182
|
-
success: {
|
|
7183
|
-
es: 'Éxito',
|
|
7184
|
-
en: 'Success',
|
|
7185
|
-
},
|
|
7186
|
-
warning: {
|
|
7187
|
-
es: 'Advertencia',
|
|
7188
|
-
en: 'Warning',
|
|
7189
|
-
},
|
|
7190
|
-
info: {
|
|
7191
|
-
es: 'Información',
|
|
7192
|
-
en: 'Information',
|
|
7193
|
-
},
|
|
7194
|
-
// Common confirmations
|
|
7195
|
-
areYouSure: {
|
|
7196
|
-
es: '¿Estás seguro?',
|
|
7197
|
-
en: 'Are you sure?',
|
|
7198
|
-
},
|
|
7199
|
-
deleteConfirmation: {
|
|
7200
|
-
es: '¿Estás seguro de que deseas eliminar {itemName}?',
|
|
7201
|
-
en: 'Are you sure you want to delete {itemName}?',
|
|
7202
|
-
},
|
|
7203
|
-
unsavedChanges: {
|
|
7204
|
-
es: 'Tienes cambios sin guardar. ¿Deseas continuar?',
|
|
7205
|
-
en: 'You have unsaved changes. Do you want to continue?',
|
|
7206
|
-
},
|
|
7207
|
-
// Common form labels
|
|
7208
|
-
required: {
|
|
7209
|
-
es: 'Requerido',
|
|
7210
|
-
en: 'Required',
|
|
7211
|
-
},
|
|
7212
|
-
optional: {
|
|
7213
|
-
es: 'Opcional',
|
|
7214
|
-
en: 'Optional',
|
|
7140
|
+
es: {
|
|
7141
|
+
// Common buttons
|
|
7142
|
+
ok: 'Aceptar',
|
|
7143
|
+
cancel: 'Cancelar',
|
|
7144
|
+
save: 'Guardar',
|
|
7145
|
+
delete: 'Eliminar',
|
|
7146
|
+
edit: 'Editar',
|
|
7147
|
+
close: 'Cerrar',
|
|
7148
|
+
back: 'Volver',
|
|
7149
|
+
next: 'Siguiente',
|
|
7150
|
+
previous: 'Anterior',
|
|
7151
|
+
finish: 'Finalizar',
|
|
7152
|
+
continue: 'Continuar',
|
|
7153
|
+
// Common actions
|
|
7154
|
+
add: 'Agregar',
|
|
7155
|
+
remove: 'Quitar',
|
|
7156
|
+
search: 'Buscar',
|
|
7157
|
+
filter: 'Filtrar',
|
|
7158
|
+
sort: 'Ordenar',
|
|
7159
|
+
refresh: 'Actualizar',
|
|
7160
|
+
// Common states and messages
|
|
7161
|
+
loading: 'Cargando...',
|
|
7162
|
+
noData: 'No hay datos disponibles',
|
|
7163
|
+
error: 'Error',
|
|
7164
|
+
success: 'Éxito',
|
|
7165
|
+
warning: 'Advertencia',
|
|
7166
|
+
info: 'Información',
|
|
7167
|
+
// Common confirmations
|
|
7168
|
+
areYouSure: '¿Estás seguro?',
|
|
7169
|
+
deleteConfirmation: '¿Estás seguro de que deseas eliminar {itemName}?',
|
|
7170
|
+
unsavedChanges: 'Tienes cambios sin guardar. ¿Deseas continuar?',
|
|
7171
|
+
// Common form labels
|
|
7172
|
+
required: 'Requerido',
|
|
7173
|
+
optional: 'Opcional',
|
|
7174
|
+
// Common placeholders
|
|
7175
|
+
searchPlaceholder: 'Buscar...',
|
|
7215
7176
|
},
|
|
7216
|
-
|
|
7217
|
-
|
|
7218
|
-
|
|
7219
|
-
|
|
7177
|
+
en: {
|
|
7178
|
+
// Common buttons
|
|
7179
|
+
ok: 'OK',
|
|
7180
|
+
cancel: 'Cancel',
|
|
7181
|
+
save: 'Save',
|
|
7182
|
+
delete: 'Delete',
|
|
7183
|
+
edit: 'Edit',
|
|
7184
|
+
close: 'Close',
|
|
7185
|
+
back: 'Back',
|
|
7186
|
+
next: 'Next',
|
|
7187
|
+
previous: 'Previous',
|
|
7188
|
+
finish: 'Finish',
|
|
7189
|
+
continue: 'Continue',
|
|
7190
|
+
// Common actions
|
|
7191
|
+
add: 'Add',
|
|
7192
|
+
remove: 'Remove',
|
|
7193
|
+
search: 'Search',
|
|
7194
|
+
filter: 'Filter',
|
|
7195
|
+
sort: 'Sort',
|
|
7196
|
+
refresh: 'Refresh',
|
|
7197
|
+
// Common states and messages
|
|
7198
|
+
loading: 'Loading...',
|
|
7199
|
+
noData: 'No data available',
|
|
7200
|
+
error: 'Error',
|
|
7201
|
+
success: 'Success',
|
|
7202
|
+
warning: 'Warning',
|
|
7203
|
+
info: 'Information',
|
|
7204
|
+
// Common confirmations
|
|
7205
|
+
areYouSure: 'Are you sure?',
|
|
7206
|
+
deleteConfirmation: 'Are you sure you want to delete {itemName}?',
|
|
7207
|
+
unsavedChanges: 'You have unsaved changes. Do you want to continue?',
|
|
7208
|
+
// Common form labels
|
|
7209
|
+
required: 'Required',
|
|
7210
|
+
optional: 'Optional',
|
|
7211
|
+
// Common placeholders
|
|
7212
|
+
searchPlaceholder: 'Search...',
|
|
7220
7213
|
},
|
|
7221
7214
|
};
|
|
7222
7215
|
const GlobalContent = new TextContent(globalContentData);
|