توثيق حول توسيع Discourse باستخدام الإضافات، السمات، ومكونات السمات، والعمل مع الكود الأساسي، واستخدام واجهة برمجة تطبيقات Discourse.
المقدمة
- مقدمة: مقدمة في تطوير Discourse
بيئات التطوير
- حاوية التطوير: تطوير Discourse باستخدام حاوية تطوير
- GitHub Codespaces: تطوير Discourse على GitHub Codespaces
- إعداد Docker: تثبيت Discourse للتطوير باستخدام Docker
- إعداد macOS: تثبيت Discourse على macOS للتطوير
- إعداد Ubuntu/Debian: تثبيت Discourse على Ubuntu أو Debian للتطوير
- إعداد Windows: تثبيت Discourse على Windows للتطوير
- إضافات غير Docker: تثبيت الإضافات في بيئة التطوير غير Docker
- الإعداد المحلي: إعداد بيئة تطوير Discourse محلية؟
- إعداد متعدد المواقع: إعداد بيئة تطوير متعددة المواقع
- إعداد Fedora: إعداد Discourse للتطوير على Fedora Linux
الكود والجوانب الداخلية
- مكونات Ember: إضافة مكونات Ember إلى Discourse
- الفحص والتنسيق: فحص وتنسيق الكود تلقائيًا قبل الالتزامات
- اختبارات القبول: كتابة اختبارات قبول واختبارات المكونات لكود Ember في Discourse
- تشغيل مجموعات الاختبار: كيفية تشغيل مجموعات اختبار QUnit الأساسية للإضافات والسمات في Discourse
- توافق الإصدارات: تثبيت إصدارات الإضافات والسمات لتثبيتات Discourse الأقدم (فروع d-compat)
- ملكية كائنات Ember: ملكية كائنات Ember (getOwner، حقن الخدمات، إلخ.)
- أداء JS: استخدام «tachometer» من Google لقياس تغييرات أداء JS في Discourse
- CI مع GitHub Actions: إعداد التكامل المستمر باستخدام GitHub Actions
- ملحقات Markdown: دليل المطور لملاحق Markdown
- تحويل النوافذ المنبثقة: تحويل النوافذ المنبثقة من وحدات التحكم القديمة إلى واجهة برمجة تطبيقات DModal الجديدة
- واجهة برمجة تطبيقات DModal: استخدام واجهة برمجة تطبيقات DModal لعرض نوافذ منبثقة (أي نوافذ منبثقة/حوارات) في Discourse
- واجهة برمجة تطبيقات JS: استخدام واجهة برمجة تطبيقات JS
- موصلات منافذ الإضافات: استخدام موصلات منافذ الإضافات من سمة أو إضافة
- modifyClass: استخدام modifyClass لتغيير السلوك الأساسي
- إنشاء مسارات: إنشاء مسارات في Discourse وعرض البيانات
- طريقة المصادقة: إضافة طريقة مصادقة «مدارة» جديدة إلى Discourse
- تسلسل نماذج ActiveRecord بالخطأ: منع تسلسل نماذج ActiveRecord بالخطأ
- تجاوز القوالب: (غير موصى به) تجاوز قوالب Discourse من سمة أو إضافة
- كائنات الخدمة: استخدام كائنات الخدمة في Discourse
- مواصفات النظام: كتابة مواصفات نظام شاملة لنظام واجهة مستخدم Discourse
- FormKit: مجموعة أدوات Discourse لعرض النماذج.
- محفزات AppEvents: مرجع محفزات AppEvents
- المحولات: استخدام المحولات لتخصيص القيم والسلوك من جانب العميل
- تخصيص قائمة المواضيع: تخصيص قائمة المواضيع
- إرشادات CSS: إرشادات لفئات CSS باستخدام BEM
- تلميح النوع والتحقق من صحة JS: تلميح نوع JavaScript والتحقق من صحته (typescript)
- التصميم للأجهزة: التصميم لأجهزة مختلفة (حجم العرض، اللمس/التمرير، إلخ.)
الإضافات
- إضافة أساسية: تطوير إضافات Discourse - الجزء 1 - إنشاء إضافة أساسية
- منفذ الإضافة: تطوير إضافات Discourse - الجزء 2 - الاتصال بمنفذ إضافة
- إعدادات الموقع: تطوير إضافات Discourse - الجزء 3 - إضافة إعدادات مخصصة للموقع
- إعداد Git: تطوير إضافات Discourse - الجزء 4 - إعداد Git
- واجهة الإدارة: تطوير إضافات Discourse - الجزء 5 - إضافة واجهة إدارة
- اختبارات القبول: تطوير إضافات Discourse - الجزء 6 - إضافة اختبارات قبول
- نشر إضافتك: تطوير إضافات Discourse - الجزء 7 - نشر إضافتك
- مناطق جديدة: إضافة منطقة جديدة من الإضافة
- تكامل الدردشة: إضافة موفر جديد إلى discourse-chat-integration
- امتداد markdown-it: إعادة تغليف امتداد markdown-it كإضافة Discourse
- تحميل Rails التلقائي: هيكلة الإضافة لتحميل Rails التلقائي
السمات والمكونات
- تطوير السمات: تطوير سمات Discourse ومكونات السمات
- مرجع سريع: دليل مرجعي سريع لمطور السمات
- دليل المصممين: دليل المصممين للبدء مع السمات في Discourse
- منشئ السمات: البدء مع منشئ السمات وواجهة سطر أوامر السمات
- واجهة سطر أوامر السمات: تثبيت تطبيق وحدة تحكم واجهة سطر أوامر سمات Discourse لمساعدتك في بناء السمات
- هيكل السمة: هيكل السمات ومكونات السمات
- ملفات JS متعددة: تقسيم جافا سكريبت السمة إلى ملفات متعددة
- ملفات SCSS متعددة: تقسيم SCSS السمة إلى ملفات متعددة
- إعدادات السمة: إضافة إعدادات إلى سمة Discourse
- كائنات لإعدادات السمة: نوع الكائنات لإعدادات السمة
- ترحيل الإعدادات: ترحيل إعدادات سمة Discourse
- بيانات السمة الوصفية: إضافة بيانات وصفية ولقطات شاشة إلى سمة
- متغيرات الأساسية: استخدام متغيرات Discourse الأساسية في سمتك
- سلاسل قابلة للترجمة: إضافة سلاسل قابلة للترجمة إلى السمات ومكونات السمات
- اختبار E2E: اختبار النظام الشامل للسمات ومكونات السمات
- تقليل الصيانة: تقليل الصيانة على تخصيصات السمة
- أحجام الخطوط: تغيير أحجام الخطوط في سماتك
- تضمين الأصول: تضمين الأصول (مثل الصور، الخطوط) في السمات والمكونات
- أيقونات مخصصة: استبدال أيقونات SVG الافتراضية في Discourse بأيقونات مخصصة في سمة
- الوضع المظلم: تحديث السمات والإضافات لدعم الوضع المظلم التلقائي
- محددات السمات: محددات السمات: مقدمة موجزة
- العناصر الزائفة: إدراج نص أو صور في أي مكان على موقعك باستخدام العناصر الزائفة في CSS
- مكون الخط: إنشاء ومشاركة مكون سمة خط
- لغة Highlight.JS: تثبيت لغة جديدة لـ Highlight.JS عبر مكون سمة
- محتوى الصفحة الرئيسية: إضافة محتوى مخصص يظهر فقط على صفحتك الرئيسية
- تنسيق الرسالة: دعم تنسيق الرسالة للترجمة
- تغييرات الأيقونات العالمية: تغيير الأيقونات عالميًا
- أيقونات بديلة: أيقونات بديلة
- نمط منشور الويكي: تغيير نمط منشور الويكي
- مخطط الألوان: إنشاء ومشاركة مخطط ألوان
- قائمة التنقل: استخدام معلمة الاستعلام
navigation_menuلمعاينة الشريط الجانبي أو خيارات أخرى - أنماط محتوى المنشور: تخصيص محتوى المنشورات بأنماطك الخاصة
- لقطات شاشة السمات: إضافة لقطات شاشة معاينة إلى سمات Discourse
- إعدادات الموقع القابلة للتخصيص: التحكم في إعدادات الموقع باستخدام السمات
أدلة عامة
- وضع العلامات البيضاء لتطبيقات الجوال: أمور يجب مراعاتها قبل اتخاذ قرار وضع العلامات البيضاء لتطبيقات Discourse للجوال
- أتمتة مخصصة: إنشاء أتمتة مخصصة
- دفعة بيانات عامة: دفعة بيانات عامة لـ Discourse
- تقييمات الذكاء الاصطناعي: تشغيل تقييمات الذكاء الاصطناعي لـ Discourse
برنامج تعليمي لتطوير السمات
- 1 - مقدمة: برنامج تعليمي لمطور السمات: 1. مقدمة
- 2 - سمة عن بعد: برنامج تعليمي لمطور السمات: 2. إنشاء سمة عن بعد
- 3 - CSS: برنامج تعليمي لمطور السمات: 3. CSS في السمات
- 4 - المنافذ: برنامج تعليمي لمطور السمات: 4. استخدام المنافذ لإدراج واستبدال المحتوى
- 5 - المكونات: برنامج تعليمي لمطور السمات: 5. بناء واستخدام المكونات
- 6 - واجهة برمجة تطبيقات JS: برنامج تعليمي لمطور السمات: 6. استخدام واجهة برمجة تطبيقات JS
- 7 - خاتمة: برنامج تعليمي لمطور السمات: 7. الخاتمة