اذهب إلى المحتوى

Mustafa Suleiman

الأعضاء
  • المساهمات

    9647
  • تاريخ الانضمام

  • تاريخ آخر زيارة

  • عدد الأيام التي تصدر بها

    296

كل منشورات العضو Mustafa Suleiman

  1. يجب عليك إضافة عنصر آخر إلى ملف AndroidManifest.xml لتمكين Deep Linking من التعرف على وسائل تواصل URL المحددة والمسموح بها في التطبيق. وتستطيع إضافة تحويل الروابط العادية إلى روابط عميقة باستخدام مكتبة "react-native-deep-linking" التي تقدم وظائف لإنشاء روابط عميقة واستخدامها في تطبيق React Native. توفر هذه المكتبة لك إعداد التعليمات البرمجية الخاصة بك لإنشاء وتحليل روابط عميقة وتنفيذ الإجراءات المناسبة على أساسها. أولاً ، يجب تثبيت المكتبة باستخدام npm: npm install --save react-native-deep-linking ثم استيرادها في ملف JS الخاص بك: import DeepLinking from 'react-native-deep-linking'; وهناك دالة DeepLinking.addScheme متوفرة لإضافة أسماء الأساليب الخاصة بتطبيقك إلى قائمة الأساليب المسموح بها للاتصال العميق. DeepLinking.addScheme('mychat://'); ثم استخدام دالة DeepLinking.addRoute لإضافة أنواع معينة من الطرق إلى الأساليب المسموح بها للاتصال العميق. مثلاً، إذا كنت تريد أن تكون قادرًا على النقر فوق الروابط التي تحتوي على "/chat/" في الرابط لفتح تطبيقك وعرض المحادثات المتعلقة بهذا المستخدم ، يمكنك استخدام هذا الأمر: DeepLinking.addRoute('/chat/:username', (response) => { const username = response.username; // Perform the appropriate action based on the username parameter }); ستعمل هذه الوظيفة عندما يتم النقر على الروابط التي تحتوي على "mychat://chat/jane". أيضًا، يجب إضافة بعض الأكواد إلى ملف AndroidManifest.xml لتمكين التطبيق من التعرف على الروابط العميقة. حيث يجب أن تحتوي على وسم <intent-filter> تحت العلامة <activity> في ملف AndroidManifest.xml يحتوي على بيانات الروابط العميقة المراد تمكين التطبيق من التعرف عليها. وتحديد مجموعة من البيانات المتعلقة بالروابط العميقة مثل البروتوكول، الرابط الأساسي، وأي معلمات إضافية إذا كانت موجودة. ففي الكود السابق، تم إضافة فلاتر النوايا (intent filters) للاعتراف بالروابط العميقة المرتبطة بـ "mychat" و "www.example.com". بعد إضافة هذه الفلاتر، عليك باستخدام مكتبة مثل "react-native-deep-link" للتفاعل مع روابط العمليات العميقة في التطبيق، وللتعرف على الروابط العميقة وتحويلها إلى عمليات داخل التطبيق. كمثال، تستطيع استخدام الكود التالي للاستجابة لروابط العمليات العميقة: import { Linking } from 'react-native'; Linking.addEventListener('url', (event) => { // Handle deep link event }); تستخدم دالة Linking.addEventListener للاستماع إلى حدث رابط العمليات العميقة، ويمكن استخدام دالة Linking.getInitialURL للتحقق مما إذا كان التطبيق يفتح لأول مرة باستخدام رابط عملية عميقة. وباستخدام هذه المكتبة تستطيع توجيه المستخدمين إلى الصفحة المناسبة داخل التطبيق عند النقر على رابط العملية العميقة.
  2. لم أقم بالتجربة، ولكن المشكلة قد تكمن في أن الدالة save() في ملف models/cart.js تقوم بإضافة المنتج إلى ملف السلة التسوق كل مرة يتم فيها استدعاءها. بمعنى آخر، إذا تم زيادة كمية منتج معين في سلة التسوق بالفعل، فإن الدالة save() ستزيد الكمية مرة أخرى عندما يتم استدعاءها مرة أخرى. وتستطيع حل هذه المشكلة بتعديل الدالة Cart.save في ملف cart.js للتأكد من إذا كان المنتج موجودًا بالفعل في العربة فلا تزيد عدد الكمية بل يتم الاحتفاظ بها كما هي، بينما إذا كان المنتج غير موجود يتم حفظه في العربة بعدة قطع والكمية تكون واحدة. static async save(id, price) { try { const cartFile = path.join(__dirname, "../", "data", "cart.json"); const fileContent = await fs.readFile(cartFile); const cart = JSON.parse(fileContent); const productIndex = cart.products.findIndex((product) => product.id === id); if (productIndex !== -1) { cart.products[productIndex].quantity++; } else { cart.products.push({ id, price, quantity: 1 }); } await fs.writeFile(cartFile, JSON.stringify(cart)); } catch (error) { console.log(error); } }
  3. اللغة الأكثر استخدامًا في مجال الذكاء الاصطناعي هي لغة بايثون، ولكن أولاً، يمكنك البدء بتعلم الأساسيات في علم الحاسوب والرياضيات، حيث يعتبر التميز في هذين المجالين ضروريًا لفهم مفاهيم الـ AI. بعد ذلك، يمكنك تعلم لغات البرمجة المستخدمة في AI مثل Python و R و MATLAB، ويوجد في أكاديمية حسوب دورة كاملة خاصة بلغة البايثون، ستتعلم فيها ما يلي: ماذا ستتعلم في هذه الدورة؟ الأسس البرمجية السليمة عبر لغة Python التعامل مع مختلف صيغ الملفات مثل إكسل Excel وورد Word وخدمات المستندات السحابية استخراج البيانات من صفحات الويب Web Scraping وتحليلها أساسيات التعامل مع قواعد البيانات عبر بايثون، والتعامل مع البريد الإلكتروني لإرسال الرسائل أساسيات إطار العمل جانغو Django بناء تطبيق إدارة المهام باستخدام إطار العمل جانغو Django تطوير متجر إلكتروني متكامل باستخدام إطار العمل جانغو Django وربطه مع وسائل الدفع باي بال PayPal وسترايب Stripe أساسيات إطار العمل فلاسك Flask، وبناء مدونة بسيطة تطوير واجهة برمجية API اعتمادًا على نمط RESTful لمعالجة الصور وقد تم النقاش من قبل حول مجال الذكاء الاصطناعي، فأرجو من قراءة التالي تجنبًا للتكرار: وكنصيحة، إذا كنت صغير السن، فتعلم ما تريده فالمجال واعد لكن في الدول الأجنبية، أما إذا كنت تبحث عن وظيفة عما قريب فالأفضل تحديد وجهتك بدقة والبحث عن المهارات المطلوبة في سوق العمل.
  4. Await في Flutter هي كلمة مفتاحية تستخدم مع العمليات الغير متزامنة أو العمليات الثقيلة التي لا يمكن تنفيذها بشكل فوري. ويتم استخدام Await في Flutter لتحسين أداء التطبيق وتجنب حدوث مشاكل في التنفيذ، حيث تستخدمات Await مع دوال تعيد Future في Flutter، وتسمى هذه الدوال بـ "Future Functions". وعند استخدام Await مع Future Function، يتم إيقاف تنفيذ الدالة الحالية حتى يتم الانتهاء من العملية الغير متزامنة، واسترداد القيمة المتوقعة، ولذلك، فاستخدام Await في Flutter يساعد على تنظيم تنفيذ البرنامج وتفادي حدوث المشاكل والأخطاء التي قد تنجم عن تنفيذ العمليات الثقيلة بشكل متزامن. مثلاً، إذا كان لدينا دالة fetchData() التي تقوم بجلب بيانات من API وتعيد Future، يمكننا استخدام await لجلب البيانات وإظهارها في واجهة المستخدم كما يلي: Future<void> fetchData() async { // جلب البيانات من API final response = await http.get(Uri.parse('https://example.com/api/data')); // تحويل بيانات الاستجابة إلى قائمة من العناصر final data = jsonDecode(response.body) as List<dynamic>; // إظهار البيانات في واجهة المستخدم setState(() { _data = data; }); } وتستطيع استخدام await مع أي دالة تعيد Future في Flutter، مثل دوال تعيد Future من نوع SharedPreferences و AnimationController. مثال آخر: إذا كان لدينا طريقة لاستدعاء ملف JSON من الإنترنت باستخدام حزمة http في Flutter ، فتستطيع استخدام await لإيقاف تنفيذ الكود حتى يتم جلب الملف: import 'package:http/http.dart' as http; Future<String> fetchJson() async { final response = await http.get(Uri.parse('https://example.com/data.json')); if (response.statusCode == 200) { return response.body; } else { throw Exception('Failed to load data'); } } تعود الدالة fetchJson بـ Future<String> ، وتستخدم http.get() لجلب بيانات JSON من URL. بعد ذلك ، نستخدم await لإيقاف تنفيذ الكود حتى يتم جلب الملف. إذا كانت الاستجابة من الملقم بنجاح (مثلاً ،رمز الاستجابة 200) ، فستعود الدالة بـ response.body (الجسم الخاص بالاستجابة) كنص String ، وإلا سيتم تنفيذ Exception.
  5. تم التوضيح من قبل عزيزي، يمكنك دمج البيانات المسترجعة من الجدولين في نفس القائمة باستخدام الدالة addAll() في مكانين مختلفين في الكود. هناك عدة طرق للقيام بذلك وهذا مثال لكيفية الدمج: Future<void> _fetchData() async { final FirebaseFirestore firestore = FirebaseFirestore.instance; // Fetch the first query snapshot and extract the value of 'TopicState' final QuerySnapshot topicsSnapshot = await firestore .collection('topics') .where('id', isEqualTo: widget.PostID) .get(); final int topicState = topicsSnapshot.docs.isNotEmpty ? topicsSnapshot.docs.first.get('Id_Sub_Category') : null; final QuerySnapshot subCategorySnapshot = await firestore.collection('Sub_Category').where('idSubCat', isEqualTo: topicState).get(); final List<FullListWomanModel> data = []; if (topicsSnapshot.docs.isNotEmpty) { data.addAll(topicsSnapshot.docs.map((doc) => FullListWomanModel.fromJson(doc.data() as Map<String, dynamic>)).toList()); } if (subCategorySnapshot.docs.isNotEmpty) { // Loop over the documents of the Sub_Category collection and check if the document already exists in the data list to avoid duplication subCategorySnapshot.docs.forEach((doc) { final FullListWomanModel model = FullListWomanModel.fromJson(doc.data() as Map<String, dynamic>); if (!data.contains(model)) { data.add(model); } }); } setState(() { _ListDataDisplay = data; }); } الكود يقوم بإضافة جميع الوثائق التي تم العثور عليها في الجدول الثاني Sub_Category إلى القائمة data، ولكنه يتحقق أيضًا مما إذا كانت الوثيقة موجودة بالفعل في القائمة الرئيسية لتجنب التكرار والحفاظ على وجود عناصر فريدة في القائمة المدمجة النهائية.
  6. حاول تنفيذ التالي : استخدام قيمة مشتركة بين الجدولين (idSubCat) لدمج البيانات في القائمة، بعد دمج البيانات ، وإضافة القائمة المدموجة إلى القائمة الرئيسية التي تحتوي على جميع البيانات. Future < void > _fetchData() async { final FirebaseFirestore firestore = FirebaseFirestore.instance; final QuerySnapshot subCategorySnapshot = await firestore .collection('Sub_Category') .where('idSubCat', isEqualTo: (await firestore .collection('topics') .where('id', isEqualTo: widget.PostID) .get()) .docs .first .get('Id_Sub_Category')) .get(); final List < FullListWomanModel > data = []; if (subCategorySnapshot.docs.isNotEmpty) { final List < FullListWomanModel > subCategories = subCategorySnapshot.docs .map((doc) => FullListWomanModel.fromJson(doc.data() as Map < String, dynamic > )) .toList(); data.addAll(subCategories); } final QuerySnapshot topicsSnapshot = await firestore .collection('topics') .where('id', isEqualTo: widget.PostID) .get(); if (topicsSnapshot.docs.isNotEmpty) { final List < FullListWomanModel > topics = topicsSnapshot.docs .map((doc) => FullListWomanModel.fromJson(doc.data() as Map < String, dynamic > )) .toList(); // Merge the two lists based on a common field final Map < int, FullListWomanModel > mergedData = {}; for (final topic in topics) { mergedData[topic.id] = topic; } for (final subCategory in subCategories) { mergedData[subCategory.idSubCat] = subCategory; } final List < FullListWomanModel > mergedList = mergedData.values.toList(); data.addAll(mergedList); } setState(() { _ListDataDisplay = data; }); }
  7. قمت بتعديل الكود لك ليصبح مختصرًا أكثر ويحصل على نفس البيانات بشكل أكثر فعالية، وتستطيع استخدام الدالة "sort" بعد ذلك إذا رغبت في فرز البيانات. Future<void> _fetchData() async { final FirebaseFirestore firestore = FirebaseFirestore.instance; final QuerySnapshot subCategorySnapshot = await firestore .collection('Sub_Category') .where('idSubCat', isEqualTo: (await firestore .collection('topics') .where('id', isEqualTo: widget.PostID) .get()) .docs .first .get('Id_Sub_Category')) .get(); final List<FullListWomanModel> data = []; if (subCategorySnapshot.docs.isNotEmpty) { final List<FullListWomanModel> subCategories = subCategorySnapshot.docs .map((doc) => FullListWomanModel.fromJson(doc.data() as Map<String, dynamic>)) .toList(); data.addAll(subCategories); } setState(() { _ListDataDisplay = data; }); } وإليك شرح مختصر، الكود يستخدم Firebase للاستعلام عن بيانات من جداول مختلفة ودمجها في مصفوفة واحدة. وذلك من خلال استخدام الحقل الفريد في جدول الـ "topics" للوصول إلى جدول الـ "Sub_Category" باستخدام دالة الـ "join" ، ثم جمع البيانات التي تحتاجها في مصفوفة واحدة باستخدام الدالة "addAll". وتستطيع الاستغناء عن sort فأنت لست بحاجة إليها بالنسبة لسؤالك.
  8. حاول تجربة الحل التالي: استخدم الحقل الفريد في جدول الـ "topics" للوصول إلى جدول الـ "Sub_Category" ، وذلك باستخدام دالة الـ "join". اجمع البيانات التي تحتاجها في مصفوفة واحدة باستخدام الدالة "addAll" كما هو موضح في الكود الحالي الخاص بك. ثم، تستطيع استخدام الدالة "sort" لفرز المصفوفة بناءً على الوقت الذي تم الحصول عليه من كل جدول. ليصبح الكود بعد التعديل كالتالي: Future<void> _fetchData() async { final FirebaseFirestore firestore = FirebaseFirestore.instance; final QuerySnapshot topicsSnapshot = await firestore .collection('topics') .where('id', isEqualTo: widget.PostID) .get(); final int topicState = topicsSnapshot.docs.isNotEmpty ? topicsSnapshot.docs.first.get('Id_Sub_Category') : null; final QuerySnapshot subCategorySnapshot = await firestore .collection('Sub_Category') .where('idSubCat', isEqualTo: topicState) .get(); final List<FullListWomanModel> data = []; // 1. دمج الجدولين بإستخدام join if (topicsSnapshot.docs.isNotEmpty && subCategorySnapshot.docs.isNotEmpty) { final List<QuerySnapshot> snapshots = await Future.wait([ firestore.collection('topics').where('id', isEqualTo: widget.PostID).get(), firestore .collection('Sub_Category') .where('idSubCat', isEqualTo: topicState) .get(), ]); final List<FullListWomanModel> topics = snapshots[0].docs.map((doc) => FullListWomanModel.fromJson(doc.data() as Map<String, dynamic>)).toList(); final List<FullListWomanModel> subCategories = snapshots[1].docs.map((doc) => FullListWomanModel.fromJson(doc.data() as Map<String, dynamic>)).toList(); // 2. إضافة البيانات إلى مصفوفة واحدة باستخدام addAll data.addAll(topics); data.addAll(subCategories); // 3. فرز المصفوفة بناءً على الوقت الذي تم الحصول عليه من كل جدول data.sort((a, b) => b.time.compareTo(a.time)); } setState(() { _ListDataDisplay = data; }); }
  9. أرجو أن أكون قد فهمت سؤالك بشكل صحيح، أنت تريد إضافة خدمة جديدة صحيح؟ في البداية دعني أوضح أنك بحاجة إلى التحدث إلى الدعم الخاص بمنصة خمسات في حال كان هناك مشكلة في إضافة الخدمة أو قبولها. وقد تم شرح من قبل كيف يتم إضافة الخدمات على منصة خمسات. الطريقة الصحيحه لإضافة خدمة مميزة تجذب المشترى كيفية العمل على موقع خمسات وتحقيق أول 5 دولار؟ إضافة خدمة مميزة كيفية إضافة التطويرات وإن كانت المصادر السابقة لا تجيب على سؤالك، أرجو منك توضيح المطلوب بالضبط، وأيضًا إذا كان يتم إتباع التعليمات الخاصة بالإضافة أو الخدمة، فعليك بالتحدث لمركز الدعم على منصة خمسات كما أشرت إليك.
  10. أرجو منك مشاركة الملفات بشكل صحيح، حيث أن الملف الذي أرفقته غير صالح، أي عليك بضغط مجلد المشروع بالكامل ثم إرفاقه في السؤال. وقد ذكرت لك من قبل طريقة استدعاء البيانات في سؤالك الذي طرحته هنا. مشكله عندما احاول استخراج معلومات من قاعدة البيانات إلى form تظهر لي أخطاء فأرجو منك التوضيح، ما الذي تم تعديله على الكود الخاص بك، وماهي الأخطاء لنتمكن من مساعدتك. وعليك بالتحقق من النقاط التالية: تأكد من أن اسم المستخدم وكلمة المرور واسم قاعدة البيانات المستخدمة في ملف الاتصال config.php صحيحة ومتطابقة مع تلك المستخدمة في phpMyAdmin. الاستعلام المرسل إلى قاعدة البيانات صحيح ولا يحتوي على أخطاء إملائية أو أخرى. المتغيرات المستخدمة في استعلام SQL معرفة مسبقًا وليس لها أي قيم غير صحيحة أو فارغة. استخدام دالة mysqli_query() يعيد نتيجة صحيحة ولا يوجد بها أي خطأ. المتغيرات المستخدمة في الاستعلام SQL تمرر بشكل صحيح إلى دالة mysqli_query()، عن طريق تحديد قيمتها بشكل صحيح في استعلام SQL. نوع البيانات المرجعة من استخدام دالة mysqli_query() هي من نوع mysqli_result، وإلا فإنها ستكون قيمة خاطئة وستؤدي إلى حدوث الأخطاء. المتغيرات المستخدمة في العرض والاستخدام في الكود معرفة مسبقًا ولا يوجد بها أي قيم غير صحيحة أو فارغة. الصفحة التي تستخدمها لعرض البيانات تحتوي على المكونات اللازمة لعرض البيانات بشكل صحيح، مثل جدول HTML وعناوين الأعمدة وصفوف البيانات.
  11. السن مناسب حيث أن الأطفال في سن 11 عامًا قادرون على تعلم البرمجة، ويتمتعون بالقدرة على فهم مفاهيم البرمجة والقدرة على الابتكار والإبداع في إنشاء البرامج. والحد الأدنى لتعلم البرمجة يمكن أن يختلف من شخص لآخر، وذلك يعتمد على مدى الاستعداد والقدرة على التعلم والتفاعل مع المواد التعليمية. ومع ذلك، فإن الحد الأدنى الموصى به للبدء في تعلم البرمجة هو حوالي 8-10 سنوات، ويمكن للأطفال في هذا العمر أن يتعلموا البرمجة باستخدام لغات البرمجة المناسبة لهذا العمر مثل Scratch و Blockly وغيرها. وفي دورة علوم الحاسب سيتم شرح الأساسيات ومن ضمنها استخدام بيئة سكراتش لتعلم أساسيات التفكير المنطقي ومفاهيم البرمجة. وإليك نبذة مختصرة عن الدورة: ماذا ستتعلم في هذه الدورة؟ أساسيات الحاسوب وعلومه والتفكير المنطقي وما هي الخوارزميات وكيف تفيد في البرمجة تطبيقات عملية على أساسيات التفكير المنطقي باستخدام بيئة سكراتش Scratch التفاعلية أساسيات لغة البرمجة JavaScript وتطبيق المفاهيم التي تم شرحها باستخدامها، والتوسع في شرح التطبيقات العملية للغات البرمجة أساسيات أنظمة التشغيل المختلفة وكيفية تثبيت البرمجيات اللازمة للبرمجة عليها أساسيات سطر الأوامر في نظام لينكس، وشرح الأسس التي بني عليها النظام مع تطبيقها عمليًا أنظمة قواعد البيانات المختلفة، مع شرح تفصيلي للغة SQL للتعامل معها مبادئ أساسية في أنظمة قواعد البيانات NoSQL المفاهيم الأساسية التي تبنى فيها صفحات الويب مفاهيم أساسية في الشبكات والخوادم، وكيف يتم استقبال الطلبيات إلى الخادم والرد عليها مبادئ الحماية والأمان في الويب لمن هذه الدورة؟ لمن لا يمتلك أي خبرة مسبقة في البرمجة ويريد الدخول في هذا المجال الشيق لمن يفكر بتغيير مساره المهني ويرغب بأن يصبح مبرمج ولا يعرف من أين يبدأ للمبرمجين الذين تعلموا احدى لغات البرمجة ذاتياً ويرغبوا بملئ الفراغات وتعلم الأسس لطلاب الجامعات الذين يواجهوا صعوبة ببعض المواد مثل أنظمة التشغيل وقواعد البيانات لمن حاول تعلم البرمجة بالسابق وشعر أنها صعبة ولم يتمكن من المواصلة وبعد الإنتهاء منها، سيستطيع الطفل استيعاب مجال البرمجة والمفاهيم المحيطة به، ويصبح قادر على تحديد ما الذي يريد تعلمه بعد ذلك من خلال الدورات الأخرى. وباشتراكه في دورة علوم الحاسب، يمكنه رؤية المسار الأول من باقي الدورات لتحديد ما الذي يريده قبل الاشتراك في الدورة. والمهم في ذلك السن، هو تحبيب وترغيب البرمجة إلى الطفل وعدم إنتظار نتائج منه، بل يكفي تقديم دورة علوم الحاسب إليه وتشجيعه على دراستها، حتى لو قام بدراستها على مراحل لا مشكلة. وأيضًا التعلم عملية تكرارية، لذلك قد يحتاج إلى إعادة تكرار المشاهدة والتطبيق على ما تعلمه على فترات متباعدة، وبذلك يتم كسر الحاجز واستيعاب المفاهيم والأساسيات. وهناك فيديو خاص عن نصائح لتعليم البرمجة للأطفال من أكاديمية حسوب.
  12. مجال العمر الحر ليس مجال بحد ذاته بل سوق عمل، ويجب عليك إمتلاك مهارة للمنافسة به والحصول على مشاريع وفرص توظيف عن بعد. وفي البداية عليك بمعرفة المجالات الملطوبة في مواقع العمل الحر والتي منها المواقع التالية: مستقل خمسات بعيد ومن المفترض أن تكوني متخصصة في أحد المهارات التالية للعمل على المواقع السابقة: أعمال وخدمات استشارية برمجة، تطوير المواقع والتطبيقات هندسة، عمارة وتصميم داخلي تصميم، فيديو وصوتيات تسويق إلكتروني ومبيعات كتابة، تحرير، ترجمة ولغات دعم، مساعدة وإدخال بيانات تدريب وتعليم عن بعد وكل مجال من السابق بداخله تخصصات أخرى، فمثلاً، مجال البرمجة يحتوي على برمجة المواقع وبرمجة تطبيقات الهاتف وبرمجة برامج سطح المكتب، وبداخل كل تخصص هناك لغات برمجة مختلفة وهكذا. والأمر قد يبدوا معقد من الخارج، لكن خطوة بخطوة سيسهل الأمر عليك والجميع بدأ من نقطة الصفر. وبالنسبة للمدة اللازمة لتعلم أي مهارة، ففي رأي من 6 شهور وحتى سنة أو سنتين، حيث أن الأمر يتوقف على مقدار إجتهادك، وأيضًا معلوماتك المتوفرة أو خبراتك التي قد تساعدك في التعلم بشكل أسرع. والأفضل لك هو قراءة المقالات التالية لتحديد المجال الذي تريده، وفهم طبيعة العمل الحر بشكل شامل، بدلاً من التصورات الخيالية التي يروج لها على وسائل التواصل الإجتماعي. دليلك الشامل إلى العمل الحر عبر الإنترنت 28 وظيفة من وظائف العمل الحر الأكثر طلبًا للمبتدئين: 10 مقالات في مجال العمل الحر ينبغي لك قراءتها كيفية العمل على موقع مستقل وتحقيق أول 25 دولار بعد أن تقومي بقراءة المقالات السابقة، لا تترددي في الاستفسار عما تحتاجيه هنا، ولكن بعد قراءة المقالات. وأيضًا قد تحتاجي إلى قراءة النقاش التالي:
  13. بالإمكان ربط كود بايثون مع كود React Native باستخدام Bridge API. ويستخدم Bridge API لإنشاء واجهات المستخدم والتعامل مع قواعد البيانات والاتصال بخدمات الويب والتحكم في التحليلات والأدوات الأخرى التي تعمل بلغة بايثون. ويتم تنفيذ Bridge API باستخدام وظيفة "native modules" في React Native و "Python modules" في بايثون. ويجب معرفة أنه يمكن استخدام Bridge API لتوفير القدرة على إعادة استخدام برامج بايثون الموجودة بالفعل وإضافة ميزات جديدة إلى تطبيقات React Native باستخدام لغة بايثون. مثلاً، تستطيعي استخدام بايثون لإنشاء نماذج التعلم الآلي والتفاعل معها في تطبيق React Native، وذلك من خلال مكتبة TensorFlow المتاحة في بايثون لإنشاء نماذج تعلم الآلة وتدريبها على البيانات. وبعد ذلك نستخدم Bridge API لربط تطبيق React Native مع تلك النماذج وتوفير واجهة المستخدم اللازمة لتفاعل المستخدمين معها. مثال بسيط على طريقة الربط بين بايثون وReact Native في البداية، عليك بإنشاء وحدة بايثون بسيطة تُسمى "calculator.py" وضعي بها الكود التالي: def add(a, b): return a + b الآن سنقوم بإنشاء Native Module في React Native لاستدعاء هذه الوحدة. يمكنك إنشاء ملف جديد يسمى "CalculatorModule.js" وضعي به التالي: import { NativeModules } from 'react-native'; const { Calculator } = NativeModules; export default { add: (a, b) => { return Calculator.add(a, b); }, }; وتأكدي من تحديد اسم Native Module كـ "Calculator"، ثم يمكنك استخدام هذا Native Module في كود React Native الخاص بك. من خلال إنشاء شاشة جديدة تُسمى "CalculatorScreen.js" كالتالي: import React, { useState } from 'react'; import { View, Text, TextInput, Button } from 'react-native'; import Calculator from './CalculatorModule'; const CalculatorScreen = () => { const [a, setA] = useState(''); const [b, setB] = useState(''); const [result, setResult] = useState(''); const handleAdd = () => { const res = Calculator.add(Number(a), Number(b)); setResult(res.toString()); }; return ( <View> <TextInput value={a} onChangeText={setA} /> <TextInput value={b} onChangeText={setB} /> <Button title="Add" onPress={handleAdd} /> <Text>{result}</Text> </View> ); }; export default CalculatorScreen; وكما ترين يتم استدعاء Native Module "Calculator" واستخدامه في دالة "handleAdd" لجمع الأعداد المدخلة، وعرض نتيجة الجمع في عنصر "Text". والمثال بسيط لكنه يوضح كيفية استخدام Bridge API لربط كود بايثون مع كود React Native، وبنفس المبدأ تستطيعي تطوير تطبيقات React Native متكاملة مع قواعد البيانات والتحكم في التحليلات والأدوات الأخرى.
  14. بالطبع يمكنك إنشاء مواقع، تطبيقات وبرامج سطح مكتب باستخدام جافاسكريبت. والتطبيقات يتم إنشائها باستخدام إطار العمل الشهير "React Native"، و الذي يستخدم مجموعة متنوعة من التقنيات والأدوات بما في ذلك HTML و CSS و JavaScript لإنشاء تطبيقات الهواتف. وبالنسبة لكفاءة التطبيقات المبنية باستخدام الجافاسكريبت، فإنها متقاربة في الأداء مقارنة باللغات الأخرى المستخدمة في تطوير التطبيقات مثل Swift و Kotlin و Java. ومع ذلك ، فإن كفاءة التطبيق يعتمد على عدة عوامل أخرى بما في ذلك نوع التطبيق وحجم البيانات التي يتم تداولها ومستوى تحسين الأداء للكود. والمقارنة ظالمة بعض الشيء، حيث أن React Native يسمح لك بإنشاء تطبيقات متعددة المنصات بسهولة بين منصتي iOS و Android ، وبالتالي يسهل عملية تطوير التطبيقات ويوفر الكثير من الوقت والجهد. أما التطبيقات الأصلية Native المبنية بواسطة Swift و Kotlin و Java فهي لا تعمل على المنصات الأخرى، أي Swift تستخدم لبناء تطبيقات لنظام iOS بينما Kotlin و Java لنظام أندرويد. وقد تم ذكر المزيد من التفاصيل والشرح والمقارنات في نقاشات سابقة، أرجو منك قرائتها تجنبًا للتكرار.
  15. مساحة الرامات لديك صغيرة جدًا، وتشغيل نظامي وهمي على تلك المساحة من الرامات أمر صعب، لذلك يجب أن تكون على الأقل 8 جيجابايت وتلك مساحة صغيرة أيضًا، ففي الوقت الحالي المساحة المناسبة للرامات هي 16 جيجابايت. وذلك لتتمكن من تشغيل المتصفح ومتابعة الدروس وتشغيل محرر الأكواد وبرامج أخرى بجانب النظام الوهمي وأيضًا النظام الأساسي الخاص بك يشغل ما بين 2 جيجابايت إلى 4 جيجابايت. ولا تضغط على نفسك كثيرًا، يكفيك 8 جيجابايت من الذاكرة العشوائية لتعمل بشكل جيد، والأفضل هو 16 أو 12 جيجابايت حسب استطاعتك. وأيضًا سيفيدك بالتأكيد شراء هارد SSD وجعله وحدة التخزين الأساسية للنظام والبرامج لديك، فالعمل على هارد HDDيجعلك تشعر كأن الجهاز يعاني حتى لو كانت مواصفات الحاسوب مرتفعة، وذلك سبب سرعة القراءة والكتابة المنخفضة لذلك النوع من وحدة التخزين. لكن كما أشرت لك، الأمر يتوقف على ميزانيتك ولا تضغط على نفسك كثيرًا ،قم بشراء الرامات أولاً وتستطيع شراء رامات مستخدمة و SSD وأيضًا بتكلفة منخفضة.
  16. .loader { border: 16px solid #f3f3f3; border-top: 16px solid #3498db; border-radius: 50%; width: 120px; height: 120px; animation: spin 2s linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } السبب هو أنك قمت بنسخ تنسيق CSS الخاص بالـ Loader السابق حيث أنني وفرت لك تنسيق للـ Loader بسيط يقوم بالدوران، أما إذا أردت استخدام الصورة فعليك باستخدام تنسيق مختلف أي قم بإزالة التنسيق الذي نسخته أنت. وعليك بتنسيق كلاس .loader بالشكل الذي تراه مناسبًا. وكنصيحة عزيزي، لا تقم أبدًا بنسخ الكود دون أن تقرأه وتعرف ما الذي يضيفه لمشروعك أو ماذا يفعل، تجنبًا لحدوث مشاكل في الكود الخاص بك.
  17. عليك بإضافة مسار الصورة الصحيح في الكود الذي اشرت إليه سابقٌا، فمثلاً لو كانت الصورة داخل مجلد images في مجلد المشروع فسيصبح المسار كالتالي: <!-- loader --> <div class="loader"> <img src="images/loader.gif"> </div>
  18. السبب في أن جميع العناصر لديها نفس القيمة percentage هو لأنه تم تحديث القيمة في الحلقة forEach بشكل متكرر وتم استخدام نفس الحالة لجميع العناصر. ولذلك، عليك باستخدام دالة محدثة لتحديث قيمة percentage لكل عنصر في الحدث onscroll. ويمكن تغيير الكود كالتالي: const [percentage, setPercentage] = useState({}) window.onscroll = function () { if (window.scrollY >= progressAnim.current.offsetTop - 300) { skills.forEach(skill => { setPercentage(prevPercentage => ({ ...prevPercentage, [skill.id]: skill.progress })) }) } } return ( <div className="App"> <Section src={img_1} /> <Section src={img_2} /> <div className="skills" ref={progressAnim}> {skills.map(skill => ( <Progress key={skill.id} percentage={percentage[skill.id] || 0} circleWidth="200" name={skill.language} /> ))} </div> </div> ) حيث تم تحويل القيمة percentage إلى كائن حيث يتم استخدام معرف العنصر كمفتاح. ثم استخدام دالة محدثة لتحديث قيمة percentage بشكل منفصل لكل عنصر. أخيراً، واستخدام القيمة المحدثة في كل عنصر في عنصر تقدم الدائرة Progress. طريقة أخرى و هناك طريقة أخرى لحل هذه المشكلة، وهي باستخدام useEffect بدلاً من استخدام دالة محدثة في حدث onscroll، كالتالي: const [percentage, setPercentage] = useState({}) useEffect(() => { const handleScroll = () => { if (window.scrollY >= progressAnim.current.offsetTop - 300) { const newPercentage = {} skills.forEach(skill => { newPercentage[skill.id] = skill.progress }) setPercentage(newPercentage) } } window.addEventListener('scroll', handleScroll) return () => { window.removeEventListener('scroll', handleScroll) } }, [skills, progressAnim]) return ( <div className="App"> <Section src={img_1} /> <Section src={img_2} /> <div className="skills" ref={progressAnim}> {skills.map(skill => ( <Progress key={skill.id} percentage={percentage[skill.id] || 0} circleWidth="200" name={skill.language} /> ))} </div> </div> ) باستخدام useEffect بدلاً من الحدث onscroll، يتم استدعاء دالة handleScroll في كل مرة يتم فيها التمرير، وتحدث قيمة percentage فقط إذا تم تمرير العنصر المطلوب. ثم إضافة الحدث الذي يتم استدعاءه إلى النافذة في useEffect. وفي النهاية، وإزالة الحدث عند إزالة المكون.
  19. إضافة صوت ترحيبي و Loader لإضافة صوت الترحيب ، تستطيع استخدام عنصر HTML5 audio ، ويتم تشغيله باستخدام JavaScript. أولاً ، قم بإنشاء عنصر audio في HTML الخاص بك باستخدام العلامة <audio> ، وحدد مصدر الصوت الخاص بك باستخدام العلامة <source> ، كما يلي: <audio id="welcome-sound"> <source src="path/to/sound/file.mp3" type="audio/mp3"> </audio> بعد ذلك، عليك استخدام addEventListener لتعيين حدث load لتشغيل الصوت عندما تنتهي صفحة الويب من التحميل بدلاً من استخدام window.onload. وسنعتمد على حدث DOMContentLoaded بدلاً من load لتحديد الحدث الذي يتم إطلاقه عندما يتم تحميل كل العناصر في الصفحة بشكل كامل بدلاً من انتظار الصفحة بالكامل (مثل الصور) للانتهاء من التحميل ، وهذا يجعل الصفحة تستجيب بشكل أسرع. document.addEventListener("DOMContentLoaded", function(event) { // تشغيل الصوت document.getElementById('welcome-sound').play(); }); إضافة loader إلى صفحتك سيتم الجمع ما بين استخدام العناصر المختلفة في CSS لإنشاء loader مخصص، وتستطيع استخدام صور GIF المحملة مسبقًا ، مثل الصورة التي أرفقتها، أو يمكنك استخدام الرسومات SVG أو CSS لإنشاء loader. بعد ذلك ، سنعتمد على JavaScript لإظهار وإخفاء loader بناءً على حالة تحميل الصفحة. HTML <!-- loader --> <div class="loader"> <img src="path/to/loader/image.gif"> </div> CSS .loader { border: 16px solid #f3f3f3; border-top: 16px solid #3498db; border-radius: 50%; width: 120px; height: 120px; animation: spin 2s linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } في الكود أعلاه ، يتم إنشاء loader باستخدام حدود CSS ودائرة مع مجموعة محددة من الألوان. يتم إنشاء الحركة باستخدام animation CSS ، والذي يسمح لل loader بالدوران بشكل لا نهائي. Javascript document.addEventListener("DOMContentLoaded", function(event) { const loader = document.querySelector(".loader"); loader.style.display = "none"; // إخفاء loader عند بدء تحميل الصفحة // تشغيل الصوت document.getElementById('welcome-sound').play(); // إظهار loader بعد 3 ثوانٍ من بدء تحميل الصفحة setTimeout(function() { loader.style.display = "block"; }, 3000); // إخفاء loader بعد 5 ثوانٍ من بدء تحميل الصفحة setTimeout(function() { loader.style.display = "none"; }, 5000); }); من خلال استهداف العنصر .loader باستخدام document.querySelector يتم إخفاؤه باستخدام style.display = "none". ثم تشغيل الصوت بواسطة document.getElementById('welcome-sound').play();. بعد ذلك ، يتم استخدام setTimeout لإظهار loader بعد 3 ثوانٍ من بدء تحميل الصفحة ، وإخفائه بعد 5 ثواني. إضافة صوت عندما يقوم الزائر بإنشاء حساب جديد عليك باستخدام العنصر audio في HTML لتشغيل الصوت ويمكنك تعيين مصدر الصوت في الـ JavaScript. بالنسبة لإضافة اسم العميل المسجل إلى رسالة الصوت ، سنعتمد على قيمة العنصر input الخاص بالاسم لاسترداد الاسم الذي قام المستخدم بكتابته. ثم يمكنك إضافة هذا الاسم إلى نص الرسالة الصوتية باستخدام concat في JavaScript. HTML <input type="text" id="name" placeholder="الاسم"> <button id="submit">إنشاء الحساب</button> <audio id="welcome-sound"> <source src="welcome.mp3" type="audio/mpeg"> </audio> Javascript document.getElementById("submit").addEventListener("click", function() { const name = document.getElementById("name").value; const welcomeMessage = "مرحباً " + name + "! تم إنشاء حسابك بنجاح"; const audio = document.getElementById("welcome-sound"); audio.src = "welcome.mp3"; // مصدر الصوت audio.play(); setTimeout(function() { alert(welcomeMessage); }, 3000); // 3 ثوانٍ للتأكد من عرض الرسالة الصوتية بشكل كامل }); الكود يستخدم addEventListener لاستماع حدث النقر على الزر "إنشاء الحساب". ويتم استخدام قيمة العنصر input الخاص بالاسم لإعداد رسالة الترحيب بشكل ديناميكي. ثم يتم تشغيل الصوت وإضافة رسالة الترحيب إلى الـ alert التي تظهر بعد ثلاث ثوانٍ من تشغيل الصوت. ويمكنك تغيير المدة المحددة في setTimeout وفقًا لاحتياجاتك.
  20. يجب عليك الحرص عند استخدام برامج التسويق وارسال الرسائل الترويجية على تيليجرام، لأنه إذا قمت بإرسال العديد من الرسائل إلى مستخدمين لا يرغبون فيها، فقد يتم التبليغ عن حسابك ويتم حظره من قبل تيليجرام. وبالنسبة للحلول الممكنة، يمكن تجربة الخيارات التالية: الحرص على عدم إرسال العديد من الرسائل المزعجة في فترة قصيرة، والتأكد من الحصول على موافقة المستخدمين قبل إرسال الرسائل. استخدام خدمات الرسائل الجماعية الرسمية على تيليجرام والتي توفرها شركة تيليجرام نفسها، مثل Telegram Advertising وTelegram Bot API، والتي تتيح لك إرسال الرسائل التسويقية بطريقة شرعية. ,حد الرسائل الأقصى لإرسال الرسائل من خلال Telegram Bot API هو 30 رسالة في الثانية، وهذا يعني أنه يمكنك إرسال حوالي 1,800 رسالة في الدقيقة باستخدام هذه الواجهة. ومع ذلك، عليك بالحرص في عدم إرسال الرسائل بشكل متكرر ومتعدد، حتى لا يتم حظر حساب البوت الخاص بك من قبل تيليجرام، والأفضل استخدام المهام المجدولة للحفاظ على توزيع متساوٍ للرسائل على مدار اليوم بدلاً من إرسال جميع الرسائل في نفس الوقت. وأيضًا عليك بتحسين جودة المحتوى الذي ترسله، وجعله مفيداً وجذاباً للمستخدمين، مما يقلل من احتمالية التبليغ عنها. عند التبليغ عن رسائلك أنها Spam أو مزعجة سيتم حظر أو تقييد حسابك بعد عدد معين من التبليغات، حيث يتم فحص حسابك من قبل مشرفي تيليجرام. وهناك حل آخر وهو إنشاء جروب خاص بالمهتمين بما تسوق له، والأمر سيستغرق وقت، لكن تلك الطريقة أفضل ومستدامة وستحقق نتائج بلا شك، وهناك عدة طرق لفعل ذلك، إما من خلال توفير عروض في الجروب الخاص بك، خصومات أو شروحات حصرية وهكذا، أي يجب أن يحصل المستخدم على فائدة من إشتراكه في القناة أو الجروب الخاص بك. وبالنسبة لحسابك الذي تم حظره، حاول التحدث وشرح مشكلتك من خلال الرابط التالي : https://telegram.me/spambot
  21. لعرض القائمة الكاملة للأوامر التي تم إدخالها في التيرمنال، قم بإدخال الأمر التالي في النافذة الخاصة بالتيرمنال وستظهر لك جميع الأوامر التي قمت بإدخالها في السابق بالترتيب الزمني. history أيضًا تستطيع استخدام الأمر التالي للبحث عن أوامر محددة بدلاً من عرض القائمة بأكملها. history | grep 'الأمر المبحوث عنه' مثلاً، للعثور على جميع الأوامر التي تحتوي على "git" في السجل السابق للأوامر، قم بإدخال الأمر history | grep 'git'
  22. تستطيع الحصول على المجلد الخاص بمشروع Unity من خلال إطار العمل (Editor) في Unity، حيث يحتوي على جميع الملفات والمجلدات الخاصة بمشروعك. وعليك بالنقر بزر الماوس الأيمن على ايقونة المشروع في لوحة المشاريع في Unity، ثم اختيار "Show in Explorer"، و سيتم فتح نافذة المستكشف وسترى المجلد الذي يحتوي على جميع ملفات المشروع. بمجرد الحصول على هذا المجلد، يمكنك متابعة الخطوات التي ذكرتها سابقًا لحل المشكلة التي تواجهك.
  23. رسالة الخطأ تعني عدم وجود ملف meta لبعض الملفات في مجلدات البرنامج، وبالتالي يتم تجاهل تلك الملفات من قبل البرنامج. لحل هذا الخطأ، عليك بالاتي : افتح مجلد "Asset Packages" في مشروع Unity الخاص بك. ابحث عن المجلد "com.unity.render-pipelines.universal" وافتحه. ابحث عن المجلد "Editor" وافتحه. ابحث عن المجلد "VFXGraph" وافتحه. ابحث عن المجلد "Shaders" وافتحه. ابحث عن الملفات المشار إليها في رسالة الخطأ ("PassForward2D.template" و "PassDepthOrMV.template"). انسخ الملفات المشار إليها إلى مجلد "Assets" في مشروع Unity الخاص بك. قم بفتح Unity وانتظر حتى يتم إعادة بناء المشروع. تأكد من أن الملفات المنسوخة موجودة الآن في مجلد "Assets" وأنها لا تزال موجودة في المجلدات الأصلية. يجب أن يعمل البرنامج الآن دون أي مشاكل. وإذا لم يتم حل المشكلة بهذه الطريقة، يمكنك محاولة إعادة تنزيل البكج الذي قمت بتثبيته في Unity وتثبيته مرة أخرى للتأكد من أن جميع الملفات المطلوبة موجودة.
  24. في البداية يجب عليك معرفة الخطوات اللازمة للإشتراك في عرض رمضان: 1- توجه إلى الرابط التالي : https://academy.hsoub.com/ وستجد عرض رمضان أمامك قم بالضغط عليه: 2- بعد ذلك ستجد زر باسم اشترك الآن، اضغط عليه: 3- سيتم نقلك إلى القسم الخاص بإختيار الدورات وإتمام عملية الدفع، حيث أن وسيلة الدفع المتوفرة هي بطاقة الإئتمان فقط بالنسبة لعرض رمضان. وأيضًا لا تتوفر أكواد خصم "لعرض رمضان"، فهو عرض بذاته. وإذا كنت تريد الدفع عن طريق باي بال، فعليك بالتواصل مع مركز المساعدة الخاص بأكاديمية حسوب بخصوص ذلك الأمر، فمن الممكن أن يخبروك أن تقوم بشراء دورة بدون العرض والدفع من خلال باي بال ثم سيتم إضافة الدورة الأخرى التي تريدها. وأرجو منك قراءة النقاش التالي:
  25. في البداية يجب عليك فهم كيف يتم الربط بين ملفات HTML , CSS, JavaScript. وهناك عدة طرق، ولكن الطريقة الأسهل هي بإضافة رابط ملفات CSS و JavaScript داخل ملف HTML. وHTML هي لغة تصميم صفحات الويب ويمكن الربط بين ملفات HTML و CSS عن طريق استخدام عنصر الـlink. ويتم وضع هذا العنصر في العنوان <head> من صفحة HTML، واستخدام الـlink للإشارة إلى ملف CSS الذي يحتوي على التعليمات البرمجية المتعلقة بتصميم الصفحة. وللقيام بذلك عليك جميع ملفات المشروع داخل مجلد واحد على هاتفك. مثال: <head> <link rel="stylesheet" type="text/css" href="style.css"> </head> وكما ترى استخدمت العنصر <link> مع تحديد الخاصية rel="stylesheet" التي تشير إلى أن هذا العنصر يربط بين ملف HTML وملف CSS. وتحديد الخاصية type="text/css" التي تشير إلى نوع الملف الذي يتم الربط به، وهو ملف CSS. وأخيراً تحديد مسار الملف الذي يتم الربط به بإستخدام الخاصية href="style.css". وإذا كان الملف داخل مجلد آخر في مجلد المشروع، أي مثلاً داخل مجلد باسم mohamedفيجب كتابة المسار بشكل صحيح كالتالي: <head> <link rel="stylesheet" type="text/css" href="mohamed/style.css"> </head> أما بالنسبة للربط بين ملفات HTML و JavaScript فهو يتم عن طريق استخدام العنصر <script>. فعند وضع الكود البرمجي للـ JavaScript داخل العنصر <script>، سيتم تنفيذ الكود عند تحميل الصفحة. وذلك من خلال ربط ملف JavaScript الخارجي باستخدام الخاصية src، بتحديد مسار الملف الذي يتم الربط به. مثال: <head> <script src="كود.js"></script> </head> ولا تنسى كتابة اسم الملف والمسار الصحيح، فهنا قمنا بربط كود الجافاسكريبت بواسطة ملف باسم كود.js أشهر محررات الأكواد على الهاتف الجدير بالذكر أنه يمكنك استخدام VScode الخاص بأجهزة الحاسوب من خلال المتصفح عن طريق الرابط التالي: https://vscode.dev أما بخصوص التطبيقات فتستطيع الإعتماد على أحد التطبيقات التالية: 1- DroidEdit محرر نصوص يحتوي على العديد من الميزات المفيدة مثل الإكمال التلقائي، والتميز اللوني، وإدارة الملفات، وتوفير مساحة التخزين السحابية. 2-Quoda يوفر Quoda الكثير من الميزات المفيدة للمستخدمين، مثل تمييز الألوان وتحرير الشفرة المصدرية وحفظ المشروعات. 3- Acode محرر نصوص يتميز بالسرعة والبساطة، ويدعم العديد من لغات البرمجة ويتميز بالأدوات المفيدة وسهولة الاستخدام. 4- Turbo Editor محرر نصوص بسيط وسهل الاستخدام يتيح للمستخدمين الوصول إلى أدوات التحرير المهمة بسرعة، مثل البحث، والاستبدال، والتميز اللوني. 5- QuickEdit محرر نصوص بسيط وسهل الاستخدام يتيح للمستخدمين الوصول إلى أدوات التحرير المهمة بسرعة، مثل البحث، والاستبدال، والتميز اللوني. 6- Code Peeker Pro تطبيق خفيف يمكن استخدامه لتحرير وعرض ملفات الشفرة المصدرية المختلفة، كما يدعم العديد من لغات البرمجة. 7- Codeanywhere تطبيق متميز لتحرير الشفرة المصدرية ويتيح الوصول إلى الأدوات المتقدمة للتحرير، ويوفر للمستخدمين التخزين السحابي والوصول إلى ملفات الشفرة المصدرية في أي وقت ومن أي مكان.
×
×
  • أضف...