@intlayer/docs 7.0.3 → 7.0.4

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 (159) hide show
  1. package/blog/ar/intlayer_with_i18next.md +68 -106
  2. package/blog/ar/intlayer_with_next-i18next.md +84 -288
  3. package/blog/ar/intlayer_with_next-intl.md +58 -337
  4. package/blog/ar/intlayer_with_react-i18next.md +68 -290
  5. package/blog/ar/intlayer_with_react-intl.md +63 -266
  6. package/blog/de/intlayer_with_i18next.md +77 -97
  7. package/blog/de/intlayer_with_next-i18next.md +69 -296
  8. package/blog/de/intlayer_with_next-intl.md +59 -340
  9. package/blog/de/intlayer_with_react-i18next.md +68 -290
  10. package/blog/de/intlayer_with_react-intl.md +62 -264
  11. package/blog/en/intlayer_with_i18next.md +67 -103
  12. package/blog/en/intlayer_with_next-i18next.md +69 -294
  13. package/blog/en/intlayer_with_next-intl.md +48 -300
  14. package/blog/en/intlayer_with_react-i18next.md +61 -289
  15. package/blog/en/intlayer_with_react-intl.md +61 -284
  16. package/blog/en/next-i18next_vs_next-intl_vs_intlayer.md +1 -1
  17. package/blog/en-GB/intlayer_with_i18next.md +67 -103
  18. package/blog/en-GB/intlayer_with_next-i18next.md +71 -292
  19. package/blog/en-GB/intlayer_with_next-intl.md +58 -337
  20. package/blog/en-GB/intlayer_with_react-i18next.md +67 -289
  21. package/blog/en-GB/intlayer_with_react-intl.md +61 -264
  22. package/blog/es/intlayer_with_i18next.md +67 -103
  23. package/blog/es/intlayer_with_next-i18next.md +71 -296
  24. package/blog/es/intlayer_with_next-intl.md +57 -338
  25. package/blog/es/intlayer_with_react-i18next.md +68 -290
  26. package/blog/es/intlayer_with_react-intl.md +62 -265
  27. package/blog/fr/intlayer_with_i18next.md +66 -104
  28. package/blog/fr/intlayer_with_next-i18next.md +82 -285
  29. package/blog/fr/intlayer_with_next-intl.md +57 -338
  30. package/blog/fr/intlayer_with_react-i18next.md +67 -289
  31. package/blog/fr/intlayer_with_react-intl.md +61 -264
  32. package/blog/hi/intlayer_with_i18next.md +68 -104
  33. package/blog/hi/intlayer_with_next-i18next.md +74 -299
  34. package/blog/hi/intlayer_with_next-intl.md +57 -239
  35. package/blog/hi/intlayer_with_react-i18next.md +69 -291
  36. package/blog/hi/intlayer_with_react-intl.md +65 -268
  37. package/blog/id/intlayer_with_i18next.md +126 -0
  38. package/blog/id/intlayer_with_next-i18next.md +142 -0
  39. package/blog/id/intlayer_with_next-intl.md +113 -0
  40. package/blog/id/intlayer_with_react-i18next.md +124 -0
  41. package/blog/id/intlayer_with_react-intl.md +122 -0
  42. package/blog/it/intlayer_with_i18next.md +67 -103
  43. package/blog/it/intlayer_with_next-i18next.md +71 -296
  44. package/blog/it/intlayer_with_next-intl.md +57 -338
  45. package/blog/it/intlayer_with_react-i18next.md +68 -290
  46. package/blog/it/intlayer_with_react-intl.md +62 -265
  47. package/blog/ja/intlayer_with_i18next.md +68 -103
  48. package/blog/ja/intlayer_with_next-i18next.md +85 -283
  49. package/blog/ja/intlayer_with_next-intl.md +58 -336
  50. package/blog/ja/intlayer_with_react-i18next.md +68 -290
  51. package/blog/ja/intlayer_with_react-intl.md +62 -264
  52. package/blog/ko/intlayer_with_i18next.md +80 -96
  53. package/blog/ko/intlayer_with_next-i18next.md +85 -287
  54. package/blog/ko/intlayer_with_next-intl.md +68 -327
  55. package/blog/ko/intlayer_with_react-i18next.md +68 -290
  56. package/blog/ko/intlayer_with_react-intl.md +64 -266
  57. package/blog/pl/intlayer_with_i18next.md +126 -0
  58. package/blog/pl/intlayer_with_next-i18next.md +142 -0
  59. package/blog/pl/intlayer_with_next-intl.md +111 -0
  60. package/blog/pl/intlayer_with_react-i18next.md +124 -0
  61. package/blog/pl/intlayer_with_react-intl.md +122 -0
  62. package/blog/pt/intlayer_with_i18next.md +67 -103
  63. package/blog/pt/intlayer_with_next-i18next.md +72 -293
  64. package/blog/pt/intlayer_with_next-intl.md +57 -256
  65. package/blog/pt/intlayer_with_react-i18next.md +104 -78
  66. package/blog/pt/intlayer_with_react-intl.md +62 -266
  67. package/blog/ru/intlayer_with_i18next.md +66 -104
  68. package/blog/ru/intlayer_with_next-i18next.md +71 -296
  69. package/blog/ru/intlayer_with_next-intl.md +58 -337
  70. package/blog/ru/intlayer_with_react-i18next.md +68 -290
  71. package/blog/ru/intlayer_with_react-intl.md +62 -265
  72. package/blog/tr/intlayer_with_i18next.md +71 -107
  73. package/blog/tr/intlayer_with_next-i18next.md +72 -297
  74. package/blog/tr/intlayer_with_next-intl.md +58 -339
  75. package/blog/tr/intlayer_with_react-i18next.md +69 -291
  76. package/blog/tr/intlayer_with_react-intl.md +63 -285
  77. package/blog/vi/intlayer_with_i18next.md +126 -0
  78. package/blog/vi/intlayer_with_next-i18next.md +142 -0
  79. package/blog/vi/intlayer_with_next-intl.md +111 -0
  80. package/blog/vi/intlayer_with_react-i18next.md +124 -0
  81. package/blog/vi/intlayer_with_react-intl.md +122 -0
  82. package/blog/zh/intlayer_with_i18next.md +67 -102
  83. package/blog/zh/intlayer_with_next-i18next.md +72 -296
  84. package/blog/zh/intlayer_with_next-intl.md +58 -336
  85. package/blog/zh/intlayer_with_react-i18next.md +68 -290
  86. package/blog/zh/intlayer_with_react-intl.md +63 -106
  87. package/dist/cjs/generated/blog.entry.cjs +13 -1
  88. package/dist/cjs/generated/blog.entry.cjs.map +1 -1
  89. package/dist/cjs/generated/docs.entry.cjs +13 -1
  90. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  91. package/dist/cjs/generated/frequentQuestions.entry.cjs +13 -1
  92. package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
  93. package/dist/cjs/generated/legal.entry.cjs +13 -1
  94. package/dist/cjs/generated/legal.entry.cjs.map +1 -1
  95. package/dist/esm/generated/blog.entry.mjs +13 -2
  96. package/dist/esm/generated/blog.entry.mjs.map +1 -1
  97. package/dist/esm/generated/docs.entry.mjs +13 -2
  98. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  99. package/dist/esm/generated/frequentQuestions.entry.mjs +13 -2
  100. package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
  101. package/dist/esm/generated/legal.entry.mjs +13 -2
  102. package/dist/esm/generated/legal.entry.mjs.map +1 -1
  103. package/dist/types/generated/blog.entry.d.ts.map +1 -1
  104. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  105. package/dist/types/generated/frequentQuestions.entry.d.ts.map +1 -1
  106. package/dist/types/generated/legal.entry.d.ts.map +1 -1
  107. package/docs/ar/plugins/sync-json.md +244 -0
  108. package/docs/de/plugins/sync-json.md +244 -0
  109. package/docs/de/releases/v7.md +1 -18
  110. package/docs/en/CI_CD.md +1 -1
  111. package/docs/en/configuration.md +1 -1
  112. package/docs/en/formatters.md +1 -1
  113. package/docs/en/how_works_intlayer.md +1 -1
  114. package/docs/en/intlayer_CMS.md +1 -1
  115. package/docs/en/intlayer_cli.md +26 -1
  116. package/docs/en/intlayer_with_nextjs_14.md +3 -1
  117. package/docs/en/intlayer_with_nextjs_15.md +3 -1
  118. package/docs/en/intlayer_with_nextjs_16.md +3 -1
  119. package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
  120. package/docs/en/intlayer_with_nuxt.md +1 -1
  121. package/docs/en/intlayer_with_react_native+expo.md +1 -1
  122. package/docs/en/intlayer_with_react_router_v7.md +1 -1
  123. package/docs/en/intlayer_with_tanstack.md +1 -1
  124. package/docs/en/intlayer_with_vite+preact.md +1 -1
  125. package/docs/en/intlayer_with_vite+react.md +1 -1
  126. package/docs/en/intlayer_with_vite+solid.md +1 -1
  127. package/docs/en/intlayer_with_vite+svelte.md +1 -1
  128. package/docs/en/intlayer_with_vite+vue.md +1 -1
  129. package/docs/en/plugins/sync-json.md +1 -1
  130. package/docs/en/roadmap.md +1 -1
  131. package/docs/en-GB/plugins/sync-json.md +244 -0
  132. package/docs/es/plugins/sync-json.md +244 -0
  133. package/docs/es/releases/v7.md +1 -18
  134. package/docs/fr/intlayer_with_nextjs_16.md +2 -51
  135. package/docs/fr/plugins/sync-json.md +244 -0
  136. package/docs/fr/releases/v7.md +1 -18
  137. package/docs/hi/intlayer_with_nextjs_16.md +3 -2
  138. package/docs/hi/plugins/sync-json.md +244 -0
  139. package/docs/id/plugins/sync-json.md +244 -0
  140. package/docs/id/releases/v7.md +1 -18
  141. package/docs/it/plugins/sync-json.md +244 -0
  142. package/docs/it/releases/v7.md +1 -18
  143. package/docs/ja/intlayer_with_nextjs_16.md +44 -205
  144. package/docs/ja/plugins/sync-json.md +244 -0
  145. package/docs/ja/releases/v7.md +1 -18
  146. package/docs/ko/plugins/sync-json.md +244 -0
  147. package/docs/ko/releases/v7.md +1 -18
  148. package/docs/pl/plugins/sync-json.md +244 -0
  149. package/docs/pt/intlayer_with_nextjs_16.md +1 -52
  150. package/docs/pt/plugins/sync-json.md +244 -0
  151. package/docs/ru/plugins/sync-json.md +244 -0
  152. package/docs/tr/plugins/sync-json.md +245 -0
  153. package/docs/vi/plugins/sync-json.md +244 -0
  154. package/docs/zh/plugins/sync-json.md +244 -0
  155. package/package.json +14 -14
  156. package/src/generated/blog.entry.ts +26 -3
  157. package/src/generated/docs.entry.ts +26 -3
  158. package/src/generated/frequentQuestions.entry.ts +26 -3
  159. package/src/generated/legal.entry.ts +26 -3
