@intlayer/docs 8.1.5 → 8.1.7

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 (81) hide show
  1. package/README.md +18 -9
  2. package/dist/cjs/generated/docs.entry.cjs +1 -1
  3. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  4. package/dist/esm/generated/docs.entry.mjs +1 -1
  5. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  6. package/dist/types/generated/docs.entry.d.ts +2 -0
  7. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  8. package/docs/ar/compiler.md +26 -0
  9. package/docs/ar/intlayer_with_nextjs_compiler.md +481 -0
  10. package/docs/ar/intlayer_with_vite+react_compiler.md +369 -0
  11. package/docs/ar/readme.md +138 -110
  12. package/docs/de/compiler.md +26 -0
  13. package/docs/de/intlayer_with_nextjs_compiler.md +481 -0
  14. package/docs/de/intlayer_with_vite+react_compiler.md +369 -0
  15. package/docs/de/readme.md +152 -124
  16. package/docs/en/compiler.md +27 -0
  17. package/docs/en/intlayer_with_nextjs_compiler.md +481 -0
  18. package/docs/en/intlayer_with_vite+react_compiler.md +368 -0
  19. package/docs/en/readme.md +129 -105
  20. package/docs/en-GB/compiler.md +26 -0
  21. package/docs/en-GB/intlayer_with_nextjs_compiler.md +481 -0
  22. package/docs/en-GB/intlayer_with_vite+react_compiler.md +369 -0
  23. package/docs/en-GB/readme.md +134 -108
  24. package/docs/es/compiler.md +26 -0
  25. package/docs/es/intlayer_with_nextjs_compiler.md +481 -0
  26. package/docs/es/intlayer_with_vite+react_compiler.md +369 -0
  27. package/docs/es/readme.md +149 -121
  28. package/docs/fr/compiler.md +26 -0
  29. package/docs/fr/intlayer_with_nextjs_compiler.md +481 -0
  30. package/docs/fr/intlayer_with_vite+react_compiler.md +369 -0
  31. package/docs/fr/readme.md +150 -122
  32. package/docs/hi/compiler.md +26 -0
  33. package/docs/hi/intlayer_with_nextjs_compiler.md +481 -0
  34. package/docs/hi/intlayer_with_vite+react_compiler.md +370 -0
  35. package/docs/hi/readme.md +153 -125
  36. package/docs/id/compiler.md +26 -0
  37. package/docs/id/intlayer_with_nextjs_compiler.md +481 -0
  38. package/docs/id/intlayer_with_vite+react_compiler.md +369 -0
  39. package/docs/id/readme.md +133 -105
  40. package/docs/it/compiler.md +26 -0
  41. package/docs/it/intlayer_with_nextjs_compiler.md +481 -0
  42. package/docs/it/intlayer_with_vite+react_compiler.md +374 -0
  43. package/docs/it/readme.md +155 -127
  44. package/docs/ja/compiler.md +26 -0
  45. package/docs/ja/intlayer_with_nextjs_compiler.md +481 -0
  46. package/docs/ja/intlayer_with_vite+react_compiler.md +369 -0
  47. package/docs/ja/readme.md +152 -126
  48. package/docs/ko/compiler.md +26 -0
  49. package/docs/ko/intlayer_with_nextjs_compiler.md +481 -0
  50. package/docs/ko/intlayer_with_vite+react_compiler.md +369 -0
  51. package/docs/ko/readme.md +154 -126
  52. package/docs/pl/compiler.md +26 -0
  53. package/docs/pl/intlayer_with_nextjs_compiler.md +481 -0
  54. package/docs/pl/intlayer_with_vite+react_compiler.md +369 -0
  55. package/docs/pl/readme.md +134 -106
  56. package/docs/pt/compiler.md +27 -1
  57. package/docs/pt/intlayer_with_nextjs_compiler.md +481 -0
  58. package/docs/pt/intlayer_with_vite+react_compiler.md +374 -0
  59. package/docs/pt/readme.md +154 -126
  60. package/docs/ru/compiler.md +26 -0
  61. package/docs/ru/intlayer_with_nextjs_compiler.md +481 -0
  62. package/docs/ru/intlayer_with_vite+react_compiler.md +369 -0
  63. package/docs/ru/readme.md +137 -109
  64. package/docs/tr/compiler.md +26 -0
  65. package/docs/tr/intlayer_with_nextjs_compiler.md +481 -0
  66. package/docs/tr/intlayer_with_vite+react_compiler.md +375 -0
  67. package/docs/tr/readme.md +139 -111
  68. package/docs/uk/compiler.md +26 -0
  69. package/docs/uk/intlayer_with_nextjs_compiler.md +481 -0
  70. package/docs/uk/intlayer_with_vite+react_compiler.md +369 -0
  71. package/docs/uk/readme.md +133 -109
  72. package/docs/vi/compiler.md +27 -1
  73. package/docs/vi/intlayer_with_nextjs_compiler.md +481 -0
  74. package/docs/vi/intlayer_with_vite+react_compiler.md +369 -0
  75. package/docs/vi/readme.md +138 -110
  76. package/docs/zh/compiler.md +26 -0
  77. package/docs/zh/intlayer_with_nextjs_compiler.md +481 -0
  78. package/docs/zh/intlayer_with_vite+react_compiler.md +372 -0
  79. package/docs/zh/readme.md +148 -120
  80. package/package.json +7 -8
  81. package/src/generated/docs.entry.ts +40 -0
