@intlayer/docs 8.0.0 → 8.0.1-canary.1

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.
Files changed (172) hide show
  1. package/dist/cjs/generated/docs.entry.cjs +160 -0
  2. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  3. package/dist/esm/generated/docs.entry.mjs +160 -0
  4. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  5. package/dist/types/generated/docs.entry.d.ts +8 -0
  6. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  7. package/docs/ar/intlayer_with_adonisjs.md +394 -0
  8. package/docs/ar/intlayer_with_hono.md +223 -0
  9. package/docs/ar/intlayer_with_vite+preact.md +317 -675
  10. package/docs/ar/packages/adonis-intlayer/exports.md +50 -0
  11. package/docs/ar/packages/adonis-intlayer/intlayer.md +54 -0
  12. package/docs/ar/packages/adonis-intlayer/t.md +149 -0
  13. package/docs/ar/packages/hono-intlayer/exports.md +59 -0
  14. package/docs/ar/packages/hono-intlayer/intlayer.md +60 -0
  15. package/docs/ar/packages/hono-intlayer/t.md +268 -0
  16. package/docs/de/intlayer_with_adonisjs.md +392 -0
  17. package/docs/de/intlayer_with_hono.md +418 -0
  18. package/docs/de/intlayer_with_vite+preact.md +272 -632
  19. package/docs/de/packages/adonis-intlayer/exports.md +50 -0
  20. package/docs/de/packages/adonis-intlayer/intlayer.md +54 -0
  21. package/docs/de/packages/adonis-intlayer/t.md +149 -0
  22. package/docs/de/packages/hono-intlayer/exports.md +59 -0
  23. package/docs/de/packages/hono-intlayer/intlayer.md +59 -0
  24. package/docs/de/packages/hono-intlayer/t.md +316 -0
  25. package/docs/en/index.md +8 -0
  26. package/docs/en/intlayer_with_adonisjs.md +388 -0
  27. package/docs/en/intlayer_with_hono.md +418 -0
  28. package/docs/en/intlayer_with_vite+preact.md +171 -556
  29. package/docs/en/introduction.md +1 -0
  30. package/docs/en/packages/adonis-intlayer/exports.md +50 -0
  31. package/docs/en/packages/adonis-intlayer/intlayer.md +54 -0
  32. package/docs/en/packages/adonis-intlayer/t.md +149 -0
  33. package/docs/en/packages/hono-intlayer/exports.md +59 -0
  34. package/docs/en/packages/hono-intlayer/intlayer.md +59 -0
  35. package/docs/en/packages/hono-intlayer/t.md +316 -0
  36. package/docs/en-GB/intlayer_with_adonisjs.md +394 -0
  37. package/docs/en-GB/intlayer_with_hono.md +418 -0
  38. package/docs/en-GB/intlayer_with_vite+preact.md +236 -583
  39. package/docs/en-GB/packages/adonis-intlayer/exports.md +50 -0
  40. package/docs/en-GB/packages/adonis-intlayer/intlayer.md +54 -0
  41. package/docs/en-GB/packages/adonis-intlayer/t.md +149 -0
  42. package/docs/en-GB/packages/hono-intlayer/exports.md +59 -0
  43. package/docs/en-GB/packages/hono-intlayer/intlayer.md +59 -0
  44. package/docs/en-GB/packages/hono-intlayer/t.md +316 -0
  45. package/docs/es/intlayer_with_adonisjs.md +388 -0
  46. package/docs/es/intlayer_with_hono.md +418 -0
  47. package/docs/es/intlayer_with_vite+preact.md +286 -650
  48. package/docs/es/packages/adonis-intlayer/exports.md +50 -0
  49. package/docs/es/packages/adonis-intlayer/intlayer.md +54 -0
  50. package/docs/es/packages/adonis-intlayer/t.md +149 -0
  51. package/docs/es/packages/hono-intlayer/exports.md +59 -0
  52. package/docs/es/packages/hono-intlayer/intlayer.md +59 -0
  53. package/docs/es/packages/hono-intlayer/t.md +316 -0
  54. package/docs/fr/intlayer_with_adonisjs.md +388 -0
  55. package/docs/fr/intlayer_with_hono.md +418 -0
  56. package/docs/fr/intlayer_with_vite+preact.md +274 -614
  57. package/docs/fr/packages/adonis-intlayer/exports.md +50 -0
  58. package/docs/fr/packages/adonis-intlayer/intlayer.md +54 -0
  59. package/docs/fr/packages/adonis-intlayer/t.md +149 -0
  60. package/docs/fr/packages/hono-intlayer/exports.md +59 -0
  61. package/docs/fr/packages/hono-intlayer/intlayer.md +59 -0
  62. package/docs/fr/packages/hono-intlayer/t.md +316 -0
  63. package/docs/hi/intlayer_with_adonisjs.md +394 -0
  64. package/docs/hi/intlayer_with_hono.md +227 -0
  65. package/docs/hi/intlayer_with_vite+preact.md +304 -680
  66. package/docs/hi/packages/adonis-intlayer/exports.md +50 -0
  67. package/docs/hi/packages/adonis-intlayer/intlayer.md +54 -0
  68. package/docs/hi/packages/adonis-intlayer/t.md +149 -0
  69. package/docs/hi/packages/hono-intlayer/exports.md +59 -0
  70. package/docs/hi/packages/hono-intlayer/intlayer.md +60 -0
  71. package/docs/hi/packages/hono-intlayer/t.md +268 -0
  72. package/docs/id/intlayer_with_adonisjs.md +394 -0
  73. package/docs/id/intlayer_with_hono.md +227 -0
  74. package/docs/id/intlayer_with_vite+preact.md +297 -697
  75. package/docs/id/packages/adonis-intlayer/exports.md +50 -0
  76. package/docs/id/packages/adonis-intlayer/intlayer.md +54 -0
  77. package/docs/id/packages/adonis-intlayer/t.md +149 -0
  78. package/docs/id/packages/hono-intlayer/exports.md +59 -0
  79. package/docs/id/packages/hono-intlayer/intlayer.md +60 -0
  80. package/docs/id/packages/hono-intlayer/t.md +268 -0
  81. package/docs/it/intlayer_with_adonisjs.md +394 -0
  82. package/docs/it/intlayer_with_hono.md +227 -0
  83. package/docs/it/intlayer_with_vite+preact.md +290 -659
  84. package/docs/it/packages/adonis-intlayer/exports.md +50 -0
  85. package/docs/it/packages/adonis-intlayer/intlayer.md +54 -0
  86. package/docs/it/packages/adonis-intlayer/t.md +149 -0
  87. package/docs/it/packages/hono-intlayer/exports.md +59 -0
  88. package/docs/it/packages/hono-intlayer/intlayer.md +60 -0
  89. package/docs/it/packages/hono-intlayer/t.md +268 -0
  90. package/docs/ja/intlayer_with_adonisjs.md +394 -0
  91. package/docs/ja/intlayer_with_hono.md +227 -0
  92. package/docs/ja/intlayer_with_vite+preact.md +307 -662
  93. package/docs/ja/packages/adonis-intlayer/exports.md +50 -0
  94. package/docs/ja/packages/adonis-intlayer/intlayer.md +54 -0
  95. package/docs/ja/packages/adonis-intlayer/t.md +149 -0
  96. package/docs/ja/packages/hono-intlayer/exports.md +59 -0
  97. package/docs/ja/packages/hono-intlayer/intlayer.md +60 -0
  98. package/docs/ja/packages/hono-intlayer/t.md +268 -0
  99. package/docs/ko/intlayer_with_adonisjs.md +394 -0
  100. package/docs/ko/intlayer_with_hono.md +227 -0
  101. package/docs/ko/intlayer_with_vite+preact.md +303 -703
  102. package/docs/ko/packages/adonis-intlayer/exports.md +50 -0
  103. package/docs/ko/packages/adonis-intlayer/intlayer.md +54 -0
  104. package/docs/ko/packages/adonis-intlayer/t.md +149 -0
  105. package/docs/ko/packages/hono-intlayer/exports.md +59 -0
  106. package/docs/ko/packages/hono-intlayer/intlayer.md +60 -0
  107. package/docs/ko/packages/hono-intlayer/t.md +268 -0
  108. package/docs/pl/intlayer_with_adonisjs.md +394 -0
  109. package/docs/pl/intlayer_with_hono.md +227 -0
  110. package/docs/pl/intlayer_with_vite+preact.md +289 -690
  111. package/docs/pl/packages/adonis-intlayer/exports.md +50 -0
  112. package/docs/pl/packages/adonis-intlayer/intlayer.md +54 -0
  113. package/docs/pl/packages/adonis-intlayer/t.md +149 -0
  114. package/docs/pl/packages/hono-intlayer/exports.md +59 -0
  115. package/docs/pl/packages/hono-intlayer/intlayer.md +60 -0
  116. package/docs/pl/packages/hono-intlayer/t.md +268 -0
  117. package/docs/pt/intlayer_with_adonisjs.md +394 -0
  118. package/docs/pt/intlayer_with_hono.md +227 -0
  119. package/docs/pt/intlayer_with_vite+preact.md +275 -637
  120. package/docs/pt/packages/adonis-intlayer/exports.md +50 -0
  121. package/docs/pt/packages/adonis-intlayer/intlayer.md +54 -0
  122. package/docs/pt/packages/adonis-intlayer/t.md +149 -0
  123. package/docs/pt/packages/hono-intlayer/exports.md +59 -0
  124. package/docs/pt/packages/hono-intlayer/intlayer.md +60 -0
  125. package/docs/pt/packages/hono-intlayer/t.md +268 -0
  126. package/docs/ru/intlayer_with_adonisjs.md +393 -0
  127. package/docs/ru/intlayer_with_hono.md +223 -0
  128. package/docs/ru/intlayer_with_vite+preact.md +319 -683
  129. package/docs/ru/packages/adonis-intlayer/exports.md +50 -0
  130. package/docs/ru/packages/adonis-intlayer/intlayer.md +54 -0
  131. package/docs/ru/packages/adonis-intlayer/t.md +149 -0
  132. package/docs/ru/packages/hono-intlayer/exports.md +59 -0
  133. package/docs/ru/packages/hono-intlayer/intlayer.md +60 -0
  134. package/docs/ru/packages/hono-intlayer/t.md +268 -0
  135. package/docs/tr/intlayer_with_adonisjs.md +394 -0
  136. package/docs/tr/intlayer_with_hono.md +227 -0
  137. package/docs/tr/intlayer_with_vite+preact.md +332 -665
  138. package/docs/tr/packages/adonis-intlayer/exports.md +50 -0
  139. package/docs/tr/packages/adonis-intlayer/intlayer.md +54 -0
  140. package/docs/tr/packages/adonis-intlayer/t.md +149 -0
  141. package/docs/tr/packages/hono-intlayer/exports.md +59 -0
  142. package/docs/tr/packages/hono-intlayer/intlayer.md +60 -0
  143. package/docs/tr/packages/hono-intlayer/t.md +268 -0
  144. package/docs/uk/intlayer_with_adonisjs.md +394 -0
  145. package/docs/uk/intlayer_with_hono.md +227 -0
  146. package/docs/uk/intlayer_with_vite+preact.md +228 -626
  147. package/docs/uk/packages/adonis-intlayer/exports.md +50 -0
  148. package/docs/uk/packages/adonis-intlayer/intlayer.md +54 -0
  149. package/docs/uk/packages/adonis-intlayer/t.md +149 -0
  150. package/docs/uk/packages/hono-intlayer/exports.md +59 -0
  151. package/docs/uk/packages/hono-intlayer/intlayer.md +60 -0
  152. package/docs/uk/packages/hono-intlayer/t.md +268 -0
  153. package/docs/vi/intlayer_with_adonisjs.md +394 -0
  154. package/docs/vi/intlayer_with_hono.md +227 -0
  155. package/docs/vi/intlayer_with_vite+preact.md +294 -679
  156. package/docs/vi/packages/adonis-intlayer/exports.md +50 -0
  157. package/docs/vi/packages/adonis-intlayer/intlayer.md +54 -0
  158. package/docs/vi/packages/adonis-intlayer/t.md +149 -0
  159. package/docs/vi/packages/hono-intlayer/exports.md +59 -0
  160. package/docs/vi/packages/hono-intlayer/intlayer.md +60 -0
  161. package/docs/vi/packages/hono-intlayer/t.md +268 -0
  162. package/docs/zh/intlayer_with_adonisjs.md +393 -0
  163. package/docs/zh/intlayer_with_hono.md +418 -0
  164. package/docs/zh/intlayer_with_vite+preact.md +338 -743
  165. package/docs/zh/packages/adonis-intlayer/exports.md +50 -0
  166. package/docs/zh/packages/adonis-intlayer/intlayer.md +54 -0
  167. package/docs/zh/packages/adonis-intlayer/t.md +149 -0
  168. package/docs/zh/packages/hono-intlayer/exports.md +59 -0
  169. package/docs/zh/packages/hono-intlayer/intlayer.md +60 -0
  170. package/docs/zh/packages/hono-intlayer/t.md +294 -0
  171. package/package.json +6 -6
  172. package/src/generated/docs.entry.ts +160 -0
