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

{% block title %}Inspect Grading Session - IMProofBench Admin{% endblock %}

{% block extra_css %}
<style>
    .grading-table th {
        background-color: #f8f9fa;
        font-weight: 600;
        white-space: nowrap;
    }
    .grading-table td {
        vertical-align: middle;
    }
    .grade-true {
        color: #28a745;
        font-weight: 600;
    }
    .grade-false {
        color: #dc3545;
        font-weight: 600;
    }
    .grade-not-sure {
        color: #ffc107;
        font-weight: 600;
    }
    .grade-na {
        color: #6c757d;
        font-weight: 600;
    }
    .progress-grade {
        font-size: 1.2rem;
        font-weight: bold;
    }
    .model-identity {
        background-color: #e3f2fd;
        padding: 0.25rem 0.5rem;
        border-radius: 4px;
        font-weight: 600;
    }
    .tier-section {
        margin-bottom: 2rem;
    }
    .tier-header {
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
        padding: 0.75rem 1rem;
        border-radius: 8px 8px 0 0;
        margin-bottom: 0;
        font-weight: 600;
    }
    .grading-status {
        display: inline-block;
        padding: 0.25rem 0.5rem;
        border-radius: 4px;
        font-size: 0.875rem;
        font-weight: 600;
    }
    .status-completed {
        background-color: #d4edda;
        color: #155724;
    }
    .status-given_up {
        background-color: #f8d7da;
        color: #721c24;
    }
    .status-in_progress {
        background-color: #fff3cd;
        color: #856404;
    }
    .status-not_started {
        background-color: #e2e3e5;
        color: #383d41;
    }
    .session-info {
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
        border-radius: 8px;
        padding: 1.5rem;
        margin-bottom: 2rem;
    }
    .info-row {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 0.5rem;
    }
    .info-label {
        font-weight: 600;
        color: #6c757d;
    }
    .info-value {
        font-weight: 500;
        color: #212529;
    }
    .comments-section {
        background-color: #f8f9fa;
        padding: 0.75rem;
        border-radius: 4px;
        margin-top: 0.5rem;
    }
    .flag-warning {
        background-color: #fff3cd;
        border-left: 4px solid #ffc107;
        padding: 0.5rem 1rem;
        margin-bottom: 0.5rem;
    }
    .answer-content {
        max-height: 300px;
        overflow-y: auto;
        padding: 1rem;
        background-color: #f8f9fa;
        border-radius: 4px;
        margin-bottom: 1rem;
    }