@@ -0,0 +1,374 @@
1
+ ---
2
+ createdAt: 2024-03-07
3
+ updatedAt: 2025-12-30
4
+ title: Vite e React i18n - Trasforma un'app esistente in un'app multilingue (guida i18n 2026)
5
+ description: Scopri come rendere multilingue la tua applicazione Vite e React esistente utilizzando Intlayer Compiler. Segui la documentazione per l'internazionalizzazione (i18n) e la traduzione con l'IA.
6
+ keywords:
7
+ - Internazionalizzazione
8
+ - Documentazione
9
+ - Intlayer
10
+ - Vite
11
+ - React
12
+ - Compilatore
13
+ - IA
14
+ slugs:
15
+ - doc
16
+ - ambiente
17
+ - vite-e-react
18
+ - compilatore
19
+ - IA
20
+ applicationTemplate: https://github.com/aymericzip/intlayer-vite-react-template
21
+ youtubeVideo: https://www.youtube.com/watch?v=dS9L7uJeak4
22
+ history:
23
+ - version: 8.1.6
24
+ date: 2026-02-23
25
+ changes: Rilascio iniziale
26
+ ---
27
+
28
+ # Come rendere multilingue (i18n) un'applicazione Vite e React esistente (guida i18n 2026)
29
+
30
+ <Tabs defaultTab="video">
31
+ <Tab label="Video" value="video">
32
+
33
+ <iframe title="La migliore soluzione i18n per Vite e React? Scopri Intlayer" class="m-auto aspect-16/9 w-full overflow-hidden rounded-lg border-0" allow="autoplay; gyroscope;" loading="lazy" width="1080" height="auto" src="https://www.youtube.com/embed/dS9L7uJeak4?si=VaKmrYMmXjo3xpk2"/>
34
+
35
+ </Tab>
36
+ <Tab label="Codice" value="code">
37
+
38
+ <iframe
39
+ src="https://stackblitz.com/github/aymericzip/intlayer-vite-react-template?embed=1&ctl=1&file=intlayer.config.ts"
40
+ className="m-auto overflow-hidden rounded-lg border-0 max-md:size-full max-md:h-[700px] md:aspect-16/9 md:w-full"
41
+ title="Demo CodeSandbox - Come internazionalizzare la tua applicazione usando Intlayer"
42
+ sandbox="allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts"
43
+ loading="lazy"
44
+ />
45
+
46
+ </Tab>
47
+ </Tabs>
48
+
49
+ Vedi il [Template dell'Applicazione](https://github.com/aymericzip/intlayer-vite-react-template) su GitHub.
50
+
51
+ ## Indice
52
+
53
+ <TOC/>
54
+
55
+ ## Perché è difficile internazionalizzare un'applicazione esistente?
56
+
57
+ Se hai mai provato ad aggiungere più lingue a un'app creata per una sola, conosci il dolore. Non è solo "difficile", è noioso. Devi setacciare ogni singolo file, dare la caccia a ogni stringa di testo e spostarle in file dizionario separati.
58
+
59
+ Poi arriva la parte rischiosa: sostituire tutto quel testo con hook di codice senza rompere il layout o la logica. È il tipo di lavoro che blocca lo sviluppo di nuove funzionalità per settimane e sembra un refactoring senza fine.
60
+
61
+ ## Cos'è l'Intlayer Compiler?
62
+
63
+ L'**Intlayer Compiler** è stato creato per saltare quel lavoro manuale faticoso. Invece di estrarre manualmente le stringhe, il compilatore lo fa per te. Scansiona il tuo codice, trova il testo e utilizza l'IA per generare i dizionari dietro le quinte.
64
+ Quindi, modifica il tuo codice durante la build per iniettare gli hook i18n necessari. In pratica, continui a scrivere la tua app come se fosse in una sola lingua, e il compilatore gestisce automaticamente la trasformazione multilingue.
65
+
66
+ > Doc Compiler: [https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/compiler.md](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/compiler.md)
67
+
68
+ ### Limitazioni
69
+
70
+ Poiché il compilatore esegue l'analisi e la trasformazione del codice (inserendo hook e generando dizionari) in fase di **compilazione**, può **rallentare il processo di build** della tua applicazione.
71
+
72
+ Per mitigare questo impatto durante lo sviluppo, puoi configurare il compilatore per l'esecuzione in modalità [`'build-only'`](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/configuration.md) o disabilitarlo quando non è necessario.
73
+
74
+ ---
75
+
76
+ ## Guida Passo dopo Passo per Configurare Intlayer in un'Applicazione Vite e React
77
+
78
+ ### Passaggio 1: Installare le Dipendenze
79
+
80
+ Installa i pacchetti necessari utilizzando npm:
81
+
82
+ ```bash packageManager="npm"
83
+ npm install intlayer react-intlayer
84
+ npm install vite-intlayer --save-dev
85
+ npx intlayer init
86
+ ```
87
+
88
+ ```bash packageManager="pnpm"
89
+ pnpm add intlayer react-intlayer
90
+ pnpm add vite-intlayer --save-dev
91
+ pnpm intlayer init
92
+ ```
93
+
94
+ ```bash packageManager="yarn"
95
+ yarn add intlayer react-intlayer
96
+ yarn add vite-intlayer --save-dev
97
+ yarn intlayer init
98
+ ```
99
+
100
+ ```bash packageManager="bun"
101
+ bun add intlayer react-intlayer
102
+ bun add vite-intlayer --dev
103
+ bunx intlayer init
104
+ ```
105
+
106
+ - **intlayer**
107
+ Il pacchetto principale che fornisce strumenti di internazionalizzazione per la gestione della configurazione, la traduzione, la [dichiarazione dei contenuti](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/dictionary/content_file.md), la transpilazione e i [comandi CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/cli/index.md).
108
+
109
+ - **react-intlayer**
110
+ Il pacchetto che integra Intlayer con l'applicazione React. Fornisce context provider e hook per l'internazionalizzazione in React.
111
+
112
+ - **vite-intlayer**
113
+ Include il plugin Vite per l'integrazione di Intlayer con il [bundler Vite](https://vite.dev/guide/why.html#why-bundle-for-production), oltre al middleware per rilevare la lingua preferita dell'utente, gestire i cookie e gestire il reindirizzamento degli URL.
114
+
115
+ ### Passaggio 2: Configurare il Progetto
116
+
117
+ Crea un file di configurazione per impostare le lingue della tua applicazione:
118
+
119
+ ```typescript fileName="intlayer.config.ts"
120
+ import { Locales, type IntlayerConfig } from "intlayer";
121
+
122
+ const config: IntlayerConfig = {
123
+ internationalization: {
124
+ locales: [
125
+ Locales.ENGLISH,
126
+ Locales.FRENCH,
127
+ Locales.SPANISH,
128
+ Locales.ITALIAN,
129
+ ],
130
+ defaultLocale: Locales.ENGLISH,
131
+ },
132
+ compiler: {
133
+ enabled: true, // Può essere impostato su 'build-only' per limitare l'impatto in modalità dev
134
+ outputDir: "i18n",
135
+ dictionaryKeyPrefix: "", // Nessun prefisso comp-
136
+ },
137
+ ai: {
138
+ provider: "openai",
139
+ model: "gpt-5-mini",
140
+ apiKey: process.env.OPEN_AI_API_KEY,
141
+ applicationContext: "Questa è un'app di mappe", // Nota: puoi personalizzare questa descrizione dell'app
142
+ },
143
+ };
144
+
145
+ export default config;
146
+ ```
147
+
148
+ > **Nota**: Assicurati di avere la tua `OPEN_AI_API_KEY` impostata nelle variabili d'ambiente.
149
+
150
+ > Attraverso questo file di configurazione, puoi impostare URL localizzati, reindirizzamenti middleware, nomi dei cookie, la posizione e l'estensione delle tue dichiarazioni di contenuto, disabilitare i log di Intlayer nella console e altro ancora. Per un elenco completo dei parametri disponibili, consulta la [documentazione della configurazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/configuration.md).
151
+
152
+ ### Passaggio 3: Integrare Intlayer nella Configurazione di Vite
153
+
154
+ Aggiungi il plugin intlayer nella tua configurazione.
155
+
156
+ ```typescript fileName="vite.config.ts"
157
+ import { defineConfig } from "vite";
158
+ import react from "@vitejs/plugin-react-swc";
159
+ import { intlayer, intlayerCompiler } from "vite-intlayer";
160
+
161
+ // https://vitejs.dev/config/
162
+ export default defineConfig({
163
+ plugins: [react(), intlayer(), intlayerCompiler()],
164
+ });
165
+ ```
166
+
167
+ > Il plugin Vite `intlayer()` viene utilizzato per integrare Intlayer con Vite. Garantisce la creazione dei file di dichiarazione del contenuto e li monitora in modalità sviluppo. Definisce le variabili d'ambiente Intlayer all'interno dell'applicazione Vite. Inoltre, fornisce alias per ottimizzare le prestazioni.
168
+
169
+ > Il plugin Vite `intlayerCompiler()` viene utilizzato per estrarre il contenuto dai componenti e scrivere i file `.content`.
170
+
171
+ ### Passaggio 4: Compilare il Codice
172
+
173
+ Scrivi semplicemente i tuoi componenti con stringhe codificate nella tua lingua predefinita. Il compilatore gestisce il resto.
174
+
175
+ Esempio di come potrebbe apparire la tua pagina:
176
+
177
+ <Tabs>
178
+ <Tab value="Codice">
179
+
180
+ ```tsx fileName="src/App.tsx"
181
+ import { useState, type FC } from "react";
182
+ import reactLogo from "./assets/react.svg";
183
+ import viteLogo from "/vite.svg";
184
+ import "./App.css";
185
+ import { IntlayerProvider } from "react-intlayer";
186
+
187
+ const AppContent: FC = () => {
188
+ const [count, setCount] = useState(0);
189
+
190
+ return (
191
+ <>
192
+ <div>
193
+ <a href="https://vitejs.dev" target="_blank">
194
+ <img src={viteLogo} className="logo" alt="Logo Vite" />
195
+ </a>
196
+ <a href="https://react.dev" target="_blank">
197
+ <img src={reactLogo} className="logo react" alt="Logo React" />
198
+ </a>
199
+ </div>
200
+ <h1>Vite + React</h1>
201
+ <div className="card">
202
+ <button onClick={() => setCount((count) => count + 1)}>
203
+ il conteggio è {count}
204
+ </button>
205
+ <p>
206
+ Modifica <code>src/App.tsx</code> e salva per testare HMR
207
+ </p>
208
+ </div>
209
+ <p className="read-the-docs">
210
+ Clicca sui loghi Vite e React per saperne di più
211
+ </p>
212
+ </>
213
+ );
214
+ };
215
+
216
+ const App: FC = () => (
217
+ <IntlayerProvider>
218
+ <AppContent />
219
+ </IntlayerProvider>
220
+ );
221
+
222
+ export default App;
223
+ ```
224
+
225
+ </Tab>
226
+ <Tab value="Output">
227
+
228
+ ```ts fileName="i18n/app-content.content.json"
229
+ {
230
+ key: "app-content",
231
+ content: {
232
+ nodeType: "translation",
233
+ translation: {
234
+ en: {
235
+ viteLogo: "Vite logo",
236
+ reactLogo: "React logo",
237
+ title: "Vite + React",
238
+ countButton: "count is",
239
+ editMessage: "Edit",
240
+ hmrMessage: "and save to test HMR",
241
+ readTheDocs: "Click on the Vite and React logos to learn more",
242
+ },
243
+ it: {
244
+ viteLogo: "Logo Vite",
245
+ reactLogo: "Logo React",
246
+ title: "Vite + React",
247
+ countButton: "il conteggio è",
248
+ editMessage: "Modifica",
249
+ hmrMessage: "e salva per testare HMR",
250
+ readTheDocs: "Clicca sui loghi Vite e React per saperne di più",
251
+ },
252
+ }
253
+ }
254
+ }
255
+ ```
256
+
257
+ ```tsx fileName="src/App.tsx"
258
+ import { useState, type FC } from "react";
259
+ import reactLogo from "./assets/react.svg";
260
+ import viteLogo from "/vite.svg";
261
+ import "./App.css";
262
+ import { IntlayerProvider, useIntlayer } from "react-intlayer";
263
+
264
+ const AppContent: FC = () => {
265
+ const [count, setCount] = useState(0);
266
+ const content = useIntlayer("app-content");
267
+
268
+ return (
269
+ <>
270
+ <div>
271
+ <a href="https://vitejs.dev" target="_blank">
272
+ <img src={viteLogo} className="logo" alt={content.viteLogo.value} />
273
+ </a>
274
+ <a href="https://react.dev" target="_blank">
275
+ <img
276
+ src={reactLogo}
277
+ className="logo react"
278
+ alt={content.reactLogo.value}
279
+ />
280
+ </a>
281
+ </div>
282
+ <h1>{content.title}</h1>
283
+ <div className="card">
284
+ <button onClick={() => setCount((count) => count + 1)}>
285
+ {content.countButton} {count}
286
+ </button>
287
+ <p>
288
+ {content.editMessage} <code>src/App.tsx</code> {content.hmrMessage}
289
+ </p>
290
+ </div>
291
+ <p className="read-the-docs">{content.readTheDocs}</p>
292
+ </>
293
+ );
294
+ };
295
+
296
+ const App: FC = () => (
297
+ <IntlayerProvider>
298
+ <AppContent />
299
+ </IntlayerProvider>
300
+ );
301
+
302
+ export default App;
303
+ ```
304
+
305
+ </Tab>
306
+ </Tabs>
307
+
308
+ - **`IntlayerProvider`** viene utilizzato per fornire la lingua ai componenti annidati.
309
+
310
+ ### (Opzionale) Passaggio 6: Cambiare la lingua del contenuto
311
+
312
+ Per cambiare la lingua del tuo contenuto, puoi utilizzare la funzione `setLocale` fornita dall'hook `useLocale`. Questa funzione ti consente di impostare la lingua dell'applicazione e aggiornare il contenuto di conseguenza.
313
+
314
+ ```tsx fileName="src/components/LocaleSwitcher.tsx"
315
+ import type { FC } from "react";
316
+ import { Locales } from "intlayer";
317
+ import { useLocale } from "react-intlayer";
318
+
319
+ const LocaleSwitcher: FC = () => {
320
+ const { setLocale } = useLocale();
321
+
322
+ return (
323
+ <button onClick={() => setLocale(Locales.English)}>
324
+ Cambia lingua in inglese
325
+ </button>
326
+ );
327
+ };
328
+ ```
329
+
330
+ > Per saperne di più sull'hook `useLocale`, consulta la [documentazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/packages/react-intlayer/useLocale.md).
331
+
332
+ ### (Opzionale) Passaggio 7: Riempire le traduzioni mancanti
333
+
334
+ Intlayer fornisce uno strumento CLI per aiutarti a riempire le traduzioni mancanti. Puoi usare il comando `intlayer` per testare e riempire le traduzioni mancanti dal tuo codice.
335
+
336
+ ```bash
337
+ npx intlayer test # Testa se ci sono traduzioni mancanti
338
+ ```
339
+
340
+ ```bash
341
+ npx intlayer fill # Riempi le traduzioni mancanti
342
+ ```
343
+
344
+ > Per maggiori dettagli, fare riferimento alla [documentazione CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/cli/ci.md)
345
+
346
+ ### Configurazione Git
347
+
348
+ Si consiglia di ignorare i file generati da Intlayer. Ciò consente di evitare di caricarli nel repository Git.
349
+
350
+ Per farlo, puoi aggiungere le seguenti istruzioni al tuo file `.gitignore`:
351
+
352
+ ```plaintext fileName=".gitignore"
353
+ # Ignora i file generati da Intlayer
354
+ .intlayer
355
+ ```
356
+
357
+ ### Estensione VS Code
358
+
359
+ Per migliorare la tua esperienza di sviluppo con Intlayer, puoi installare l'**Estensione ufficiale Intlayer per VS Code**.
360
+
361
+ [Installa dal Marketplace di VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
362
+
363
+ Questa estensione fornisce:
364
+
365
+ - **Autocompletamento** per le chiavi di traduzione.
366
+ - **Rilevamento errori in tempo reale** per traduzioni mancanti.
367
+ - **Anteprime in linea** del contenuto tradotto.
368
+ - **Azioni rapide** per creare e aggiornare facilmente le traduzioni.
369
+
370
+ Per maggiori dettagli su come utilizzare l'estensione, consulta la [documentazione dell'estensione Intlayer per VS Code](https://intlayer.org/doc/vs-code-extension).
371
+
372
+ ### Approfondimenti
373
+
374
+ Per approfondire, puoi implementare l'[editor visuale](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/intlayer_visual_editor.md) o esternalizzare i tuoi contenuti utilizzando il [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/en/intlayer_CMS.md).