{% extends 'base.html' %}
{% load static %}
{% load question_extras %}

{% block title %}Grading Comparison - IMProofBench{% endblock %}

{% block content %}
<div class="container mt-4">
    <div class="row">
        <div class="col-12">
            <div class="d-flex justify-content-between align-items-center mb-3">
                <div>
                    <h2>Grading Comparison Analysis</h2>
                    <p class="lead mb-0">Questions with multiple finalized grading sessions for inter-rater reliability analysis.</p>
                </div>
            </div>

            {% if questions_with_sessions %}

                <!-- Global Statistics Dashboard -->
                {% if global_stats %}
                <div class="row mb-4">
                    <!-- 1. Summary Dashboard -->
                    <div class="col-12 mb-3">
                        <div class="card border-primary">
                            <div class="card-header bg-primary text-white">
                                <h5 class="mb-0"><i class="bi bi-graph-up me-2"></i>Global Statistics Summary</h5>
                            </div>
                            <div class="card-body">
                                <div class="row text-center">
                                    <div class="col-md-3">
                                        <h3 class="text-primary mb-1">{{ global_stats.total_questions }}</h3>
                                        <p class="text-muted mb-0 small">Questions Compared</p>
                                    </div>
                                    <div class="col-md-3">
                                        <h3 class="mb-1">
                                            <span class="badge bg-{% if global_stats.avg_overall_agreement >= 80 %}success{% elif global_stats.avg_overall_agreement >= 60 %}warning{% else %}danger{% endif %} fs-4">
                                                {{ global_stats.avg_overall_agreement }}%
                                            </span>
                                        </h3>
                                        <p class="text-muted mb-0 small">Avg Overall Agreement</p>
                                    </div>
                                    <div class="col-md-3">
                                        <h3 class="mb-1">
                                            <span class="badge bg-{% if global_stats.avg_progress_diff <= 0.5 %}success{% elif global_stats.avg_progress_diff <= 1.0 %}warning{% else %}danger{% endif %} fs-4">
                                                {{ global_stats.avg_progress_diff }}
                                            </span>
                                        </h3>
                                        <p class="text-muted mb-0 small">Avg Progress Grade Diff</p>
                                    </div>
                                    <div class="col-md-3">
                                        <h3 class="mb-1">
                                            <span class="badge bg-{% if global_stats.median_progress_diff <= 0.5 %}success{% elif global_stats.median_progress_diff <= 1.0 %}warning{% else %}danger{% endif %} fs-4">
                                                {{ global_stats.median_progress_diff }}
                                            </span>
                                        </h3>
                                        <p class="text-muted mb-0 small">Median Progress Grade Diff</p>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>

                    <!-- 2. Agreement Distribution -->
                    {% if agreement_distribution %}
                    <div class="col-md-4">
                        <div class="card h-100">
                            <div class="card-header d-flex justify-content-between align-items-center">
                                <h6 class="mb-0"><i class="bi bi-pie-chart me-2"></i>Agreement Distribution</h6>
                                <a href="{% url 'questions:export_agreement_summary' %}" class="btn btn-sm btn-success" title="Download CSV">
                                    <i class="bi bi-download"></i>
                                </a>
                            </div>
                            <div class="card-body">
                                <div class="mb-2">
                                    <div class="d-flex justify-content-between align-items-center">
                                        <span><i class="bi bi-circle-fill text-success me-2"></i>High (≥80%)</span>
                                        <strong>{{ agreement_distribution.high.count }} ({{ agreement_distribution.high.pct }}%)</strong>
                                    </div>
                                    <div class="progress mt-1" style="height: 20px;">
                                        <div class="progress-bar bg-success" style="width: {{ agreement_distribution.high.pct }}%">{{ agreement_distribution.high.pct }}%</div>
                                    </div>
                                </div>
                                <div class="mb-2">
                                    <div class="d-flex justify-content-between align-items-center">
                                        <span><i class="bi bi-circle-fill text-warning me-2"></i>Moderate (60-79%)</span>
                                        <strong>{{ agreement_distribution.moderate.count }} ({{ agreement_distribution.moderate.pct }}%)</strong>
                                    </div>
                                    <div class="progress mt-1" style="height: 20px;">
                                        <div class="progress-bar bg-warning" style="width: {{ agreement_distribution.moderate.pct }}%">{{ agreement_distribution.moderate.pct }}%</div>
                                    </div>
                                </div>
                                <div>
                                    <div class="d-flex justify-content-between align-items-center">
                                        <span><i class="bi bi-circle-fill text-danger me-2"></i>Low (<60%)</span>
                                        <strong>{{ agreement_distribution.low.count }} ({{ agreement_distribution.low.pct }}%)</strong>
                                    </div>
                                    <div class="progress mt-1" style="height: 20px;">
                                        <div class="progress-bar bg-danger" style="width: {{ agreement_distribution.low.pct }}%">{{ agreement_distribution.low.pct }}%</div>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                    {% endif %}

                    <!-- 3. Category-Level Analysis -->
                    {% if category_stats %}
                    <div class="col-md-4">
                        <div class="card h-100">
                            <div class="card-header d-flex justify-content-between align-items-center">
                                <h6 class="mb-0"><i class="bi bi-bar-chart me-2"></i>Category Agreement (Lowest First)</h6>
                                <a href="{% url 'questions:export_category_aggregates' %}" class="btn btn-sm btn-success" title="Download CSV">
                                    <i class="bi bi-download"></i>
                                </a>
                            </div>
                            <div class="card-body">
                                <div class="table-responsive">
                                    <table class="table table-sm mb-0">
                                        <tbody>
                                            {% for cat_key, cat_pct in category_stats|slice:":5" %}
                                            <tr>
                                                <td class="small">{{ category_labels|get_item:cat_key|default:cat_key }}</td>
                                                <td class="text-end">
                                                    {% if cat_pct is not None %}
                                                        <span class="badge bg-{% if cat_pct >= 80 %}success{% elif cat_pct >= 60 %}warning{% else %}danger{% endif %}">
                                                            {{ cat_pct }}%
                                                        </span>
                                                    {% else %}
                                                        <span class="text-muted">N/A</span>
                                                    {% endif %}
                                                </td>
                                            </tr>
                                            {% endfor %}
                                        </tbody>
                                    </table>
                                </div>
                            </div>
                        </div>
                    </div>
                    {% endif %}

                    <!-- 4. Progress Grade Difference Distribution -->
                    {% if progress_grade_stats and progress_grade_stats.difference_distribution %}
                    <div class="col-md-4">
                        <div class="card h-100">
                            <div class="card-header d-flex justify-content-between align-items-center">
                                <h6 class="mb-0"><i class="bi bi-bar-chart-fill me-2"></i>Progress Grade Difference Distribution</h6>
                                <div class="btn-group" role="group">
                                    <a href="{% url 'questions:export_progress_summary' %}" class="btn btn-sm btn-success" title="Download Summary CSV">
                                        <i class="bi bi-download"></i> Summary
                                    </a>
                                    <a href="{% url 'questions:export_progress_distribution' %}" class="btn btn-sm btn-success" title="Download Distribution CSV">
                                        <i class="bi bi-download"></i> Distribution
                                    </a>
                                </div>
                            </div>
                            <div class="card-body">
                                {% with total=progress_grade_stats.total_comparisons %}
                                {% if total > 0 %}
                                    <!-- Difference = 0 (Exact Match) -->
                                    <div class="mb-2">
                                        <div class="d-flex justify-content-between align-items-center mb-1">
                                            <span class="small"><strong>0 Points</strong></span>
                                            <strong class="small">
                                                {{ progress_grade_stats.difference_distribution.0 }}
                                                <span class="text-muted">
                                                    ({% widthratio progress_grade_stats.difference_distribution.0 total 100 %}%)
                                                </span>
                                            </strong>
                                        </div>
                                        <div class="progress" style="height: 18px;">
                                            <div class="progress-bar bg-success"
                                                 style="width: {% widthratio progress_grade_stats.difference_distribution.0 total 100 %}%">
                                                {% widthratio progress_grade_stats.difference_distribution.0 total 100 %}%
                                            </div>
                                        </div>
                                    </div>

                                    <!-- Difference = 1 -->
                                    <div class="mb-2">
                                        <div class="d-flex justify-content-between align-items-center mb-1">
                                            <span class="small"><strong>1 Point</strong></span>
                                            <strong class="small">
                                                {{ progress_grade_stats.difference_distribution.1 }}
                                                <span class="text-muted">
                                                    ({% widthratio progress_grade_stats.difference_distribution.1 total 100 %}%)
                                                </span>
                                            </strong>
                                        </div>
                                        <div class="progress" style="height: 18px;">
                                            <div class="progress-bar bg-info"
                                                 style="width: {% widthratio progress_grade_stats.difference_distribution.1 total 100 %}%">
                                                {% widthratio progress_grade_stats.difference_distribution.1 total 100 %}%
                                            </div>
                                        </div>
                                    </div>

                                    <!-- Difference = 2 -->
                                    <div class="mb-2">
                                        <div class="d-flex justify-content-between align-items-center mb-1">
                                            <span class="small"><strong>2 Points</strong></span>
                                            <strong class="small">
                                                {{ progress_grade_stats.difference_distribution.2 }}
                                                <span class="text-muted">
                                                    ({% widthratio progress_grade_stats.difference_distribution.2 total 100 %}%)
                                                </span>
                                            </strong>
                                        </div>
                                        <div class="progress" style="height: 18px;">
                                            <div class="progress-bar bg-warning"
                                                 style="width: {% widthratio progress_grade_stats.difference_distribution.2 total 100 %}%">
                                                {% widthratio progress_grade_stats.difference_distribution.2 total 100 %}%
                                            </div>
                                        </div>
                                    </div>

                                    <!-- Difference = 3 -->
                                    <div class="mb-2">
                                        <div class="d-flex justify-content-between align-items-center mb-1">
                                            <span class="small"><strong>3 Points</strong></span>
                                            <strong class="small">
                                                {{ progress_grade_stats.difference_distribution.3 }}
                                                <span class="text-muted">
                                                    ({% widthratio progress_grade_stats.difference_distribution.3 total 100 %}%)
                                                </span>
                                            </strong>
                                        </div>
                                        <div class="progress" style="height: 18px;">
                                            <div class="progress-bar bg-danger"
                                                 style="width: {% widthratio progress_grade_stats.difference_distribution.3 total 100 %}%">
                                                {% widthratio progress_grade_stats.difference_distribution.3 total 100 %}%
                                            </div>
                                        </div>
                                    </div>

                                    <p class="text-muted small mb-0">
                                        <i class="bi bi-info-circle me-1"></i>{{ total }} comparisons
                                    </p>
                                {% else %}
                                    <p class="text-muted mb-0">No progress grade data available</p>
                                {% endif %}
                                {% endwith %}
                            </div>
                        </div>
                    </div>
                    {% endif %}
                </div>
                {% endif %}

                <div class="d-flex justify-content-between align-items-center mb-3">
                    <div class="alert alert-info mb-0">
                        <strong>Found {{ page_obj.paginator.count }} question{{ page_obj.paginator.count|pluralize }}</strong> with 2 or more finalized grading sessions.
                    </div>
                    <div class="btn-group ms-3" role="group" aria-label="Export options">
                        <a href="{% url 'questions:export_agreement_distribution' %}" class="btn btn-success" title="Download per-question statistics">
                            <i class="bi bi-download me-1"></i>Per-Question Stats
                        </a>
                        <a href="{% url 'questions:export_per_question_categories' %}" class="btn btn-success" title="Download per-question category breakdown">
                            <i class="bi bi-download me-1"></i>Category Breakdown
                        </a>
                    </div>
                </div>

                <div class="table-responsive">
                    <table class="table table-hover">
                        <thead>
                            <tr>
                                <th>Question ID</th>
                                <th>Title</th>
                                <th>Author</th>
                                <th>Graders</th>
                                <th>Sessions</th>
                                <th>Overall Agreement</th>
                                <th>Avg Progress Grade Diff</th>
                                <th>Actions</th>
                            </tr>
                        </thead>
                        <tbody>
                            {% for item in questions_with_sessions %}
                                <tr>
                                    <td>
                                        <a href="{% url 'questions:detail' item.question.pk %}" class="text-decoration-none">
                                            #{{ item.question.id }}
                                        </a>
                                    </td>
                                    <td>
                                        <a href="{% url 'questions:detail' item.question.pk %}" class="text-decoration-none">
                                            {{ item.question.title|truncatewords:10 }}
                                        </a>
                                    </td>
                                    <td>{{ item.question.author.get_full_name }}</td>
                                    <td>
                                        <small>
                                            {% for grader in item.graders %}
                                                <span class="badge bg-success me-1" title="Finalized">
                                                    {{ grader.name }}
                                                    <i class="bi bi-check-circle"></i>
                                                </span>
                                            {% endfor %}
                                        </small>
                                    </td>
                                    <td>{{ item.session_count }}</td>
                                    <td>
                                        {% if item.quick_agreement is not None %}
                                            <span class="badge bg-{% if item.quick_agreement >= 80 %}success{% elif item.quick_agreement >= 60 %}warning{% else %}danger{% endif %}">
                                                {{ item.quick_agreement }}%
                                            </span>
                                        {% elif item.session_count == 2 %}
                                            <span class="text-muted">N/A</span>
                                        {% else %}
                                            <span class="text-muted">3+ sessions</span>
                                        {% endif %}
                                    </td>
                                    <td>
                                        {% if item.progress_mean_diff is not None %}
                                            <span class="badge bg-{% if item.progress_mean_diff <= 0.5 %}success{% elif item.progress_mean_diff <= 1.0 %}warning{% else %}danger{% endif %}">
                                                {{ item.progress_mean_diff }}
                                            </span>
                                        {% elif item.session_count == 2 %}
                                            <span class="text-muted">N/A</span>
                                        {% else %}
                                            <span class="text-muted">3+ sessions</span>
                                        {% endif %}
                                    </td>
                                    <td>
                                        <a href="{% url 'questions:grading_comparison_detail' item.question.pk %}"
                                           class="btn btn-sm btn-primary">
                                            <i class="bi bi-graph-up"></i> Compare
                                        </a>
                                        <a href="{% url 'questions:grading_comparison_export' item.question.pk %}"
                                           class="btn btn-sm btn-success">
                                            <i class="bi bi-download"></i> CSV
                                        </a>
                                    </td>
                                </tr>
                            {% endfor %}
                        </tbody>
                    </table>
                </div>

                <!-- Pagination -->
                {% if page_obj.has_other_pages %}
                    <nav aria-label="Page navigation">
                        <ul class="pagination justify-content-center">
                            {% if page_obj.has_previous %}
                                <li class="page-item">
                                    <a class="page-link" href="?page=1">First</a>
                                </li>
                                <li class="page-item">
                                    <a class="page-link" href="?page={{ page_obj.previous_page_number }}">Previous</a>
                                </li>
                            {% endif %}

                            <li class="page-item active">
                                <span class="page-link">
                                    Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}
                                </span>
                            </li>

                            {% if page_obj.has_next %}
                                <li class="page-item">
                                    <a class="page-link" href="?page={{ page_obj.next_page_number }}">Next</a>
                                </li>
                                <li class="page-item">
                                    <a class="page-link" href="?page={{ page_obj.paginator.num_pages }}">Last</a>
                                </li>
                            {% endif %}
                        </ul>
                    </nav>
                {% endif %}

            {% else %}
                <div class="alert alert-warning">
                    <strong>No questions with multiple finalized grading sessions found.</strong>
                    <p class="mb-0 mt-2">Questions need at least 2 finalized grading sessions (from different graders) to appear in this list. Graders must complete and finalize their sessions before comparison is available.</p>
                </div>
            {% endif %}

            <div class="mt-4">
                <h4>About Grading Comparison</h4>
                <p>This tool helps assess consistency between different graders evaluating the same model answers.</p>

                <div class="row">
                    <div class="col-md-6">
                        <h5 class="h6">Overall Agreement</h5>
                        <ul class="small">
                            <li>Percentage of agreement across all 8 binary grading categories</li>
                            <li><strong class="text-success">Green (≥80%):</strong> Substantial agreement</li>
                            <li><strong class="text-warning">Yellow (60-79%):</strong> Moderate agreement</li>
                            <li><strong class="text-danger">Red (<60%):</strong> Low agreement - may need discussion</li>
                        </ul>
                    </div>
                    <div class="col-md-6">
                        <h5 class="h6">Progress Grade Difference</h5>
                        <ul class="small">
                            <li>Mean absolute difference between progress grades (0-3 scale)</li>
                            <li><strong class="text-success">Green (≤0.5):</strong> Very close agreement</li>
                            <li><strong class="text-warning">Yellow (0.5-1.0):</strong> Moderate difference</li>
                            <li><strong class="text-danger">Red (>1.0):</strong> Large difference - review needed</li>
                        </ul>
                    </div>
                </div>

                <p class="mt-3">
                    <a href="{% url 'home' %}" class="btn btn-secondary">
                        <i class="bi bi-arrow-left"></i> Back to Home
                    </a>
                </p>
            </div>
        </div>
    </div>
</div>
{% endblock %}
