@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.
Files changed (56) hide show
  1. package/blog/en/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  2. package/blog/en-GB/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  3. package/blog/es/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  4. package/blog/id/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  5. package/blog/it/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  6. package/blog/ja/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  7. package/blog/ko/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  8. package/blog/uk/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  9. package/blog/vi/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  10. package/blog/zh/next-i18next_vs_next-intl_vs_intlayer.md +1 -3
  11. package/dist/cjs/generated/docs.entry.cjs +20 -0
  12. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  13. package/dist/esm/generated/docs.entry.mjs +20 -0
  14. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  15. package/dist/types/generated/docs.entry.d.ts +1 -0
  16. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  17. package/docs/ar/intlayer_with_storybook.md +521 -0
  18. package/docs/bn/intlayer_with_hono.md +428 -0
  19. package/docs/de/intlayer_with_storybook.md +521 -0
  20. package/docs/en/configuration.md +160 -508
  21. package/docs/en/intlayer_with_storybook.md +521 -0
  22. package/docs/en-GB/intlayer_with_storybook.md +521 -0
  23. package/docs/es/configuration.md +387 -754
  24. package/docs/es/intlayer_with_storybook.md +521 -0
  25. package/docs/fr/configuration.md +384 -757
  26. package/docs/fr/intlayer_with_storybook.md +521 -0
  27. package/docs/hi/intlayer_with_storybook.md +521 -0
  28. package/docs/id/intlayer_with_storybook.md +521 -0
  29. package/docs/it/intlayer_with_storybook.md +521 -0
  30. package/docs/ja/intlayer_with_storybook.md +521 -0
  31. package/docs/ko/intlayer_with_storybook.md +521 -0
  32. package/docs/pl/intlayer_with_storybook.md +521 -0
  33. package/docs/pt/intlayer_with_storybook.md +521 -0
  34. package/docs/ru/intlayer_with_storybook.md +521 -0
  35. package/docs/tr/intlayer_with_storybook.md +521 -0
  36. package/docs/uk/intlayer_with_storybook.md +521 -0
  37. package/docs/ur/intlayer_with_hono.md +428 -0
  38. package/docs/vi/intlayer_with_storybook.md +521 -0
  39. package/docs/zh/intlayer_with_storybook.md +521 -0
  40. package/package.json +6 -6
  41. package/src/generated/docs.entry.ts +20 -0
  42. package/docs/ar/configuration.md +0 -1124
  43. package/docs/de/configuration.md +0 -1296
  44. package/docs/en-GB/configuration.md +0 -1123
  45. package/docs/hi/configuration.md +0 -1118
  46. package/docs/id/configuration.md +0 -1235
  47. package/docs/it/configuration.md +0 -1301
  48. package/docs/ja/configuration.md +0 -1121
  49. package/docs/ko/configuration.md +0 -1121
  50. package/docs/pl/configuration.md +0 -1226
  51. package/docs/pt/configuration.md +0 -1293
  52. package/docs/ru/configuration.md +0 -1112
  53. package/docs/tr/configuration.md +0 -1114
  54. package/docs/uk/configuration.md +0 -1241
  55. package/docs/vi/configuration.md +0 -1263
  56. package/docs/zh/configuration.md +0 -1115
