@intlayer/docs 5.8.1 → 6.0.0-canary.1

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 (378) hide show
  1. package/blog/ar/rag_powered_documentation_assistant.md +282 -0
  2. package/blog/de/rag_powered_documentation_assistant.md +282 -0
  3. package/blog/en/rag_powered_documentation_assistant.md +289 -0
  4. package/blog/en-GB/rag_powered_documentation_assistant.md +284 -0
  5. package/blog/es/rag_powered_documentation_assistant.md +308 -0
  6. package/blog/fr/rag_powered_documentation_assistant.md +308 -0
  7. package/blog/hi/rag_powered_documentation_assistant.md +284 -0
  8. package/blog/it/rag_powered_documentation_assistant.md +284 -0
  9. package/blog/ja/rag_powered_documentation_assistant.md +284 -0
  10. package/blog/ko/rag_powered_documentation_assistant.md +283 -0
  11. package/blog/pt/rag_powered_documentation_assistant.md +284 -0
  12. package/blog/ru/rag_powered_documentation_assistant.md +284 -0
  13. package/blog/tr/index.md +69 -0
  14. package/blog/tr/internationalization_and_SEO.md +273 -0
  15. package/blog/tr/intlayer_with_i18next.md +162 -0
  16. package/blog/tr/intlayer_with_next-i18next.md +367 -0
  17. package/blog/tr/intlayer_with_next-intl.md +392 -0
  18. package/blog/tr/intlayer_with_react-i18next.md +346 -0
  19. package/blog/tr/intlayer_with_react-intl.md +345 -0
  20. package/blog/tr/list_i18n_technologies/CMS/drupal.md +143 -0
  21. package/blog/tr/list_i18n_technologies/CMS/wix.md +167 -0
  22. package/blog/tr/list_i18n_technologies/CMS/wordpress.md +188 -0
  23. package/blog/tr/list_i18n_technologies/frameworks/angular.md +125 -0
  24. package/blog/tr/list_i18n_technologies/frameworks/flutter.md +150 -0
  25. package/blog/tr/list_i18n_technologies/frameworks/react-native.md +217 -0
  26. package/blog/tr/list_i18n_technologies/frameworks/react.md +155 -0
  27. package/blog/tr/list_i18n_technologies/frameworks/svelte.md +129 -0
  28. package/blog/tr/list_i18n_technologies/frameworks/vue.md +130 -0
  29. package/blog/tr/next-i18next_vs_next-intl_vs_intlayer.md +170 -0
  30. package/blog/tr/rag_powered_documentation_assistant.md +284 -0
  31. package/blog/tr/react-i18next_vs_react-intl_vs_intlayer.md +162 -0
  32. package/blog/tr/vue-i18n_vs_intlayer.md +276 -0
  33. package/blog/tr/what_is_internationalization.md +166 -0
  34. package/blog/zh/rag_powered_documentation_assistant.md +284 -0
  35. package/dist/cjs/generated/blog.entry.cjs +212 -0
  36. package/dist/cjs/generated/blog.entry.cjs.map +1 -1
  37. package/dist/cjs/generated/docs.entry.cjs +660 -132
  38. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  39. package/dist/cjs/generated/frequentQuestions.entry.cjs +84 -0
  40. package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
  41. package/dist/cjs/generated/legal.entry.cjs +6 -0
  42. package/dist/cjs/generated/legal.entry.cjs.map +1 -1
  43. package/dist/esm/generated/blog.entry.mjs +212 -0
  44. package/dist/esm/generated/blog.entry.mjs.map +1 -1
  45. package/dist/esm/generated/docs.entry.mjs +660 -132
  46. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  47. package/dist/esm/generated/frequentQuestions.entry.mjs +84 -0
  48. package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
  49. package/dist/esm/generated/legal.entry.mjs +6 -0
  50. package/dist/esm/generated/legal.entry.mjs.map +1 -1
  51. package/dist/types/generated/blog.entry.d.ts +1 -0
  52. package/dist/types/generated/blog.entry.d.ts.map +1 -1
  53. package/dist/types/generated/docs.entry.d.ts +5 -2
  54. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  55. package/dist/types/generated/frequentQuestions.entry.d.ts.map +1 -1
  56. package/dist/types/generated/legal.entry.d.ts.map +1 -1
  57. package/docs/ar/autoFill.md +41 -40
  58. package/docs/ar/configuration.md +202 -199
  59. package/docs/ar/dictionary/content_file.md +1059 -0
  60. package/docs/ar/intlayer_CMS.md +4 -4
  61. package/docs/ar/intlayer_with_nestjs.md +271 -0
  62. package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
  63. package/docs/ar/intlayer_with_react_router_v7.md +533 -0
  64. package/docs/ar/intlayer_with_tanstack.md +465 -299
  65. package/docs/ar/intlayer_with_vite+preact.md +7 -7
  66. package/docs/ar/intlayer_with_vite+react.md +7 -7
  67. package/docs/ar/intlayer_with_vite+vue.md +9 -9
  68. package/docs/ar/packages/vite-intlayer/index.md +3 -3
  69. package/docs/ar/readme.md +261 -0
  70. package/docs/ar/testing.md +199 -0
  71. package/docs/de/autoFill.md +42 -19
  72. package/docs/de/configuration.md +155 -147
  73. package/docs/de/dictionary/content_file.md +1059 -0
  74. package/docs/de/intlayer_CMS.md +4 -5
  75. package/docs/de/intlayer_with_nestjs.md +270 -0
  76. package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
  77. package/docs/de/intlayer_with_react_router_v7.md +537 -0
  78. package/docs/de/intlayer_with_tanstack.md +469 -302
  79. package/docs/de/intlayer_with_vite+preact.md +7 -7
  80. package/docs/de/intlayer_with_vite+react.md +7 -7
  81. package/docs/de/intlayer_with_vite+vue.md +9 -9
  82. package/docs/de/packages/vite-intlayer/index.md +3 -3
  83. package/docs/de/readme.md +261 -0
  84. package/docs/de/testing.md +200 -0
  85. package/docs/en/CI_CD.md +4 -6
  86. package/docs/en/autoFill.md +25 -5
  87. package/docs/en/configuration.md +45 -54
  88. package/docs/en/dictionary/content_file.md +1054 -0
  89. package/docs/en/intlayer_CMS.md +8 -7
  90. package/docs/en/intlayer_cli.md +112 -5
  91. package/docs/en/intlayer_with_nestjs.md +268 -0
  92. package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
  93. package/docs/en/intlayer_with_react_router_v7.md +531 -0
  94. package/docs/en/intlayer_with_tanstack.md +463 -294
  95. package/docs/en/intlayer_with_vite+preact.md +8 -8
  96. package/docs/en/intlayer_with_vite+react.md +8 -8
  97. package/docs/en/intlayer_with_vite+vue.md +8 -8
  98. package/docs/en/packages/intlayer/getLocalizedUrl.md +102 -25
  99. package/docs/en/packages/vite-intlayer/index.md +3 -3
  100. package/docs/en/readme.md +261 -0
  101. package/docs/en/testing.md +200 -0
  102. package/docs/en-GB/autoFill.md +29 -6
  103. package/docs/en-GB/configuration.md +79 -71
  104. package/docs/en-GB/dictionary/content_file.md +1084 -0
  105. package/docs/en-GB/intlayer_CMS.md +4 -5
  106. package/docs/en-GB/intlayer_with_nestjs.md +268 -0
  107. package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
  108. package/docs/en-GB/intlayer_with_react_router_v7.md +533 -0
  109. package/docs/en-GB/intlayer_with_tanstack.md +466 -299
  110. package/docs/en-GB/intlayer_with_vite+preact.md +7 -7
  111. package/docs/en-GB/intlayer_with_vite+react.md +7 -7
  112. package/docs/en-GB/intlayer_with_vite+vue.md +9 -9
  113. package/docs/en-GB/packages/vite-intlayer/index.md +3 -3
  114. package/docs/en-GB/readme.md +261 -0
  115. package/docs/en-GB/testing.md +200 -0
  116. package/docs/es/autoFill.md +45 -23
  117. package/docs/es/configuration.md +171 -167
  118. package/docs/es/dictionary/content_file.md +1088 -0
  119. package/docs/es/intlayer_CMS.md +4 -5
  120. package/docs/es/intlayer_with_nestjs.md +268 -0
  121. package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
  122. package/docs/es/intlayer_with_react_router_v7.md +533 -0
  123. package/docs/es/intlayer_with_tanstack.md +469 -280
  124. package/docs/es/intlayer_with_vite+preact.md +7 -7
  125. package/docs/es/intlayer_with_vite+react.md +7 -7
  126. package/docs/es/intlayer_with_vite+vue.md +9 -9
  127. package/docs/es/packages/vite-intlayer/index.md +3 -3
  128. package/docs/es/readme.md +261 -0
  129. package/docs/es/testing.md +200 -0
  130. package/docs/fr/autoFill.md +47 -24
  131. package/docs/fr/configuration.md +213 -198
  132. package/docs/fr/dictionary/content_file.md +1054 -0
  133. package/docs/fr/intlayer_CMS.md +4 -5
  134. package/docs/fr/intlayer_with_nestjs.md +268 -0
  135. package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
  136. package/docs/fr/intlayer_with_react_router_v7.md +549 -0
  137. package/docs/fr/intlayer_with_tanstack.md +465 -279
  138. package/docs/fr/intlayer_with_vite+preact.md +7 -7
  139. package/docs/fr/intlayer_with_vite+react.md +7 -7
  140. package/docs/fr/intlayer_with_vite+vue.md +9 -9
  141. package/docs/fr/packages/vite-intlayer/index.md +3 -3
  142. package/docs/fr/readme.md +261 -0
  143. package/docs/fr/testing.md +200 -0
  144. package/docs/hi/autoFill.md +47 -25
  145. package/docs/hi/configuration.md +194 -189
  146. package/docs/hi/dictionary/content_file.md +1056 -0
  147. package/docs/hi/intlayer_CMS.md +4 -5
  148. package/docs/hi/intlayer_with_nestjs.md +269 -0
  149. package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
  150. package/docs/hi/intlayer_with_react_router_v7.md +533 -0
  151. package/docs/hi/intlayer_with_tanstack.md +467 -282
  152. package/docs/hi/intlayer_with_vite+preact.md +7 -7
  153. package/docs/hi/intlayer_with_vite+react.md +7 -7
  154. package/docs/hi/intlayer_with_vite+vue.md +9 -9
  155. package/docs/hi/packages/vite-intlayer/index.md +3 -3
  156. package/docs/hi/readme.md +261 -0
  157. package/docs/hi/testing.md +200 -0
  158. package/docs/it/autoFill.md +46 -24
  159. package/docs/it/configuration.md +169 -161
  160. package/docs/it/dictionary/content_file.md +1061 -0
  161. package/docs/it/intlayer_CMS.md +4 -5
  162. package/docs/it/intlayer_with_nestjs.md +268 -0
  163. package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
  164. package/docs/it/intlayer_with_react_router_v7.md +535 -0
  165. package/docs/it/intlayer_with_tanstack.md +467 -301
  166. package/docs/it/intlayer_with_vite+preact.md +7 -7
  167. package/docs/it/intlayer_with_vite+react.md +7 -7
  168. package/docs/it/intlayer_with_vite+vue.md +9 -9
  169. package/docs/it/packages/vite-intlayer/index.md +3 -3
  170. package/docs/it/readme.md +261 -0
  171. package/docs/it/testing.md +200 -0
  172. package/docs/ja/autoFill.md +45 -23
  173. package/docs/ja/configuration.md +243 -204
  174. package/docs/ja/dictionary/content_file.md +1064 -0
  175. package/docs/ja/intlayer_CMS.md +4 -5
  176. package/docs/ja/intlayer_with_nestjs.md +268 -0
  177. package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
  178. package/docs/ja/intlayer_with_react_router_v7.md +534 -0
  179. package/docs/ja/intlayer_with_tanstack.md +467 -303
  180. package/docs/ja/intlayer_with_vite+preact.md +7 -7
  181. package/docs/ja/intlayer_with_vite+react.md +7 -7
  182. package/docs/ja/intlayer_with_vite+vue.md +9 -9
  183. package/docs/ja/packages/vite-intlayer/index.md +3 -3
  184. package/docs/ja/readme.md +263 -0
  185. package/docs/ja/testing.md +200 -0
  186. package/docs/ko/autoFill.md +39 -16
  187. package/docs/ko/configuration.md +217 -197
  188. package/docs/ko/dictionary/content_file.md +1060 -0
  189. package/docs/ko/intlayer_CMS.md +4 -5
  190. package/docs/ko/intlayer_with_nestjs.md +268 -0
  191. package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
  192. package/docs/ko/intlayer_with_react_router_v7.md +540 -0
  193. package/docs/ko/intlayer_with_tanstack.md +466 -302
  194. package/docs/ko/intlayer_with_vite+preact.md +7 -7
  195. package/docs/ko/intlayer_with_vite+react.md +7 -7
  196. package/docs/ko/intlayer_with_vite+vue.md +9 -9
  197. package/docs/ko/packages/vite-intlayer/index.md +3 -3
  198. package/docs/ko/readme.md +261 -0
  199. package/docs/ko/testing.md +200 -0
  200. package/docs/pt/autoFill.md +39 -15
  201. package/docs/pt/configuration.md +165 -147
  202. package/docs/pt/dictionary/content_file.md +1062 -0
  203. package/docs/pt/intlayer_CMS.md +4 -5
  204. package/docs/pt/intlayer_with_nestjs.md +271 -0
  205. package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
  206. package/docs/pt/intlayer_with_react_router_v7.md +535 -0
  207. package/docs/pt/intlayer_with_tanstack.md +469 -300
  208. package/docs/pt/intlayer_with_vite+preact.md +7 -7
  209. package/docs/pt/intlayer_with_vite+react.md +7 -7
  210. package/docs/pt/intlayer_with_vite+vue.md +9 -9
  211. package/docs/pt/packages/vite-intlayer/index.md +3 -3
  212. package/docs/pt/readme.md +261 -0
  213. package/docs/pt/testing.md +200 -0
  214. package/docs/ru/autoFill.md +52 -30
  215. package/docs/ru/configuration.md +164 -117
  216. package/docs/ru/dictionary/content_file.md +1064 -0
  217. package/docs/ru/intlayer_CMS.md +4 -4
  218. package/docs/ru/intlayer_with_nestjs.md +270 -0
  219. package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
  220. package/docs/ru/intlayer_with_react_router_v7.md +534 -0
  221. package/docs/ru/intlayer_with_tanstack.md +470 -305
  222. package/docs/ru/intlayer_with_vite+preact.md +7 -7
  223. package/docs/ru/intlayer_with_vite+react.md +7 -7
  224. package/docs/ru/intlayer_with_vite+vue.md +9 -9
  225. package/docs/ru/packages/vite-intlayer/index.md +3 -3
  226. package/docs/ru/readme.md +261 -0
  227. package/docs/ru/testing.md +202 -0
  228. package/docs/tr/CI_CD.md +198 -0
  229. package/docs/tr/autoFill.md +201 -0
  230. package/docs/tr/configuration.md +585 -0
  231. package/docs/tr/dictionary/condition.md +243 -0
  232. package/docs/tr/dictionary/content_file.md +1055 -0
  233. package/docs/tr/dictionary/enumeration.md +251 -0
  234. package/docs/tr/dictionary/file.md +228 -0
  235. package/docs/tr/dictionary/function_fetching.md +218 -0
  236. package/docs/tr/dictionary/gender.md +279 -0
  237. package/docs/tr/dictionary/insertion.md +191 -0
  238. package/docs/tr/dictionary/markdown.md +385 -0
  239. package/docs/tr/dictionary/nesting.md +279 -0
  240. package/docs/tr/dictionary/translation.md +315 -0
  241. package/docs/tr/formatters.md +618 -0
  242. package/docs/tr/how_works_intlayer.md +254 -0
  243. package/docs/tr/index.md +168 -0
  244. package/docs/tr/interest_of_intlayer.md +288 -0
  245. package/docs/tr/intlayer_CMS.md +347 -0
  246. package/docs/tr/intlayer_cli.md +570 -0
  247. package/docs/tr/intlayer_visual_editor.md +269 -0
  248. package/docs/tr/intlayer_with_angular.md +694 -0
  249. package/docs/tr/intlayer_with_create_react_app.md +1218 -0
  250. package/docs/tr/intlayer_with_express.md +415 -0
  251. package/docs/tr/intlayer_with_lynx+react.md +511 -0
  252. package/docs/tr/intlayer_with_nestjs.md +268 -0
  253. package/docs/tr/intlayer_with_nextjs_14.md +1029 -0
  254. package/docs/tr/intlayer_with_nextjs_15.md +1506 -0
  255. package/docs/tr/intlayer_with_nextjs_page_router.md +1484 -0
  256. package/docs/tr/intlayer_with_nuxt.md +773 -0
  257. package/docs/tr/intlayer_with_react_native+expo.md +660 -0
  258. package/docs/tr/intlayer_with_react_router_v7.md +531 -0
  259. package/docs/tr/intlayer_with_tanstack.md +452 -0
  260. package/docs/tr/intlayer_with_vite+preact.md +1673 -0
  261. package/docs/tr/intlayer_with_vite+react.md +1632 -0
  262. package/docs/tr/intlayer_with_vite+solid.md +288 -0
  263. package/docs/tr/intlayer_with_vite+svelte.md +288 -0
  264. package/docs/tr/intlayer_with_vite+vue.md +1042 -0
  265. package/docs/tr/introduction.md +209 -0
  266. package/docs/tr/locale_mapper.md +244 -0
  267. package/docs/tr/mcp_server.md +207 -0
  268. package/docs/tr/packages/@intlayer/api/index.md +58 -0
  269. package/docs/tr/packages/@intlayer/chokidar/index.md +57 -0
  270. package/docs/tr/packages/@intlayer/cli/index.md +47 -0
  271. package/docs/tr/packages/@intlayer/config/index.md +142 -0
  272. package/docs/tr/packages/@intlayer/core/index.md +51 -0
  273. package/docs/tr/packages/@intlayer/design-system/index.md +47 -0
  274. package/docs/tr/packages/@intlayer/dictionary-entry/index.md +53 -0
  275. package/docs/tr/packages/@intlayer/editor/index.md +47 -0
  276. package/docs/tr/packages/@intlayer/editor-react/index.md +47 -0
  277. package/docs/tr/packages/@intlayer/webpack/index.md +61 -0
  278. package/docs/tr/packages/angular-intlayer/index.md +59 -0
  279. package/docs/tr/packages/express-intlayer/index.md +258 -0
  280. package/docs/tr/packages/express-intlayer/t.md +459 -0
  281. package/docs/tr/packages/intlayer/getConfiguration.md +151 -0
  282. package/docs/tr/packages/intlayer/getEnumeration.md +165 -0
  283. package/docs/tr/packages/intlayer/getHTMLTextDir.md +127 -0
  284. package/docs/tr/packages/intlayer/getLocaleLang.md +87 -0
  285. package/docs/tr/packages/intlayer/getLocaleName.md +124 -0
  286. package/docs/tr/packages/intlayer/getLocalizedUrl.md +324 -0
  287. package/docs/tr/packages/intlayer/getMultilingualUrls.md +225 -0
  288. package/docs/tr/packages/intlayer/getPathWithoutLocale.md +81 -0
  289. package/docs/tr/packages/intlayer/getTranslation.md +196 -0
  290. package/docs/tr/packages/intlayer/getTranslationContent.md +195 -0
  291. package/docs/tr/packages/intlayer/index.md +505 -0
  292. package/docs/tr/packages/intlayer-cli/index.md +71 -0
  293. package/docs/tr/packages/intlayer-editor/index.md +139 -0
  294. package/docs/tr/packages/lynx-intlayer/index.md +85 -0
  295. package/docs/tr/packages/next-intlayer/index.md +154 -0
  296. package/docs/tr/packages/next-intlayer/t.md +354 -0
  297. package/docs/tr/packages/next-intlayer/useDictionary.md +270 -0
  298. package/docs/tr/packages/next-intlayer/useIntlayer.md +265 -0
  299. package/docs/tr/packages/next-intlayer/useLocale.md +133 -0
  300. package/docs/tr/packages/nuxt-intlayer/index.md +59 -0
  301. package/docs/tr/packages/preact-intlayer/index.md +55 -0
  302. package/docs/tr/packages/react-intlayer/index.md +148 -0
  303. package/docs/tr/packages/react-intlayer/t.md +304 -0
  304. package/docs/tr/packages/react-intlayer/useDictionary.md +554 -0
  305. package/docs/tr/packages/react-intlayer/useI18n.md +478 -0
  306. package/docs/tr/packages/react-intlayer/useIntlayer.md +253 -0
  307. package/docs/tr/packages/react-intlayer/useLocale.md +212 -0
  308. package/docs/tr/packages/react-native-intlayer/index.md +85 -0
  309. package/docs/tr/packages/react-scripts-intlayer/index.md +82 -0
  310. package/docs/tr/packages/solid-intlayer/index.md +56 -0
  311. package/docs/tr/packages/svelte-intlayer/index.md +55 -0
  312. package/docs/tr/packages/vite-intlayer/index.md +82 -0
  313. package/docs/tr/packages/vue-intlayer/index.md +59 -0
  314. package/docs/tr/per_locale_file.md +321 -0
  315. package/docs/tr/readme.md +261 -0
  316. package/docs/tr/roadmap.md +338 -0
  317. package/docs/tr/testing.md +200 -0
  318. package/docs/tr/vs_code_extension.md +154 -0
  319. package/docs/zh/autoFill.md +40 -18
  320. package/docs/zh/configuration.md +245 -226
  321. package/docs/zh/dictionary/content_file.md +1064 -0
  322. package/docs/zh/intlayer_CMS.md +4 -5
  323. package/docs/zh/intlayer_with_nestjs.md +268 -0
  324. package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
  325. package/docs/zh/intlayer_with_react_router_v7.md +535 -0
  326. package/docs/zh/intlayer_with_tanstack.md +468 -278
  327. package/docs/zh/intlayer_with_vite+preact.md +7 -7
  328. package/docs/zh/intlayer_with_vite+react.md +7 -7
  329. package/docs/zh/intlayer_with_vite+vue.md +7 -7
  330. package/docs/zh/packages/vite-intlayer/index.md +3 -3
  331. package/docs/zh/readme.md +261 -0
  332. package/docs/zh/testing.md +198 -0
  333. package/frequent_questions/tr/SSR_Next_no_[locale].md +105 -0
  334. package/frequent_questions/tr/array_as_content_declaration.md +72 -0
  335. package/frequent_questions/tr/build_dictionaries.md +59 -0
  336. package/frequent_questions/tr/build_error_CI_CD.md +75 -0
  337. package/frequent_questions/tr/customized_locale_list.md +65 -0
  338. package/frequent_questions/tr/domain_routing.md +114 -0
  339. package/frequent_questions/tr/esbuild_error.md +30 -0
  340. package/frequent_questions/tr/get_locale_cookie.md +142 -0
  341. package/frequent_questions/tr/intlayer_command_undefined.md +156 -0
  342. package/frequent_questions/tr/locale_incorect_in_url.md +74 -0
  343. package/frequent_questions/tr/static_rendering.md +45 -0
  344. package/frequent_questions/tr/translated_path_url.md +56 -0
  345. package/frequent_questions/tr/unknown_command.md +98 -0
  346. package/legal/tr/privacy_notice.md +83 -0
  347. package/legal/tr/terms_of_service.md +55 -0
  348. package/package.json +12 -12
  349. package/src/generated/blog.entry.ts +212 -0
  350. package/src/generated/docs.entry.ts +663 -135
  351. package/src/generated/frequentQuestions.entry.ts +85 -1
  352. package/src/generated/legal.entry.ts +7 -1
  353. package/docs/ar/dictionary/content_extention_customization.md +0 -100
  354. package/docs/ar/dictionary/get_started.md +0 -527
  355. package/docs/de/dictionary/content_extention_customization.md +0 -100
  356. package/docs/de/dictionary/get_started.md +0 -531
  357. package/docs/en/dictionary/content_extention_customization.md +0 -102
  358. package/docs/en/dictionary/get_started.md +0 -529
  359. package/docs/en-GB/dictionary/content_extention_customization.md +0 -100
  360. package/docs/en-GB/dictionary/get_started.md +0 -591
  361. package/docs/es/dictionary/content_extention_customization.md +0 -100
  362. package/docs/es/dictionary/get_started.md +0 -527
  363. package/docs/fr/dictionary/content_extention_customization.md +0 -100
  364. package/docs/fr/dictionary/get_started.md +0 -527
  365. package/docs/hi/dictionary/content_extention_customization.md +0 -100
  366. package/docs/hi/dictionary/get_started.md +0 -527
  367. package/docs/it/dictionary/content_extention_customization.md +0 -113
  368. package/docs/it/dictionary/get_started.md +0 -573
  369. package/docs/ja/dictionary/content_extention_customization.md +0 -113
  370. package/docs/ja/dictionary/get_started.md +0 -576
  371. package/docs/ko/dictionary/content_extention_customization.md +0 -100
  372. package/docs/ko/dictionary/get_started.md +0 -530
  373. package/docs/pt/dictionary/content_extention_customization.md +0 -100
  374. package/docs/pt/dictionary/get_started.md +0 -532
  375. package/docs/ru/dictionary/content_extention_customization.md +0 -100
  376. package/docs/ru/dictionary/get_started.md +0 -575
  377. package/docs/zh/dictionary/content_extention_customization.md +0 -117
  378. package/docs/zh/dictionary/get_started.md +0 -533
