@intlayer/docs 8.12.2 → 8.12.4-canary.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/blog.cjs.map +1 -1
- package/dist/cjs/common.cjs.map +1 -1
- package/dist/cjs/doc.cjs.map +1 -1
- package/dist/cjs/frequentQuestions.cjs.map +1 -1
- package/dist/cjs/generated/blog.entry.cjs +1 -0
- package/dist/cjs/generated/blog.entry.cjs.map +1 -1
- package/dist/cjs/generated/docs.entry.cjs +1 -0
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/cjs/generated/frequentQuestions.entry.cjs +1 -0
- package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
- package/dist/cjs/generated/legal.entry.cjs +1 -0
- package/dist/cjs/generated/legal.entry.cjs.map +1 -1
- package/dist/cjs/legal.cjs.map +1 -1
- package/dist/esm/blog.mjs.map +1 -1
- package/dist/esm/common.mjs.map +1 -1
- package/dist/esm/doc.mjs.map +1 -1
- package/dist/esm/frequentQuestions.mjs.map +1 -1
- package/dist/esm/generated/blog.entry.mjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
- package/dist/esm/generated/legal.entry.mjs.map +1 -1
- package/dist/esm/legal.mjs.map +1 -1
- package/dist/types/blog.d.ts.map +1 -1
- package/dist/types/common.d.ts.map +1 -1
- package/dist/types/doc.d.ts.map +1 -1
- package/dist/types/frequentQuestions.d.ts.map +1 -1
- package/dist/types/legal.d.ts.map +1 -1
- package/docs/ar/bundle_optimization.md +250 -102
- package/docs/ar/configuration.md +10 -10
- package/docs/bn/bundle_optimization.md +252 -104
- package/docs/bn/configuration.md +10 -10
- package/docs/cs/bundle_optimization.md +253 -105
- package/docs/cs/configuration.md +10 -10
- package/docs/de/bundle_optimization.md +245 -97
- package/docs/de/configuration.md +10 -10
- package/docs/en/bundle_optimization.md +172 -49
- package/docs/en/configuration.md +10 -10
- package/docs/en-GB/bundle_optimization.md +230 -82
- package/docs/en-GB/configuration.md +10 -10
- package/docs/es/bundle_optimization.md +250 -102
- package/docs/es/configuration.md +10 -10
- package/docs/fr/bundle_optimization.md +223 -75
- package/docs/fr/configuration.md +10 -10
- package/docs/hi/bundle_optimization.md +253 -105
- package/docs/hi/configuration.md +10 -10
- package/docs/id/bundle_optimization.md +258 -110
- package/docs/id/configuration.md +10 -10
- package/docs/it/bundle_optimization.md +249 -103
- package/docs/it/configuration.md +10 -10
- package/docs/ja/bundle_optimization.md +245 -97
- package/docs/ja/configuration.md +10 -10
- package/docs/ko/bundle_optimization.md +253 -105
- package/docs/ko/configuration.md +10 -10
- package/docs/nl/bundle_optimization.md +249 -101
- package/docs/nl/configuration.md +10 -10
- package/docs/pl/bundle_optimization.md +258 -111
- package/docs/pl/configuration.md +10 -10
- package/docs/pt/bundle_optimization.md +256 -115
- package/docs/pt/configuration.md +10 -10
- package/docs/ru/bundle_optimization.md +253 -105
- package/docs/ru/configuration.md +10 -10
- package/docs/tr/bundle_optimization.md +255 -107
- package/docs/tr/configuration.md +10 -10
- package/docs/uk/bundle_optimization.md +250 -102
- package/docs/uk/configuration.md +10 -10
- package/docs/ur/bundle_optimization.md +257 -109
- package/docs/ur/configuration.md +10 -10
- package/docs/vi/bundle_optimization.md +259 -111
- package/docs/vi/configuration.md +10 -10
- package/docs/zh/bundle_optimization.md +260 -112
- package/docs/zh/configuration.md +10 -10
- package/docs/zh-TW/bundle_optimization.md +602 -0
- package/package.json +8 -8
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
---
|
|
2
2
|
createdAt: 2025-11-25
|
|
3
|
-
updatedAt: 2026-
|
|
3
|
+
updatedAt: 2026-06-07
|
|
4
4
|
title: تحسين حجم وأداء حزمة i18n
|
|
5
|
-
description:
|
|
5
|
+
description: قم بتقليل حجم حزمة تطبيقك عن طريق تحسين محتوى التدويل (i18n). تعلم كيفية الاستفادة من "tree shaking" والتحميل الكسول (lazy loading) للقواميس مع Intlayer.
|
|
6
6
|
keywords:
|
|
7
|
-
- تحسين الحزمة
|
|
7
|
+
- تحسين الحزمة (Bundle Optimization)
|
|
8
8
|
- أتمتة المحتوى
|
|
9
9
|
- المحتوى الديناميكي
|
|
10
10
|
- Intlayer
|
|
@@ -16,33 +16,36 @@ slugs:
|
|
|
16
16
|
- concept
|
|
17
17
|
- bundle-optimization
|
|
18
18
|
history:
|
|
19
|
+
- version: 8.12.0
|
|
20
|
+
date: 2026-06-07
|
|
21
|
+
changes: "تمت إضافة `intlayerPurgeBabelPlugin` و `intlayerMinifyBabelPlugin` لـ Babel/Webpack؛ توضيح مسار الإضافات (plugin pipeline)"
|
|
19
22
|
- version: 8.7.0
|
|
20
23
|
date: 2026-04-08
|
|
21
|
-
changes: "إضافة
|
|
24
|
+
changes: "إضافة خياري `minify` و `purge` لإعدادات البناء"
|
|
22
25
|
---
|
|
23
26
|
|
|
24
27
|
# تحسين حجم وأداء حزمة i18n
|
|
25
28
|
|
|
26
|
-
|
|
29
|
+
أحد أكثر التحديات شيوعًا مع حلول i18n التقليدية التي تعتمد على ملفات JSON هو إدارة حجم المحتوى. إذا لم يقم المطورون بتقسيم المحتوى يدويًا إلى مساحات أسماء (namespaces)، فغالبًا ما ينتهي الأمر بالمستخدمين بتنزيل الترجمات الخاصة بكل صفحة وربما لكل لغة فقط لعرض صفحة واحدة.
|
|
27
30
|
|
|
28
|
-
على سبيل المثال،
|
|
31
|
+
على سبيل المثال، تطبيق يحتوي على 10 صفحات مترجمة إلى 10 لغات قد يتسبب في قيام المستخدم بتنزيل محتوى الـ 100 صفحة، على الرغم من أنه يحتاج فقط إلى **واحدة** (الصفحة الحالية باللغة الحالية). يؤدي هذا إلى إهدار عرض النطاق الترددي وبطء في أوقات التحميل.
|
|
29
32
|
|
|
30
|
-
|
|
33
|
+
**يحل Intlayer هذه المشكلة من خلال التحسين في وقت البناء.** فهو يحلل الكود الخاص بك لاكتشاف القواميس التي يتم استخدامها فعليًا لكل مكون ويعيد إدراج المحتوى الضروري فقط في حزمتك.
|
|
31
34
|
|
|
32
35
|
## جدول المحتويات
|
|
33
36
|
|
|
34
37
|
<TOC />
|
|
35
38
|
|
|
36
|
-
##
|
|
39
|
+
## قم بتحليل حزمتك
|
|
37
40
|
|
|
38
|
-
|
|
41
|
+
يُعد تحليل حزمتك هو الخطوة الأولى لتحديد ملفات JSON "الثقيلة" وفرص تقسيم الكود (code-splitting). تُنشئ هذه الأدوات مخططًا شجريًا (treemap) مرئيًا للكود المترجم لتطبيقك، مما يسمح لك بمعرفة أي المكتبات تستهلك المساحة الأكبر بالضبط.
|
|
39
42
|
|
|
40
43
|
<Tabs>
|
|
41
44
|
<Tab value="vite">
|
|
42
45
|
|
|
43
46
|
### Vite / Rollup
|
|
44
47
|
|
|
45
|
-
يستخدم Vite
|
|
48
|
+
يستخدم Vite الـ Rollup تحت الغطاء. تُنشئ الإضافة `rollup-plugin-visualizer` ملف HTML تفاعليًا يوضح حجم كل وحدة في الرسم البياني الخاص بك.
|
|
46
49
|
|
|
47
50
|
```bash
|
|
48
51
|
npm install -D rollup-plugin-visualizer
|
|
@@ -69,7 +72,7 @@ export default defineConfig({
|
|
|
69
72
|
|
|
70
73
|
### Next.js (Turbopack)
|
|
71
74
|
|
|
72
|
-
للمشاريع التي تستخدم App Router
|
|
75
|
+
للمشاريع التي تستخدم الـ App Router والـ Turbopack، يوفر Next.js محللًا تجريبيًا مدمجًا لا يتطلب أي تبعيات إضافية.
|
|
73
76
|
|
|
74
77
|
```bash packageManager='npm'
|
|
75
78
|
npx next experimental-analyze
|
|
@@ -92,7 +95,7 @@ bun next experimental-analyze
|
|
|
92
95
|
|
|
93
96
|
### Next.js (Webpack)
|
|
94
97
|
|
|
95
|
-
إذا كنت تستخدم
|
|
98
|
+
إذا كنت تستخدم مُحزم Webpack الافتراضي في Next.js، فاستخدم المحلل الرسمي للحزم (bundle analyzer). قم بتشغيله عن طريق تعيين متغير بيئة أثناء البناء.
|
|
96
99
|
|
|
97
100
|
```bash packageManager='npm'
|
|
98
101
|
npm install -D @next/bundle-analyzer
|
|
@@ -116,7 +119,7 @@ const withBundleAnalyzer = require("@next/bundle-analyzer")({
|
|
|
116
119
|
});
|
|
117
120
|
|
|
118
121
|
module.exports = withBundleAnalyzer({
|
|
119
|
-
//
|
|
122
|
+
// إعدادات Next.js الخاصة بك
|
|
120
123
|
});
|
|
121
124
|
```
|
|
122
125
|
|
|
@@ -129,9 +132,9 @@ ANALYZE=true npm run build
|
|
|
129
132
|
</Tab>
|
|
130
133
|
<Tab value="Webpack (CRA / Angular / etc)">
|
|
131
134
|
|
|
132
|
-
### Webpack
|
|
135
|
+
### Standard Webpack
|
|
133
136
|
|
|
134
|
-
|
|
137
|
+
لـ Create React App (ejected)، أو Angular، أو إعدادات Webpack المخصصة، استخدم المعيار الصناعي `webpack-bundle-analyzer`.
|
|
135
138
|
|
|
136
139
|
```bash packageManager='npm'
|
|
137
140
|
npm install -D webpack-bundle-analyzer
|
|
@@ -166,18 +169,55 @@ export default {
|
|
|
166
169
|
</Tab>
|
|
167
170
|
</Tabs>
|
|
168
171
|
|
|
169
|
-
## كيف
|
|
172
|
+
## كيف يعمل
|
|
170
173
|
|
|
171
|
-
|
|
174
|
+
يستخدم Intlayer **نهجًا لكل مكون**. بخلاف ملفات JSON العامة، يتم تعريف المحتوى الخاص بك بجانب مكوناتك أو بداخلها. أثناء عملية البناء، يقوم Intlayer بـ:
|
|
172
175
|
|
|
173
|
-
1.
|
|
174
|
-
2.
|
|
175
|
-
3.
|
|
176
|
+
1. **تحليل** الكود الخاص بك للعثور على استدعاءات `useIntlayer`.
|
|
177
|
+
2. **بناء** محتوى القاموس المقابل.
|
|
178
|
+
3. **استبدال** استدعاء `useIntlayer` بكود مُحسّن استنادًا إلى إعداداتك.
|
|
176
179
|
|
|
177
|
-
هذا
|
|
180
|
+
يضمن هذا ما يلي:
|
|
178
181
|
|
|
179
|
-
- إذا لم يتم استيراد مكون، فلن يتم تضمين محتواه في الحزمة (
|
|
180
|
-
- إذا
|
|
182
|
+
- إذا لم يتم استيراد مكون، فلن يتم تضمين محتواه في الحزمة (Dead Code Elimination).
|
|
183
|
+
- إذا كان المكون محملًا بكسل (lazy-loaded)، فسيتم تحميل محتواه بكسل أيضًا.
|
|
184
|
+
|
|
185
|
+
## مرجع الإضافات
|
|
186
|
+
|
|
187
|
+
يتم تقسيم تحسين البناء في Intlayer إلى عدة إضافات منفصلة، لكل منها مسؤولية واحدة. ففهم ما تفعله كل إضافة يمنع الارتباك عند إعدادها.
|
|
188
|
+
|
|
189
|
+
### إضافات Babel (`@intlayer/babel`)
|
|
190
|
+
|
|
191
|
+
تُستخدم هذه مباشرة في `babel.config.js` للإعدادات المستندة إلى Webpack (مثل Next.js مع Babel، CRA، Webpack المخصص، إلخ).
|
|
192
|
+
|
|
193
|
+
| الإضافة | ما تفعله |
|
|
194
|
+
| :---------------------------- | :------------------------------------------------------------------------------------------------------------------- |
|
|
195
|
+
| `intlayerExtractBabelPlugin` | تمسح ملفات `.content.ts` وتكتب القواميس المجمعة إلى `.intlayer/` |
|
|
196
|
+
| `intlayerOptimizeBabelPlugin` | تعيد كتابة `useIntlayer('key')` → `useDictionary(hash)` وتحقن الـ `import` المطابق للقاموس |
|
|
197
|
+
| `intlayerPurgeBabelPlugin` | تمسح جميع ملفات المصدر، تزيل **حقول المحتوى غير المستخدمة** من ملفات القاموس المجمعة `.intlayer/**/*.json` |
|
|
198
|
+
| `intlayerMinifyBabelPlugin` | **تعيد تسمية مفاتيح حقول المحتوى** إلى أسماء مستعارة أبجدية قصيرة (`title` → `a`) في كل من ملفات JSON والكود المصدري |
|
|
199
|
+
|
|
200
|
+
> **ترتيب الإضافات مهم.** في `babel.config.js` يجب أن تظهر إضافات التطهير (purge) والتصغير (minify) **قبل** إضافة التحسين (optimize). تقوم خطوة التحسين باستبدال `useIntlayer('key')` باستدعاء مبهم لـ `useDictionary(hash)`، مما يمحو معلومات مفتاح القاموس التي تحتاجها خطوات التطهير والتصغير لتحديد الحقول المستخدمة.
|
|
201
|
+
|
|
202
|
+
يحتوي كل مُكوّن إضافي في Babel على مساعد خيارات مطابق يقرأ `intlayer.config.ts` الخاص بك مرة واحدة في وقت تحميل الإعدادات ويُرجع قيمًا محلولة مسبقًا:
|
|
203
|
+
|
|
204
|
+
| مساعد الخيارات (Options helper) | يُستخدم مع |
|
|
205
|
+
| :------------------------------ | :---------------------------- |
|
|
206
|
+
| `getExtractPluginOptions()` | `intlayerExtractBabelPlugin` |
|
|
207
|
+
| `getOptimizePluginOptions()` | `intlayerOptimizeBabelPlugin` |
|
|
208
|
+
| `getPurgePluginOptions()` | `intlayerPurgeBabelPlugin` |
|
|
209
|
+
| `getMinifyPluginOptions()` | `intlayerMinifyBabelPlugin` |
|
|
210
|
+
|
|
211
|
+
### إضافات Vite (`vite-intlayer`)
|
|
212
|
+
|
|
213
|
+
لا يحتاج مستخدمو Vite **مطلقًا لإعداد هذه بشكل مباشر**. يتم ربطها تلقائيًا عند استدعاء `withIntlayer()` في `vite.config.ts`. تقوم الأعلام `build.purge` و `build.minify` في `intlayer.config.ts` بتبديل السلوك المقابل دون أي تسجيل إضافي للإضافات.
|
|
214
|
+
|
|
215
|
+
| إضافة Vite الداخلية | السلوك المكافئ |
|
|
216
|
+
| :------------------ | :--------------------------------------------------------------------------------------------- |
|
|
217
|
+
| Usage analyzer | نفس مسار التحليل في `intlayerPurgeBabelPlugin` |
|
|
218
|
+
| Dictionary prune | نفس مسار كتابة JSON في `intlayerPurgeBabelPlugin` |
|
|
219
|
+
| Dictionary minify | نفس مسار كتابة JSON في `intlayerMinifyBabelPlugin` |
|
|
220
|
+
| Babel transform | نفس مسار إعادة تسمية كود المصدر لـ `intlayerMinifyBabelPlugin` + `intlayerOptimizeBabelPlugin` |
|
|
181
221
|
|
|
182
222
|
## الإعداد حسب المنصة
|
|
183
223
|
|
|
@@ -186,9 +226,9 @@ export default {
|
|
|
186
226
|
|
|
187
227
|
### Next.js
|
|
188
228
|
|
|
189
|
-
يتطلب Next.js إضافة `@intlayer/swc`
|
|
229
|
+
يتطلب Next.js إضافة `@intlayer/swc` لخطوة التحسين (إعادة كتابة الاستيراد)، لأن Next.js يستخدم SWC للبناء.
|
|
190
230
|
|
|
191
|
-
>
|
|
231
|
+
> لا يتم تثبيت هذا المكون الإضافي افتراضيًا لأن مكونات SWC لا تزال تجريبية لـ Next.js. قد يتغير هذا في المستقبل.
|
|
192
232
|
|
|
193
233
|
```bash packageManager="npm"
|
|
194
234
|
npm install -D @intlayer/swc
|
|
@@ -206,21 +246,63 @@ pnpm add -D @intlayer/swc
|
|
|
206
246
|
bun add -d @intlayer/swc
|
|
207
247
|
```
|
|
208
248
|
|
|
209
|
-
بمجرد التثبيت،
|
|
249
|
+
بمجرد التثبيت، سيكتشف Intlayer ويستخدم الإضافة تلقائيًا.
|
|
250
|
+
|
|
251
|
+
بالنسبة لخطوات **التطهير (purge) والتصغير (minify)** (إزالة الحقول وإعادة تسميتها)، قم بتثبيت `@intlayer/babel` بجانبه وأضف إضافات Babel. نظرًا لأن Next.js يستخدم SWC للتحويل ولكنه لا يزال يقيّم `babel.config.js` لإعدادات الإضافات، يتم تشغيل إضافات Babel كخطوة مسبقة قبل SWC.
|
|
252
|
+
|
|
253
|
+
```bash packageManager="npm"
|
|
254
|
+
npm install -D @intlayer/babel
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
```javascript fileName="babel.config.js"
|
|
258
|
+
const {
|
|
259
|
+
intlayerPurgeBabelPlugin,
|
|
260
|
+
intlayerMinifyBabelPlugin,
|
|
261
|
+
getPurgePluginOptions,
|
|
262
|
+
getMinifyPluginOptions,
|
|
263
|
+
} = require("@intlayer/babel");
|
|
264
|
+
|
|
265
|
+
module.exports = {
|
|
266
|
+
presets: ["next/babel"],
|
|
267
|
+
plugins: [
|
|
268
|
+
// Purge: يزيل حقول المحتوى غير المستخدمة من .intlayer/**/*.json
|
|
269
|
+
[intlayerPurgeBabelPlugin, getPurgePluginOptions()],
|
|
270
|
+
// Minify: يعيد تسمية مفاتيح حقول المحتوى في ملف JSON + الكود المصدري
|
|
271
|
+
[intlayerMinifyBabelPlugin, getMinifyPluginOptions()],
|
|
272
|
+
// ملاحظة: intlayerOptimizeBabelPlugin غير مطلوب هنا لأن
|
|
273
|
+
// @intlayer/swc يتعامل مع إعادة كتابة useIntlayer → useDictionary.
|
|
274
|
+
],
|
|
275
|
+
};
|
|
276
|
+
```
|
|
210
277
|
|
|
211
278
|
</Tab>
|
|
212
279
|
<Tab value="vite">
|
|
213
280
|
|
|
214
281
|
### Vite
|
|
215
282
|
|
|
216
|
-
يستخدم Vite
|
|
283
|
+
يستخدم Vite الإضافة `@intlayer/babel`، والتي يتم تضمينها كتبعية لـ `vite-intlayer`. يتم تشغيل خط أنابيب التحسين الكامل - إعادة كتابة الاستيراد والتطهير والتصغير - افتراضيًا ولا يتطلب أي تسجيل إضافي.
|
|
284
|
+
|
|
285
|
+
قم بتفعيل الـ purge و الـ minify عن طريق ضبط الأعلام المقابلة في `intlayer.config.ts`:
|
|
286
|
+
|
|
287
|
+
```typescript fileName="intlayer.config.ts"
|
|
288
|
+
import type { IntlayerConfig } from "intlayer";
|
|
289
|
+
|
|
290
|
+
const config: IntlayerConfig = {
|
|
291
|
+
build: {
|
|
292
|
+
purge: true, // يزيل حقول المحتوى غير المستخدمة من ملفات JSON المجمعة
|
|
293
|
+
minify: true, // يعيد تسمية مفاتيح حقول المحتوى إلى أسماء مستعارة قصيرة
|
|
294
|
+
},
|
|
295
|
+
};
|
|
296
|
+
|
|
297
|
+
export default config;
|
|
298
|
+
```
|
|
217
299
|
|
|
218
300
|
</Tab>
|
|
219
301
|
<Tab value="webpack">
|
|
220
302
|
|
|
221
|
-
### Webpack
|
|
303
|
+
### Webpack (و Next.js مع Babel)
|
|
222
304
|
|
|
223
|
-
|
|
305
|
+
تثبيت `@intlayer/babel`:
|
|
224
306
|
|
|
225
307
|
```bash packageManager="npm"
|
|
226
308
|
npm install -D @intlayer/babel
|
|
@@ -238,73 +320,101 @@ pnpm add -D @intlayer/babel
|
|
|
238
320
|
bun add -d @intlayer/babel
|
|
239
321
|
```
|
|
240
322
|
|
|
241
|
-
|
|
323
|
+
أضف جميع الإضافات الأربعة إلى `babel.config.js` بالترتيب الصحيح:
|
|
324
|
+
|
|
325
|
+
```javascript fileName="babel.config.js"
|
|
242
326
|
const {
|
|
243
|
-
|
|
327
|
+
intlayerExtractBabelPlugin,
|
|
328
|
+
intlayerPurgeBabelPlugin,
|
|
329
|
+
intlayerMinifyBabelPlugin,
|
|
244
330
|
intlayerOptimizeBabelPlugin,
|
|
331
|
+
getExtractPluginOptions,
|
|
332
|
+
getPurgePluginOptions,
|
|
333
|
+
getMinifyPluginOptions,
|
|
334
|
+
getOptimizePluginOptions,
|
|
245
335
|
} = require("@intlayer/babel");
|
|
246
336
|
|
|
247
337
|
module.exports = {
|
|
248
|
-
plugins: [
|
|
338
|
+
plugins: [
|
|
339
|
+
// Extract: يجمّع ملفات .content.ts → .intlayer/**/*.json
|
|
340
|
+
[intlayerExtractBabelPlugin, getExtractPluginOptions()],
|
|
341
|
+
|
|
342
|
+
// Purge: يزيل الحقول غير المستخدمة من .intlayer/**/*.json
|
|
343
|
+
// (يقرأ العلم build.purge من intlayer.config.ts)
|
|
344
|
+
[intlayerPurgeBabelPlugin, getPurgePluginOptions()],
|
|
345
|
+
|
|
346
|
+
// Minify: يعيد تسمية مفاتيح الحقول في JSON + الكود المصدري
|
|
347
|
+
// (يقرأ العلم build.minify من intlayer.config.ts)
|
|
348
|
+
[intlayerMinifyBabelPlugin, getMinifyPluginOptions()],
|
|
349
|
+
|
|
350
|
+
// Optimize: يعيد كتابة useIntlayer('key') → useDictionary(hash)
|
|
351
|
+
// يجب أن يأتي أخيرًا لأنه يمحو مفتاح القاموس.
|
|
352
|
+
[intlayerOptimizeBabelPlugin, getOptimizePluginOptions()],
|
|
353
|
+
],
|
|
249
354
|
};
|
|
250
355
|
```
|
|
251
356
|
|
|
252
357
|
</Tab>
|
|
253
358
|
</Tabs>
|
|
254
359
|
|
|
255
|
-
## التكوين
|
|
360
|
+
## التكوين (Configuration)
|
|
256
361
|
|
|
257
|
-
يمكنك التحكم في كيفية
|
|
362
|
+
يمكنك التحكم في كيفية قيام Intlayer بتحسين حزمتك عبر الخاصية `build` في ملف `intlayer.config.ts`.
|
|
258
363
|
|
|
259
364
|
```typescript fileName="intlayer.config.ts"
|
|
260
365
|
import { Locales, type IntlayerConfig } from "intlayer";
|
|
261
366
|
|
|
262
367
|
const config: IntlayerConfig = {
|
|
263
368
|
internationalization: {
|
|
264
|
-
locales: [Locales.ENGLISH, Locales.
|
|
369
|
+
locales: [Locales.ENGLISH, Locales.ARABIC],
|
|
265
370
|
defaultLocale: Locales.ENGLISH,
|
|
266
371
|
},
|
|
267
372
|
dictionary: {
|
|
268
373
|
importMode: "dynamic",
|
|
269
374
|
},
|
|
270
375
|
build: {
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
* يشير إلى ما إذا كان يجب على البناء التحقق من أنواع TypeScript
|
|
283
|
-
*/
|
|
284
|
-
checkTypes: false;
|
|
376
|
+
// استبدال استدعاءات useIntlayer() باستيرادات مباشرة للقاموس في وقت البناء.
|
|
377
|
+
// undefined = تلقائي (مُمكّن في الإنتاج), true = دائمًا, false = أبدًا.
|
|
378
|
+
optimize: undefined,
|
|
379
|
+
|
|
380
|
+
// إعادة تسمية مفاتيح حقول المحتوى في القواميس المجمعة إلى أسماء مستعارة
|
|
381
|
+
// أبجدية قصيرة (مثل title → a). يقلل من حجم JSON؛ يتطلب optimize.
|
|
382
|
+
minify: true,
|
|
383
|
+
|
|
384
|
+
// إزالة حقول المحتوى التي لا يتم الوصول إليها أبدًا في الكود المصدري.
|
|
385
|
+
// يتطلب optimize.
|
|
386
|
+
purge: true,
|
|
285
387
|
},
|
|
286
388
|
};
|
|
287
389
|
|
|
288
390
|
export default config;
|
|
289
391
|
```
|
|
290
392
|
|
|
291
|
-
>
|
|
393
|
+
> يُوصى بالاحتفاظ بالقيمة الافتراضية (`undefined`) للتحسين `optimize` في معظم الحالات.
|
|
292
394
|
|
|
293
|
-
> راجع
|
|
395
|
+
> راجع مرجع التكوين للحصول على جميع الخيارات: [التكوين](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ar/configuration.md)
|
|
294
396
|
|
|
295
|
-
### خيارات البناء
|
|
397
|
+
### خيارات البناء (Build Options)
|
|
296
398
|
|
|
297
|
-
|
|
399
|
+
| الخاصية | النوع | الافتراضي | الوصف |
|
|
400
|
+
| :------------- | :--------------------- | :---------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
|
401
|
+
| **`optimize`** | `boolean \| undefined` | `undefined` | يفعّل خطوة إعادة كتابة الاستيراد. `undefined` = نشط فقط في البناء المخصص للإنتاج. `false` يعطل التطهير (purge) والتصغير (minify) أيضًا. |
|
|
402
|
+
| **`minify`** | `boolean` | `false` | يعيد تسمية مفاتيح حقول المحتوى في ملفات JSON المجمعة إلى أسماء مستعارة أبجدية قصيرة. يعيد كتابة وصول الخصائص المطابقة في الكود المصدري أيضًا. لا يكون له تأثير إذا كان الـ `optimize` هو `false`. |
|
|
403
|
+
| **`purge`** | `boolean` | `false` | يزيل حقول المحتوى التي لا يتم الوصول إليها بشكل ثابت من ملفات JSON المجمعة. لا يكون له تأثير إذا كان الـ `optimize` هو `false`. |
|
|
298
404
|
|
|
299
|
-
|
|
300
|
-
| :------------- | :-------- | :---------------- | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
301
|
-
| **`optimize`** | `boolean` | `undefined` | يتحكم فيما إذا كان تفعيل تحسين البناء ممكّنًا. إذا كانت القيمة `true`، يقوم Intlayer باستبدال استدعاءات القاموس بحقنات محسّنة. إذا كانت `false`، يتم تعطيل التحسين. من المثالي تعيينها إلى `true` في بيئة الإنتاج. |
|
|
302
|
-
| **`minify`** | `boolean` | `false` | ما إذا كان سيتم تصغير القواميس لتقليل حجم الحزمة. |
|
|
303
|
-
| **`purge`** | `boolean` | `false` | ما إذا كان سيتم تطهير المفاتيح غير المستخدمة في القواميس. |
|
|
405
|
+
### التصغير (إعادة تسمية مفتاح الحقل)
|
|
304
406
|
|
|
305
|
-
|
|
407
|
+
إن الخاصية `build.minify` **لا** تُصغّر حزمة JavaScript الخاصة بك — يُعالج المُحزم الخاص بك ذلك. وبدلاً من ذلك، فإنها تُقلص ملفات JSON الخاصة بالقاموس المجمع عن طريق استبدال كل مفتاح حقل محتوى محدد من قبل المستخدم باسم مستعار أبجدي قصير:
|
|
306
408
|
|
|
307
|
-
|
|
409
|
+
```
|
|
410
|
+
// قبل التصغير
|
|
411
|
+
{ "title": "مرحبًا", "subtitle": "بالعالم" }
|
|
412
|
+
|
|
413
|
+
// بعد التصغير
|
|
414
|
+
{ "a": "مرحبًا", "b": "بالعالم" }
|
|
415
|
+
```
|
|
416
|
+
|
|
417
|
+
يتم تطبيق نفس إعادة التسمية على جميع عمليات الوصول إلى الخصائص في كود المصدر الخاص بك، وبالتالي يصبح `content.title` `content.a` في المخرجات المجمعة. ويكون السلوك أثناء وقت التشغيل متطابقًا.
|
|
308
418
|
|
|
309
419
|
```typescript fileName="intlayer.config.ts"
|
|
310
420
|
import type { IntlayerConfig } from "intlayer";
|
|
@@ -318,11 +428,13 @@ const config: IntlayerConfig = {
|
|
|
318
428
|
export default config;
|
|
319
429
|
```
|
|
320
430
|
|
|
321
|
-
>
|
|
431
|
+
> يتم تخطي التصغير عندما يكون `optimize` في وضع `false` أو عندما يكون `editor.enabled` في وضع `true` (يحتاج المحرر المرئي إلى أسماء الحقول الأصلية للسماح بالتحرير).
|
|
432
|
+
|
|
433
|
+
> يتم أيضًا تخطي التصغير بالنسبة للقواميس التي تم تحميلها عبر `importMode: 'fetch'` لأن ملف JSON الخاص بهم يُقدّم من واجهة برمجة تطبيقات (API) بعيدة باستخدام أسماء الحقول الأصلية — سيؤدي تغيير أسماء المفاتيح من جانب العميل إلى كسر العقد بين الخادم/العميل.
|
|
322
434
|
|
|
323
|
-
### التطهير (
|
|
435
|
+
### التطهير (إزالة الحقول غير المستخدمة)
|
|
324
436
|
|
|
325
|
-
|
|
437
|
+
يحلل `build.purge` حقول المحتوى التي يتم الوصول إليها فعليًا في الكود المصدري الخاص بك ويزيل كل الحقول الأخرى من ملفات JSON المجمعة.
|
|
326
438
|
|
|
327
439
|
```typescript fileName="intlayer.config.ts"
|
|
328
440
|
import type { IntlayerConfig } from "intlayer";
|
|
@@ -336,27 +448,43 @@ const config: IntlayerConfig = {
|
|
|
336
448
|
export default config;
|
|
337
449
|
```
|
|
338
450
|
|
|
339
|
-
|
|
451
|
+
**مثال:** قاموس يحتوي على خمسة حقول يتم استخدام اثنين منها فقط:
|
|
452
|
+
|
|
453
|
+
```
|
|
454
|
+
// قبل التطهير
|
|
455
|
+
{ "title": "…", "subtitle": "…", "cta": "…", "footer": "…", "badge": "…" }
|
|
456
|
+
|
|
457
|
+
// بعد التطهير (تم الوصول إلى title + subtitle فقط في المصدر)
|
|
458
|
+
{ "title": "…", "subtitle": "…" }
|
|
459
|
+
```
|
|
460
|
+
|
|
461
|
+
> يتم تخطي التطهير (Purge) عندما يكون `optimize` في وضع `false` أو عندما يكون `editor.enabled` في وضع `true`.
|
|
462
|
+
|
|
463
|
+
> يتم أيضًا تخطي التطهير كإجراء احترازي عندما يتعذر تحليل ملف المصدر، أو عندما يتم تعيين نتيجة `useIntlayer` لمتغير ويتم تمريرها بطرق لا يستطيع المحلل الثابت تتبعها (مثل وضعها في كائن بطريقة النشر، تمريرها كخاصية بدون تفكيك الهيكل). في تلك الحالات، يتم الاحتفاظ بالقاموس بالكامل.
|
|
340
464
|
|
|
341
465
|
### وضع الاستيراد (Import Mode)
|
|
342
466
|
|
|
343
|
-
بالنسبة للتطبيقات الكبيرة، التي تتضمن
|
|
467
|
+
بالنسبة للتطبيقات الكبيرة، التي تتضمن العديد من الصفحات واللغات، قد يمثل ملف JSON الخاص بك جزءًا كبيرًا من حجم الحزمة. يسمح لك Intlayer بالتحكم في كيفية تحميل القواميس باستخدام خيار `importMode`.
|
|
468
|
+
|
|
469
|
+
### التعريف العام
|
|
344
470
|
|
|
345
|
-
يمكن
|
|
471
|
+
يمكن تحديد وضع الاستيراد بشكل عام في ملف `intlayer.config.ts` الخاص بك.
|
|
346
472
|
|
|
347
473
|
```typescript fileName="intlayer.config.ts"
|
|
348
474
|
import type { IntlayerConfig } from "intlayer";
|
|
349
475
|
|
|
350
476
|
const config: IntlayerConfig = {
|
|
351
|
-
|
|
352
|
-
|
|
477
|
+
dictionary: {
|
|
478
|
+
importMode: "dynamic", // الافتراضي هو 'static'
|
|
353
479
|
},
|
|
354
480
|
};
|
|
355
481
|
|
|
356
482
|
export default config;
|
|
357
483
|
```
|
|
358
484
|
|
|
359
|
-
|
|
485
|
+
### التعريف لكل قاموس
|
|
486
|
+
|
|
487
|
+
يمكنك تجاوز وضع الاستيراد (import mode) لقواميس فردية في ملفات `.content.{{ts|tsx|js|jsx|mjs|cjs|json|jsonc|json5|md|mdx|yaml|yml}}` الخاصة بها.
|
|
360
488
|
|
|
361
489
|
```ts
|
|
362
490
|
import { type Dictionary, t } from "intlayer";
|
|
@@ -372,83 +500,103 @@ const appContent: Dictionary = {
|
|
|
372
500
|
export default appContent;
|
|
373
501
|
```
|
|
374
502
|
|
|
375
|
-
| الخاصية | النوع |
|
|
376
|
-
| :--------------- | :--------------------------------- |
|
|
377
|
-
| **`importMode`** | `'static'`, `'dynamic'`, `'fetch'` | `'static'`
|
|
503
|
+
| الخاصية | النوع | الافتراضي | الوصف |
|
|
504
|
+
| :--------------- | :--------------------------------- | :--------- | :------------------------------------------------------------------------------------------- |
|
|
505
|
+
| **`importMode`** | `'static'`, `'dynamic'`, `'fetch'` | `'static'` | **مُلغى**: استخدم `dictionary.importMode` بدلاً منه. يحدد كيفية تحميل القواميس (انظر أدناه). |
|
|
378
506
|
|
|
379
|
-
|
|
380
|
-
يمكنك تعريفه عالميًا في ملف `intlayer.config.ts` تحت كائن `dictionary` أو تجاوزه لقاموس معين في ملف `.content.ts` الخاص به.
|
|
507
|
+
يُحدد إعداد `importMode` كيفية حقن محتوى القاموس في المكون الخاص بك. يمكنك تعريفه بشكل عام في `intlayer.config.ts` تحت كائن `dictionary`، أو تجاوزه لكل قاموس على حدة في ملف `.content.ts` الخاص به.
|
|
381
508
|
|
|
382
|
-
### 1. الوضع الثابت (`default`)
|
|
509
|
+
### 1. الوضع الثابت (Static Mode - `default`)
|
|
383
510
|
|
|
384
|
-
في الوضع الثابت،
|
|
511
|
+
في الوضع الثابت، يستبدل Intlayer استدعاء `useIntlayer` بـ `useDictionary` ويحقن القاموس مباشرة في حزمة JavaScript.
|
|
385
512
|
|
|
386
|
-
-
|
|
387
|
-
-
|
|
513
|
+
- **المميزات:** تقديم فوري (متزامن)، بدون طلبات شبكة إضافية أثناء مرحلة الإماهة (hydration).
|
|
514
|
+
- **العيوب:** تتضمن الحزمة ترجمات لـ **جميع** اللغات المتاحة لذلك المكون المحدد.
|
|
388
515
|
- **الأفضل لـ:** تطبيقات الصفحة الواحدة (SPA).
|
|
389
516
|
|
|
390
517
|
**مثال على الكود المحول:**
|
|
391
518
|
|
|
392
519
|
```tsx
|
|
393
|
-
//
|
|
520
|
+
// الكود الخاص بك
|
|
394
521
|
const content = useIntlayer("my-key");
|
|
395
522
|
|
|
396
|
-
//
|
|
523
|
+
// رسم توضيحي للكود المحسن بعد التحويل (الوضع الثابت)
|
|
524
|
+
// هذا لأغراض التوضيح فقط، سيكون الكود الفعلي مختلفًا لأسباب التحسين
|
|
397
525
|
const content = useDictionary({
|
|
398
526
|
key: "my-key",
|
|
399
527
|
content: {
|
|
400
528
|
nodeType: "translation",
|
|
401
529
|
translation: {
|
|
402
530
|
en: "My title",
|
|
403
|
-
|
|
531
|
+
ar: "عنواني",
|
|
404
532
|
},
|
|
405
533
|
},
|
|
406
534
|
});
|
|
407
535
|
```
|
|
408
536
|
|
|
409
|
-
### 2. الوضع الديناميكي
|
|
537
|
+
### 2. الوضع الديناميكي (Dynamic Mode)
|
|
410
538
|
|
|
411
|
-
في الوضع الديناميكي، يستبدل Intlayer
|
|
539
|
+
في الوضع الديناميكي، يستبدل Intlayer الـ `useIntlayer` بـ `useDictionaryAsync`. يستخدم هذا الـ `import()` (آلية تشبه الـ Suspense) لتحميل ملف JSON للغة الحالية خصيصًا بكسل.
|
|
412
540
|
|
|
413
|
-
-
|
|
414
|
-
-
|
|
415
|
-
- **الأفضل لـ:** كتل
|
|
541
|
+
- **المميزات:** **هز الشجرة على مستوى اللغة (Locale-level tree shaking).** سيقوم المستخدم الذي يشاهد النسخة الإنجليزية بتنزيل القاموس الإنجليزي _فقط_. لن يتم تحميل القاموس العربي أبدًا.
|
|
542
|
+
- **العيوب:** يطلق طلب شبكة (إحضار أصول) لكل مكون أثناء الإماهة (hydration).
|
|
543
|
+
- **الأفضل لـ:** كتل النصوص الكبيرة، أو المقالات، أو التطبيقات التي تدعم لغات متعددة حيث يكون حجم الحزمة أمرًا بالغ الأهمية.
|
|
416
544
|
|
|
417
545
|
**مثال على الكود المحول:**
|
|
418
546
|
|
|
419
547
|
```tsx
|
|
420
|
-
//
|
|
548
|
+
// الكود الخاص بك
|
|
421
549
|
const content = useIntlayer("my-key");
|
|
422
550
|
|
|
423
|
-
//
|
|
551
|
+
// رسم توضيحي للكود المحسن بعد التحويل (الوضع الديناميكي)
|
|
552
|
+
// هذا لأغراض التوضيح فقط، سيكون الكود الفعلي مختلفًا لأسباب التحسين
|
|
424
553
|
const content = useDictionaryAsync({
|
|
425
554
|
en: () =>
|
|
426
555
|
import(".intlayer/dynamic_dictionary/my-key/en.json").then(
|
|
427
556
|
(mod) => mod.default
|
|
428
557
|
),
|
|
429
|
-
|
|
430
|
-
import(".intlayer/dynamic_dictionary/my-key/
|
|
558
|
+
ar: () =>
|
|
559
|
+
import(".intlayer/dynamic_dictionary/my-key/ar.json").then(
|
|
431
560
|
(mod) => mod.default
|
|
432
561
|
),
|
|
433
562
|
});
|
|
434
563
|
```
|
|
435
564
|
|
|
436
|
-
> عند استخدام `importMode: 'dynamic'`، إذا كان لديك 100 مكون
|
|
565
|
+
> عند استخدام `importMode: 'dynamic'`، إذا كان لديك 100 مكون تستخدم `useIntlayer` على صفحة واحدة، سيحاول المتصفح القيام بـ 100 عملية جلب (fetch) منفصلة. لتجنب "شلال" الطلبات هذا، قم بتجميع المحتوى في ملفات `.content` أقل (على سبيل المثال، قاموس واحد لكل قسم في الصفحة) بدلاً من واحد لكل مكون دقيق (atom component). يمكنك أيضًا استخدام ملفات `.content` متعددة تستخدم نفس المفتاح. وسيقوم Intlayer بدمجها في قاموس واحد.
|
|
437
566
|
|
|
438
567
|
### 3. وضع الجلب (Fetch Mode)
|
|
439
568
|
|
|
440
|
-
يتصرف بشكل مشابه للوضع الديناميكي
|
|
569
|
+
يتصرف بشكل مشابه للوضع الديناميكي ولكنه يحاول جلب القواميس من Intlayer Live Sync API أولاً. إذا فشل استدعاء API أو لم يتم تمييز المحتوى للتحديثات المباشرة، فإنه يتراجع ليعمل باستخدام الاستيراد الديناميكي (dynamic import).
|
|
570
|
+
|
|
571
|
+
**مثال على الكود المحول:**
|
|
572
|
+
|
|
573
|
+
```tsx
|
|
574
|
+
// الكود الخاص بك
|
|
575
|
+
const content = useIntlayer("my-key");
|
|
576
|
+
|
|
577
|
+
// رسم توضيحي للكود المحسن (وضع الجلب)
|
|
578
|
+
const content = useDictionaryAsync({
|
|
579
|
+
en: () =>
|
|
580
|
+
fetch("https://intlayer.my-domain.com/dictionary/my-key/en").then((res) =>
|
|
581
|
+
res.json()
|
|
582
|
+
),
|
|
583
|
+
ar: () =>
|
|
584
|
+
fetch("https://intlayer.my-domain.com/dictionary/my-key/ar").then((res) =>
|
|
585
|
+
res.json()
|
|
586
|
+
),
|
|
587
|
+
});
|
|
588
|
+
```
|
|
441
589
|
|
|
442
|
-
> راجع
|
|
590
|
+
> راجع وثائق نظام إدارة المحتوى (CMS) لمزيد من التفاصيل: [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ar/intlayer_CMS.md)
|
|
443
591
|
|
|
444
|
-
> في وضع
|
|
592
|
+
> في وضع الجلب (fetch)، لا يتم تطبيق التطهير (purge) والتصغير (minification) لأن ملف JSON يتم تقديمه من API بعيدة باستخدام أسماء الحقول الأصلية.
|
|
445
593
|
|
|
446
|
-
##
|
|
594
|
+
## ملخص: الثابت مقابل الديناميكي
|
|
447
595
|
|
|
448
|
-
| الميزة
|
|
449
|
-
|
|
|
450
|
-
| **حجم حزمة
|
|
451
|
-
| **التحميل الأولي**
|
|
452
|
-
| **طلبات الشبكة**
|
|
453
|
-
|
|
|
454
|
-
| **أفضل استخدام**
|
|
596
|
+
| الميزة | الوضع الثابت (Static Mode) | الوضع الديناميكي (Dynamic Mode) |
|
|
597
|
+
| :--------------------------- | :-------------------------------------------- | :------------------------------------------- |
|
|
598
|
+
| **حجم حزمة JS** | أكبر (يتضمن جميع اللغات للمكون) | أصغر (كود فقط، بدون محتوى) |
|
|
599
|
+
| **التحميل الأولي** | فوري (المحتوى موجود في الحزمة) | تأخير طفيف (يجلب الـ JSON) |
|
|
600
|
+
| **طلبات الشبكة** | 0 طلبات إضافية | طلب واحد لكل مفتاح قاموس |
|
|
601
|
+
| **هز الشجرة (Tree Shaking)** | على مستوى المكون | على مستوى المكون + مستوى اللغة |
|
|
602
|
+
| **أفضل حالة استخدام** | مكونات واجهة المستخدم (UI)، التطبيقات الصغيرة | الصفحات ذات النصوص الكثيرة، العديد من اللغات |
|
package/docs/ar/configuration.md
CHANGED
|
@@ -672,16 +672,16 @@ routing: {
|
|
|
672
672
|
|
|
673
673
|
عند استخدام التخزين في الكوكيز، يمكن تعيين سمات إضافية:
|
|
674
674
|
|
|
675
|
-
| الحقل | الوصف
|
|
676
|
-
| ---------- |
|
|
677
|
-
| `name` | اسم الكوكيز. الافتراضي: `'INTLAYER_LOCALE'`
|
|
678
|
-
| `domain` | نطاق الكوكيز. الافتراضي: `undefined`
|
|
679
|
-
| `path` | مسار الكوكيز. الافتراضي: `undefined`
|
|
680
|
-
| `secure` | يتطلب HTTPS. الافتراضي: `undefined`
|
|
681
|
-
| `httpOnly` | علامة HTTP-only. الافتراضي: `undefined`
|
|
682
|
-
| `sameSite` | سياسة SameSite.
|
|
683
|
-
| `expires` | تاريخ
|
|
684
|
-
| `maxAge` | العمر بالثواني منذ الإنشاء. له الأسبقية على `expires`. الافتراضي: `undefined`
|
|
675
|
+
| الحقل | الوصف | النوع |
|
|
676
|
+
| ---------- | ------------------------------------------------------------------------------------------------------ | ----------------------------------------------------- |
|
|
677
|
+
| `name` | اسم الكوكيز. الافتراضي: `'INTLAYER_LOCALE'` | `string` |
|
|
678
|
+
| `domain` | نطاق الكوكيز. الافتراضي: `undefined` | `string` |
|
|
679
|
+
| `path` | مسار الكوكيز. الافتراضي: `undefined` | `string` |
|
|
680
|
+
| `secure` | يتطلب HTTPS. الافتراضي: `undefined` | `boolean` |
|
|
681
|
+
| `httpOnly` | علامة HTTP-only. الافتراضي: `undefined` | `boolean` |
|
|
682
|
+
| `sameSite` | سياسة SameSite. | `'strict'` | <br/> `'lax'` | <br/> `'none'` |
|
|
683
|
+
| `expires` | رقم يمثل الأيام منذ الإنشاء؛ تاريخ (أو سلسلة ISO للتاريخ) هو تاريخ انتهاء مطلق. الافتراضي: `undefined` | `Date` | <br/> `number` | <br/> `string` |
|
|
684
|
+
| `maxAge` | العمر بالثواني منذ الإنشاء. له الأسبقية على `expires`. الافتراضي: `undefined` | `number` |
|
|
685
685
|
|
|
686
686
|
#### سمات التخزين (Storage Attributes)
|
|
687
687
|
|