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

{% block title %}Grading Comparison: {{ question.title }} - IMProofBench{% endblock %}

{% block content %}
<div class="container-fluid mt-4">
    <div class="row">
        <div class="col-12">
            <!-- Header -->
            <div class="d-flex justify-content-between align-items-center mb-3">
                <div>
                    <h2>Grading Comparison</h2>
                    <p class="lead mb-0">
                        Question #{{ question.id }}: {{ question.title }}
                    </p>
                    <small class="text-muted">Author: {{ question.author.get_full_name }}</small>
                </div>
                <div>
                    <a href="{% url 'questions:grading_comparison_list' %}" class="btn btn-secondary">
                        <i class="bi bi-arrow-left"></i> Back to List
                    </a>
                    <a href="{% url 'questions:grading_comparison_export' question.pk %}" class="btn btn-success">
                        <i class="bi bi-download"></i> Export CSV
                    </a>
                </div>
            </div>

            <!-- Grading Sessions Overview -->
            <div class="card mb-4">
                <div class="card-header">
                    <h4 class="mb-0">Grading Sessions ({{ sessions.count }})</h4>
                </div>
                <div class="card-body">
                    <div class="row">
                        {% for session_data in sessions_data %}
                            <div class="col-md-6 mb-3">
                                <div class="card">
                                    <div class="card-body">
                                        <h5 class="card-title">
                                            {{ session_data.grader_name }}
                                            {% if session_data.session.is_finalized %}
                                                <span class="badge bg-success">Finalized</span>
                                            {% else %}
                                                <span class="badge bg-warning">Active</span>
                                            {% endif %}
                                        </h5>
                                        <p class="card-text">
                                            <small class="text-muted">
                                                Created: {{ session_data.session.created_at|date:"M d, Y H:i" }}<br>
                                                {% if session_data.session.is_finalized %}
                                                    Finalized: {{ session_data.session.finalized_at|date:"M d, Y H:i" }}
                                                {% endif %}
                                            </small>
                                        </p>
                                        <p class="mb-0">
                                            <strong>{{ session_data.gradings.count }}</strong> answer{{ session_data.gradings.count|pluralize }} graded
                                        </p>
                                    </div>
                                </div>
                            </div>
                        {% endfor %}
                    </div>
                </div>
            </div>

            <!-- Pairwise Agreement Statistics -->
            {% if pairwise_stats %}
                <div class="card mb-4">
                    <div class="card-header">
                        <h4 class="mb-0">Agreement Statistics</h4>
                    </div>
                    <div class="card-body">
                        {% for pair in pairwise_stats %}
                            <div class="mb-4">
                                <h5>{{ pair.grader1 }} vs {{ pair.grader2 }}</h5>

                                <div class="row mb-3">
                                    <div class="col-md-3">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Overall Agreement</h6>
                                                <h3 class="card-title mb-0">
                                                    <span class="badge bg-{% if pair.stats.overall_agreement >= 80 %}success{% elif pair.stats.overall_agreement >= 60 %}warning{% else %}danger{% endif %} fs-4">
                                                        {{ pair.stats.overall_agreement }}%
                                                    </span>
                                                </h3>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="col-md-3">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Answers Compared</h6>
                                                <h3 class="card-title mb-0">{{ pair.stats.n_compared }}</h3>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="col-md-3">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Total Comparisons</h6>
                                                <h3 class="card-title mb-0">{{ pair.stats.total_comparisons }}</h3>
                                                <small class="text-muted">(across all categories)</small>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="col-md-3">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Progress Correlation</h6>
                                                <h3 class="card-title mb-0">
                                                    {% if pair.stats.progress_correlation is not None %}
                                                        {{ pair.stats.progress_correlation }}
                                                    {% else %}
                                                        N/A
                                                    {% endif %}
                                                </h3>
                                            </div>
                                        </div>
                                    </div>
                                </div>

                                <!-- Progress Grade Agreement Metrics -->
                                {% if pair.stats.progress_agreement %}
                                <div class="row mb-3">
                                    <div class="col-12">
                                        <h6 class="mt-3 mb-2">Progress Grade Agreement</h6>
                                    </div>
                                    <div class="col-md-4">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Exact Agreement</h6>
                                                <h3 class="card-title mb-0">
                                                    {% if pair.stats.progress_agreement.exact_agreement_pct is not None %}
                                                        <span class="badge bg-{% if pair.stats.progress_agreement.exact_agreement_pct >= 70 %}success{% elif pair.stats.progress_agreement.exact_agreement_pct >= 50 %}warning{% else %}danger{% endif %} fs-4">
                                                            {{ pair.stats.progress_agreement.exact_agreement_pct }}%
                                                        </span>
                                                    {% else %}
                                                        <span class="text-muted">N/A</span>
                                                    {% endif %}
                                                </h3>
                                                <small class="text-muted">Same grade (0-0, 1-1, etc.)</small>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="col-md-4">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Within-1 Agreement</h6>
                                                <h3 class="card-title mb-0">
                                                    {% if pair.stats.progress_agreement.within_1_agreement_pct is not None %}
                                                        <span class="badge bg-{% if pair.stats.progress_agreement.within_1_agreement_pct >= 85 %}success{% elif pair.stats.progress_agreement.within_1_agreement_pct >= 70 %}warning{% else %}danger{% endif %} fs-4">
                                                            {{ pair.stats.progress_agreement.within_1_agreement_pct }}%
                                                        </span>
                                                    {% else %}
                                                        <span class="text-muted">N/A</span>
                                                    {% endif %}
                                                </h3>
                                                <small class="text-muted">Grades differ by ≤1 point</small>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="col-md-4">
                                        <div class="card text-center">
                                            <div class="card-body">
                                                <h6 class="card-subtitle mb-2 text-muted">Mean Difference</h6>
                                                <h3 class="card-title mb-0">
                                                    {% if pair.stats.progress_agreement.mean_absolute_difference is not None %}
                                                        <span class="badge bg-{% if pair.stats.progress_agreement.mean_absolute_difference <= 0.5 %}success{% elif pair.stats.progress_agreement.mean_absolute_difference <= 1.0 %}warning{% else %}danger{% endif %} fs-4">
                                                            {{ pair.stats.progress_agreement.mean_absolute_difference }}
                                                        </span>
                                                    {% else %}
                                                        <span class="text-muted">N/A</span>
                                                    {% endif %}
                                                </h3>
                                                <small class="text-muted">Average grade difference (0-3 scale)</small>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                                {% endif %}

                                <!-- Per-Category Breakdown -->
                                <h6>Category-by-Category Agreement</h6>
                                <div class="table-responsive">
                                    <table class="table table-sm table-bordered">
                                        <thead>
                                            <tr>
                                                <th>Category</th>
                                                <th>Agreement</th>
                                                <th>Agreed</th>
                                                <th>Total</th>
                                            </tr>
                                        </thead>
                                        <tbody>
                                            {% for cat_key, cat_label in category_labels.items %}
                                                {% with cat_stats=pair.stats.category_agreements|get_item:cat_key %}
                                                    <tr>
                                                        <td>{{ cat_label }}</td>
                                                        <td>
                                                            {% if cat_stats.agreement_pct is not None %}
                                                                <span class="badge bg-{% if cat_stats.agreement_pct >= 80 %}success{% elif cat_stats.agreement_pct >= 60 %}warning{% else %}danger{% endif %}">
                                                                    {{ cat_stats.agreement_pct }}%
                                                                </span>
                                                            {% else %}
                                                                <span class="text-muted">N/A</span>
                                                            {% endif %}
                                                        </td>
                                                        <td>{{ cat_stats.agreements }}</td>
                                                        <td>{{ cat_stats.total }}</td>
                                                    </tr>
                                                {% endwith %}
                                            {% endfor %}
                                        </tbody>
                                    </table>
                                </div>
                            </div>

                            {% if not forloop.last %}
                                <hr>
                            {% endif %}
                        {% endfor %}
                    </div>
                </div>
            {% endif %}

            <!-- Comparison Matrix -->
            <div class="card mb-4">
                <div class="card-header">
                    <h4 class="mb-0">Side-by-Side Comparison</h4>
                    <small class="text-muted">Compare grading decisions for each model answer across graders</small>
                </div>
                <div class="card-body">
                    {% if comparison_matrix %}
                        <div class="table-responsive">
                            <table class="table table-bordered table-sm" style="font-size: 0.85rem;">
                                <thead class="table-light">
                                    <tr>
                                        <th rowspan="2" class="align-middle">Model</th>
                                        {% for session_data in sessions_data %}
                                            <th colspan="10" class="text-center">{{ session_data.grader_name }}</th>
                                        {% endfor %}
                                    </tr>
                                    <tr>
                                        {% for session_data in sessions_data %}
                                            <th style="font-size: 0.75rem;">Alias</th>
                                            <th style="font-size: 0.75rem;" title="Incorrect Logic">IL</th>
                                            <th style="font-size: 0.75rem;" title="Hallucinated Facts">HF</th>
                                            <th style="font-size: 0.75rem;" title="Calculation Error">CE</th>
                                            <th style="font-size: 0.75rem;" title="Conceptual Error">CO</th>
                                            <th style="font-size: 0.75rem;" title="Problem Understanding">PU</th>
                                            <th style="font-size: 0.75rem;" title="Correct End Result">CR</th>
                                            <th style="font-size: 0.75rem;" title="Mathematical Insight">MI</th>
                                            <th style="font-size: 0.75rem;" title="Useful Progress">UP</th>
                                            <th style="font-size: 0.75rem;" title="Progress Grade (0-3)">PG</th>
                                        {% endfor %}
                                    </tr>
                                </thead>
                                <tbody>
                                    {% for row in comparison_matrix %}
                                        <tr>
                                            <td class="fw-bold">{{ row.model_name }}</td>
                                            {% for session_grading in row.session_gradings %}
                                                {% if session_grading.grading %}
                                                    <td>{{ session_grading.alias|default:"N/A" }}</td>
                                                    {% for field in 'error_incorrect_logic,error_hallucinated,error_calculation,error_conceptual,achievement_understanding,achievement_correct_result,achievement_insight,achievement_usefulness'|split:',' %}
                                                        {% with state=session_grading.grading|get_attr:field %}
                                                            <td class="text-center
                                                                {% if state %}
                                                                    {% if state.state_code == 'true' %}bg-danger bg-opacity-25{% endif %}
                                                                    {% if state.state_code == 'false' %}bg-success bg-opacity-25{% endif %}
                                                                    {% if state.state_code == 'not_sure' %}bg-warning bg-opacity-25{% endif %}
                                                                    {% if state.state_code == 'not_applicable' %}bg-secondary bg-opacity-25{% endif %}
                                                                {% endif %}
                                                            ">
                                                                {% if state %}
                                                                    {% if state.state_code == 'true' %}✓{% endif %}
                                                                    {% if state.state_code == 'false' %}✗{% endif %}
                                                                    {% if state.state_code == 'not_sure' %}?{% endif %}
                                                                    {% if state.state_code == 'not_applicable' %}N/A{% endif %}
                                                                {% else %}
                                                                    -
                                                                {% endif %}
                                                            </td>
                                                        {% endwith %}
                                                    {% endfor %}
                                                    <td class="text-center fw-bold
                                                        {% if session_grading.grading.progress_grade == 0 %}bg-danger bg-opacity-25{% endif %}
                                                        {% if session_grading.grading.progress_grade == 1 %}bg-warning bg-opacity-25{% endif %}
                                                        {% if session_grading.grading.progress_grade == 2 %}bg-info bg-opacity-25{% endif %}
                                                        {% if session_grading.grading.progress_grade == 3 %}bg-success bg-opacity-25{% endif %}
                                                    ">
                                                        {% if session_grading.grading.progress_grade is not None %}
                                                            {{ session_grading.grading.progress_grade }}
                                                        {% else %}
                                                            -
                                                        {% endif %}
                                                    </td>
                                                {% else %}
                                                    <td colspan="10" class="text-center text-muted">Not graded</td>
                                                {% endif %}
                                            {% endfor %}
                                        </tr>
                                    {% endfor %}
                                </tbody>
                            </table>
                        </div>

                        <div class="mt-3">
                            <h6>Legend</h6>
                            <div class="row">
                                <div class="col-md-4">
                                    <p><small><strong>Error Categories:</strong></small></p>
                                    <ul class="small">
                                        <li><strong>IL:</strong> Incorrect Logic</li>
                                        <li><strong>HF:</strong> Hallucinated Facts</li>
                                        <li><strong>CE:</strong> Calculation Error</li>
                                        <li><strong>CO:</strong> Conceptual Error</li>
                                    </ul>
                                </div>
                                <div class="col-md-4">
                                    <p><small><strong>Achievement Categories:</strong></small></p>
                                    <ul class="small">
                                        <li><strong>PU:</strong> Problem Understanding</li>
                                        <li><strong>CR:</strong> Correct End Result</li>
                                        <li><strong>MI:</strong> Mathematical Insight</li>
                                        <li><strong>UP:</strong> Useful Progress</li>
                                    </ul>
                                </div>
                                <div class="col-md-4">
                                    <p><small><strong>Progress Grade (PG):</strong></small></p>
                                    <ul class="small">
                                        <li><strong>0:</strong> None (no progress)</li>
                                        <li><strong>1:</strong> Minimal progress</li>
                                        <li><strong>2:</strong> Substantial progress</li>
                                        <li><strong>3:</strong> Near-complete solution</li>
                                    </ul>
                                </div>
                            </div>
                            <p><small><strong>Binary Values:</strong> ✓ = True (error present / achievement present), ✗ = False, ? = Not Sure, N/A = Not Applicable, - = Not rated</small></p>
                        </div>
                    {% else %}
                        <div class="alert alert-info">No gradings available for comparison.</div>
                    {% endif %}
                </div>
            </div>

        </div>
    </div>
</div>

<style>
    /* Improve readability of comparison table */
    .table-bordered th, .table-bordered td {
        border: 1px solid #dee2e6 !important;
    }

    /* Hover effect for matrix rows */
    .table tbody tr:hover {
        background-color: rgba(0, 0, 0, 0.02);
    }

    /* Make header sticky for long tables */
    @media (min-width: 768px) {
        .table-responsive {
            max-height: 800px;
            overflow-y: auto;
        }

        .table thead th {
            position: sticky;
            top: 0;
            background-color: #f8f9fa;
            z-index: 10;
        }
    }
</style>
{% endblock %}
