@intlayer/docs 8.4.5 → 8.4.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.
- package/blog/en/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/en-GB/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/es/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/id/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/it/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/ja/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/ko/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/uk/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/vi/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/blog/zh/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
- package/dist/cjs/generated/docs.entry.cjs +20 -0
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +20 -0
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +1 -0
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/docs/ar/intlayer_with_storybook.md +521 -0
- package/docs/bn/intlayer_with_hono.md +428 -0
- package/docs/de/intlayer_with_storybook.md +521 -0
- package/docs/en/configuration.md +160 -508
- package/docs/en/intlayer_with_storybook.md +521 -0
- package/docs/en-GB/intlayer_with_storybook.md +521 -0
- package/docs/es/configuration.md +387 -754
- package/docs/es/intlayer_with_storybook.md +521 -0
- package/docs/fr/configuration.md +384 -757
- package/docs/fr/intlayer_with_storybook.md +521 -0
- package/docs/hi/intlayer_with_storybook.md +521 -0
- package/docs/id/intlayer_with_storybook.md +521 -0
- package/docs/it/intlayer_with_storybook.md +521 -0
- package/docs/ja/intlayer_with_storybook.md +521 -0
- package/docs/ko/intlayer_with_storybook.md +521 -0
- package/docs/pl/intlayer_with_storybook.md +521 -0
- package/docs/pt/intlayer_with_storybook.md +521 -0
- package/docs/ru/intlayer_with_storybook.md +521 -0
- package/docs/tr/intlayer_with_storybook.md +521 -0
- package/docs/uk/intlayer_with_storybook.md +521 -0
- package/docs/ur/intlayer_with_hono.md +428 -0
- package/docs/vi/intlayer_with_storybook.md +521 -0
- package/docs/zh/intlayer_with_storybook.md +521 -0
- package/package.json +6 -6
- package/src/generated/docs.entry.ts +20 -0
- package/docs/ar/configuration.md +0 -1124
- package/docs/de/configuration.md +0 -1296
- package/docs/en-GB/configuration.md +0 -1123
- package/docs/hi/configuration.md +0 -1118
- package/docs/id/configuration.md +0 -1235
- package/docs/it/configuration.md +0 -1301
- package/docs/ja/configuration.md +0 -1121
- package/docs/ko/configuration.md +0 -1121
- package/docs/pl/configuration.md +0 -1226
- package/docs/pt/configuration.md +0 -1293
- package/docs/ru/configuration.md +0 -1112
- package/docs/tr/configuration.md +0 -1114
- package/docs/uk/configuration.md +0 -1241
- package/docs/vi/configuration.md +0 -1263
- package/docs/zh/configuration.md +0 -1115
package/docs/id/configuration.md
DELETED
|
@@ -1,1235 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
createdAt: 2024-08-13
|
|
3
|
-
updatedAt: 2026-03-12
|
|
4
|
-
title: Konfigurasi
|
|
5
|
-
description: Pelajari cara mengonfigurasi Intlayer untuk aplikasi Anda. Pahami berbagai pengaturan dan opsi yang tersedia untuk menyesuaikan Intlayer sesuai kebutuhan Anda.
|
|
6
|
-
keywords:
|
|
7
|
-
- Konfigurasi
|
|
8
|
-
- Pengaturan
|
|
9
|
-
- Kustomisasi
|
|
10
|
-
- Intlayer
|
|
11
|
-
- Opsi
|
|
12
|
-
slugs:
|
|
13
|
-
- doc
|
|
14
|
-
- concept
|
|
15
|
-
- configuration
|
|
16
|
-
history:
|
|
17
|
-
- version: 8.3.0
|
|
18
|
-
date: 2026-03-11
|
|
19
|
-
changes: Pindahkan 'baseDir' dari konfigurasi 'content' ke 'system'
|
|
20
|
-
- version: 8.2.0
|
|
21
|
-
date: 2026-03-09
|
|
22
|
-
changes: Perbarui opsi kompiler, tambahkan dukungan 'output' dan 'noMetadata'
|
|
23
|
-
- version: 8.1.7
|
|
24
|
-
date: 2026-02-25
|
|
25
|
-
changes: Perbarui opsi kompiler
|
|
26
|
-
- version: 8.0.6
|
|
27
|
-
date: 2026-02-12
|
|
28
|
-
changes: Tambahkan dukungan untuk penyedia Open Router, Alibaba, Amazon, Google Vertex Bedrock, Fireworks, Groq, Hugging Face, dan Together.ai
|
|
29
|
-
- version: 8.0.5
|
|
30
|
-
date: 2026-02-06
|
|
31
|
-
changes: Tambahkan `dataSerialization` ke konfigurasi AI
|
|
32
|
-
- version: 8.0.0
|
|
33
|
-
date: 2026-01-22
|
|
34
|
-
changes: Pindahkan konfigurasi build importMode ke konfigurasi kamus.
|
|
35
|
-
- version: 8.0.0
|
|
36
|
-
date: 2026-01-18
|
|
37
|
-
changes: Pisahkan konfigurasi sistem dari konfigurasi konten. Pindahkan jalur internal ke properti `system`. Tambahkan `codeDir` untuk memisahkan file konten dari transformasi kode.
|
|
38
|
-
- version: 8.0.0
|
|
39
|
-
date: 2026-01-18
|
|
40
|
-
changes: Tambahkan opsi kamus `location` dan `schema`
|
|
41
|
-
- version: 7.5.1
|
|
42
|
-
date: 2026-01-10
|
|
43
|
-
changes: Menambahkan dukungan untuk format file JSON5 dan JSONC
|
|
44
|
-
- version: 7.5.0
|
|
45
|
-
date: 2025-12-17
|
|
46
|
-
changes: Menambahkan opsi `buildMode`
|
|
47
|
-
- version: 7.0.0
|
|
48
|
-
date: 2025-10-25
|
|
49
|
-
changes: Menambahkan konfigurasi `dictionary`
|
|
50
|
-
- version: 7.0.0
|
|
51
|
-
date: 2025-10-21
|
|
52
|
-
changes: Mengganti konfigurasi `middleware` dengan `routing`
|
|
53
|
-
- version: 7.0.0
|
|
54
|
-
date: 2025-10-12
|
|
55
|
-
changes: Menambahkan opsi `formatCommand`
|
|
56
|
-
- version: 6.2.0
|
|
57
|
-
date: 2025-10-12
|
|
58
|
-
changes: Memperbarui opsi `excludedPath`
|
|
59
|
-
- version: 6.0.2
|
|
60
|
-
date: 2025-09-23
|
|
61
|
-
changes: Menambahkan opsi `outputFormat`
|
|
62
|
-
- version: 6.0.0
|
|
63
|
-
date: 2025-09-21
|
|
64
|
-
changes: Menghapus field `dictionaryOutput` dan field `i18nextResourcesDir`
|
|
65
|
-
- version: 6.0.0
|
|
66
|
-
date: 2025-09-16
|
|
67
|
-
changes: Menambahkan mode import `live`
|
|
68
|
-
- version: 6.0.0
|
|
69
|
-
date: 2025-09-04
|
|
70
|
-
changes: Mengganti field `hotReload` dengan `liveSync` dan menambahkan field `liveSyncPort` serta `liveSyncURL`
|
|
71
|
-
- version: 5.6.1
|
|
72
|
-
date: 2025-07-25
|
|
73
|
-
changes: Mengganti `activateDynamicImport` dengan opsi `importMode`
|
|
74
|
-
- version: 5.6.0
|
|
75
|
-
date: 2025-07-13
|
|
76
|
-
changes: Mengubah default contentDir dari `['src']` menjadi `['.']`
|
|
77
|
-
- version: 5.5.11
|
|
78
|
-
date: 2025-06-29
|
|
79
|
-
changes: Menambahkan perintah `docs`
|
|
80
|
-
---
|
|
81
|
-
|
|
82
|
-
# Dokumentasi Konfigurasi Intlayer
|
|
83
|
-
|
|
84
|
-
## Ikhtisar
|
|
85
|
-
|
|
86
|
-
File konfigurasi Intlayer memungkinkan kustomisasi berbagai aspek plugin, seperti internasionalisasi, middleware, dan penanganan konten. Dokumen ini memberikan deskripsi rinci tentang setiap properti dalam konfigurasi.
|
|
87
|
-
|
|
88
|
-
---
|
|
89
|
-
|
|
90
|
-
## Daftar Isi
|
|
91
|
-
|
|
92
|
-
<TOC/>
|
|
93
|
-
|
|
94
|
-
---
|
|
95
|
-
|
|
96
|
-
## Dukungan File Konfigurasi
|
|
97
|
-
|
|
98
|
-
Intlayer menerima format file konfigurasi JSON, JS, MJS, dan TS:
|
|
99
|
-
|
|
100
|
-
- `intlayer.config.ts`
|
|
101
|
-
- `intlayer.config.js`
|
|
102
|
-
- `intlayer.config.json`
|
|
103
|
-
- `intlayer.config.json5`
|
|
104
|
-
- `intlayer.config.jsonc`
|
|
105
|
-
- `intlayer.config.cjs`
|
|
106
|
-
- `intlayer.config.mjs`
|
|
107
|
-
- `.intlayerrc`
|
|
108
|
-
|
|
109
|
-
---
|
|
110
|
-
|
|
111
|
-
## Contoh file konfigurasi
|
|
112
|
-
|
|
113
|
-
````typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
114
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
115
|
-
import { nextjsRewrite } from "intlayer/routing";
|
|
116
|
-
import { z } from "zod";
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* Example Intlayer configuration file showing all available options.
|
|
120
|
-
*/
|
|
121
|
-
const config: IntlayerConfig = {
|
|
122
|
-
/**
|
|
123
|
-
* Configuration for internationalization settings.
|
|
124
|
-
*/
|
|
125
|
-
internationalization: {
|
|
126
|
-
/**
|
|
127
|
-
* List of supported locales in the application.
|
|
128
|
-
* Default: [Locales.ENGLISH]
|
|
129
|
-
*/
|
|
130
|
-
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* List of required locales that must be defined in every dictionary.
|
|
134
|
-
* If empty, all locales are required in `strict` mode.
|
|
135
|
-
* Default: []
|
|
136
|
-
*/
|
|
137
|
-
requiredLocales: [Locales.ENGLISH],
|
|
138
|
-
|
|
139
|
-
/**
|
|
140
|
-
* Strictness level for internationalized content.
|
|
141
|
-
* - "strict": Errors if any declared locale is missing or undeclared.
|
|
142
|
-
* - "inclusive": Warnings if a declared locale is missing.
|
|
143
|
-
* - "loose": Accepts any existing locale.
|
|
144
|
-
* Default: "inclusive"
|
|
145
|
-
*/
|
|
146
|
-
strictMode: "inclusive",
|
|
147
|
-
|
|
148
|
-
/**
|
|
149
|
-
* Default locale used as a fallback if the requested locale is not found.
|
|
150
|
-
* Default: Locales.ENGLISH
|
|
151
|
-
*/
|
|
152
|
-
defaultLocale: Locales.ENGLISH,
|
|
153
|
-
},
|
|
154
|
-
|
|
155
|
-
/**
|
|
156
|
-
* Settings that control dictionary operations and fallback behavior.
|
|
157
|
-
*/
|
|
158
|
-
dictionary: {
|
|
159
|
-
/**
|
|
160
|
-
* Controls how dictionaries are imported.
|
|
161
|
-
* - "static": Statically imported at build time.
|
|
162
|
-
* - "dynamic": Dynamically imported using Suspense.
|
|
163
|
-
* - "fetch": Fetched dynamically via the live sync API.
|
|
164
|
-
* Default: "static"
|
|
165
|
-
*/
|
|
166
|
-
importMode: "static",
|
|
167
|
-
|
|
168
|
-
/**
|
|
169
|
-
* Strategy for auto-filling missing translations using AI.
|
|
170
|
-
* Can be a boolean or a path pattern to store filled content.
|
|
171
|
-
* Default: true
|
|
172
|
-
*/
|
|
173
|
-
fill: true,
|
|
174
|
-
|
|
175
|
-
/**
|
|
176
|
-
* Physical location of the dictionary files.
|
|
177
|
-
* - "local": Stored in the local filesystem.
|
|
178
|
-
* - "remote": Stored in the Intlayer CMS.
|
|
179
|
-
* - "hybrid": Stored in the local filesystem and the Intlayer CMS.
|
|
180
|
-
* - "plugin" (or any custom string): Provided by a plugin or a custom source.
|
|
181
|
-
* Default: "local"
|
|
182
|
-
*/
|
|
183
|
-
location: "local",
|
|
184
|
-
|
|
185
|
-
/**
|
|
186
|
-
* Whether to automatically transform content (e.g., Markdown to HTML).
|
|
187
|
-
* Default: false
|
|
188
|
-
*/
|
|
189
|
-
contentAutoTransformation: false,
|
|
190
|
-
},
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* Routing and middleware configuration.
|
|
194
|
-
*/
|
|
195
|
-
routing: {
|
|
196
|
-
/**
|
|
197
|
-
* Locale routing strategy.
|
|
198
|
-
* - "prefix-no-default": Prefix all except the default locale (e.g., /dashboard, /fr/dashboard).
|
|
199
|
-
* - "prefix-all": Prefix all locales (e.g., /en/dashboard, /fr/dashboard).
|
|
200
|
-
* - "no-prefix": No locale in the URL.
|
|
201
|
-
* - "search-params": Use ?locale=...
|
|
202
|
-
* Default: "prefix-no-default"
|
|
203
|
-
*/
|
|
204
|
-
mode: "prefix-no-default",
|
|
205
|
-
|
|
206
|
-
/**
|
|
207
|
-
* Where to store the user's selected locale.
|
|
208
|
-
* Options: 'cookie', 'localStorage', 'sessionStorage', 'header', or an array of these.
|
|
209
|
-
* Default: ['cookie', 'header']
|
|
210
|
-
*/
|
|
211
|
-
storage: ["cookie", "header"],
|
|
212
|
-
|
|
213
|
-
/**
|
|
214
|
-
* Base path for the application URLs.
|
|
215
|
-
* Default: ""
|
|
216
|
-
*/
|
|
217
|
-
basePath: "",
|
|
218
|
-
|
|
219
|
-
/**
|
|
220
|
-
* Custom URL rewriting rules for locale-specific paths.
|
|
221
|
-
*/
|
|
222
|
-
rewrite: nextjsRewrite({
|
|
223
|
-
"/[locale]/about": {
|
|
224
|
-
en: "/[locale]/about",
|
|
225
|
-
fr: "/[locale]/a-propos",
|
|
226
|
-
},
|
|
227
|
-
}),
|
|
228
|
-
},
|
|
229
|
-
|
|
230
|
-
/**
|
|
231
|
-
* Settings for finding and processing content files.
|
|
232
|
-
*/
|
|
233
|
-
content: {
|
|
234
|
-
/**
|
|
235
|
-
* File extensions to scan for dictionaries.
|
|
236
|
-
* Default: ['.content.ts', '.content.js', '.content.json', etc.]
|
|
237
|
-
*/
|
|
238
|
-
fileExtensions: [".content.ts", ".content.js", ".content.json"],
|
|
239
|
-
|
|
240
|
-
/**
|
|
241
|
-
* Directories where .content files are located.
|
|
242
|
-
* Default: ["."]
|
|
243
|
-
*/
|
|
244
|
-
contentDir: ["src"],
|
|
245
|
-
|
|
246
|
-
/**
|
|
247
|
-
* Directories where source code is located.
|
|
248
|
-
* Used for build optimization and code transformation.
|
|
249
|
-
* Default: ["."]
|
|
250
|
-
*/
|
|
251
|
-
codeDir: ["src"],
|
|
252
|
-
|
|
253
|
-
/**
|
|
254
|
-
* Patterns to exclude from scanning.
|
|
255
|
-
* Default: ['node_modules', '.intlayer', etc.]
|
|
256
|
-
*/
|
|
257
|
-
excludedPath: ["node_modules"],
|
|
258
|
-
|
|
259
|
-
/**
|
|
260
|
-
* Whether to watch for changes and rebuild dictionaries in development.
|
|
261
|
-
* Default: true in development
|
|
262
|
-
*/
|
|
263
|
-
watch: true,
|
|
264
|
-
|
|
265
|
-
/**
|
|
266
|
-
* Command to format newly created / updated .content files.
|
|
267
|
-
*/
|
|
268
|
-
formatCommand: 'npx prettier --write "{{file}}"',
|
|
269
|
-
},
|
|
270
|
-
|
|
271
|
-
/**
|
|
272
|
-
* Visual Editor configuration.
|
|
273
|
-
*/
|
|
274
|
-
editor: {
|
|
275
|
-
/**
|
|
276
|
-
* Whether the visual editor is enabled.
|
|
277
|
-
* Default: false
|
|
278
|
-
*/
|
|
279
|
-
enabled: true,
|
|
280
|
-
|
|
281
|
-
/**
|
|
282
|
-
* URL of your application for origin validation.
|
|
283
|
-
* Default: ""
|
|
284
|
-
*/
|
|
285
|
-
applicationURL: "http://localhost:3000",
|
|
286
|
-
|
|
287
|
-
/**
|
|
288
|
-
* Port for the local editor server.
|
|
289
|
-
* Default: 8000
|
|
290
|
-
*/
|
|
291
|
-
port: 8000,
|
|
292
|
-
|
|
293
|
-
/**
|
|
294
|
-
* Public URL for the editor.
|
|
295
|
-
* Default: "http://localhost:8000"
|
|
296
|
-
*/
|
|
297
|
-
editorURL: "http://localhost:8000",
|
|
298
|
-
|
|
299
|
-
/**
|
|
300
|
-
* Intlayer CMS URL.
|
|
301
|
-
* Default: "https://app.intlayer.org"
|
|
302
|
-
*/
|
|
303
|
-
cmsURL: "https://app.intlayer.org",
|
|
304
|
-
|
|
305
|
-
/**
|
|
306
|
-
* Backend API URL.
|
|
307
|
-
* Default: "https://back.intlayer.org"
|
|
308
|
-
*/
|
|
309
|
-
backendURL: "https://back.intlayer.org",
|
|
310
|
-
|
|
311
|
-
/**
|
|
312
|
-
* Whether to enable real-time content synchronization.
|
|
313
|
-
* Default: false
|
|
314
|
-
*/
|
|
315
|
-
liveSync: true,
|
|
316
|
-
},
|
|
317
|
-
|
|
318
|
-
/**
|
|
319
|
-
* AI-powered translation and generation settings.
|
|
320
|
-
*/
|
|
321
|
-
ai: {
|
|
322
|
-
/**
|
|
323
|
-
* AI provider to use.
|
|
324
|
-
* Options: 'openai', 'anthropic', 'mistral', 'deepseek', 'gemini', 'ollama', 'openrouter', 'alibaba', 'fireworks', 'groq', 'huggingface', 'bedrock', 'googlevertex', 'togetherai'
|
|
325
|
-
* Default: 'openai'
|
|
326
|
-
*/
|
|
327
|
-
provider: "openai",
|
|
328
|
-
|
|
329
|
-
/**
|
|
330
|
-
* Model to use from the selected provider.
|
|
331
|
-
*/
|
|
332
|
-
model: "gpt-4o",
|
|
333
|
-
|
|
334
|
-
/**
|
|
335
|
-
* Provider API key.
|
|
336
|
-
*/
|
|
337
|
-
apiKey: process.env.OPENAI_API_KEY,
|
|
338
|
-
|
|
339
|
-
/**
|
|
340
|
-
* Global context to guide the AI in generating translations.
|
|
341
|
-
*/
|
|
342
|
-
applicationContext: "This is a travel booking application.",
|
|
343
|
-
|
|
344
|
-
/**
|
|
345
|
-
* Base URL for the AI API.
|
|
346
|
-
*/
|
|
347
|
-
/**
|
|
348
|
-
* Data serialisasi
|
|
349
|
-
*
|
|
350
|
-
* Opsi:
|
|
351
|
-
* - "json": Standar, andal; menggunakan lebih banyak token.
|
|
352
|
-
* - "toon": Token lebih sedikit, kurang konsisten dibandingkan JSON.
|
|
353
|
-
*
|
|
354
|
-
* Default: "json"
|
|
355
|
-
*/
|
|
356
|
-
dataSerialization: "json",
|
|
357
|
-
},
|
|
358
|
-
|
|
359
|
-
/**
|
|
360
|
-
* Build and optimization settings.
|
|
361
|
-
*/
|
|
362
|
-
build: {
|
|
363
|
-
/**
|
|
364
|
-
* Build execution mode.
|
|
365
|
-
* - "auto": Automatic build during app build.
|
|
366
|
-
* - "manual": Requires explicit build command.
|
|
367
|
-
* Default: "auto"
|
|
368
|
-
*/
|
|
369
|
-
mode: "auto",
|
|
370
|
-
|
|
371
|
-
/**
|
|
372
|
-
* Whether to optimize the final bundle by pruning unused dictionaries.
|
|
373
|
-
* Default: true in production
|
|
374
|
-
*/
|
|
375
|
-
optimize: true,
|
|
376
|
-
|
|
377
|
-
/**
|
|
378
|
-
* Output format for generated dictionary files.
|
|
379
|
-
* Default: ['esm', 'cjs']
|
|
380
|
-
*/
|
|
381
|
-
outputFormat: ["esm"],
|
|
382
|
-
|
|
383
|
-
/**
|
|
384
|
-
* Indicates if the build should check TypeScript types.
|
|
385
|
-
* Default: false
|
|
386
|
-
*/
|
|
387
|
-
checkTypes: false,
|
|
388
|
-
},
|
|
389
|
-
|
|
390
|
-
/**
|
|
391
|
-
* Logger configuration.
|
|
392
|
-
*/
|
|
393
|
-
log: {
|
|
394
|
-
/**
|
|
395
|
-
* Logging level.
|
|
396
|
-
* - "default": Standard logging.
|
|
397
|
-
* - "verbose": Detailed debug logging.
|
|
398
|
-
* - "disabled": No logging.
|
|
399
|
-
* Default: "default"
|
|
400
|
-
*/
|
|
401
|
-
mode: "default",
|
|
402
|
-
|
|
403
|
-
/**
|
|
404
|
-
* Prefix for all log messages.
|
|
405
|
-
* Default: "[intlayer]"
|
|
406
|
-
*/
|
|
407
|
-
prefix: "[intlayer]",
|
|
408
|
-
},
|
|
409
|
-
|
|
410
|
-
/**
|
|
411
|
-
* System configuration (Advanced use cases)
|
|
412
|
-
*/
|
|
413
|
-
system: {
|
|
414
|
-
/**
|
|
415
|
-
* Directory for storing localization dictionaries.
|
|
416
|
-
*/
|
|
417
|
-
dictionariesDir: ".intlayer/dictionary",
|
|
418
|
-
|
|
419
|
-
/**
|
|
420
|
-
* Directory for module augmentation.
|
|
421
|
-
*/
|
|
422
|
-
moduleAugmentationDir: ".intlayer/types",
|
|
423
|
-
|
|
424
|
-
/**
|
|
425
|
-
* Directory for storing unmerged dictionaries.
|
|
426
|
-
*/
|
|
427
|
-
unmergedDictionariesDir: ".intlayer/unmerged_dictionary",
|
|
428
|
-
|
|
429
|
-
/**
|
|
430
|
-
* Directory for storing dictionary types.
|
|
431
|
-
*/
|
|
432
|
-
typesDir: ".intlayer/types",
|
|
433
|
-
|
|
434
|
-
/**
|
|
435
|
-
* Directory where main application files are stored.
|
|
436
|
-
*/
|
|
437
|
-
mainDir: ".intlayer/main",
|
|
438
|
-
|
|
439
|
-
/**
|
|
440
|
-
* Directory where the configuration files are stored.
|
|
441
|
-
*/
|
|
442
|
-
configDir: ".intlayer/config",
|
|
443
|
-
|
|
444
|
-
/**
|
|
445
|
-
* Directory where the cache files are stored.
|
|
446
|
-
*/
|
|
447
|
-
cacheDir: ".intlayer/cache",
|
|
448
|
-
},
|
|
449
|
-
|
|
450
|
-
/**
|
|
451
|
-
* Compiler configuration (Advanced use cases)
|
|
452
|
-
*/
|
|
453
|
-
compiler: {
|
|
454
|
-
/**
|
|
455
|
-
* Menunjukkan apakah kompiler harus diaktifkan.
|
|
456
|
-
*
|
|
457
|
-
* - false : Menonaktifkan kompiler.
|
|
458
|
-
* - true : Mengaktifkan kompiler.
|
|
459
|
-
* - "build-only" : Melewatkan kompiler selama pengembangan untuk mempercepat waktu mulai.
|
|
460
|
-
*
|
|
461
|
-
* Nilai default : false
|
|
462
|
-
*/
|
|
463
|
-
enabled: true,
|
|
464
|
-
|
|
465
|
-
/**
|
|
466
|
-
* Mendefinisikan jalur file output. Menggantikan `outputDir`.
|
|
467
|
-
*
|
|
468
|
-
* - Jalur yang dimulai dengan `./` diselesaikan relatif terhadap direktori komponen.
|
|
469
|
-
* - Jalur yang dimulai dengan `/` diselesaikan relatif terhadap root proyek (`baseDir`).
|
|
470
|
-
*
|
|
471
|
-
* - Menyertakan variabel `{{locale}}` dalam jalur akan mengaktifkan pembuatan kamus yang dipisahkan berdasarkan bahasa.
|
|
472
|
-
*
|
|
473
|
-
* Contoh:
|
|
474
|
-
* ```ts
|
|
475
|
-
* {
|
|
476
|
-
* // Buat file .content.ts multi-bahasa di sebelah komponen
|
|
477
|
-
* output: ({ fileName, extension }) => `./${fileName}${extension}`,
|
|
478
|
-
*
|
|
479
|
-
* // output: './{{fileName}}{{extension}}', // Padanan menggunakan string template
|
|
480
|
-
* }
|
|
481
|
-
* ```
|
|
482
|
-
*
|
|
483
|
-
* ```ts
|
|
484
|
-
* {
|
|
485
|
-
* // Buat file JSON terpusat berdasarkan bahasa di root proyek
|
|
486
|
-
* output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`,
|
|
487
|
-
*
|
|
488
|
-
* // output: '/locales/{{locale}}/{{key}}.content.json', // Padanan menggunakan string template
|
|
489
|
-
* }
|
|
490
|
-
* ```
|
|
491
|
-
*
|
|
492
|
-
* Daftar variabel:
|
|
493
|
-
* - `fileName`: Nama file.
|
|
494
|
-
* - `key`: Kunci konten.
|
|
495
|
-
* - `locale`: Bahasa konten.
|
|
496
|
-
* - `extension`: Ekstensi file.
|
|
497
|
-
* - `componentFileName`: Nama file komponen.
|
|
498
|
-
* - `componentExtension`: Ekstensi file komponen.
|
|
499
|
-
* - `format`: Format kamus.
|
|
500
|
-
* - `componentFormat`: Format kamus komponen.
|
|
501
|
-
* - `componentDirPath`: Jalur direktori komponen.
|
|
502
|
-
*/
|
|
503
|
-
output: ({ locale, key }) => `compiler/${locale}/${key}.json`,
|
|
504
|
-
|
|
505
|
-
/**
|
|
506
|
-
* Menunjukkan apakah komponen harus disimpan setelah ditransformasi.
|
|
507
|
-
* Dengan begitu, kompiler hanya perlu dijalankan sekali untuk mentransformasi aplikasi, lalu dapat dihapus.
|
|
508
|
-
*/
|
|
509
|
-
saveComponents: false,
|
|
510
|
-
|
|
511
|
-
/**
|
|
512
|
-
* Masukkan konten saja dalam file yang dihasilkan. Berguna untuk output JSON i18next atau ICU MessageFormat per bahasa.
|
|
513
|
-
*/
|
|
514
|
-
noMetadata: false,
|
|
515
|
-
|
|
516
|
-
/**
|
|
517
|
-
* Awalan kunci kamus
|
|
518
|
-
*/
|
|
519
|
-
dictionaryKeyPrefix: "", // Tambahkan awalan opsional untuk kunci kamus yang diekstrak
|
|
520
|
-
},
|
|
521
|
-
|
|
522
|
-
/**
|
|
523
|
-
* Custom schemas to validate the dictionaries content.
|
|
524
|
-
*/
|
|
525
|
-
schemas: {
|
|
526
|
-
"my-schema": z.object({
|
|
527
|
-
title: z.string(),
|
|
528
|
-
}),
|
|
529
|
-
},
|
|
530
|
-
|
|
531
|
-
/**
|
|
532
|
-
* Plugins configuration.
|
|
533
|
-
*/
|
|
534
|
-
plugins: [],
|
|
535
|
-
};
|
|
536
|
-
|
|
537
|
-
export default config;
|
|
538
|
-
````
|
|
539
|
-
|
|
540
|
-
## Referensi Konfigurasi
|
|
541
|
-
|
|
542
|
-
Bagian berikut menjelaskan berbagai pengaturan konfigurasi yang tersedia untuk Intlayer.
|
|
543
|
-
|
|
544
|
-
---
|
|
545
|
-
|
|
546
|
-
### Konfigurasi Internasionalisasi
|
|
547
|
-
|
|
548
|
-
Mendefinisikan pengaturan yang terkait dengan internasionalisasi, termasuk locale yang tersedia dan locale default untuk aplikasi.
|
|
549
|
-
|
|
550
|
-
#### Properti
|
|
551
|
-
|
|
552
|
-
- **locales**:
|
|
553
|
-
- _Tipe_: `string[]`
|
|
554
|
-
- _Default_: `['en']`
|
|
555
|
-
- _Deskripsi_: Daftar locale yang didukung dalam aplikasi.
|
|
556
|
-
- _Contoh_: `['en', 'fr', 'es']`
|
|
557
|
-
|
|
558
|
-
- **requiredLocales**:
|
|
559
|
-
- _Tipe_: `string[]`
|
|
560
|
-
- _Default_: `[]`
|
|
561
|
-
- _Deskripsi_: Daftar locale yang wajib ada dalam aplikasi.
|
|
562
|
-
- _Contoh_: `[]`
|
|
563
|
-
- _Catatan_: Jika kosong, semua locale diwajibkan dalam mode `strict`.
|
|
564
|
-
- _Catatan_: Pastikan locale yang wajib juga didefinisikan dalam field `locales`.
|
|
565
|
-
- **strictMode**:
|
|
566
|
-
- _Tipe_: `string`
|
|
567
|
-
- _Default_: `inclusive`
|
|
568
|
-
- _Deskripsi_: Menjamin implementasi konten internasionalisasi yang kuat menggunakan typescript.
|
|
569
|
-
- _Catatan_: Jika diatur ke "strict", fungsi terjemahan `t` akan mengharuskan setiap locale yang dideklarasikan untuk didefinisikan. Jika satu locale hilang, atau jika locale tidak dideklarasikan dalam konfigurasi Anda, maka akan menghasilkan error.
|
|
570
|
-
- _Catatan_: Jika diatur ke "inclusive", fungsi terjemahan `t` akan mengharuskan setiap locale yang dideklarasikan untuk didefinisikan. Jika satu locale hilang, akan memberikan peringatan. Namun akan menerima jika locale tidak dideklarasikan dalam konfigurasi Anda, tetapi ada.
|
|
571
|
-
- _Catatan_: Jika diatur ke "loose", fungsi terjemahan `t` akan menerima locale yang ada.
|
|
572
|
-
|
|
573
|
-
- **defaultLocale**:
|
|
574
|
-
- _Tipe_: `string`
|
|
575
|
-
- _Default_: `'en'`
|
|
576
|
-
- _Deskripsi_: Locale default yang digunakan sebagai fallback jika locale yang diminta tidak ditemukan.
|
|
577
|
-
- _Contoh_: `'en'`
|
|
578
|
-
- _Catatan_: Ini digunakan untuk menentukan locale ketika tidak ada yang ditentukan dalam URL, cookie, atau header.
|
|
579
|
-
|
|
580
|
-
---
|
|
581
|
-
|
|
582
|
-
### Konfigurasi Editor
|
|
583
|
-
|
|
584
|
-
Mendefinisikan pengaturan terkait editor terintegrasi, termasuk port server dan status aktif.
|
|
585
|
-
|
|
586
|
-
#### Properti
|
|
587
|
-
|
|
588
|
-
- **applicationURL**:
|
|
589
|
-
- _Tipe_: `string`
|
|
590
|
-
- _Default_: `http://localhost:3000`
|
|
591
|
-
- _Deskripsi_: URL aplikasi. Digunakan untuk membatasi asal editor demi alasan keamanan.
|
|
592
|
-
- _Contoh_:
|
|
593
|
-
- `'http://localhost:3000'`
|
|
594
|
-
- `'https://example.com'`
|
|
595
|
-
- `process.env.INTLAYER_EDITOR_URL`
|
|
596
|
-
- _Catatan_: URL aplikasi. Digunakan untuk membatasi asal editor demi alasan keamanan. Jika diatur ke `'*'`, editor dapat diakses dari asal mana pun.
|
|
597
|
-
|
|
598
|
-
- **port**:
|
|
599
|
-
- _Tipe_: `number`
|
|
600
|
-
- _Default_: `8000`
|
|
601
|
-
- _Deskripsi_: Port yang digunakan oleh server editor visual.
|
|
602
|
-
|
|
603
|
-
- **editorURL**:
|
|
604
|
-
- _Tipe_: `string`
|
|
605
|
-
- _Default_: `'http://localhost:8000'`
|
|
606
|
-
- _Deskripsi_: URL server editor. Digunakan untuk membatasi asal editor demi alasan keamanan.
|
|
607
|
-
- `'http://localhost:3000'`
|
|
608
|
-
- `'https://example.com'`
|
|
609
|
-
- `process.env.INTLAYER_EDITOR_URL`
|
|
610
|
-
- _Catatan_: URL server editor yang dapat diakses dari aplikasi. Digunakan untuk membatasi asal yang dapat berinteraksi dengan aplikasi demi alasan keamanan. Jika diatur ke `'*'`, editor dapat diakses dari asal mana pun. Harus diatur jika port diubah, atau jika editor dihosting di domain yang berbeda.
|
|
611
|
-
|
|
612
|
-
- **cmsURL**:
|
|
613
|
-
- _Tipe_: `string`
|
|
614
|
-
- _Default_: `'https://intlayer.org'`
|
|
615
|
-
- _Deskripsi_: URL dari Intlayer CMS.
|
|
616
|
-
- _Contoh_: `'https://intlayer.org'`
|
|
617
|
-
- _Catatan_: URL dari Intlayer CMS.
|
|
618
|
-
|
|
619
|
-
- **backendURL**:
|
|
620
|
-
- _Tipe_: `string`
|
|
621
|
-
- _Default_: `https://back.intlayer.org`
|
|
622
|
-
- _Deskripsi_: URL dari server backend.
|
|
623
|
-
- _Contoh_: `http://localhost:4000`
|
|
624
|
-
|
|
625
|
-
- **enabled**:
|
|
626
|
-
- _Tipe_: `boolean`
|
|
627
|
-
- _Default_: `true`
|
|
628
|
-
- _Deskripsi_: Menunjukkan apakah aplikasi berinteraksi dengan visual editor.
|
|
629
|
-
- _Contoh_: `process.env.NODE_ENV !== 'production'`
|
|
630
|
-
- _Catatan_: Jika true, editor akan dapat berinteraksi dengan aplikasi. Jika false, editor tidak akan dapat berinteraksi dengan aplikasi. Dalam hal apa pun, editor hanya dapat diaktifkan oleh visual editor. Menonaktifkan editor untuk lingkungan tertentu adalah cara untuk menegakkan keamanan.
|
|
631
|
-
|
|
632
|
-
- **clientId**:
|
|
633
|
-
- _Tipe_: `string` | `undefined`
|
|
634
|
-
- _Default_: `undefined`
|
|
635
|
-
- _Deskripsi_: clientId dan clientSecret memungkinkan paket intlayer untuk melakukan autentikasi dengan backend menggunakan autentikasi oAuth2. Token akses digunakan untuk mengautentikasi pengguna yang terkait dengan proyek. Untuk mendapatkan token akses, kunjungi https://app.intlayer.org/project dan buat akun.
|
|
636
|
-
- _Contoh_: `true`
|
|
637
|
-
- _Catatan_: Penting: clientId dan clientSecret harus dijaga kerahasiaannya dan tidak dibagikan secara publik. Pastikan untuk menyimpannya di lokasi yang aman, seperti variabel lingkungan.
|
|
638
|
-
|
|
639
|
-
- **clientSecret**:
|
|
640
|
-
- _Tipe_: `string` | `undefined`
|
|
641
|
-
- _Default_: `undefined`
|
|
642
|
-
- _Deskripsi_: clientId dan clientSecret memungkinkan paket intlayer untuk melakukan autentikasi dengan backend menggunakan autentikasi oAuth2. Token akses digunakan untuk mengautentikasi pengguna yang terkait dengan proyek. Untuk mendapatkan token akses, kunjungi https://app.intlayer.org/project dan buat akun.
|
|
643
|
-
- _Contoh_: `true`
|
|
644
|
-
- _Catatan_: Penting: clientId dan clientSecret harus dijaga kerahasiaannya dan tidak dibagikan secara publik. Pastikan untuk menyimpannya di lokasi yang aman, seperti variabel lingkungan.
|
|
645
|
-
|
|
646
|
-
- **dictionaryPriorityStrategy**:
|
|
647
|
-
- _Tipe_: `string`
|
|
648
|
-
- _Default_: `'local_first'`
|
|
649
|
-
- _Deskripsi_: Strategi untuk memprioritaskan kamus dalam kasus adanya kamus lokal dan jauh. Jika diatur ke `'distant_first'`, aplikasi akan memprioritaskan kamus jauh dibandingkan kamus lokal. Jika diatur ke `'local_first'`, aplikasi akan memprioritaskan kamus lokal dibandingkan kamus jauh.
|
|
650
|
-
- _Contoh_: `'distant_first'`
|
|
651
|
-
|
|
652
|
-
- **liveSync**:
|
|
653
|
-
- _Tipe_: `boolean`
|
|
654
|
-
- _Default_: `false`
|
|
655
|
-
- _Deskripsi_: Menunjukkan apakah server aplikasi harus melakukan hot reload konten aplikasi ketika perubahan terdeteksi pada CMS / Visual Editor / Backend.
|
|
656
|
-
- _Contoh_: `true`
|
|
657
|
-
- _Catatan_: Misalnya, ketika kamus baru ditambahkan atau diperbarui, aplikasi akan memperbarui konten yang ditampilkan di halaman.
|
|
658
|
-
- _Catatan_: Live sync membutuhkan eksternalisasi konten aplikasi ke server lain. Itu berarti dapat sedikit memengaruhi performa aplikasi. Untuk membatasi hal ini, kami menyarankan untuk meng-host aplikasi dan server live sync pada mesin yang sama. Selain itu, kombinasi live sync dan `optimize` dapat menghasilkan sejumlah besar permintaan ke server live sync. Tergantung pada infrastruktur Anda, kami menyarankan untuk menguji kedua opsi dan kombinasi keduanya.
|
|
659
|
-
|
|
660
|
-
- **liveSyncPort**:
|
|
661
|
-
- _Tipe_: `number`
|
|
662
|
-
- _Default_: `4000`
|
|
663
|
-
- _Deskripsi_: Port dari server live sync.
|
|
664
|
-
- _Contoh_: `4000`
|
|
665
|
-
- _Catatan_: Port dari server live sync.
|
|
666
|
-
|
|
667
|
-
- **liveSyncURL**:
|
|
668
|
-
- _Tipe_: `string`
|
|
669
|
-
- _Default_: `'http://localhost:{liveSyncPort}'`
|
|
670
|
-
- _Deskripsi_: URL dari server live sync.
|
|
671
|
-
- _Contoh_: `'https://example.com'`
|
|
672
|
-
- _Catatan_: Mengarah ke localhost secara default tetapi dapat diubah ke URL mana pun dalam kasus server live sync jarak jauh.
|
|
673
|
-
|
|
674
|
-
### Konfigurasi Routing
|
|
675
|
-
|
|
676
|
-
Pengaturan yang mengontrol perilaku routing, termasuk struktur URL, penyimpanan locale, dan penanganan middleware.
|
|
677
|
-
|
|
678
|
-
#### Properti
|
|
679
|
-
|
|
680
|
-
- **mode**:
|
|
681
|
-
- _Tipe_: `'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'`
|
|
682
|
-
- _Default_: `'prefix-no-default'`
|
|
683
|
-
- _Deskripsi_: Mode routing URL untuk penanganan locale.
|
|
684
|
-
- _Contoh_:
|
|
685
|
-
- `'prefix-no-default'`: `/dashboard` (en) atau `/fr/dashboard` (fr)
|
|
686
|
-
- `'prefix-all'`: `/en/dashboard` (en) atau `/fr/dashboard` (fr)
|
|
687
|
-
- `'no-prefix'`: `/dashboard` (locale ditangani dengan cara lain)
|
|
688
|
-
- `'search-params'`: `/dashboard?locale=fr`
|
|
689
|
-
- _Catatan_: Pengaturan ini tidak memengaruhi manajemen cookie atau penyimpanan locale.
|
|
690
|
-
|
|
691
|
-
- **storage**:
|
|
692
|
-
- _Tipe_: `false | 'cookie' | 'localStorage' | 'sessionStorage' | 'header' | CookiesAttributes | StorageAttributes | Array`
|
|
693
|
-
- _Default_: `'localStorage'`
|
|
694
|
-
- _Deskripsi_: Konfigurasi untuk menyimpan locale di sisi klien.
|
|
695
|
-
|
|
696
|
-
- **cookie**:
|
|
697
|
-
- _Deskripsi_: Menyimpan data dalam cookie, potongan kecil data yang disimpan di browser klien, dapat diakses di sisi klien dan server.
|
|
698
|
-
- _Catatan_: Untuk penyimpanan yang sesuai dengan GDPR, pastikan persetujuan pengguna yang tepat sebelum penggunaan.
|
|
699
|
-
- _Catatan_: Parameter cookie dapat disesuaikan jika diatur sebagai CookiesAttributes (`{ type: 'cookie', name: 'custom-locale', secure: true, httpOnly: false }`).
|
|
700
|
-
|
|
701
|
-
- **localStorage**:
|
|
702
|
-
- _Deskripsi_: Menyimpan data di browser tanpa tanggal kedaluwarsa, memungkinkan data bertahan antar sesi, hanya dapat diakses di sisi klien.
|
|
703
|
-
- _Catatan_: Ideal untuk menyimpan data jangka panjang tetapi perlu memperhatikan implikasi privasi dan keamanan karena sifatnya yang tidak kedaluwarsa kecuali secara eksplisit dihapus.
|
|
704
|
-
- _Catatan_: Penyimpanan locale hanya dapat diakses di sisi klien, proxy intlayer tidak akan dapat mengaksesnya.
|
|
705
|
-
- _Catatan_: Parameter penyimpanan locale dapat disesuaikan jika diatur sebagai StorageAttributes (`{ type: 'localStorage', name: 'custom-locale' }`).
|
|
706
|
-
|
|
707
|
-
- **sessionStorage**:
|
|
708
|
-
- _Deskripsi_: Menyimpan data selama durasi sesi halaman, artinya data akan dihapus setelah tab atau jendela ditutup, hanya dapat diakses di sisi klien.
|
|
709
|
-
- _Catatan_: Cocok untuk penyimpanan data sementara untuk setiap sesi.
|
|
710
|
-
- _Catatan_: Penyimpanan locale hanya dapat diakses di sisi klien, proxy intlayer tidak akan dapat mengaksesnya.
|
|
711
|
-
- _Catatan_: Parameter penyimpanan locale dapat disesuaikan jika diatur sebagai StorageAttributes (`{ type: 'sessionStorage', name: 'custom-locale' }`).
|
|
712
|
-
|
|
713
|
-
- **header**:
|
|
714
|
-
- _Deskripsi_: Memanfaatkan header HTTP untuk menyimpan atau mengirim data locale, cocok untuk penentuan bahasa di sisi server.
|
|
715
|
-
- _Catatan_: Berguna dalam panggilan API untuk menjaga konsistensi pengaturan bahasa di seluruh permintaan.
|
|
716
|
-
- _Catatan_: Header hanya dapat diakses di sisi server, sisi klien tidak akan dapat mengaksesnya.
|
|
717
|
-
- _Catatan_: Nama header dapat disesuaikan jika diatur sebagai StorageAttributes (`{ type: 'header', name: 'custom-locale' }`).
|
|
718
|
-
|
|
719
|
-
- **basePath**:
|
|
720
|
-
- _Tipe_: `string`
|
|
721
|
-
- _Default_: `''`
|
|
722
|
-
- _Deskripsi_: Jalur dasar untuk URL aplikasi.
|
|
723
|
-
- _Contoh_: `'/my-app'`
|
|
724
|
-
- _Catatan_:
|
|
725
|
-
- Jika aplikasi dihosting di `https://example.com/my-app`
|
|
726
|
-
- Jalur dasar adalah `'/my-app'`
|
|
727
|
-
- URL akan menjadi `https://example.com/my-app/en`
|
|
728
|
-
- Jika jalur dasar tidak diatur, URL akan menjadi `https://example.com/en`
|
|
729
|
-
|
|
730
|
-
- **rewrite**:
|
|
731
|
-
- _Tipe_: `Record<string, StrictModeLocaleMap<string>>`
|
|
732
|
-
- _Default_: `undefined`
|
|
733
|
-
- _Deskripsi_: Aturan penulisan ulang URL khusus yang menggantikan mode routing default untuk jalur tertentu. Memungkinkan Anda untuk mendefinisikan jalur khusus bahasa yang berbeda dari perilaku routing standar. Mendukung parameter rute dinamis menggunakan sintaks `[param]`.
|
|
734
|
-
- _Contoh_:
|
|
735
|
-
```typescript
|
|
736
|
-
routing: {
|
|
737
|
-
mode: "prefix-no-default", // Strategi fallback
|
|
738
|
-
rewrite: nextjsRewrite({
|
|
739
|
-
"/[locale]/about": {
|
|
740
|
-
en: "/[locale]/about",
|
|
741
|
-
fr: "/[locale]/a-propos",
|
|
742
|
-
},
|
|
743
|
-
"/[locale]/product/[slug]": {
|
|
744
|
-
en: "/[locale]/product/[slug]",
|
|
745
|
-
fr: "/[locale]/produit/[slug]",
|
|
746
|
-
},
|
|
747
|
-
"/[locale]/blog/[category]/[id]": {
|
|
748
|
-
en: "/[locale]/blog/[category]/[id]",
|
|
749
|
-
fr: "/[locale]/journal/[category]/[id]",
|
|
750
|
-
},
|
|
751
|
-
}),
|
|
752
|
-
}
|
|
753
|
-
```
|
|
754
|
-
- _Catatan_: Aturan penulisan ulang memiliki prioritas di atas perilaku `mode` default. Jika jalur cocok dengan aturan penulisan ulang, jalur yang dilokalisasi dari konfigurasi penulisan ulang akan digunakan alih-alih prefiks bahasa standar.
|
|
755
|
-
- _Catatan_: Parameter rute dinamis didukung menggunakan notasi kurung siku (misalnya, `[slug]`, `[id]`). Nilai parameter secara otomatis diekstrak dari URL dan diinterpolasi ke dalam jalur yang ditulis ulang.
|
|
756
|
-
- _Catatan_: Bekerja dengan aplikasi Next.js dan Vite. Middleware/proxy akan secara otomatis menulis ulang permintaan masuk untuk mencocokkan struktur rute internal.
|
|
757
|
-
- _Catatan_: Saat menghasilkan URL dengan `getLocalizedUrl()`, aturan penulisan ulang secara otomatis diterapkan jika cocok dengan jalur yang disediakan.
|
|
758
|
-
- _Referensi_: Untuk informasi lebih lanjut, lihat [Penulisan Ulang URL Kustom](https://github.com/aymericzip/intlayer/blob/main/docs/docs/id/custom_url_rewrites.md).
|
|
759
|
-
|
|
760
|
-
#### Atribut Cookie
|
|
761
|
-
|
|
762
|
-
Saat menggunakan penyimpanan cookie, Anda dapat mengonfigurasi atribut cookie tambahan:
|
|
763
|
-
|
|
764
|
-
- **name**: Nama cookie (default: `'INTLAYER_LOCALE'`)
|
|
765
|
-
- **domain**: Domain cookie (default: tidak ditentukan)
|
|
766
|
-
- **path**: Jalur cookie (default: tidak ditentukan)
|
|
767
|
-
- **secure**: Memerlukan HTTPS (default: tidak ditentukan)
|
|
768
|
-
- **httpOnly**: Flag hanya HTTP (default: tidak ditentukan)
|
|
769
|
-
- **sameSite**: Kebijakan SameSite (`'strict' | 'lax' | 'none'`)
|
|
770
|
-
- **expires**: Tanggal kedaluwarsa atau jumlah hari (default: undefined)
|
|
771
|
-
|
|
772
|
-
#### Atribut Penyimpanan Locale
|
|
773
|
-
|
|
774
|
-
Saat menggunakan localStorage atau sessionStorage:
|
|
775
|
-
|
|
776
|
-
- **type**: Tipe penyimpanan (`'localStorage' | 'sessionStorage'`)
|
|
777
|
-
- **name**: Nama kunci penyimpanan (default: `'INTLAYER_LOCALE'`)
|
|
778
|
-
|
|
779
|
-
#### Contoh Konfigurasi
|
|
780
|
-
|
|
781
|
-
Berikut beberapa contoh konfigurasi umum untuk struktur routing v7 yang baru:
|
|
782
|
-
|
|
783
|
-
**Konfigurasi Dasar (Default)**:
|
|
784
|
-
|
|
785
|
-
```typescript
|
|
786
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
787
|
-
// intlayer.config.ts
|
|
788
|
-
const config: IntlayerConfig = {
|
|
789
|
-
internationalization: {
|
|
790
|
-
locales: ["en", "fr", "es"],
|
|
791
|
-
defaultLocale: "en",
|
|
792
|
-
},
|
|
793
|
-
routing: {
|
|
794
|
-
mode: "prefix-no-default",
|
|
795
|
-
storage: "localStorage",
|
|
796
|
-
headerName: "x-intlayer-locale",
|
|
797
|
-
basePath: "",
|
|
798
|
-
},
|
|
799
|
-
};
|
|
800
|
-
|
|
801
|
-
export default config;
|
|
802
|
-
```
|
|
803
|
-
|
|
804
|
-
**Konfigurasi Sesuai GDPR**:
|
|
805
|
-
|
|
806
|
-
```typescript
|
|
807
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
808
|
-
// intlayer.config.ts
|
|
809
|
-
const config: IntlayerConfig = {
|
|
810
|
-
internationalization: {
|
|
811
|
-
locales: ["en", "fr", "es"],
|
|
812
|
-
defaultLocale: "en",
|
|
813
|
-
},
|
|
814
|
-
routing: {
|
|
815
|
-
mode: "prefix-no-default",
|
|
816
|
-
storage: [
|
|
817
|
-
{
|
|
818
|
-
type: "localStorage",
|
|
819
|
-
name: "user-locale",
|
|
820
|
-
},
|
|
821
|
-
{
|
|
822
|
-
type: "cookie",
|
|
823
|
-
name: "user-locale",
|
|
824
|
-
secure: true,
|
|
825
|
-
sameSite: "strict",
|
|
826
|
-
httpOnly: false,
|
|
827
|
-
},
|
|
828
|
-
],
|
|
829
|
-
headerName: "x-intlayer-locale",
|
|
830
|
-
basePath: "",
|
|
831
|
-
},
|
|
832
|
-
};
|
|
833
|
-
|
|
834
|
-
export default config;
|
|
835
|
-
```
|
|
836
|
-
|
|
837
|
-
**Mode Parameter Pencarian**:
|
|
838
|
-
|
|
839
|
-
```typescript
|
|
840
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
841
|
-
// intlayer.config.ts
|
|
842
|
-
const config: IntlayerConfig = {
|
|
843
|
-
internationalization: {
|
|
844
|
-
locales: ["en", "fr", "es"],
|
|
845
|
-
defaultLocale: "en",
|
|
846
|
-
},
|
|
847
|
-
routing: {
|
|
848
|
-
mode: "search-params",
|
|
849
|
-
storage: "localStorage",
|
|
850
|
-
headerName: "x-intlayer-locale",
|
|
851
|
-
basePath: "",
|
|
852
|
-
},
|
|
853
|
-
};
|
|
854
|
-
|
|
855
|
-
export default config;
|
|
856
|
-
```
|
|
857
|
-
|
|
858
|
-
**Mode Tanpa Prefix dengan Penyimpanan Kustom**:
|
|
859
|
-
|
|
860
|
-
```typescript
|
|
861
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
862
|
-
// intlayer.config.ts
|
|
863
|
-
const config: IntlayerConfig = {
|
|
864
|
-
internationalization: {
|
|
865
|
-
locales: ["en", "fr", "es"],
|
|
866
|
-
defaultLocale: "en",
|
|
867
|
-
},
|
|
868
|
-
routing: {
|
|
869
|
-
mode: "no-prefix",
|
|
870
|
-
storage: {
|
|
871
|
-
type: "sessionStorage",
|
|
872
|
-
name: "app-locale",
|
|
873
|
-
},
|
|
874
|
-
headerName: "x-custom-locale",
|
|
875
|
-
basePath: "/my-app",
|
|
876
|
-
},
|
|
877
|
-
};
|
|
878
|
-
|
|
879
|
-
export default config;
|
|
880
|
-
```
|
|
881
|
-
|
|
882
|
-
---
|
|
883
|
-
|
|
884
|
-
### Konfigurasi Konten
|
|
885
|
-
|
|
886
|
-
Pengaturan terkait penanganan konten dalam aplikasi, termasuk nama direktori, ekstensi file, dan konfigurasi turunan.
|
|
887
|
-
|
|
888
|
-
#### Properti
|
|
889
|
-
|
|
890
|
-
- **watch**:
|
|
891
|
-
- _Tipe_: `boolean`
|
|
892
|
-
- _Default_: `process.env.NODE_ENV === 'development'`
|
|
893
|
-
- _Deskripsi_: Menunjukkan apakah Intlayer harus memantau perubahan pada file deklarasi konten dalam aplikasi untuk membangun kembali kamus terkait.
|
|
894
|
-
|
|
895
|
-
- **fileExtensions**:
|
|
896
|
-
- _Tipe_: `string[]`
|
|
897
|
-
- _Default_: `['.content.ts', '.content.js', '.content.cjs', '.content.mjs', '.content.json', '.content.tsx', '.content.jsx']`
|
|
898
|
-
- _Deskripsi_: Ekstensi file yang dicari saat membangun kamus.
|
|
899
|
-
- _Contoh_: `['.data.ts', '.data.js', '.data.json']`
|
|
900
|
-
- _Catatan_: Menyesuaikan ekstensi file dapat membantu menghindari konflik.
|
|
901
|
-
|
|
902
|
-
- **contentDir**:
|
|
903
|
-
- _Tipe_: `string[]`
|
|
904
|
-
- _Default_: `['.']`
|
|
905
|
-
- _Contoh_: `['src', '../../ui-library', require.resolve("@my-package/content")]`
|
|
906
|
-
- _Deskripsi_: Jalur direktori tempat file definisi konten (`.content.*`) disimpan.
|
|
907
|
-
- _Catatan_: Ini digunakan untuk memantau file konten untuk membangun ulang kamus.
|
|
908
|
-
|
|
909
|
-
- **codeDir**:
|
|
910
|
-
- _Tipe_: `string[]`
|
|
911
|
-
- _Default_: `['.']`
|
|
912
|
-
- _Contoh_: `['src', '../../ui-library']`
|
|
913
|
-
- _Deskripsi_: Jalur direktori tempat kode disimpan, relatif terhadap direktori dasar.
|
|
914
|
-
- _Catatan_: Ini digunakan untuk memantau file kode untuk ditransformasikan (pemangkasan, optimasi). Menjaga ini terpisah dari `contentDir` dapat meningkatkan kinerja build dengan menghindari pemindaian yang tidak perlu pada file konten.
|
|
915
|
-
|
|
916
|
-
- **dictionariesDir**:
|
|
917
|
-
- _Tipe_: `string`
|
|
918
|
-
- _Default_: `'.intlayer/dictionary'`
|
|
919
|
-
- _Deskripsi_: Jalur direktori untuk menyimpan hasil sementara atau output.
|
|
920
|
-
|
|
921
|
-
- **moduleAugmentationDir**:
|
|
922
|
-
- _Tipe_: `string`
|
|
923
|
-
- _Default_: `'.intlayer/types'`
|
|
924
|
-
- _Deskripsi_: Direktori untuk augmentasi modul, memungkinkan saran IDE yang lebih baik dan pengecekan tipe.
|
|
925
|
-
- _Contoh_: `'intlayer-types'`
|
|
926
|
-
- _Catatan_: Pastikan untuk memasukkan ini dalam `tsconfig.json`.
|
|
927
|
-
|
|
928
|
-
- **unmergedDictionariesDir**:
|
|
929
|
-
- _Tipe_: `string`
|
|
930
|
-
- _Default_: `'.intlayer/unmerged_dictionary'`
|
|
931
|
-
- _Deskripsi_: Direktori untuk menyimpan kamus yang belum digabungkan.
|
|
932
|
-
- _Contoh_: `'translations'`
|
|
933
|
-
|
|
934
|
-
- **typesDir**:
|
|
935
|
-
- _Tipe_: `string`
|
|
936
|
-
- _Default_: `'types'`
|
|
937
|
-
- _Deskripsi_: Direktori untuk menyimpan tipe kamus.
|
|
938
|
-
- _Contoh_: `'intlayer-types'`
|
|
939
|
-
|
|
940
|
-
- **mainDir**:
|
|
941
|
-
- _Tipe_: `string`
|
|
942
|
-
- _Default_: `'main'`
|
|
943
|
-
- _Deskripsi_: Direktori tempat file aplikasi utama disimpan.
|
|
944
|
-
- _Contoh_: `'intlayer-main'`
|
|
945
|
-
|
|
946
|
-
- **excludedPath**:
|
|
947
|
-
- _Tipe_: `string[]`
|
|
948
|
-
- _Default_: `['**/node_modules/**', '**/dist/**', '**/build/**', '**/.intlayer/**', '**/.next/**', '**/.nuxt/**', '**/.expo/**', '**/.vercel/**', '**/.turbo/**', '**/.tanstack/**']`
|
|
949
|
-
- _Deskripsi_: Direktori yang dikecualikan dari pencarian konten.
|
|
950
|
-
- _Catatan_: Pengaturan ini belum digunakan, tetapi direncanakan untuk implementasi di masa depan.
|
|
951
|
-
|
|
952
|
-
---
|
|
953
|
-
|
|
954
|
-
### Konfigurasi Sistem
|
|
955
|
-
|
|
956
|
-
Pengaturan terkait jalur internal dan hasil output Intlayer. Pengaturan ini biasanya bersifat internal dan tidak perlu diubah oleh pengguna.
|
|
957
|
-
|
|
958
|
-
#### Properti
|
|
959
|
-
|
|
960
|
-
- **baseDir**:
|
|
961
|
-
- _Tipe_: `string`
|
|
962
|
-
- _Default_: `process.cwd()`
|
|
963
|
-
- _Deskripsi_: Direktori dasar untuk proyek.
|
|
964
|
-
- _Contoh_: `'/path/to/project'`
|
|
965
|
-
- _Catatan_: Ini digunakan untuk menyelesaikan semua direktori terkait Intlayer.
|
|
966
|
-
|
|
967
|
-
- **formatCommand**:
|
|
968
|
-
- _Tipe_: `string`
|
|
969
|
-
- _Default_: `undefined`
|
|
970
|
-
- _Deskripsi_: Perintah untuk memformat konten. Ketika intlayer menulis file .content Anda secara lokal, perintah ini akan digunakan untuk memformat konten.
|
|
971
|
-
- _Contoh_: `'npx prettier --write "{{file}}" --log-level silent'` Menggunakan Prettier
|
|
972
|
-
- _Contoh_: `'npx biome format "{{file}}" --write --log-level none'` Menggunakan Biome
|
|
973
|
-
- _Contoh_: `'npx eslint --fix "{{file}}" --quiet'` Menggunakan ESLint
|
|
974
|
-
- _Catatan_: Intlayer akan menggantikan {{file}} dengan path file yang akan diformat.
|
|
975
|
-
- _Catatan_: Jika tidak diatur, Intlayer akan mencoba mendeteksi perintah format secara otomatis dengan mencoba menyelesaikan perintah berikut: prettier, biome, eslint.
|
|
976
|
-
|
|
977
|
-
### Konfigurasi Kamus
|
|
978
|
-
|
|
979
|
-
Pengaturan yang mengontrol operasi kamus, termasuk perilaku pengisian otomatis dan pembuatan konten.
|
|
980
|
-
|
|
981
|
-
Konfigurasi kamus ini memiliki dua tujuan utama:
|
|
982
|
-
|
|
983
|
-
1. **Nilai Default**: Mendefinisikan nilai default saat membuat file deklarasi konten
|
|
984
|
-
2. **Perilaku Cadangan**: Memberikan nilai cadangan ketika bidang tertentu tidak didefinisikan, memungkinkan Anda untuk menentukan perilaku operasi kamus secara global
|
|
985
|
-
|
|
986
|
-
Untuk informasi lebih lanjut tentang file deklarasi konten dan bagaimana nilai konfigurasi diterapkan, lihat [Dokumentasi File Konten](https://github.com/aymericzip/intlayer/blob/main/docs/docs/id/dictionary/content_file.md).
|
|
987
|
-
|
|
988
|
-
#### Properti
|
|
989
|
-
|
|
990
|
-
- **fill**
|
|
991
|
-
- **description**
|
|
992
|
-
- **locale**
|
|
993
|
-
- **location**
|
|
994
|
-
- **priority**
|
|
995
|
-
- **live**
|
|
996
|
-
- **schema**
|
|
997
|
-
- **title**
|
|
998
|
-
- **tags**
|
|
999
|
-
- **version**
|
|
1000
|
-
|
|
1001
|
-
---
|
|
1002
|
-
|
|
1003
|
-
### Konfigurasi Logger
|
|
1004
|
-
|
|
1005
|
-
Pengaturan yang mengontrol logger, termasuk prefix yang digunakan.
|
|
1006
|
-
|
|
1007
|
-
#### Properti
|
|
1008
|
-
|
|
1009
|
-
- **mode**:
|
|
1010
|
-
- _Tipe_: `string`
|
|
1011
|
-
- _Default_: `default`
|
|
1012
|
-
- _Deskripsi_: Menunjukkan mode dari logger.
|
|
1013
|
-
- _Opsi_: `default`, `verbose`, `disabled`
|
|
1014
|
-
- _Contoh_: `default`
|
|
1015
|
-
- _Catatan_: Mode dari logger. Mode verbose akan mencatat lebih banyak informasi, tetapi dapat digunakan untuk tujuan debugging. Mode disabled akan menonaktifkan logger.
|
|
1016
|
-
|
|
1017
|
-
- **prefix**:
|
|
1018
|
-
- _Tipe_: `string`
|
|
1019
|
-
- _Default_: `'[intlayer] '`
|
|
1020
|
-
- _Deskripsi_: Prefix dari logger.
|
|
1021
|
-
- _Contoh_: `'[my custom prefix] '`
|
|
1022
|
-
- _Catatan_: Prefix dari logger.
|
|
1023
|
-
|
|
1024
|
-
### Konfigurasi AI
|
|
1025
|
-
|
|
1026
|
-
Pengaturan yang mengontrol fitur AI dari Intlayer, termasuk provider, model, dan API key.
|
|
1027
|
-
|
|
1028
|
-
Konfigurasi ini bersifat opsional jika Anda terdaftar di [Intlayer Dashboard](https://app.intlayer.org/project) menggunakan access key. Intlayer akan secara otomatis mengelola solusi AI yang paling efisien dan hemat biaya untuk kebutuhan Anda. Menggunakan opsi default memastikan pemeliharaan jangka panjang yang lebih baik karena Intlayer terus diperbarui untuk menggunakan model yang paling relevan.
|
|
1029
|
-
|
|
1030
|
-
Jika Anda lebih memilih menggunakan API key sendiri atau model tertentu, Anda dapat mendefinisikan konfigurasi AI kustom Anda.
|
|
1031
|
-
Konfigurasi AI ini akan digunakan secara global di seluruh lingkungan Intlayer Anda. Perintah CLI akan menggunakan pengaturan ini sebagai default untuk perintah (misalnya `fill`), serta SDK, Visual Editor, dan CMS. Anda dapat menimpa nilai default ini untuk kasus penggunaan tertentu dengan menggunakan parameter perintah.
|
|
1032
|
-
|
|
1033
|
-
Intlayer mendukung beberapa provider AI untuk fleksibilitas dan pilihan yang lebih baik. Provider yang saat ini didukung adalah:
|
|
1034
|
-
|
|
1035
|
-
- **OpenAI** (default)
|
|
1036
|
-
- **Anthropic Claude**
|
|
1037
|
-
- **Mistral AI**
|
|
1038
|
-
- **DeepSeek**
|
|
1039
|
-
- **Google Gemini**
|
|
1040
|
-
- **Meta Llama**
|
|
1041
|
-
- **Ollama**
|
|
1042
|
-
- **OpenRouter**
|
|
1043
|
-
- **Alibaba Cloud**
|
|
1044
|
-
- **Fireworks**
|
|
1045
|
-
- **Hugging Face**
|
|
1046
|
-
- **Groq**
|
|
1047
|
-
- **Amazon Bedrock**
|
|
1048
|
-
- **Google AI Studio**
|
|
1049
|
-
- **Google Vertex**
|
|
1050
|
-
- **Together.ai**
|
|
1051
|
-
- **ollama**
|
|
1052
|
-
|
|
1053
|
-
#### Properti
|
|
1054
|
-
|
|
1055
|
-
- **provider**:
|
|
1056
|
-
- _Tipe_: `string`
|
|
1057
|
-
- _Default_: `'openai'`
|
|
1058
|
-
- _Deskripsi_: Provider yang digunakan untuk fitur AI dari Intlayer.
|
|
1059
|
-
- _Opsi_: `'openai'`, `'anthropic'`, `'mistral'`, `'deepseek'`, `'gemini'`, `'ollama'`, `'openrouter'`, `'alibaba'`, `'fireworks'`, `'groq'`, `'huggingface'`, `'bedrock'`, `'googleaistudio'`, `'googlevertex'`, `'togetherai'`
|
|
1060
|
-
- _Contoh_: `'anthropic'`
|
|
1061
|
-
- _Catatan_: Penyedia yang berbeda mungkin memerlukan kunci API yang berbeda dan memiliki model harga yang berbeda.
|
|
1062
|
-
|
|
1063
|
-
- **model**:
|
|
1064
|
-
- _Tipe_: `string`
|
|
1065
|
-
- _Default_: Tidak ada
|
|
1066
|
-
- _Deskripsi_: Model yang digunakan untuk fitur AI di Intlayer.
|
|
1067
|
-
- _Contoh_: `'gpt-4o-2024-11-20'`
|
|
1068
|
-
- _Catatan_: Model spesifik yang digunakan bervariasi tergantung penyedia.
|
|
1069
|
-
|
|
1070
|
-
- **temperature**:
|
|
1071
|
-
- _Tipe_: `number`
|
|
1072
|
-
- _Default_: Tidak ada
|
|
1073
|
-
- _Deskripsi_: Temperature mengontrol tingkat keacakan respons AI.
|
|
1074
|
-
- _Contoh_: `0.1`
|
|
1075
|
-
- _Catatan_: Temperature yang lebih tinggi akan membuat AI lebih kreatif dan kurang dapat diprediksi.
|
|
1076
|
-
|
|
1077
|
-
- **apiKey**:
|
|
1078
|
-
- _Tipe_: `string`
|
|
1079
|
-
- _Default_: Tidak ada
|
|
1080
|
-
- _Deskripsi_: Kunci API Anda untuk penyedia yang dipilih.
|
|
1081
|
-
- _Contoh_: `process.env.OPENAI_API_KEY`
|
|
1082
|
-
- _Catatan_: Penting: Kunci API harus dijaga kerahasiaannya dan tidak dibagikan secara publik. Pastikan untuk menyimpannya di lokasi yang aman, seperti variabel lingkungan.
|
|
1083
|
-
|
|
1084
|
-
- **applicationContext**:
|
|
1085
|
-
- _Tipe_: `string`
|
|
1086
|
-
- _Default_: Tidak ada
|
|
1087
|
-
- _Deskripsi_: Memberikan konteks tambahan tentang aplikasi Anda kepada model AI, membantu menghasilkan terjemahan yang lebih akurat dan sesuai konteks. Ini dapat mencakup informasi tentang domain aplikasi Anda, audiens target, nada, atau terminologi khusus.
|
|
1088
|
-
|
|
1089
|
-
- **baseURL**:
|
|
1090
|
-
- _Tipe_: `string`
|
|
1091
|
-
- _Default_: Tidak ada
|
|
1092
|
-
- _Deskripsi_: URL dasar untuk API AI.
|
|
1093
|
-
- _Contoh_: `'https://api.openai.com/v1'`
|
|
1094
|
-
- _Catatan_: Dapat digunakan untuk menunjuk ke endpoint API AI lokal atau kustom.
|
|
1095
|
-
|
|
1096
|
-
- **dataSerialization**:
|
|
1097
|
-
- _Tipe_: `'json' | 'toon'`
|
|
1098
|
-
- _Default_: `'json'`
|
|
1099
|
-
- _Deskripsi_: Format serialisasi data yang digunakan untuk fitur AI Intlayer.
|
|
1100
|
-
- _Contoh_: `'toon'`
|
|
1101
|
-
- _Catatan_: `json`: Standar, andal; menggunakan lebih banyak token. `toon`: Lebih sedikit token, kurang konsisten dibandingkan JSON.
|
|
1102
|
-
|
|
1103
|
-
### Konfigurasi Build
|
|
1104
|
-
|
|
1105
|
-
Pengaturan yang mengontrol bagaimana Intlayer mengoptimalkan dan membangun internasionalisasi aplikasi Anda.
|
|
1106
|
-
|
|
1107
|
-
Opsi build berlaku untuk plugin `@intlayer/babel` dan `@intlayer/swc`.
|
|
1108
|
-
|
|
1109
|
-
> Dalam mode pengembangan, Intlayer menggunakan impor statis untuk kamus agar pengalaman pengembangan menjadi lebih sederhana.
|
|
1110
|
-
|
|
1111
|
-
> Saat dioptimalkan, Intlayer akan mengganti panggilan kamus untuk mengoptimalkan chunking, sehingga bundel akhir hanya mengimpor kamus yang benar-benar digunakan.
|
|
1112
|
-
|
|
1113
|
-
#### Properti
|
|
1114
|
-
|
|
1115
|
-
- **mode**:
|
|
1116
|
-
- _Tipe_: `'auto' | 'manual'`
|
|
1117
|
-
- _Default_: `'auto'`
|
|
1118
|
-
- _Deskripsi_: Mengontrol mode build.
|
|
1119
|
-
- _Contoh_: `'manual'`
|
|
1120
|
-
- _Catatan_: Jika 'auto', build akan diaktifkan secara otomatis saat aplikasi dibangun.
|
|
1121
|
-
- _Catatan_: Jika 'manual', build akan disetel hanya ketika perintah build dieksekusi.
|
|
1122
|
-
- _Catatan_: Dapat digunakan untuk menonaktifkan build kamus, misalnya ketika eksekusi di lingkungan Node.js harus dihindari.
|
|
1123
|
-
|
|
1124
|
-
- **optimize**:
|
|
1125
|
-
- _Tipe_: `boolean`
|
|
1126
|
-
- _Default_: `process.env.NODE_ENV === 'production'`
|
|
1127
|
-
- _Deskripsi_: Mengontrol apakah build harus dioptimalkan.
|
|
1128
|
-
- _Contoh_: `true`
|
|
1129
|
-
- _Catatan_: Saat diaktifkan, Intlayer akan mengganti semua panggilan kamus untuk mengoptimalkan chunking. Dengan begitu, bundel akhir hanya akan mengimpor kamus yang digunakan. Semua impor akan tetap sebagai impor statis untuk menghindari pemrosesan async saat memuat kamus.
|
|
1130
|
-
- _Catatan_: Intlayer akan mengganti semua panggilan `useIntlayer` dengan mode yang ditentukan oleh opsi `importMode` dan `getIntlayer` dengan `getDictionary`.
|
|
1131
|
-
- _Catatan_: Opsi ini bergantung pada plugin `@intlayer/babel` dan `@intlayer/swc`.
|
|
1132
|
-
- _Catatan_: Pastikan semua kunci dideklarasikan secara statis dalam panggilan `useIntlayer`. Contoh: `useIntlayer('navbar')`.
|
|
1133
|
-
|
|
1134
|
-
- **checkTypes**:
|
|
1135
|
-
- _Tipe_: `boolean`
|
|
1136
|
-
- _Default_: `false`
|
|
1137
|
-
- _Deskripsi_: Menunjukkan apakah build harus memeriksa tipe TypeScript dan mencatat kesalahan.
|
|
1138
|
-
- _Catatan_: Hal ini dapat memperlambat proses build.
|
|
1139
|
-
|
|
1140
|
-
- **outputFormat**:
|
|
1141
|
-
- _Tipe_: `'esm' | 'cjs'`
|
|
1142
|
-
- _Default_: `'esm'`
|
|
1143
|
-
- _Deskripsi_: Mengontrol format output dari kamus.
|
|
1144
|
-
- _Contoh_: `'cjs'`
|
|
1145
|
-
- _Catatan_: Format output dari kamus.
|
|
1146
|
-
|
|
1147
|
-
- **traversePattern**:
|
|
1148
|
-
- _Tipe_: `string[]`
|
|
1149
|
-
- _Default_: `['**\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\/node_modules/**']`
|
|
1150
|
-
- _Deskripsi_: Pola yang menentukan file mana yang harus dilalui selama optimasi.
|
|
1151
|
-
- _Contoh_: `['src/**\/*.{ts,tsx}', '../ui-library/**\/*.{ts,tsx}', '!**/node_modules/**']`
|
|
1152
|
-
- _Catatan_: Gunakan ini untuk membatasi optimasi hanya pada file kode yang relevan dan meningkatkan performa build.
|
|
1153
|
-
- _Catatan_: Opsi ini akan diabaikan jika `optimize` dinonaktifkan.
|
|
1154
|
-
- _Catatan_: Gunakan pola glob.
|
|
1155
|
-
|
|
1156
|
-
---
|
|
1157
|
-
|
|
1158
|
-
### Konfigurasi Kompiler
|
|
1159
|
-
|
|
1160
|
-
Pengaturan yang mengontrol kompiler Intlayer, yang mengekstrak kamus langsung dari komponen Anda.
|
|
1161
|
-
|
|
1162
|
-
#### Properti
|
|
1163
|
-
|
|
1164
|
-
- **enabled**:
|
|
1165
|
-
- _Tipe_: `boolean | 'build-only'`
|
|
1166
|
-
- _Default_: `true`
|
|
1167
|
-
- _Deskripsi_: Menunjukkan apakah kompiler harus diaktifkan untuk mengekstrak kamus.
|
|
1168
|
-
- _Contoh_: `'build-only'`
|
|
1169
|
-
- _Catatan_: Menyetelnya ke `'build-only'` akan melewati kompiler selama mode pengembangan untuk mempercepat waktu build. Ini hanya akan berjalan pada perintah build.
|
|
1170
|
-
|
|
1171
|
-
- **dictionaryKeyPrefix**:
|
|
1172
|
-
- _Tipe_: `string`
|
|
1173
|
-
- _Default_: `''`
|
|
1174
|
-
- _Deskripsi_: Awalan untuk kunci kamus yang diekstrak.
|
|
1175
|
-
- _Contoh_: `'my-key-'`
|
|
1176
|
-
- _Catatan_: Saat kamus diekstrak, kunci dihasilkan berdasarkan nama file. Awalan ini ditambahkan ke kunci yang dihasilkan untuk mencegah konflik.
|
|
1177
|
-
|
|
1178
|
-
- **saveComponents**:
|
|
1179
|
-
- _Tipe_: `boolean`
|
|
1180
|
-
- _Default_: `false`
|
|
1181
|
-
- _Deskripsi_: Menunjukkan apakah komponen harus disimpan setelah diubah.
|
|
1182
|
-
- _Catatan_: Jika true, kompiler akan mengganti file asli dengan file yang diubah. Dengan begitu, kompiler hanya dapat dijalankan sekali untuk mengubah aplikasi, dan kemudian dapat dihapus.
|
|
1183
|
-
|
|
1184
|
-
- **transformPattern**:
|
|
1185
|
-
- _Tipe_: `string | string[]`
|
|
1186
|
-
- _Default_: `['**/*.{ts,tsx,jsx,js,cjs,mjs,svelte,vue}', '!**/node_modules/**']`
|
|
1187
|
-
- _Deskripsi_: Pola yang menentukan file mana yang harus dilalui selama optimasi.
|
|
1188
|
-
- _Contoh_: `['src/**/*.{ts,tsx}', '!**/node_modules/**']`
|
|
1189
|
-
- _Catatan_: Gunakan ini untuk membatasi optimasi hanya pada file kode yang relevan dan meningkatkan performa build.
|
|
1190
|
-
|
|
1191
|
-
- **excludePattern**:
|
|
1192
|
-
- _Tipe_: `string | string[]`
|
|
1193
|
-
- _Default_: `['**/node_modules/**']`
|
|
1194
|
-
- _Deskripsi_: Pola yang menentukan file mana yang harus dikecualikan selama optimasi.
|
|
1195
|
-
- _Contoh_: `['**/node_modules/**', '!**/node_modules/react/**']`
|
|
1196
|
-
|
|
1197
|
-
- **output**:
|
|
1198
|
-
- _Tipe_: `FilePathPattern`
|
|
1199
|
-
- _Default_: `undefined`
|
|
1200
|
-
- _Deskripsi_: Mendefinisikan jalur file output. Menggantikan `outputDir`. Menangani variabel dinamis melalui string template atau fungsi. Variabel yang didukung: `{{fileName}}`, `{{key}}`, `{{locale}}`, `{{extension}}`, `{{componentFileName}}`, `{{componentExtension}}`, `{{format}}`, `{{componentFormat}}`, dan `{{componentDirPath}}`.
|
|
1201
|
-
- _Catatan_: Jalur yang dimulai dengan `./` diselesaikan relatif terhadap direktori komponen. Jalur yang dimulai dengan `/` diselesaikan relatif terhadap root proyek (`baseDir`).
|
|
1202
|
-
- _Catatan_: Menyertakan variabel `{{locale}}` dalam jalur akan mengaktifkan pembuatan kamus yang dipisahkan berdasarkan bahasa.
|
|
1203
|
-
- _Contoh_:
|
|
1204
|
-
- **Buat file multi-bahasa di samping komponen**:
|
|
1205
|
-
- String: `'./{{fileName}}{{extension}}'`
|
|
1206
|
-
- Fungsi: `({ fileName, extension }) => \`./${fileName}${extension}\``
|
|
1207
|
-
|
|
1208
|
-
- **Output file JSON terpusat per bahasa**:
|
|
1209
|
-
- String: `'/locales/{{locale}}/{{key}}.content.json'`
|
|
1210
|
-
- Fungsi: `({ key, locale }) => \`/locales/${locale}/${key}.content.json\``
|
|
1211
|
-
|
|
1212
|
-
- **noMetadata**:
|
|
1213
|
-
- _Tipe_: `boolean`
|
|
1214
|
-
- _Default_: `false`
|
|
1215
|
-
- _Deskripsi_: Menunjukkan apakah metadata harus disimpan dalam file. Jika benar, kompiler tidak akan menyimpan metadata kamus (kunci, pembungkus konten).
|
|
1216
|
-
- _Catatan_: Berguna jika digunakan dengan plugin `loadJSON`. Berguna untuk output JSON i18next atau ICU MessageFormat per bahasa.
|
|
1217
|
-
- _Contoh_:
|
|
1218
|
-
Jika `true` :
|
|
1219
|
-
|
|
1220
|
-
```json
|
|
1221
|
-
{
|
|
1222
|
-
"key": "value"
|
|
1223
|
-
}
|
|
1224
|
-
```
|
|
1225
|
-
|
|
1226
|
-
Jika `false`:
|
|
1227
|
-
|
|
1228
|
-
```json
|
|
1229
|
-
{
|
|
1230
|
-
"key": "value",
|
|
1231
|
-
"content": {
|
|
1232
|
-
"key": "value"
|
|
1233
|
-
}
|
|
1234
|
-
}
|
|
1235
|
-
```
|