@@ -0,0 +1,200 @@
1
+ ---
2
+ createdAt: 2025-03-01
3
+ updatedAt: 2025-09-20
4
+ title: Testando seu conteúdo
5
+ description: Descubra como testar seu conteúdo com Intlayer.
6
+ keywords:
7
+ - Testes
8
+ - Intlayer
9
+ - Internacionalização
10
+ - CMS
11
+ - Sistema de Gestão de Conteúdo
12
+ - Editor Visual
13
+ slugs:
14
+ - doc
15
+ - testing
16
+ ---
17
+
18
+ # Testando seu conteúdo
19
+
20
+ Este guia mostra como verificar automaticamente se seus dicionários estão completos, detectar traduções faltantes antes do lançamento e testar a interface localizada em seu aplicativo.
21
+
22
+ ---
23
+
24
+ ## O que você pode testar
25
+
26
+ - **Traduções faltantes**: falhar no CI se algum idioma obrigatório estiver faltando em qualquer dicionário.
27
+ - **Renderização da interface localizada**: renderizar componentes com um provedor de idioma específico e verificar textos/atributos visíveis.
28
+ - **Auditorias em tempo de build**: executar uma auditoria rápida localmente via CLI.
29
+
30
+ ---
31
+
32
+ ## Início rápido: auditoria via CLI
33
+
34
+ Execute a auditoria a partir da raiz do seu projeto:
35
+
36
+ ```bash
37
+ npx intlayer content test
38
+ ```
39
+
40
+ Flags úteis:
41
+
42
+ - `--env-file [caminho]`: carrega variáveis de ambiente a partir de um arquivo.
43
+ - `-e, --env [nome]`: seleciona um perfil de ambiente.
44
+ - `--base-dir [caminho]`: define o diretório base do app para resolução.
45
+ - `--verbose`: exibe logs detalhados.
46
+ - `--prefix [rótulo]`: prefixa as linhas de log.
47
+
48
+ Nota: o CLI imprime um relatório detalhado, mas não retorna código de erro em caso de falhas. Para controle em CI, adicione um teste unitário (abaixo) que assegure que não há locais obrigatórios faltando.
49
+
50
+ ---
51
+
52
+ ## Teste programático (Vitest/Jest)
53
+
54
+ Use a API do CLI do Intlayer para garantir que não há traduções faltando para os locais obrigatórios.
55
+
56
+ ```ts fileName=i18n.test.ts
57
+ /* @vitest-environment node */
58
+ import { listMissingTranslations } from "intlayer/cli";
59
+ import { describe, expect, it } from "vitest";
60
+
61
+ describe("traduções", () => {
62
+ it("não possui locais obrigatórios faltando", () => {
63
+ const result = listMissingTranslations();
64
+
65
+ if (result.missingRequiredLocales.length > 0) {
66
+ // Útil quando o teste falha localmente ou no CI
67
+ console.log(result.missingTranslations);
68
+ }
69
+
70
+ expect(result.missingRequiredLocales).toHaveLength(0);
71
+ });
72
+ });
73
+ ```
74
+
75
+ Equivalente em Jest:
76
+
77
+ ```ts fileName=i18n.test.ts
78
+ import { listMissingTranslations } from "intlayer/cli";
79
+
80
+ test("não possui locais obrigatórios faltando", () => {
81
+ const result = listMissingTranslations();
82
+
83
+ if (result.missingRequiredLocales.length > 0) {
84
+ // eslint-disable-next-line no-console
85
+ console.log(result.missingTranslations);
86
+ }
87
+
88
+ expect(result.missingRequiredLocales).toHaveLength(0);
89
+ });
90
+ ```
91
+
92
+ Como funciona:
93
+
94
+ - O Intlayer lê sua configuração (locales, requiredLocales) e os dicionários declarados, então reporta:
95
+ - `missingTranslations`: por chave, quais locais estão faltando e de qual arquivo.
96
+ - `missingLocales`: união de todos os locais faltantes.
97
+ - `missingRequiredLocales`: subconjunto limitado a `requiredLocales` (ou todos os locais se `requiredLocales` não estiver definido).
98
+
99
+ ---
100
+
101
+ ## Testando UI localizada (React / Next.js)
102
+
103
+ Renderize componentes dentro de um provedor Intlayer e faça asserções no conteúdo visível.
104
+
105
+ Exemplo React (Testing Library):
106
+
107
+ ```tsx
108
+ import { IntlayerProvider } from "react-intlayer/client";
109
+ import { render, screen } from "@testing-library/react";
110
+ import { MyComponent } from "./MyComponent";
111
+
112
+ test("renders localized title in English", () => {
113
+ render(
114
+ <IntlayerProvider locale="en-US">
115
+ <MyComponent />
116
+ </IntlayerProvider>
117
+ );
118
+
119
+ expect(screen.getByText("Título esperado em inglês")).toBeInTheDocument();
120
+ });
121
+ ```
122
+
123
+ Exemplo Next.js (App Router): use o wrapper do framework:
124
+
125
+ ```tsx
126
+ import { IntlayerClientProvider } from "next-intlayer/client";
127
+ import { render, screen } from "@testing-library/react";
128
+ import { MyPage } from "./MyPage";
129
+
130
+ test("renderiza título localizado em francês", () => {
131
+ render(
132
+ <IntlayerClientProvider locale="fr-FR">
133
+ <MyPage />
134
+ </IntlayerClientProvider>
135
+ );
136
+ expect(
137
+ screen.getByRole("heading", { name: "Titre attendu" })
138
+ ).toBeInTheDocument();
139
+ });
140
+ ```
141
+
142
+ Dicas:
143
+
144
+ - Quando precisar dos valores brutos das strings para atributos (ex.: `aria-label`), acesse o campo `.value` retornado por `useIntlayer` no React.
145
+ - Mantenha os dicionários localizados junto com os componentes para facilitar os testes unitários e a limpeza.
146
+
147
+ ---
148
+
149
+ ## Integração Contínua
150
+
151
+ Adicione um teste que falhe a build quando traduções obrigatórias estiverem faltando.
152
+
153
+ `package.json`:
154
+
155
+ ```json
156
+ {
157
+ "scripts": {
158
+ "test:i18n": "vitest run -c"
159
+ }
160
+ }
161
+ ```
162
+
163
+ Exemplo GitHub Actions:
164
+
165
+ ```yaml
166
+ name: CI
167
+ on: [push, pull_request]
168
+ jobs:
169
+ test:
170
+ runs-on: ubuntu-latest
171
+ steps:
172
+ - uses: actions/checkout@v4
173
+ - uses: actions/setup-node@v4
174
+ with:
175
+ node-version: 20
176
+ - run: npm ci
177
+ - run: npm run test:i18n
178
+ ```
179
+
180
+ Opcional: execute a auditoria CLI para um resumo legível por humanos junto com os testes:
181
+
182
+ ```bash
183
+ npx intlayer content test --verbose
184
+ ```
185
+
186
+ ---
187
+
188
+ ## Solução de Problemas
189
+
190
+ - Certifique-se de que sua configuração do Intlayer define `locales` e (opcionalmente) `requiredLocales`.
191
+ - Se seu aplicativo usa dicionários dinâmicos ou remotos, execute os testes em um ambiente onde os dicionários estejam disponíveis.
192
+ - Para monorepos mistos, use `--base-dir` para apontar o CLI para a raiz correta da aplicação.
193
+
194
+ ---
195
+
196
+ ## Histórico do Documento
197
+
198
+ | Versão | Data | Alterações |
199
+ | ------ | ---------- | --------------------- |
200
+ | 6.0.0 | 2025-09-20 | Introdução dos testes |
@@ -1,8 +1,8 @@
1
1
  ---