@@ -0,0 +1,244 @@
1
+ ---
2
+ createdAt: 2025-03-13
3
+ updatedAt: 2025-10-05
4
+ title: Sync JSON Plugin
5
+ description: Synchronisieren Sie Intlayer-Wörterbücher mit Drittanbieter-i18n-JSON-Dateien (i18next, next-intl, react-intl, vue-i18n und mehr). Behalten Sie Ihr bestehendes i18n bei und verwenden Sie Intlayer, um Ihre Nachrichten zu verwalten, zu übersetzen und zu testen.
6
+ keywords:
7
+ - Intlayer
8
+ - Sync JSON
9
+ - i18next
10
+ - next-intl
11
+ - react-intl
12
+ - vue-i18n
13
+ - next-translate
14
+ - nuxt-i18n
15
+ - LinguiJS
16
+ - Polyglot.js
17
+ - Solid-i18next
18
+ - svelte-i18n
19
+ - i18n
20
+ - Übersetzungen
21
+ slugs:
22
+ - doc
23
+ - plugin
24
+ - sync-json
25
+ history:
26
+ - version: 6.1.6
27
+ date: 2025-10-05
28
+ changes: Erste Dokumentation des Sync JSON Plugins
29
+ ---
30
+
31
+ # Sync JSON (i18n-Brücken)
32
+
33
+ Verwenden Sie Intlayer als Ergänzung zu Ihrem bestehenden i18n-Stack. Dieses Plugin hält Ihre JSON-Nachrichten mit den Intlayer-Wörterbüchern synchron, sodass Sie:
34
+
35
+ - i18next, next-intl, react-intl, vue-i18n, next-translate, nuxt-i18n, Solid-i18next, svelte-i18n usw. beibehalten können.
36
+ - Ihre Nachrichten mit Intlayer (CLI, CI, Anbieter, CMS) verwalten und übersetzen, ohne Ihre App umzustrukturieren.
37
+ - Tutorials und SEO-Inhalte für jedes Ökosystem bereitstellen und gleichzeitig Intlayer als JSON-Verwaltungsschicht vorschlagen.
38
+
39
+ Hinweise und aktueller Umfang:
40
+
41
+ - Die Externalisierung zum CMS funktioniert für Übersetzungen und klassischen Text.
42
+ - Noch keine Unterstützung für Einfügungen, Pluralformen/ICU oder erweiterte Laufzeitfunktionen anderer Bibliotheken.
43
+ - Der visuelle Editor wird für Ausgaben von Drittanbieter-i18n noch nicht unterstützt.
44
+
45
+ ### Wann Sie dieses Plugin verwenden sollten
46
+
47
+ - Sie verwenden bereits eine i18n-Bibliothek und speichern Nachrichten in JSON-Dateien.
48
+ - Sie möchten KI-unterstütztes Ausfüllen, Tests in CI und Content-Operationen durchführen, ohne Ihre Rendering-Laufzeit zu ändern.
49
+
50
+ ## Installation
51
+
52
+ ```bash
53
+ pnpm add -D @intlayer/sync-json-plugin
54
+ # oder
55
+ npm i -D @intlayer/sync-json-plugin
56
+ ```
57
+
58
+ ## Schnellstart
59
+
60
+ Fügen Sie das Plugin zu Ihrer `intlayer.config.ts` hinzu und verweisen Sie auf Ihre bestehende JSON-Struktur.
61
+
62
+ ```ts fileName="intlayer.config.ts"
63
+ import { defineConfig, Locales } from "intlayer";
64
+ import { syncJSON } from "@intlayer/sync-json-plugin";
65
+
66
+ export default defineConfig({
67
+ internationalization: {
68
+ locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
69
+ defaultLocale: Locales.ENGLISH,
70
+ },
71
+
72
+ // Halten Sie Ihre aktuellen JSON-Dateien mit den Intlayer-Wörterbüchern synchron
73
+ plugins: [
74
+ syncJSON({
75
+ // Pro-Locale, pro-Namespace Layout (z.B. next-intl, i18next mit Namespaces)
76
+ source: ({ key, locale }) => `./locales/${locale}/${key}.json`,
77
+ }),
78
+ ],
79
+ });
80
+ ```
81
+
82
+ Alternative: Einzelne Datei pro Locale (häufig bei i18next/react-intl Setups):
83
+
84
+ ```ts fileName="intlayer.config.ts"
85
+ plugins: [
86
+ syncJSON({
87
+ source: ({ locale }) => `./locales/${locale}.json`,
88
+ }),
89
+ ];
90
+ ```
91
+
92
+ ### Funktionsweise
93
+
94
+ - Lesen: Das Plugin entdeckt JSON-Dateien über Ihren `source`-Builder und lädt sie als Intlayer-Wörterbücher.
95
+ - Schreiben: Nach dem Build und Ausfüllen schreibt es die lokalisierten JSON-Dateien zurück an dieselben Pfade (mit einer abschließenden neuen Zeile, um Formatierungsprobleme zu vermeiden).
96
+ - Auto-Fill: Das Plugin deklariert einen `autoFill`-Pfad für jedes Wörterbuch. Das Ausführen von `intlayer fill` aktualisiert standardmäßig nur fehlende Übersetzungen in Ihren JSON-Dateien.
97
+
98
+ API:
99
+
100
+ ```ts
101
+ syncJSON({
102
+ source: ({ key, locale }) => string, // erforderlich
103
+ location?: string, // optionales Label, Standard: "plugin"
104
+ priority?: number, // optionale Priorität zur Konfliktlösung, Standard: 0
105
+ });
106
+ ```
107
+
108
+ ## Mehrere JSON-Quellen und Priorität
109
+
110
+ Sie können mehrere `syncJSON`-Plugins hinzufügen, um verschiedene JSON-Quellen zu synchronisieren. Dies ist nützlich, wenn Sie mehrere i18n-Bibliotheken oder unterschiedliche JSON-Strukturen in Ihrem Projekt haben.
111
+
112
+ ### Prioritätssystem
113
+
114
+ Wenn mehrere Plugins denselben Wörterbuchschlüssel ansprechen, bestimmt der Parameter `priority`, welches Plugin Vorrang hat:
115
+
116
+ - Höhere Prioritätszahlen haben Vorrang vor niedrigeren
117
+ - Die Standardpriorität von `.content`-Dateien ist `0`
118
+ - Die Standardpriorität von Plugin-Content-Dateien ist `-1`
119
+ - Plugins mit derselben Priorität werden in der Reihenfolge verarbeitet, in der sie in der Konfiguration erscheinen
120
+
121
+ ```ts fileName="intlayer.config.ts"
122
+ import { defineConfig, Locales } from "intlayer";
123
+ import { syncJSON } from "@intlayer/sync-json-plugin";
124
+
125
+ export default defineConfig({
126
+ internationalization: {
127
+ locales: [Locales.ENGLISH, Locales.FRENCH],
128
+ defaultLocale: Locales.ENGLISH,
129
+ },
130
+
131
+ plugins: [
132
+ // Primäre JSON-Quelle (höchste Priorität)
133
+ syncJSON({
134
+ source: ({ key, locale }) => `./locales/${locale}/${key}.json`,
135
+ location: "main-translations",
136
+ priority: 10,
137
+ }),
138
+
139
+ // Fallback-JSON-Quelle (niedrigere Priorität)
140
+ syncJSON({
141
+ source: ({ locale }) => `./fallback-locales/${locale}.json`,
142
+ location: "fallback-translations",
143
+ priority: 5,
144
+ }),
145
+
146
+ // Legacy-JSON-Quelle (niedrigste Priorität)
147
+ syncJSON({
148
+ source: ({ locale }) => `/my/other/app/legacy/${locale}/messages.json`,
149
+ location: "legacy-translations",
150
+ priority: 1,
151
+ }),
152
+ ],
153
+ });
154
+ ```
155
+
156
+ ### Konfliktlösung
157
+
158
+ Wenn derselbe Übersetzungsschlüssel in mehreren JSON-Quellen vorhanden ist:
159
+
160
+ 1. Bestimmt das Plugin mit der höchsten Priorität den endgültigen Wert
161
+ 2. Werden Quellen mit niedrigerer Priorität als Fallbacks für fehlende Schlüssel verwendet
162
+ 3. Ermöglicht es Ihnen, Legacy-Übersetzungen beizubehalten und gleichzeitig schrittweise auf neue Strukturen umzusteigen
163
+
164
+ ## Integrationen
165
+
166
+ Nachfolgend sind gängige Zuordnungen aufgeführt. Belassen Sie Ihre Laufzeit unverändert; fügen Sie nur das Plugin hinzu.
167
+
168
+ ### i18next
169
+
170
+ Typische Dateistruktur: `./public/locales/{locale}/{namespace}.json` oder `./locales/{locale}/{namespace}.json`.
171
+
172
+ ```ts fileName="intlayer.config.ts"
173
+ import { syncJSON } from "@intlayer/sync-json-plugin";
174
+
175
+ export default {
176
+ plugins: [
177
+ syncJSON({
178
+ source: ({ key, locale }) => `./locales/${locale}/${key}.json`,
179
+ }),
180
+ ],
181
+ };
182
+ ```
183
+
184
+ ### next-intl
185
+
186
+ JSON-Nachrichten pro Locale (oft `./messages/{locale}.json`) oder pro Namespace.
187
+
188
+ ```ts fileName="intlayer.config.ts"
189
+ plugins: [
190
+ syncJSON({
191
+ source: ({ locale, key }) => `./messages/${locale}/${key}.json`,
192
+ }),
193
+ ];
194
+ ```
195
+
196
+ Siehe auch: `docs/de/intlayer_with_next-intl.md`.
197
+
198
+ ### react-intl
199
+
200
+ Einzelne JSON-Datei pro Locale ist üblich:
201
+
202
+ ```ts fileName="intlayer.config.ts"
203
+ plugins: [
204
+ syncJSON({
205
+ source: ({ locale }) => `./locales/${locale}.json`,
206
+ }),
207
+ ];
208
+ ```
209
+
210
+ ### vue-i18n
211
+
212
+ Entweder eine einzelne Datei pro Locale oder pro Namespace:
213
+
214
+ ```ts fileName="intlayer.config.ts"
215
+ plugins: [
216
+ syncJSON({
217
+ source: ({ key, locale }) => `./src/locales/${locale}/${key}.json`,
218
+ }),
219
+ ];
220
+ ```
221
+
222
+ ## CLI
223
+
224
+ Die synchronisierten JSON-Dateien werden wie andere `.content`-Dateien behandelt. Das bedeutet, dass alle intlayer-Befehle für die synchronisierten JSON-Dateien verfügbar sind. Einschließlich:
225
+
226
+ - `intlayer content test`, um zu testen, ob Übersetzungen fehlen
227
+ - `intlayer content list`, um die synchronisierten JSON-Dateien aufzulisten
228
+ - `intlayer content fill`, um fehlende Übersetzungen zu ergänzen
229
+ - `intlayer content push`, um die synchronisierten JSON-Dateien zu pushen
230
+ - `intlayer content pull`, um die synchronisierten JSON-Dateien zu pullen
231
+
232
+ Siehe [Intlayer CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/de/intlayer_cli.md) für weitere Details.
233
+
234
+ ## Einschränkungen (aktuell)
235
+
236
+ - Keine Unterstützung für Einfügungen oder Pluralformen/ICU bei der Verwendung von Drittanbieter-Bibliotheken.
237
+ - Visueller Editor ist für Nicht-Intlayer-Laufzeiten noch nicht verfügbar.
238
+ - Nur JSON-Synchronisierung; Nicht-JSON-Katalogformate werden nicht unterstützt.
239
+
240
+ ## Warum das wichtig ist
241
+
242
+ - Wir können etablierte i18n-Lösungen empfehlen und Intlayer als Zusatzmodul positionieren.
243
+ - Wir nutzen deren SEO/Schlüsselwörter mit Tutorials, die abschließend vorschlagen, Intlayer zur Verwaltung von JSON einzusetzen.
244
+ - Erweitert die ansprechbare Zielgruppe von „neuen Projekten“ auf „jedes Team, das bereits i18n verwendet“.
@@ -411,23 +411,6 @@ Das System führt automatisch aus:
411
411
 
