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

{% block title %}Grading Inspection - IMProofBench Admin{% endblock %}

{% block extra_css %}
<style>
    .session-card {
        transition: all 0.3s ease;
        cursor: pointer;
    }
    .session-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    }
    .progress-bar-container {
        background-color: #e9ecef;
        border-radius: 4px;
        overflow: hidden;
        height: 24px;
        position: relative;
    }
    .progress-segment {
        float: left;
        height: 100%;
        text-align: center;
        line-height: 24px;
        font-size: 12px;
        color: white;
        font-weight: 600;
        min-width: 2px;
    }
    .progress-completed {
        background-color: #28a745;
    }
    .progress-given-up {
        background-color: #dc3545;
    }
    .progress-in-progress {
        background-color: #ffc107;
    }
    .progress-not-started {
        background-color: #6c757d;
    }
    .stats-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 1rem;
    }
    .stat-card {
        text-align: center;
        padding: 1.5rem;
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
        border-radius: 8px;
        border: 2px solid;
    }
    .stat-card.active {
        border-color: #28a745;
    }
    .stat-card.finalized {
        border-color: #007bff;
    }
    .stat-card.total {
        border-color: #6c757d;
    }
    .session-meta {
        font-size: 0.875rem;
        color: #6c757d;
    }
    .grader-name {
        font-weight: 600;
        color: #495057;
    }
    .question-title {
        color: #007bff;
        text-decoration: none;
    }
    .question-title:hover {
        text-decoration: underline;
    }
    .empty-state {
        text-align: center;
        padding: 3rem;
        color: #6c757d;
    }
    .empty-state i {
        font-size: 3rem;
        margin-bottom: 1rem;
        display: block;
    }
</style>
{% endblock %}

{% block page_header %}
<div class="text-center mb-4">
    <h1 class="display-5 fw-bold text-danger">
        <i class="bi bi-clipboard-check me-2"></i>Grading Inspection
    </h1>
    <p class="lead text-muted">Monitor and manage grading sessions across all questions</p>
</div>
{% endblock %}

{% block content %}

<!-- Summary Statistics -->
<div class="stats-grid mb-4">
    <div class="stat-card total">
        <h2 class="mb-1">{{ total_sessions }}</h2>
        <p class="mb-0 text-muted">Total Sessions</p>
    </div>
    <div class="stat-card active">
        <h2 class="mb-1">{{ active_count }}</h2>
        <p class="mb-0 text-muted">Active Sessions</p>
    </div>
    <div class="stat-card finalized">
        <h2 class="mb-1">{{ finalized_count }}</h2>
        <p class="mb-0 text-muted">Finalized Sessions</p>
    </div>
</div>

<!-- Active Sessions -->
<div class="card mb-4">
    <div class="card-header bg-success text-white">
        <h4 class="mb-0">
            <i class="bi bi-hourglass-split me-2"></i>Active Grading Sessions ({{ active_count }})
        </h4>
    </div>
    <div class="card-body">
        {% if active_sessions %}
            <div class="table-responsive">
                <table class="table table-hover">
                    <thead>
                        <tr>
                            <th>Question</th>
                            <th>Grader</th>
                            <th>Progress</th>
                            <th>Started<br><small class="text-muted fw-normal" style="font-size: 0.85em;">Last Activity</small></th>
                            <th>Actions</th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for session_data in active_sessions %}
                        <tr>
                            <td>
                                <a href="{% url 'questions:detail' pk=session_data.session.question.pk %}"
                                   class="question-title">
                                    Q{{ session_data.session.question.pk }}: {{ session_data.session.question.title|truncatechars:40 }}
                                </a>
                            </td>
                            <td class="grader-name" title="{{ session_data.session.grader.email }}">
                                {{ session_data.session.grader.email|truncatechars:20 }}
                            </td>
                            <td style="min-width: 200px;">
                                <div class="progress-bar-container">
                                    {% if session_data.completed > 0 %}
                                    <div class="progress-segment progress-completed"
                                         style="width: {% widthratio session_data.completed session_data.total_answers 100 %}%"
                                         title="Completed: {{ session_data.completed }} answer{{ session_data.completed|pluralize }}">
                                        {% if session_data.completed > 0 %}{{ session_data.completed }}{% endif %}
                                    </div>
                                    {% endif %}
                                    {% if session_data.given_up > 0 %}
                                    <div class="progress-segment progress-given-up"
                                         style="width: {% widthratio session_data.given_up session_data.total_answers 100 %}%"
                                         title="Given Up: {{ session_data.given_up }} answer{{ session_data.given_up|pluralize }}">
                                        {% if session_data.given_up > 0 %}{{ session_data.given_up }}{% endif %}
                                    </div>
                                    {% endif %}
                                    {% if session_data.in_progress > 0 %}
                                    <div class="progress-segment progress-in-progress"
                                         style="width: {% widthratio session_data.in_progress session_data.total_answers 100 %}%"
                                         title="In Progress: {{ session_data.in_progress }} answer{{ session_data.in_progress|pluralize }}">
                                        {% if session_data.in_progress > 0 %}{{ session_data.in_progress }}{% endif %}
                                    </div>
                                    {% endif %}
                                    {% if session_data.not_started > 0 %}
                                    <div class="progress-segment progress-not-started"
                                         style="width: {% widthratio session_data.not_started session_data.total_answers 100 %}%"
                                         title="Not Started: {{ session_data.not_started }} answer{{ session_data.not_started|pluralize }}">
                                        {% if session_data.not_started > 0 %}{{ session_data.not_started }}{% endif %}
                                    </div>
                                    {% endif %}
                                </div>
                                <small class="text-muted">{{ session_data.progress_percentage }}% complete</small>
                            </td>
                            <td class="session-meta">
                                {{ session_data.session.created_at|date:"M d, Y g:i A" }}
                                {% if session_data.last_activity %}
                                    {% if session_data.last_activity != session_data.session.created_at %}
                                        <br><small class="text-muted" style="font-size: 0.85em;">{{ session_data.last_activity|timesince }} ago</small>
                                    {% else %}
                                        <br><small class="text-muted" style="font-size: 0.85em;">Just started</small>
                                    {% endif %}
                                {% else %}
                                    <br><small class="text-muted" style="font-size: 0.85em;">No activity yet</small>
                                {% endif %}
                            </td>
                            <td>
                                <a href="{% url 'questions:grading_overview' question_id=session_data.session.question.pk %}?inspect_session={{ session_data.session.pk }}"
                                   class="btn btn-sm btn-outline-primary">
                                    <i class="bi bi-eye"></i> Inspect
                                </a>
                                <form method="post" action="{% url 'questions:delete_grading_session' pk=session_data.session.pk %}"
                                      style="display: inline-block;"
                                      onsubmit="return confirm('Are you sure you want to delete this grading session for Question {{ session_data.session.question.pk }} by {{ session_data.session.grader.email }}? This action cannot be undone.');">
                                    {% csrf_token %}
                                    <button type="submit" class="btn btn-sm btn-outline-danger">
                                        <i class="bi bi-trash"></i> Delete
                                    </button>
                                </form>
                            </td>
                        </tr>
                        {% endfor %}
                    </tbody>
                </table>
            </div>
        {% else %}
            <div class="empty-state">
                <i class="bi bi-inbox"></i>
                <p>No active grading sessions</p>
            </div>
        {% endif %}
    </div>
