الرئيسيةبيئة اختبارمعرض الأعمالتطبيقوثيقةمدونة
    • Englishالإنجليزية
      EN
    • русскийالروسية
      RU
    • 日本語اليابانية
      JA
    • françaisالفرنسية
      FR
    • 한국어الكورية
      KO
    • 中文الصينية
      ZH
    • españolالإسبانية
      ES
    • Deutschالألمانية
      DE
    • العربيةالعربية
      AR
    • italianoالإيطالية
      IT
    • British Englishالإنجليزية (المملكة المتحدة)
      EN-GB
    • portuguêsالبرتغالية
      PT
    • हिन्दीالهندية
      HI
    • Türkçeالتركية
      TR
    • polskiالبولندية
      PL
    • Indonesiaالإندونيسية
      ID
    • Tiếng Việtالفيتنامية
      VI
    • українськаالأوكرانية
      UK
    /
    تصفية المستندات حسب الإطار
    Alt+←
    لماذا Intlayer؟
    ابدأ
    مفهوم
    • كيف يعمل Intlayer
    • التكوين
    • TestFillBuildWatchExtractLoginPushPullConfigurationListVersionEditorLiveDebugDoc ReviewDoc TranslateSDK
    • المحرر المرئي
    • CMS
    • تكامل CI/CD
    • ترجمةجمعتعدادشرطجنسإدراجملفتداخلMarkdownHTMLجلب الوظيفة
    • ملف لكل لغة
    • محرر
    • الملء التلقائي
    • اختبار
    • تحسين الحزمة
    بيئة
    • Next.js 14 وموجه التطبيق
      Next.js 15
      Next.js بدون locale URL
      Next.js وموجه الصفحة
      المترجم
    • Tanstack Start Solid
    • Astro و React
      Astro و Svelte
      Astro و Vue
      Astro و Solid
      Astro و Preact
      Astro و Lit
      Astro و Vanilla JS
    • React Router v7
      React Router v7 (fs-routes)
      Compiler
    • Nuxt و Vue
    • Vite و Solid
    • SvelteKit
    • Vite و Preact
    • Vite و Vanilla JS
    • Vite و Lit
    • Angular 19 (Webpack)
      Analog
    • React CRA
    • React Native و Expo
    • Express.js
      NestJS
      Fastify
      Hono
      Adonis
    • Lynx و React
    Plugins
    • JSON
    • gettext (.po)
    امتداد VS Code
    وكيل
    • خادم MCP
    • مهارات الوكيل
    إصدارات
    • v8
    • v7
    • v6
    مؤشر أداء
    • Next.js
    • TanStack
    • Vue
    • Solid
    • Svelte
    مدونة
    طرح سؤال
    1. Documentation
    2. مفهوم
    3. CMS
    إنشاء:2025-08-23آخر تحديث:2025-08-23
    شاهد الفيديو التعليمي

    هذه الصفحة لديها فيديو تعليمي متاح.

    استخدم هذه الصفحة والموفر AI الذي تريده
    ChatGPT
    Claude
    DeepSeek
    Google AI mode
    Gemini
    Perplexity
    Mistral
    Grok

    استخدم مساعدك المفضل للملخص واستخدم هذه الصفحة والموفر AI الذي تريده

    تاريخ الإصدارات

    1. "إضافة توثيق المزامنة الحية"
      v6.0.122‏/9‏/2025
    2. "استبدال حقل `hotReload` بـ `liveSync`"
      v6.0.04‏/9‏/2025
    3. "بدء السجل"
      v5.5.1029‏/6‏/2025

    تمت ترجمة محتوى هذه الصفحة باستخدام الذكاء الاصطناعي.

    اعرض آخر نسخة المحتوى الأصلي باللغة الإنكليزية
    تعديل هذه الوثيقة

    إذا كان لديك فكرة لتحسين هذه الوثيقة، فلا تتردد في المساهمة من خلال تقديم طلب سحب على GitHub.

    رابط GitHub للتوثيق
    نسخ

    نسخ الـ Markdown من المستند إلى الحافظة

    توثيق نظام إدارة المحتوى Intlayer (CMS)

    www.youtube.com

    نظام إدارة المحتوى Intlayer هو تطبيق يسمح لك بإخراج محتواك من مشروع Intlayer.

    لهذا، قدم Intlayer مفهوم "القواميس البعيدة".

    واجهة نظام إدارة المحتوى Intlayer

    فهم القواميس البعيدة

    يفرق Intlayer بين القواميس "المحلية" و"البعيدة".

    • القاموس "المحلي" هو قاموس يتم إعلانه داخل مشروع Intlayer الخاص بك. مثل ملف إعلان زر، أو شريط التنقل الخاص بك. إخراج المحتوى الخاص بك لا معنى له في هذه الحالة لأن هذا المحتوى من المفترض ألا يتغير كثيرًا.

    • القاموس "البعيد" هو قاموس يتم إدارته من خلال نظام إدارة المحتوى Intlayer CMS. قد يكون مفيدًا للسماح لفريقك بإدارة المحتوى مباشرة على موقعك الإلكتروني، ويهدف أيضًا إلى استخدام ميزات اختبار A/B والتحسين التلقائي لمحركات البحث (SEO).

    المحرر المرئي مقابل نظام إدارة المحتوى (CMS)

    محرر Intlayer Visual هو أداة تتيح لك إدارة المحتوى الخاص بك في محرر مرئي للقواميس المحلية. بمجرد إجراء تغيير، سيتم استبدال المحتوى في قاعدة الشيفرة. هذا يعني أن التطبيق سيتم إعادة بنائه وستتم إعادة تحميل الصفحة لعرض المحتوى الجديد.

    على النقيض من ذلك، فإن نظام إدارة المحتوى Intlayer CMS هو أداة تتيح لك إدارة المحتوى الخاص بك في محرر مرئي للقواميس البعيدة. بمجرد إجراء تغيير، لن يؤثر المحتوى على قاعدة الشيفرة الخاصة بك. وسيعرض الموقع تلقائيًا المحتوى المُعدل.

    التكامل

    لمزيد من التفاصيل حول كيفية تثبيت الحزمة، راجع القسم ذي الصلة أدناه:

    التكامل مع Next.js

    للتكامل مع Next.js، راجع دليل الإعداد.

    التكامل مع Create React App

    للتكامل مع Create React App، راجع دليل الإعداد.

    التكامل مع Vite + React

    للتكامل مع Vite + React، راجع دليل الإعداد.

    التهيئة

    قم بتشغيل الأمر التالي لتسجيل الدخول إلى Intlayer CMS:

    bash
    نسخ الكود

    نسخ الكود إلى الحافظة

    npx intlayer login

    سيؤدي هذا إلى فتح المتصفح الافتراضي الخاص بك لإكمال عملية المصادقة والحصول على بيانات الاعتماد اللازمة (معرف العميل وسر العميل) لاستخدام خدمات Intlayer.

    في ملف تهيئة Intlayer الخاص بك، يمكنك تخصيص إعدادات نظام إدارة المحتوى:

    intlayer.config.ts
    نسخ الكود

    نسخ الكود إلى الحافظة

    import type { IntlayerConfig } from "intlayer";
    
    const config: IntlayerConfig = {
      // ... إعدادات التهيئة الأخرى
      editor: {
        /**
         * مطلوب
         *
         * عنوان URL الخاص بالتطبيق.
         * هذا هو العنوان الذي يستهدفه المحرر المرئي.
         */
        applicationURL: process.env.INTLAYER_APPLICATION_URL,
    
        /**
         * مطلوب
         *
         * معرف العميل والسر السري للعميل مطلوبان لتمكين المحرر.
         * يسمحان بتحديد هوية المستخدم الذي يقوم بتحرير المحتوى.
         * يمكن الحصول عليهما بإنشاء عميل جديد في لوحة تحكم Intlayer - المشاريع (https://app.intlayer.org/projects).
         * clientId: process.env.INTLAYER_CLIENT_ID,
         * clientSecret: process.env.INTLAYER_CLIENT_SECRET,
         */
        clientId: process.env.INTLAYER_CLIENT_ID,
        clientSecret: process.env.INTLAYER_CLIENT_SECRET,
    
        /**
         * اختياري
         *
         * في حال كنت تستضيف نظام إدارة المحتوى Intlayer بنفسك، يمكنك تعيين عنوان URL الخاص بنظام إدارة المحتوى.
         *
         * عنوان URL الخاص بنظام إدارة المحتوى Intlayer.
         * بشكل افتراضي، يتم تعيينه إلى https://intlayer.org
         */
        cmsURL: process.env.INTLAYER_CMS_URL,
    
        /**
         * اختياري
         *
         * في حال كنت تستضيف نظام إدارة المحتوى Intlayer بنفسك، يمكنك تعيين عنوان URL الخاص بالواجهة الخلفية.
         *
         * عنوان URL الخاص بنظام إدارة المحتوى Intlayer.
         * بشكل افتراضي، يتم تعيينه إلى https://back.intlayer.org
         */
        backendURL: process.env.INTLAYER_BACKEND_URL,
      },
    };
    
    export default config;
    إذا لم يكن لديك معرف عميل وسر عميل، يمكنك الحصول عليهما بإنشاء عميل جديد في لوحة تحكم Intlayer - المشاريع.
    لرؤية جميع المعلمات المتاحة، راجع توثيق التهيئة.

    استخدام نظام إدارة المحتوى

    دفع التهيئة الخاصة بك

    لتكوين نظام إدارة محتوى Intlayer، يمكنك استخدام أوامر intlayer CLI.

    bash
    نسخ الكود

    نسخ الكود إلى الحافظة

    npx intlayer config push
    إذا كنت تستخدم متغيرات البيئة في ملف التهيئة intlayer.config.ts، يمكنك تحديد البيئة المطلوبة باستخدام الوسيطة --env:
    bash
    نسخ الكود

    نسخ الكود إلى الحافظة

    npx intlayer config push --env production

    يقوم هذا الأمر برفع تهيئتك إلى نظام إدارة محتوى Intlayer.

    دفع قاموس

    لتحويل قواميس اللغة المحلية الخاصة بك إلى قاموس بعيد، يمكنك استخدام أوامر intlayer CLI.

    bash
    نسخ الكود

    نسخ الكود إلى الحافظة

    npx intlayer dictionary push -d my-first-dictionary-key
    إذا كنت تستخدم متغيرات البيئة في ملف التهيئة intlayer.config.ts الخاص بك، يمكنك تحديد البيئة المطلوبة باستخدام الوسيطة --env:
    bash
    نسخ الكود

    نسخ الكود إلى الحافظة

    npx intlayer dictionary push -d my-first-dictionary-key --env production

    يقوم هذا الأمر برفع قواميس المحتوى الأولية الخاصة بك، مما يجعلها متاحة للتحميل والتحرير غير المتزامن عبر منصة Intlayer.

    تحرير القاموس

    بعد ذلك، ستتمكن من رؤية وإدارة قاموسك في نظام إدارة محتوى Intlayer.

    التزامن الحي

    يتيح التزامن الحي لتطبيقك عكس تغييرات محتوى نظام إدارة المحتوى أثناء وقت التشغيل. لا حاجة لإعادة البناء أو إعادة النشر. عند التمكين، يتم بث التحديثات إلى خادم التزامن الحي الذي يقوم بتحديث القواميس التي يقرأها تطبيقك.

    يتطلب التزامن الحي اتصالًا مستمرًا بالخادم وهو متاح في خطة المؤسسات.

    قم بتمكين التزامن الحي عن طريق تحديث تكوين Intlayer الخاص بك:

    intlayer.config.ts
    نسخ الكود

    نسخ الكود إلى الحافظة

    import type { IntlayerConfig } from "intlayer";
    
    const config: IntlayerConfig = {
      // ... إعدادات التكوين الأخرى
      editor: {
        /**
         * يُمكّن إعادة تحميل التكوينات المحلية تلقائيًا عند اكتشاف تغييرات.
         * على سبيل المثال، عند إضافة قاموس أو تحديثه، يقوم التطبيق بتحديث
         * المحتوى المعروض على الصفحة.
         *
         * نظرًا لأن إعادة التحميل الساخن تتطلب اتصالًا مستمرًا بالخادم،
         * فهي متاحة فقط لعملاء خطة `enterprise`.
         *
         * الافتراضي: false
         */
        liveSync: true,
      },
      dictionary: {
        /**
         * يتحكم في كيفية استيراد القواميس:
         *
         * - "live": يتم جلب القواميس ديناميكيًا باستخدام واجهة برمجة تطبيقات المزامنة الحية (Live Sync API).
         *   يستبدل useIntlayer بـ useDictionaryDynamic.
         *
         * ملاحظة: يستخدم الوضع الحي (Live) واجهة برمجة تطبيقات المزامنة الحية لجلب القواميس. إذا فشل استدعاء الواجهة،
         * يتم استيراد القواميس ديناميكيًا.
         * ملاحظة: فقط القواميس التي تحتوي على محتوى عن بُعد وعلامة "live" تستخدم الوضع الحي.
         * القواميس الأخرى تستخدم الوضع الديناميكي لأداء أفضل.
         */
        importMode: "fetch",
      },
    };
    
    export default config;

    ابدأ خادم المزامنة الحية لتغليف تطبيقك:

    مثال باستخدام Next.js:

    package.json
    نسخ الكود

    نسخ الكود إلى الحافظة

    {  "scripts": {    // ... سكريبتات أخرى    "build": "next build",    "dev": "next dev",    "start": "npx intlayer live --with 'next start'",  },}

    مثال باستخدام Vite:

    package.json
    نسخ الكود

    نسخ الكود إلى الحافظة

    {  "scripts": {    // ... سكريبتات أخرى    "build": "vite build",    "dev": "vite dev",    "start": "npx intlayer live --with 'vite start'",  },}

    يقوم خادم المزامنة الحية بتغليف تطبيقك ويطبق المحتوى المحدث تلقائيًا عند وصوله.

    لتلقي إشعارات التغيير من نظام إدارة المحتوى (CMS)، يحافظ خادم المزامنة الحية على اتصال SSE مع الخادم الخلفي. عندما يتغير المحتوى في نظام إدارة المحتوى، يقوم الخادم الخلفي بإرسال التحديث إلى خادم المزامنة الحية، الذي يقوم بكتابة القواميس الجديدة. سيعكس تطبيقك التحديث في التنقل التالي أو عند إعادة تحميل المتصفح, دون الحاجة لإعادة بناء التطبيق.

    مخطط التدفق (نظام إدارة المحتوى/الخادم الخلفي -> خادم المزامنة الحية -> خادم التطبيق -> الواجهة الأمامية):

    مخطط منطق المزامنة الحية

    كيف يعمل:

    مخطط تدفق المزامنة الحية نظام إدارة المحتوى/الخادم الخلفي/خادم المزامنة الحية/خادم التطبيق/الواجهة الأمامية

    سير عمل التطوير (محلي)

    • في بيئة التطوير، يتم جلب جميع القواميس البعيدة عند بدء تشغيل التطبيق، بحيث يمكنك اختبار التحديثات بسرعة.
    • لاختبار المزامنة الحية محليًا مع Next.js، قم بتغليف خادم التطوير الخاص بك:
    package.json
    نسخ الكود

    نسخ الكود إلى الحافظة

    {  "scripts": {    // ... سكريبتات أخرى    "dev": "npx intlayer live --with 'next dev'",    // "dev": "npx intlayer live --with 'vite dev'", // لـ Vite  },}

    قم بتمكين التحسين حتى يطبق Intlayer تحولات الاستيراد الحي أثناء التطوير:

    intlayer.config.ts
    نسخ الكود

    نسخ الكود إلى الحافظة

    import type { IntlayerConfig } from "intlayer";
    
    const config: IntlayerConfig = {
      editor: {
        applicationURL: "http://localhost:5173",
        liveSyncURL: "http://localhost:4000",
        liveSync: true,
      },
      dictionary: {
        importMode: "fetch",
      },
      build: {
        optimize: true,
      },
    };
    
    export default config;

    يقوم هذا الإعداد بتغليف خادم التطوير الخاص بك مع خادم المزامنة الحية، ويجلب القواميس البعيدة عند بدء التشغيل، ويقوم ببث التحديثات من نظام إدارة المحتوى عبر SSE. قم بتحديث الصفحة لرؤية التغييرات.

    ملاحظات وقيود:

    • أضف مصدر المزامنة الحية إلى سياسة أمان موقعك (CSP). تأكد من السماح بعنوان URL الخاص بالمزامنة الحية في connect-src (و frame-ancestors إذا كان ذلك مناسبًا).
    • لا تعمل المزامنة الحية مع المخرجات الثابتة. بالنسبة لـ Next.js، يجب أن تكون الصفحة ديناميكية لتلقي التحديثات أثناء وقت التشغيل (على سبيل المثال، استخدم generateStaticParams، generateMetadata، getServerSideProps، أو getStaticProps بشكل مناسب لتجنب القيود الخاصة بالمحتوى الثابت فقط).
    • في نظام إدارة المحتوى (CMS)، يحتوي كل قاموس على علامة live. يتم جلب القواميس التي تحمل العلامة live=true فقط عبر واجهة برمجة تطبيقات المزامنة الحية؛ أما القواميس الأخرى فتُستورد ديناميكيًا وتظل دون تغيير أثناء وقت التشغيل.
    • يتم تقييم علامة live لكل قاموس أثناء وقت البناء. إذا لم يتم وسم المحتوى البعيد بعلامة live=true أثناء البناء، يجب عليك إعادة البناء لتمكين المزامنة الحية لذلك القاموس.
    • يجب أن يكون خادم المزامنة الحية قادرًا على الكتابة إلى .intlayer. في الحاويات، تأكد من وجود صلاحية الكتابة إلى /.intlayer.

    تصحيح الأخطاء

    إذا واجهت أي مشاكل مع نظام إدارة المحتوى (CMS)، تحقق من الأمور التالية:

    • التطبيق يعمل.

    • تم إعداد تكوين المحرر بشكل صحيح في ملف تكوين Intlayer الخاص بك.

      • الحقول المطلوبة:
        • يجب أن يتطابق عنوان URL الخاص بالتطبيق مع العنوان الذي قمت بتعيينه في تكوين المحرر (applicationURL).
        • عنوان URL الخاص بنظام إدارة المحتوى (CMS)
    • تأكد من أن تكوين المشروع تم دفعه إلى نظام إدارة محتوى Intlayer.

    • يستخدم المحرر المرئي إطار iframe لعرض موقعك الإلكتروني. تأكد من أن سياسة أمان المحتوى (CSP) لموقعك تسمح بعنوان URL الخاص بنظام إدارة المحتوى كـ frame-ancestors ('https://app.intlayer.org' بشكل افتراضي). تحقق من وحدة تحكم المحرر لأي أخطاء.

    المحرر المرئي
    تكامل CI/CD
    Alt+→

    في هذه الصفحة

      المناقشات مجهولة الهوية ويتم مراجعتها بانتظام لمعالجة المشكلات الشائعة. لا تتردد في مشاركة أفكار الميزات أو التعليقات على الوثائق أو أي شيء يتعلق بـ Intlayer, نستخدم هذه المدخلات لتشكيل خارطة الطريق وتحسين المنتج.

      npx intlayer login
      npx intlayer config push
      npx intlayer config push --env production
      npx intlayer dictionary push -d my-first-dictionary-key
      npx intlayer dictionary push -d my-first-dictionary-key --env production
      {  "scripts": {    // ... سكريبتات أخرى    "build": "next build",    "dev": "next dev",    "start": "npx intlayer live --with 'next start'",  },}
      {  "scripts": {    // ... سكريبتات أخرى    "build": "vite build",    "dev": "vite dev",    "start": "npx intlayer live --with 'vite start'",  },}
      {  "scripts": {    // ... سكريبتات أخرى    "dev": "npx intlayer live --with 'next dev'",    // "dev": "npx intlayer live --with 'vite dev'", // لـ Vite  },}