@intlayer/docs 8.0.0 → 8.0.1-canary.0
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/dist/cjs/generated/docs.entry.cjs +160 -0
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +160 -0
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +8 -0
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/docs/ar/intlayer_with_adonisjs.md +394 -0
- package/docs/ar/intlayer_with_hono.md +223 -0
- package/docs/ar/intlayer_with_vite+preact.md +317 -675
- package/docs/ar/packages/adonis-intlayer/exports.md +50 -0
- package/docs/ar/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/ar/packages/adonis-intlayer/t.md +149 -0
- package/docs/ar/packages/hono-intlayer/exports.md +59 -0
- package/docs/ar/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/ar/packages/hono-intlayer/t.md +268 -0
- package/docs/de/intlayer_with_adonisjs.md +392 -0
- package/docs/de/intlayer_with_hono.md +418 -0
- package/docs/de/intlayer_with_vite+preact.md +272 -632
- package/docs/de/packages/adonis-intlayer/exports.md +50 -0
- package/docs/de/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/de/packages/adonis-intlayer/t.md +149 -0
- package/docs/de/packages/hono-intlayer/exports.md +59 -0
- package/docs/de/packages/hono-intlayer/intlayer.md +59 -0
- package/docs/de/packages/hono-intlayer/t.md +316 -0
- package/docs/en/index.md +8 -0
- package/docs/en/intlayer_with_adonisjs.md +388 -0
- package/docs/en/intlayer_with_hono.md +418 -0
- package/docs/en/intlayer_with_vite+preact.md +171 -556
- package/docs/en/introduction.md +1 -0
- package/docs/en/packages/adonis-intlayer/exports.md +50 -0
- package/docs/en/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/en/packages/adonis-intlayer/t.md +149 -0
- package/docs/en/packages/hono-intlayer/exports.md +59 -0
- package/docs/en/packages/hono-intlayer/intlayer.md +59 -0
- package/docs/en/packages/hono-intlayer/t.md +316 -0
- package/docs/en-GB/intlayer_with_adonisjs.md +394 -0
- package/docs/en-GB/intlayer_with_hono.md +418 -0
- package/docs/en-GB/intlayer_with_vite+preact.md +236 -583
- package/docs/en-GB/packages/adonis-intlayer/exports.md +50 -0
- package/docs/en-GB/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/en-GB/packages/adonis-intlayer/t.md +149 -0
- package/docs/en-GB/packages/hono-intlayer/exports.md +59 -0
- package/docs/en-GB/packages/hono-intlayer/intlayer.md +59 -0
- package/docs/en-GB/packages/hono-intlayer/t.md +316 -0
- package/docs/es/intlayer_with_adonisjs.md +388 -0
- package/docs/es/intlayer_with_hono.md +418 -0
- package/docs/es/intlayer_with_vite+preact.md +286 -650
- package/docs/es/packages/adonis-intlayer/exports.md +50 -0
- package/docs/es/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/es/packages/adonis-intlayer/t.md +149 -0
- package/docs/es/packages/hono-intlayer/exports.md +59 -0
- package/docs/es/packages/hono-intlayer/intlayer.md +59 -0
- package/docs/es/packages/hono-intlayer/t.md +316 -0
- package/docs/fr/intlayer_with_adonisjs.md +388 -0
- package/docs/fr/intlayer_with_hono.md +418 -0
- package/docs/fr/intlayer_with_vite+preact.md +274 -614
- package/docs/fr/packages/adonis-intlayer/exports.md +50 -0
- package/docs/fr/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/fr/packages/adonis-intlayer/t.md +149 -0
- package/docs/fr/packages/hono-intlayer/exports.md +59 -0
- package/docs/fr/packages/hono-intlayer/intlayer.md +59 -0
- package/docs/fr/packages/hono-intlayer/t.md +316 -0
- package/docs/hi/intlayer_with_adonisjs.md +394 -0
- package/docs/hi/intlayer_with_hono.md +227 -0
- package/docs/hi/intlayer_with_vite+preact.md +304 -680
- package/docs/hi/packages/adonis-intlayer/exports.md +50 -0
- package/docs/hi/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/hi/packages/adonis-intlayer/t.md +149 -0
- package/docs/hi/packages/hono-intlayer/exports.md +59 -0
- package/docs/hi/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/hi/packages/hono-intlayer/t.md +268 -0
- package/docs/id/intlayer_with_adonisjs.md +394 -0
- package/docs/id/intlayer_with_hono.md +227 -0
- package/docs/id/intlayer_with_vite+preact.md +297 -697
- package/docs/id/packages/adonis-intlayer/exports.md +50 -0
- package/docs/id/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/id/packages/adonis-intlayer/t.md +149 -0
- package/docs/id/packages/hono-intlayer/exports.md +59 -0
- package/docs/id/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/id/packages/hono-intlayer/t.md +268 -0
- package/docs/it/intlayer_with_adonisjs.md +394 -0
- package/docs/it/intlayer_with_hono.md +227 -0
- package/docs/it/intlayer_with_vite+preact.md +290 -659
- package/docs/it/packages/adonis-intlayer/exports.md +50 -0
- package/docs/it/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/it/packages/adonis-intlayer/t.md +149 -0
- package/docs/it/packages/hono-intlayer/exports.md +59 -0
- package/docs/it/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/it/packages/hono-intlayer/t.md +268 -0
- package/docs/ja/intlayer_with_adonisjs.md +394 -0
- package/docs/ja/intlayer_with_hono.md +227 -0
- package/docs/ja/intlayer_with_vite+preact.md +307 -662
- package/docs/ja/packages/adonis-intlayer/exports.md +50 -0
- package/docs/ja/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/ja/packages/adonis-intlayer/t.md +149 -0
- package/docs/ja/packages/hono-intlayer/exports.md +59 -0
- package/docs/ja/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/ja/packages/hono-intlayer/t.md +268 -0
- package/docs/ko/intlayer_with_adonisjs.md +394 -0
- package/docs/ko/intlayer_with_hono.md +227 -0
- package/docs/ko/intlayer_with_vite+preact.md +303 -703
- package/docs/ko/packages/adonis-intlayer/exports.md +50 -0
- package/docs/ko/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/ko/packages/adonis-intlayer/t.md +149 -0
- package/docs/ko/packages/hono-intlayer/exports.md +59 -0
- package/docs/ko/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/ko/packages/hono-intlayer/t.md +268 -0
- package/docs/pl/intlayer_with_adonisjs.md +394 -0
- package/docs/pl/intlayer_with_hono.md +227 -0
- package/docs/pl/intlayer_with_vite+preact.md +289 -690
- package/docs/pl/packages/adonis-intlayer/exports.md +50 -0
- package/docs/pl/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/pl/packages/adonis-intlayer/t.md +149 -0
- package/docs/pl/packages/hono-intlayer/exports.md +59 -0
- package/docs/pl/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/pl/packages/hono-intlayer/t.md +268 -0
- package/docs/pt/intlayer_with_adonisjs.md +394 -0
- package/docs/pt/intlayer_with_hono.md +227 -0
- package/docs/pt/intlayer_with_vite+preact.md +275 -637
- package/docs/pt/packages/adonis-intlayer/exports.md +50 -0
- package/docs/pt/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/pt/packages/adonis-intlayer/t.md +149 -0
- package/docs/pt/packages/hono-intlayer/exports.md +59 -0
- package/docs/pt/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/pt/packages/hono-intlayer/t.md +268 -0
- package/docs/ru/intlayer_with_adonisjs.md +393 -0
- package/docs/ru/intlayer_with_hono.md +223 -0
- package/docs/ru/intlayer_with_vite+preact.md +319 -683
- package/docs/ru/packages/adonis-intlayer/exports.md +50 -0
- package/docs/ru/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/ru/packages/adonis-intlayer/t.md +149 -0
- package/docs/ru/packages/hono-intlayer/exports.md +59 -0
- package/docs/ru/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/ru/packages/hono-intlayer/t.md +268 -0
- package/docs/tr/intlayer_with_adonisjs.md +394 -0
- package/docs/tr/intlayer_with_hono.md +227 -0
- package/docs/tr/intlayer_with_vite+preact.md +332 -665
- package/docs/tr/packages/adonis-intlayer/exports.md +50 -0
- package/docs/tr/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/tr/packages/adonis-intlayer/t.md +149 -0
- package/docs/tr/packages/hono-intlayer/exports.md +59 -0
- package/docs/tr/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/tr/packages/hono-intlayer/t.md +268 -0
- package/docs/uk/intlayer_with_adonisjs.md +394 -0
- package/docs/uk/intlayer_with_hono.md +227 -0
- package/docs/uk/intlayer_with_vite+preact.md +228 -626
- package/docs/uk/packages/adonis-intlayer/exports.md +50 -0
- package/docs/uk/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/uk/packages/adonis-intlayer/t.md +149 -0
- package/docs/uk/packages/hono-intlayer/exports.md +59 -0
- package/docs/uk/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/uk/packages/hono-intlayer/t.md +268 -0
- package/docs/vi/intlayer_with_adonisjs.md +394 -0
- package/docs/vi/intlayer_with_hono.md +227 -0
- package/docs/vi/intlayer_with_vite+preact.md +294 -679
- package/docs/vi/packages/adonis-intlayer/exports.md +50 -0
- package/docs/vi/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/vi/packages/adonis-intlayer/t.md +149 -0
- package/docs/vi/packages/hono-intlayer/exports.md +59 -0
- package/docs/vi/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/vi/packages/hono-intlayer/t.md +268 -0
- package/docs/zh/intlayer_with_adonisjs.md +393 -0
- package/docs/zh/intlayer_with_hono.md +418 -0
- package/docs/zh/intlayer_with_vite+preact.md +338 -743
- package/docs/zh/packages/adonis-intlayer/exports.md +50 -0
- package/docs/zh/packages/adonis-intlayer/intlayer.md +54 -0
- package/docs/zh/packages/adonis-intlayer/t.md +149 -0
- package/docs/zh/packages/hono-intlayer/exports.md +59 -0
- package/docs/zh/packages/hono-intlayer/intlayer.md +60 -0
- package/docs/zh/packages/hono-intlayer/t.md +294 -0
- package/package.json +6 -6
- package/src/generated/docs.entry.ts +160 -0
|
@@ -0,0 +1,388 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2025-08-23
|
|
3
|
+
updatedAt: 2025-12-30
|
|
4
|
+
title: AdonisJS i18n - Cómo traducir tu aplicación AdonisJS – guía 2026
|
|
5
|
+
description: Descubre cómo hacer que tu backend de AdonisJS sea multilingüe. Sigue la documentación para internacionalizarlo (i18n) y traducirlo.
|
|
6
|
+
keywords:
|
|
7
|
+
- Internacionalización
|
|
8
|
+
- Documentación
|
|
9
|
+
- Intlayer
|
|
10
|
+
- AdonisJS
|
|
11
|
+
- JavaScript
|
|
12
|
+
- Backend
|
|
13
|
+
slugs:
|
|
14
|
+
- doc
|
|
15
|
+
- environment
|
|
16
|
+
- adonisjs
|
|
17
|
+
applicationTemplate: https://github.com/aymericzip/intlayer-adonisjs-template
|
|
18
|
+
history:
|
|
19
|
+
- version: 8.0.0
|
|
20
|
+
date: 2025-12-30
|
|
21
|
+
changes: Inicializar historial
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
# Traduce tu backend de AdonisJS usando Intlayer | Internacionalización (i18n)
|
|
25
|
+
|
|
26
|
+
`adonis-intlayer` es un potente paquete de internacionalización (i18n) para aplicaciones AdonisJS, diseñado para hacer que tus servicios de backend sean accesibles globalmente proporcionando respuestas localizadas basadas en las preferencias del cliente.
|
|
27
|
+
|
|
28
|
+
### Casos de Uso Prácticos
|
|
29
|
+
|
|
30
|
+
- **Mostrar Errores de Backend en el Idioma del Usuario**: Cuando ocurre un error, mostrar los mensajes en el idioma nativo del usuario mejora la comprensión y reduce la frustración. Esto es especialmente útil para mensajes de error dinámicos que podrían mostrarse en componentes front-end como avisos (toasts) o modales.
|
|
31
|
+
|
|
32
|
+
- **Recuperar Contenido Multilingüe**: Para aplicaciones que extraen contenido de una base de datos, la internacionalización garantiza que puedas servir este contenido en varios idiomas. Esto es crucial para plataformas como sitios de comercio electrónico o sistemas de gestión de contenido que necesitan mostrar descripciones de productos, artículos y otros contenidos en el idioma preferido por el usuario.
|
|
33
|
+
|
|
34
|
+
- **Enviar Correos Electrónicos Multilingües**: Ya sean correos transaccionales, campañas de marketing o NOTIFICACIONES, enviar correos electrónicos en el idioma del destinatario puede aumentar significativamente el compromiso y la efectividad.
|
|
35
|
+
|
|
36
|
+
- **Notificaciones Push Multilingües**: Para aplicaciones móviles, enviar notificaciones push en el idioma preferido del usuario puede mejorar la interacción y la retención. Este toque personal puede hacer que las notificaciones se sientan más relevantes y procesables.
|
|
37
|
+
|
|
38
|
+
- **Otras Comunicaciones**: Cualquier forma de comunicación desde el backend, como mensajes SMS, alertas del sistema o actualizaciones de la interfaz de usuario, se beneficia de estar en el idioma del usuario, garantizando la claridad y mejorando la experiencia general del usuario.
|
|
39
|
+
|
|
40
|
+
Al internacionalizar el backend, tu aplicación no solo respeta las diferencias culturales, sino que también se alinea mejor con las necesidades del mercado global, lo que lo convierte en un paso clave para escalar tus servicios en todo el mundo.
|
|
41
|
+
|
|
42
|
+
## Primeros Pasos
|
|
43
|
+
|
|
44
|
+
### Instalación
|
|
45
|
+
|
|
46
|
+
Para comenzar a usar `adonis-intlayer`, instala el paquete usando npm:
|
|
47
|
+
|
|
48
|
+
```bash packageManager="npm"
|
|
49
|
+
npm install intlayer adonis-intlayer
|
|
50
|
+
npx intlayer init
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
```bash packageManager="pnpm"
|
|
54
|
+
pnpm add intlayer adonis-intlayer
|
|
55
|
+
pnpm intlayer init
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
```bash packageManager="yarn"
|
|
59
|
+
yarn add intlayer adonis-intlayer
|
|
60
|
+
yarn intlayer init
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
```bash packageManager="bun"
|
|
64
|
+
bun add intlayer adonis-intlayer
|
|
65
|
+
bunx intlayer init
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
### Configuración
|
|
69
|
+
|
|
70
|
+
Configura los ajustes de internacionalización creando un archivo `intlayer.config.ts` en la raíz de tu proyecto:
|
|
71
|
+
|
|
72
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
73
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
74
|
+
|
|
75
|
+
const config: IntlayerConfig = {
|
|
76
|
+
internationalization: {
|
|
77
|
+
locales: [
|
|
78
|
+
Locales.ENGLISH,
|
|
79
|
+
Locales.RUSSIAN,
|
|
80
|
+
Locales.JAPANESE,
|
|
81
|
+
Locales.FRENCH,
|
|
82
|
+
Locales.KOREAN,
|
|
83
|
+
Locales.CHINESE,
|
|
84
|
+
Locales.SPANISH,
|
|
85
|
+
Locales.GERMAN,
|
|
86
|
+
Locales.ARABIC,
|
|
87
|
+
Locales.ITALIAN,
|
|
88
|
+
Locales.ENGLISH_UNITED_KINGDOM,
|
|
89
|
+
Locales.PORTUGUESE,
|
|
90
|
+
Locales.HINDI,
|
|
91
|
+
Locales.TURKISH,
|
|
92
|
+
Locales.POLISH,
|
|
93
|
+
Locales.INDONESIAN,
|
|
94
|
+
Locales.VIETNAMESE,
|
|
95
|
+
Locales.UKRAINIAN,
|
|
96
|
+
],
|
|
97
|
+
defaultLocale: Locales.ENGLISH,
|
|
98
|
+
},
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
export default config;
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
105
|
+
import { Locales } from "intlayer";
|
|
106
|
+
|
|
107
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
108
|
+
const config = {
|
|
109
|
+
internationalization: {
|
|
110
|
+
locales: [
|
|
111
|
+
Locales.ENGLISH,
|
|
112
|
+
Locales.RUSSIAN,
|
|
113
|
+
Locales.JAPANESE,
|
|
114
|
+
Locales.FRENCH,
|
|
115
|
+
Locales.KOREAN,
|
|
116
|
+
Locales.CHINESE,
|
|
117
|
+
Locales.SPANISH,
|
|
118
|
+
Locales.GERMAN,
|
|
119
|
+
Locales.ARABIC,
|
|
120
|
+
Locales.ITALIAN,
|
|
121
|
+
Locales.ENGLISH_UNITED_KINGDOM,
|
|
122
|
+
Locales.PORTUGUESE,
|
|
123
|
+
Locales.HINDI,
|
|
124
|
+
Locales.TURKISH,
|
|
125
|
+
Locales.POLISH,
|
|
126
|
+
Locales.INDONESIAN,
|
|
127
|
+
Locales.VIETNAMESE,
|
|
128
|
+
Locales.UKRAINIAN,
|
|
129
|
+
],
|
|
130
|
+
defaultLocale: Locales.ENGLISH,
|
|
131
|
+
},
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
export default config;
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
138
|
+
const { Locales } = require("intlayer");
|
|
139
|
+
|
|
140
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
141
|
+
const config = {
|
|
142
|
+
internationalization: {
|
|
143
|
+
locales: [
|
|
144
|
+
Locales.ENGLISH,
|
|
145
|
+
Locales.RUSSIAN,
|
|
146
|
+
Locales.JAPANESE,
|
|
147
|
+
Locales.FRENCH,
|
|
148
|
+
Locales.KOREAN,
|
|
149
|
+
Locales.CHINESE,
|
|
150
|
+
Locales.SPANISH,
|
|
151
|
+
Locales.GERMAN,
|
|
152
|
+
Locales.ARABIC,
|
|
153
|
+
Locales.ITALIAN,
|
|
154
|
+
Locales.ENGLISH_UNITED_KINGDOM,
|
|
155
|
+
Locales.PORTUGUESE,
|
|
156
|
+
Locales.HINDI,
|
|
157
|
+
Locales.TURKISH,
|
|
158
|
+
Locales.POLISH,
|
|
159
|
+
Locales.INDONESIAN,
|
|
160
|
+
Locales.VIETNAMESE,
|
|
161
|
+
Locales.UKRAINIAN,
|
|
162
|
+
],
|
|
163
|
+
defaultLocale: Locales.ENGLISH,
|
|
164
|
+
},
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
module.exports = config;
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
### Declara Tu Contenido
|
|
171
|
+
|
|
172
|
+
Crea y gestiona tus declaraciones de contenido para almacenar traducciones:
|
|
173
|
+
|
|
174
|
+
```typescript fileName="app/index.content.ts" contentDeclarationFormat="typescript"
|
|
175
|
+
import { t, type Dictionary } from "intlayer";
|
|
176
|
+
|
|
177
|
+
const indexContent = {
|
|
178
|
+
key: "index",
|
|
179
|
+
content: {
|
|
180
|
+
exampleOfContent: t({
|
|
181
|
+
en: "Example of returned content in English",
|
|
182
|
+
fr: "Exemple de contenu renvoyé en français",
|
|
183
|
+
"es-ES": "Ejemplo de contenido devuelto en español (España)",
|
|
184
|
+
"es-MX": "Ejemplo de contenido devuelto en español (México)",
|
|
185
|
+
}),
|
|
186
|
+
},
|
|
187
|
+
} satisfies Dictionary;
|
|
188
|
+
|
|
189
|
+
export default indexContent;
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
```javascript fileName="app/index.content.mjs" contentDeclarationFormat="esm"
|
|
193
|
+
import { t } from "intlayer";
|
|
194
|
+
|
|
195
|
+
/** @type {import('intlayer').Dictionary} */
|
|
196
|
+
const indexContent = {
|
|
197
|
+
key: "index",
|
|
198
|
+
content: {
|
|
199
|
+
exampleOfContent: t({
|
|
200
|
+
en: "Example of returned content in English",
|
|
201
|
+
fr: "Exemple de contenu renvoyé en français",
|
|
202
|
+
"es-ES": "Ejemplo de contenido devuelto en español (España)",
|
|
203
|
+
"es-MX": "Ejemplo de contenido devuelto en español (México)",
|
|
204
|
+
}),
|
|
205
|
+
},
|
|
206
|
+
};
|
|
207
|
+
|
|
208
|
+
export default indexContent;
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
```javascript fileName="app/index.content.cjs" contentDeclarationFormat="commonjs"
|
|
212
|
+
const { t } = require("intlayer");
|
|
213
|
+
|
|
214
|
+
/** @type {import('intlayer').Dictionary} */
|
|
215
|
+
const indexContent = {
|
|
216
|
+
key: "index",
|
|
217
|
+
content: {
|
|
218
|
+
exampleOfContent: t({
|
|
219
|
+
en: "Example of returned content in English",
|
|
220
|
+
fr: "Exemple de contenu renvoyé en français",
|
|
221
|
+
"es-ES": "Ejemplo de contenido devuelto en español (España)",
|
|
222
|
+
"es-MX": "Ejemplo de contenido devuelto en español (México)",
|
|
223
|
+
}),
|
|
224
|
+
},
|
|
225
|
+
};
|
|
226
|
+
|
|
227
|
+
module.exports = indexContent;
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
```json fileName="app/index.content.json" contentDeclarationFormat="json"
|
|
231
|
+
{
|
|
232
|
+
"$schema": "https://intlayer.org/schema.json",
|
|
233
|
+
"key": "index",
|
|
234
|
+
"content": {
|
|
235
|
+
"exampleOfContent": {
|
|
236
|
+
"nodeType": "translation",
|
|
237
|
+
"translation": {
|
|
238
|
+
"en": "Example of returned content in English",
|
|
239
|
+
"fr": "Exemple de contenu renvoyé en français",
|
|
240
|
+
"es-ES": "Ejemplo de contenido devuelto en español (España)",
|
|
241
|
+
"es-MX": "Ejemplo de contenido devuelto en español (México)"
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
> Tus declaraciones de contenido pueden definirse en cualquier lugar de tu aplicación, siempre que estén incluidas en el directorio `contentDir` (por defecto, `./src` o `./app`) y coincidan con la extensión de archivo de declaración de contenido (por defecto, `.content.{json,ts,tsx,js,jsx,mjs,cjs}`).
|
|
249
|
+
|
|
250
|
+
> Para más detalles, consulta la [documentación de declaración de contenido](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/dictionary/content_file.md).
|
|
251
|
+
|
|
252
|
+
### Configuración de la Aplicación AdonisJS
|
|
253
|
+
|
|
254
|
+
Configura tu aplicación AdonisJS para usar `adonis-intlayer`.
|
|
255
|
+
|
|
256
|
+
#### Registrar el middleware
|
|
257
|
+
|
|
258
|
+
Primero, necesitas registrar el middleware `intlayer` en tu aplicación.
|
|
259
|
+
|
|
260
|
+
```typescript fileName="start/kernel.ts"
|
|
261
|
+
router.use([() => import("adonis-intlayer/middleware")]);
|
|
262
|
+
```
|
|
263
|
+
|
|
264
|
+
#### Define tus rutas
|
|
265
|
+
|
|
266
|
+
```typescript fileName="start/routes.ts"
|
|
267
|
+
import router from "@adonisjs/core/services/router";
|
|
268
|
+
import { t, getIntlayer, getDictionary } from "adonis-intlayer";
|
|
269
|
+
import indexContent from "../app/index.content";
|
|
270
|
+
|
|
271
|
+
router.get("/t_example", async () => {
|
|
272
|
+
return t({
|
|
273
|
+
en: "Example of returned content in English",
|
|
274
|
+
fr: "Exemple de contenu renvoyé en français",
|
|
275
|
+
"es-ES": "Ejemplo de contenido devuelto en español (España)",
|
|
276
|
+
"es-MX": "Ejemplo de contenido devuelto en español (México)",
|
|
277
|
+
});
|
|
278
|
+
});
|
|
279
|
+
|
|
280
|
+
router.get("/getIntlayer_example", async () => {
|
|
281
|
+
return getIntlayer("index").exampleOfContent;
|
|
282
|
+
});
|
|
283
|
+
|
|
284
|
+
router.get("/getDictionary_example", async () => {
|
|
285
|
+
return getDictionary(indexContent).exampleOfContent;
|
|
286
|
+
});
|
|
287
|
+
```
|
|
288
|
+
|
|
289
|
+
#### Funciones
|
|
290
|
+
|
|
291
|
+
`adonis-intlayer` exporta varias funciones para manejar la internacionalización en tu aplicación:
|
|
292
|
+
|
|
293
|
+
- `t(content, locale?)`: Función de traducción básica.
|
|
294
|
+
- `getIntlayer(key, locale?)`: Recupera contenido por clave de tus diccionarios.
|
|
295
|
+
- `getDictionary(dictionary, locale?)`: Recupera contenido de un objeto de diccionario específico.
|
|
296
|
+
- `getLocale()`: Recupera el idioma actual del contexto de la solicitud.
|
|
297
|
+
|
|
298
|
+
#### Uso en Controladores
|
|
299
|
+
|
|
300
|
+
```typescript fileName="app/controllers/example_controller.ts"
|
|
301
|
+
import type { HttpContext } from "@adonisjs/core/http";
|
|
302
|
+
import { t } from "adonis-intlayer";
|
|
303
|
+
|
|
304
|
+
export default class ExampleController {
|
|
305
|
+
async index({ response }: HttpContext) {
|
|
306
|
+
return response.send(
|
|
307
|
+
t({
|
|
308
|
+
en: "Hello from controller",
|
|
309
|
+
es: "Hola desde el controlador",
|
|
310
|
+
})
|
|
311
|
+
);
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
```
|
|
315
|
+
|
|
316
|
+
### Compatibilidad
|
|
317
|
+
|
|
318
|
+
`adonis-intlayer` es totalmente compatible con:
|
|
319
|
+
|
|
320
|
+
- [`react-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/react-intlayer/index.md) para aplicaciones React
|
|
321
|
+
- [`next-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/next-intlayer/index.md) para aplicaciones Next.js
|
|
322
|
+
- [`vite-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/vite-intlayer/index.md) para aplicaciones Vite
|
|
323
|
+
|
|
324
|
+
También funciona a la perfección con cualquier solución de internacionalización en diversos entornos, incluidos navegadores y solicitudes de API. Puedes personalizar el middleware para detectar el idioma a través de encabezados o cookies:
|
|
325
|
+
|
|
326
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
327
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
328
|
+
|
|
329
|
+
const config: IntlayerConfig = {
|
|
330
|
+
// ... Otras opciones de configuración
|
|
331
|
+
middleware: {
|
|
332
|
+
headerName: "my-locale-header",
|
|
333
|
+
cookieName: "my-locale-cookie",
|
|
334
|
+
},
|
|
335
|
+
};
|
|
336
|
+
|
|
337
|
+
export default config;
|
|
338
|
+
```
|
|
339
|
+
|
|
340
|
+
Por defecto, `adonis-intlayer` interpretará el encabezado `Accept-Language` para determinar el idioma preferido del cliente.
|
|
341
|
+
|
|
342
|
+
> Para más información sobre configuración y temas avanzados, visita nuestra [documentación](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/configuration.md).
|
|
343
|
+
|
|
344
|
+
### Configurar TypeScript
|
|
345
|
+
|
|
346
|
+
`adonis-intlayer` aprovecha las potentes capacidades de TypeScript para mejorar el proceso de internacionalización. El tipado estático de TypeScript garantiza que se tenga en cuenta cada clave de traducción, reduciendo el riesgo de traducciones faltantes y mejorando la mantenibilidad.
|
|
347
|
+
|
|
348
|
+

|
|
349
|
+
|
|
350
|
+

|
|
351
|
+
|
|
352
|
+
Asegúrate de que los tipos autogenerados (por defecto en ./types/intlayer.d.ts) estén incluidos en tu archivo tsconfig.json.
|
|
353
|
+
|
|
354
|
+
```json5 fileName="tsconfig.json"
|
|
355
|
+
{
|
|
356
|
+
// ... Tus configuraciones de TypeScript existentes
|
|
357
|
+
"include": [
|
|
358
|
+
// ... Tus configuraciones de TypeScript existentes
|
|
359
|
+
".intlayer/**/*.ts", // Incluye los tipos autogenerados
|
|
360
|
+
],
|
|
361
|
+
}
|
|
362
|
+
```
|
|
363
|
+
|
|
364
|
+
### Extensión de VS Code
|
|
365
|
+
|
|
366
|
+
Para mejorar tu experiencia de desarrollo con Intlayer, puedes instalar la **Extensión oficial de Intlayer para VS Code**.
|
|
367
|
+
|
|
368
|
+
[Instalar desde el Marketplace de VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
|
|
369
|
+
|
|
370
|
+
Esta extensión proporciona:
|
|
371
|
+
|
|
372
|
+
- **Autocompletado** para claves de traducción.
|
|
373
|
+
- **Detección de errores en tiempo real** para traducciones faltantes.
|
|
374
|
+
- **Vistas previas en línea** del contenido traducido.
|
|
375
|
+
- **Acciones rápidas** para crear y actualizar traducciones fácilmente.
|
|
376
|
+
|
|
377
|
+
Para más detalles sobre cómo usar la extensión, consulta la [documentación de la Extensión de Intlayer para VS Code](https://intlayer.org/es/doc/vs-code-extension).
|
|
378
|
+
|
|
379
|
+
### Configuración de Git
|
|
380
|
+
|
|
381
|
+
Se recomienda ignorar los archivos generados por Intlayer. Esto te permite evitar subirlos a tu repositorio de Git.
|
|
382
|
+
|
|
383
|
+
Para hacer esto, puedes agregar las siguientes instrucciones a tu archivo `.gitignore`:
|
|
384
|
+
|
|
385
|
+
```plaintext fileName=".gitignore"
|
|
386
|
+
# Ignorar los archivos generados por Intlayer
|
|
387
|
+
.intlayer
|
|
388
|
+
```
|