</div>

<!-- Finalized Sessions -->
<div class="card mb-4">
    <div class="card-header bg-primary text-white">
        <h4 class="mb-0">
            <i class="bi bi-check-circle me-2"></i>Finalized Grading Sessions ({{ finalized_count }})
        </h4>
    </div>
    <div class="card-body">
        {% if finalized_sessions %}
            <div class="table-responsive">
                <table class="table table-hover">
                    <thead>
                        <tr>
                            <th>Question</th>
                            <th>Grader</th>
                            <th>Total Answers</th>
                            <th>Completed</th>
                            <th>Given Up</th>
                            <th>Finalized</th>
                            <th>Actions</th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for session_data in finalized_sessions %}
                        <tr>
                            <td>
                                <a href="{% url 'questions:detail' pk=session_data.session.question.pk %}"
                                   class="question-title">
                                    Q{{ session_data.session.question.pk }}: {{ session_data.session.question.title|truncatechars:40 }}
                                </a>
                            </td>
                            <td class="grader-name" title="{{ session_data.session.grader.email }}">
                                {{ session_data.session.grader.email|truncatechars:20 }}
                            </td>
                            <td class="text-center">
                                <span class="badge bg-info">{{ session_data.total_answers }}</span>
                            </td>
                            <td class="text-center">
                                <span class="badge bg-success">{{ session_data.completed }}</span>
                            </td>
                            <td class="text-center">
                                <span class="badge bg-danger">{{ session_data.given_up }}</span>
                            </td>
                            <td class="session-meta">
                                {{ session_data.session.finalized_at|date:"M d, Y g:i A" }}
                            </td>
                            <td>
                                <a href="{% url 'questions:grading_overview' question_id=session_data.session.question.pk %}?inspect_session={{ session_data.session.pk }}"
                                   class="btn btn-sm btn-outline-primary">
                                    <i class="bi bi-eye"></i> Inspect
                                </a>
                            </td>
                        </tr>
                        {% endfor %}
                    </tbody>
                </table>
            </div>
        {% else %}
            <div class="empty-state">
                <i class="bi bi-inbox"></i>
                <p>No finalized grading sessions</p>
            </div>
        {% endif %}
    </div>
</div>

<!-- Questions Without Grading Sessions -->
{% if questions_without_sessions %}
<div class="card">
    <div class="card-header bg-warning">
        <h4 class="mb-0">
            <i class="bi bi-exclamation-triangle me-2"></i>Questions with Released Answers but No Grading Sessions
        </h4>
    </div>
    <div class="card-body">
        <div class="table-responsive">
            <table class="table table-hover">
                <thead>
                    <tr>
                        <th>Question</th>
                        <th>Author</th>
                        <th>Released Answers</th>
                        <th>Actions</th>
                    </tr>
                </thead>
                <tbody>
                    {% for item in questions_without_sessions %}
                    <tr>
                        <td>
                            <a href="{% url 'questions:detail' pk=item.question.pk %}"
                               class="question-title">
                                Q{{ item.question.pk }}: {{ item.question.title|truncatechars:50 }}
                            </a>
                        </td>
                        <td>
                            {{ item.question.author.name }}
                        </td>
                        <td class="text-center">
                            <span class="badge bg-info">{{ item.released_count }}</span>
                        </td>
                        <td>
                            <a href="{% url 'questions:detail' pk=item.question.pk %}"
                               class="btn btn-sm btn-outline-info">
                                <i class="bi bi-eye"></i> View Question
                            </a>
                        </td>
                    </tr>
                    {% endfor %}
                </tbody>
            </table>
        </div>
    </div>
</div>
{% endif %}

{% endblock %}

{% block extra_js %}
<script>
document.addEventListener('DOMContentLoaded', function() {
    // Add tooltips to progress segments
    var tooltipTriggerList = [].slice.call(document.querySelectorAll('[title]'));
    var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
        return new bootstrap.Tooltip(tooltipTriggerEl);
    });
});
</script>
{% endblock %}