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

{% block title %}Grade Model Answers - {{ question.title|default:"Question" }} - IMProofBench{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item">
                <a href="{% url 'questions:list' %}" class="text-decoration-none">
                    <i class="bi bi-file-earmark-text me-1"></i>
                    Questions
                </a>
            </li>
            <li class="breadcrumb-item">
                <a href="{% url 'questions:detail' question.pk %}" class="text-decoration-none">
                    {{ question.title|default:"Question"|truncatechars:30 }}
                </a>
            </li>
            <li class="breadcrumb-item active">Grade Model Answers</li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}

{% if admin_inspection_mode %}
<!-- Admin Inspection Banner -->
<div class="alert alert-info d-flex align-items-center mb-4" role="alert">
    <i class="bi bi-shield-lock flex-shrink-0 me-3 fs-4"></i>
    <div>
        <strong>Admin Inspection Mode</strong><br>
        You are viewing the grading session of <strong>{{ inspected_grader.email }}</strong> in read-only mode.
        <a href="{% url 'questions:grading_inspection' %}" class="ms-2">← Back to Grading Inspection</a>
    </div>
</div>
{% endif %}

<div class="row">
    <div class="col-lg-12">
        <!-- Header Card -->
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-warning text-dark">
                <div class="d-flex justify-content-between align-items-center">
                    <div>
                        <h4 class="mb-0">
                            <i class="bi bi-clipboard-check me-2"></i>
                            Grading Sessions{% if admin_inspection_mode %} (Read-Only){% endif %}
                        </h4>
                        <small class="text-muted">
                            Question: {{ question.title|default:"Untitled" }}
                            {% if admin_inspection_mode %}
                            <br>Grader: {{ inspected_grader.email }}
                            {% endif %}
                        </small>
                    </div>
                    <div class="text-end">
                        <span class="badge bg-info fs-6">
                            <i class="bi bi-collection me-1"></i>
                            {{ sessions_data|length }} Session{% if sessions_data|length != 1 %}s{% endif %}
                        </span>
                    </div>
                </div>
            </div>
        </div>

        <!-- Loop through each session -->
        {% for session_data in sessions_data %}
        <div class="card shadow-sm mb-4 {% if session_data.session.is_finalized %}border-success{% endif %}">
            <div class="card-header {% if session_data.session.is_finalized %}bg-success bg-opacity-10{% else %}bg-light{% endif %}">
                <div class="d-flex justify-content-between align-items-center">
                    <div>
                        <h5 class="mb-0">
                            <i class="bi bi-calendar-event me-2"></i>
                            Session {{ forloop.counter }} - {{ session_data.session.created_at|date:"F d, Y g:i A" }}
                        </h5>
                    </div>
                    <div class="text-end">
                        {% if session_data.session.is_finalized %}
                            <span class="badge bg-success fs-6">
                                <i class="bi bi-check-circle me-1"></i>
                                Finalized
                            </span>
                        {% else %}
                            <span class="badge bg-info fs-6">
                                <i class="bi bi-hourglass-split me-1"></i>
                                Active
                            </span>
                        {% endif %}
                    </div>
                </div>
            </div>
            <div class="card-body">
                <!-- Progress Overview -->
                <div class="row mb-4">
                    <div class="col-md-3">
                        <div class="text-center">
                            <h5 class="text-muted">Total Answers</h5>
                            <h2 class="text-primary">{{ session_data.total_count }}</h2>
                        </div>
                    </div>
                    <div class="col-md-3">
                        <div class="text-center">
                            <h5 class="text-muted">Completed</h5>
                            <h2 class="text-success">{{ session_data.completed_count }}</h2>
                        </div>
                    </div>
                    <div class="col-md-3">
                        <div class="text-center">
                            <h5 class="text-muted">In Progress</h5>
                            <h2 class="text-warning">{{ session_data.in_progress_count }}</h2>
                        </div>
                    </div>
                    <div class="col-md-3">
                        <div class="text-center">
                            <h5 class="text-muted">Not Started</h5>
                            <h2 class="text-secondary">{{ session_data.not_started_count }}</h2>
                        </div>
                    </div>
                </div>

                <!-- Progress Bar -->
                <div class="progress mb-4" style="height: 30px;">
                    {% if session_data.total_count > 0 %}
                        {% widthratio session_data.completed_count session_data.total_count 100 as completed_pct %}
                        {% widthratio session_data.in_progress_count session_data.total_count 100 as progress_pct %}
                        {% widthratio session_data.given_up_count session_data.total_count 100 as given_up_pct %}

                        <div class="progress-bar bg-success" role="progressbar"
                             style="width: {{ completed_pct }}%"
                             aria-valuenow="{{ completed_pct }}" aria-valuemin="0" aria-valuemax="100">
                            {% if session_data.completed_count > 0 %}{{ session_data.completed_count }} Completed{% endif %}
                        </div>
                        <div class="progress-bar bg-warning" role="progressbar"
                             style="width: {{ progress_pct }}%"
                             aria-valuenow="{{ progress_pct }}" aria-valuemin="0" aria-valuemax="100">
                            {% if session_data.in_progress_count > 0 %}{{ session_data.in_progress_count }} In Progress{% endif %}
                        </div>
                        <div class="progress-bar bg-danger" role="progressbar"
                             style="width: {{ given_up_pct }}%"
                             aria-valuenow="{{ given_up_pct }}" aria-valuemin="0" aria-valuemax="100">
                            {% if session_data.given_up_count > 0 %}{{ session_data.given_up_count }} Given Up{% endif %}
                        </div>
                    {% endif %}
                </div>

                <!-- Finalization Section -->
                {% if not session_data.session.is_finalized and session_data.all_complete %}
                <div class="alert alert-info d-flex justify-content-between align-items-center">
                    <div>
                        <i class="bi bi-info-circle me-2"></i>
                        <strong>All answers in this session have been graded!</strong>
                        You can now finalize this session to reveal model identities.
                    </div>
                    <form method="post" action="{% url 'questions:grading_finalize' question.pk %}" class="m-0">
                        {% csrf_token %}
                        <input type="hidden" name="session_id" value="{{ session_data.session.id }}">
                        <button type="submit" class="btn btn-success">
                            <i class="bi bi-check-circle me-1"></i>
                            Finalize This Session
                        </button>
                    </form>
                </div>
                {% endif %}

                <!-- Grading Table -->
                <div class="table-responsive">
                    <table class="table table-hover mb-0">
                        <thead class="table-light">
                            <tr>
                                <th class="text-center" style="width: 80px;">Answer</th>
                                <th class="text-center" style="width: 50px;">Tier</th>
                                <th style="min-width: 150px;">Model</th>
                                <th class="text-center" style="width: 100px;">Status</th>
                                <th class="text-center" colspan="4">AI Mistakes</th>
                                <th class="text-center" colspan="4">AI Achievements</th>
                                <th class="text-center" style="width: 100px;">Final Grade</th>
                                <th class="text-center" style="width: 120px;">Actions</th>
                            </tr>
                            <tr class="small text-muted">
                                <th></th>
                                <th></th>
                                <th></th>
                                <th></th>
                                <!-- AI Mistakes -->
                                <th class="text-center" title="Incorrect Logic or Reasoning">Logic</th>
                                <th class="text-center" title="Hallucinated Results or Literature">Hallu.</th>
                                <th class="text-center" title="Calculation Mistakes">Calc.</th>
                                <th class="text-center" title="Conceptual Misunderstanding">Concept</th>
                                <!-- AI Achievements -->
                                <th class="text-center" title="Problem Understanding">Underst.</th>
                                <th class="text-center" title="Correct End Result">Result</th>
                                <th class="text-center" title="Insight and Creativity">Insight</th>
                                <th class="text-center" title="Practical Usefulness">Useful</th>
                                <th></th>
                                <th></th>
                            </tr>
                        </thead>
                        <tbody>
                            <!-- Tier 1 Section -->
                            {% if session_data.tier1_aliases %}
                            {% for alias_data in session_data.tier1_aliases %}
                            <tr>
                                <td class="text-center fw-bold">{{ alias_data.alias }}</td>
                                <td class="text-center">
                                    <span class="badge bg-warning text-dark">T1</span>
                                </td>
                                <td>
                                    {% if session_data.session.is_finalized %}
                                        <strong>{{ alias_data.model_name }}</strong><br>
                                        <small class="text-muted">{{ alias_data.company_name }}</small>
                                    {% else %}
                                        <span class="text-muted fst-italic">(grade all to reveal)</span>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    {% if alias_data.grading_status == 'completed' %}
                                        <span class="badge bg-success">Completed</span>
                                    {% elif alias_data.grading_status == 'in_progress' %}
                                        <span class="badge bg-warning text-dark">In Progress</span>
                                    {% elif alias_data.grading_status == 'given_up' %}
                                        <span class="badge bg-danger">Given Up</span>
                                    {% else %}
                                        <span class="badge bg-secondary">Not Started</span>
                                    {% endif %}
                                </td>
                                <!-- AI Mistakes -->
                                <td class="text-center">{{ alias_data.error_incorrect_logic|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_hallucinated|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_calculation|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_conceptual|yesno:"✓,✗,?" }}</td>
                                <!-- AI Achievements -->
                                <td class="text-center">{{ alias_data.achievement_understanding|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.achievement_correct_result == 'N/A' %}
                                        <span class="text-muted">N/A</span>
                                    {% else %}
                                        {{ alias_data.achievement_correct_result|yesno:"✓,✗,?" }}
                                    {% endif %}
                                </td>
                                <td class="text-center">{{ alias_data.achievement_insight|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.achievement_usefulness|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.progress_grade %}
                                        <strong>{{ alias_data.progress_grade }}</strong>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    <a href="{% url 'questions:grading_detail' question.pk alias_data.alias %}{% if admin_inspection_mode %}?inspect_session={{ session_data.session.pk }}{% endif %}"
                                       class="btn btn-sm btn-outline-primary">
                                        {% if admin_inspection_mode %}
                                            <i class="bi bi-eye"></i> View
                                        {% elif alias_data.grading_status == 'not_started' %}
                                            <i class="bi bi-play-fill"></i> Start
                                        {% elif session_data.session.is_finalized %}
                                            <i class="bi bi-pencil-square"></i> View
                                        {% else %}
                                            <i class="bi bi-pencil-square"></i> Edit
                                        {% endif %}
                                    </a>
                                </td>
                            </tr>
                            {% endfor %}
                            {% endif %}

                            <!-- Tier 2-3 Section -->
                            {% if session_data.tier23_aliases %}
                            {% for alias_data in session_data.tier23_aliases %}
                            <tr>
                                <td class="text-center fw-bold">{{ alias_data.alias }}</td>
                                <td class="text-center">
                                    <span class="badge bg-secondary">T2-3</span>
                                </td>
                                <td>
                                    {% if session_data.session.is_finalized %}
                                        <strong>{{ alias_data.model_name }}</strong><br>
                                        <small class="text-muted">{{ alias_data.company_name }}</small>
                                    {% else %}
                                        <span class="text-muted fst-italic">(grade all to reveal)</span>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    {% if alias_data.grading_status == 'completed' %}
                                        <span class="badge bg-success">Completed</span>
                                    {% elif alias_data.grading_status == 'in_progress' %}
                                        <span class="badge bg-warning text-dark">In Progress</span>
                                    {% elif alias_data.grading_status == 'given_up' %}
                                        <span class="badge bg-danger">Given Up</span>
                                    {% else %}
                                        <span class="badge bg-secondary">Not Started</span>
                                    {% endif %}
                                </td>
                                <!-- AI Mistakes -->
                                <td class="text-center">{{ alias_data.error_incorrect_logic|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_hallucinated|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_calculation|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_conceptual|yesno:"✓,✗,?" }}</td>
                                <!-- AI Achievements -->
                                <td class="text-center">{{ alias_data.achievement_understanding|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.achievement_correct_result == 'N/A' %}
                                        <span class="text-muted">N/A</span>
                                    {% else %}
                                        {{ alias_data.achievement_correct_result|yesno:"✓,✗,?" }}
                                    {% endif %}
                                </td>
                                <td class="text-center">{{ alias_data.achievement_insight|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.achievement_usefulness|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.progress_grade %}
                                        <strong>{{ alias_data.progress_grade }}</strong>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    <a href="{% url 'questions:grading_detail' question.pk alias_data.alias %}{% if admin_inspection_mode %}?inspect_session={{ session_data.session.pk }}{% endif %}"
                                       class="btn btn-sm btn-outline-primary">
                                        {% if admin_inspection_mode %}
                                            <i class="bi bi-eye"></i> View
                                        {% elif alias_data.grading_status == 'not_started' %}
                                            <i class="bi bi-play-fill"></i> Start
                                        {% elif session_data.session.is_finalized %}
                                            <i class="bi bi-pencil-square"></i> View
                                        {% else %}
                                            <i class="bi bi-pencil-square"></i> Edit
                                        {% endif %}
                                    </a>
                                </td>
                            </tr>
                            {% endfor %}
                            {% endif %}

                            <!-- Tier 4+ Section -->
                            {% if session_data.tier4plus_aliases %}
                            {% for alias_data in session_data.tier4plus_aliases %}
                            <tr>
                                <td class="text-center fw-bold">{{ alias_data.alias }}</td>
                                <td class="text-center">
                                    <span class="badge bg-info text-dark">T4+</span>
                                </td>
                                <td>
                                    {% if session_data.session.is_finalized %}
                                        <strong>{{ alias_data.model_name }}</strong><br>
                                        <small class="text-muted">{{ alias_data.company_name }}</small>
                                    {% else %}
                                        <span class="text-muted fst-italic">(grade all to reveal)</span>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    {% if alias_data.grading_status == 'completed' %}
                                        <span class="badge bg-success">Completed</span>
                                    {% elif alias_data.grading_status == 'in_progress' %}
                                        <span class="badge bg-warning text-dark">In Progress</span>
                                    {% elif alias_data.grading_status == 'given_up' %}
                                        <span class="badge bg-danger">Given Up</span>
                                    {% else %}
                                        <span class="badge bg-secondary">Not Started</span>
                                    {% endif %}
                                </td>
                                <!-- AI Mistakes -->
                                <td class="text-center">{{ alias_data.error_incorrect_logic|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_hallucinated|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_calculation|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.error_conceptual|yesno:"✓,✗,?" }}</td>
                                <!-- AI Achievements -->
                                <td class="text-center">{{ alias_data.achievement_understanding|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.achievement_correct_result == 'N/A' %}
                                        <span class="text-muted">N/A</span>
                                    {% else %}
                                        {{ alias_data.achievement_correct_result|yesno:"✓,✗,?" }}
                                    {% endif %}
                                </td>
                                <td class="text-center">{{ alias_data.achievement_insight|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">{{ alias_data.achievement_usefulness|yesno:"✓,✗,?" }}</td>
                                <td class="text-center">
                                    {% if alias_data.progress_grade %}
                                        <strong>{{ alias_data.progress_grade }}</strong>
                                    {% endif %}
                                </td>
                                <td class="text-center">
                                    <a href="{% url 'questions:grading_detail' question.pk alias_data.alias %}{% if admin_inspection_mode %}?inspect_session={{ session_data.session.pk }}{% endif %}"
                                       class="btn btn-sm btn-outline-primary">
                                        {% if admin_inspection_mode %}
                                            <i class="bi bi-eye"></i> View
                                        {% elif alias_data.grading_status == 'not_started' %}
                                            <i class="bi bi-play-fill"></i> Start
                                        {% elif session_data.session.is_finalized %}
                                            <i class="bi bi-pencil-square"></i> View
                                        {% else %}
                                            <i class="bi bi-pencil-square"></i> Edit
                                        {% endif %}
                                    </a>
                                </td>
                            </tr>
                            {% endfor %}
                            {% endif %}
                        </tbody>
                    </table>
                </div>
            </div>
        </div>
        {% empty %}
        <div class="alert alert-info">
            <i class="bi bi-info-circle me-2"></i>
            No grading sessions exist yet. Visit this page when model answers are released for grading.
        </div>
        {% endfor %}

        <!-- Action Buttons -->
        <div class="d-flex justify-content-between">
            <a href="{% url 'questions:detail' question.pk %}" class="btn btn-outline-secondary">
                <i class="bi bi-arrow-left me-2"></i>
                Back to Question
            </a>
        </div>
    </div>
</div>
{% endblock %}

{% block extra_css %}
<style>
    .table th {
        white-space: nowrap;
        font-size: 0.875rem;
    }

    .table td {
        vertical-align: middle;
    }

    /* Status symbols styling - columns 5 through 12 (after Answer, Tier, Model, Status) */
    .table td:nth-child(n+5):nth-child(-n+12) {
        font-size: 1.2rem;
        font-weight: bold;
    }

    /* Check mark green */
    .table td:contains("✓") {
        color: #198754;
    }

    /* X mark red */
    .table td:contains("✗") {
        color: #dc3545;
    }

    /* Question mark gray */
    .table td:contains("?") {
        color: #6c757d;
    }
</style>
{% endblock %}