@@ -1,1241 +0,0 @@
1
- ---
2
- createdAt: 2024-08-13
3
- updatedAt: 2026-03-12
4
- title: Конфігурація
5
- description: Дізнайтеся, як налаштувати Intlayer для вашого застосунку. Зрозумійте різні параметри та опції, доступні для налаштування Intlayer відповідно до ваших потреб.
6
- keywords:
7
- - Конфігурація
8
- - Налаштування
9
- - Кастомізація
10
- - Intlayer
11
- - Опції
12
- slugs:
13
- - doc
14
- - concept
15
- - configuration
16
- history:
17
- - version: 8.3.0
18
- date: 2026-03-11
19
- changes: Перемістити 'baseDir' з конфігурації 'content' до конфігурації 'system'
20
- - version: 8.2.0
21
- date: 2026-03-09
22
- changes: Оновлення опцій компілятора, додавання підтримки 'output' та 'noMetadata'
23
- - version: 8.1.7
24
- date: 2026-02-25
25
- changes: Оновлення опцій компілятора
26
- - version: 8.0.6
27
- date: 2026-02-12
28
- changes: Додано підтримку провайдерів Open Router, Alibaba, Amazon, Google Vertex Bedrock, Fireworks, Groq, Hugging Face та Together.ai
29
- - version: 8.0.5
30
- date: 2026-02-06
31
- changes: Додано `dataSerialization` до конфігурації AI
32
- - version: 8.0.0
33
- date: 2026-01-22
34
- changes: Перемістити конфігурацію збірки importMode до конфігурації словника.
35
- - version: 8.0.0
36
- date: 2026-01-18
37
- changes: Розділити конфігурацію системи від конфігурації контенту. Перемістити внутрішні шляхи до властивості `system`. Додати `codeDir` для розділення файлів контенту та перетворення коду.
38
- - version: 8.0.0
39
- date: 2026-01-18
40
- changes: Додано опції словника `location` та `schema`
41
- - version: 7.5.1
42
- date: 2026-01-10
43
- changes: Додано підтримку форматів файлів JSON5 та JSONC
44
- - version: 7.5.0
45
- date: 2025-12-17
46
- changes: Додано опцію `buildMode`
47
- - version: 7.0.0
48
- date: 2025-10-25
49
- changes: Додано конфігурацію `dictionary`
50
- - version: 7.0.0
51
- date: 2025-10-21
52
- changes: Замінено `middleware` на конфігурацію `routing`
53
- - version: 7.0.0
54
- date: 2025-10-12
55
- changes: Додано опцію `formatCommand`
56
- - version: 6.2.0
57
- date: 2025-10-12
58
- changes: Оновлено опцію `excludedPath`
59
- - version: 6.0.2
60
- date: 2025-09-23
61
- changes: Додано опцію `outputFormat`
62
- - version: 6.0.0
63
- date: 2025-09-21
64
- changes: Вилучено поле `dictionaryOutput` та поле `i18nextResourcesDir`
65
- - version: 6.0.0
66
- date: 2025-09-16
67
- changes: Додано режим імпорту `live`
68
- - version: 6.0.0
69
- date: 2025-09-04
70
- changes: Замінено поле `hotReload` на `liveSync` та додано поля `liveSyncPort` і `liveSyncURL`
71
- - version: 5.6.1
72
- date: 2025-07-25
73
- changes: Замінено `activateDynamicImport` опцією `importMode`
74
- - version: 5.6.0
75
- date: 2025-07-13
76
- changes: Змінено значення за замовчуванням для contentDir з `['src']` на `['.']`
77
- - version: 5.5.11
78
- date: 2025-06-29
79
- changes: Додано команди `docs`
80
- ---
81
-
82
- # Документація конфігурації Intlayer
83
-
84
- ## Огляд
85
-
86
- Файли конфігурації Intlayer дозволяють налаштовувати різні аспекти плагіна, такі як інтернаціоналізація, middleware та обробка контенту. У цьому документі наведено детальний опис кожної властивості конфігурації.
87
-
88
- ---
89
-
90
- ## Зміст
91
-
92
- <TOC/>
93
-
94
- ---
95
-
96
- ## Підтримувані формати файлів конфігурації
97
-
98
- Intlayer підтримує формати файлів конфігурації JSON, JS, MJS та 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
- ## Приклад файлу конфігурації
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
- * Серіалізація даних
351
- *
352
- * Опції:
353
- * - "json": Стандартний, надійний; використовує більше токенів.
354
- * - "toon": Менше токенів, менш послідовний, ніж JSON.
355
- *
356
- * За замовчуванням: "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
- * Вказує, чи має бути увімкнено компілятор.
458
- *
459
- * - false : Вимкнути компілятор.
460
- * - true : Увімкнути компілятор.
461
- * - "build-only" : Пропустити компілятор під час розробки для прискорення запуску.
462
- *
463
- * Значення за замовчуванням : false
464
- */
465
- enabled: true,
466
-
467
- /**
468
- * Визначає шлях до вихідних файлів. Замінює `outputDir`.
469
- *
470
- * - Шляхи, що починаються з `./`, розв'язуються відносно каталогу компонента.
471
- * - Шляхи, що починаються з `/`, розв'язуються відносно кореня проєкту (`baseDir`).
472
- *
473
- * - Включення змінної `{{locale}}` у шлях дозволить генерувати словники, розділені за локалями.
474
- *
475
- * Приклади:
476
- * ```ts
477
- * {
478
- * // Створює багатомовні файли .content.ts поруч із компонентом
479
- * output: ({ fileName, extension }) => `./${fileName}${extension}`,
480
- *
481
- * // output: './{{fileName}}{{extension}}', // Еквівалент з використанням рядкового шаблону
482
- * }
483
- * ```
484
- *
485
- * ```ts
486
- * {
487
- * // Створює централізовані JSON-файли за локалями в корені проєкту
488
- * output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`,
489
- *
490
- * // output: '/locales/{{locale}}/{{key}}.content.json', // Еквівалент з використанням рядкового шаблону
491
- * }
492
- * ```
493
- *
494
- * Список змінних:
495
- * - `fileName`: Назва файлу.
496
- * - `key`: Ключ контенту.
497
- * - `locale`: Локаль контенту.
498
- * - `extension`: Розширення файлу.
499
- * - `componentFileName`: Назва файлу компонента.
500
- * - `componentExtension`: Розширення файлу компонента.
501
- * - `format`: Формат словника.
502
- * - `componentFormat`: Формат словника компонента.
503
- * - `componentDirPath`: Шлях до каталогу компонента.
504
- */
505
- output: ({ locale, key }) => `compiler/${locale}/${key}.json`,
506
-
507
- /**
508
- * Вказує, чи мають компоненти зберігатися після трансформації.
509
- * Таким чином компілятор можна запустити лише один раз для трансформації додатка, а потім видалити.
510
- */
511
- saveComponents: false,
512
-
513
- /**
514
- * Вставляти лише вміст у згенерований файл. Корисно для JSON-виводів i18next або ICU MessageFormat для кожної локалі.
515
- */
516
- noMetadata: false,
517
-
518
- /**
519
- * Префікс ключа словника
520
- */
521
- dictionaryKeyPrefix: "", // Додайте необов'язковий префікс для витягнутих ключів словника
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
- ## Довідник конфігурації
543
-
544
- Нижченаведені розділи описують різні параметри конфігурації, доступні в Intlayer.
545
-
546
- ---
547
-
548
- ### Налаштування інтернаціоналізації
549
-
550
- Визначає параметри, пов'язані з інтернаціоналізацією, включно з доступними локалями та локаллю за замовчуванням для застосунку.
551
-
552
- #### Властивості
553
-
554
- - **locales**:
555
- - _Тип_: `string[]`
556
- - _За замовчуванням_: `['en']`
557
- - _Опис_: Список локалей, які підтримуються в застосунку.
558
- - _Приклад_: `['en', 'fr', 'es']`
559
-
560
- - **requiredLocales**:
561
- - _Тип_: `string[]`
562
- - _За замовчуванням_: `[]`
563
- - _Опис_: Перелік обов'язкових локалей у застосунку.
564
- - _Приклад_: `[]`
565
- - _Примітка_: Якщо порожній, усі локалі є обов'язковими в режимі `strict`.
566
- - _Примітка_: Переконайтеся, що обов'язкові локалі також визначені в полі `locales`.
567
- - **strictMode**:
568
- - _Тип_: `string`
569
- - _Типово_: `inclusive`
570
- - _Опис_: Забезпечує суворі реалізації інтернаціоналізованого контенту з використанням TypeScript.
571
- - _Примітка_: Якщо встановлено "strict", функція перекладу `t` вимагатиме, щоб кожна оголошена локаль була визначена. Якщо якась локаль відсутня або не зазначена в конфігурації, буде викинута помилка.
572
- - _Примітка_: Якщо встановлено "inclusive", функція перекладу `t` вимагатиме, щоб кожна оголошена locale була визначена. Якщо одна locale відсутня, буде виведено попередження. Проте функція прийме locale, яка не оголошена у вашій конфігурації, але існує.
573
- - _Примітка_: Якщо встановлено "loose", функція перекладу `t` прийматиме будь-яку наявну locale.
574
-
575
- - **defaultLocale**:
576
- - _Тип_: `string`
577
- - _Типово_: `'en'`
578
- - _Опис_: Локаль за замовчуванням, яка використовується як fallback, якщо запитувана локаль не знайдена.
579
- - _Приклад_: `'en'`
580
- - _Примітка_: Використовується для визначення локалі, коли вона не вказана в URL, cookie або заголовку.
581
-
582
- ---
583
-
584
- ### Editor Configuration
585
-
586
- Визначає налаштування, пов'язані з інтегрованим редактором, включно з портом сервера та статусом активності.
587
-
588
- #### Properties
589
-
590
- - **applicationURL**:
591
- - _Тип_: `string`
592
- - _За замовчуванням_: `http://localhost:3000`
593
- - _Опис_: URL додатка. Використовується для обмеження origin редактора з міркувань безпеки.
594
- - _Приклад_:
595
- - `'http://localhost:3000'`
596
- - `'https://example.com'`
597
- - `process.env.INTLAYER_EDITOR_URL`
598
- - _Примітка_: URL додатка. Використовується для обмеження origin редактора з міркувань безпеки. Якщо встановлено в `'*'`, редактор доступний з будь-якого origin.
599
-
600
- - **port**:
601
- - _Тип_: `number`
602
- - _За замовчуванням_: `8000`
603
- - _Опис_: Порт, який використовується сервером візуального редактора.
604
-
605
- - **editorURL**:
606
- - _Тип_: `string`
607
- - _За замовчуванням_: `'http://localhost:8000'`
608
- - _Опис_: URL сервера редактора. Використовується для обмеження origin редактора з міркувань безпеки.
609
- - `'http://localhost:3000'`
610
- - `'https://example.com'`
611
- - `process.env.INTLAYER_EDITOR_URL`
612
- - _Примітка_: URL сервера редактора, до якого звертається додаток. Використовується для обмеження origins, які можуть взаємодіяти з додатком з міркувань безпеки. Якщо встановлено `'*'`, редактор доступний з будь-якого origin. Має бути вказаний, якщо змінено порт або якщо редактор розміщено на іншому домені.
613
-
614
- - **cmsURL**:
615
- - _Тип_: `string`
616
- - _Типово_: `'https://intlayer.org'`
617
- - _Опис_: URL Intlayer CMS.
618
- - _Приклад_: `'https://intlayer.org'`
619
- - _Примітка_: URL Intlayer CMS.
620
-
621
- - **backendURL**:
622
- - _Тип_: `string`
623
- - _Типово_: `https://back.intlayer.org`
624
- - _Опис_: URL backend-сервера.
625
- - _Приклад_: `http://localhost:4000`
626
-
627
- - **enabled**:
628
- - _Тип_: `boolean`
629
- - _За замовчуванням_: `true`
630
- - _Опис_: Вказує, чи додаток взаємодіє з візуальним редактором.
631
- - _Приклад_: `process.env.NODE_ENV !== 'production'`
632
- - _Примітка_: Якщо `true`, редактор зможе взаємодіяти з додатком. Якщо `false`, редактор не зможе взаємодіяти з додатком. У будь-якому випадку редактор може бути ввімкнений лише візуальним редактором. Вимкнення редактора для окремих середовищ, спосіб підвищити безпеку.
633
-
634
- - **clientId**:
635
- - _Тип_: `string` | `undefined`
636
- - _За замовчуванням_: `undefined`
637
- - _Опис_: clientId і clientSecret дозволяють пакетам intlayer автентифікуватися з бекендом за допомогою автентифікації oAuth2. Access token використовується для автентифікації користувача, пов’язаного з проєктом. Щоб отримати access token, перейдіть на https://app.intlayer.org/project та створіть обліковий запис.
638
- - _Приклад_: `true`
639
- - _Примітка_: Важливо: clientId та clientSecret мають зберігатися в секреті і не розголошуватися публічно. Переконайтеся, що вони зберігаються у безпечному місці, наприклад у змінних оточення.
640
-
641
- - **clientSecret**:
642
- - _Тип_: `string` | `undefined`
643
- - _Типово_: `undefined`
644
- - _Опис_: clientId та clientSecret дозволяють пакетам intlayer автентифікуватися з бекендом за допомогою oAuth2. Токен доступу використовується для автентифікації користувача, пов’язаного з проєктом. Щоб отримати токен доступу, перейдіть на https://app.intlayer.org/project і створіть обліковий запис.
645
- - _Приклад_: `true`
646
- - _Примітка_: Важливо: clientId та clientSecret слід зберігати в таємниці й не розголошувати публічно. Переконайтеся, що зберігаєте їх у безпечному місці, наприклад у environment variables.
647
-
648
- - **dictionaryPriorityStrategy**:
649
- - _Тип_: `string`
650
- - _Типово_: `'local_first'`
651
- - _Опис_: Стратегія пріоритету словників у разі наявності як локальних, так і віддалених словників. Якщо встановлено `'distant_first'`, застосунок віддаватиме пріоритет віддаленим словникам над локальними. Якщо встановлено `'local_first'`, застосунок віддаватиме пріоритет локальним словникам над віддаленими.
652
- - _Приклад_: `'distant_first'`
653
-
654
- - **liveSync**:
655
- - _Тип_: `boolean`
656
- - _Типово_: `false`
657
- - _Опис_: Вказує, чи має сервер застосунку виконувати hot reload контенту застосунку при виявленні змін у CMS / Visual Editor / Backend.
658
- - _Приклад_: `true`
659
- - _Примітка_: Наприклад, коли додається або оновлюється новий словник, застосунок оновить контент, що відображається на сторінці.
660
- - _Примітка_: Live sync потребує винесення вмісту застосунку на інший сервер. Це означає, що це може трохи вплинути на продуктивність застосунку. Щоб обмежити цей вплив, рекомендуємо розміщувати застосунок і live sync сервер на одній машині. Також комбінація live sync та `optimize` може спричинити значну кількість запитів до live sync сервера. Залежно від вашої інфраструктури, рекомендуємо протестувати обидві опції та їх комбінацію.
661
-
662
- - **liveSyncPort**:
663
- - _Тип_: `number`
664
- - _За замовчуванням_: `4000`
665
- - _Опис_: Порт live sync сервера.
666
- - _Приклад_: `4000`
667
- - _Примітка_: Порт live sync сервера.
668
-
669
- - **liveSyncURL**:
670
- - _Тип_: `string`
671
- - _За замовчуванням_: `'http://localhost:{liveSyncPort}'`
672
- - _Опис_: URL live sync сервера.
673
- - _Приклад_: `'https://example.com'`
674
- - _Примітка_: За замовчуванням вказує на localhost, але може бути змінений на будь-який URL у випадку віддаленого live sync сервера.
675
-
676
- ### Конфігурація маршрутизації
677
-
678
- Налаштування, що контролюють поведінку маршрутизації, включно зі структурою URL, зберіганням locale та обробкою middleware.
679
-
680
- #### Властивості
681
-
682
- - **mode**:
683
- - _Тип_: `'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'`
684
- - _Типово_: `'prefix-no-default'`
685
- - _Опис_: Режим маршрутизації URL для обробки locale.
686
- - _Examples_:
687
- - `'prefix-no-default'`: `/dashboard` (en) або `/fr/dashboard` (fr)
688
- - `'prefix-all'`: `/en/dashboard` (en) або `/fr/dashboard` (fr)
689
- - `'no-prefix'`: `/dashboard` (locale обробляється іншими способами`)
690
- - `'search-params'`: `/dashboard?locale=fr`
691
- - _Примітка_: Це налаштування не впливає на керування cookie або зберіганням локалі.
692
-
693
- - **storage**:
694
- - _Тип_: `false | 'cookie' | 'localStorage' | 'sessionStorage' | 'header' | CookiesAttributes | StorageAttributes | Array`
695
- - _Типово_: `'localStorage'`
696
- - _Опис_: Налаштування для зберігання локалі на клієнті.
697
-
698
- - **cookie**:
699
- - _Опис_: Зберігає дані в cookie, невеликі фрагменти даних, що зберігаються в браузері клієнта, доступні як на стороні клієнта, так і на стороні сервера.
700
- - _Примітка_: Для зберігання, що відповідає вимогам GDPR, перед використанням забезпечте належну згоду користувача.
701
- - _Примітка_: Параметри cookie можна налаштувати, якщо вказати їх як CookiesAttributes (`{ type: 'cookie', name: 'custom-locale', secure: true, httpOnly: false }`).
702
-
703
- - **localStorage**:
704
- - _Опис_: Зберігає дані в браузері без дат закінчення терміну дії, що дозволяє зберігати дані між сесіями, доступне лише на боці клієнта.
705
- - _Примітка_: Ідеально підходить для зберігання довгострокових даних, проте слід враховувати питання приватності та безпеки через відсутність строку дії, якщо їх не видалити явно.
706
- - _Примітка_: Сховище локалі доступне лише на боці клієнта, проксі intlayer не зможе до нього отримати доступ.
707
- - _Примітка_: Параметри сховища локалі можна налаштувати, якщо вказати їх як StorageAttributes (`{ type: 'localStorage', name: 'custom-locale' }`).
708
-
709
- - **sessionStorage**:
710
- - _Опис_: Зберігає дані протягом сеансу сторінки, тобто вони очищуються після закриття вкладки або вікна, доступне лише на боці клієнта.
711
- - _Примітка_: Підходить для тимчасового збереження даних для кожної сесії.
712
- - _Примітка_: Сховище локалі доступне лише на стороні клієнта, проксі intlayer не зможе до нього звертатися.
713
- - _Примітка_: Параметри збереження локалі можна налаштувати, якщо задати їх як StorageAttributes (`{ type: 'sessionStorage', name: 'custom-locale' }`).
714
-
715
- - **header**:
716
- - _Опис_: Використовує HTTP-заголовки для збереження або передачі даних локалі, підходить для визначення мови на стороні сервера.
717
- - _Примітка_: Корисно в API-запитах для підтримки узгоджених налаштувань мови між запитами.
718
- - _Примітка_: Заголовок доступний лише на стороні сервера, клієнт не зможе отримати до нього доступ.
719
- - _Примітка_: Назву заголовка можна змінити, якщо вказати її в StorageAttributes (`{ type: 'header', name: 'custom-locale' }`).
720
-
721
- - **basePath**:
722
- - _Тип_: `string`
723
- - _За замовчуванням_: `''`
724
- - _Опис_: Базовий шлях для URL-адрес застосунку.
725
- - _Приклад_: `'/my-app'`
726
- - _Примітка_:
727
- - Якщо застосунок розміщений за адресою `https://example.com/my-app`
728
- - Базовий шлях, `'/my-app'`
729
- - URL буде `https://example.com/my-app/en`
730
- - Якщо базовий шлях не встановлено, URL буде `https://example.com/en`
731
-
732
- - **rewrite**:
733
- - _Тип_: `Record<string, StrictModeLocaleMap<string>>`
734
- - _За замовчуванням_: `undefined`
735
- - _Опис_: Користувацькі правила перезапису URL, які перевизначають режим маршрутизації за замовчуванням для певних шляхів. Дозволяє визначати специфічні для локалі шляхи, які відрізняються від стандартної поведінки маршрутизації. Підтримує динамічні параметри маршруту з використанням синтаксису `[param]`.
736
- - _Приклад_:
737
- ```typescript
738
- routing: {
739
- mode: "prefix-no-default", // Стратегія відкату
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
- - _Примітка_: Правила перезапису мають пріоритет над поведінкою `mode` за замовчуванням. Якщо шлях відповідає правилу перезапису, буде використано локалізований шлях з конфігурації перезапису замість стандартного префікса локалі.
757
- - _Примітка_: Динамічні параметри маршруту підтримуються з використанням нотації в квадратних дужках (наприклад, `[slug]`, `[id]`). Значення параметрів автоматично витягуються з URL та інтерполюються в перезаписаний шлях.
758
- - _Примітка_: Працює з додатками Next.js та Vite. Middleware/proxy автоматично перезапише вхідні запити, щоб відповідати внутрішній структурі маршруту.
759
- - _Примітка_: При генерації URL за допомогою `getLocalizedUrl()` правила перезапису автоматично застосовуються, якщо вони відповідають наданому шляху.
760
- - _Посилання_: Для отримання додаткової інформації див. [Користувацьке перезаписування URL](https://github.com/aymericzip/intlayer/blob/main/docs/docs/uk/custom_url_rewrites.md).
761
-
762
- #### Атрибути cookie
763
-
764
- При використанні зберігання в cookie ви можете налаштувати додаткові атрибути cookie:
765
-
766
- - **name**: Ім'я cookie (за замовчуванням: `'INTLAYER_LOCALE'`)
767
- - **domain**: Домен cookie (за замовчуванням: undefined)
768
- - **path**: Шлях cookie (за замовчуванням: undefined)
769
- - **secure**: Вимагати HTTPS (за замовчуванням: undefined)
770
- - **httpOnly**: Прапорець лише для HTTP (httpOnly) (за замовчуванням: undefined)
771
- - **sameSite**: Політика SameSite (`'strict' | 'lax' | 'none'`)
772
- - **expires**: Дата закінчення строку дії або кількість днів (значення за замовчуванням: undefined)
773
-
774
- #### Атрибути збереження локалі
775
-
776
- Коли використовується localStorage або sessionStorage:
777
-
778
- - **type**: Тип сховища (`'localStorage' | 'sessionStorage'`)
779
- - **name**: Ім'я ключа в сховищі (за замовчуванням: `'INTLAYER_LOCALE'`)
780
-
781
- #### Приклади конфігурації
782
-
783
- Нижче наведені поширені приклади конфігурації для нової структури маршрутизації v7:
784
-
785
- **Базова конфігурація (за замовчуванням)**:
786
-
787
- ```typescript
788
- import { Locales, type IntlayerConfig } from "intlayer";
789
- // intlayer.config.ts
790
- const config: IntlayerConfig = {
791
- internationalization: {
792
- locales: ["en", "fr", "es"],
793
- defaultLocale: "en",
794
- },
795
- routing: {
796
- mode: "prefix-no-default",
797
- storage: "localStorage",
798
- headerName: "x-intlayer-locale",
799
- },
800
- };
801
-
802
- export default config;
803
- ```
804
-
805
- **Конфігурація, сумісна з GDPR**:
806
-
807
- ```typescript
808
- import { Locales, type IntlayerConfig } from "intlayer";
809
- // intlayer.config.ts
810
- const config: IntlayerConfig = {
811
- internationalization: {
812
- locales: ["en", "fr", "es"],
813
- defaultLocale: "en",
814
- },
815
- routing: {
816
- mode: "prefix-no-default",
817
- storage: [
818
- {
819
- type: "localStorage",
820
- name: "user-locale",
821
- },
822
- {
823
- type: "cookie",
824
- name: "user-locale",
825
- secure: true,
826
- sameSite: "strict",
827
- httpOnly: false,
828
- },
829
- ],
830
- },
831
- };
832
-
833
- export default config;
834
- ```
835
-
836
- **Режим параметрів пошуку**:
837
-
838
- ```typescript
839
- import { Locales, type IntlayerConfig } from "intlayer";
840
- // intlayer.config.ts
841
- const config: IntlayerConfig = {
842
- internationalization: {
843
- locales: ["en", "fr", "es"],
844
- defaultLocale: "en",
845
- },
846
- routing: {
847
- mode: "search-params",
848
- },
849
- };
850
-
851
- export default config;
852
- ```
853
-
854
- **Режим без префікса з кастомним сховищем**:
855
-
856
- ```typescript
857
- import { Locales, type IntlayerConfig } from "intlayer";
858
- // intlayer.config.ts
859
- const config: IntlayerConfig = {
860
- internationalization: {
861
- locales: ["en", "fr", "es"],
862
- defaultLocale: "en",
863
- },
864
- routing: {
865
- mode: "no-prefix",
866
- storage: {
867
- type: "sessionStorage",
868
- },
869
- },
870
- };
871
-
872
- export default config;
873
- ```
874
-
875
- ---
876
-
877
- ### Конфігурація контенту
878
-
879
- Налаштування, пов'язані з обробкою контенту в додатку, включаючи назви директорій, розширення файлів та похідні конфігурації.
880
-
881
- #### Властивості
882
-
883
- - **watch**:
884
- - _Тип_: `boolean`
885
- - _За замовчуванням_: `process.env.NODE_ENV === 'development'`
886
- - _Опис_: Вказує, чи Intlayer має відслідковувати зміни в файлах декларації контенту в додатку, щоб перебудувати відповідні словники.
887
-
888
- - **fileExtensions**:
889
- - _Тип_: `string[]`
890
- - _За замовчуванням_: `['.content.ts', '.content.js', '.content.cjs', '.content.mjs', '.content.json', '.content.tsx', '.content.jsx']`
891
- - _Опис_: Розширення файлів, які слід шукати під час побудови словників.
892
- - _Приклад_: `['.data.ts', '.data.js', '.data.json']`
893
- - _Примітка_: Налаштування розширень файлів може допомогти уникнути конфліктів.
894
-
895
- - **contentDir**:
896
- - _Тип_: `string[]`
897
- - _За замовчуванням_: `['.']`
898
- - _Приклад_: `['src', '../../ui-library', require.resolve("@my-package/content")]`
899
- - _Опис_: Шлях до каталогу, де зберігаються файли визначення контенту (`.content.*`).
900
- - _Примітка_: Використовується для відстеження файлів контенту для перебудови словників.
901
-
902
- - **codeDir**:
903
- - _Тип_: `string[]`
904
- - _За замовчуванням_: `['.']`
905
- - _Приклад_: `['src', '../../ui-library']`
906
- - _Опис_: Шлях до каталогу, де зберігається код, відносно базового каталогу.
907
- - _Примітка_: Використовується для відстеження файлів коду для перетворення (обрізання, оптимізація). Тримання цього окремо від `contentDir` може покращити продуктивність збірки, уникаючи непотрібного сканування файлів контенту.
908
-
909
- ---
910
-
911
- ### Конфігурація системи
912
-
913
- Налаштування, пов'язані з внутрішніми шляхами та вихідними результатами Intlayer. Ці налаштування зазвичай є внутрішніми і не повинні змінюватися користувачем.
914
-
915
- #### Властивості
916
-
917
- - **baseDir**:
918
- - _Тип_: `string`
919
- - _За замовчуванням_: `process.cwd()`
920
- - _Опис_: Базова директорія проекту.
921
- - _Приклад_: `'/path/to/project'`
922
- - _Примітка_: Використовується для визначення всіх директорій, пов'язаних з Intlayer.
923
-
924
- - **dictionariesDir**:
925
- - _Тип_: `string`
926
- - _За замовчуванням_: `'.intlayer/dictionary'`
927
- - _Опис_: Каталог для збереження словників локалізації.
928
- - _Приклад_: `'translations'`
929
-
930
- - **moduleAugmentationDir**:
931
- - _Тип_: `string`
932
- - _За замовчуванням_: `'.intlayer/types'`
933
- - _Опис_: Каталог для module augmentation, що дозволяє покращені підказки IDE та перевірку типів.
934
- - _Приклад_: `'intlayer-types'`
935
- - _Примітка_: Переконайтеся, що цей каталог включений у `tsconfig.json`.
936
-
937
- - **unmergedDictionariesDir**:
938
- - _Тип_: `string`
939
- - _За замовчуванням_: `'.intlayer/unmerged_dictionary'`
940
- - _Опис_: Каталог для збереження незлитих словників.
941
- - _Приклад_: `'translations'`
942
-
943
- - **typesDir**:
944
- - _Тип_: `string`
945
- - _За замовчуванням_: `'types'`
946
- - _Опис_: Каталог для збереження типів словників.
947
- - _Приклад_: `'intlayer-types'`
948
-
949
- - **mainDir**:
950
- - _Тип_: `string`
951
- - _За замовчуванням_: `'main'`
952
- - _Опис_: Каталог, де зберігаються основні файли застосунку.
953
- - _Приклад_: `'intlayer-main'`
954
-
955
- - **excludedPath**:
956
- - _Тип_: `string[]`
957
- - _За замовчуванням_: `['**/node_modules/**', '**/dist/**', '**/build/**', '**/.intlayer/**', '**/.next/**', '**/.nuxt/**', '**/.expo/**', '**/.vercel/**', '**/.turbo/**', '**/.tanstack/**']`
958
- - _Опис_: Каталоги, виключені з пошуку вмісту.
959
- - _Примітка_: Ця налаштування ще не використовується, але планується для майбутньої реалізації.
960
-
961
- - **formatCommand**:
962
- - _Тип_: `string`
963
- - _Типово_: `undefined`
964
- - _Опис_: Команда для форматування вмісту. Коли Intlayer записуватиме ваші .content файли локально, ця команда буде використана для форматування вмісту.
965
- - _Приклад_: `'npx prettier --write "{{file}}" --log-level silent'` За допомогою Prettier
966
- - _Приклад_: `'npx biome format "{{file}}" --write --log-level none'` За допомогою Biome
967
- - _Приклад_: `'npx eslint --fix "{{file}}" --quiet'` За допомогою ESLint
968
- - _Примітка_: Intlayer замінить {{file}} на шлях до файлу, який потрібно форматувати.
969
- - _Примітка_: Якщо не вказано, Intlayer спробує визначити команду форматування автоматично. Він буде намагатися знайти такі команди: prettier, biome, eslint.
970
-
971
- ### Конфігурація словника
972
-
973
- Налаштування, які керують операціями словника, включаючи поведінку автоматичного заповнення та генерацію контенту.
974
-
975
- Ця конфігурація словника має дві основні цілі:
976
-
977
- 1. **Значення за замовчуванням**: Визначати значення за замовчуванням під час створення файлів декларації контенту
978
- 2. **Поведінка при відсутності значень**: Забезпечувати запасні значення, коли певні поля не визначені, що дозволяє задавати поведінку операцій словника глобально
979
-
980
- Щоб дізнатися більше про файли декларації контенту та про те, як застосовуються значення конфігурації, див. [Документацію щодо контент-файлів](https://github.com/aymericzip/intlayer/blob/main/docs/docs/uk/dictionary/content_file.md).
981
-
982
- #### Властивості
983
-
984
- - **fill**
985
- - **description**
986
- - **locale**
987
- - **location**
988
- - **importMode**:
989
- - _Примітка_: **Deprecated**: Use `dictionary.importMode` instead.
990
- - _Тип_: `'static' | 'dynamic' | 'fetch'`
991
- - _Типово_: `'static'`
992
- - _Опис_: Controls how dictionaries are imported.
993
- - _Приклад_: `'dynamic'`
994
- - **priority**
995
- - **live**
996
- - **schema**
997
- - **title**
998
- - **tags**
999
- - **version**
1000
-
1001
- ---
1002
-
1003
- ### Конфігурація логера
1004
-
1005
- Налаштування, що керують логером, включно з префіксом, який слід використовувати.
1006
-
1007
- #### Властивості
1008
-
1009
- - **mode**:
1010
- - _Тип_: `string`
1011
- - _За замовчуванням_: `default`
1012
- - _Опис_: Вказує режим роботи логера.
1013
- - _Опції_: `default`, `verbose`, `disabled`
1014
- - _Приклад_: `default`
1015
- - _Примітка_: Режим роботи логера. Режим `verbose` записуватиме більше інформації й підходить для налагодження. Режим `disabled` вимкне логер.
1016
-
1017
- - **prefix**:
1018
- - _Тип_: `string`
1019
- - _Типово_: `'[intlayer] '`
1020
- - _Опис_: Префікс logger'а.
1021
- - _Приклад_: `'[my custom prefix] '`
1022
- - _Примітка_: Префікс logger'а.
1023
-
1024
- ### Конфігурація AI
1025
-
1026
- Налаштування, які контролюють AI-функції Intlayer, включно з провайдером, моделлю та API-ключем.
1027
-
1028
- Ця конфігурація є необов'язковою, якщо ви зареєстровані на [Intlayer Dashboard](https://app.intlayer.org/project) і використовуєте ключ доступу. Intlayer автоматично підбере найефективніше та економічно вигідне AI-рішення для ваших потреб. Використання опцій за замовчуванням забезпечує кращу довгострокову підтримуваність, оскільки Intlayer постійно оновлюється, щоб використовувати найбільш релевантні моделі.
1029
-
1030
- Якщо ви віддаєте перевагу використовувати власний API-ключ або конкретну модель, ви можете визначити власну конфігурацію AI.
1031
- Ця конфігурація ШІ буде використовуватися глобально в усьому вашому середовищі Intlayer. Команди CLI використовуватимуть ці налаштування як значення за замовчуванням для команд (наприклад, `fill`), а також SDK, Visual Editor і CMS. Ви можете перевизначати ці значення за замовчуванням для конкретних випадків використання за допомогою параметрів команд.
1032
-
1033
- Intlayer підтримує кількох постачальників ШІ для більшої гнучкості та вибору. Наразі підтримуються такі постачальники:
1034
-
1035
- - **OpenAI** (за замовчуванням)
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
- #### Властивості
1054
-
1055
- - **provider**:
1056
- - _Тип_: `string`
1057
- - _Типово_: `'openai'`
1058
- - _Опис_: Постачальник, який використовуватиметься для функцій ШІ Intlayer.
1059
- - _Options_: `'openai'`, `'anthropic'`, `'mistral'`, `'deepseek'`, `'gemini'`, `'ollama'`, `'openrouter'`, `'alibaba'`, `'fireworks'`, `'groq'`, `'huggingface'`, `'bedrock'`, `'googleaistudio'`, `'googlevertex'`, `'togetherai'`
1060
- - _Приклад_: `'anthropic'`
1061
- - _Примітка_: Різні провайдери можуть вимагати різні API-ключі та мати різні моделі ціноутворення.
1062
-
1063
- - **model**:
1064
- - _Тип_: `string`
1065
- - _Типово_: None
1066
- - _Опис_: Модель, яку слід використовувати для функцій ШІ в Intlayer.
1067
- - _Приклад_: `'gpt-4o-2024-11-20'`
1068
- - _Примітка_: Конкретна модель для використання залежить від провайдера.
1069
-
1070
- - **temperature**:
1071
- - _Тип_: `number`
1072
- - _Типово_: None
1073
- - _Опис_: Параметр temperature контролює випадковість відповідей ШІ.
1074
- - _Приклад_: `0.1`
1075
- - _Примітка_: Вища температура зробить ШІ більш креативним та менш передбачуваним.
1076
-
1077
- - **apiKey**:
1078
- - _Тип_: `string`
1079
- - _Типово_: None
1080
- - _Опис_: Ваш API-ключ для вибраного провайдера.
1081
- - _Приклад_: `process.env.OPENAI_API_KEY`
1082
- - _Примітка_: Важливо: API-ключі слід зберігати в таємниці та не поширювати публічно. Будь ласка, зберігайте їх у безпечному місці, наприклад у змінних середовища.
1083
-
1084
- - **applicationContext**:
1085
- - _Тип_: `string`
1086
- - _Типово_: None
1087
- - _Опис_: Надає додатковий контекст про ваш застосунок для AI-моделі, допомагаючи їй генерувати точніші та контекстуально доречні переклади. Це може включати інформацію про домен вашого додатку, цільову аудиторію, тон або специфічну термінологію.
1088
- - _Примітка_: Ви можете використовувати його, щоб додати більше правил для AI-моделі (e.g. "You should not transform urls").
1089
- - _Приклад_: `'My application context'`
1090
-
1091
- - **baseURL**:
1092
- - _Тип_: `string`
1093
- - _Типово_: None
1094
- - _Опис_: Базовий URL для AI API.
1095
- - _Приклад_: `'https://api.openai.com/v1'`
1096
- - _Приклад_: `'http://localhost:5000'`
1097
- - _Примітка_: Може використовуватися для вказівки локального або кастомного AI API endpoint.
1098
-
1099
- - **dataSerialization**:
1100
- - _Тип_: `'json' | 'toon'`
1101
- - _За замовчуванням_: `'json'`
1102
- - _Опис_: Формат серіалізації даних для використання у функціях ШІ Intlayer.
1103
- - _Приклад_: `'toon'`
1104
- - _Примітка_: `json`: Стандартний, надійний; використовує більше токенів. `toon`: Менше токенів, менш стабільний, ніж JSON.
1105
-
1106
- > Якщо ви надаєте додаткові параметри, Intlayer передасть їх AI-моделі як контекст. Це можна використовувати для налаштування інтенсивності міркувань, детальності тексту тощо
1107
-
1108
- ### Конфігурація збірки
1109
-
1110
- Налаштування, що контролюють, як Intlayer оптимізує та збирає інтернаціоналізацію вашого застосунку.
1111
-
1112
- Параметри збірки застосовуються до плагінів `@intlayer/babel` та `@intlayer/swc`.
1113
-
1114
- > У режимі розробки Intlayer використовує статичні імпорти словників, щоб спростити процес розробки.
1115
-
1116
- > У режимі оптимізації Intlayer замінює виклики словників для оптимізації розбиття на чанки (chunking), тож фінальний бандл імпортує лише ті словники, які фактично використовуються.
1117
-
1118
- #### Властивості
1119
-
1120
- - **mode**:
1121
- - _Тип_: `'auto' | 'manual'`
1122
- - _За замовчуванням_: `'auto'`
1123
- - _Опис_: Керує режимом збірки.
1124
- - _Приклад_: `'manual'`
1125
- - _Примітка_: Якщо 'auto', збірка буде увімкнена автоматично під час побудови застосунку.
1126
- - _Примітка_: Якщо 'manual', збірка буде встановлена лише під час виконання команди збірки.
1127
- - _Примітка_: Може використовуватися для вимкнення збірки словників, наприклад, коли слід уникати виконання в середовищі Node.js.
1128
-
1129
- - **optimize**:
1130
- - _Тип_: `boolean`
1131
- - _За замовчуванням_: `undefined`
1132
- - _Опис_: Керує тим, чи слід оптимізувати збірку.
1133
- - _Приклад_: `process.env.NODE_ENV === 'production'`
1134
- - _Примітка_: За замовчуванням оптимізація збірки не зафіксована. Якщо не встановлено, Intlayer запустить оптимізацію під час збірки вашого застосунку (vite / nextjs / тощо). Встановлення `true` примусово увімкне оптимізацію збірки, включно з режимом розробки. Встановлення `false` вимкне оптимізацію збірки.
1135
- - _Примітка_: Коли ввімкнено, Intlayer замінює всі виклики словників для оптимізації розбиття на чанки. Таким чином фінальний бандл імпортуватиме лише ті словники, які використовуються. Всі імпорти залишаться статичними, щоб уникнути асинхронної обробки під час завантаження словників.
1136
- - _Примітка_: Intlayer замінить усі виклики `useIntlayer` на варіант, визначений опцією `importMode`, а `getIntlayer`, на `getDictionary`.
1137
- - _Примітка_: Ця опція покладається на плагіни `@intlayer/babel` та `@intlayer/swc`.
1138
- - _Примітка_: Переконайтесь, що всі ключі оголошені статично у викликах `useIntlayer`. Наприклад `useIntlayer('navbar')`.
1139
-
1140
- - **checkTypes**:
1141
- - _Тип_: `boolean`
1142
- - _Типово_: `false`
1143
- - _Опис_: Вказує, чи повинна збірка перевіряти типи TypeScript та реєструвати помилки.
1144
- - _Примітка_: Це може уповільнити процес збірки.
1145
-
1146
- - **outputFormat**:
1147
- - _Тип_: `'esm' | 'cjs'`
1148
- - _Типово_: `'esm'`
1149
- - _Опис_: Керує форматом виводу словників.
1150
- - _Приклад_: `'cjs'`
1151
- - _Примітка_: Формат виводу словників.
1152
-
1153
- - **traversePattern**:
1154
- - _Тип_: `string[]`
1155
- - _Типово_: `['**\/*.{js,ts,mjs,cjs,jsx,tsx}', '!**\/node_modules/**']`
1156
- - _Опис_: Шаблони, що визначають, які файли слід обходити під час оптимізації.
1157
- - _Приклад_: `['src/**\/*.{ts,tsx}', '../ui-library/**\/*.{ts,tsx}', '!**/node_modules/**']`
1158
- - _Примітка_: Використовуйте це, щоб обмежити оптимізацію релевантними файлами коду та покращити продуктивність збірки.
1159
- - _Примітка_: Ця опція буде ігнорована, якщо `optimize` вимкнено.
1160
- - _Примітка_: Використовуйте glob-шаблон.
1161
-
1162
- ---
1163
-
1164
- ### Конфігурація компілятора
1165
-
1166
- Налаштування, що керують компілятором Intlayer, який витягує словники безпосередньо з ваших компонентів.
1167
-
1168
- #### Властивості
1169
-
1170
- - **enabled**:
1171
- - _Тип_: `boolean | 'build-only'`
1172
- - _За замовчуванням_: `true`
1173
- - _Опис_: Вказує, чи повинен бути ввімкнений компілятор для витягування словників.
1174
- - _Приклад_: `'build-only'`
1175
- - _Примітка_: Встановлення значення `'build-only'` призведе до пропуску компілятора під час режиму розробки для прискорення часу запуску. Він буде запускатися лише для команд збірки.
1176
-
1177
- - **dictionaryKeyPrefix**:
1178
- - _Тип_: `string`
1179
- - _За замовчуванням_: `''`
1180
- - _Опис_: Префікс для витягнутих ключів словника.
1181
- - _Приклад_: `'my-key-'`
1182
- - _Примітка_: Під час витягування словників ключ генерується на основі назви файлу. Цей префікс додається до згенерованого ключа, щоб запобігти конфліктам.
1183
-
1184
- - **saveComponents**:
1185
- - _Тип_: `boolean`
1186
- - _За замовчуванням_: `false`
1187
- - _Опис_: Вказує, чи повинні зберігатися компоненти після їх трансформації.
1188
- - _Примітка_: Якщо встановлено значення true, компілятор замінить оригінальні файли трансформованими. Таким чином, компілятор можна запустити лише один раз для трансформації застосунку, а потім видалити його.
1189
-
1190
- - **transformPattern**:
1191
- - _Тип_: `string | string[]`
1192
- - _За замовчуванням_: `['**/*.{ts,tsx,jsx,js,cjs,mjs,svelte,vue}', '!**/node_modules/**']`
1193
- - _Опис_: Шаблони, що визначають, які файли слід обходити під час оптимізації.
1194
- - _Приклад_: `['src/**/*.{ts,tsx}', '!**/node_modules/**']`
1195
- - _Примітка_: Використовуйте це, щоб обмежити оптимізацію релевантними файлами коду та покращити продуктивність збірки.
1196
-
1197
- - **excludePattern**:
1198
- - _Тип_: `string | string[]`
1199
- - _За замовчуванням_: `['**/node_modules/**']`
1200
- - _Опис_: Шаблони, що визначають, які файли слід виключити під час оптимізації.
1201
- - _Приклад_: `['**/node_modules/**', '!**/node_modules/react/**']`
1202
-
1203
- - **output**:
1204
- - _Тип_: `FilePathPattern`
1205
- - _Типово_: `undefined`
1206
- - _Опис_: Визначає шлях до вихідних файлів. Замінює `outputDir`. Підтримує динамічні змінні через рядкові шаблони або функцію. Підтримувані змінні: `{{fileName}}`, `{{key}}`, `{{locale}}`, `{{extension}}`, `{{componentFileName}}`, `{{componentExtension}}`, `{{format}}`, `{{componentFormat}}`, та `{{componentDirPath}}`.
1207
- - _Примітка_: Шляхи, що починаються з `./`, розв'язуються відносно каталогу компонента. Шляхи, що починаються з `/`, розв'язуються відносно кореня проєкту (`baseDir`).
1208
- - _Примітка_: Включення змінної `{{locale}}` у шлях дозволить генерувати словники, розділені за локалями.
1209
- - _Приклад_:
1210
- - **Багатомовний файл поруч із компонентом**:
1211
- - Рядок: `'./{{fileName}}{{extension}}'`
1212
- - Функція: `({ fileName, extension }) => \`./${fileName}${extension}\``
1213
-
1214
- - **Централізовані JSON-файли для кожної локалі**:
1215
- - Рядок: `'/locales/{{locale}}/{{key}}.content.json'`
1216
- - Функція: `({ key, locale }) => \`/locales/${locale}/${key}.content.json\``
1217
-
1218
- - **noMetadata**:
1219
- - _Тип_: `boolean`
1220
- - _Типово_: `false`
1221
- - _Опис_: Вказує, чи мають метадані зберігатися у файлі. Якщо true, компілятор не зберігатиме метадані словників (ключ, оболонка вмісту). Корисно для виводу JSON для i18next або ICU MessageFormat для кожної локалі.
1222
- - _Примітка_: Корисно при використанні з плагіном `loadJSON`.
1223
- - _Приклад_:
1224
- Якщо `true` :
1225
-
1226
- ```json
1227
- {
1228
- "key": "value"
1229
- }
1230
- ```
1231
-
1232
- Якщо `false`:
1233
-
1234
- ```json
1235
- {
1236
- "key": "value",
1237
- "content": {
1238
- "key": "value"
1239
- }
1240
- }
1241
- ```