2
2
  createdAt: 2025-03-13
3
- updatedAt: 2025-06-29
3
+ updatedAt: 2025-09-20
4
4
  title: Автозаполнение
5
- description: Узнайте, как использовать функцию автозаполнения в Intlayer для автоматического заполнения контента на основе предопределённых шаблонов. Следуйте этой документации, чтобы эффективно реализовать функции автозаполнения в вашем проекте.
5
+ description: Узнайте, как использовать функцию автозаполнения в Intlayer для автоматического заполнения контента на основе предопределённых шаблонов. Следуйте этой документации, чтобы эффективно внедрить функции автозаполнения в вашем проекте.
6
6
  keywords:
7
7
  - Автозаполнение
8
8
  - Автоматизация контента
@@ -17,28 +17,28 @@ slugs:
17
17
  - auto-fill
18
18
  ---
19
19
 
20
- # Файлы декларации контента с автозаполнением
20
+ # Переводы файлов декларации автозаполнения контента
21
21
 
22
- **Файлы декларации контента с автозаполнением** - это способ ускорить ваш процесс разработки.
23
- Механизм автозаполнения работает через отношение _мастер-слейв_ между файлами декларации контента. Когда основной (мастер) файл обновляется, Intlayer автоматически применяет эти изменения к производным (автозаполненным) файлам декларации.
22
+ **Файлы декларации автозаполнения контента** это способ ускорить ваш процесс разработки.
23
+
24
+ Механизм автозаполнения работает через _мастер-слейв_ отношения между файлами декларации контента. Когда основной (мастер) файл обновляется, Intlayer автоматически применяет эти изменения к производным (автозаполненным) файлам декларации.
24
25
 
