<!DOCTYPE html>
<html lang="ar" dir="rtl">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>إصلاح إضافة SiliconSY</title>
    <style>
        :root {
            --primary-color: #0073aa;
            --secondary-color: #46b450;
            --text-color: #333;
            --light-gray: #f5f5f5;
            --border-color: #e0e0e0;
            --shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
            --transition: all 0.3s ease;
        }
        
        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }
        
        body {
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
            line-height: 1.6;
            color: var(--text-color);
            background-color: #f9f9f9;
            padding: 20px;
            direction: rtl;
        }
        
        .container {
            max-width: 1200px;
            margin: 0 auto;
        }
        
        header {
            text-align: center;
            margin-bottom: 30px;
            padding: 20px;
            background: linear-gradient(135deg, #0073aa 0%, #005a87 100%);
            color: white;
            border-radius: 8px;
            box-shadow: var(--shadow);
        }
        
        h1 {
            font-size: 2.2rem;
            margin-bottom: 10px;
        }
        
        .solution-section {
            background: white;
            border-radius: 8px;
            padding: 25px;
            margin-bottom: 30px;
            box-shadow: var(--shadow);
        }
        
        .solution-title {
            color: var(--primary-color);
            margin-bottom: 20px;
            padding-bottom: 10px;
            border-bottom: 2px solid var(--light-gray);
        }
        
        .solution-content {
            line-height: 1.8;
        }
        
        .code-block {
            background: #2d2d2d;
            color: #f8f8f2;
            padding: 20px;
            border-radius: 5px;
            overflow-x: auto;
            margin: 20px 0;
            font-family: 'Courier New', monospace;
            line-height: 1.5;
        }
        
        .important-note {
            background: #fff9e6;
            border-right: 4px solid #ffc107;
            padding: 15px;
            margin: 20px 0;
            border-radius: 4px;
        }
        
        /* أنماط الإضافة المعدلة */
        .siliconsy-posts-grid {
            margin: 20px 0;
        }
        
        .siliconsy-posts-container {
            display: flex;
            flex-wrap: wrap;
            gap: 20px;
            margin-bottom: 30px;
        }
        
        .siliconsy-post {
            width: calc(20% - 20px);
            box-sizing: border-box;
        }
        
        .siliconsy-post-inner {
            border: 1px solid var(--border-color);
            border-radius: 8px;
            overflow: hidden;
            transition: var(--transition);
            box-shadow: var(--shadow);
            background: #fff;
            height: 100%;
        }
        
        .siliconsy-post-image {
            width: 100%;
            height: 200px;
            overflow: hidden;
            background-color: var(--light-gray);
            display: flex;
            align-items: center;
            justify-content: center;
        }
        
        .siliconsy-post-image img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.3s ease;
        }
        
        .siliconsy-post-content {
            padding: 15px;
        }
        
        .siliconsy-post-title {
            margin: 0 0 15px 0;
            font-size: 16px;
            line-height: 1.4;
            height: 45px;
            overflow: hidden;
        }
        
        .siliconsy-post-title a {
            color: var(--text-color);
            text-decoration: none;
            transition: var(--transition);
        }
        
        .siliconsy-post-meta {
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        
        .siliconsy-btn {
            display: inline-block;
            padding: 8px 15px;
            border-radius: 4px;
            text-decoration: none;
            font-weight: 600;
            font-size: 14px;
            transition: var(--transition);
            text-align: center;
            cursor: pointer;
        }
        
        .siliconsy-more-btn {
            background: linear-gradient(145deg, #0073aa, #005a87);
            color: white;
            box-shadow: 0 4px 6px rgba(0, 115, 170, 0.3);
        }
        
        .siliconsy-category-btn {
            background: linear-gradient(145deg, #46b450, #389a41);
            color: white;
            box-shadow: 0 4px 6px rgba(70, 180, 80, 0.3);
        }
        
        .siliconsy-pagination {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 15px;
            margin-top: 20px;
        }
        
        .siliconsy-pagination a {
            padding: 8px 16px;
            background: #f1f1f1;
            color: #333;
            text-decoration: none;
            border-radius: 4px;
            transition: var(--transition);
            font-weight: 600;
            cursor: pointer;
        }
        
        .siliconsy-pagination a:hover {
            background: var(--primary-color);
            color: white;
        }
        
        .demo-container {
            background: white;
            border-radius: 8px;
            padding: 25px;
            box-shadow: var(--shadow);
            margin-top: 30px;
        }
        
        @media (max-width: 768px) {
            .siliconsy-post {
                width: calc(50% - 20px);
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <header>
            <h1>إصلاح إضافة SiliconSY</h1>
            <p>حل مشكلة الصورة البارزة وزر التالي والسابق</p>
        </header>
        
        <div class="solution-section">
            <h2 class="solution-title">المشكلة 1: عدم جلب الصورة البارزة</h2>
            <div class="solution-content">
                <p>مشكلة الصورة البارزة ليست في ملف التنسيقات (CSS) ولكن في كود PHP الذي يجب أن:</p>
                <ol>
                    <li>يطلب تضمين بيانات الوسائط في استجابة API بإضافة <code>_embed=1</code> لرابط API</li>
                    <li>يستخرج رابط الصورة بشكل صحيح من البيانات المعادة</li>
                    <li>يوفر صورة بديلة عندما لا تتوفر الصورة الأصلية</li>
                </ol>
                
                <div class="important-note">
                    <strong>ملاحظة مهمة:</strong> ملف التنسيقات (CSS) مسؤول فقط عن تنسيق العناصر وتصميمها، وليس عن جلب البيانات.
                </div>
                
                <p>كود PHP المصحح في ملف <code>class-siliconsy-api.php</code>:</p>
                <div class="code-block">
// يجب إضافة _embed=1 لطلب API
$response = wp_remote_get(
    $this->api_url . '/posts?categories=' . $category_id . 
    '&per_page=' . $per_page . '&page=' . $page . '&_embed=1',
    $args
);
                </div>
                
                <p>كود PHP المصحح في ملف <code>class-siliconsy-render.php</code>:</p>
                <div class="code-block">
public function get_featured_image($post, $size = 'medium') {
    // التحقق من وجود الصورة البارزة في البيانات المضمنة
    if (isset($post['_embedded']['wp:featuredmedia'][0])) {
        $media = $post['_embedded']['wp:featuredmedia'][0];
        
        // محاولة الحصول على الحجم المطلوب
        if (isset($media['media_details']['sizes'][$size]['source_url'])) {
            return $media['media_details']['sizes'][$size]['source_url'];
        }
        
        // إذا لم يتوفر الحجم المطلوب، استخدام الصورة الكاملة
        if (isset($media['source_url'])) {
            return $media['source_url'];
        }
    }
    
    // استخدام صورة افتراضية إذا لم توجد صورة
    return SILICONSY_PLUGIN_URL . 'assets/images/placeholder.jpg';
}
                </div>
            </div>
        </div>
        
        <div class="solution-section">
            <h2 class="solution-title">المشكلة 2: زر التالي والسابق لا يعمل</h2>
            <div class="solution-content">
                <p>لإصلاح مشكلة الزر التالي والسابق، تحتاج إلى:</p>
                <ol>
                    <li>ضمان أن JavaScript يستمع لنقرات الأزرار بشكل صحيح</li>
                    <li>استخدام Ajax لتحميل المحتوى دون تحديث الصفحة</li>
                    <li>معالجة استجابة Ajax بشكل صحيح</li>
                </ol>
                
                <p>كود JavaScript المصحح في ملف <code>script.js</code>:</p>
                <div class="code-block">
jQuery(document).ready(function($) {
    // استخدام event delegation للتعامل مع الأزرار dynamically
    $(document).on('click', '.siliconsy-pagination a', function(e) {
        e.preventDefault();
        
        var button = $(this);
        var page = button.data('page');
        var container = button.closest('.siliconsy-posts-grid');
        var category = container.data('category');
        var per_page = container.data('per-page');
        
        // إظهار مؤشر التحميل
        container.append('&lt;div class="siliconsy-loading"&gt;جاري تحميل المحتوى...&lt;/div&gt;');
        
        // إرسال طلب Ajax
        $.ajax({
            url: siliconsy_ajax.url,
            type: 'POST',
            data: {
                action: 'siliconsy_load_posts',
                nonce: siliconsy_ajax.nonce,
                category: category,
                per_page: per_page,
                page: page
            },
            success: function(response) {
                if (response.success) {
                    // استبدال المحتوى القديم بالجديد
                    container.html(response.data.html);
                    
                    // التمرير لأعلى العنصر
                    $('html, body').animate({
                        scrollTop: container.offset().top - 20
                    }, 500);
                } else {
                    alert('حدث خطأ: ' + response.data);
                }
            },
            error: function() {
                alert('حدث خطأ في الاتصال بالخادم');
            }
        });
    });
});
                </div>
                
                <p>كود PHP المصحح في ملف <code>siliconsy.php</code> لدعم Ajax:</p>
                <div class="code-block">
// إضافة دالة معالجة Ajax
public function ajax_load_posts() {
    // التحقق من nonce للأمان
    if (!wp_verify_nonce($_POST['nonce'], 'siliconsy_nonce')) {
        wp_die('غير مصرح به');
    }
    
    $category = isset($_POST['category']) ? intval($_POST['category']) : 44;
    $per_page = isset($_POST['per_page']) ? intval($_POST['per_page']) : 5;
    $page = isset($_POST['page']) ? intval($_POST['page']) : 1;
    
    $api = new SiliconSY_API();
    $render = new SiliconSY_Render();
    
    $posts_data = $api->get_posts($category, $per_page, $page);
    
    if (is_wp_error($posts_data)) {
        wp_send_json_error($posts_data->get_error_message());
    } else {
        $response = array(
            'html' => $render->display_posts_grid($posts_data, $page, array('category' => $category, 'per_page' => $per_page)),
            'page' => $page,
            'total_pages' => $posts_data['total_pages']
        );
        wp_send_json_success($response);
    }
}

// تسجيل دالة Ajax
add_action('wp_ajax_siliconsy_load_posts', array($this, 'ajax_load_posts'));
add_action('wp_ajax_nopriv_siliconsy_load_posts', array($this, 'ajax_load_posts'));
                </div>
            </div>
        </div>
        
        <div class="demo-container">
            <h2>عرض توضيحي للإضافة بعد التصحيح</h2>
            <p>هذا نموذج يوضح كيف يجب أن تبدو الإضافة بعد تطبيق التصحيحات:</p>
            
            <div class="siliconsy-posts-grid">
                <div class="siliconsy-posts-container">
                    <div class="siliconsy-post">
                        <div class="siliconsy-post-inner">
                            <div class="siliconsy-post-image">
                                <img src="https://picsum.photos/350/200?random=1" alt="مقال تجريبي">
                            </div>
                            <div class="siliconsy-post-content">
                                <h3 class="siliconsy-post-title">
                                    <a href="#">مقال تجريبي مع عنوان طويل بعض الشيء</a>
                                </h3>
                                <div class="siliconsy-post-meta">
                                    <a href="#" class="siliconsy-btn siliconsy-more-btn">المزيد</a>
                                    <a href="#" class="siliconsy-btn siliconsy-category-btn">التقنية</a>
                                </div>
                            </div>
                        </div>
                    </div>
                    
                    <div class="siliconsy-post">
                        <div class="siliconsy-post-inner">
                            <div class="siliconsy-post-image">
                                <img src="https://picsum.photos/350/200?random=2" alt="مقال تجريبي">
                            </div>
                            <div class="siliconsy-post-content">
                                <h3 class="siliconsy-post-title">
                                    <a href="#">مقال تجريبي ثاني</a>
                                </h3>
                                <div class="siliconsy-post-meta">
                                    <a href="#" class="siliconsy-btn siliconsy-more-btn">المزيد</a>
                                    <a href="#" class="siliconsy-btn siliconsy-category-btn">التقنية</a>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                
                <div class="siliconsy-pagination">
                    <a href="#" class="siliconsy-pagination-prev" data-page="1">السابق</a>
                    <span class="siliconsy-pagination-info">الصفحة 2 من 5</span>
                    <a href="#" class="siliconsy-pagination-next" data-page="3">التالي</a>
                </div>
            </div>
        </div>
    </div>

    <script>
        // محاكاة لعمل الزر التالي والسابق في العرض التوضيحي
        document.addEventListener('DOMContentLoaded', function() {
            const paginationLinks = document.querySelectorAll('.siliconsy-pagination a');
            
            paginationLinks.forEach(link => {
                link.addEventListener('click', function(e) {
                    e.preventDefault();
                    alert('في التنفيذ الفعلي، سيتم تحميل الصفحة ' + this.getAttribute('data-page') + ' باستخدام Ajax دون تحديث الصفحة');
                });
            });
        });
    </script>
</body>
</html>