@@ -0,0 +1,418 @@
1
+ ---
2
+ createdAt: 2025-08-23
3
+ updatedAt: 2025-12-30
4
+ title: i18n Hono - Comment traduire votre application Hono – guide 2026
5
+ description: Découvrez comment rendre votre backend Hono multilingue. Suivez la documentation pour l'internationaliser (i18n) et le traduire.
6
+ keywords:
7
+ - Internationalisation
8
+ - Documentation
9
+ - Intlayer
10
+ - Hono
11
+ - JavaScript
12
+ - Backend
13
+ slugs:
14
+ - doc
15
+ - environment
16
+ - hono
17
+ applicationTemplate: https://github.com/aymericzip/intlayer-hono-template
18
+ history:
19
+ - version: 7.5.9
20
+ date: 2025-12-30
21
+ changes: Ajouter la commande init
22
+ - version: 5.5.10
23
+ date: 2025-06-29
24
+ changes: Historique initial
25
+ ---
26
+
27
+ # Traduisez votre site web backend Hono en utilisant Intlayer | Internationalisation (i18n)
28
+
29
+ `hono-intlayer` est un puissant middleware d'internationalisation (i18n) pour les applications Hono, conçu pour rendre vos services backend accessibles mondialement en fournissant des réponses localisées basées sur les préférences du client.
30
+
31
+ ### Cas d'Utilisation Pratiques
32
+
33
+ - **Affichage des Erreurs Backend dans la Langue de l'Utilisateur** : Lorsqu'une erreur survient, l'affichage de messages dans la langue maternelle de l'utilisateur améliore la compréhension et réduit la frustration. Ceci est particulièrement utile pour les messages d'erreur dynamiques qui pourraient être affichés dans des composants front-end comme des toasts ou des modales.
34
+
35
+ - **Récupération de Contenu Multilingue** : Pour les applications extrayant du contenu d'une base de données, l'internationalisation garantit que vous pouvez servir ce contenu en plusieurs langues. C'est crucial pour des plateformes comme les sites de commerce électronique ou les systèmes de gestion de contenu qui doivent afficher des descriptions de produits, des articles et d'autres contenus dans la langue préférée de l'utilisateur.
36
+
37
+ - **Envoi d'E-mails Multilingues** : Qu'il s'agisse d'e-mails transactionnels, de campagnes marketing ou de notifications, l'envoi d'e-mails dans la langue du destinataire peut augmenter considérablement l'engagement et l'efficacité.
38
+
39
+ - **Notifications Push Multilingues** : Pour les applications mobiles, l'envoi de notifications push dans la langue préférée d'un utilisateur peut améliorer l'interaction et la rétention. Cette touche personnelle peut rendre les notifications plus pertinentes et exploitables.
40
+
41
+ - **Autres Communications** : Toute forme de communication depuis le backend, comme les messages SMS, les alertes système ou les mises à jour de l'interface utilisateur, bénéficie d'être dans la langue de l'utilisateur, garantissant la clarté et améliorant l'expérience utilisateur globale.
42
+
43
+ En internationalisant le backend, votre application respecte non seulement les différences culturelles mais s'aligne également mieux avec les besoins du marché mondial, ce qui en fait une étape clé pour l'expansion de vos services à l'échelle mondiale.
44
+
45
+ ## Mise en Route
46
+
47
+ ### Installation
48
+
49
+ Pour commencer à utiliser `hono-intlayer`, installez le paquet en utilisant npm :
50
+
51
+ ```bash packageManager="npm"
52
+ npm install intlayer hono-intlayer
53
+ npx intlayer init
54
+ ```
55
+
56
+ ```bash packageManager="pnpm"
57
+ pnpm add intlayer hono-intlayer
58
+ pnpm intlayer init
59
+ ```
60
+
61
+ ```bash packageManager="yarn"
62
+ yarn add intlayer hono-intlayer
63
+ yarn intlayer init
64
+ ```
65
+
66
+ ```bash packageManager="bun"
67
+ bun add intlayer hono-intlayer
68
+ bunx intlayer init
69
+ ```
70
+
71
+ ### Configuration
72
+
73
+ Configurez les paramètres d'internationalisation en créant un fichier `intlayer.config.ts` à la racine de votre projet :
74
+
75
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
76
+ import { Locales, type IntlayerConfig } from "intlayer";
77
+
78
+ const config: IntlayerConfig = {
79
+ internationalization: {
80
+ locales: [
81
+ Locales.ENGLISH,
82
+ Locales.FRENCH,
83
+ Locales.SPANISH_MEXICO,
84
+ Locales.SPANISH_SPAIN,
85
+ ],
86
+ defaultLocale: Locales.ENGLISH,
87
+ },
88
+ };
89
+
90
+ export default config;
91
+ ```
92
+
93
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
94
+ import { Locales } from "intlayer";
95
+
96
+ /** @type {import('intlayer').IntlayerConfig} */
97
+ const config = {
98
+ internationalization: {
99
+ locales: [
100
+ Locales.ENGLISH,
101
+ Locales.FRENCH,
102
+ Locales.SPANISH_MEXICO,
103
+ Locales.SPANISH_SPAIN,
104
+ ],
105
+ defaultLocale: Locales.ENGLISH,
106
+ },
107
+ };
108
+
109
+ export default config;
110
+ ```
111
+
112
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
113
+ const { Locales } = require("intlayer");
114
+
115
+ /** @type {import('intlayer').IntlayerConfig} */
116
+ const config = {
117
+ internationalization: {
118
+ locales: [
119
+ Locales.ENGLISH,
120
+ Locales.FRENCH,
121
+ Locales.SPANISH_MEXICO,
122
+ Locales.SPANISH_SPAIN,
123
+ ],
124
+ defaultLocale: Locales.ENGLISH,
125
+ },
126
+ };
127
+
128
+ module.exports = config;
129
+ ```
130
+
131
+ ### Déclarez Votre Contenu
132
+
133
+ Créez et gérez vos déclarations de contenu pour stocker les traductions :
134
+
135
+ ```typescript fileName="src/index.content.ts" contentDeclarationFormat="typescript"
136
+ import { t, type Dictionary } from "intlayer";
137
+
138
+ const indexContent = {
139
+ key: "index",
140
+ content: {
141
+ exampleOfContent: t({
142
+ en: "Example of returned content in English",
143
+ fr: "Exemple de contenu renvoyé en français",
144
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
145
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
146
+ }),
147
+ },
148
+ } satisfies Dictionary;
149
+
150
+ export default indexContent;
151
+ ```
152
+
153
+ ```javascript fileName="src/index.content.mjs" contentDeclarationFormat="esm"
154
+ import { t } from "intlayer";
155
+
156
+ /** @type {import('intlayer').Dictionary} */
157
+ const indexContent = {
158
+ key: "index",
159
+ content: {
160
+ exampleOfContent: t({
161
+ en: "Example of returned content in English",
162
+ fr: "Exemple de contenu renvoyé en français",
163
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
164
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
165
+ }),
166
+ },
167
+ };
168
+
169
+ export default indexContent;
170
+ ```
171
+
172
+ ```javascript fileName="src/index.content.cjs" codeFormat="commonjs"
173
+ const { t } = require("intlayer");
174
+
175
+ /** @type {import('intlayer').Dictionary} */
176
+ const indexContent = {
177
+ key: "index",
178
+ content: {
179
+ exampleOfContent: t({
180
+ en: "Example of returned content in English",
181
+ fr: "Exemple de contenu renvoyé en français",
182
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
183
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
184
+ }),
185
+ },
186
+ };
187
+
188
+ module.exports = indexContent;
189
+ ```
190
+
191
+ ```json fileName="src/index.content.json" contentDeclarationFormat="json"
192
+ {
193
+ "$schema": "https://intlayer.org/schema.json",
194
+ "key": "index",
195
+ "content": {
196
+ "exampleOfContent": {
197
+ "nodeType": "translation",
198
+ "translation": {
199
+ "en": "Example of returned content in English",
200
+ "fr": "Exemple de contenu renvoyé en français",
201
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
202
+ "es-MX": "Ejemplo de contenu devuelto en español (México)"
203
+ }
204
+ }
205
+ }
206
+ }
207
+ ```
208
+
209
+ > Vos déclarations de contenu peuvent être définies n'importe où dans votre application dès qu'elles sont incluses dans le répertoire `contentDir` (par défaut, `./src`). Et correspondent à l'extension de fichier de déclaration de contenu (par défaut, `.content.{json,ts,tsx,js,jsx,mjs,cjs}`).
210
+
211
+ > Pour plus de détails, reportez-vous à la [documentation sur la déclaration de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/dictionary/content_file.md).
212
+
213
+ ### Configuration de l'Application Hono
214
+
215
+ Configurez votre application Hono pour utiliser `hono-intlayer` :
216
+
217
+ ```typescript fileName="src/index.ts" codeFormat="typescript"
218
+ import { Hono } from "hono";
219
+ import { intlayer, t, getDictionary, getIntlayer } from "hono-intlayer";
220
+ import dictionaryExample from "./index.content";
221
+
222
+ const app = new Hono();
223
+
224
+ // Charger le gestionnaire de requêtes d'internationalisation
225
+ app.use("*", intlayer());
226
+
227
+ // Routes
228
+ app.get("/t_example", (c) => {
229
+ return c.text(
230
+ t({
231
+ en: "Example of returned content in English",
232
+ fr: "Exemple de contenu renvoyé en français",
233
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
234
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
235
+ })
236
+ );
237
+ });
238
+
239
+ app.get("/getIntlayer_example", (c) => {
240
+ return c.json(getIntlayer("index").exampleOfContent);
241
+ });
242
+
243
+ app.get("/getDictionary_example", (c) => {
244
+ return c.json(getDictionary(dictionaryExample).exampleOfContent);
245
+ });
246
+
247
+ export default app;
248
+ ```
249
+
250
+ ```javascript fileName="src/index.mjs" codeFormat="esm"
251
+ import { Hono } from "hono";
252
+ import { intlayer, t, getDictionary, getIntlayer } from "hono-intlayer";
253
+ import dictionaryExample from "./index.content";
254
+
255
+ const app = new Hono();
256
+
257
+ // Charger le gestionnaire de requêtes d'internationalisation
258
+ app.use("*", intlayer());
259
+
260
+ // Routes
261
+ app.get("/t_example", (c) => {
262
+ return c.text(
263
+ t({
264
+ en: "Example of returned content in English",
265
+ fr: "Exemple de contenu renvoyé en français",
266
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
267
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
268
+ })
269
+ );
270
+ });
271
+
272
+ app.get("/getIntlayer_example", (c) => {
273
+ return c.json(getIntlayer("index").exampleOfContent);
274
+ });
275
+
276
+ app.get("/getDictionary_example", (c) => {
277
+ return c.json(getDictionary(dictionaryExample).exampleOfContent);
278
+ });
279
+
280
+ export default app;
281
+ ```
282
+
283
+ ```javascript fileName="src/index.cjs" codeFormat="commonjs"
284
+ const { Hono } = require("hono");
285
+ const { intlayer, t, getDictionary, getIntlayer } = require("hono-intlayer");
286
+ const dictionaryExample = require("./index.content");
287
+
288
+ const app = new Hono();
289
+
290
+ // Charger le gestionnaire de requêtes d'internationalisation
291
+ app.use("*", intlayer());
292
+
293
+ // Routes
294
+ app.get("/t_example", (c) => {
295
+ return c.text(
296
+ t({
297
+ en: "Example of returned content in English",
298
+ fr: "Exemple de contenu renvoyé en français",
299
+ "es-ES": "Ejemplo de contenu devuelto en español (España)",
300
+ "es-MX": "Ejemplo de contenu devuelto en español (México)",
301
+ })
302
+ );
303
+ });
304
+
305
+ app.get("/getIntlayer_example", (c) => {
306
+ return c.json(getIntlayer("index").exampleOfContent);
307
+ });
308
+
309
+ app.get("/getDictionary_example", (c) => {
310
+ return c.json(getDictionary(dictionaryExample).exampleOfContent);
311
+ });
312
+
313
+ module.exports = app;
314
+ ```
315
+
316
+ ### Compatibilité
317
+
318
+ `hono-intlayer` est entièrement compatible avec :
319
+
320
+ - [`react-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/react-intlayer/index.md) pour les applications React
321
+ - [`next-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/next-intlayer/index.md) pour les applications Next.js
322
+ - [`vite-intlayer`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/packages/vite-intlayer/index.md) pour les applications Vite
323
+
324
+ Il fonctionne également sans problème avec n'importe quelle solution d'internationalisation dans divers environnements, y compris les navigateurs et les requêtes API. Vous pouvez personnaliser le middleware pour détecter la langue via les en-têtes ou les cookies :
325
+
326
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
327
+ import { Locales, type IntlayerConfig } from "intlayer";
328
+
329
+ const config: IntlayerConfig = {
330
+ // ... Autres options de configuration
331
+ middleware: {
332
+ headerName: "my-locale-header",
333
+ cookieName: "my-locale-cookie",
334
+ },
335
+ };
336
+
337
+ export default config;
338
+ ```
339
+
340
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
341
+ import { Locales } from "intlayer";
342
+
343
+ /** @type {import('intlayer').IntlayerConfig} */
344
+ const config = {
345
+ // ... Autres options de configuration
346
+ middleware: {
347
+ headerName: "my-locale-header",
348
+ cookieName: "my-locale-cookie",
349
+ },
350
+ };
351
+
352
+ export default config;
353
+ ```
354
+
355
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
356
+ const { Locales } = require("intlayer");
357
+
358
+ /** @type {import('intlayer').IntlayerConfig} */
359
+ const config = {
360
+ // ... Autres options de configuration
361
+ middleware: {
362
+ headerName: "my-locale-header",
363
+ cookieName: "my-locale-cookie",
364
+ },
365
+ };
366
+
367
+ module.exports = config;
368
+ ```
369
+
370
+ Par défaut, `hono-intlayer` interprétera l'en-tête `Accept-Language` pour déterminer la langue préférée du client.
371
+
372
+ > Pour plus d'informations sur la configuration et les sujets avancés, visitez notre [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/docs/fr/configuration.md).
373
+
374
+ ### Configurer TypeScript
375
+
376
+ `hono-intlayer` exploite les capacités robustes de TypeScript pour améliorer le processus d'internationalisation. Le typage statique de TypeScript garantit que chaque clé de traduction est prise en compte, réduisant le risque de traductions manquantes et améliorant la maintenabilité.
377
+
378
+ ![Autocomplétion](https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png?raw=true)
379
+
380
+ ![Erreur de traduction](https://github.com/aymericzip/intlayer/blob/main/docs/assets/translation_error.png?raw=true)
381
+
382
+ Assurez-vous que les types autogénérés (par défaut dans ./types/intlayer.d.ts) sont inclus dans votre fichier tsconfig.json.
383
+
384
+ ```json5 fileName="tsconfig.json"
385
+ {
386
+ // ... Vos configurations TypeScript existantes
387
+ "include": [
388
+ // ... Vos configurations TypeScript existantes
389
+ ".intlayer/**/*.ts", // Inclure les types auto-générés
390
+ ],
391
+ }
392
+ ```
393
+
394
+ ### Extension VS Code
395
+
396
+ Pour améliorer votre expérience de développement avec Intlayer, vous pouvez installer l'extension officielle **Intlayer VS Code Extension**.
397
+
398
+ [Installer depuis le VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
399
+
400
+ Cette extension fournit :
401
+
402
+ - **Autocomplétion** pour les clés de traduction.
403
+ - **Détection d'erreurs en temps réel** pour les traductions manquantes.
404
+ - **Aperçus en ligne** du contenu traduit.
405
+ - **Actions rapides** pour créer et mettre à jour facilement les traductions.
406
+
407
+ Pour plus de détails sur la façon d'utiliser l'extension, reportez-vous à la [documentation de l'extension Intlayer VS Code](https://intlayer.org/doc/vs-code-extension).
408
+
409
+ ### Configuration Git
410
+
411
+ Il est recommandé d'ignorer les fichiers générés par Intlayer. Cela vous permet d'éviter de les commettre dans votre dépôt Git.
412
+
413
+ Pour ce faire, vous pouvez ajouter les instructions suivantes à votre fichier `.gitignore` :
414
+
415
+ ```plaintext fileName=".gitignore"
416
+ # Ignorer les fichiers générés par Intlayer
417
+ .intlayer
418
+ ```