25
26
  ```ts fileName="src/components/example/example.content.ts"
26
27
  import { Locales, type Dictionary } from "intlayer";
27
28
 
28
- // Основной файл декларации контента с автозаполнением
29
29
  const exampleContent = {
30
30
  key: "example",
31
31
  locale: Locales.ENGLISH,
32
32
  autoFill: "./example.content.json",
33
33
  content: {
34
- contentExample: "This is an example of content", // Это пример содержимого
34
+ contentExample: "Это пример контента", // пример контента
35
35
  },
36
36
  } satisfies Dictionary;
37
37
 
38
38
  export default exampleContent;
39
39
  ```
40
40
 
41
- Вот [файл декларации контента для каждого языка](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ru/per_locale_file.md), использующий инструкцию `autoFill`.
41
+ Вот [файл декларации контента для каждого локаля](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ru/per_locale_file.md), использующий инструкцию `autoFill`.
42
42
 
43
43
  Затем, когда вы выполните следующую команду:
44
44
 
@@ -46,7 +46,7 @@ export default exampleContent;
46
46
  npx intlayer fill --file 'src/components/example/example.content.ts'
47
47
  ```
48
48
 
49
- Intlayer автоматически сгенерирует производный файл декларации по пути `src/components/example/example.content.json`, заполнив все локали, которые ещё не объявлены в основном файле.
49
+ Intlayer автоматически сгенерирует производный файл декларации по пути `src/components/example/example.content.json`, заполняя все локали, которые ещё не объявлены в основном файле.
50
50
 
51
51
  ```json5 fileName="src/components/example/example.content.json"