412
412
  **Vorher (v6):**
413
413
 
414
- ````typescript
415
- export default {
416
- #### Konfigurationszuordnung
417
-
418
- | v6 Konfiguration | v7 Konfiguration |
419
- | -------------------------- | ---------------------------------------------------- |
420
- | `autoFill: xxx` | `fill: xxx` |
421
- | `prefixDefault: false` | `mode: 'prefix-no-default'` |
422
- | `prefixDefault: true` | `mode: 'prefix-all'` |
423
- | `noPrefix: true` | `mode: 'no-prefix'` |
424
- | `cookieName: 'my-locale'` | `storage: { type: 'cookie', name: 'my-locale' }` |
425
- | `serverSetCookie: 'never'` | `storage: false` oder Entfernen des Cookies aus dem Speicher-Array |
426
-
427
- #### Beispiel Migration
428
-
429
- **Vorher (v6):**
430
-
431
414
  ```typescript
432
415
  export default {
433
416
  middleware: {
@@ -439,7 +422,7 @@ export default {
439
422
  noPrefix: false,
440
423
  },
441
424
  };
442
- ````
425
+ ```
443
426
 
444
427
  **Nachher (v7):**
445
428
 
package/docs/en/CI_CD.md CHANGED
@@ -27,7 +27,7 @@ Intlayer allows the automatic generation of translations for your content declar
27
27
 
28
28
  ## Table of Contents
29
29
 
30
- <TOC>
30
+ <TOC/>
31
31
 
32
32
  ## Using the CMS
33
33
 
@@ -59,7 +59,7 @@ Intlayer configuration files allow customization of various aspects of the plugi
59
59
 
60
60
  ## Table of Contents
61
61
 
62
- <TOC>
62
+ <TOC/>
63
63
 
64
64
  ---
65
65
 
@@ -46,7 +46,7 @@ history:
46
46
 
47
47
  ## Table of Contents
48
48
 
49
- <TOC>
49
+ <TOC/>
50
50
 
51
51
  ## Overview
52
52
 
@@ -23,7 +23,7 @@ history:
23
23
 
24
24
  ## Table of Contents
25
25
 
26
- <TOC>
26
+ <TOC/>
27
27
 
28
28
  ## Overview
29
29
 
@@ -41,7 +41,7 @@ For that, Intlayer introduce the concept of 'distant dictionaries'.
41
41
 
42
42
  ## Table of Contents
43
43
 
44
- <TOC>
44
+ <TOC/>
45
45
 
46
46
  ---
47
47
 
@@ -52,7 +52,7 @@ history:
52
52
 
53
53
  ## Table of Contents
54
54
 
55
- <TOC>
55
+ <TOC/>
56
56
 
57
57
  ---
58
58
 
@@ -150,6 +150,10 @@ This command will find your declaration content files as default as `./src/**/*.
150
150
 
151
151
  > Example: `npx intlayer build --skip-prepare`
152
152
 
153
+ - **`--no-cache`**: Disable the cache.
154
+
155
+ > Example: `npx intlayer build --no-cache`
156
+
153
157
  ### Watch dictionaries
154
158
 
155
159
  ```bash
@@ -203,6 +207,10 @@ If [intlayer editor](https://github.com/aymericzip/intlayer/blob/main/docs/docs/
203
207
 
204
208
  > Example: `npx intlayer dictionary push --env-file .env.production.local`
205
209
 
210
+ - **`--no-cache`**: Disable the cache.
211
+
212
+ > Example: `npx intlayer build --no-cache`
213
+
206
214
  **Environment variables options:**
207
215
 
208
216
  - **`--env`**: Specify the environment (e.g., `development`, `production`). Useful in the case you use environment variables in your intlayer configuration file.
@@ -279,6 +287,10 @@ If [intlayer editor](https://github.com/aymericzip/intlayer/blob/main/docs/docs/
279
287
 
280
288
  > Example: `npx intlayer dictionary push --env-file .env.production.local`
281
289
 
290
+ - **`--no-cache`**: Disable the cache.
291
+
292
+ > Example: `npx intlayer build --no-cache`
293
+
282
294
  **Environment variables options:**
283
295
 
284
296
  - **`--env`**: Specify the environment (e.g., `development`, `production`).
@@ -392,6 +404,10 @@ This command analyzes your content declaration files for potential issues such a
392
404
 
393
405
  > Example: `npx intlayer fill --base-dir ./src`
394
406
 
407
+ - **`--no-cache`**: Disable the cache.
408
+
409
+ > Example: `npx intlayer build --no-cache`
410
+
395
411
  **Preparation options:**
396
412
 
397
413
  - **`--build`**: Build the dictionaries before pushing to ensure the content is up to date. True will force the build, false will skip the build, undefined will allow using the cache of the build.
@@ -448,6 +464,10 @@ Total missing required locales: 0
448
464
 
449
465
  > Example: `npx intlayer content test --base-dir ./src --env-file .env.production.local`
450
466
 
467
+ - **`--no-cache`**: Disable the cache.
468
+
469
+ > Example: `npx intlayer build --no-cache`
470
+
451
471
  **Preparation options:**
452
472
 
453
473
  - **`--build`**: Build the dictionaries before pushing to ensure the content is up to date. True will force the build, false will skip the build, undefined will allow using the cache of the build.
@@ -530,6 +550,7 @@ npx intlayer configuration get
530
550
  - **`--env-file`**: Provide a custom environment file to load variables from.
531
551
  - **`--base-dir`**: Specify the base directory for the project.
532
552
  - **`--verbose`**: Enable verbose logging for debugging. (default to true using CLI)
553
+ - **`--no-cache`**: Disable the cache.
533
554
 
534
555
  #### Push Configuration
535
556
 
@@ -550,6 +571,7 @@ npx intlayer configuration push
550
571
  - **`--env-file`**: Provide a custom environment file to load variables from.
551
572
  - **`--base-dir`**: Specify the base directory for the project.
552
573
  - **`--verbose`**: Enable verbose logging for debugging. (default to true using CLI)
574
+ - **`--no-cache`**: Disable the cache.
553
575
 
554
576
  By pushing the configuration, your project is fully integrated with the Intlayer CMS, enabling seamless dictionary management across teams.
555
577
 
@@ -623,6 +645,7 @@ npx intlayer doc translate
623
645
  - **`--env`**: Specify the environment (e.g., `development`, `production`).
624
646
  - **`--env-file [envFile]`**: Provide a custom environment file to load variables from.
625
647
  - **`--base-dir`**: Specify the base directory for the project.
648
+ - **`--no-cache`**: Disable the cache.
626
649
 
627
650
  > Example: `npx intlayer doc translate --base-dir ./docs --env-file .env.production.local`
628
651
 
@@ -738,6 +761,8 @@ Live Sync lets your app reflect CMS content changes at runtime. No rebuild or re
738
761
 
739
762
  - **`--base-dir`**: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the `intlayer.config.{ts,js,json,cjs,mjs}` file in the base directory.
740
763
 
764
+ - **`--no-cache`**: Disable the cache.
765
+
741
766
  > Example: `npx intlayer dictionary push --env-file .env.production.local`
742
767
 
743
768
  **Log options:**
@@ -40,7 +40,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-next-14-templa
40
40
 
41
41
  ## Table of Contents
42
42
 
43
- <TOC>
43
+ <TOC/>
44
44
 
45
45
  ## What is Intlayer?
46
46
 
@@ -1488,6 +1488,8 @@ yarn add @intlayer/swc --save-dev
1488
1488
 
1489
1489
  > Note: This package is not installed by default because SWC plugins are still experimental on Next.js. It may change in the future.
1490
1490
 
1491
+ > Note: If you set the option as `importMode: 'dynamic'` or `importMode: 'live'`, it will rely on Suspense, so you will have to wrap your `useIntlayer` calls in a `Suspense` boundary. That means, you will not be able to use the `useIntlayer` directly at the top level of your Page / Layout component.
1492
+
1491
1493
  ### Configure TypeScript
1492
1494
 
1493
1495
  Intlayer use module augmentation to get benefits of TypeScript and make your codebase stronger.
@@ -49,7 +49,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-next-15-templa
49
49
 
50
50
  ## Table of Contents
51
51
 
52
- <TOC>
52
+ <TOC/>
53
53
 
54
54
  ## What is Intlayer?
55
55
 
@@ -1550,6 +1550,8 @@ yarn add @intlayer/swc --save-dev
1550
1550
 
1551
1551
  > Note: This package is not installed by default because SWC plugins are still experimental on Next.js. It may change in the future.
1552
1552
 
1553
+ > Note: If you set the option as `importMode: 'dynamic'` or `importMode: 'live'`, it will rely on Suspense, so you will have to wrap your `useIntlayer` calls in a `Suspense` boundary. That means, you will not be able to use the `useIntlayer` directly at the top level of your Page / Layout component.
1554
+
1553
1555
  ### Watch dictionaries changes on Turbopack
1554
1556
 
1555
1557
  When using Turbopack as your development server with the `next dev --turbopack` command, dictionary changes will not be automatically detected by default.
@@ -30,7 +30,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-next-16-templa
30
30
 
31
31
  ## Table of Contents
32
32
 
33
- <TOC>
33
+ <TOC/>
34
34
 
35
35
  ## What is Intlayer?
36
36
 
@@ -1525,6 +1525,8 @@ yarn add @intlayer/swc --save-dev
1525
1525
 
1526
1526
  > Note: This package is not installed by default because SWC plugins are still experimental on Next.js. It may change in the future.
1527
1527
 
1528
+ > Note: If you set the option as `importMode: 'dynamic'` or `importMode: 'live'`, it will rely on Suspense, so you will have to wrap your `useIntlayer` calls in a `Suspense` boundary. That means, you will not be able to use the `useIntlayer` directly at the top level of your Page / Layout component.
1529
+
1528
1530
  ### Watch dictionaries changes on Turbopack
1529
1531
 
1530
1532
  When using Turbopack as your development server with the `next dev` command, dictionary changes will not be automatically detected by default.
@@ -29,7 +29,7 @@ history:
29
29
 
30
30
  ## Table of Contents
31
31
 
32
- <TOC>
32
+ <TOC/>
33
33
 
34
34
  ## What is Intlayer?
35
35
 
@@ -27,7 +27,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-nuxt-template)
27
27
 
28
28
  ## Table of Contents
29
29
 
30
- <TOC>
30
+ <TOC/>
31
31
 
32
32
  ## What is Intlayer?
33
33
 
@@ -30,7 +30,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-react-native-t
30
30
 
31
31
  ## Table of Contents
32
32
 
33
- <TOC>
33
+ <TOC/>
34
34
 
35
35
  ## What is Intlayer?
36
36
 
@@ -33,7 +33,7 @@ This guide demonstrates how to integrate **Intlayer** for seamless international
33
33
 
34
34
  ## Table of Contents
35
35
 
36
- <TOC>
36
+ <TOC/>
37
37
 
38
38
  ## What is Intlayer?
39
39
 
@@ -30,7 +30,7 @@ history:
30
30
 
31
31
  ## Table of Contents
32
32
 
33
- <TOC>
33
+ <TOC/>
34
34
 
35
35
  This guide demonstrates how to integrate **Intlayer** for seamless internationalization in Tanstack Start projects with locale-aware routing, TypeScript support, and modern development practices.
36
36
 
@@ -32,7 +32,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-vite-preact-te
32
32
 
33
33
  ## Table of Contents
34
34
 
35
- <TOC>
35
+ <TOC/>
36
36
 
37
37
  ## What is Intlayer?
38
38
 
@@ -31,7 +31,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-vite-react-tem
31
31
 
32
32
  ## Table of Contents
33
33
 
34
- <TOC>
34
+ <TOC/>
35
35
 
36
36
  ## What is Intlayer?
37
37
 
@@ -44,7 +44,7 @@ With Intlayer, you can:
44
44
 
45
45
  ## Table of Contents
46
46
 
47
- <TOC>
47
+ <TOC/>
48
48
 
49
49
  ### Step 1: Install Dependencies
50
50
 
@@ -29,7 +29,7 @@ history:
29
29
 
30
30
  ## Table of Contents
31
31
 
32
- <TOC>
32
+ <TOC/>
33
33
 
34
34
  ## What is Intlayer?
35
35
 
@@ -27,7 +27,7 @@ See [Application Template](https://github.com/aymericzip/intlayer-vite-vue-templ
27
27
 
28
28
  ## Table of Contents
29
29
 
30
- <TOC>
30
+ <TOC/>
31
31
 
32
32
  ## What is Intlayer?
33
33
 
@@ -28,7 +28,7 @@ history:
28
28
  changes: Initial Sync JSON plugin documentation
29
29
  ---
30
30
 
31
- ## Sync JSON (i18n bridges)
31
+ # Sync JSON (i18n bridges)
32
32
 
33
33
  Use Intlayer as an add‑on to your existing i18n stack. This plugin keeps your JSON messages in sync with Intlayer dictionaries so you can:
34
34
 
@@ -33,7 +33,7 @@ Intlayer is a content management and internationalization solution designed to s
33
33
 
34
34
  ## Table of Contents
35
35
 
36
- <TOC>
36
+ <TOC/>
37
37
 
38
38
  ---
39
39