@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/vi/configuration.md
DELETED
|
@@ -1,1263 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
createdAt: 2024-08-13
|
|
3
|
-
updatedAt: 2026-03-12
|
|
4
|
-
title: Cấu hình
|
|
5
|
-
description: Tìm hiểu cách cấu hình Intlayer cho ứng dụng của bạn. Hiểu các thiết lập và tùy chọn khác nhau để tùy chỉnh Intlayer theo nhu cầu của bạn.
|
|
6
|
-
keywords:
|
|
7
|
-
- Cấu hình
|
|
8
|
-
- Thiết lập
|
|
9
|
-
- Tùy chỉnh
|
|
10
|
-
- Intlayer
|
|
11
|
-
- Tùy chọn
|
|
12
|
-
slugs:
|
|
13
|
-
- doc
|
|
14
|
-
- concept
|
|
15
|
-
- configuration
|
|
16
|
-
history:
|
|
17
|
-
- version: 8.3.0
|
|
18
|
-
date: 2026-03-11
|
|
19
|
-
changes: Di chuyển 'baseDir' từ cấu hình 'content' sang cấu hình 'system'
|
|
20
|
-
- version: 8.2.0
|
|
21
|
-
date: 2026-03-09
|
|
22
|
-
changes: Cập nhật các tùy chọn trình biên dịch, thêm hỗ trợ 'output' và 'noMetadata'
|
|
23
|
-
- version: 8.1.7
|
|
24
|
-
date: 2026-02-25
|
|
25
|
-
changes: Cập nhật các tùy chọn trình biên dịch
|
|
26
|
-
- version: 8.0.6
|
|
27
|
-
date: 2026-02-12
|
|
28
|
-
changes: Thêm hỗ trợ cho các nhà cung cấp Open Router, Alibaba, Amazon, Google Vertex Bedrock, Fireworks, Groq, Hugging Face và Together.ai
|
|
29
|
-
- version: 8.0.5
|
|
30
|
-
date: 2026-02-06
|
|
31
|
-
changes: Thêm `dataSerialization` vào cấu hình AI
|
|
32
|
-
- version: 8.0.0
|
|
33
|
-
date: 2026-01-22
|
|
34
|
-
changes: Di chuyển cấu hình build importMode sang cấu hình từ điển.
|
|
35
|
-
- version: 8.0.0
|
|
36
|
-
date: 2026-01-18
|
|
37
|
-
changes: Tách cấu hình hệ thống khỏi cấu hình nội dung. Di chuyển các đường dẫn nội bộ sang thuộc tính `system`. Thêm `codeDir` để tách các tệp nội dung khỏi việc chuyển đổi mã.
|
|
38
|
-
- version: 8.0.0
|
|
39
|
-
date: 2026-01-18
|
|
40
|
-
changes: Thêm các tùy chọn từ điển `location` và `schema`
|
|
41
|
-
- version: 7.5.1
|
|
42
|
-
date: 2026-01-10
|
|
43
|
-
changes: Thêm hỗ trợ cho các định dạng tệp JSON5 và JSONC
|
|
44
|
-
- version: 7.5.0
|
|
45
|
-
date: 2025-12-17
|
|
46
|
-
changes: Thêm tùy chọn `buildMode`
|
|
47
|
-
- version: 7.0.0
|
|
48
|
-
date: 2025-10-25
|
|
49
|
-
changes: Thêm cấu hình `dictionary`
|
|
50
|
-
- version: 7.0.0
|
|
51
|
-
date: 2025-10-21
|
|
52
|
-
changes: Thay thế `middleware` bằng cấu hình `routing`
|
|
53
|
-
- version: 7.0.0
|
|
54
|
-
date: 2025-10-12
|
|
55
|
-
changes: Thêm tùy chọn `formatCommand`
|
|
56
|
-
- version: 6.2.0
|
|
57
|
-
date: 2025-10-12
|
|
58
|
-
changes: Cập nhật tùy chọn `excludedPath`
|
|
59
|
-
- version: 6.0.2
|
|
60
|
-
date: 2025-09-23
|
|
61
|
-
changes: Thêm tùy chọn `outputFormat`
|
|
62
|
-
- version: 6.0.0
|
|
63
|
-
date: 2025-09-21
|
|
64
|
-
changes: Loại bỏ trường `dictionaryOutput` và trường `i18nextResourcesDir`
|
|
65
|
-
- version: 6.0.0
|
|
66
|
-
date: 2025-09-16
|
|
67
|
-
changes: Thêm chế độ nhập khẩu `live`
|
|
68
|
-
- version: 6.0.0
|
|
69
|
-
date: 2025-09-04
|
|
70
|
-
changes: Thay thế trường `hotReload` bằng `liveSync` và thêm các trường `liveSyncPort` và `liveSyncURL`
|
|
71
|
-
- version: 5.6.1
|
|
72
|
-
date: 2025-07-25
|
|
73
|
-
changes: Thay thế `activateDynamicImport` bằng tùy chọn `importMode`
|
|
74
|
-
- version: 5.6.0
|
|
75
|
-
date: 2025-07-13
|
|
76
|
-
changes: Thay đổi giá trị mặc định của contentDir từ `['src']` thành `['.']`
|
|
77
|
-
- version: 5.5.11
|
|
78
|
-
date: 2025-06-29
|
|
79
|
-
changes: Thêm các lệnh `docs`
|
|
80
|
-
---
|
|
81
|
-
|
|
82
|
-
# Tài liệu Cấu hình Intlayer
|
|
83
|
-
|
|
84
|
-
## Tổng quan
|
|
85
|
-
|
|
86
|
-
Các tệp cấu hình Intlayer cho phép tùy chỉnh nhiều khía cạnh khác nhau của plugin, chẳng hạn như quốc tế hóa, middleware và xử lý nội dung. Tài liệu này cung cấp mô tả chi tiết về từng thuộc tính trong cấu hình.
|
|
87
|
-
|
|
88
|
-
---
|
|
89
|
-
|
|
90
|
-
## Mục lục
|
|
91
|
-
|
|
92
|
-
<TOC/>
|
|
93
|
-
|
|
94
|
-
---
|
|
95
|
-
|
|
96
|
-
## Hỗ trợ tệp cấu hình
|
|
97
|
-
|
|
98
|
-
Intlayer chấp nhận các định dạng tệp cấu hình JSON, JS, MJS và 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
|
-
## Ví dụ tệp cấu hình
|
|
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
|
-
baseURL: "http://localhost:3000",
|
|
348
|
-
|
|
349
|
-
/**
|
|
350
|
-
* Tuần tự hóa dữ liệu
|
|
351
|
-
*
|
|
352
|
-
* Tùy chọn:
|
|
353
|
-
* - "json": Tiêu chuẩn, đáng tin cậy; tiêu tốn nhiều token hơn.
|
|
354
|
-
* - "toon": Ít token hơn, kém nhất quán hơn JSON.
|
|
355
|
-
*
|
|
356
|
-
* Mặc định: "json"
|
|
357
|
-
*/
|
|
358
|
-
dataSerialization: "json",
|
|
359
|
-
},
|
|
360
|
-
|
|
361
|
-
/**
|
|
362
|
-
* Build and optimization settings.
|
|
363
|
-
*/
|
|
364
|
-
build: {
|
|
365
|
-
/**
|
|
366
|
-
* Build execution mode.
|
|
367
|
-
* - "auto": Automatic build during app build.
|
|
368
|
-
* - "manual": Requires explicit build command.
|
|
369
|
-
* Default: "auto"
|
|
370
|
-
*/
|
|
371
|
-
mode: "auto",
|
|
372
|
-
|
|
373
|
-
/**
|
|
374
|
-
* Whether to optimize the final bundle by pruning unused dictionaries.
|
|
375
|
-
* Default: true in production
|
|
376
|
-
*/
|
|
377
|
-
optimize: true,
|
|
378
|
-
|
|
379
|
-
/**
|
|
380
|
-
* Output format for generated dictionary files.
|
|
381
|
-
* Default: ['esm', 'cjs']
|
|
382
|
-
*/
|
|
383
|
-
outputFormat: ["esm"],
|
|
384
|
-
|
|
385
|
-
/**
|
|
386
|
-
* Indicates if the build should check TypeScript types.
|
|
387
|
-
* Default: false
|
|
388
|
-
*/
|
|
389
|
-
checkTypes: false,
|
|
390
|
-
},
|
|
391
|
-
|
|
392
|
-
/**
|
|
393
|
-
* Logger configuration.
|
|
394
|
-
*/
|
|
395
|
-
log: {
|
|
396
|
-
/**
|
|
397
|
-
* Logging level.
|
|
398
|
-
* - "default": Standard logging.
|
|
399
|
-
* - "verbose": Detailed debug logging.
|
|
400
|
-
* - "disabled": No logging.
|
|
401
|
-
* Default: "default"
|
|
402
|
-
*/
|
|
403
|
-
mode: "default",
|
|
404
|
-
|
|
405
|
-
/**
|
|
406
|
-
* Prefix for all log messages.
|
|
407
|
-
* Default: "[intlayer]"
|
|
408
|
-
*/
|
|
409
|
-
prefix: "[intlayer]",
|
|
410
|
-
},
|
|
411
|
-
|
|
412
|
-
/**
|
|
413
|
-
* System configuration (Advanced use cases)
|
|
414
|
-
*/
|
|
415
|
-
system: {
|
|
416
|
-
/**
|
|
417
|
-
* Directory for storing localization dictionaries.
|
|
418
|
-
*/
|
|
419
|
-
dictionariesDir: ".intlayer/dictionary",
|
|
420
|
-
|
|
421
|
-
/**
|
|
422
|
-
* Directory for module augmentation.
|
|
423
|
-
*/
|
|
424
|
-
moduleAugmentationDir: ".intlayer/types",
|
|
425
|
-
|
|
426
|
-
/**
|
|
427
|
-
* Directory for storing unmerged dictionaries.
|
|
428
|
-
*/
|
|
429
|
-
unmergedDictionariesDir: ".intlayer/unmerged_dictionary",
|
|
430
|
-
|
|
431
|
-
/**
|
|
432
|
-
* Directory for storing dictionary types.
|
|
433
|
-
*/
|
|
434
|
-
typesDir: ".intlayer/types",
|
|
435
|
-
|
|
436
|
-
/**
|
|
437
|
-
* Directory where main application files are stored.
|
|
438
|
-
*/
|
|
439
|
-
mainDir: ".intlayer/main",
|
|
440
|
-
|
|
441
|
-
/**
|
|
442
|
-
* Directory where the configuration files are stored.
|
|
443
|
-
*/
|
|
444
|
-
configDir: ".intlayer/config",
|
|
445
|
-
|
|
446
|
-
/**
|
|
447
|
-
* Directory where the cache files are stored.
|
|
448
|
-
*/
|
|
449
|
-
cacheDir: ".intlayer/cache",
|
|
450
|
-
},
|
|
451
|
-
|
|
452
|
-
/**
|
|
453
|
-
* Compiler configuration (Advanced use cases)
|
|
454
|
-
*/
|
|
455
|
-
compiler: {
|
|
456
|
-
/**
|
|
457
|
-
* Cho biết trình biên dịch có nên được bật hay không.
|
|
458
|
-
*
|
|
459
|
-
* - false : Vô hiệu hóa trình biên dịch.
|
|
460
|
-
* - true : Kích hoạt trình biên dịch.
|
|
461
|
-
* - "build-only" : Bỏ qua trình biên dịch trong quá trình phát triển để tăng tốc thời gian khởi động.
|
|
462
|
-
*
|
|
463
|
-
* Giá trị mặc định : false
|
|
464
|
-
*/
|
|
465
|
-
enabled: true,
|
|
466
|
-
|
|
467
|
-
/**
|
|
468
|
-
* Xác định đường dẫn tệp đầu ra. Thay thế `outputDir`.
|
|
469
|
-
*
|
|
470
|
-
* - Các đường dẫn bắt đầu bằng `./` được giải quyết tương đối so với thư mục component.
|
|
471
|
-
* - Các đường dẫn bắt đầu bằng `/` được giải quyết tương đối so với thư mục gốc của dự án (`baseDir`).
|
|
472
|
-
*
|
|
473
|
-
* - Việc bao gồm biến `{{locale}}` trong đường dẫn sẽ cho phép tạo các từ điển được tách biệt theo ngôn ngữ.
|
|
474
|
-
*
|
|
475
|
-
* Ví dụ:
|
|
476
|
-
* ```ts
|
|
477
|
-
* {
|
|
478
|
-
* // Tạo tệp .content.ts đa ngôn ngữ bên cạnh component
|
|
479
|
-
* output: ({ fileName, extension }) => `./${fileName}${extension}`,
|
|
480
|
-
*
|
|
481
|
-
* // output: './{{fileName}}{{extension}}', // Cách viết tương đương bằng template string
|
|
482
|
-
* }
|
|
483
|
-
* ```
|
|
484
|
-
*
|
|
485
|
-
* ```ts
|
|
486
|
-
* {
|
|
487
|
-
* // Tạo tệp JSON tập trung theo ngôn ngữ trong thư mục gốc của dự án
|
|
488
|
-
* output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`,
|
|
489
|
-
*
|
|
490
|
-
* // output: '/locales/{{locale}}/{{key}}.content.json', // Cách viết tương đương bằng template string
|
|
491
|
-
* }
|
|
492
|
-
* ```
|
|
493
|
-
*
|
|
494
|
-
* Danh sách biến:
|
|
495
|
-
* - `fileName`: Tên tệp.
|
|
496
|
-
* - `key`: Khóa nội dung.
|
|
497
|
-
* - `locale`: Ngôn ngữ nội dung.
|
|
498
|
-
* - `extension`: Phần mở rộng tệp.
|
|
499
|
-
* - `componentFileName`: Tên tệp component.
|
|
500
|
-
* - `componentExtension`: Phần mở rộng tệp component.
|
|
501
|
-
* - `format`: Định dạng từ điển.
|
|
502
|
-
* - `componentFormat`: Định dạng từ điển component.
|
|
503
|
-
* - `componentDirPath`: Đường dẫn thư mục component.
|
|
504
|
-
*/
|
|
505
|
-
output: ({ locale, key }) => `compiler/${locale}/${key}.json`,
|
|
506
|
-
|
|
507
|
-
/**
|
|
508
|
-
* Cho biết liệu các thành phần có nên được lưu sau khi được chuyển đổi hay không.
|
|
509
|
-
* Bằng cách đó, trình biên dịch có thể được chạy một lần duy nhất để chuyển đổi ứng dụng, và sau đó nó có thể được gỡ bỏ.
|
|
510
|
-
*/
|
|
511
|
-
saveComponents: false,
|
|
512
|
-
|
|
513
|
-
/**
|
|
514
|
-
* Chỉ chèn nội dung vào tệp đã tạo. Hữu ích cho đầu ra JSON i18next hoặc ICU MessageFormat theo từng ngôn ngữ.
|
|
515
|
-
*/
|
|
516
|
-
noMetadata: false,
|
|
517
|
-
|
|
518
|
-
/**
|
|
519
|
-
* Tiền tố khóa từ điển
|
|
520
|
-
*/
|
|
521
|
-
dictionaryKeyPrefix: "", // Thêm tiền tố tùy chọn cho các khóa từ điển được trích xuất
|
|
522
|
-
},
|
|
523
|
-
|
|
524
|
-
/**
|
|
525
|
-
* Custom schemas to validate the dictionaries content.
|
|
526
|
-
*/
|
|
527
|
-
schemas: {
|
|
528
|
-
"my-schema": z.object({
|
|
529
|
-
title: z.string(),
|
|
530
|
-
}),
|
|
531
|
-
},
|
|
532
|
-
|
|
533
|
-
/**
|
|
534
|
-
* Plugins configuration.
|
|
535
|
-
*/
|
|
536
|
-
plugins: [],
|
|
537
|
-
};
|
|
538
|
-
|
|
539
|
-
export default config;
|
|
540
|
-
````
|
|
541
|
-
|
|
542
|
-
## Tham chiếu Cấu hình
|
|
543
|
-
|
|
544
|
-
Các phần sau mô tả các thiết lập cấu hình khác nhau có sẵn cho Intlayer.
|
|
545
|
-
|
|
546
|
-
---
|
|
547
|
-
|
|
548
|
-
### Cấu hình Quốc tế hóa
|
|
549
|
-
|
|
550
|
-
Định nghĩa các thiết lập liên quan đến quốc tế hóa, bao gồm các ngôn ngữ có sẵn và ngôn ngữ mặc định cho ứng dụng.
|
|
551
|
-
|
|
552
|
-
#### Thuộc tính
|
|
553
|
-
|
|
554
|
-
- **locales**:
|
|
555
|
-
- _Kiểu_: `string[]`
|
|
556
|
-
- _Mặc định_: `['en']`
|
|
557
|
-
- _Mô tả_: Danh sách các ngôn ngữ được hỗ trợ trong ứng dụng.
|
|
558
|
-
- _Ví dụ_: `['en', 'fr', 'es']`
|
|
559
|
-
|
|
560
|
-
- **requiredLocales**:
|
|
561
|
-
- _Kiểu_: `string[]`
|
|
562
|
-
- _Mặc định_: `[]`
|
|
563
|
-
- _Mô tả_: Danh sách các ngôn ngữ bắt buộc trong ứng dụng.
|
|
564
|
-
- _Ví dụ_: `[]`
|
|
565
|
-
- _Lưu ý_: Nếu để trống, tất cả các ngôn ngữ đều bắt buộc trong chế độ `strict`.
|
|
566
|
-
- _Lưu ý_: Đảm bảo các ngôn ngữ bắt buộc cũng được định nghĩa trong trường `locales`.
|
|
567
|
-
- **strictMode**:
|
|
568
|
-
- _Kiểu_: `string`
|
|
569
|
-
- _Mặc định_: `inclusive`
|
|
570
|
-
- _Mô tả_: Đảm bảo việc triển khai nội dung quốc tế hóa mạnh mẽ bằng cách sử dụng typescript.
|
|
571
|
-
- _Lưu ý_: Nếu được đặt thành "strict", hàm dịch `t` sẽ yêu cầu mỗi ngôn ngữ được khai báo phải được định nghĩa. Nếu thiếu một ngôn ngữ hoặc nếu một ngôn ngữ không được khai báo trong cấu hình của bạn, nó sẽ báo lỗi.
|
|
572
|
-
- _Lưu ý_: Nếu được đặt thành "inclusive", hàm dịch `t` sẽ yêu cầu mỗi ngôn ngữ được khai báo phải được định nghĩa. Nếu thiếu một ngôn ngữ, nó sẽ cảnh báo. Nhưng sẽ chấp nhận nếu một ngôn ngữ không được khai báo trong cấu hình của bạn nhưng tồn tại.
|
|
573
|
-
- _Lưu ý_: Nếu được đặt thành "loose", hàm dịch `t` sẽ chấp nhận bất kỳ ngôn ngữ nào tồn tại.
|
|
574
|
-
|
|
575
|
-
- **defaultLocale**:
|
|
576
|
-
- _Kiểu_: `string`
|
|
577
|
-
- _Mặc định_: `'en'`
|
|
578
|
-
- _Mô tả_: Ngôn ngữ mặc định được sử dụng làm dự phòng nếu ngôn ngữ yêu cầu không được tìm thấy.
|
|
579
|
-
- _Ví dụ_: `'en'`
|
|
580
|
-
- _Lưu ý_: Điều này được sử dụng để xác định ngôn ngữ khi không có ngôn ngữ nào được chỉ định trong URL, cookie hoặc header.
|
|
581
|
-
|
|
582
|
-
---
|
|
583
|
-
|
|
584
|
-
### Cấu hình Trình soạn thảo
|
|
585
|
-
|
|
586
|
-
Định nghĩa các thiết lập liên quan đến trình soạn thảo tích hợp, bao gồm cổng máy chủ và trạng thái hoạt động.
|
|
587
|
-
|
|
588
|
-
#### Thuộc tính
|
|
589
|
-
|
|
590
|
-
- **applicationURL**:
|
|
591
|
-
- _Kiểu_: `string`
|
|
592
|
-
- _Mặc định_: `http://localhost:3000`
|
|
593
|
-
- _Mô tả_: URL của ứng dụng. Được sử dụng để giới hạn nguồn gốc của trình soạn thảo vì lý do bảo mật.
|
|
594
|
-
- _Ví dụ_:
|
|
595
|
-
- `'http://localhost:3000'`
|
|
596
|
-
- `'https://example.com'`
|
|
597
|
-
- `process.env.INTLAYER_EDITOR_URL`
|
|
598
|
-
- _Lưu ý_: URL của ứng dụng. Được sử dụng để giới hạn nguồn gốc của trình soạn thảo vì lý do bảo mật. Nếu được đặt thành `'*'`, trình soạn thảo có thể truy cập từ bất kỳ nguồn gốc nào.
|
|
599
|
-
|
|
600
|
-
- **port**:
|
|
601
|
-
- _Kiểu_: `number`
|
|
602
|
-
- _Mặc định_: `8000`
|
|
603
|
-
- _Mô tả_: Cổng được sử dụng bởi máy chủ trình soạn thảo trực quan.
|
|
604
|
-
|
|
605
|
-
- **editorURL**:
|
|
606
|
-
- _Kiểu_: `string`
|
|
607
|
-
- _Mặc định_: `'http://localhost:8000'`
|
|
608
|
-
- _Mô tả_: URL của máy chủ trình soạn thảo. Được sử dụng để giới hạn nguồn gốc của trình soạn thảo vì lý do bảo mật.
|
|
609
|
-
- `'http://localhost:3000'`
|
|
610
|
-
- `'https://example.com'`
|
|
611
|
-
- `process.env.INTLAYER_EDITOR_URL`
|
|
612
|
-
- _Lưu ý_: URL của máy chủ trình soạn thảo để truy cập từ ứng dụng. Được sử dụng để giới hạn các nguồn gốc có thể tương tác với ứng dụng vì lý do bảo mật. Nếu được đặt thành `'*'`, trình soạn thảo có thể truy cập từ bất kỳ nguồn gốc nào. Nên được đặt nếu cổng bị thay đổi, hoặc nếu trình soạn thảo được lưu trữ trên một miền khác.
|
|
613
|
-
|
|
614
|
-
- **cmsURL**:
|
|
615
|
-
- _Kiểu_: `string`
|
|
616
|
-
- _Mặc định_: `'https://intlayer.org'`
|
|
617
|
-
- _Mô tả_: URL của Intlayer CMS.
|
|
618
|
-
- _Ví dụ_: `'https://intlayer.org'`
|
|
619
|
-
- _Lưu ý_: URL của Intlayer CMS.
|
|
620
|
-
|
|
621
|
-
- **backendURL**:
|
|
622
|
-
- _Kiểu_: `string`
|
|
623
|
-
- _Mặc định_: `https://back.intlayer.org`
|
|
624
|
-
- _Mô tả_: URL của máy chủ backend.
|
|
625
|
-
- _Ví dụ_: `http://localhost:4000`
|
|
626
|
-
|
|
627
|
-
- **enabled**:
|
|
628
|
-
- _Kiểu_: `boolean`
|
|
629
|
-
- _Mặc định_: `true`
|
|
630
|
-
- _Mô tả_: Chỉ ra liệu ứng dụng có tương tác với trình soạn thảo trực quan hay không.
|
|
631
|
-
- _Ví dụ_: `process.env.NODE_ENV !== 'production'`
|
|
632
|
-
- _Lưu ý_: Nếu là true, trình soạn thảo sẽ có thể tương tác với ứng dụng. Nếu là false, trình soạn thảo sẽ không thể tương tác với ứng dụng. Trong mọi trường hợp, trình soạn thảo chỉ có thể được kích hoạt bởi trình soạn thảo trực quan. Việc vô hiệu hóa trình soạn thảo cho các môi trường cụ thể là một cách để tăng cường bảo mật.
|
|
633
|
-
|
|
634
|
-
- **clientId**:
|
|
635
|
-
- _Kiểu_: `string` | `undefined`
|
|
636
|
-
- _Mặc định_: `undefined`
|
|
637
|
-
- _Mô tả_: clientId và clientSecret cho phép các package của intlayer xác thực với backend sử dụng xác thực oAuth2. Một access token được sử dụng để xác thực người dùng liên quan đến dự án. Để lấy access token, truy cập https://app.intlayer.org/project và tạo một tài khoản.
|
|
638
|
-
- _Ví dụ_: `true`
|
|
639
|
-
- _Lưu ý_: Quan trọng: clientId và clientSecret cần được giữ bí mật và không được chia sẻ công khai. Vui lòng đảm bảo giữ chúng ở nơi an toàn, chẳng hạn như biến môi trường.
|
|
640
|
-
|
|
641
|
-
- **clientSecret**:
|
|
642
|
-
- _Kiểu_: `string` | `undefined`
|
|
643
|
-
- _Mặc định_: `undefined`
|
|
644
|
-
- _Mô tả_: clientId và clientSecret cho phép các package của intlayer xác thực với backend sử dụng xác thực oAuth2. Một access token được sử dụng để xác thực người dùng liên quan đến dự án. Để lấy access token, truy cập https://app.intlayer.org/project và tạo một tài khoản.
|
|
645
|
-
- _Ví dụ_: `true`
|
|
646
|
-
- _Lưu ý_: Quan trọng: clientId và clientSecret cần được giữ bí mật và không được chia sẻ công khai. Vui lòng đảm bảo giữ chúng ở nơi an toàn, chẳng hạn như biến môi trường.
|
|
647
|
-
|
|
648
|
-
- **dictionaryPriorityStrategy**:
|
|
649
|
-
- _Kiểu_: `string`
|
|
650
|
-
- _Mặc định_: `'local_first'`
|
|
651
|
-
- _Mô tả_: Chiến lược ưu tiên từ điển trong trường hợp có cả từ điển cục bộ và từ điển từ xa. Nếu được đặt thành `'distant_first'`, ứng dụng sẽ ưu tiên từ điển từ xa hơn từ điển cục bộ. Nếu được đặt thành `'local_first'`, ứng dụng sẽ ưu tiên từ điển cục bộ hơn từ điển từ xa.
|
|
652
|
-
- _Ví dụ_: `'distant_first'`
|
|
653
|
-
|
|
654
|
-
- **liveSync**:
|
|
655
|
-
- _Kiểu_: `boolean`
|
|
656
|
-
- _Mặc định_: `false`
|
|
657
|
-
- _Mô tả_: Chỉ định liệu server ứng dụng có nên tải lại nóng nội dung của ứng dụng khi phát hiện có thay đổi trên CMS / Visual Editor / Backend hay không.
|
|
658
|
-
- _Ví dụ_: `true`
|
|
659
|
-
- _Lưu ý_: Ví dụ, khi một từ điển mới được thêm hoặc cập nhật, ứng dụng sẽ cập nhật nội dung để hiển thị trên trang.
|
|
660
|
-
- _Lưu ý_: Live sync cần phải đưa nội dung của ứng dụng ra một server khác. Điều này có nghĩa là nó có thể ảnh hưởng nhẹ đến hiệu năng của ứng dụng. Để hạn chế điều này, chúng tôi khuyến nghị nên host ứng dụng và server live sync trên cùng một máy. Ngoài ra, sự kết hợp giữa live sync và `optimize` có thể tạo ra một số lượng lớn các yêu cầu đến server live sync. Tùy thuộc vào hạ tầng của bạn, chúng tôi khuyến nghị nên thử nghiệm cả hai tùy chọn và sự kết hợp của chúng.
|
|
661
|
-
|
|
662
|
-
- **liveSyncPort**:
|
|
663
|
-
- _Kiểu_: `number`
|
|
664
|
-
- _Mặc định_: `4000`
|
|
665
|
-
- _Mô tả_: Cổng của server live sync.
|
|
666
|
-
- _Ví dụ_: `4000`
|
|
667
|
-
- _Lưu ý_: Cổng của server live sync.
|
|
668
|
-
|
|
669
|
-
- **liveSyncURL**:
|
|
670
|
-
- _Kiểu_: `string`
|
|
671
|
-
- _Mặc định_: `'http://localhost:{liveSyncPort}'`
|
|
672
|
-
- _Mô tả_: URL của server live sync.
|
|
673
|
-
- _Ví dụ_: `'https://example.com'`
|
|
674
|
-
- _Lưu ý_: Mặc định trỏ tới localhost nhưng có thể thay đổi thành bất kỳ URL nào trong trường hợp server live sync từ xa.
|
|
675
|
-
|
|
676
|
-
### Cấu hình Routing
|
|
677
|
-
|
|
678
|
-
Các thiết lập kiểm soát hành vi routing, bao gồm cấu trúc URL, lưu trữ locale và xử lý middleware.
|
|
679
|
-
|
|
680
|
-
#### Thuộc tính
|
|
681
|
-
|
|
682
|
-
- **mode**:
|
|
683
|
-
- _Kiểu_: `'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'`
|
|
684
|
-
- _Mặc định_: `'prefix-no-default'`
|
|
685
|
-
- _Mô tả_: Chế độ routing URL để xử lý locale.
|
|
686
|
-
- _Ví dụ_:
|
|
687
|
-
- `'prefix-no-default'`: `/dashboard` (en) hoặc `/fr/dashboard` (fr)
|
|
688
|
-
- `'prefix-all'`: `/en/dashboard` (en) hoặc `/fr/dashboard` (fr)
|
|
689
|
-
- `'no-prefix'`: `/dashboard` (locale được xử lý bằng cách khác)
|
|
690
|
-
- `'search-params'`: `/dashboard?locale=fr`
|
|
691
|
-
- _Lưu ý_: Thiết lập này không ảnh hưởng đến quản lý cookie hoặc lưu trữ locale.
|
|
692
|
-
|
|
693
|
-
- **storage**:
|
|
694
|
-
- _Kiểu_: `false | 'cookie' | 'localStorage' | 'sessionStorage' | 'header' | CookiesAttributes | StorageAttributes | Array`
|
|
695
|
-
- _Mặc định_: `'localStorage'`
|
|
696
|
-
- _Mô tả_: Cấu hình để lưu trữ locale trên client.
|
|
697
|
-
|
|
698
|
-
- **cookie**:
|
|
699
|
-
- _Mô tả_: Lưu dữ liệu trong cookie, các mẩu dữ liệu nhỏ được lưu trên trình duyệt của client, có thể truy cập cả phía client và server.
|
|
700
|
-
- _Lưu ý_: Để tuân thủ GDPR, cần đảm bảo có sự đồng ý của người dùng trước khi sử dụng.
|
|
701
|
-
- _Lưu ý_: Các tham số cookie có thể tùy chỉnh nếu được đặt dưới dạng CookiesAttributes (`{ type: 'cookie', name: 'custom-locale', secure: true, httpOnly: false }`).
|
|
702
|
-
|
|
703
|
-
- **localStorage**:
|
|
704
|
-
- _Mô tả_: Lưu dữ liệu trong trình duyệt mà không có ngày hết hạn, cho phép dữ liệu tồn tại qua các phiên làm việc, chỉ có thể truy cập ở phía client.
|
|
705
|
-
- _Lưu ý_: Phù hợp để lưu trữ dữ liệu lâu dài nhưng cần lưu ý về các vấn đề bảo mật và quyền riêng tư do dữ liệu không hết hạn trừ khi được xóa rõ ràng.
|
|
706
|
-
- _Lưu ý_: Bộ lưu trữ locale chỉ có thể truy cập ở phía client, proxy intlayer sẽ không thể truy cập được.
|
|
707
|
-
- _Lưu ý_: Các tham số lưu trữ locale có thể tùy chỉnh nếu được đặt dưới dạng StorageAttributes (`{ type: 'localStorage', name: 'custom-locale' }`).
|
|
708
|
-
|
|
709
|
-
- **sessionStorage**:
|
|
710
|
-
- _Mô tả_: Lưu dữ liệu trong suốt phiên làm việc của trang, nghĩa là dữ liệu sẽ bị xóa khi tab hoặc cửa sổ trình duyệt đóng, chỉ có thể truy cập ở phía client.
|
|
711
|
-
- _Lưu ý_: Phù hợp để lưu trữ dữ liệu tạm thời cho mỗi phiên làm việc.
|
|
712
|
-
- _Lưu ý_: Bộ lưu trữ locale chỉ có thể truy cập ở phía client, proxy intlayer sẽ không thể truy cập được.
|
|
713
|
-
- _Lưu ý_: Các tham số lưu trữ locale có thể tùy chỉnh nếu được đặt dưới dạng StorageAttributes (`{ type: 'sessionStorage', name: 'custom-locale' }`).
|
|
714
|
-
|
|
715
|
-
- **header**:
|
|
716
|
-
- _Mô tả_: Sử dụng các header HTTP để lưu trữ hoặc truyền dữ liệu locale, phù hợp cho việc xác định ngôn ngữ phía server.
|
|
717
|
-
- _Lưu ý_: Hữu ích trong các cuộc gọi API để duy trì cài đặt ngôn ngữ nhất quán qua các yêu cầu.
|
|
718
|
-
- _Lưu ý_: Header chỉ có thể truy cập ở phía server, phía client sẽ không thể truy cập được.
|
|
719
|
-
- _Lưu ý_: Tên header có thể tùy chỉnh nếu được đặt dưới dạng StorageAttributes (`{ type: 'header', name: 'custom-locale' }`).
|
|
720
|
-
|
|
721
|
-
- **basePath**:
|
|
722
|
-
- _Kiểu_: `string`
|
|
723
|
-
- _Mặc định_: `''`
|
|
724
|
-
- _Mô tả_: Đường dẫn cơ sở cho các URL của ứng dụng.
|
|
725
|
-
- _Ví dụ_: `'/my-app'`
|
|
726
|
-
- _Lưu ý_:
|
|
727
|
-
- Nếu ứng dụng được lưu trữ tại `https://example.com/my-app`
|
|
728
|
-
- Đường dẫn cơ sở là `'/my-app'`
|
|
729
|
-
- URL sẽ là `https://example.com/my-app/en`
|
|
730
|
-
- Nếu không đặt đường dẫn cơ sở, URL sẽ là `https://example.com/en`
|
|
731
|
-
|
|
732
|
-
- **rewrite**:
|
|
733
|
-
- _Kiểu_: `Record<string, StrictModeLocaleMap<string>>`
|
|
734
|
-
- _Mặc định_: `undefined`
|
|
735
|
-
- _Mô tả_: Quy tắc viết lại URL tùy chỉnh ghi đè chế độ định tuyến mặc định cho các đường dẫn cụ thể. Cho phép bạn xác định các đường dẫn cụ thể theo ngôn ngữ khác với hành vi định tuyến tiêu chuẩn. Hỗ trợ tham số tuyến động bằng cách sử dụng cú pháp `[param]`.
|
|
736
|
-
- _Ví dụ_:
|
|
737
|
-
```typescript
|
|
738
|
-
routing: {
|
|
739
|
-
mode: "prefix-no-default", // Chiến lược dự phòng
|
|
740
|
-
rewrite: nextjsRewrite({
|
|
741
|
-
"/[locale]/about": {
|
|
742
|
-
en: "/[locale]/about",
|
|
743
|
-
fr: "/[locale]/a-propos",
|
|
744
|
-
},
|
|
745
|
-
"/[locale]/product/[slug]": {
|
|
746
|
-
en: "/[locale]/product/[slug]",
|
|
747
|
-
fr: "/[locale]/produit/[slug]",
|
|
748
|
-
},
|
|
749
|
-
"/[locale]/blog/[category]/[id]": {
|
|
750
|
-
en: "/[locale]/blog/[category]/[id]",
|
|
751
|
-
fr: "/[locale]/journal/[category]/[id]",
|
|
752
|
-
},
|
|
753
|
-
}),
|
|
754
|
-
}
|
|
755
|
-
```
|
|
756
|
-
- _Lưu ý_: Các quy tắc viết lại có ưu tiên cao hơn hành vi `mode` mặc định. Nếu một đường dẫn khớp với quy tắc viết lại, đường dẫn đã được bản địa hóa từ cấu hình viết lại sẽ được sử dụng thay vì tiền tố ngôn ngữ tiêu chuẩn.
|
|
757
|
-
- _Lưu ý_: Tham số tuyến động được hỗ trợ bằng cách sử dụng ký hiệu ngoặc vuông (ví dụ: `[slug]`, `[id]`). Giá trị tham số được tự động trích xuất từ URL và nội suy vào đường dẫn đã viết lại.
|
|
758
|
-
- _Lưu ý_: Hoạt động với ứng dụng Next.js và Vite. Middleware/proxy sẽ tự động viết lại các yêu cầu đến để khớp với cấu trúc tuyến nội bộ.
|
|
759
|
-
- _Lưu ý_: Khi tạo URL bằng `getLocalizedUrl()`, các quy tắc viết lại được áp dụng tự động nếu chúng khớp với đường dẫn được cung cấp.
|
|
760
|
-
- _Tham khảo_: Để biết thêm thông tin, xem [Viết lại URL tùy chỉnh](https://github.com/aymericzip/intlayer/blob/main/docs/docs/vi/custom_url_rewrites.md).
|
|
761
|
-
|
|
762
|
-
#### Thuộc tính Cookie
|
|
763
|
-
|
|
764
|
-
Khi sử dụng lưu trữ cookie, bạn có thể cấu hình thêm các thuộc tính cookie:
|
|
765
|
-
|
|
766
|
-
- **name**: Tên cookie (mặc định: `'INTLAYER_LOCALE'`)
|
|
767
|
-
- **domain**: Miền cookie (mặc định: không xác định)
|
|
768
|
-
- **path**: Đường dẫn cookie (mặc định: không xác định)
|
|
769
|
-
- **secure**: Yêu cầu HTTPS (mặc định: không xác định)
|
|
770
|
-
- **httpOnly**: Cờ chỉ HTTP (mặc định: không xác định)
|
|
771
|
-
- **sameSite**: Chính sách SameSite (`'strict' | 'lax' | 'none'`)
|
|
772
|
-
- **expires**: Ngày hết hạn hoặc số ngày (mặc định: không xác định)
|
|
773
|
-
|
|
774
|
-
#### Thuộc tính lưu trữ Locale
|
|
775
|
-
|
|
776
|
-
Khi sử dụng localStorage hoặc sessionStorage:
|
|
777
|
-
|
|
778
|
-
- **type**: Loại lưu trữ (`'localStorage' | 'sessionStorage'`)
|
|
779
|
-
- **name**: Tên khóa lưu trữ (mặc định: `'INTLAYER_LOCALE'`)
|
|
780
|
-
|
|
781
|
-
### Cấu hình Hệ thống
|
|
782
|
-
|
|
783
|
-
Các cài đặt liên quan đến đường dẫn nội bộ và kết quả đầu ra của Intlayer. Các cài đặt này thường mang tính nội bộ và người dùng không cần phải sửa đổi.
|
|
784
|
-
|
|
785
|
-
#### Thuộc tính
|
|
786
|
-
|
|
787
|
-
- **baseDir**:
|
|
788
|
-
- _Kiểu_: `string`
|
|
789
|
-
- _Mặc định_: `process.cwd()`
|
|
790
|
-
- _Mô tả_: Thư mục gốc của dự án.
|
|
791
|
-
- _Ví dụ_: `'/path/to/project'`
|
|
792
|
-
- _Lưu ý_: Được sử dụng để giải quyết tất cả các thư mục liên quan đến Intlayer.
|
|
793
|
-
|
|
794
|
-
- **dictionariesDir**:
|
|
795
|
-
- _Kiểu_: `string`
|
|
796
|
-
- _Mặc định_: `'.intlayer/dictionary'`
|
|
797
|
-
- _Mô tả_: Đường dẫn thư mục để lưu trữ các từ điển bản địa hóa.
|
|
798
|
-
- _Ví dụ_: `'translations'`
|
|
799
|
-
|
|
800
|
-
- **moduleAugmentationDir**:
|
|
801
|
-
- _Kiểu_: `string`
|
|
802
|
-
- _Mặc định_: `'.intlayer/types'`
|
|
803
|
-
- _Mô tả_: Thư mục dành cho việc mở rộng module, giúp IDE gợi ý và kiểm tra kiểu tốt hơn.
|
|
804
|
-
- _Ví dụ_: `'intlayer-types'`
|
|
805
|
-
- _Lưu ý_: Hãy chắc chắn bao gồm thư mục này trong `tsconfig.json`.
|
|
806
|
-
|
|
807
|
-
- **unmergedDictionariesDir**:
|
|
808
|
-
- _Kiểu_: `string`
|
|
809
|
-
- _Mặc định_: `'.intlayer/unmerged_dictionary'`
|
|
810
|
-
- _Mô tả_: Thư mục để lưu trữ các từ điển chưa được hợp nhất.
|
|
811
|
-
- _Ví dụ_: `'translations'`
|
|
812
|
-
|
|
813
|
-
- **typesDir**:
|
|
814
|
-
- _Kiểu_: `string`
|
|
815
|
-
- _Mặc định_: `'types'`
|
|
816
|
-
- _Mô tả_: Thư mục để lưu trữ các kiểu của từ điển.
|
|
817
|
-
- _Ví dụ_: `'intlayer-types'`
|
|
818
|
-
|
|
819
|
-
- **mainDir**:
|
|
820
|
-
- _Kiểu_: `string`
|
|
821
|
-
- _Mặc định_: `'main'`
|
|
822
|
-
- _Mô tả_: Thư mục nơi lưu trữ các tệp chính của ứng dụng.
|
|
823
|
-
- _Ví dụ_: `'intlayer-main'`
|
|
824
|
-
|
|
825
|
-
#### Ví dụ cấu hình
|
|
826
|
-
|
|
827
|
-
Dưới đây là một số ví dụ cấu hình phổ biến cho cấu trúc routing mới v7:
|
|
828
|
-
|
|
829
|
-
**Cấu hình cơ bản (Mặc định)**:
|
|
830
|
-
|
|
831
|
-
```typescript
|
|
832
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
833
|
-
// intlayer.config.ts
|
|
834
|
-
const config: IntlayerConfig = {
|
|
835
|
-
internationalization: {
|
|
836
|
-
locales: ["en", "fr", "es"],
|
|
837
|
-
defaultLocale: "en",
|
|
838
|
-
},
|
|
839
|
-
routing: {
|
|
840
|
-
mode: "prefix-no-default",
|
|
841
|
-
storage: "localStorage",
|
|
842
|
-
headerName: "x-intlayer-locale",
|
|
843
|
-
},
|
|
844
|
-
};
|
|
845
|
-
|
|
846
|
-
export default config;
|
|
847
|
-
```
|
|
848
|
-
|
|
849
|
-
**Cấu hình tuân thủ GDPR**:
|
|
850
|
-
|
|
851
|
-
```typescript
|
|
852
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
853
|
-
// intlayer.config.ts
|
|
854
|
-
const config: IntlayerConfig = {
|
|
855
|
-
internationalization: {
|
|
856
|
-
locales: ["en", "fr", "es"],
|
|
857
|
-
defaultLocale: "en",
|
|
858
|
-
},
|
|
859
|
-
routing: {
|
|
860
|
-
mode: "prefix-no-default",
|
|
861
|
-
storage: [
|
|
862
|
-
{
|
|
863
|
-
type: "localStorage",
|
|
864
|
-
name: "user-locale",
|
|
865
|
-
},
|
|
866
|
-
{
|
|
867
|
-
type: "cookie",
|
|
868
|
-
name: "user-locale",
|
|
869
|
-
secure: true,
|
|
870
|
-
sameSite: "strict",
|
|
871
|
-
httpOnly: false,
|
|
872
|
-
},
|
|
873
|
-
],
|
|
874
|
-
},
|
|
875
|
-
};
|
|
876
|
-
|
|
877
|
-
export default config;
|
|
878
|
-
```
|
|
879
|
-
|
|
880
|
-
**Chế độ Tham số Tìm kiếm**:
|
|
881
|
-
|
|
882
|
-
```typescript
|
|
883
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
884
|
-
// intlayer.config.ts
|
|
885
|
-
const config: IntlayerConfig = {
|
|
886
|
-
internationalization: {
|
|
887
|
-
locales: ["en", "fr", "es"],
|
|
888
|
-
defaultLocale: "en",
|
|
889
|
-
},
|
|
890
|
-
routing: {
|
|
891
|
-
mode: "search-params",
|
|
892
|
-
},
|
|
893
|
-
};
|
|
894
|
-
|
|
895
|
-
export default config;
|
|
896
|
-
```
|
|
897
|
-
|
|
898
|
-
**Chế độ Không Tiền Tố với Bộ Lưu Trữ Tùy Chỉnh**:
|
|
899
|
-
|
|
900
|
-
```typescript
|
|
901
|
-
import { Locales, type IntlayerConfig } from "intlayer";
|
|
902
|
-
// intlayer.config.ts
|
|
903
|
-
const config: IntlayerConfig = {
|
|
904
|
-
internationalization: {
|
|
905
|
-
locales: ["en", "fr", "es"],
|
|
906
|
-
defaultLocale: "en",
|
|
907
|
-
},
|
|
908
|
-
routing: {
|
|
909
|
-
mode: "no-prefix",
|
|
910
|
-
storage: {
|
|
911
|
-
type: "sessionStorage",
|
|
912
|
-
},
|
|
913
|
-
},
|
|
914
|
-
};
|
|
915
|
-
|
|
916
|
-
export default config;
|
|
917
|
-
```
|
|
918
|
-
|
|
919
|
-
---
|
|
920
|
-
|
|
921
|
-
### Cấu hình Nội dung
|
|
922
|
-
|
|
923
|
-
Các thiết lập liên quan đến việc xử lý nội dung trong ứng dụng, bao gồm tên thư mục, phần mở rộng tệp, và các cấu hình dẫn xuất.
|
|
924
|
-
|
|
925
|
-
#### Thuộc tính
|
|
926
|
-
|
|
927
|
-
- **watch**:
|
|
928
|
-
- _Kiểu_: `boolean`
|
|
929
|
-
- _Mặc định_: `process.env.NODE_ENV === 'development'`
|
|
930
|
-
- _Mô tả_: Chỉ định liệu Intlayer có nên theo dõi các thay đổi trong các tệp khai báo nội dung trong ứng dụng để xây dựng lại các từ điển liên quan hay không.
|
|
931
|
-
|
|
932
|
-
- **fileExtensions**:
|
|
933
|
-
- _Kiểu_: `string[]`
|
|
934
|
-
- _Mặc định_: `['.content.ts', '.content.js', '.content.cjs', '.content.mjs', '.content.json', '.content.tsx', '.content.jsx']`
|
|
935
|
-
- _Mô tả_: Các phần mở rộng tệp cần tìm khi xây dựng từ điển.
|
|
936
|
-
- _Ví dụ_: `['.data.ts', '.data.js', '.data.json']`
|
|
937
|
-
- _Lưu ý_: Tùy chỉnh phần mở rộng tệp có thể giúp tránh xung đột.
|
|
938
|
-
|
|
939
|
-
- **contentDir**:
|
|
940
|
-
- _Kiểu_: `string[]`
|
|
941
|
-
- _Mặc định_: `['.']`
|
|
942
|
-
- _Ví dụ_: `['src', '../../ui-library', require.resolve("@my-package/content")]`
|
|
943
|
-
- _Mô tả_: Đường dẫn thư mục nơi lưu trữ các tệp định nghĩa nội dung (`.content.*`).
|
|
944
|
-
- _Lưu ý_: Được sử dụng để theo dõi các tệp nội dung để xây dựng lại từ điển.
|
|
945
|
-
|
|
946
|
-
- **codeDir**:
|
|
947
|
-
- _Kiểu_: `string[]`
|
|
948
|
-
- _Mặc định_: `['.']`
|
|
949
|
-
- _Ví dụ_: `['src', '../../ui-library']`
|
|
950
|
-
- _Mô tả_: Đường dẫn thư mục nơi lưu trữ mã, tương đối với thư mục cơ sở.
|
|
951
|
-
- _Lưu ý_: Được sử dụng để theo dõi các tệp mã để chuyển đổi (cắt tỉa, tối ưu hóa). Giữ điều này tách biệt khỏi `contentDir` có thể cải thiện hiệu suất xây dựng bằng cách tránh quét không cần thiết các tệp nội dung.
|
|
952
|
-
|
|
953
|
-
- **dictionariesDir**:
|
|
954
|
-
- _Kiểu_: `string`
|
|
955
|
-
- _Mặc định_: `'.intlayer/dictionaries'`
|
|
956
|
-
- _Mô tả_: Đường dẫn thư mục để lưu trữ kết quả trung gian hoặc đầu ra.
|
|
957
|
-
|
|
958
|
-
- **moduleAugmentationDir**:
|
|
959
|
-
- _Kiểu_: `string`
|
|
960
|
-
- _Mặc định_: `'.intlayer/types'`
|
|
961
|
-
- _Mô tả_: Thư mục dành cho việc mở rộng module, giúp IDE gợi ý và kiểm tra kiểu tốt hơn.
|
|
962
|
-
- _Ví dụ_: `'intlayer-types'`
|
|
963
|
-
- _Lưu ý_: Hãy chắc chắn bao gồm thư mục này trong `tsconfig.json`.
|
|
964
|
-
|
|
965
|
-
- **unmergedDictionariesDir**:
|
|
966
|
-
- _Kiểu_: `string`
|
|
967
|
-
- _Mặc định_: `'.intlayer/unmerged_dictionary'`
|
|
968
|
-
- _Mô tả_: Thư mục để lưu trữ các từ điển chưa được hợp nhất.
|
|
969
|
-
- _Ví dụ_: `'translations'`
|
|
970
|
-
|
|
971
|
-
- **dictionariesDir**:
|
|
972
|
-
- _Kiểu_: `string`
|
|
973
|
-
- _Mặc định_: `'.intlayer/dictionary'`
|
|
974
|
-
- _Mô tả_: Thư mục để lưu trữ các từ điển bản địa hóa.
|
|
975
|
-
- _Ví dụ_: `'translations'`
|
|
976
|
-
|
|
977
|
-
- **typesDir**:
|
|
978
|
-
- _Kiểu_: `string`
|
|
979
|
-
- _Mặc định_: `'types'`
|
|
980
|
-
- _Mô tả_: Thư mục để lưu trữ các kiểu của từ điển.
|
|
981
|
-
- _Ví dụ_: `'intlayer-types'`
|
|
982
|
-
|
|
983
|
-
- **mainDir**:
|
|
984
|
-
- _Kiểu_: `string`
|
|
985
|
-
- _Mặc định_: `'main'`
|
|
986
|
-
- _Mô tả_: Thư mục nơi lưu trữ các tệp chính của ứng dụng.
|
|
987
|
-
- _Ví dụ_: `'intlayer-main'`
|
|
988
|
-
|
|
989
|
-
- **excludedPath**:
|
|
990
|
-
- _Kiểu_: `string[]`
|
|
991
|
-
- _Mặc định_: `['**/node_modules/**', '**/dist/**', '**/build/**', '**/.intlayer/**', '**/.next/**', '**/.nuxt/**', '**/.expo/**', '**/.vercel/**', '**/.turbo/**', '**/.tanstack/**']`
|
|
992
|
-
- _Mô tả_: Các thư mục bị loại trừ khỏi việc tìm kiếm nội dung.
|
|
993
|
-
- _Lưu ý_: Cài đặt này hiện chưa được sử dụng, nhưng dự kiến sẽ được triển khai trong tương lai.
|
|
994
|
-
|
|
995
|
-
- **formatCommand**:
|
|
996
|
-
- _Kiểu_: `string`
|
|
997
|
-
- _Mặc định_: `undefined`
|
|
998
|
-
- _Mô tả_: Lệnh để định dạng nội dung. Khi Intlayer ghi các tệp .content của bạn trên máy cục bộ, lệnh này sẽ được sử dụng để định dạng nội dung.
|
|
999
|
-
- _Ví dụ_: `'npx prettier --write "{{file}}" --log-level silent'` Sử dụng Prettier
|
|
1000
|
-
- _Ví dụ_: `'npx biome format "{{file}}" --write --log-level none'` Sử dụng Biome
|
|
1001
|
-
- _Ví dụ_: `'npx eslint --fix "{{file}}" --quiet'` Sử dụng ESLint
|
|
1002
|
-
- _Lưu ý_: Intlayer sẽ thay thế {{file}} bằng đường dẫn của tệp cần định dạng.
|
|
1003
|
-
- _Lưu ý_: Nếu không được thiết lập, Intlayer sẽ cố gắng tự động phát hiện lệnh định dạng. Bằng cách thử giải quyết các lệnh sau: prettier, biome, eslint.
|
|
1004
|
-
|
|
1005
|
-
### Cấu hình Từ điển
|
|
1006
|
-
|
|
1007
|
-
Các cài đặt kiểm soát hoạt động của từ điển, bao gồm hành vi tự động điền và tạo nội dung.
|
|
1008
|
-
|
|
1009
|
-
Cấu hình từ điển này phục vụ hai mục đích chính:
|
|
1010
|
-
|
|
1011
|
-
1. **Giá trị Mặc định**: Định nghĩa các giá trị mặc định khi tạo các tệp khai báo nội dung
|
|
1012
|
-
2. **Hành vi Dự phòng**: Cung cấp các giá trị dự phòng khi các trường cụ thể không được định nghĩa, cho phép bạn định nghĩa hành vi hoạt động của từ điển trên toàn cục
|
|
1013
|
-
|
|
1014
|
-
Để biết thêm thông tin về các tệp khai báo nội dung và cách các giá trị cấu hình được áp dụng, xem [Tài liệu Tệp Nội dung](https://github.com/aymericzip/intlayer/blob/main/docs/docs/vi/dictionary/content_file.md).
|
|
1015
|
-
|
|
1016
|
-
#### Thuộc tính
|
|
1017
|
-
|
|
1018
|
-
- **fill**
|
|
1019
|
-
- **description**
|
|
1020
|
-
- **locale**
|
|
1021
|
-
- **location**
|
|
1022
|
-
- **priority**
|
|
1023
|
-
- **live**
|
|
1024
|
-
- **schema**
|
|
1025
|
-
- **title**
|
|
1026
|
-
- **tags**
|
|
1027
|
-
- **version**
|
|
1028
|
-
|
|
1029
|
-
---
|
|
1030
|
-
|
|
1031
|
-
### Cấu hình Logger
|
|
1032
|
-
|
|
1033
|
-
Các cài đặt kiểm soát logger, bao gồm tiền tố sử dụng.
|
|
1034
|
-
|
|
1035
|
-
#### Thuộc tính
|
|
1036
|
-
|
|
1037
|
-
- **mode**:
|
|
1038
|
-
- _Kiểu_: `string`
|
|
1039
|
-
- _Mặc định_: `default`
|
|
1040
|
-
- _Mô tả_: Chỉ định chế độ của logger.
|
|
1041
|
-
- _Tùy chọn_: `default`, `verbose`, `disabled`
|
|
1042
|
-
- _Ví dụ_: `default`
|
|
1043
|
-
- _Lưu ý_: Chế độ của logger. Chế độ verbose sẽ ghi lại nhiều thông tin hơn, nhưng có thể được sử dụng cho mục đích gỡ lỗi. Chế độ disabled sẽ tắt logger.
|
|
1044
|
-
|
|
1045
|
-
- **prefix**:
|
|
1046
|
-
- _Kiểu_: `string`
|
|
1047
|
-
- _Mặc định_: `'[intlayer] '`
|
|
1048
|
-
- _Mô tả_: Tiền tố của logger.
|
|
1049
|
-
- _Ví dụ_: `'[my custom prefix] '`
|
|
1050
|
-
- _Lưu ý_: Tiền tố của logger.
|
|
1051
|
-
|
|
1052
|
-
### Cấu hình AI
|
|
1053
|
-
|
|
1054
|
-
Các cài đặt kiểm soát các tính năng AI của Intlayer, bao gồm nhà cung cấp, mô hình và khóa API.
|
|
1055
|
-
|
|
1056
|
-
Cấu hình này là tùy chọn nếu bạn đã đăng ký trên [Bảng điều khiển Intlayer](https://app.intlayer.org/project) bằng khóa truy cập. Intlayer sẽ tự động quản lý giải pháp AI hiệu quả và tiết kiệm chi phí nhất cho nhu cầu của bạn. Sử dụng các tùy chọn mặc định đảm bảo khả năng bảo trì lâu dài tốt hơn khi Intlayer liên tục cập nhật để sử dụng các mô hình phù hợp nhất.
|
|
1057
|
-
|
|
1058
|
-
Nếu bạn muốn sử dụng khóa API riêng hoặc mô hình cụ thể, bạn có thể định nghĩa cấu hình AI tùy chỉnh của mình.
|
|
1059
|
-
Cấu hình AI này sẽ được sử dụng toàn cục trong môi trường Intlayer của bạn. Các lệnh CLI sẽ sử dụng các cài đặt này làm mặc định cho các lệnh (ví dụ: `fill`), cũng như SDK, Visual Editor và CMS. Bạn có thể ghi đè các giá trị mặc định này cho các trường hợp sử dụng cụ thể bằng cách sử dụng các tham số lệnh.
|
|
1060
|
-
|
|
1061
|
-
Intlayer hỗ trợ nhiều nhà cung cấp AI để tăng tính linh hoạt và lựa chọn. Các nhà cung cấp hiện được hỗ trợ bao gồm:
|
|
1062
|
-
|
|
1063
|
-
- **OpenAI** (mặc định)
|
|
1064
|
-
- **Anthropic Claude**
|
|
1065
|
-
- **Mistral AI**
|
|
1066
|
-
- **DeepSeek**
|
|
1067
|
-
- **Google Gemini**
|
|
1068
|
-
- **Meta Llama**
|
|
1069
|
-
- **Ollama**
|
|
1070
|
-
- **OpenRouter**
|
|
1071
|
-
- **Alibaba Cloud**
|
|
1072
|
-
- **Fireworks**
|
|
1073
|
-
- **Hugging Face**
|
|
1074
|
-
- **Groq**
|
|
1075
|
-
- **Amazon Bedrock**
|
|
1076
|
-
- **Google AI Studio**
|
|
1077
|
-
- **Google Vertex**
|
|
1078
|
-
- **Together.ai**
|
|
1079
|
-
- **ollama**
|
|
1080
|
-
|
|
1081
|
-
#### Thuộc tính
|
|
1082
|
-
|
|
1083
|
-
- **provider**:
|
|
1084
|
-
- _Kiểu_: `string`
|
|
1085
|
-
- _Mặc định_: `'openai'`
|
|
1086
|
-
- _Mô tả_: Nhà cung cấp được sử dụng cho các tính năng AI của Intlayer.
|
|
1087
|
-
- _Tùy chọn_: `'openai'`, `'anthropic'`, `'mistral'`, `'deepseek'`, `'gemini'`, `'ollama'`, `'openrouter'`, `'alibaba'`, `'fireworks'`, `'groq'`, `'huggingface'`, `'bedrock'`, `'googleaistudio'`, `'googlevertex'`, `'togetherai'`
|
|
1088
|
-
- _Ví dụ_: `'anthropic'`
|
|
1089
|
-
- _Lưu ý_: Các nhà cung cấp khác nhau có thể yêu cầu các khóa API khác nhau và có các mô hình giá khác nhau.
|
|
1090
|
-
|
|
1091
|
-
- **model**:
|
|
1092
|
-
- _Kiểu_: `string`
|
|
1093
|
-
- _Mặc định_: Không có
|
|
1094
|
-
- _Mô tả_: Mô hình được sử dụng cho các tính năng AI của Intlayer.
|
|
1095
|
-
- _Ví dụ_: `'gpt-4o-2024-11-20'`
|
|
1096
|
-
- _Lưu ý_: Mô hình cụ thể được sử dụng sẽ khác nhau tùy theo nhà cung cấp.
|
|
1097
|
-
|
|
1098
|
-
- **temperature**:
|
|
1099
|
-
- _Kiểu_: `number`
|
|
1100
|
-
- _Mặc định_: Không có
|
|
1101
|
-
- _Mô tả_: Tham số temperature điều khiển độ ngẫu nhiên trong các phản hồi của AI.
|
|
1102
|
-
- _Ví dụ_: `0.1`
|
|
1103
|
-
- _Lưu ý_: Temperature cao hơn sẽ làm AI sáng tạo hơn và ít dự đoán được hơn.
|
|
1104
|
-
|
|
1105
|
-
- **apiKey**:
|
|
1106
|
-
- _Kiểu_: `string`
|
|
1107
|
-
- _Mặc định_: Không có
|
|
1108
|
-
- _Mô tả_: Khóa API của bạn cho nhà cung cấp đã chọn.
|
|
1109
|
-
- _Ví dụ_: `process.env.OPENAI_API_KEY`
|
|
1110
|
-
- _Lưu ý_: Quan trọng: Các khóa API cần được giữ bí mật và không được chia sẻ công khai. Vui lòng đảm bảo giữ chúng ở một vị trí an toàn, chẳng hạn như biến môi trường.
|
|
1111
|
-
|
|
1112
|
-
- **applicationContext**:
|
|
1113
|
-
- _Kiểu_: `string`
|
|
1114
|
-
- _Mặc định_: Không có
|
|
1115
|
-
- _Mô tả_: Cung cấp bối cảnh bổ sung về ứng dụng của bạn cho mô hình AI, giúp nó tạo ra các bản dịch chính xác hơn và phù hợp với ngữ cảnh. Điều này có thể bao gồm thông tin về lĩnh vực ứng dụng, đối tượng mục tiêu, giọng điệu hoặc thuật ngữ cụ thể của bạn.
|
|
1116
|
-
|
|
1117
|
-
- **baseURL**:
|
|
1118
|
-
- _Kiểu_: `string`
|
|
1119
|
-
- _Mặc định_: Không có
|
|
1120
|
-
- _Mô tả_: URL cơ sở cho API AI.
|
|
1121
|
-
- _Ví dụ_: `'https://api.openai.com/v1'`
|
|
1122
|
-
- _Lưu ý_: Có thể được sử dụng để trỏ đến một điểm cuối API AI cục bộ hoặc tùy chỉnh.
|
|
1123
|
-
|
|
1124
|
-
- **dataSerialization**:
|
|
1125
|
-
- _Loại_: `'json' | 'toon'`
|
|
1126
|
-
- _Mặc định_: `'json'`
|
|
1127
|
-
- _Mô tả_: Định dạng tuần tự hóa dữ liệu được sử dụng cho các tính năng AI của Intlayer.
|
|
1128
|
-
- _Ví dụ_: `'toon'`
|
|
1129
|
-
- _Ghi chú_: `json`: Tiêu chuẩn, đáng tin cậy; sử dụng nhiều token hơn. `toon`: Ít token hơn, kém nhất quán hơn JSON.
|
|
1130
|
-
|
|
1131
|
-
### Cấu hình Build
|
|
1132
|
-
|
|
1133
|
-
Các thiết lập kiểm soát cách Intlayer tối ưu hóa và xây dựng tính quốc tế hóa của ứng dụng bạn.
|
|
1134
|
-
|
|
1135
|
-
Các tùy chọn build áp dụng cho các plugin `@intlayer/babel` và `@intlayer/swc`.
|
|
1136
|
-
|
|
1137
|
-
> Ở chế độ phát triển, Intlayer sử dụng các import tĩnh cho từ điển để đơn giản hóa trải nghiệm phát triển.
|
|
1138
|
-
|
|
1139
|
-
> Khi được tối ưu hóa, Intlayer sẽ thay thế các lệnh gọi từ điển để tối ưu hóa việc chia nhỏ, do đó gói cuối cùng chỉ nhập các từ điển thực sự được sử dụng.
|
|
1140
|
-
|
|
1141
|
-
#### Thuộc tính
|
|
1142
|
-
|
|
1143
|
-
- **mode**:
|
|
1144
|
-
- _Kiểu_: `'auto' | 'manual'`
|
|
1145
|
-
- _Mặc định_: `'auto'`
|
|
1146
|
-
- _Mô tả_: Điều khiển chế độ build.
|
|
1147
|
-
- _Ví dụ_: `'manual'`
|
|
1148
|
-
- _Lưu ý_: Nếu 'auto', build sẽ được bật tự động khi ứng dụng được build.
|
|
1149
|
-
- _Lưu ý_: Nếu 'manual', build sẽ chỉ được đặt khi lệnh build được thực thi.
|
|
1150
|
-
- _Lưu ý_: Có thể được sử dụng để vô hiệu hóa build từ điển, ví dụ khi nên tránh thực thi trong môi trường Node.js.
|
|
1151
|
-
|
|
1152
|
-
- **optimize**:
|
|
1153
|
-
- _Kiểu_: `boolean`
|
|
1154
|
-
- _Mặc định_: `process.env.NODE_ENV === 'production'`
|
|
1155
|
-
- _Mô tả_: Điều khiển việc có nên tối ưu hóa quá trình build hay không.
|
|
1156
|
-
- _Ví dụ_: `true`
|
|
1157
|
-
- _Lưu ý_: Khi được bật, Intlayer sẽ thay thế tất cả các lệnh gọi từ điển để tối ưu hóa việc chia nhỏ. Bằng cách đó, gói cuối cùng sẽ chỉ nhập các từ điển được sử dụng. Tất cả các import sẽ vẫn giữ ở dạng import tĩnh để tránh xử lý bất đồng bộ khi tải các từ điển.
|
|
1158
|
-
- _Lưu ý_: Intlayer sẽ thay thế tất cả các lệnh gọi `useIntlayer` bằng chế độ được định nghĩa trong tùy chọn `importMode` và `getIntlayer` bằng `getDictionary`.
|
|
1159
|
-
- _Lưu ý_: Tùy chọn này dựa vào các plugin `@intlayer/babel` và `@intlayer/swc`.
|
|
1160
|
-
- _Lưu ý_: Đảm bảo tất cả các khóa được khai báo tĩnh trong các lệnh gọi `useIntlayer`. Ví dụ: `useIntlayer('navbar')`.
|
|
1161
|
-
|
|
1162
|
-
- **checkTypes**:
|
|
1163
|
-
- _Loại_: `boolean`
|
|
1164
|
-
- _Mặc định_: `false`
|
|
1165
|
-
- _Mô tả_: Cho biết liệu quá trình xây dựng có nên kiểm tra các kiểu TypeScript và ghi lại lỗi hay không.
|
|
1166
|
-
- _Ghi chú_: Điều này có thể làm chậm quá trình xây dựng.
|
|
1167
|
-
|
|
1168
|
-
- **outputFormat**:
|
|
1169
|
-
- _Kiểu_: `'esm' | 'cjs'`
|
|
1170
|
-
- _Mặc định_: `'esm'`
|
|
1171
|
-
- _Mô tả_: Điều khiển định dạng đầu ra của các từ điển.
|
|
1172
|
-
- _Ví dụ_: `'cjs'`
|
|
1173
|
-
- _Lưu ý_: Định dạng đầu ra của các từ điển.
|
|
1174
|
-
|
|
1175
|
-
- **traversePattern**:
|
|
1176
|
-
- _Kiểu_: `string[]`
|
|
1177
|
-
- _Mặc định_: `['**\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\/node_modules/**']`
|
|
1178
|
-
- _Mô tả_: Các mẫu định nghĩa những tệp nào sẽ được duyệt trong quá trình tối ưu hóa.
|
|
1179
|
-
- _Ví dụ_: `['src/**\/*.{ts,tsx}', '../ui-library/**\/*.{ts,tsx}', '!**/node_modules/**']`
|
|
1180
|
-
- _Lưu ý_: Sử dụng để giới hạn tối ưu hóa chỉ cho các tệp mã liên quan và cải thiện hiệu suất xây dựng.
|
|
1181
|
-
- _Lưu ý_: Tùy chọn này sẽ bị bỏ qua nếu `optimize` bị vô hiệu hóa.
|
|
1182
|
-
- _Lưu ý_: Sử dụng mẫu glob.
|
|
1183
|
-
|
|
1184
|
-
---
|
|
1185
|
-
|
|
1186
|
-
### Cấu hình Trình biên dịch
|
|
1187
|
-
|
|
1188
|
-
Các cài đặt kiểm soát trình biên dịch Intlayer, trình biên dịch này sẽ trích xuất các từ điển trực tiếp từ các thành phần của bạn.
|
|
1189
|
-
|
|
1190
|
-
#### Thuộc tính
|
|
1191
|
-
|
|
1192
|
-
- **enabled**:
|
|
1193
|
-
- _Kiểu_: `boolean | 'build-only'`
|
|
1194
|
-
- _Mặc định_: `true`
|
|
1195
|
-
- _Mô tả_: Cho biết liệu trình biên dịch có nên được bật để trích xuất từ điển hay không.
|
|
1196
|
-
- _Ví dụ_: `'build-only'`
|
|
1197
|
-
- _Lưu ý_: Đặt thành `'build-only'` sẽ bỏ qua trình biên dịch trong chế độ phát triển để tăng tốc thời gian khởi động. Nó sẽ chỉ chạy trên các lệnh build.
|
|
1198
|
-
|
|
1199
|
-
- **dictionaryKeyPrefix**:
|
|
1200
|
-
- _Kiểu_: `string`
|
|
1201
|
-
- _Mặc định_: `''`
|
|
1202
|
-
- _Mô tả_: Tiền tố cho các khóa từ điển được trích xuất.
|
|
1203
|
-
- _Ví dụ_: `'my-key-'`
|
|
1204
|
-
- _Lưu ý_: Khi từ điển được trích xuất, khóa được tạo dựa trên tên tệp. Tiền tố này được thêm vào khóa đã tạo để ngăn chặn xung đột.
|
|
1205
|
-
|
|
1206
|
-
- **saveComponents**:
|
|
1207
|
-
- _Kiểu_: `boolean`
|
|
1208
|
-
- _Mặc định_: `false`
|
|
1209
|
-
- _Mô tả_: Cho biết liệu các thành phần có nên được lưu sau khi được chuyển đổi hay không.
|
|
1210
|
-
- _Lưu ý_: Nếu đúng (true), trình biên dịch sẽ thay thế các tệp gốc bằng các tệp đã chuyển đổi. Bằng cách đó, trình biên dịch chỉ có thể được chạy một lần để chuyển đổi ứng dụng, sau đó có thể được gỡ bỏ.
|
|
1211
|
-
|
|
1212
|
-
- **transformPattern**:
|
|
1213
|
-
- _Kiểu_: `string | string[]`
|
|
1214
|
-
- _Mặc định_: `['**/*.{ts,tsx,jsx,js,cjs,mjs,svelte,vue}', '!**/node_modules/**']`
|
|
1215
|
-
- _Mô tả_: Các mẫu xác định những tệp nào akan được duyệt qua trong quá trình tối ưu hóa.
|
|
1216
|
-
- _Ví dụ_: `['src/**/*.{ts,tsx}', '!**/node_modules/**']`
|
|
1217
|
-
- _Lưu ý_: Sử dụng điều này để giới hạn tối ưu hóa cho các tệp mã liên quan và cải thiện hiệu suất xây dựng.
|
|
1218
|
-
|
|
1219
|
-
- **excludePattern**:
|
|
1220
|
-
- _Kiểu_: `string | string[]`
|
|
1221
|
-
- _Mặc định_: `['**/node_modules/**']`
|
|
1222
|
-
- _Mô tả_: Các mẫu xác định những tệp nào sẽ bị loại trừ trong quá trình tối ưu hóa.
|
|
1223
|
-
- _Ví dụ_: `['**/node_modules/**', '!**/node_modules/react/**']`
|
|
1224
|
-
|
|
1225
|
-
- **output**:
|
|
1226
|
-
- _Kiểu_: `FilePathPattern`
|
|
1227
|
-
- _Mặc định_: `undefined`
|
|
1228
|
-
- _Mô tả_: Xác định đường dẫn tệp đầu ra. Thay thế `outputDir`. Hỗ trợ các biến động thông qua template string hoặc hàm. Các biến được hỗ trợ: `{{fileName}}`, `{{key}}`, `{{locale}}`, `{{extension}}`, `{{componentFileName}}`, `{{componentExtension}}`, `{{format}}`, `{{componentFormat}}`, và `{{componentDirPath}}`.
|
|
1229
|
-
- _Lưu ý_: Các đường dẫn bắt đầu bằng `./` được giải quyết tương đối so với thư mục component. Các đường dẫn bắt đầu bằng `/` được giải quyết tương đối so với thư mục gốc của dự án (`baseDir`).
|
|
1230
|
-
- _Lưu ý_: Việc bao gồm biến `{{locale}}` trong đường dẫn sẽ cho phép tạo các từ điển được tách biệt theo ngôn ngữ.
|
|
1231
|
-
- _Ví dụ_:
|
|
1232
|
-
- **Tạo các tệp đa ngôn ngữ bên cạnh component**:
|
|
1233
|
-
- Chuỗi: `'./{{fileName}}{{extension}}'`
|
|
1234
|
-
- Hàm: `({ fileName, extension }) => \`./${fileName}${extension}\``
|
|
1235
|
-
|
|
1236
|
-
- **Xuất các tệp JSON tập trung cho mỗi ngôn ngữ**:
|
|
1237
|
-
- Chuỗi: `'/locales/{{locale}}/{{key}}.content.json'`
|
|
1238
|
-
- Hàm: `({ key, locale }) => \`/locales/${locale}/${key}.content.json\``
|
|
1239
|
-
|
|
1240
|
-
- **noMetadata**:
|
|
1241
|
-
- _Kiểu_: `boolean`
|
|
1242
|
-
- _Mặc định_: `false`
|
|
1243
|
-
- _Mô tả_: Cho biết liệu siêu dữ liệu có nên được lưu trong tệp hay không. Nếu true, trình biên dịch sẽ không lưu siêu dữ liệu của từ điển (khóa, trình bao bọc nội dung). Hữu ích cho đầu ra JSON i18next hoặc ICU MessageFormat cho mỗi ngôn ngữ.
|
|
1244
|
-
- _Ghi chú_: Hữu ích nếu được sử dụng với plugin `loadJSON`.
|
|
1245
|
-
- _Ví dụ_:
|
|
1246
|
-
Nếu `true` :
|
|
1247
|
-
|
|
1248
|
-
```json
|
|
1249
|
-
{
|
|
1250
|
-
"key": "value"
|
|
1251
|
-
}
|
|
1252
|
-
```
|
|
1253
|
-
|
|
1254
|
-
Nếu `false`:
|
|
1255
|
-
|
|
1256
|
-
```json
|
|
1257
|
-
{
|
|
1258
|
-
"key": "value",
|
|
1259
|
-
"content": {
|
|
1260
|
-
"key": "value"
|
|
1261
|
-
}
|
|
1262
|
-
}
|
|
1263
|
-
```
|