52
52
  {
@@ -63,23 +63,23 @@ Intlayer автоматически сгенерирует производны
63
63
  }
64
64
  ```
65
65
 
66
- После этого оба файла декларации будут объединены в один словарь, доступный через стандартный хук `useIntlayer("example")` (react) / композицию (vue).
66
+ После этого оба файла деклараций будут объединены в один словарь, доступный через стандартный хук `useIntlayer("example")` (react) / композицию (vue).
67
67
 
68
- ## Формат файла с автозаполнением
68
+ ## Формат автозаполненного файла
69
69
 
70
- Рекомендуемый формат для автоматически заполняемых файлов деклараций - **JSON**, что помогает избежать ограничений форматирования. Однако Intlayer также поддерживает форматы `.ts`, `.js`, `.mjs`, `.cjs` и другие.
70
+ Рекомендуемый формат для автоматически заполняемых файлов деклараций **JSON**, который помогает избежать ограничений форматирования. Однако Intlayer также поддерживает форматы `.ts`, `.js`, `.mjs`, `.cjs` и другие.
71
71
 
72
72
  ```ts fileName="src/components/example/example.content.ts"
73
73
  const exampleContent = {
74
74
  key: "example",
75
75
  autoFill: "./example.filled.content.ts",
76
76
  content: {
77
- // Ваш контент
77
+ // Ваше содержимое
78
78
  },
79
79
  };
