@intlayer/docs 7.0.0-canary.2 → 7.0.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/common.cjs.map +1 -1
- package/dist/esm/common.mjs.map +1 -1
- package/dist/types/common.d.ts +5 -0
- package/dist/types/common.d.ts.map +1 -1
- package/docs/ar/configuration.md +0 -24
- package/docs/ar/intlayer_with_nextjs_16.md +1652 -0
- package/docs/ar/releases/v7.md +485 -0
- package/docs/de/configuration.md +0 -24
- package/docs/de/intlayer_with_nextjs_16.md +1662 -0
- package/docs/de/releases/v7.md +502 -0
- package/docs/en/autoFill.md +3 -1
- package/docs/en/configuration.md +53 -58
- package/docs/en/intlayer_with_nextjs_15.md +5 -2
- package/docs/en/intlayer_with_nextjs_16.md +4 -4
- package/docs/en/releases/v7.md +142 -2
- package/docs/en-GB/configuration.md +9 -30
- package/docs/en-GB/intlayer_with_nextjs_16.md +1642 -0
- package/docs/en-GB/releases/v7.md +485 -0
- package/docs/es/configuration.md +0 -24
- package/docs/es/intlayer_with_nextjs_16.md +1670 -0
- package/docs/es/releases/v7.md +502 -0
- package/docs/fr/configuration.md +0 -24
- package/docs/fr/intlayer_with_nextjs_16.md +1692 -0
- package/docs/fr/releases/v7.md +503 -0
- package/docs/hi/configuration.md +0 -24
- package/docs/hi/intlayer_with_nextjs_16.md +1618 -0
- package/docs/hi/releases/v7.md +485 -0
- package/docs/id/intlayer_with_nextjs_16.md +1604 -0
- package/docs/id/releases/v7.md +502 -0
- package/docs/it/configuration.md +0 -24
- package/docs/it/intlayer_with_nextjs_16.md +1600 -0
- package/docs/it/releases/v7.md +504 -0
- package/docs/ja/configuration.md +0 -24
- package/docs/ja/intlayer_CMS.md +0 -9
- package/docs/ja/intlayer_with_nextjs_16.md +1788 -0
- package/docs/ja/releases/v7.md +503 -0
- package/docs/ko/configuration.md +0 -24
- package/docs/ko/intlayer_with_nextjs_16.md +1641 -0
- package/docs/ko/releases/v7.md +503 -0
- package/docs/pl/intlayer_with_nextjs_16.md +1645 -0
- package/docs/pl/releases/v7.md +485 -0
- package/docs/pt/configuration.md +0 -24
- package/docs/pt/intlayer_with_nextjs_16.md +1646 -0
- package/docs/pt/introduction.md +0 -15
- package/docs/pt/releases/v7.md +485 -0
- package/docs/ru/configuration.md +0 -24
- package/docs/ru/intlayer_with_nextjs_16.md +1610 -0
- package/docs/ru/releases/v7.md +485 -0
- package/docs/tr/configuration.md +0 -24
- package/docs/tr/intlayer_with_nextjs_16.md +1599 -0
- package/docs/tr/releases/v7.md +485 -0
- package/docs/vi/intlayer_with_nextjs_16.md +1597 -0
- package/docs/vi/releases/v7.md +485 -0
- package/docs/zh/configuration.md +0 -24
- package/docs/zh/intlayer_CMS.md +0 -23
- package/docs/zh/intlayer_with_nextjs_16.md +1628 -0
- package/docs/zh/releases/v7.md +486 -0
- package/package.json +14 -14
- package/src/common.ts +5 -0
|
@@ -0,0 +1,502 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2025-09-22
|
|
3
|
+
updatedAt: 2025-09-23
|
|
4
|
+
title: Neue Intlayer v7 - Was ist neu?
|
|
5
|
+
description: Entdecken Sie, was neu ist in Intlayer v7. Wichtige Verbesserungen in Leistung, Entwicklererfahrung und neue Funktionen zur Optimierung Ihres Internationalisierungs-Workflows.
|
|
6
|
+
keywords:
|
|
7
|
+
- Intlayer
|
|
8
|
+
- Lokalisierung
|
|
9
|
+
- Entwicklung
|
|
10
|
+
- Leistung
|
|
11
|
+
- Entwicklererfahrung
|
|
12
|
+
- Funktionen
|
|
13
|
+
- React
|
|
14
|
+
- Next.js
|
|
15
|
+
- JavaScript
|
|
16
|
+
- TypeScript
|
|
17
|
+
slugs:
|
|
18
|
+
- doc
|
|
19
|
+
- releases
|
|
20
|
+
- v7
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
# Neue Intlayer v7 - Was ist neu?
|
|
24
|
+
|
|
25
|
+
Willkommen bei Intlayer v7! Dieses große Release bringt bedeutende Verbesserungen in Leistung, Typsicherheit und Entwicklererfahrung. Nachfolgend finden Sie die Highlights, Migrationshinweise und praktische Beispiele.
|
|
26
|
+
|
|
27
|
+
## Highlights
|
|
28
|
+
|
|
29
|
+
- Caching-Strategie für schnellere Builds
|
|
30
|
+
- Verbesserte TypeScript-Typgenerierung mit sprachspezifischen Typen
|
|
31
|
+
- Bundle-Optimierung: Sprachen als Strings statt als Enum
|
|
32
|
+
- Neue Routing-Modi: `prefix-no-default`, `prefix-all`, `no-prefix`, `search-params`
|
|
33
|
+
- DSGVO-konforme Sprachspeicherung mit localStorage als Standard
|
|
34
|
+
- Flexible Speicher-Konfiguration: Cookies, localStorage, sessionStorage oder mehrere gleichzeitig
|
|
35
|
+
- 30 % kleinere Paketgröße des Visual Editors
|
|
36
|
+
- Erweiterte Middleware-Konfigurationsoptionen
|
|
37
|
+
- Aktualisiertes Verhalten des Fill-Kommandos für bessere Inhaltsverwaltung
|
|
38
|
+
- Verbesserte Stabilität durch vollständige Aktualisierung der Content-Declaration-Dateien
|
|
39
|
+
- Intelligentes Retry-Management für höhere Übersetzungsgenauigkeit
|
|
40
|
+
- Parallelisierung für schnellere Übersetzungsverarbeitung
|
|
41
|
+
- Intelligentes Chunking zur Handhabung großer Dateien innerhalb der KI-Kontextgrenzen
|
|
42
|
+
|
|
43
|
+
---
|
|
44
|
+
|
|
45
|
+
## Leistung: Caching für schnellere Builds
|
|
46
|
+
|
|
47
|
+
Anstatt bei jedem Build die Content-Declaration-Dateien mit esbuild neu zu erstellen, implementiert Version 7 eine Caching-Strategie, die den Build-Prozess beschleunigt.
|
|
48
|
+
|
|
49
|
+
```bash
|
|
50
|
+
npx intlayer build
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
Das neue Caching-System:
|
|
54
|
+
|
|
55
|
+
- Speichert kompilierte Content-Declaration-Dateien, um redundante Verarbeitung zu vermeiden
|
|
56
|
+
- Erkennt Änderungen und baut nur modifizierte Dateien neu auf
|
|
57
|
+
- Reduziert die Build-Zeiten bei großen Projekten erheblich
|
|
58
|
+
|
|
59
|
+
---
|
|
60
|
+
|
|
61
|
+
## TypeScript: Sprachspezifische Typgenerierung
|
|
62
|
+
|
|
63
|
+
TypeScript-Typen werden nun pro Sprache generiert, was eine stärkere Typisierung ermöglicht und Union-Typen über alle Sprachen hinweg eliminiert.
|
|
64
|
+
|
|
65
|
+
**Verhalten in v6:**
|
|
66
|
+
|
|
67
|
+
```tsx
|
|
68
|
+
const content = getIntlayer("my-title-content", "en");
|
|
69
|
+
// typeof content = { title: "My title" } | { title: "Mon titre" } | { title: "Mi título" }
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
**Verhalten in v7:**
|
|
73
|
+
|
|
74
|
+
```tsx
|
|
75
|
+
const content = getIntlayer("my-title-content", "en");
|
|
76
|
+
// typeof content = { title: "My title" }
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
Vorteile:
|
|
80
|
+
|
|
81
|
+
- Präzisere Autovervollständigung in Ihrer IDE
|
|
82
|
+
- Bessere Typensicherheit ohne Typverschmutzung über verschiedene Sprachen hinweg
|
|
83
|
+
- Verbesserte Leistung durch Reduzierung der Typkomplexität
|
|
84
|
+
|
|
85
|
+
---
|
|
86
|
+
|
|
87
|
+
## Bundle-Optimierung: Sprachen als Strings
|
|
88
|
+
|
|
89
|
+
Der Typ `Locales` ist kein Enum mehr, was bedeutet, dass er jetzt vollständig tree-shakeable ist und Ihr Bundle nicht mehr mit tausenden ungenutzten Sprachdatensätzen aufbläht.
|
|
90
|
+
|
|
91
|
+
**v6:**
|
|
92
|
+
|
|
93
|
+
```typescript
|
|
94
|
+
import { Locales } from "intlayer";
|
|
95
|
+
// Enum, das alle Sprachen enthält -> nicht tree-shakeable
|
|
96
|
+
|
|
97
|
+
const locale: Locales = Locales.ENGLISH;
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
**v7:**
|
|
101
|
+
|
|
102
|
+
```typescript
|
|
103
|
+
import { Locales, Locale } from "intlayer";
|
|
104
|
+
// String-Typ -> vollständig tree-shakeable
|
|
105
|
+
|
|
106
|
+
const locale: Locale = Locales.ENGLISH;
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
> Da `Locales` kein Enum mehr ist, müssen Sie den Typ von `Locales` zu `Locale` ändern, um die Sprache als Typ zu erhalten.
|
|
110
|
+
|
|
111
|
+
Siehe die [Implementierungsdetails](https://github.com/aymericzip/intlayer/blob/main/packages/%40intlayer/types/src/index.ts) für weitere Informationen.
|
|
112
|
+
|
|
113
|
+
---
|
|
114
|
+
|
|
115
|
+
## Neue Routing-Modi für mehr Flexibilität
|
|
116
|
+
|
|
117
|
+
v7 führt eine einheitliche `routing.mode`-Konfiguration ein, die die vorherigen Optionen `prefixDefault` und `noPrefix` ersetzt und eine feinere Steuerung der URL-Struktur ermöglicht.
|
|
118
|
+
|
|
119
|
+
### Verfügbare Routing-Modi
|
|
120
|
+
|
|
121
|
+
- **`prefix-no-default`** (Standard): Die Standardsprache hat kein Präfix, andere Sprachen schon
|
|
122
|
+
- `/dashboard` (en) oder `/fr/dashboard` (fr)
|
|
123
|
+
- **`prefix-all`**: Alle Sprachen haben ein Präfix
|
|
124
|
+
- `/en/dashboard` (en) oder `/fr/dashboard` (fr)
|
|
125
|
+
- **`no-prefix`**: Keine Sprachpräfixe in URLs (Sprache wird über Speicher/Header gehandhabt)
|
|
126
|
+
- `/dashboard` für alle Sprachen
|
|
127
|
+
- **`search-params`**: Sprache wird als Abfrageparameter übergeben
|
|
128
|
+
- `/dashboard?locale=en` oder `/dashboard?locale=fr`
|
|
129
|
+
|
|
130
|
+
### Grundkonfiguration
|
|
131
|
+
|
|
132
|
+
```typescript
|
|
133
|
+
// intlayer.config.ts
|
|
134
|
+
export default {
|
|
135
|
+
internationalization: {
|
|
136
|
+
locales: ["en", "fr", "es"],
|
|
137
|
+
defaultLocale: "en",
|
|
138
|
+
},
|
|
139
|
+
routing: {
|
|
140
|
+
mode: "prefix-no-default", // Standard
|
|
141
|
+
},
|
|
142
|
+
};
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
---
|
|
146
|
+
|
|
147
|
+
## DSGVO-Konformität: localStorage / Cookie-Speicherung
|
|
148
|
+
|
|
149
|
+
v7 legt besonderen Wert auf den Schutz der Privatsphäre der Nutzer, indem `localStorage` als Standard-Speichermechanismus anstelle von Cookies verwendet wird. Diese Änderung unterstützt die DSGVO-Konformität, indem sie die Notwendigkeit einer Cookie-Einwilligung für Spracheinstellungen vermeidet.
|
|
150
|
+
|
|
151
|
+
### Speicher-Konfigurationsoptionen
|
|
152
|
+
|
|
153
|
+
Das neue Feld `routing.storage` ist zusätzlich zu den bisherigen Optionen `middleware.cookieName` und `middleware.serverSetCookie` verfügbar und bietet flexible Speicher-Konfigurationen:
|
|
154
|
+
|
|
155
|
+
```typescript
|
|
156
|
+
// Speicher deaktivieren
|
|
157
|
+
storage: false
|
|
158
|
+
|
|
159
|
+
// Einfache Speichertypen
|
|
160
|
+
storage: 'cookie'
|
|
161
|
+
storage: 'localStorage'
|
|
162
|
+
storage: 'sessionStorage'
|
|
163
|
+
|
|
164
|
+
// Cookie mit benutzerdefinierten Attributen
|
|
165
|
+
storage: {
|
|
166
|
+
type: 'cookie',
|
|
167
|
+
name: 'custom-locale',
|
|
168
|
+
domain: '.example.com',
|
|
169
|
+
secure: true,
|
|
170
|
+
sameSite: 'strict'
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
// localStorage mit benutzerdefiniertem Schlüssel
|
|
174
|
+
storage: {
|
|
175
|
+
type: 'localStorage',
|
|
176
|
+
name: 'custom-locale'
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
// Mehrere Speichertypen zur Redundanz
|
|
180
|
+
storage: ['cookie', 'localStorage']
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
### DSGVO-konformes Konfigurationsbeispiel
|
|
184
|
+
|
|
185
|
+
Für produktive Anwendungen, die Funktionalität mit DSGVO-Konformität in Einklang bringen müssen:
|
|
186
|
+
|
|
187
|
+
```typescript
|
|
188
|
+
// intlayer.config.ts
|
|
189
|
+
export default {
|
|
190
|
+
internationalization: {
|
|
191
|
+
locales: ["en", "fr", "es"],
|
|
192
|
+
defaultLocale: "en",
|
|
193
|
+
},
|
|
194
|
+
routing: {
|
|
195
|
+
mode: "prefix-no-default",
|
|
196
|
+
storage: [
|
|
197
|
+
{
|
|
198
|
+
type: "localStorage", // Primärer Speicher (kein Einverständnis erforderlich)
|
|
199
|
+
name: "user-locale",
|
|
200
|
+
},
|
|
201
|
+
{
|
|
202
|
+
type: "cookie", // Optionale Cookie-Speicherung (erfordert Einverständnis)
|
|
203
|
+
name: "user-locale",
|
|
204
|
+
secure: true,
|
|
205
|
+
sameSite: "strict",
|
|
206
|
+
httpOnly: false,
|
|
207
|
+
},
|
|
208
|
+
],
|
|
209
|
+
},
|
|
210
|
+
};
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
### Aktivieren / Deaktivieren der Cookie-Speicherung
|
|
214
|
+
|
|
215
|
+
Beispiel mit React / Next.js:
|
|
216
|
+
|
|
217
|
+
Kann global definiert werden:
|
|
218
|
+
|
|
219
|
+
```typescript
|
|
220
|
+
<IntlayerProvider isCookieEnabled={false}>
|
|
221
|
+
<App />
|
|
222
|
+
</IntlayerProvider>
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
Kann lokal für jeden Hook überschrieben werden:
|
|
226
|
+
|
|
227
|
+
```ts
|
|
228
|
+
const { setLocale } = useLocale({ isCookieEnabled: false });
|
|
229
|
+
|
|
230
|
+
setLocale("en");
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
**Hinweis:** Cookies sind standardmäßig aktiviert.
|
|
234
|
+
**Hinweis:** Prüfen Sie die [DSGVO-Cookie-Anforderungen](https://gdpr.eu/cookies/) für Ihren spezifischen Anwendungsfall.
|
|
235
|
+
|
|
236
|
+
---
|
|
237
|
+
|
|
238
|
+
## Visual Editor: 30 % kleineres Paket
|
|
239
|
+
|
|
240
|
+
Das Visual Editor-Paket wurde optimiert und ist nun 30 % kleiner als die vorherige Version, dank:
|
|
241
|
+
|
|
242
|
+
- Verbesserungen der Leistung des Code-Editors
|
|
243
|
+
- Entfernung unnötiger Abhängigkeiten von Intlayer-Kernpaketen
|
|
244
|
+
- Besseres Tree-Shaking und Modul-Bündelung
|
|
245
|
+
|
|
246
|
+
Dies führt zu schnelleren Downloadzeiten und verbesserter Laufzeitleistung Ihrer Anwendung.
|
|
247
|
+
|
|
248
|
+
---
|
|
249
|
+
|
|
250
|
+
## Fill-Befehl: Aktualisiertes Verhalten für besseres Content-Management
|
|
251
|
+
|
|
252
|
+
v7 führt ein verbessertes Verhalten für den `fill`-Befehl ein, das ein vorhersehbareres und flexibleres Content-Management ermöglicht:
|
|
253
|
+
|
|
254
|
+
### Neues Fill-Verhalten
|
|
255
|
+
|
|
256
|
+
- **`fill: true`** - Überschreibt die aktuelle Datei mit ausgefülltem Inhalt für alle Sprachen
|
|
257
|
+
- **`fill: "path/to/file"`** - Füllt die angegebene Datei, ohne die aktuelle Datei zu verändern
|
|
258
|
+
- **`fill: false`** - Deaktiviert das automatische Ausfüllen vollständig
|
|
259
|
+
|
|
260
|
+
### Verbesserte Unterstützung für komplexe Inhaltsstrukturen
|
|
261
|
+
|
|
262
|
+
Der Fill-Befehl unterstützt jetzt komplexe Inhaltsdeklarationsstrukturen, einschließlich:
|
|
263
|
+
|
|
264
|
+
- **Zusammengesetzte Objekte**: Inhaltsdeklarationen, die auf andere Objekte verweisen
|
|
265
|
+
- **Destrukturierter Inhalt**: Inhalt, der Destrukturierungsmuster verwendet
|
|
266
|
+
- **Verschachtelte Verweise**: Objekte, die sich in komplexen Hierarchien gegenseitig aufrufen
|
|
267
|
+
- **Dynamische Inhaltsstrukturen**: Inhalt mit bedingten oder berechneten Eigenschaften
|
|
268
|
+
|
|
269
|
+
### Vorteile
|
|
270
|
+
|
|
271
|
+
- **Klarere Absicht**: Das Verhalten ist jetzt expliziter bezüglich dessen, was geändert wird
|
|
272
|
+
- **Bessere Trennung**: Inhaltsdateien können von ausgefüllten Übersetzungen getrennt gehalten werden
|
|
273
|
+
- **Verbesserter Arbeitsablauf**: Entwickler haben mehr Kontrolle darüber, wo Übersetzungen gespeichert werden
|
|
274
|
+
- **Unterstützung komplexer Strukturen**: Umgang mit anspruchsvollen Inhaltsarchitekturen mit mehreren miteinander verbundenen Objekten
|
|
275
|
+
|
|
276
|
+
### Beispielanwendung
|
|
277
|
+
|
|
278
|
+
```typescript
|
|
279
|
+
// Überschreibt die aktuelle Datei mit allen Sprachversionen
|
|
280
|
+
const content = {
|
|
281
|
+
key: "example",
|
|
282
|
+
fill: true, // Überschreibt diese Datei
|
|
283
|
+
content: {
|
|
284
|
+
title: "Hello World",
|
|
285
|
+
},
|
|
286
|
+
};
|
|
287
|
+
|
|
288
|
+
// Füllt eine separate Datei, ohne die aktuelle Datei zu ändern
|
|
289
|
+
const content = {
|
|
290
|
+
key: "example",
|
|
291
|
+
fill: "./translations.json", // Erstellt/aktualisiert translations.json
|
|
292
|
+
content: {
|
|
293
|
+
title: "Hello World",
|
|
294
|
+
},
|
|
295
|
+
};
|
|
296
|
+
|
|
297
|
+
// Deaktiviert Auto-Fill
|
|
298
|
+
const content = {
|
|
299
|
+
key: "example",
|
|
300
|
+
fill: false, // Kein Auto-Fill
|
|
301
|
+
content: {
|
|
302
|
+
title: "Hallo Welt",
|
|
303
|
+
},
|
|
304
|
+
};
|
|
305
|
+
|
|
306
|
+
// Komplexe Inhaltsstruktur mit zusammengesetzten Objekten
|
|
307
|
+
const sharedContent = {
|
|
308
|
+
buttons: {
|
|
309
|
+
save: "Speichern", // Speichern-Button
|
|
310
|
+
cancel: "Abbrechen", // Abbrechen-Button
|
|
311
|
+
},
|
|
312
|
+
};
|
|
313
|
+
|
|
314
|
+
const content = {
|
|
315
|
+
key: "complex-example",
|
|
316
|
+
fill: true,
|
|
317
|
+
content: {
|
|
318
|
+
// Verweise auf andere Objekte
|
|
319
|
+
sharedContent,
|
|
320
|
+
|
|
321
|
+
// Destrukturierter Inhalt
|
|
322
|
+
...sharedContent,
|
|
323
|
+
|
|
324
|
+
// Verschachtelte Verweise
|
|
325
|
+
sections: [
|
|
326
|
+
{
|
|
327
|
+
...sharedContent.buttons,
|
|
328
|
+
header: "Abschnitt 1",
|
|
329
|
+
},
|
|
330
|
+
],
|
|
331
|
+
},
|
|
332
|
+
};
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
---
|
|
336
|
+
|
|
337
|
+
## Verbesserte Stabilität und Übersetzungsverwaltung
|
|
338
|
+
|
|
339
|
+
v7 führt mehrere Verbesserungen ein, um die Inhaltsübersetzung zuverlässiger und effizienter zu gestalten:
|
|
340
|
+
|
|
341
|
+
### Vollständige Aktualisierung der Inhaltsdeklarationsdateien
|
|
342
|
+
|
|
343
|
+
Das System aktualisiert jetzt `.content.{ts,js,cjs,mjs}`-Dateien anstelle von Teilaktualisierungen, was sicherstellt:
|
|
344
|
+
|
|
345
|
+
- **Datenintegrität**: Vollständige Datei-Neuschreibungen verhindern partielle Updates, die Inhalte beschädigen könnten
|
|
346
|
+
- **Konsistenz**: Alle Sprachversionen werden atomar aktualisiert, um Synchronisation zu gewährleisten
|
|
347
|
+
- **Zuverlässigkeit**: Verringert das Risiko unvollständiger oder fehlerhafter Inhaltsdateien
|
|
348
|
+
|
|
349
|
+
### Intelligentes Wiederholungsmanagement
|
|
350
|
+
|
|
351
|
+
Neue Wiederholungsmechanismen verhindern das Hochladen von Inhalten in falschen Formaten und vermeiden, dass der gesamte Füllprozess bei einem fehlgeschlagenen Request abbricht.
|
|
352
|
+
|
|
353
|
+
### Parallelisierung für schnellere Verarbeitung
|
|
354
|
+
|
|
355
|
+
Übersetzungsoperationen werden jetzt in einer Warteschlange ausgeführt, um sie parallel laufen zu lassen. Dies beschleunigt den Prozess erheblich.
|
|
356
|
+
|
|
357
|
+
### Intelligentes Chunking für große Dateien
|
|
358
|
+
|
|
359
|
+
Fortschrittliche Chunking-Strategien verarbeiten große Inhaltsdateien, ohne die Kontextfenster der KI zu überschreiten:
|
|
360
|
+
|
|
361
|
+
### Beispiel-Workflow
|
|
362
|
+
|
|
363
|
+
```typescript
|
|
364
|
+
// Große Inhaltsdatei wird automatisch in Chunks aufgeteilt
|
|
365
|
+
const content = {
|
|
366
|
+
key: "large-documentation",
|
|
367
|
+
fill: true,
|
|
368
|
+
content: {
|
|
369
|
+
// Große Inhalte werden automatisch für die KI-Verarbeitung in Abschnitte unterteilt
|
|
370
|
+
introduction: "..." // 5000+ Zeichen
|
|
371
|
+
sections: [
|
|
372
|
+
// Mehrere große Abschnitte
|
|
373
|
+
]
|
|
374
|
+
}
|
|
375
|
+
};
|
|
376
|
+
```
|
|
377
|
+
|
|
378
|
+
Das System führt automatisch aus:
|
|
379
|
+
|
|
380
|
+
1. Analysiert die Größe und Struktur des Inhalts
|
|
381
|
+
2. Unterteilt den Inhalt angemessen in Abschnitte
|
|
382
|
+
3. Verarbeitet die Abschnitte parallel
|
|
383
|
+
4. Validiert und versucht bei Bedarf erneut
|
|
384
|
+
5. Rekonstruiert die vollständige Datei
|
|
385
|
+
|
|
386
|
+
---
|
|
387
|
+
|
|
388
|
+
## Migrationshinweise von v6
|
|
389
|
+
|
|
390
|
+
### Entfernte Konfigurationen
|
|
391
|
+
|
|
392
|
+
- **`middleware.cookieName`**: Ersetzt durch `routing.storage`
|
|
393
|
+
- **`middleware.serverSetCookie`**: Ersetzt durch `routing.storage`
|
|
394
|
+
- **`middleware.prefixDefault`**: Ersetzt durch `routing.mode`
|
|
395
|
+
- **`middleware.noPrefix`**: Ersetzt durch `routing.mode`
|
|
396
|
+
|
|
397
|
+
### Migrationszuordnung
|
|
398
|
+
|
|
399
|
+
#### Konfigurationszuordnung
|
|
400
|
+
|
|
401
|
+
| v6 Konfiguration | v7 Konfiguration |
|
|
402
|
+
| -------------------------- | -------------------------------------------------------------------- |
|
|
403
|
+
| `autoFill: xxx` | `fill: xxx` |
|
|
404
|
+
| `prefixDefault: false` | `mode: 'prefix-no-default'` |
|
|
405
|
+
| `prefixDefault: true` | `mode: 'prefix-all'` |
|
|
406
|
+
| `noPrefix: true` | `mode: 'no-prefix'` |
|
|
407
|
+
| `cookieName: 'my-locale'` | `storage: { type: 'cookie', name: 'my-locale' }` |
|
|
408
|
+
| `serverSetCookie: 'never'` | `storage: false` oder entfernen Sie den Cookie aus dem Storage-Array |
|
|
409
|
+
|
|
410
|
+
#### Beispiel Migration
|
|
411
|
+
|
|
412
|
+
**Vorher (v6):**
|
|
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
|
+
```typescript
|
|
432
|
+
export default {
|
|
433
|
+
middleware: {
|
|
434
|
+
headerName: "x-intlayer-locale",
|
|
435
|
+
cookieName: "intlayer-locale",
|
|
436
|
+
prefixDefault: false,
|
|
437
|
+
basePath: "",
|
|
438
|
+
serverSetCookie: "always",
|
|
439
|
+
noPrefix: false,
|
|
440
|
+
},
|
|
441
|
+
};
|
|
442
|
+
````
|
|
443
|
+
|
|
444
|
+
**Nachher (v7):**
|
|
445
|
+
|
|
446
|
+
```typescript
|
|
447
|
+
export default {
|
|
448
|
+
routing: {
|
|
449
|
+
mode: "prefix-no-default",
|
|
450
|
+
storage: "localStorage", // oder 'cookie', falls Cookie-Speicherung benötigt wird
|
|
451
|
+
headerName: "x-intlayer-locale",
|
|
452
|
+
basePath: "",
|
|
453
|
+
},
|
|
454
|
+
};
|
|
455
|
+
```
|
|
456
|
+
|
|
457
|
+
#### Wörterbuch-Inhaltszuordnung
|
|
458
|
+
|
|
459
|
+
| v6 Wörterbuch-Inhalt | v7 Wörterbuch-Inhalt |
|
|
460
|
+
| -------------------- | -------------------- |
|
|
461
|
+
| `autoFill: xxx` | `fill: xxx` |
|
|
462
|
+
|
|
463
|
+
#### Beispiel Migration
|
|
464
|
+
|
|
465
|
+
**Vorher (v6):**
|
|
466
|
+
|
|
467
|
+
```typescript
|
|
468
|
+
const content = {
|
|
469
|
+
key: "example",
|
|
470
|
+
autoFill: true, // Überschreibt diese Datei
|
|
471
|
+
content: {
|
|
472
|
+
title: "Hallo Welt",
|
|
473
|
+
},
|
|
474
|
+
};
|
|
475
|
+
```
|
|
476
|
+
|
|
477
|
+
**Nach (v7):**
|
|
478
|
+
|
|
479
|
+
```typescript
|
|
480
|
+
const content = {
|
|
481
|
+
key: "example",
|
|
482
|
+
fill: true, // Überschreibt diese Datei
|
|
483
|
+
content: {
|
|
484
|
+
title: "Hallo Welt",
|
|
485
|
+
},
|
|
486
|
+
};
|
|
487
|
+
```
|
|
488
|
+
|
|
489
|
+
---
|
|
490
|
+
|
|
491
|
+
## Migrationshinweise von v5 zu v6
|
|
492
|
+
|
|
493
|
+
Siehe die [Migrationshinweise von v5 zu v6](https://github.com/aymericzip/intlayer/blob/main/docs/docs/de/releases/v6.md) für weitere Informationen.
|
|
494
|
+
|
|
495
|
+
---
|
|
496
|
+
|
|
497
|
+
## Nützliche Links
|
|
498
|
+
|
|
499
|
+
- [Konfigurationsreferenz](https://github.com/aymericzip/intlayer/blob/main/docs/docs/de/configuration.md)
|
|
500
|
+
- [Middleware-Dokumentation](https://github.com/aymericzip/intlayer/blob/main/docs/docs/de/packages/next-intlayer/index.md)
|
|
501
|
+
- [TypeScript-Typen](https://github.com/aymericzip/intlayer/blob/main/packages/%40intlayer/types/src/index.ts)
|
|
502
|
+
- [DSGVO Cookie-Richtlinien](https://gdpr.eu/cookies/)
|
package/docs/en/autoFill.md
CHANGED
|
@@ -67,6 +67,8 @@ const config: IntlayerConfig = {
|
|
|
67
67
|
defaultLocale: Locales.ENGLISH,
|
|
68
68
|
requiredLocales: [Locales.ENGLISH], // Recommended to avoid Property 'pl' is missing in type '{ en: string; xxx } on your t function if
|
|
69
69
|
},
|
|
70
|
+
},
|
|
71
|
+
dictionary: {
|
|
70
72
|
fill: {
|
|
71
73
|
en: true, // Fill and edit the current file for English
|
|
72
74
|
fr: "./translations/fr.json", // Create separate file for French
|
|
@@ -133,7 +135,7 @@ const config: IntlayerConfig = {
|
|
|
133
135
|
defaultLocale: Locales.ENGLISH,
|
|
134
136
|
requiredLocales: [Locales.ENGLISH, Locales.FRENCH],
|
|
135
137
|
},
|
|
136
|
-
|
|
138
|
+
dictionary: {
|
|
137
139
|
// Auto-generate missing translations for all dictionaries
|
|
138
140
|
fill: "./{{fileName}}Filled.content.ts",
|
|
139
141
|
//
|