</style>
{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item"><a href="{% url 'questions:grading_inspection' %}">Grading Inspection</a></li>
            <li class="breadcrumb-item active">Session #{{ session.id }}</li>
        </ol>
    </nav>
    <h1 class="display-5 fw-bold text-danger">
        <i class="bi bi-clipboard-check me-2"></i>Inspect Grading Session
    </h1>
    <p class="lead text-muted">Viewing grading session by {{ session.grader.email }}</p>
</div>
{% endblock %}

{% block content %}

<!-- Session Information -->
<div class="session-info">
    <div class="row">
        <div class="col-md-6">
            <div class="info-row">
                <span class="info-label">Question:</span>
                <span class="info-value">
                    <a href="{% url 'questions:detail' pk=question.pk %}" class="text-decoration-none">
                        Q{{ question.pk }}: {{ question.question_title|truncatechars:50 }}
                    </a>
                </span>
            </div>
            <div class="info-row">
                <span class="info-label">Grader:</span>
                <span class="info-value">{{ session.grader.email }}</span>
            </div>
            <div class="info-row">
                <span class="info-label">Status:</span>
                <span class="info-value">
                    {% if session.is_finalized %}
                        <span class="badge bg-primary">Finalized</span>
                    {% else %}
                        <span class="badge bg-success">Active</span>
                    {% endif %}
                </span>
            </div>
        </div>
        <div class="col-md-6">
            <div class="info-row">
                <span class="info-label">Created:</span>
                <span class="info-value">{{ session.created_at|date:"M d, Y g:i A" }}</span>
            </div>
            {% if session.is_finalized %}
            <div class="info-row">
                <span class="info-label">Finalized:</span>
                <span class="info-value">{{ session.finalized_at|date:"M d, Y g:i A" }}</span>
            </div>
            {% endif %}
            <div class="info-row">
                <span class="info-label">Progress:</span>
                <span class="info-value">
                    {{ completed_count }}/{{ total_count }} completed,
                    {{ given_up_count }} given up,
                    {{ in_progress_count }} in progress,
                    {{ not_started_count }} not started
                </span>
            </div>
        </div>
    </div>

    {% if session.grader_notes %}
    <div class="mt-3">
        <strong>Grader's Notes:</strong>
        <div class="comments-section">
            {{ session.grader_notes|linebreaks }}
        </div>
    </div>
    {% endif %}
</div>

<!-- Tier 1 Grading Results -->
{% if tier1_aliases %}
<div class="tier-section">
    <h3 class="tier-header">Tier 1 Models</h3>
    <div class="table-responsive">
        <table class="table table-bordered grading-table">
            <thead>
                <tr>
                    <th>Alias</th>
                    <th>Model Identity</th>
                    <th>Status</th>
                    <th>Progress</th>
                    <th>Errors</th>
                    <th>Achievements</th>
                    <th>Comments</th>
                </tr>
            </thead>
            <tbody>
                {% for alias_data in tier1_aliases %}
                <tr>
                    <td><strong>{{ alias_data.alias }}</strong></td>
                    <td>
                        <span class="model-identity">
                            {{ alias_data.company_name }}/{{ alias_data.model_name }}
                        </span>
                    </td>
                    <td>
                        <span class="grading-status status-{{ alias_data.grading_status }}">
                            {% if alias_data.grading_status == 'not_started' %}
                                Not Started
                            {% elif alias_data.grading_status == 'in_progress' %}
                                In Progress
                            {% elif alias_data.grading_status == 'given_up' %}
                                Given Up
                            {% else %}
                                {{ alias_data.grading_status|title }}
                            {% endif %}
                        </span>
                    </td>
                    <td>
                        {% if alias_data.progress_grade %}
                            <span class="progress-grade">{{ alias_data.progress_grade }}</span>
                        {% else %}
                            <span class="text-muted">—</span>
                        {% endif %}
                    </td>
                    <td>
                        <small>
                            Logic: {% if alias_data.error_incorrect_logic == True %}<span class="grade-true">✓</span>{% elif alias_data.error_incorrect_logic == False %}<span class="grade-false">✗</span>{% elif alias_data.error_incorrect_logic == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Hallucinated: {% if alias_data.error_hallucinated == True %}<span class="grade-true">✓</span>{% elif alias_data.error_hallucinated == False %}<span class="grade-false">✗</span>{% elif alias_data.error_hallucinated == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Calculation: {% if alias_data.error_calculation == True %}<span class="grade-true">✓</span>{% elif alias_data.error_calculation == False %}<span class="grade-false">✗</span>{% elif alias_data.error_calculation == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Conceptual: {% if alias_data.error_conceptual == True %}<span class="grade-true">✓</span>{% elif alias_data.error_conceptual == False %}<span class="grade-false">✗</span>{% elif alias_data.error_conceptual == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}
                        </small>
                    </td>
                    <td>
                        <small>
                            Understanding: {% if alias_data.achievement_understanding == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_understanding == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_understanding == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Correct: {% if alias_data.achievement_correct_result == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_correct_result == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_correct_result == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Insight: {% if alias_data.achievement_insight == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_insight == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_insight == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Usefulness: {% if alias_data.achievement_usefulness == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_usefulness == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_usefulness == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}
                        </small>
                    </td>
                    <td>
                        {% if alias_data.flag_for_organizers %}
                        <div class="flag-warning">
                            <i class="bi bi-flag-fill text-warning"></i> Flagged
                        </div>
                        {% endif %}
                        {% if alias_data.comments %}
                            <small>{{ alias_data.comments|truncatechars:100 }}</small>
                        {% else %}
                            <span class="text-muted">—</span>
                        {% endif %}
                    </td>
                </tr>
                {% endfor %}
            </tbody>
        </table>
    </div>
</div>
{% endif %}

<!-- Tier 2-3 Grading Results -->
{% if tier23_aliases %}
<div class="tier-section">
    <h3 class="tier-header">Tier 2-3 Models</h3>
    <div class="table-responsive">
        <table class="table table-bordered grading-table">
            <thead>
                <tr>
                    <th>Alias</th>
                    <th>Model Identity</th>
                    <th>Status</th>
                    <th>Progress</th>
                    <th>Errors</th>
                    <th>Achievements</th>
                    <th>Comments</th>
                </tr>
            </thead>
            <tbody>
                {% for alias_data in tier23_aliases %}
                <tr>
                    <td><strong>{{ alias_data.alias }}</strong></td>
                    <td>
                        <span class="model-identity">
                            {{ alias_data.company_name }}/{{ alias_data.model_name }}
                        </span>
                    </td>
                    <td>
                        <span class="grading-status status-{{ alias_data.grading_status }}">
                            {% if alias_data.grading_status == 'not_started' %}
                                Not Started
                            {% elif alias_data.grading_status == 'in_progress' %}
                                In Progress
                            {% elif alias_data.grading_status == 'given_up' %}
                                Given Up
                            {% else %}
                                {{ alias_data.grading_status|title }}
                            {% endif %}
                        </span>
                    </td>
                    <td>
                        {% if alias_data.progress_grade %}
                            <span class="progress-grade">{{ alias_data.progress_grade }}</span>
                        {% else %}
                            <span class="text-muted">—</span>
                        {% endif %}
                    </td>
                    <td>
                        <small>
                            Logic: {% if alias_data.error_incorrect_logic == True %}<span class="grade-true">✓</span>{% elif alias_data.error_incorrect_logic == False %}<span class="grade-false">✗</span>{% elif alias_data.error_incorrect_logic == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Hallucinated: {% if alias_data.error_hallucinated == True %}<span class="grade-true">✓</span>{% elif alias_data.error_hallucinated == False %}<span class="grade-false">✗</span>{% elif alias_data.error_hallucinated == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Calculation: {% if alias_data.error_calculation == True %}<span class="grade-true">✓</span>{% elif alias_data.error_calculation == False %}<span class="grade-false">✗</span>{% elif alias_data.error_calculation == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Conceptual: {% if alias_data.error_conceptual == True %}<span class="grade-true">✓</span>{% elif alias_data.error_conceptual == False %}<span class="grade-false">✗</span>{% elif alias_data.error_conceptual == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}
                        </small>
                    </td>
                    <td>
                        <small>
                            Understanding: {% if alias_data.achievement_understanding == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_understanding == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_understanding == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Correct: {% if alias_data.achievement_correct_result == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_correct_result == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_correct_result == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Insight: {% if alias_data.achievement_insight == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_insight == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_insight == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}<br>
                            Usefulness: {% if alias_data.achievement_usefulness == True %}<span class="grade-true">✓</span>{% elif alias_data.achievement_usefulness == False %}<span class="grade-false">✗</span>{% elif alias_data.achievement_usefulness == 'N/A' %}<span class="grade-na">N/A</span>{% else %}<span class="text-muted">?</span>{% endif %}
                        </small>
                    </td>
                    <td>
                        {% if alias_data.flag_for_organizers %}
                        <div class="flag-warning">
                            <i class="bi bi-flag-fill text-warning"></i> Flagged
                        </div>
                        {% endif %}
                        {% if alias_data.comments %}
                            <small>{{ alias_data.comments|truncatechars:100 }}</small>
                        {% else %}
                            <span class="text-muted">—</span>
                        {% endif %}
                    </td>
                </tr>
                {% endfor %}
            </tbody>
        </table>
    </div>
</div>
{% endif %}

<!-- Navigation -->
<div class="mt-4">
    <a href="{% url 'questions:grading_inspection' %}" class="btn btn-secondary">
        <i class="bi bi-arrow-left"></i> Back to Grading Inspection
    </a>
    <a href="{% url 'questions:detail' pk=question.pk %}" class="btn btn-info ms-2">
        <i class="bi bi-file-earmark-text"></i> View Question
    </a>
</div>

{% endblock %}

{% block extra_js %}
<script>
document.addEventListener('DOMContentLoaded', function() {
    // Initialize tooltips if needed
    var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
    var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
        return new bootstrap.Tooltip(tooltipTriggerEl);
    });
});
</script>
{% endblock %}