80
80
  ```
81
81
 
82
- Это создаст файл по пути:
82
+ Это сгенерирует файл по адресу:
83
83
 
84
84
  ```
85
85
  src/components/example/example.filled.content.ts
@@ -87,8 +87,8 @@ src/components/example/example.filled.content.ts
87
87
 
88
88
  > Генерация файлов `.js`, `.ts` и подобных работает следующим образом:
89
89
  >
90
- > - Если файл уже существует, Intlayer проанализирует его с помощью AST (Абстрактного Синтаксического Дерева), чтобы найти каждое поле и вставить отсутствующие переводы.
91
- > - Если файл не существует, Intlayer создаст его, используя шаблон файла декларации контента по умолчанию.
90
+ > - Если файл уже существует, Intlayer будет парсить его с помощью AST (Абстрактного синтаксического дерева), чтобы найти каждое поле и вставить отсутствующие переводы.
91
+ > - Если файл не существует, Intlayer сгенерирует его, используя шаблон файла декларации содержимого по умолчанию.
92
92
 
93
93
  ## Абсолютные пути
94
94
 
@@ -99,20 +99,20 @@ const exampleContent = {
99
99
  key: "example",
100
100
  autoFill: "/messages/example.content.json",
101
101
  content: {
102
- // Ваш контент
102
+ // Ваше содержимое
103
103
  },
104
104
  };
