valtech-components 2.0.716 → 2.0.718
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/molecules/links-accordion/links-accordion.component.mjs +67 -49
- package/esm2022/lib/services/i18n/default-content.mjs +9 -1
- package/esm2022/lib/services/i18n/i18n.service.mjs +24 -3
- package/esm2022/lib/shared/utils/datetime.mjs +24 -0
- package/esm2022/lib/version.mjs +2 -2
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/valtech-components.mjs +122 -52
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/services/i18n/i18n.service.d.ts +16 -0
- package/lib/shared/utils/datetime.d.ts +21 -0
- package/lib/version.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -96,39 +96,48 @@ export class LinksAccordionComponent {
|
|
|
96
96
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: LinksAccordionComponent, isStandalone: true, selector: "val-links-accordion", inputs: { props: "props" }, outputs: { navigate: "navigate" }, viewQueries: [{ propertyName: "accordionGroup", first: true, predicate: ["accordionGroup"], descendants: true }], ngImport: i0, template: `
|
|
97
97
|
<div class="links-accordion">
|
|
98
98
|
<ion-accordion-group #accordionGroup>
|
|
99
|
-
<
|
|
100
|
-
|
|
101
|
-
[value]="getSectionValue(section, i)"
|
|
102
|
-
[toggleIcon]="section.links?.length ? 'chevron-down-outline' : ''"
|
|
103
|
-
[readonly]="!section.links?.length"
|
|
104
|
-
>
|
|
99
|
+
<ng-container *ngFor="let section of props.sections; let i = index">
|
|
100
|
+
<!-- Direct-link section: route + no children -->
|
|
105
101
|
<ion-item
|
|
106
|
-
|
|
102
|
+
*ngIf="section.route && !section.links?.length"
|
|
103
|
+
class="direct-link"
|
|
107
104
|
color="light"
|
|
108
105
|
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
109
|
-
(click)="
|
|
110
|
-
|
|
106
|
+
(click)="onLinkClick(section.route!, $event)"
|
|
107
|
+
button
|
|
111
108
|
lines="none"
|
|
112
109
|
>
|
|
113
110
|
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
114
111
|
</ion-item>
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
112
|
+
|
|
113
|
+
<!-- Accordion section: has children -->
|
|
114
|
+
<ion-accordion
|
|
118
115
|
*ngIf="section.links?.length"
|
|
116
|
+
[value]="getSectionValue(section, i)"
|
|
117
|
+
toggleIcon="chevron-down-outline"
|
|
119
118
|
>
|
|
120
|
-
<ion-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
>
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
119
|
+
<ion-item
|
|
120
|
+
slot="header"
|
|
121
|
+
color="light"
|
|
122
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
123
|
+
lines="none"
|
|
124
|
+
>
|
|
125
|
+
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
126
|
+
</ion-item>
|
|
127
|
+
<div slot="content" [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }">
|
|
128
|
+
<ion-list lines="none">
|
|
129
|
+
<ion-item
|
|
130
|
+
*ngFor="let link of section.links"
|
|
131
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
132
|
+
(click)="onLinkClick(link.route, $event)"
|
|
133
|
+
button
|
|
134
|
+
>
|
|
135
|
+
<ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
|
|
136
|
+
</ion-item>
|
|
137
|
+
</ion-list>
|
|
138
|
+
</div>
|
|
139
|
+
</ion-accordion>
|
|
140
|
+
</ng-container>
|
|
132
141
|
</ion-accordion-group>
|
|
133
142
|
</div>
|
|
134
143
|
`, isInline: true, styles: [".links-accordion .accordion-label{font-size:1.3rem}.links-accordion .accordion-item-label{font-size:1.1rem}.links-accordion ion-item{--background: var(--ion-color-light-tint)}.links-accordion ion-accordion{background:transparent}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: IonAccordionGroup, selector: "ion-accordion-group", inputs: ["animated", "disabled", "expand", "mode", "multiple", "readonly", "value"] }, { kind: "component", type: IonAccordion, selector: "ion-accordion", inputs: ["disabled", "mode", "readonly", "toggleIcon", "toggleIconSlot", "value"] }, { 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"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }] }); }
|
|
@@ -138,39 +147,48 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
138
147
|
args: [{ selector: 'val-links-accordion', standalone: true, imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList], template: `
|
|
139
148
|
<div class="links-accordion">
|
|
140
149
|
<ion-accordion-group #accordionGroup>
|
|
141
|
-
<
|
|
142
|
-
|
|
143
|
-
[value]="getSectionValue(section, i)"
|
|
144
|
-
[toggleIcon]="section.links?.length ? 'chevron-down-outline' : ''"
|
|
145
|
-
[readonly]="!section.links?.length"
|
|
146
|
-
>
|
|
150
|
+
<ng-container *ngFor="let section of props.sections; let i = index">
|
|
151
|
+
<!-- Direct-link section: route + no children -->
|
|
147
152
|
<ion-item
|
|
148
|
-
|
|
153
|
+
*ngIf="section.route && !section.links?.length"
|
|
154
|
+
class="direct-link"
|
|
149
155
|
color="light"
|
|
150
156
|
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
151
|
-
(click)="
|
|
152
|
-
|
|
157
|
+
(click)="onLinkClick(section.route!, $event)"
|
|
158
|
+
button
|
|
153
159
|
lines="none"
|
|
154
160
|
>
|
|
155
161
|
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
156
162
|
</ion-item>
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
163
|
+
|
|
164
|
+
<!-- Accordion section: has children -->
|
|
165
|
+
<ion-accordion
|
|
160
166
|
*ngIf="section.links?.length"
|
|
167
|
+
[value]="getSectionValue(section, i)"
|
|
168
|
+
toggleIcon="chevron-down-outline"
|
|
161
169
|
>
|
|
162
|
-
<ion-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
>
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
170
|
+
<ion-item
|
|
171
|
+
slot="header"
|
|
172
|
+
color="light"
|
|
173
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
174
|
+
lines="none"
|
|
175
|
+
>
|
|
176
|
+
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
177
|
+
</ion-item>
|
|
178
|
+
<div slot="content" [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }">
|
|
179
|
+
<ion-list lines="none">
|
|
180
|
+
<ion-item
|
|
181
|
+
*ngFor="let link of section.links"
|
|
182
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
183
|
+
(click)="onLinkClick(link.route, $event)"
|
|
184
|
+
button
|
|
185
|
+
>
|
|
186
|
+
<ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
|
|
187
|
+
</ion-item>
|
|
188
|
+
</ion-list>
|
|
189
|
+
</div>
|
|
190
|
+
</ion-accordion>
|
|
191
|
+
</ng-container>
|
|
174
192
|
</ion-accordion-group>
|
|
175
193
|
</div>
|
|
176
194
|
`, styles: [".links-accordion .accordion-label{font-size:1.3rem}.links-accordion .accordion-item-label{font-size:1.1rem}.links-accordion ion-item{--background: var(--ion-color-light-tint)}.links-accordion ion-accordion{background:transparent}\n"] }]
|
|
@@ -182,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
182
200
|
type: ViewChild,
|
|
183
201
|
args: ['accordionGroup']
|
|
184
202
|
}] } });
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"links-accordion.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/links-accordion/links-accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonAccordion, IonAccordionGroup, IonItem, IonLabel, IonList, MenuController } from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport { LinksAccordionLink, LinksAccordionMetadata, LinksAccordionSection } from './types';\n\n/**\n * val-links-accordion\n *\n * A hierarchical navigation component using Ionic accordions.\n * Supports sections with optional sub-links and automatic menu closing.\n *\n * @example\n * <val-links-accordion\n *   [props]=\"{\n *     sections: [\n *       { title: 'Home', route: ['/'] },\n *       { title: 'Products', links: [\n *         { text: 'Catalog', route: ['/products'] },\n *         { text: 'New Arrivals', route: ['/products', 'new'] }\n *       ]}\n *     ]\n *   }\"\n *   (navigate)=\"onNavigate($event)\"\n * ></val-links-accordion>\n *\n * @input props - Accordion configuration\n * @output navigate - Emits route when a link is clicked\n */\n@Component({\n  selector: 'val-links-accordion',\n  standalone: true,\n  imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList],\n  template: `\n    <div class=\"links-accordion\">\n      <ion-accordion-group #accordionGroup>\n        <ion-accordion\n          *ngFor=\"let section of props.sections; let i = index\"\n          [value]=\"getSectionValue(section, i)\"\n          [toggleIcon]=\"section.links?.length ? 'chevron-down-outline' : ''\"\n          [readonly]=\"!section.links?.length\"\n        >\n          <ion-item\n            slot=\"header\"\n            color=\"light\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            (click)=\"section.route ? onLinkClick(section.route, $event) : null\"\n            [button]=\"!!section.route\"\n            lines=\"none\"\n          >\n            <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n          </ion-item>\n          <div\n            slot=\"content\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            *ngIf=\"section.links?.length\"\n          >\n            <ion-list lines=\"none\">\n              <ion-item\n                *ngFor=\"let link of section.links\"\n                [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n                (click)=\"onLinkClick(link.route, $event)\"\n                button\n              >\n                <ion-label class=\"accordion-item-label\">{{ getLinkText(link) }}</ion-label>\n              </ion-item>\n            </ion-list>\n          </div>\n        </ion-accordion>\n      </ion-accordion-group>\n    </div>\n  `,\n  styleUrls: ['./links-accordion.component.scss'],\n})\nexport class LinksAccordionComponent {\n  private i18n = inject(I18nService);\n\n  /**\n   * Accordion configuration.\n   */\n  @Input() props: LinksAccordionMetadata = {\n    sections: [],\n    backgroundColor: 'var(--ion-background-color)',\n    closeMenuOnClick: true,\n    closeAccordionOnClick: true,\n  };\n\n  /**\n   * Emits the route when a link is clicked.\n   */\n  @Output() navigate = new EventEmitter<string[]>();\n\n  @ViewChild('accordionGroup') accordionGroup!: IonAccordionGroup;\n\n  constructor(\n    private router: Router,\n    private menuCtrl: MenuController\n  ) {}\n\n  /**\n   * Gets a unique value for the accordion section.\n   */\n  getSectionValue(section: LinksAccordionSection, index: number): string {\n    return section.titleKey || section.title || `section-${index}`;\n  }\n\n  /**\n   * Gets the section title, supporting i18n via titleKey.\n   */\n  getSectionTitle(section: LinksAccordionSection): string {\n    if (section.titleKey && this.props.i18nNamespace) {\n      return this.i18n.t(section.titleKey, this.props.i18nNamespace);\n    }\n    return section.title || '';\n  }\n\n  /**\n   * Gets the link text, supporting i18n via textKey.\n   */\n  getLinkText(link: LinksAccordionLink): string {\n    if (link.textKey && this.props.i18nNamespace) {\n      return this.i18n.t(link.textKey, this.props.i18nNamespace);\n    }\n    return link.text || '';\n  }\n\n  /**\n   * Handles link click - closes accordion/menu and navigates.\n   */\n  async onLinkClick(route: string[], event?: Event): Promise<void> {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    // Close accordion before navigating\n    if (this.props.closeAccordionOnClick !== false && this.accordionGroup) {\n      this.accordionGroup.value = undefined;\n    }\n\n    // Close menu if enabled\n    if (this.props.closeMenuOnClick !== false) {\n      await this.menuCtrl.close();\n    }\n\n    // Emit event\n    this.navigate.emit(route);\n\n    // Navigate\n    this.router.navigate(route);\n  }\n}\n"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"links-accordion.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/links-accordion/links-accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonAccordion, IonAccordionGroup, IonItem, IonLabel, IonList, MenuController } from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport { LinksAccordionLink, LinksAccordionMetadata, LinksAccordionSection } from './types';\n\n/**\n * val-links-accordion\n *\n * A hierarchical navigation component using Ionic accordions.\n * Supports sections with optional sub-links and automatic menu closing.\n *\n * @example\n * <val-links-accordion\n *   [props]=\"{\n *     sections: [\n *       { title: 'Home', route: ['/'] },\n *       { title: 'Products', links: [\n *         { text: 'Catalog', route: ['/products'] },\n *         { text: 'New Arrivals', route: ['/products', 'new'] }\n *       ]}\n *     ]\n *   }\"\n *   (navigate)=\"onNavigate($event)\"\n * ></val-links-accordion>\n *\n * @input props - Accordion configuration\n * @output navigate - Emits route when a link is clicked\n */\n@Component({\n  selector: 'val-links-accordion',\n  standalone: true,\n  imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList],\n  template: `\n    <div class=\"links-accordion\">\n      <ion-accordion-group #accordionGroup>\n        <ng-container *ngFor=\"let section of props.sections; let i = index\">\n          <!-- Direct-link section: route + no children -->\n          <ion-item\n            *ngIf=\"section.route && !section.links?.length\"\n            class=\"direct-link\"\n            color=\"light\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            (click)=\"onLinkClick(section.route!, $event)\"\n            button\n            lines=\"none\"\n          >\n            <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n          </ion-item>\n\n          <!-- Accordion section: has children -->\n          <ion-accordion\n            *ngIf=\"section.links?.length\"\n            [value]=\"getSectionValue(section, i)\"\n            toggleIcon=\"chevron-down-outline\"\n          >\n            <ion-item\n              slot=\"header\"\n              color=\"light\"\n              [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n              lines=\"none\"\n            >\n              <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n            </ion-item>\n            <div slot=\"content\" [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\">\n              <ion-list lines=\"none\">\n                <ion-item\n                  *ngFor=\"let link of section.links\"\n                  [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n                  (click)=\"onLinkClick(link.route, $event)\"\n                  button\n                >\n                  <ion-label class=\"accordion-item-label\">{{ getLinkText(link) }}</ion-label>\n                </ion-item>\n              </ion-list>\n            </div>\n          </ion-accordion>\n        </ng-container>\n      </ion-accordion-group>\n    </div>\n  `,\n  styleUrls: ['./links-accordion.component.scss'],\n})\nexport class LinksAccordionComponent {\n  private i18n = inject(I18nService);\n\n  /**\n   * Accordion configuration.\n   */\n  @Input() props: LinksAccordionMetadata = {\n    sections: [],\n    backgroundColor: 'var(--ion-background-color)',\n    closeMenuOnClick: true,\n    closeAccordionOnClick: true,\n  };\n\n  /**\n   * Emits the route when a link is clicked.\n   */\n  @Output() navigate = new EventEmitter<string[]>();\n\n  @ViewChild('accordionGroup') accordionGroup!: IonAccordionGroup;\n\n  constructor(\n    private router: Router,\n    private menuCtrl: MenuController\n  ) {}\n\n  /**\n   * Gets a unique value for the accordion section.\n   */\n  getSectionValue(section: LinksAccordionSection, index: number): string {\n    return section.titleKey || section.title || `section-${index}`;\n  }\n\n  /**\n   * Gets the section title, supporting i18n via titleKey.\n   */\n  getSectionTitle(section: LinksAccordionSection): string {\n    if (section.titleKey && this.props.i18nNamespace) {\n      return this.i18n.t(section.titleKey, this.props.i18nNamespace);\n    }\n    return section.title || '';\n  }\n\n  /**\n   * Gets the link text, supporting i18n via textKey.\n   */\n  getLinkText(link: LinksAccordionLink): string {\n    if (link.textKey && this.props.i18nNamespace) {\n      return this.i18n.t(link.textKey, this.props.i18nNamespace);\n    }\n    return link.text || '';\n  }\n\n  /**\n   * Handles link click - closes accordion/menu and navigates.\n   */\n  async onLinkClick(route: string[], event?: Event): Promise<void> {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    // Close accordion before navigating\n    if (this.props.closeAccordionOnClick !== false && this.accordionGroup) {\n      this.accordionGroup.value = undefined;\n    }\n\n    // Close menu if enabled\n    if (this.props.closeMenuOnClick !== false) {\n      await this.menuCtrl.close();\n    }\n\n    // Emit event\n    this.navigate.emit(route);\n\n    // Navigate\n    this.router.navigate(route);\n  }\n}\n"]}
|
|
@@ -58,6 +58,10 @@ export const VALTECH_DEFAULT_CONTENT = {
|
|
|
58
58
|
settings: 'Configuración',
|
|
59
59
|
profile: 'Perfil',
|
|
60
60
|
logout: 'Cerrar sesión',
|
|
61
|
+
// Greetings (saludo según hora)
|
|
62
|
+
goodMorning: 'Buenos días',
|
|
63
|
+
goodAfternoon: 'Buenas tardes',
|
|
64
|
+
goodEvening: 'Buenas noches',
|
|
61
65
|
// Idiomas
|
|
62
66
|
languageName_es: 'Español',
|
|
63
67
|
languageName_en: 'English',
|
|
@@ -198,6 +202,10 @@ export const VALTECH_DEFAULT_CONTENT = {
|
|
|
198
202
|
settings: 'Settings',
|
|
199
203
|
profile: 'Profile',
|
|
200
204
|
logout: 'Log out',
|
|
205
|
+
// Greetings (time-of-day salutation)
|
|
206
|
+
goodMorning: 'Good morning',
|
|
207
|
+
goodAfternoon: 'Good afternoon',
|
|
208
|
+
goodEvening: 'Good evening',
|
|
201
209
|
// Languages
|
|
202
210
|
languageName_es: 'Español',
|
|
203
211
|
languageName_en: 'English',
|
|
@@ -560,4 +568,4 @@ export const VALTECH_DEFAULT_CONTENT = {
|
|
|
560
568
|
},
|
|
561
569
|
},
|
|
562
570
|
};
|
|
563
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-content.js","sourceRoot":"","sources":["../../../../../../src/lib/services/i18n/default-content.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContentStore } from './types';\n\n/**\n * Traducciones por defecto de valtech-components.\n *\n * Estas traducciones se cargan automáticamente cuando se usa provideValtechI18n()\n * sin necesidad de configuración adicional.\n *\n * Las apps pueden sobrescribir cualquier key pasando su propio content:\n *\n * @example Sobrescribir traducciones específicas\n * ```typescript\n * provideValtechI18n({\n *   content: {\n *     _global: {\n *       es: { success: '¡Lo hicimos!' },  // Sobrescribe solo esta key\n *       en: { success: 'We did it!' },\n *     },\n *   },\n * })\n * ```\n *\n * @example Desactivar traducciones por defecto\n * ```typescript\n * provideValtechI18n({\n *   includeDefaultContent: false,\n *   content: MY_CUSTOM_CONTENT,\n * })\n * ```\n */\nexport const VALTECH_DEFAULT_CONTENT: ContentStore = {\n  _global: {\n    es: {\n      // Acciones comunes\n      submit: 'Enviar',\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      loading: 'Cargando...',\n      search: 'Buscar',\n      learnMore: 'Saber más',\n\n      // Estados\n      success: 'Éxito',\n      error: 'Error',\n      warning: 'Advertencia',\n      info: 'Información',\n\n      // Confirmaciones\n      confirmDelete: '¿Estás seguro de que deseas eliminar?',\n      confirmCancel: '¿Estás seguro de que deseas cancelar?',\n\n      // Mensajes comunes\n      noResults: 'No se encontraron resultados',\n      required: 'Este campo es requerido',\n\n      // Navegación\n      home: 'Inicio',\n      settings: 'Configuración',\n      profile: 'Perfil',\n      logout: 'Cerrar sesión',\n\n      // Idiomas\n      languageName_es: 'Español',\n      languageName_en: 'English',\n\n      // Componentes - Modales/Selects\n      ok: 'Aceptar',\n      selectOption: 'Seleccionar opción',\n      selectPlaceholder: 'Seleccionar...',\n      itemsSelected: 'elementos seleccionados',\n      selectAll: 'Seleccionar todos',\n      clear: 'Limpiar',\n      apply: 'Aplicar',\n\n      // Componentes - Fechas\n      startDate: 'Fecha inicio',\n      endDate: 'Fecha fin',\n      day: 'día',\n      days: 'días',\n\n      // Componentes - Formularios\n      uploadFile: 'Subir archivo',\n      noFileSelected: 'No has seleccionado archivo',\n      title: 'Título',\n      description: 'Descripción',\n      feedbackType: 'Tipo de feedback',\n      feedbackSuccess: 'Feedback enviado exitosamente',\n      feedbackError: 'Error al enviar el feedback',\n      titlePlaceholder: 'Describe brevemente...',\n      titleValidation: 'El título debe tener entre 5 y 200 caracteres',\n      descriptionPlaceholder: 'Proporciona más detalles...',\n      descriptionValidation: 'La descripción debe tener entre 10 y 5000 caracteres',\n\n      // Componentes - Búsqueda/Grid\n      searchNumber: 'Buscar número...',\n      selected: 'seleccionado/s',\n      max: 'máx:',\n\n      // Componentes - Listas\n      loadMoreComments: 'Cargar más comentarios',\n      noData: 'No hay datos',\n      noRecordsFound: 'No se encontraron registros para mostrar.',\n\n      // Componentes - Acciones\n      copiedToClipboard: '¡Copiado al portapapeles!',\n      language: 'Idioma',\n      selectLanguage: 'Seleccionar idioma...',\n      download: 'Descargar',\n      copy: 'Copiar',\n      share: 'Compartir',\n\n      // Componentes - Data Table / Paginación\n      actions: 'Acciones',\n      showing: 'Mostrando',\n      of: 'de',\n      perPage: 'por página',\n      firstPage: 'Primera página',\n      previousPage: 'Página anterior',\n      nextPage: 'Página siguiente',\n      lastPage: 'Última página',\n\n      // Componentes - Participant Card\n      winner: 'Ganador',\n      ticket: 'boleto',\n      tickets: 'boletos',\n      more: 'más',\n      notes: 'Notas:',\n\n      // Footer\n      allRightsReserved: 'Todos los derechos reservados.',\n\n      // Clipboard\n      linkCopied: '¡Enlace copiado!',\n\n      // Selection\n      select: 'Seleccionar',\n      selectOptions: 'Seleccionar opciones',\n\n      // Comments\n      pinned: 'Fijado',\n      edited: '(editado)',\n      showComment: 'Mostrar comentario',\n      hideReplies: 'Ocultar respuestas',\n      loadMoreReplies: 'Cargar más respuestas',\n      viewReplies: 'Ver respuestas',\n      comments: 'Comentarios',\n      noCommentsYet: 'Sin comentarios aún',\n      publish: 'Publicar',\n      sortBy: 'Ordenar por',\n      writeComment: 'Escribe un comentario...',\n      beFirstToComment: '¡Sé el primero en compartir tu opinión!',\n\n      // Timestamps\n      justNow: 'Ahora mismo',\n      minutesAgo: 'hace {minutes}m',\n      hoursAgo: 'hace {hours}h',\n      daysAgo: 'hace {days}d',\n\n      // Lists\n      loadMore: 'Cargar más',\n      noMoreItems: 'No hay más items',\n      loadingItems: 'Cargando items...',\n      allItemsLoaded: 'Todos los items han sido cargados',\n      errorOccurred: 'Ocurrió un error',\n      retry: 'Reintentar',\n\n      // Navigation\n      seeMore: 'Ver más',\n\n      // Forms - Range\n      from: 'Inicial',\n      to: 'Final',\n\n      // Stepper\n      decrease: 'Disminuir',\n      increase: 'Aumentar',\n\n      // Misc\n      random: 'Aleatorio',\n      pullToRefresh: 'Arrastra para actualizar',\n      timeExpired: 'Tiempo agotado',\n      qrCode: 'Código QR',\n\n      // Payment status\n      paymentPending: 'Pendiente',\n      paymentProcessing: 'Procesando',\n      paymentPaid: 'Pagado',\n      paymentRefunded: 'Reembolsado',\n      paymentFailed: 'Fallido',\n    },\n    en: {\n      // Common actions\n      submit: 'Submit',\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      loading: 'Loading...',\n      search: 'Search',\n      learnMore: 'Learn more',\n\n      // States\n      success: 'Success',\n      error: 'Error',\n      warning: 'Warning',\n      info: 'Information',\n\n      // Confirmations\n      confirmDelete: 'Are you sure you want to delete?',\n      confirmCancel: 'Are you sure you want to cancel?',\n\n      // Common messages\n      noResults: 'No results found',\n      required: 'This field is required',\n\n      // Navigation\n      home: 'Home',\n      settings: 'Settings',\n      profile: 'Profile',\n      logout: 'Log out',\n\n      // Languages\n      languageName_es: 'Español',\n      languageName_en: 'English',\n\n      // Components - Modals/Selects\n      ok: 'OK',\n      selectOption: 'Select option',\n      selectPlaceholder: 'Select...',\n      itemsSelected: 'items selected',\n      selectAll: 'Select all',\n      clear: 'Clear',\n      apply: 'Apply',\n\n      // Components - Dates\n      startDate: 'Start date',\n      endDate: 'End date',\n      day: 'day',\n      days: 'days',\n\n      // Components - Forms\n      uploadFile: 'Upload file',\n      noFileSelected: 'No file selected',\n      title: 'Title',\n      description: 'Description',\n      feedbackType: 'Feedback type',\n      feedbackSuccess: 'Feedback sent successfully',\n      feedbackError: 'Error sending feedback',\n      titlePlaceholder: 'Describe briefly...',\n      titleValidation: 'Title must be between 5 and 200 characters',\n      descriptionPlaceholder: 'Provide more details...',\n      descriptionValidation: 'Description must be between 10 and 5000 characters',\n\n      // Components - Search/Grid\n      searchNumber: 'Search number...',\n      selected: 'selected',\n      max: 'max:',\n\n      // Components - Lists\n      loadMoreComments: 'Load more comments',\n      noData: 'No data',\n      noRecordsFound: 'No records found to display.',\n\n      // Components - Actions\n      copiedToClipboard: 'Copied to clipboard!',\n      language: 'Language',\n      selectLanguage: 'Select language...',\n      download: 'Download',\n      copy: 'Copy',\n      share: 'Share',\n\n      // Components - Data Table / Pagination\n      actions: 'Actions',\n      showing: 'Showing',\n      of: 'of',\n      perPage: 'per page',\n      firstPage: 'First page',\n      previousPage: 'Previous page',\n      nextPage: 'Next page',\n      lastPage: 'Last page',\n\n      // Components - Participant Card\n      winner: 'Winner',\n      ticket: 'ticket',\n      tickets: 'tickets',\n      more: 'more',\n      notes: 'Notes:',\n\n      // Footer\n      allRightsReserved: 'All rights reserved.',\n\n      // Clipboard\n      linkCopied: 'Link copied!',\n\n      // Selection\n      select: 'Select',\n      selectOptions: 'Select options',\n\n      // Comments\n      pinned: 'Pinned',\n      edited: '(edited)',\n      showComment: 'Show comment',\n      hideReplies: 'Hide replies',\n      loadMoreReplies: 'Load more replies',\n      viewReplies: 'View replies',\n      comments: 'Comments',\n      noCommentsYet: 'No comments yet',\n      publish: 'Publish',\n      sortBy: 'Sort by',\n      writeComment: 'Write a comment...',\n      beFirstToComment: 'Be the first to share your thoughts!',\n\n      // Timestamps\n      justNow: 'Just now',\n      minutesAgo: '{minutes}m ago',\n      hoursAgo: '{hours}h ago',\n      daysAgo: '{days}d ago',\n\n      // Lists\n      loadMore: 'Load more',\n      noMoreItems: 'No more items',\n      loadingItems: 'Loading items...',\n      allItemsLoaded: 'All items loaded',\n      errorOccurred: 'An error occurred',\n      retry: 'Retry',\n\n      // Navigation\n      seeMore: 'See more',\n\n      // Forms - Range\n      from: 'From',\n      to: 'To',\n\n      // Stepper\n      decrease: 'Decrease',\n      increase: 'Increase',\n\n      // Misc\n      random: 'Random',\n      pullToRefresh: 'Pull to refresh',\n      timeExpired: 'Time expired',\n      qrCode: 'QR Code',\n\n      // Payment status\n      paymentPending: 'Pending',\n      paymentProcessing: 'Processing',\n      paymentPaid: 'Paid',\n      paymentRefunded: 'Refunded',\n      paymentFailed: 'Failed',\n    },\n  },\n\n  _auth: {\n    es: {\n      // Login\n      loginTitle: 'Iniciar sesión',\n      email: 'Correo electrónico',\n      emailPlaceholder: 'tu@email.com',\n      emailRequired: 'El correo es requerido',\n      emailInvalid: 'Ingresa un correo válido',\n      password: 'Contraseña',\n      passwordPlaceholder: '••••••••',\n      passwordRequired: 'La contraseña es requerida',\n      loginSubmit: 'Iniciar sesión',\n\n      // OAuth\n      orContinueWith: 'o continúa con',\n      continueWithGoogle: 'Continuar con Google',\n      continueWithApple: 'Continuar con Apple',\n      continueWithMicrosoft: 'Continuar con Microsoft',\n      connecting: 'Conectando...',\n\n      // Register\n      registerTitle: 'Crear cuenta',\n      fullName: 'Nombre completo',\n      namePlaceholder: 'Tu nombre',\n      nameRequired: 'El nombre es requerido',\n      nameMinLength: 'Mínimo 2 caracteres',\n      passwordMinLength: 'Mínimo 8 caracteres',\n      registerSubmit: 'Registrarse',\n      noAccount: '¿No tienes cuenta?',\n      register: 'Registrarse',\n      hasAccount: '¿Ya tienes cuenta?',\n      signIn: 'Iniciar sesión',\n\n      // Verify email\n      verifyTitle: 'Verificar correo',\n      verifyDescription: 'Ingresa el código de verificación enviado a tu correo.',\n      verifySubmit: 'Verificar',\n      codeRequired: 'El código es requerido',\n      codeMinLength: 'Ingresa los 6 dígitos',\n      noCodeReceived: '¿No has recibido tu código?',\n      resend: 'Reenviar',\n      resendIn: 'Reenviar en {seconds}s',\n      codeSent: 'Código reenviado. Revisa tu email.',\n      emailVerified: '¡Email verificado! Bienvenido.',\n\n      // MFA\n      mfaTitle: 'Verificación MFA',\n      mfaTOTP: 'Ingresa el código de tu app de autenticación',\n      mfaEmail: 'Ingresa el código enviado a tu correo',\n      mfaSMS: 'Ingresa el código enviado a tu teléfono',\n\n      // Forgot/Reset password\n      forgotTitle: 'Recuperar contraseña',\n      forgotDescription: 'Ingresa tu correo electrónico y te enviaremos un código.',\n      forgotSubmit: 'Enviar código',\n      forgotLink: '¿Olvidaste tu contraseña?',\n      recoverPassword: 'Recuperar contraseña',\n      resetTitle: 'Restablecer contraseña',\n      resetDescription: 'Hemos enviado un código de verificación a tu correo.',\n      newPassword: 'Nueva contraseña',\n      newPasswordHint: 'Mínimo 8 caracteres',\n      resetSubmit: 'Cambiar contraseña',\n      passwordUpdated: '¡Contraseña actualizada! Ya puedes iniciar sesión.',\n\n      // Legal\n      legalPrefix: 'Utilizamos los servicios de',\n      legalSuffix:\n        'para ofrecerte una experiencia segura. Al iniciar sesión, aceptas nuestros',\n      termsAndConditions: 'Términos y Condiciones',\n      and: 'y',\n      privacyPolicy: 'Política de Privacidad',\n\n      // Toasts\n      welcome: '¡Bienvenido!',\n      completeAllFields: 'Completa todos los campos.',\n      enterEmail: 'Ingresa tu correo electrónico.',\n\n      // Errors (mapeados de códigos backend)\n      errorInvalidCredentials: 'Correo o contraseña incorrectos',\n      errorEmailNotVerified: 'Debes verificar tu correo electrónico',\n      errorAccountSuspended: 'Tu cuenta ha sido suspendida',\n      errorEmailExists: 'Este correo ya está registrado',\n      errorWeakPassword: 'La contraseña es muy débil',\n      errorInvalidCode: 'Código incorrecto',\n      errorExpiredCode: 'El código ha expirado. Solicita uno nuevo.',\n      errorTooManyAttempts: 'Demasiados intentos, intenta más tarde',\n      errorMFAInvalidCode: 'Código de verificación incorrecto',\n      errorPopupBlocked: 'Por favor, permite ventanas emergentes',\n      errorOAuthFailed: 'Error de autenticación',\n      errorGeneric: 'Ha ocurrido un error. Intenta de nuevo.',\n    },\n    en: {\n      // Login\n      loginTitle: 'Sign in',\n      email: 'Email',\n      emailPlaceholder: 'you@email.com',\n      emailRequired: 'Email is required',\n      emailInvalid: 'Enter a valid email',\n      password: 'Password',\n      passwordPlaceholder: '••••••••',\n      passwordRequired: 'Password is required',\n      loginSubmit: 'Sign in',\n\n      // OAuth\n      orContinueWith: 'or continue with',\n      continueWithGoogle: 'Continue with Google',\n      continueWithApple: 'Continue with Apple',\n      continueWithMicrosoft: 'Continue with Microsoft',\n      connecting: 'Connecting...',\n\n      // Register\n      registerTitle: 'Create account',\n      fullName: 'Full name',\n      namePlaceholder: 'Your name',\n      nameRequired: 'Name is required',\n      nameMinLength: 'Minimum 2 characters',\n      passwordMinLength: 'Minimum 8 characters',\n      registerSubmit: 'Sign up',\n      noAccount: \"Don't have an account?\",\n      register: 'Sign up',\n      hasAccount: 'Already have an account?',\n      signIn: 'Sign in',\n\n      // Verify email\n      verifyTitle: 'Verify email',\n      verifyDescription: 'Enter the verification code sent to your email.',\n      verifySubmit: 'Verify',\n      codeRequired: 'Code is required',\n      codeMinLength: 'Enter all 6 digits',\n      noCodeReceived: \"Didn't receive your code?\",\n      resend: 'Resend',\n      resendIn: 'Resend in {seconds}s',\n      codeSent: 'Code resent. Check your email.',\n      emailVerified: 'Email verified! Welcome.',\n\n      // MFA\n      mfaTitle: 'MFA Verification',\n      mfaTOTP: 'Enter the code from your authenticator app',\n      mfaEmail: 'Enter the code sent to your email',\n      mfaSMS: 'Enter the code sent to your phone',\n\n      // Forgot/Reset password\n      forgotTitle: 'Recover password',\n      forgotDescription: 'Enter your email and we will send you a code.',\n      forgotSubmit: 'Send code',\n      forgotLink: 'Forgot your password?',\n      recoverPassword: 'Recover password',\n      resetTitle: 'Reset password',\n      resetDescription: 'We have sent a verification code to your email.',\n      newPassword: 'New password',\n      newPasswordHint: 'Minimum 8 characters',\n      resetSubmit: 'Change password',\n      passwordUpdated: 'Password updated! You can now sign in.',\n\n      // Legal\n      legalPrefix: 'We use the services of',\n      legalSuffix: 'to offer you a secure experience. By signing in, you accept our',\n      termsAndConditions: 'Terms and Conditions',\n      and: 'and',\n      privacyPolicy: 'Privacy Policy',\n\n      // Toasts\n      welcome: 'Welcome!',\n      completeAllFields: 'Complete all fields.',\n      enterEmail: 'Enter your email.',\n\n      // Errors\n      errorInvalidCredentials: 'Incorrect email or password',\n      errorEmailNotVerified: 'You must verify your email',\n      errorAccountSuspended: 'Your account has been suspended',\n      errorEmailExists: 'This email is already registered',\n      errorWeakPassword: 'Password is too weak',\n      errorInvalidCode: 'Incorrect code',\n      errorExpiredCode: 'Code has expired. Request a new one.',\n      errorTooManyAttempts: 'Too many attempts, try again later',\n      errorMFAInvalidCode: 'Incorrect verification code',\n      errorPopupBlocked: 'Please allow pop-ups',\n      errorOAuthFailed: 'Authentication error',\n      errorGeneric: 'An error occurred. Please try again.',\n    },\n  },\n\n  AppConfig: {\n    es: {\n      // Update banner\n      updateAvailable: 'Nueva versión disponible',\n      updateNow: 'Actualizar ahora',\n      clickToUpdate: 'Haz clic aquí para actualizar a la última versión',\n\n      // Maintenance page\n      maintenanceMode: 'Sistema en mantenimiento',\n      maintenanceMessage: 'Estamos realizando mejoras. Vuelve pronto.',\n    },\n    en: {\n      // Update banner\n      updateAvailable: 'New version available',\n      updateNow: 'Update now',\n      clickToUpdate: 'Click here to update to the latest version',\n\n      // Maintenance page\n      maintenanceMode: 'System under maintenance',\n      maintenanceMessage: 'We are making improvements. Come back soon.',\n    },\n  },\n\n  Feedback: {\n    es: {\n      pageUsefulQuestion: '¿Te resultó útil esta página?',\n      commentPlaceholder: 'Cuéntanos cómo podemos mejorar...',\n      thankYouMessage: '¡Gracias por tu feedback!',\n    },\n    en: {\n      pageUsefulQuestion: 'Was this page helpful?',\n      commentPlaceholder: 'Tell us how we can improve...',\n      thankYouMessage: 'Thanks for your feedback!',\n    },\n  },\n\n  ContentReaction: {\n    es: {\n      question: '¿Te resultó útil este contenido?',\n      commentPlaceholder: 'Cuéntanos más (opcional)...',\n      submit: 'Enviar',\n      update: 'Actualizar',\n      thankYou: '¡Gracias por tu opinión!',\n      submitted: 'Tu opinión ha sido registrada',\n      errorSubmitting: 'Error al enviar. Intenta de nuevo.',\n    },\n    en: {\n      question: 'Was this content helpful?',\n      commentPlaceholder: 'Tell us more (optional)...',\n      submit: 'Submit',\n      update: 'Update',\n      thankYou: 'Thanks for your feedback!',\n      submitted: 'Your feedback has been recorded',\n      errorSubmitting: 'Error submitting. Please try again.',\n    },\n  },\n\n  AvatarUpload: {\n    es: {\n      // Actions\n      changePhoto: 'Cambiar foto',\n      cropImage: 'Recortar imagen',\n      confirm: 'Confirmar',\n\n      // Status\n      uploading: 'Subiendo foto...',\n      uploadSuccess: 'Foto actualizada',\n\n      // Errors\n      uploadError: 'Error al subir la imagen',\n      uploadTimeout: 'La subida tardó demasiado. Verifica tu conexión.',\n      networkError: 'Error de red. Verifica tu conexión a internet.',\n      invalidFormat: 'Formato no válido. Usa JPG, PNG o WebP.',\n      fileTooLarge: 'La imagen es muy grande. Máximo 10MB.',\n      loadFailed: 'No se pudo cargar la imagen',\n    },\n    en: {\n      // Actions\n      changePhoto: 'Change photo',\n      cropImage: 'Crop image',\n      confirm: 'Confirm',\n\n      // Status\n      uploading: 'Uploading photo...',\n      uploadSuccess: 'Photo updated',\n\n      // Errors\n      uploadError: 'Error uploading image',\n      uploadTimeout: 'Upload took too long. Check your connection.',\n      networkError: 'Network error. Check your internet connection.',\n      invalidFormat: 'Invalid format. Use JPG, PNG or WebP.',\n      fileTooLarge: 'Image is too large. Maximum 10MB.',\n      loadFailed: 'Could not load image',\n    },\n  },\n};\n"]}
|
|
571
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-content.js","sourceRoot":"","sources":["../../../../../../src/lib/services/i18n/default-content.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContentStore } from './types';\n\n/**\n * Traducciones por defecto de valtech-components.\n *\n * Estas traducciones se cargan automáticamente cuando se usa provideValtechI18n()\n * sin necesidad de configuración adicional.\n *\n * Las apps pueden sobrescribir cualquier key pasando su propio content:\n *\n * @example Sobrescribir traducciones específicas\n * ```typescript\n * provideValtechI18n({\n *   content: {\n *     _global: {\n *       es: { success: '¡Lo hicimos!' },  // Sobrescribe solo esta key\n *       en: { success: 'We did it!' },\n *     },\n *   },\n * })\n * ```\n *\n * @example Desactivar traducciones por defecto\n * ```typescript\n * provideValtechI18n({\n *   includeDefaultContent: false,\n *   content: MY_CUSTOM_CONTENT,\n * })\n * ```\n */\nexport const VALTECH_DEFAULT_CONTENT: ContentStore = {\n  _global: {\n    es: {\n      // Acciones comunes\n      submit: 'Enviar',\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      loading: 'Cargando...',\n      search: 'Buscar',\n      learnMore: 'Saber más',\n\n      // Estados\n      success: 'Éxito',\n      error: 'Error',\n      warning: 'Advertencia',\n      info: 'Información',\n\n      // Confirmaciones\n      confirmDelete: '¿Estás seguro de que deseas eliminar?',\n      confirmCancel: '¿Estás seguro de que deseas cancelar?',\n\n      // Mensajes comunes\n      noResults: 'No se encontraron resultados',\n      required: 'Este campo es requerido',\n\n      // Navegación\n      home: 'Inicio',\n      settings: 'Configuración',\n      profile: 'Perfil',\n      logout: 'Cerrar sesión',\n\n      // Greetings (saludo según hora)\n      goodMorning: 'Buenos días',\n      goodAfternoon: 'Buenas tardes',\n      goodEvening: 'Buenas noches',\n\n      // Idiomas\n      languageName_es: 'Español',\n      languageName_en: 'English',\n\n      // Componentes - Modales/Selects\n      ok: 'Aceptar',\n      selectOption: 'Seleccionar opción',\n      selectPlaceholder: 'Seleccionar...',\n      itemsSelected: 'elementos seleccionados',\n      selectAll: 'Seleccionar todos',\n      clear: 'Limpiar',\n      apply: 'Aplicar',\n\n      // Componentes - Fechas\n      startDate: 'Fecha inicio',\n      endDate: 'Fecha fin',\n      day: 'día',\n      days: 'días',\n\n      // Componentes - Formularios\n      uploadFile: 'Subir archivo',\n      noFileSelected: 'No has seleccionado archivo',\n      title: 'Título',\n      description: 'Descripción',\n      feedbackType: 'Tipo de feedback',\n      feedbackSuccess: 'Feedback enviado exitosamente',\n      feedbackError: 'Error al enviar el feedback',\n      titlePlaceholder: 'Describe brevemente...',\n      titleValidation: 'El título debe tener entre 5 y 200 caracteres',\n      descriptionPlaceholder: 'Proporciona más detalles...',\n      descriptionValidation: 'La descripción debe tener entre 10 y 5000 caracteres',\n\n      // Componentes - Búsqueda/Grid\n      searchNumber: 'Buscar número...',\n      selected: 'seleccionado/s',\n      max: 'máx:',\n\n      // Componentes - Listas\n      loadMoreComments: 'Cargar más comentarios',\n      noData: 'No hay datos',\n      noRecordsFound: 'No se encontraron registros para mostrar.',\n\n      // Componentes - Acciones\n      copiedToClipboard: '¡Copiado al portapapeles!',\n      language: 'Idioma',\n      selectLanguage: 'Seleccionar idioma...',\n      download: 'Descargar',\n      copy: 'Copiar',\n      share: 'Compartir',\n\n      // Componentes - Data Table / Paginación\n      actions: 'Acciones',\n      showing: 'Mostrando',\n      of: 'de',\n      perPage: 'por página',\n      firstPage: 'Primera página',\n      previousPage: 'Página anterior',\n      nextPage: 'Página siguiente',\n      lastPage: 'Última página',\n\n      // Componentes - Participant Card\n      winner: 'Ganador',\n      ticket: 'boleto',\n      tickets: 'boletos',\n      more: 'más',\n      notes: 'Notas:',\n\n      // Footer\n      allRightsReserved: 'Todos los derechos reservados.',\n\n      // Clipboard\n      linkCopied: '¡Enlace copiado!',\n\n      // Selection\n      select: 'Seleccionar',\n      selectOptions: 'Seleccionar opciones',\n\n      // Comments\n      pinned: 'Fijado',\n      edited: '(editado)',\n      showComment: 'Mostrar comentario',\n      hideReplies: 'Ocultar respuestas',\n      loadMoreReplies: 'Cargar más respuestas',\n      viewReplies: 'Ver respuestas',\n      comments: 'Comentarios',\n      noCommentsYet: 'Sin comentarios aún',\n      publish: 'Publicar',\n      sortBy: 'Ordenar por',\n      writeComment: 'Escribe un comentario...',\n      beFirstToComment: '¡Sé el primero en compartir tu opinión!',\n\n      // Timestamps\n      justNow: 'Ahora mismo',\n      minutesAgo: 'hace {minutes}m',\n      hoursAgo: 'hace {hours}h',\n      daysAgo: 'hace {days}d',\n\n      // Lists\n      loadMore: 'Cargar más',\n      noMoreItems: 'No hay más items',\n      loadingItems: 'Cargando items...',\n      allItemsLoaded: 'Todos los items han sido cargados',\n      errorOccurred: 'Ocurrió un error',\n      retry: 'Reintentar',\n\n      // Navigation\n      seeMore: 'Ver más',\n\n      // Forms - Range\n      from: 'Inicial',\n      to: 'Final',\n\n      // Stepper\n      decrease: 'Disminuir',\n      increase: 'Aumentar',\n\n      // Misc\n      random: 'Aleatorio',\n      pullToRefresh: 'Arrastra para actualizar',\n      timeExpired: 'Tiempo agotado',\n      qrCode: 'Código QR',\n\n      // Payment status\n      paymentPending: 'Pendiente',\n      paymentProcessing: 'Procesando',\n      paymentPaid: 'Pagado',\n      paymentRefunded: 'Reembolsado',\n      paymentFailed: 'Fallido',\n    },\n    en: {\n      // Common actions\n      submit: 'Submit',\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      loading: 'Loading...',\n      search: 'Search',\n      learnMore: 'Learn more',\n\n      // States\n      success: 'Success',\n      error: 'Error',\n      warning: 'Warning',\n      info: 'Information',\n\n      // Confirmations\n      confirmDelete: 'Are you sure you want to delete?',\n      confirmCancel: 'Are you sure you want to cancel?',\n\n      // Common messages\n      noResults: 'No results found',\n      required: 'This field is required',\n\n      // Navigation\n      home: 'Home',\n      settings: 'Settings',\n      profile: 'Profile',\n      logout: 'Log out',\n\n      // Greetings (time-of-day salutation)\n      goodMorning: 'Good morning',\n      goodAfternoon: 'Good afternoon',\n      goodEvening: 'Good evening',\n\n      // Languages\n      languageName_es: 'Español',\n      languageName_en: 'English',\n\n      // Components - Modals/Selects\n      ok: 'OK',\n      selectOption: 'Select option',\n      selectPlaceholder: 'Select...',\n      itemsSelected: 'items selected',\n      selectAll: 'Select all',\n      clear: 'Clear',\n      apply: 'Apply',\n\n      // Components - Dates\n      startDate: 'Start date',\n      endDate: 'End date',\n      day: 'day',\n      days: 'days',\n\n      // Components - Forms\n      uploadFile: 'Upload file',\n      noFileSelected: 'No file selected',\n      title: 'Title',\n      description: 'Description',\n      feedbackType: 'Feedback type',\n      feedbackSuccess: 'Feedback sent successfully',\n      feedbackError: 'Error sending feedback',\n      titlePlaceholder: 'Describe briefly...',\n      titleValidation: 'Title must be between 5 and 200 characters',\n      descriptionPlaceholder: 'Provide more details...',\n      descriptionValidation: 'Description must be between 10 and 5000 characters',\n\n      // Components - Search/Grid\n      searchNumber: 'Search number...',\n      selected: 'selected',\n      max: 'max:',\n\n      // Components - Lists\n      loadMoreComments: 'Load more comments',\n      noData: 'No data',\n      noRecordsFound: 'No records found to display.',\n\n      // Components - Actions\n      copiedToClipboard: 'Copied to clipboard!',\n      language: 'Language',\n      selectLanguage: 'Select language...',\n      download: 'Download',\n      copy: 'Copy',\n      share: 'Share',\n\n      // Components - Data Table / Pagination\n      actions: 'Actions',\n      showing: 'Showing',\n      of: 'of',\n      perPage: 'per page',\n      firstPage: 'First page',\n      previousPage: 'Previous page',\n      nextPage: 'Next page',\n      lastPage: 'Last page',\n\n      // Components - Participant Card\n      winner: 'Winner',\n      ticket: 'ticket',\n      tickets: 'tickets',\n      more: 'more',\n      notes: 'Notes:',\n\n      // Footer\n      allRightsReserved: 'All rights reserved.',\n\n      // Clipboard\n      linkCopied: 'Link copied!',\n\n      // Selection\n      select: 'Select',\n      selectOptions: 'Select options',\n\n      // Comments\n      pinned: 'Pinned',\n      edited: '(edited)',\n      showComment: 'Show comment',\n      hideReplies: 'Hide replies',\n      loadMoreReplies: 'Load more replies',\n      viewReplies: 'View replies',\n      comments: 'Comments',\n      noCommentsYet: 'No comments yet',\n      publish: 'Publish',\n      sortBy: 'Sort by',\n      writeComment: 'Write a comment...',\n      beFirstToComment: 'Be the first to share your thoughts!',\n\n      // Timestamps\n      justNow: 'Just now',\n      minutesAgo: '{minutes}m ago',\n      hoursAgo: '{hours}h ago',\n      daysAgo: '{days}d ago',\n\n      // Lists\n      loadMore: 'Load more',\n      noMoreItems: 'No more items',\n      loadingItems: 'Loading items...',\n      allItemsLoaded: 'All items loaded',\n      errorOccurred: 'An error occurred',\n      retry: 'Retry',\n\n      // Navigation\n      seeMore: 'See more',\n\n      // Forms - Range\n      from: 'From',\n      to: 'To',\n\n      // Stepper\n      decrease: 'Decrease',\n      increase: 'Increase',\n\n      // Misc\n      random: 'Random',\n      pullToRefresh: 'Pull to refresh',\n      timeExpired: 'Time expired',\n      qrCode: 'QR Code',\n\n      // Payment status\n      paymentPending: 'Pending',\n      paymentProcessing: 'Processing',\n      paymentPaid: 'Paid',\n      paymentRefunded: 'Refunded',\n      paymentFailed: 'Failed',\n    },\n  },\n\n  _auth: {\n    es: {\n      // Login\n      loginTitle: 'Iniciar sesión',\n      email: 'Correo electrónico',\n      emailPlaceholder: 'tu@email.com',\n      emailRequired: 'El correo es requerido',\n      emailInvalid: 'Ingresa un correo válido',\n      password: 'Contraseña',\n      passwordPlaceholder: '••••••••',\n      passwordRequired: 'La contraseña es requerida',\n      loginSubmit: 'Iniciar sesión',\n\n      // OAuth\n      orContinueWith: 'o continúa con',\n      continueWithGoogle: 'Continuar con Google',\n      continueWithApple: 'Continuar con Apple',\n      continueWithMicrosoft: 'Continuar con Microsoft',\n      connecting: 'Conectando...',\n\n      // Register\n      registerTitle: 'Crear cuenta',\n      fullName: 'Nombre completo',\n      namePlaceholder: 'Tu nombre',\n      nameRequired: 'El nombre es requerido',\n      nameMinLength: 'Mínimo 2 caracteres',\n      passwordMinLength: 'Mínimo 8 caracteres',\n      registerSubmit: 'Registrarse',\n      noAccount: '¿No tienes cuenta?',\n      register: 'Registrarse',\n      hasAccount: '¿Ya tienes cuenta?',\n      signIn: 'Iniciar sesión',\n\n      // Verify email\n      verifyTitle: 'Verificar correo',\n      verifyDescription: 'Ingresa el código de verificación enviado a tu correo.',\n      verifySubmit: 'Verificar',\n      codeRequired: 'El código es requerido',\n      codeMinLength: 'Ingresa los 6 dígitos',\n      noCodeReceived: '¿No has recibido tu código?',\n      resend: 'Reenviar',\n      resendIn: 'Reenviar en {seconds}s',\n      codeSent: 'Código reenviado. Revisa tu email.',\n      emailVerified: '¡Email verificado! Bienvenido.',\n\n      // MFA\n      mfaTitle: 'Verificación MFA',\n      mfaTOTP: 'Ingresa el código de tu app de autenticación',\n      mfaEmail: 'Ingresa el código enviado a tu correo',\n      mfaSMS: 'Ingresa el código enviado a tu teléfono',\n\n      // Forgot/Reset password\n      forgotTitle: 'Recuperar contraseña',\n      forgotDescription: 'Ingresa tu correo electrónico y te enviaremos un código.',\n      forgotSubmit: 'Enviar código',\n      forgotLink: '¿Olvidaste tu contraseña?',\n      recoverPassword: 'Recuperar contraseña',\n      resetTitle: 'Restablecer contraseña',\n      resetDescription: 'Hemos enviado un código de verificación a tu correo.',\n      newPassword: 'Nueva contraseña',\n      newPasswordHint: 'Mínimo 8 caracteres',\n      resetSubmit: 'Cambiar contraseña',\n      passwordUpdated: '¡Contraseña actualizada! Ya puedes iniciar sesión.',\n\n      // Legal\n      legalPrefix: 'Utilizamos los servicios de',\n      legalSuffix: 'para ofrecerte una experiencia segura. Al iniciar sesión, aceptas nuestros',\n      termsAndConditions: 'Términos y Condiciones',\n      and: 'y',\n      privacyPolicy: 'Política de Privacidad',\n\n      // Toasts\n      welcome: '¡Bienvenido!',\n      completeAllFields: 'Completa todos los campos.',\n      enterEmail: 'Ingresa tu correo electrónico.',\n\n      // Errors (mapeados de códigos backend)\n      errorInvalidCredentials: 'Correo o contraseña incorrectos',\n      errorEmailNotVerified: 'Debes verificar tu correo electrónico',\n      errorAccountSuspended: 'Tu cuenta ha sido suspendida',\n      errorEmailExists: 'Este correo ya está registrado',\n      errorWeakPassword: 'La contraseña es muy débil',\n      errorInvalidCode: 'Código incorrecto',\n      errorExpiredCode: 'El código ha expirado. Solicita uno nuevo.',\n      errorTooManyAttempts: 'Demasiados intentos, intenta más tarde',\n      errorMFAInvalidCode: 'Código de verificación incorrecto',\n      errorPopupBlocked: 'Por favor, permite ventanas emergentes',\n      errorOAuthFailed: 'Error de autenticación',\n      errorGeneric: 'Ha ocurrido un error. Intenta de nuevo.',\n    },\n    en: {\n      // Login\n      loginTitle: 'Sign in',\n      email: 'Email',\n      emailPlaceholder: 'you@email.com',\n      emailRequired: 'Email is required',\n      emailInvalid: 'Enter a valid email',\n      password: 'Password',\n      passwordPlaceholder: '••••••••',\n      passwordRequired: 'Password is required',\n      loginSubmit: 'Sign in',\n\n      // OAuth\n      orContinueWith: 'or continue with',\n      continueWithGoogle: 'Continue with Google',\n      continueWithApple: 'Continue with Apple',\n      continueWithMicrosoft: 'Continue with Microsoft',\n      connecting: 'Connecting...',\n\n      // Register\n      registerTitle: 'Create account',\n      fullName: 'Full name',\n      namePlaceholder: 'Your name',\n      nameRequired: 'Name is required',\n      nameMinLength: 'Minimum 2 characters',\n      passwordMinLength: 'Minimum 8 characters',\n      registerSubmit: 'Sign up',\n      noAccount: \"Don't have an account?\",\n      register: 'Sign up',\n      hasAccount: 'Already have an account?',\n      signIn: 'Sign in',\n\n      // Verify email\n      verifyTitle: 'Verify email',\n      verifyDescription: 'Enter the verification code sent to your email.',\n      verifySubmit: 'Verify',\n      codeRequired: 'Code is required',\n      codeMinLength: 'Enter all 6 digits',\n      noCodeReceived: \"Didn't receive your code?\",\n      resend: 'Resend',\n      resendIn: 'Resend in {seconds}s',\n      codeSent: 'Code resent. Check your email.',\n      emailVerified: 'Email verified! Welcome.',\n\n      // MFA\n      mfaTitle: 'MFA Verification',\n      mfaTOTP: 'Enter the code from your authenticator app',\n      mfaEmail: 'Enter the code sent to your email',\n      mfaSMS: 'Enter the code sent to your phone',\n\n      // Forgot/Reset password\n      forgotTitle: 'Recover password',\n      forgotDescription: 'Enter your email and we will send you a code.',\n      forgotSubmit: 'Send code',\n      forgotLink: 'Forgot your password?',\n      recoverPassword: 'Recover password',\n      resetTitle: 'Reset password',\n      resetDescription: 'We have sent a verification code to your email.',\n      newPassword: 'New password',\n      newPasswordHint: 'Minimum 8 characters',\n      resetSubmit: 'Change password',\n      passwordUpdated: 'Password updated! You can now sign in.',\n\n      // Legal\n      legalPrefix: 'We use the services of',\n      legalSuffix: 'to offer you a secure experience. By signing in, you accept our',\n      termsAndConditions: 'Terms and Conditions',\n      and: 'and',\n      privacyPolicy: 'Privacy Policy',\n\n      // Toasts\n      welcome: 'Welcome!',\n      completeAllFields: 'Complete all fields.',\n      enterEmail: 'Enter your email.',\n\n      // Errors\n      errorInvalidCredentials: 'Incorrect email or password',\n      errorEmailNotVerified: 'You must verify your email',\n      errorAccountSuspended: 'Your account has been suspended',\n      errorEmailExists: 'This email is already registered',\n      errorWeakPassword: 'Password is too weak',\n      errorInvalidCode: 'Incorrect code',\n      errorExpiredCode: 'Code has expired. Request a new one.',\n      errorTooManyAttempts: 'Too many attempts, try again later',\n      errorMFAInvalidCode: 'Incorrect verification code',\n      errorPopupBlocked: 'Please allow pop-ups',\n      errorOAuthFailed: 'Authentication error',\n      errorGeneric: 'An error occurred. Please try again.',\n    },\n  },\n\n  AppConfig: {\n    es: {\n      // Update banner\n      updateAvailable: 'Nueva versión disponible',\n      updateNow: 'Actualizar ahora',\n      clickToUpdate: 'Haz clic aquí para actualizar a la última versión',\n\n      // Maintenance page\n      maintenanceMode: 'Sistema en mantenimiento',\n      maintenanceMessage: 'Estamos realizando mejoras. Vuelve pronto.',\n    },\n    en: {\n      // Update banner\n      updateAvailable: 'New version available',\n      updateNow: 'Update now',\n      clickToUpdate: 'Click here to update to the latest version',\n\n      // Maintenance page\n      maintenanceMode: 'System under maintenance',\n      maintenanceMessage: 'We are making improvements. Come back soon.',\n    },\n  },\n\n  Feedback: {\n    es: {\n      pageUsefulQuestion: '¿Te resultó útil esta página?',\n      commentPlaceholder: 'Cuéntanos cómo podemos mejorar...',\n      thankYouMessage: '¡Gracias por tu feedback!',\n    },\n    en: {\n      pageUsefulQuestion: 'Was this page helpful?',\n      commentPlaceholder: 'Tell us how we can improve...',\n      thankYouMessage: 'Thanks for your feedback!',\n    },\n  },\n\n  ContentReaction: {\n    es: {\n      question: '¿Te resultó útil este contenido?',\n      commentPlaceholder: 'Cuéntanos más (opcional)...',\n      submit: 'Enviar',\n      update: 'Actualizar',\n      thankYou: '¡Gracias por tu opinión!',\n      submitted: 'Tu opinión ha sido registrada',\n      errorSubmitting: 'Error al enviar. Intenta de nuevo.',\n    },\n    en: {\n      question: 'Was this content helpful?',\n      commentPlaceholder: 'Tell us more (optional)...',\n      submit: 'Submit',\n      update: 'Update',\n      thankYou: 'Thanks for your feedback!',\n      submitted: 'Your feedback has been recorded',\n      errorSubmitting: 'Error submitting. Please try again.',\n    },\n  },\n\n  AvatarUpload: {\n    es: {\n      // Actions\n      changePhoto: 'Cambiar foto',\n      cropImage: 'Recortar imagen',\n      confirm: 'Confirmar',\n\n      // Status\n      uploading: 'Subiendo foto...',\n      uploadSuccess: 'Foto actualizada',\n\n      // Errors\n      uploadError: 'Error al subir la imagen',\n      uploadTimeout: 'La subida tardó demasiado. Verifica tu conexión.',\n      networkError: 'Error de red. Verifica tu conexión a internet.',\n      invalidFormat: 'Formato no válido. Usa JPG, PNG o WebP.',\n      fileTooLarge: 'La imagen es muy grande. Máximo 10MB.',\n      loadFailed: 'No se pudo cargar la imagen',\n    },\n    en: {\n      // Actions\n      changePhoto: 'Change photo',\n      cropImage: 'Crop image',\n      confirm: 'Confirm',\n\n      // Status\n      uploading: 'Uploading photo...',\n      uploadSuccess: 'Photo updated',\n\n      // Errors\n      uploadError: 'Error uploading image',\n      uploadTimeout: 'Upload took too long. Check your connection.',\n      networkError: 'Network error. Check your internet connection.',\n      invalidFormat: 'Invalid format. Use JPG, PNG or WebP.',\n      fileTooLarge: 'Image is too large. Maximum 10MB.',\n      loadFailed: 'Could not load image',\n    },\n  },\n};\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Injectable, signal, computed } from '@angular/core';
|
|
2
2
|
import { LANG_STORAGE_KEY, DEFAULT_I18N_CONFIG, } from './types';
|
|
3
|
+
import { getTimeOfDayKey } from '../../shared/utils/datetime';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
/**
|
|
5
6
|
* Servicio de internacionalización basado en Angular Signals.
|
|
@@ -53,6 +54,26 @@ export class I18nService {
|
|
|
53
54
|
t(key, namespace, data) {
|
|
54
55
|
return this.getText(key, namespace, data);
|
|
55
56
|
}
|
|
57
|
+
/**
|
|
58
|
+
* Returns a time-of-day greeting in the current language.
|
|
59
|
+
*
|
|
60
|
+
* Uses bundled keys `goodMorning` / `goodAfternoon` / `goodEvening` from `_global`.
|
|
61
|
+
* Reactive to `lang()` when called inside a `computed()`.
|
|
62
|
+
*
|
|
63
|
+
* @param name Optional name to append: "Buenos días, Juan"
|
|
64
|
+
* @param date Optional date to evaluate (defaults to now)
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* greeting = computed(() => {
|
|
68
|
+
* this.i18n.lang();
|
|
69
|
+
* return this.i18n.greeting(this.auth.user()?.name);
|
|
70
|
+
* });
|
|
71
|
+
*/
|
|
72
|
+
greeting(name, date = new Date()) {
|
|
73
|
+
this._lang(); // track for reactivity inside computed()
|
|
74
|
+
const text = this.t(getTimeOfDayKey(date));
|
|
75
|
+
return name ? `${text}, ${name}` : text;
|
|
76
|
+
}
|
|
56
77
|
/**
|
|
57
78
|
* Obtiene texto traducido
|
|
58
79
|
*
|
|
@@ -118,7 +139,7 @@ export class I18nService {
|
|
|
118
139
|
* });
|
|
119
140
|
*/
|
|
120
141
|
registerContent(namespace, content) {
|
|
121
|
-
this._content.update(
|
|
142
|
+
this._content.update(store => ({
|
|
122
143
|
...store,
|
|
123
144
|
[namespace]: content,
|
|
124
145
|
}));
|
|
@@ -129,7 +150,7 @@ export class I18nService {
|
|
|
129
150
|
* @param contentStore Objeto con namespaces como keys
|
|
130
151
|
*/
|
|
131
152
|
registerContentBulk(contentStore) {
|
|
132
|
-
this._content.update(
|
|
153
|
+
this._content.update(store => ({
|
|
133
154
|
...store,
|
|
134
155
|
...contentStore,
|
|
135
156
|
}));
|
|
@@ -193,4 +214,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
193
214
|
type: Injectable,
|
|
194
215
|
args: [{ providedIn: 'root' }]
|
|
195
216
|
}], ctorParameters: () => [] });
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n.service.js","sourceRoot":"","sources":["../../../../../../src/lib/services/i18n/i18n.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, computed } from '@angular/core';\nimport {\n  I18nLang,\n  LanguagesContent,\n  ContentStore,\n  LANG_STORAGE_KEY,\n  DEFAULT_I18N_CONFIG,\n} from './types';\n\n/**\n * Servicio de internacionalización basado en Angular Signals.\n *\n * Características:\n * - Sin RxJS: usa Signals para evitar memory leaks y congelamiento\n * - Namespace-based: organiza traducciones por contexto\n * - Fallback multi-nivel: namespace → _global → placeholder\n * - Interpolación: soporta {variable} en textos\n *\n * @example\n * // En un componente\n * i18n = inject(I18nService);\n *\n * // Obtener texto\n * const title = this.i18n.t('title', 'Login');\n *\n * // Con interpolación\n * const welcome = this.i18n.t('welcome', 'Login', { name: 'Juan' });\n *\n * // Cambiar idioma\n * this.i18n.setLanguage('en');\n */\n@Injectable({ providedIn: 'root' })\nexport class I18nService {\n  // Estado interno con Signals\n  private readonly _lang = signal<I18nLang>(DEFAULT_I18N_CONFIG.defaultLanguage);\n  private readonly _content = signal<ContentStore>({});\n  private readonly _supportedLanguages = signal<I18nLang[]>(\n    DEFAULT_I18N_CONFIG.supportedLanguages\n  );\n\n  // Públicos readonly\n  readonly lang = this._lang.asReadonly();\n  readonly supportedLanguages = this._supportedLanguages.asReadonly();\n\n  // Computed para verificaciones rápidas\n  readonly isSpanish = computed(() => this._lang() === 'es');\n  readonly isEnglish = computed(() => this._lang() === 'en');\n\n  constructor() {\n    this.loadStoredLanguage();\n  }\n\n  /**\n   * Obtiene texto traducido (alias corto de getText)\n   *\n   * @param key Clave del texto\n   * @param namespace Namespace (default: '_global')\n   * @param data Variables para interpolación\n   * @returns Texto traducido o placeholder [namespace.key]\n   *\n   * @example\n   * i18n.t('submit');                    // busca en _global\n   * i18n.t('title', 'Login');            // busca en Login\n   * i18n.t('welcome', 'Login', {name});  // con interpolación\n   */\n  t(key: string, namespace?: string, data?: Record<string, string>): string {\n    return this.getText(key, namespace, data);\n  }\n\n  /**\n   * Obtiene texto traducido\n   *\n   * Fallback order:\n   * 1. content[namespace][lang][key]\n   * 2. content['_global'][lang][key]\n   * 3. \"[namespace.key]\" (placeholder)\n   */\n  getText(key: string, namespace?: string, data?: Record<string, string>): string {\n    const content = this._content();\n    const lang = this._lang();\n    const ns = namespace || '_global';\n\n    // Buscar en namespace específico\n    let text = content[ns]?.[lang]?.[key];\n\n    // Fallback a _global\n    if (!text && ns !== '_global') {\n      text = content['_global']?.[lang]?.[key];\n    }\n\n    // Fallback a placeholder\n    if (!text) {\n      console.warn(`[i18n] Missing translation: ${ns}.${key} (${lang})`);\n      return `[${ns}.${key}]`;\n    }\n\n    // Aplicar interpolación si hay data\n    if (data) {\n      return this.interpolate(text, data);\n    }\n\n    return text;\n  }\n\n  /**\n   * Cambia el idioma de la aplicación\n   *\n   * @param lang Nuevo idioma\n   * @param forceReload Si true, recarga la página (fallback si reactividad falla)\n   */\n  setLanguage(lang: I18nLang, forceReload = false): void {\n    if (!this._supportedLanguages().includes(lang)) {\n      console.warn(`[i18n] Language '${lang}' not in supported languages`);\n      return;\n    }\n\n    if (lang === this._lang()) {\n      return;\n    }\n\n    // Persistir en localStorage\n    localStorage.setItem(LANG_STORAGE_KEY, lang);\n\n    // Actualizar signal\n    this._lang.set(lang);\n\n    // Fallback: recargar si se solicita\n    if (forceReload) {\n      window.location.reload();\n    }\n  }\n\n  /**\n   * Registra contenido de traducciones para un namespace\n   *\n   * @param namespace Nombre del namespace\n   * @param content Contenido de traducciones\n   *\n   * @example\n   * i18n.registerContent('Login', {\n   *   es: { title: 'Iniciar sesión' },\n   *   en: { title: 'Sign in' }\n   * });\n   */\n  registerContent(namespace: string, content: LanguagesContent): void {\n    this._content.update((store) => ({\n      ...store,\n      [namespace]: content,\n    }));\n  }\n\n  /**\n   * Registra múltiples namespaces de una vez\n   *\n   * @param contentStore Objeto con namespaces como keys\n   */\n  registerContentBulk(contentStore: ContentStore): void {\n    this._content.update((store) => ({\n      ...store,\n      ...contentStore,\n    }));\n  }\n\n  /**\n   * Configura los idiomas soportados\n   */\n  setI18nLanguages(languages: I18nLang[]): void {\n    this._supportedLanguages.set(languages);\n  }\n\n  /**\n   * Obtiene todos los namespaces registrados\n   */\n  getNamespaces(): string[] {\n    return Object.keys(this._content());\n  }\n\n  /**\n   * Verifica si un namespace tiene traducciones\n   */\n  hasNamespace(namespace: string): boolean {\n    return namespace in this._content();\n  }\n\n  /**\n   * Carga idioma guardado en localStorage o detecta del navegador\n   */\n  private loadStoredLanguage(): void {\n    const stored = localStorage.getItem(LANG_STORAGE_KEY);\n\n    if (stored && this.isValidLanguage(stored)) {\n      this._lang.set(stored as I18nLang);\n      return;\n    }\n\n    // Detectar idioma del navegador\n    const browserLang = navigator.language.split('-')[0] as I18nLang;\n    if (this.isValidLanguage(browserLang)) {\n      this._lang.set(browserLang);\n      localStorage.setItem(LANG_STORAGE_KEY, browserLang);\n    }\n  }\n\n  /**\n   * Valida si un idioma está soportado\n   */\n  private isValidLanguage(lang: string): boolean {\n    return this._supportedLanguages().includes(lang as I18nLang);\n  }\n\n  /**\n   * Reemplaza {variable} en texto con valores de data\n   *\n   * @example\n   * interpolate('Hola {name}', { name: 'Juan' }) // 'Hola Juan'\n   */\n  private interpolate(text: string, data: Record<string, string>): string {\n    return Object.entries(data).reduce((result, [key, value]) => {\n      const regex = new RegExp(`\\\\{${key}\\\\}`, 'g');\n      return result.replace(regex, value);\n    }, text);\n  }\n}\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n.service.js","sourceRoot":"","sources":["../../../../../../src/lib/services/i18n/i18n.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, computed } from '@angular/core';\nimport {\n  I18nLang,\n  LanguagesContent,\n  ContentStore,\n  LANG_STORAGE_KEY,\n  DEFAULT_I18N_CONFIG,\n} from './types';\nimport { getTimeOfDayKey } from '../../shared/utils/datetime';\n\n/**\n * Servicio de internacionalización basado en Angular Signals.\n *\n * Características:\n * - Sin RxJS: usa Signals para evitar memory leaks y congelamiento\n * - Namespace-based: organiza traducciones por contexto\n * - Fallback multi-nivel: namespace → _global → placeholder\n * - Interpolación: soporta {variable} en textos\n *\n * @example\n * // En un componente\n * i18n = inject(I18nService);\n *\n * // Obtener texto\n * const title = this.i18n.t('title', 'Login');\n *\n * // Con interpolación\n * const welcome = this.i18n.t('welcome', 'Login', { name: 'Juan' });\n *\n * // Cambiar idioma\n * this.i18n.setLanguage('en');\n */\n@Injectable({ providedIn: 'root' })\nexport class I18nService {\n  // Estado interno con Signals\n  private readonly _lang = signal<I18nLang>(DEFAULT_I18N_CONFIG.defaultLanguage);\n  private readonly _content = signal<ContentStore>({});\n  private readonly _supportedLanguages = signal<I18nLang[]>(DEFAULT_I18N_CONFIG.supportedLanguages);\n\n  // Públicos readonly\n  readonly lang = this._lang.asReadonly();\n  readonly supportedLanguages = this._supportedLanguages.asReadonly();\n\n  // Computed para verificaciones rápidas\n  readonly isSpanish = computed(() => this._lang() === 'es');\n  readonly isEnglish = computed(() => this._lang() === 'en');\n\n  constructor() {\n    this.loadStoredLanguage();\n  }\n\n  /**\n   * Obtiene texto traducido (alias corto de getText)\n   *\n   * @param key Clave del texto\n   * @param namespace Namespace (default: '_global')\n   * @param data Variables para interpolación\n   * @returns Texto traducido o placeholder [namespace.key]\n   *\n   * @example\n   * i18n.t('submit');                    // busca en _global\n   * i18n.t('title', 'Login');            // busca en Login\n   * i18n.t('welcome', 'Login', {name});  // con interpolación\n   */\n  t(key: string, namespace?: string, data?: Record<string, string>): string {\n    return this.getText(key, namespace, data);\n  }\n\n  /**\n   * Returns a time-of-day greeting in the current language.\n   *\n   * Uses bundled keys `goodMorning` / `goodAfternoon` / `goodEvening` from `_global`.\n   * Reactive to `lang()` when called inside a `computed()`.\n   *\n   * @param name Optional name to append: \"Buenos días, Juan\"\n   * @param date Optional date to evaluate (defaults to now)\n   *\n   * @example\n   * greeting = computed(() => {\n   *   this.i18n.lang();\n   *   return this.i18n.greeting(this.auth.user()?.name);\n   * });\n   */\n  greeting(name?: string, date: Date = new Date()): string {\n    this._lang(); // track for reactivity inside computed()\n    const text = this.t(getTimeOfDayKey(date));\n    return name ? `${text}, ${name}` : text;\n  }\n\n  /**\n   * Obtiene texto traducido\n   *\n   * Fallback order:\n   * 1. content[namespace][lang][key]\n   * 2. content['_global'][lang][key]\n   * 3. \"[namespace.key]\" (placeholder)\n   */\n  getText(key: string, namespace?: string, data?: Record<string, string>): string {\n    const content = this._content();\n    const lang = this._lang();\n    const ns = namespace || '_global';\n\n    // Buscar en namespace específico\n    let text = content[ns]?.[lang]?.[key];\n\n    // Fallback a _global\n    if (!text && ns !== '_global') {\n      text = content['_global']?.[lang]?.[key];\n    }\n\n    // Fallback a placeholder\n    if (!text) {\n      console.warn(`[i18n] Missing translation: ${ns}.${key} (${lang})`);\n      return `[${ns}.${key}]`;\n    }\n\n    // Aplicar interpolación si hay data\n    if (data) {\n      return this.interpolate(text, data);\n    }\n\n    return text;\n  }\n\n  /**\n   * Cambia el idioma de la aplicación\n   *\n   * @param lang Nuevo idioma\n   * @param forceReload Si true, recarga la página (fallback si reactividad falla)\n   */\n  setLanguage(lang: I18nLang, forceReload = false): void {\n    if (!this._supportedLanguages().includes(lang)) {\n      console.warn(`[i18n] Language '${lang}' not in supported languages`);\n      return;\n    }\n\n    if (lang === this._lang()) {\n      return;\n    }\n\n    // Persistir en localStorage\n    localStorage.setItem(LANG_STORAGE_KEY, lang);\n\n    // Actualizar signal\n    this._lang.set(lang);\n\n    // Fallback: recargar si se solicita\n    if (forceReload) {\n      window.location.reload();\n    }\n  }\n\n  /**\n   * Registra contenido de traducciones para un namespace\n   *\n   * @param namespace Nombre del namespace\n   * @param content Contenido de traducciones\n   *\n   * @example\n   * i18n.registerContent('Login', {\n   *   es: { title: 'Iniciar sesión' },\n   *   en: { title: 'Sign in' }\n   * });\n   */\n  registerContent(namespace: string, content: LanguagesContent): void {\n    this._content.update(store => ({\n      ...store,\n      [namespace]: content,\n    }));\n  }\n\n  /**\n   * Registra múltiples namespaces de una vez\n   *\n   * @param contentStore Objeto con namespaces como keys\n   */\n  registerContentBulk(contentStore: ContentStore): void {\n    this._content.update(store => ({\n      ...store,\n      ...contentStore,\n    }));\n  }\n\n  /**\n   * Configura los idiomas soportados\n   */\n  setI18nLanguages(languages: I18nLang[]): void {\n    this._supportedLanguages.set(languages);\n  }\n\n  /**\n   * Obtiene todos los namespaces registrados\n   */\n  getNamespaces(): string[] {\n    return Object.keys(this._content());\n  }\n\n  /**\n   * Verifica si un namespace tiene traducciones\n   */\n  hasNamespace(namespace: string): boolean {\n    return namespace in this._content();\n  }\n\n  /**\n   * Carga idioma guardado en localStorage o detecta del navegador\n   */\n  private loadStoredLanguage(): void {\n    const stored = localStorage.getItem(LANG_STORAGE_KEY);\n\n    if (stored && this.isValidLanguage(stored)) {\n      this._lang.set(stored as I18nLang);\n      return;\n    }\n\n    // Detectar idioma del navegador\n    const browserLang = navigator.language.split('-')[0] as I18nLang;\n    if (this.isValidLanguage(browserLang)) {\n      this._lang.set(browserLang);\n      localStorage.setItem(LANG_STORAGE_KEY, browserLang);\n    }\n  }\n\n  /**\n   * Valida si un idioma está soportado\n   */\n  private isValidLanguage(lang: string): boolean {\n    return this._supportedLanguages().includes(lang as I18nLang);\n  }\n\n  /**\n   * Reemplaza {variable} en texto con valores de data\n   *\n   * @example\n   * interpolate('Hola {name}', { name: 'Juan' }) // 'Hola Juan'\n   */\n  private interpolate(text: string, data: Record<string, string>): string {\n    return Object.entries(data).reduce((result, [key, value]) => {\n      const regex = new RegExp(`\\\\{${key}\\\\}`, 'g');\n      return result.replace(regex, value);\n    }, text);\n  }\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns the i18n key for a time-of-day greeting based on the given date's hour.
|
|
3
|
+
*
|
|
4
|
+
* - 00:00 - 11:59 → 'goodMorning'
|
|
5
|
+
* - 12:00 - 17:59 → 'goodAfternoon'
|
|
6
|
+
* - 18:00 - 23:59 → 'goodEvening'
|
|
7
|
+
*
|
|
8
|
+
* Pure function (testable). Defaults to current local time.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* import { getTimeOfDayKey } from 'valtech-components';
|
|
12
|
+
*
|
|
13
|
+
* const key = getTimeOfDayKey(); // 'goodMorning' | 'goodAfternoon' | 'goodEvening'
|
|
14
|
+
* const text = i18n.t(key); // 'Buenos días' | 'Buenas tardes' | 'Buenas noches'
|
|
15
|
+
*/
|
|
16
|
+
export function getTimeOfDayKey(date = new Date()) {
|
|
17
|
+
const hour = date.getHours();
|
|
18
|
+
if (hour < 12)
|
|
19
|
+
return 'goodMorning';
|
|
20
|
+
if (hour < 18)
|
|
21
|
+
return 'goodAfternoon';
|
|
22
|
+
return 'goodEvening';
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NoYXJlZC91dGlscy9kYXRldGltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQUMsT0FBYSxJQUFJLElBQUksRUFBRTtJQUNyRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDN0IsSUFBSSxJQUFJLEdBQUcsRUFBRTtRQUFFLE9BQU8sYUFBYSxDQUFDO0lBQ3BDLElBQUksSUFBSSxHQUFHLEVBQUU7UUFBRSxPQUFPLGVBQWUsQ0FBQztJQUN0QyxPQUFPLGFBQWEsQ0FBQztBQUN2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaW1lLW9mLWRheSBncmVldGluZyBrZXkuXG4gKiBNYXBzIHRvIGJ1bmRsZWQgaTE4biBrZXlzIGluIGBfZ2xvYmFsYCBuYW1lc3BhY2U6IGdvb2RNb3JuaW5nIC8gZ29vZEFmdGVybm9vbiAvIGdvb2RFdmVuaW5nLlxuICovXG5leHBvcnQgdHlwZSBUaW1lT2ZEYXlLZXkgPSAnZ29vZE1vcm5pbmcnIHwgJ2dvb2RBZnRlcm5vb24nIHwgJ2dvb2RFdmVuaW5nJztcblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBpMThuIGtleSBmb3IgYSB0aW1lLW9mLWRheSBncmVldGluZyBiYXNlZCBvbiB0aGUgZ2l2ZW4gZGF0ZSdzIGhvdXIuXG4gKlxuICogLSAwMDowMCAtIDExOjU5IOKGkiAnZ29vZE1vcm5pbmcnXG4gKiAtIDEyOjAwIC0gMTc6NTkg4oaSICdnb29kQWZ0ZXJub29uJ1xuICogLSAxODowMCAtIDIzOjU5IOKGkiAnZ29vZEV2ZW5pbmcnXG4gKlxuICogUHVyZSBmdW5jdGlvbiAodGVzdGFibGUpLiBEZWZhdWx0cyB0byBjdXJyZW50IGxvY2FsIHRpbWUuXG4gKlxuICogQGV4YW1wbGVcbiAqIGltcG9ydCB7IGdldFRpbWVPZkRheUtleSB9IGZyb20gJ3ZhbHRlY2gtY29tcG9uZW50cyc7XG4gKlxuICogY29uc3Qga2V5ID0gZ2V0VGltZU9mRGF5S2V5KCk7ICAgICAgICAgIC8vICdnb29kTW9ybmluZycgfCAnZ29vZEFmdGVybm9vbicgfCAnZ29vZEV2ZW5pbmcnXG4gKiBjb25zdCB0ZXh0ID0gaTE4bi50KGtleSk7ICAgICAgICAgICAgICAgLy8gJ0J1ZW5vcyBkw61hcycgfCAnQnVlbmFzIHRhcmRlcycgfCAnQnVlbmFzIG5vY2hlcydcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFRpbWVPZkRheUtleShkYXRlOiBEYXRlID0gbmV3IERhdGUoKSk6IFRpbWVPZkRheUtleSB7XG4gIGNvbnN0IGhvdXIgPSBkYXRlLmdldEhvdXJzKCk7XG4gIGlmIChob3VyIDwgMTIpIHJldHVybiAnZ29vZE1vcm5pbmcnO1xuICBpZiAoaG91ciA8IDE4KSByZXR1cm4gJ2dvb2RBZnRlcm5vb24nO1xuICByZXR1cm4gJ2dvb2RFdmVuaW5nJztcbn1cbiJdfQ==
|
package/esm2022/lib/version.mjs
CHANGED
|
@@ -2,5 +2,5 @@
|
|
|
2
2
|
* Current version of valtech-components.
|
|
3
3
|
* This is automatically updated during the publish process.
|
|
4
4
|
*/
|
|
5
|
-
export const VERSION = '2.0.
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
export const VERSION = '2.0.718';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDdXJyZW50IHZlcnNpb24gb2YgdmFsdGVjaC1jb21wb25lbnRzLlxuICogVGhpcyBpcyBhdXRvbWF0aWNhbGx5IHVwZGF0ZWQgZHVyaW5nIHRoZSBwdWJsaXNoIHByb2Nlc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzIuMC43MTgnO1xuIl19
|