105
105
  ```
106
106
 
107
- Это создаст файл по пути:
107
+ Это сгенерирует файл по адресу:
108
108
 
109
109
  ```
110
110
  /messages/example.content.json
111
111
  ```
112
112
 
113
- ## Автоматическая генерация файлов декларации контента для каждого локаля
113
+ ## Автоматическая генерация файлов деклараций содержимого для каждого локаля
114
114
 
115
- Поле `autoFill` также поддерживает генерацию файлов декларации контента **для каждого локаля**.
115
+ Поле `autoFill` также поддерживает генерацию файлов деклараций содержимого **для каждого локаля**.
116
116
 
117
117
  ```ts fileName="src/components/example/example.content.ts"
118
118
  const exampleContent = {
@@ -122,17 +122,19 @@ const exampleContent = {
122
122
  es: "./example.es.content.json",
123
123
  },
124
124
  content: {
125
- // Ваш контент
125
+ // Ваше содержимое
126
126
  },
127
127
  };
128
128
  ```
129
129
 
130
- Это создаст два отдельных файла:
130
+ Это сгенерирует два отдельных файла:
131
131
 
132
132
  - `src/components/example/example.fr.content.json`
133
133
  - `src/components/example/example.es.content.json`
134
134
 
135
- ## Фильтрация автозаполнения по конкретному локалю
135
+ > В этом случае, если объект не содержит все локали, Intlayer пропускает генерацию оставшихся локалей.
136
+
137
+ ## Фильтрация автозаполнения для конкретной локали
136
138
 
137
139
  Использование объекта в поле `autoFill` позволяет применять фильтры и генерировать файлы только для определённых локалей.
138
140
 
@@ -143,37 +145,57 @@ const exampleContent = {
143
145
  fr: "./example.fr.content.json",
144
146
  },
145
147
  content: {
146
- // Ваш контент
148
+ // Ваше содержимое
147
149
  },
148
150
  };
149
151
  ```
150
152
 
151
- Это создаст только файл перевода для французского языка.
153
+ Это сгенерирует только файл перевода на французский язык.
152
154
 
153
155
  ## Переменные пути
154
156
 
155
- Вы можете использовать переменные внутри пути `autoFill` для динамического определения целевых путей создаваемых файлов.
157
+ Вы можете использовать переменные внутри пути `autoFill` для динамического определения целевых путей для сгенерированных файлов.
156
158
 
157
159
  **Доступные переменные:**
158
160
 
159
161
  - `{{locale}}` – Код локали (например, `fr`, `es`)
162
+ - `{{fileName}}` – Имя файла (например, `index`)
160
163
  - `{{key}}` – Ключ словаря (например, `example`)
161
164
 
162
- ```ts fileName="src/components/example/example.content.ts"
165
+ ```ts fileName="src/components/example/index.content.ts"
163
166
  const exampleContent = {
164
167
  key: "example",
165
168
  autoFill: "/messages/{{locale}}/{{key}}.content.json",
166
169
  content: {
167
- // Ваш контент
170
+ // Ваше содержимое
168
171
  },
169
172
  };
170
173
  ```
171
174
 
172
- Это создаст:
175
+ Это сгенерирует:
173
176
 
174
177
  - `/messages/fr/example.content.json`
175
178
  - `/messages/es/example.content.json`
176
179
 
180
+ ```ts fileName="src/components/example/index.content.ts"
181
+ const exampleContent = {
182
+ key: "example",
183
+ autoFill: "./{{fileName}}.content.json",
184
+ content: {
185
+ // Ваше содержимое
186
+ },
187
+ };
188
+ ```
189
+
190
+ Это сгенерирует:
191
+
192
+ - `./index.content.json`
193
+ - `./index.content.json`
194
+
177
195
  ## История документации
178
196
 
179
- - 5.5.10 - 2025-06-29: Инициализация истории
197
+ | Версия | Дата | Изменения |
198
+ | ------- | ---------- | -------------------------- |
199
+ | 6.0.0 | 2025-09-20 | Добавлена глобальная конфигурация |
200
+ | 6.0.0 | 2025-09-17 | Добавлена переменная `{{fileName}}` |
201
+ | 5.5.10 | 2025-06-29 | Инициализация истории |