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

{% block title %}Model Evaluations{% endblock %}

{% block extra_css %}
<style>
/* Question row styling */
.question-row {
    cursor: pointer;
    transition: background-color 0.15s ease-in-out;
}

.question-row:hover {
    background-color: #f8f9fa;
}

/* Evaluation status colors - Increased saturation for better visibility */
.eval-pending {
    background-color: #ffc107 !important;  /* Changed from #fff3cd - bright amber */
    color: #212529;  /* Darker text for better contrast */
}

.eval-running {
    background-color: #17a2b8 !important;  /* Changed from #cff4fc - bright cyan */
    color: #ffffff;  /* White text for contrast */
}

.eval-completed {
    background-color: #28a745 !important;  /* Changed from #d1e7dd - bright green */
    color: #ffffff;  /* White text for contrast */
}

.eval-released {
    background-color: #0a5837 !important;  /* Keep darker green for released - already good */
    color: #ffffff;
}

.eval-failed {
    background-color: #dc3545 !important;  /* Changed from #f8d7da - bright red */
    color: #ffffff;  /* White text for contrast */
}

.eval-cancelled {
    background-color: #6c757d !important;  /* Changed from #e9ecef - medium gray */
    color: #ffffff;  /* White text for contrast */
}

/* Tier grouping styles */
.tier-section {
    border-left: 3px solid #dee2e6;
    padding-left: 15px;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #dee2e6;
}

.tier-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.tier-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.tier-label {
    font-weight: 600;
    color: #495057;
    display: flex;
    align-items: center;
}

/* Evaluation grid */
.eval-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 10px;
    margin-bottom: 15px;
}

.eval-item {
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: transform 0.1s ease-in-out;
}

.eval-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.eval-checkbox {
    flex-shrink: 0;
}

.eval-link {
    color: inherit;
    text-decoration: none;
    flex-grow: 1;
}

.eval-link:hover {
    text-decoration: underline;
}

/* Action buttons */
.action-buttons {
    display: flex;
    gap: 4px;
    margin-left: auto;
    flex-shrink: 0;
}

.action-btn {
    padding: 4px 8px;
    border-radius: 4px;
    border: 1px solid;
    background: white;
    cursor: pointer;
    font-size: 0.85rem;
    transition: all 0.2s;
}

.action-btn-rerun {
    color: #0d6efd;
    border-color: #0d6efd;
}

.action-btn-rerun:hover {
    background-color: #0d6efd;
    color: white;
}

.action-btn-cancel {
    color: #dc3545;
    border-color: #dc3545;
}

.action-btn-cancel:hover {
    background-color: #dc3545;
    color: white;
}

/* Progress bar */
.progress-small {
    height: 6px;
    margin-top: 4px;
}

/* Expand/collapse icon */
.expand-icon {
    transition: transform 0.2s;
    margin-right: 8px;
}

.collapsed .expand-icon {
    transform: rotate(-90deg);
}

/* Bulk action controls */
.bulk-controls {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 10px;
    background-color: #f8f9fa;
    border-radius: 4px;
    margin-bottom: 15px;
}

.bulk-controls button {
    font-size: 0.9rem;
}
</style>
{% endblock %}

{% block content %}
<div class="container-fluid">
    <div class="row">
        <div class="col-12">
            <h1 class="mb-4">Model Evaluations</h1>
            
            <!-- Quick Stats Header -->
            <div class="row mb-4">
                <div class="col-md-3">
                    <div class="card bg-warning text-dark">
                        <div class="card-body text-center py-3">
                            <h6 class="card-title mb-1">Pending</h6>
                            <h4 class="mb-0">{{ queue_stats.pending|default:0 }}</h4>
                        </div>
                    </div>
                </div>
                <div class="col-md-3">
                    <div class="card bg-info text-white">
                        <div class="card-body text-center py-3">
                            <h6 class="card-title mb-1">Running</h6>
                            <h4 class="mb-0">{{ queue_stats.running|default:0 }}</h4>
                        </div>
                    </div>
                </div>
                <div class="col-md-3">
                    <div class="card bg-success text-white">
                        <div class="card-body text-center py-3">
                            <h6 class="card-title mb-1">Completed</h6>
                            <h4 class="mb-0">{{ queue_stats.completed|default:0 }}</h4>
                        </div>
                    </div>
                </div>
                <div class="col-md-3">
                    <div class="card bg-danger text-white">
                        <div class="card-body text-center py-3">
                            <h6 class="card-title mb-1">Failed</h6>
                            <h4 class="mb-0">{{ queue_stats.failed|default:0 }}</h4>
                        </div>
                    </div>
                </div>
            </div>

            <!-- Global Actions Panel -->
            <div class="card mb-3 border-primary">
                <div class="card-header bg-primary bg-opacity-10">
                    <h6 class="mb-0 text-primary">
                        <i class="bi bi-lightning-fill"></i> Global Actions
                    </h6>
                </div>
                <div class="card-body">
                    <div class="d-flex flex-wrap gap-2 align-items-center">
                        <button type="button" class="btn btn-sm btn-outline-warning"
                                onclick="globalSelectAllCancelled()">
                            <i class="bi bi-funnel"></i> Select All Cancelled
                        </button>
                        <button type="button" class="btn btn-sm btn-outline-primary"
                                onclick="globalBulkRerun()">
                            <i class="bi bi-arrow-repeat"></i> Re-run Selected
                        </button>
                        <span class="text-muted mx-1">|</span>
                        <button type="button" class="btn btn-sm btn-outline-success"
                                onclick="globalStandardGradingUnreleased()">
                            <i class="bi bi-check-square"></i> Standard Grading Selection (unreleased)
                        </button>
                        <button type="button" class="btn btn-sm btn-success"
                                onclick="globalReleaseForGrading()">
                            <i class="bi bi-box-arrow-up"></i> Release for Grading
                        </button>
                        <span class="text-muted mx-1">|</span>
                        <a href="{% url 'model_evaluation:export_matharena' %}" class="btn btn-sm btn-outline-info">
                            <i class="bi bi-download"></i> Export JSON
                        </a>
                    </div>
                    <div class="mt-2">
                        <small class="text-muted">
                            <i class="bi bi-info-circle"></i>
                            These actions apply to all questions on this page. Use with caution.
                        </small>
                    </div>
                </div>
            </div>

            <!-- Sort and Filter Controls -->
            <div class="row mb-3">
                <div class="col-12">
                    <form method="get" class="d-flex align-items-center gap-3">
                        <div>
                            <label class="me-2">Sort by:</label>
                            <select name="sort" class="form-select form-select-sm d-inline-block w-auto" onchange="this.form.submit()">
                                <option value="activity" {% if sort_by == 'activity' %}selected{% endif %}>Last Activity</option>
                                <option value="id" {% if sort_by == 'id' %}selected{% endif %}>Question ID</option>
                                <option value="completion" {% if sort_by == 'completion' %}selected{% endif %}>Completion %</option>
                            </select>
                        </div>
                    </form>
                </div>
            </div>
            
            {% if questions_data %}
                <div class="card">
                    <div class="card-body">
                        <table class="table table-hover mb-0">
                            <thead>
                                <tr>
                                    <th width="50"></th>
                                    <th>Question</th>
                                    <th>Progress</th>
                                    <th>Last Activity</th>
                                </tr>
                            </thead>
                            <tbody>
                                {% for qdata in questions_data %}
                                    <!-- Question Row (Expandable) -->
                                    <tr class="question-row" data-bs-toggle="collapse" data-bs-target="#{{ qdata.collapse_id }}" aria-expanded="false">
                                        <td>
                                            <i class="bi bi-chevron-down expand-icon"></i>
                                        </td>
                                        <td>
                                            <strong>
                                                <a href="{% url 'questions:detail' qdata.question.id %}"
                                                   onclick="event.stopPropagation()">
                                                    Q{{ qdata.question.id }}: {{ qdata.question.title|truncatechars:60 }}
                                                </a>
                                            </strong>
                                            {% if qdata.modified_after_evaluation %}
                                                <span class="badge bg-warning text-dark ms-2"
                                                      title="Question was modified after the latest evaluation"
                                                      data-bs-toggle="tooltip">
                                                    <i class="bi bi-exclamation-triangle-fill"></i> Modified
                                                </span>
                                            {% endif %}
                                        </td>
                                        <td>
                                            <div>
                                                {{ qdata.completed_evaluations }} / {{ qdata.total_evaluations }} completed
                                            </div>
                                            <div class="progress progress-small">
                                                <div class="progress-bar bg-success" role="progressbar" 
                                                     style="width: {% widthratio qdata.completed_evaluations qdata.total_evaluations 100 %}%"
                                                     aria-valuenow="{{ qdata.completed_evaluations }}" 
                                                     aria-valuemin="0" 
                                                     aria-valuemax="{{ qdata.total_evaluations }}">
                                                </div>
                                            </div>
                                        </td>
                                        <td>
                                            {% if qdata.last_activity %}
                                                {{ qdata.last_activity|date:"M d, H:i" }}
                                            {% else %}
                                                <span class="text-muted">—</span>
                                            {% endif %}
                                        </td>
                                    </tr>
                                    
                                    <!-- Expanded Content Row -->
                                    <tr>
                                        <td colspan="4" class="p-0 border-0">
                                            <div class="collapse" id="{{ qdata.collapse_id }}"
                                                 data-question-id="{{ qdata.question.id }}"
                                                 data-question-title="{{ qdata.question.title }}">
                                                <div class="p-4 bg-light">
                                                    <!-- Bulk action controls -->
                                                    <div class="bulk-controls">
                                                        <button type="button" class="btn btn-sm btn-outline-primary"
                                                                onclick="selectAllInQuestion('{{ qdata.collapse_id }}')">
                                                            Select All
                                                        </button>
                                                        <button type="button" class="btn btn-sm btn-outline-secondary"
                                                                onclick="deselectAllInQuestion('{{ qdata.collapse_id }}')">
                                                            Deselect All
                                                        </button>
                                                        <button type="button" class="btn btn-sm btn-outline-success"
                                                                onclick="selectStandardGrading('{{ qdata.collapse_id }}')">
                                                            Standard Grading Selection
                                                        </button>
                                                        <button type="button" class="btn btn-sm btn-outline-warning"
                                                                onclick="selectAllCancelled('{{ qdata.collapse_id }}')">
                                                            Select All Cancelled
                                                        </button>
                                                        <span class="text-muted mx-2">|</span>
                                                        <button type="button" class="btn btn-sm btn-outline-danger"
                                                                onclick="bulkCancel('{{ qdata.collapse_id }}')">
                                                            Cancel Selected
                                                        </button>
                                                        <button type="button" class="btn btn-sm btn-outline-primary"
                                                                onclick="bulkRerun('{{ qdata.collapse_id }}')">
                                                            Re-run Selected
                                                        </button>
                                                        <button type="button" class="btn btn-sm btn-success"
                                                                onclick="releaseForGrading('{{ qdata.collapse_id }}')">
                                                            Release for Grading
                                                        </button>
                                                    </div>
                                                    
                                                    {% for tier, evaluations in qdata.evaluations_by_tier.items %}
                                                        <div class="tier-section">
                                                            <div class="tier-header">
                                                                <div class="tier-label">
                                                                    <input type="checkbox" class="form-check-input tier-checkbox me-2" 
                                                                           data-question-id="{{ qdata.collapse_id }}"
                                                                           data-tier="{{ tier.tier_number }}"
                                                                           onchange="toggleTier('{{ qdata.collapse_id }}', {{ tier.tier_number }}, this.checked)">
                                                                    Tier {{ tier.tier_number }}
                                                                </div>
                                                            </div>
                                                            <div class="eval-grid">
                                                                {% for eval in evaluations %}
                                                                    <div class="eval-item
                                                                        {% if eval.is_released %}eval-released
                                                                        {% elif eval.status == 'pending' %}eval-pending
                                                                        {% elif eval.status == 'running' %}eval-running
                                                                        {% elif eval.status == 'completed' %}eval-completed
                                                                        {% elif eval.status == 'failed' %}eval-failed
                                                                        {% elif eval.status == 'cancelled' %}eval-cancelled
                                                                        {% endif %}"
                                                                        data-tier="{{ tier.tier_number }}"
                                                                        data-attempt="{{ eval.attempt.attempt_number }}"
                                                                        data-status="{{ eval.status }}"
                                                                        data-released="{{ eval.is_released|yesno:'true,false' }}"
                                                                        data-question-num="{{ qdata.question.id }}">
                                                                        <input type="checkbox" class="form-check-input eval-checkbox" 
                                                                               data-queue-id="{{ eval.id }}"
                                                                               data-question-id="{{ qdata.collapse_id }}"
                                                                               data-tier="{{ tier.tier_number }}"
                                                                               data-attempt="{{ eval.attempt.attempt_number }}"
                                                                               onchange="updateTierCheckbox('{{ qdata.collapse_id }}', {{ tier.tier_number }})">
                                                                        <a href="{% url 'model_evaluation:evaluation_detail' eval.id %}" class="eval-link">
                                                                            {{ eval.attempt.model.display_name }}
                                                                            {% if eval.attempt.attempt_number > 1 %}
                                                                                ({{ eval.attempt.attempt_number }})
                                                                            {% endif %}
                                                                        </a>
                                                                        <div class="action-buttons">
                                                                            {% if eval.is_released %}
                                                                                <!-- No inline re-run for released evaluations -->
                                                                                <span class="badge bg-success">Released</span>
                                                                            {% elif eval.status == 'pending' or eval.status == 'running' %}
                                                                                <button type="button" class="action-btn action-btn-cancel" 
                                                                                        onclick="cancelEvaluation({{ eval.id }})"
                                                                                        title="Cancel evaluation">
                                                                                    <i class="bi bi-x-circle"></i> Cancel
                                                                                </button>
                                                                            {% elif eval.status == 'completed' or eval.status == 'failed' or eval.status == 'cancelled' %}
                                                                                <button type="button" class="action-btn action-btn-rerun" 
                                                                                        onclick="rerunEvaluation({{ eval.id }})"
                                                                                        title="Re-run evaluation">
                                                                                    <i class="bi bi-arrow-clockwise"></i> Re-run
                                                                                </button>
                                                                            {% endif %}
                                                                        </div>
                                                                    </div>
                                                                {% endfor %}
                                                            </div>
                                                        </div>
                                                    {% endfor %}
                                                </div>
                                            </div>
                                        </td>
                                    </tr>
                                {% endfor %}
                            </tbody>
                        </table>
                    </div>
                </div>
            {% else %}
                <div class="alert alert-info">
                    <h4>No Active Questions</h4>
                    <p>There are no questions in the "active" state with evaluations.</p>
                    <p class="mb-0">
                        <small>{% if user.is_staff %}Questions need to be marked as "active" to appear here.{% endif %}</small>
                    </p>
                </div>
            {% endif %}
            
            <div class="mt-4">
                <a href="{% url 'home' %}" class="btn btn-secondary">
                    ← Back to Home
                </a>
            </div>
        </div>
    </div>
</div>

<!-- Hidden form for CSRF token -->
<form id="csrfForm" style="display: none;">
    {% csrf_token %}
</form>
{% endblock %}

{% block extra_js %}
<script>
// Store expanded state in sessionStorage
const EXPANDED_KEY = 'expanded_questions';

// Get expanded questions from session storage
function getExpandedQuestions() {
    const stored = sessionStorage.getItem(EXPANDED_KEY);
    return stored ? JSON.parse(stored) : [];
}

// Save expanded questions to session storage
function saveExpandedQuestions(expanded) {
    sessionStorage.setItem(EXPANDED_KEY, JSON.stringify(expanded));
}

// Handle expand/collapse with persistence
document.addEventListener('DOMContentLoaded', function() {
    // Initialize Bootstrap tooltips
    const tooltipTriggerList = document.querySelectorAll('[data-bs-toggle="tooltip"]');
    tooltipTriggerList.forEach(function(tooltipTriggerEl) {
        new bootstrap.Tooltip(tooltipTriggerEl);
    });

    const collapseElements = document.querySelectorAll('.collapse');
    const expanded = getExpandedQuestions();
    
    // Restore previously expanded questions
    expanded.forEach(function(questionId) {
        const element = document.getElementById(questionId);
        if (element) {
            const trigger = document.querySelector(`[data-bs-target="#${questionId}"]`);
            if (trigger) {
                trigger.classList.remove('collapsed');
                element.classList.add('show');
            }
        }
    });
    
    collapseElements.forEach(function(collapse) {
        collapse.addEventListener('show.bs.collapse', function() {
            const trigger = document.querySelector(`[data-bs-target="#${this.id}"]`);
            if (trigger) {
                trigger.classList.remove('collapsed');
            }
            // Add to expanded list
            const expanded = getExpandedQuestions();
            if (!expanded.includes(this.id)) {
                expanded.push(this.id);
                saveExpandedQuestions(expanded);
            }
        });
        
        collapse.addEventListener('hide.bs.collapse', function() {
            const trigger = document.querySelector(`[data-bs-target="#${this.id}"]`);
            if (trigger) {
                trigger.classList.add('collapsed');
            }
            // Remove from expanded list
            const expanded = getExpandedQuestions();
            const index = expanded.indexOf(this.id);
            if (index > -1) {
                expanded.splice(index, 1);
                saveExpandedQuestions(expanded);
            }
        });
    });
    
    // Mark collapsed rows that aren't in the expanded list
    document.querySelectorAll('.question-row').forEach(function(row) {
        const target = row.getAttribute('data-bs-target');
        if (target) {
            const questionId = target.substring(1); // Remove '#'
            if (!expanded.includes(questionId)) {
                row.classList.add('collapsed');
            }
        }
    });
});

// Get CSRF token
function getCSRFToken() {
    return document.querySelector('[name=csrfmiddlewaretoken]').value;
}

// Cancel evaluation
function cancelEvaluation(queueId) {
    if (!confirm('Cancel this evaluation?')) {
        return;
    }
    
    const form = document.createElement('form');
    form.method = 'POST';
    form.action = `/model-evaluation/evaluation/${queueId}/cancel/`;
    
    const csrfInput = document.createElement('input');
    csrfInput.type = 'hidden';
    csrfInput.name = 'csrfmiddlewaretoken';
    csrfInput.value = getCSRFToken();
    form.appendChild(csrfInput);
    
    // Add redirect parameter to stay on queue page
    const redirectInput = document.createElement('input');
    redirectInput.type = 'hidden';
    redirectInput.name = 'redirect_to';
    redirectInput.value = 'queue';
    form.appendChild(redirectInput);
    
    document.body.appendChild(form);
    form.submit();
}

// Re-run evaluation
function rerunEvaluation(queueId) {
    const form = document.createElement('form');
    form.method = 'POST';
    form.action = `/model-evaluation/evaluation/${queueId}/reevaluate/`;
    
    const csrfInput = document.createElement('input');
    csrfInput.type = 'hidden';
    csrfInput.name = 'csrfmiddlewaretoken';
    csrfInput.value = getCSRFToken();
    form.appendChild(csrfInput);
    
    // Add redirect parameter to stay on queue page
    const redirectInput = document.createElement('input');
    redirectInput.type = 'hidden';
    redirectInput.name = 'redirect_to';
    redirectInput.value = 'queue';
    form.appendChild(redirectInput);
    
    document.body.appendChild(form);
    form.submit();
}

// Select all evaluations in a question
function selectAllInQuestion(questionId) {
    const checkboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]`);
    checkboxes.forEach(cb => cb.checked = true);
    // Update tier checkboxes
    updateAllTierCheckboxes(questionId);
}

// Deselect all evaluations in a question
function deselectAllInQuestion(questionId) {
    const checkboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]`);
    checkboxes.forEach(cb => cb.checked = false);
    // Update tier checkboxes
    updateAllTierCheckboxes(questionId);
}

// Standard Grading Selection - Tier 1 attempt 1, all of Tier 2 and 3
function selectStandardGrading(questionId) {
    // First deselect all
    const allCheckboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]`);
    allCheckboxes.forEach(cb => cb.checked = false);

    // Select Tier 1 with attempt 1 only
    const tier1Attempt1 = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"][data-tier="1"][data-attempt="1"]`);
    tier1Attempt1.forEach(cb => cb.checked = true);

    // Select all of Tier 2
    const tier2 = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"][data-tier="2"]`);
    tier2.forEach(cb => cb.checked = true);

    // Select all of Tier 3
    const tier3 = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"][data-tier="3"]`);
    tier3.forEach(cb => cb.checked = true);

    // Update tier checkboxes
    updateAllTierCheckboxes(questionId);
}

// Select All Cancelled - Select only evaluations with 'cancelled' status
function selectAllCancelled(questionId) {
    // First deselect all
    const allCheckboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]`);
    allCheckboxes.forEach(cb => cb.checked = false);

    // Select only cancelled evaluations
    allCheckboxes.forEach(cb => {
        const evalItem = cb.closest('.eval-item');
        if (evalItem && evalItem.classList.contains('eval-cancelled')) {
            cb.checked = true;
        }
    });

    // Update tier checkboxes
    updateAllTierCheckboxes(questionId);
}

// Update all tier checkboxes for a question
function updateAllTierCheckboxes(questionId) {
    const tierNumbers = new Set();
    document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]`).forEach(cb => {
        tierNumbers.add(cb.getAttribute('data-tier'));
    });
    
    tierNumbers.forEach(tierNumber => {
        updateTierCheckbox(questionId, tierNumber);
    });
}

// Toggle all evaluations in a tier
function toggleTier(questionId, tierNumber, checked) {
    const checkboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"][data-tier="${tierNumber}"]`);
    checkboxes.forEach(cb => cb.checked = checked);
}

// Update tier checkbox based on individual evaluation checkboxes
function updateTierCheckbox(questionId, tierNumber) {
    const evalCheckboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"][data-tier="${tierNumber}"]`);
    const tierCheckbox = document.querySelector(`.tier-checkbox[data-question-id="${questionId}"][data-tier="${tierNumber}"]`);
    
    if (tierCheckbox) {
        const checkedCount = Array.from(evalCheckboxes).filter(cb => cb.checked).length;
        const totalCount = evalCheckboxes.length;
        
        if (checkedCount === 0) {
            tierCheckbox.checked = false;
            tierCheckbox.indeterminate = false;
        } else if (checkedCount === totalCount) {
            tierCheckbox.checked = true;
            tierCheckbox.indeterminate = false;
        } else {
            tierCheckbox.checked = false;
            tierCheckbox.indeterminate = true;
        }
    }
}

// Get selected queue IDs for a question
function getSelectedIds(questionId) {
    const checkboxes = document.querySelectorAll(`.eval-checkbox[data-question-id="${questionId}"]:checked`);
    return Array.from(checkboxes).map(cb => cb.getAttribute('data-queue-id'));
}

// Release selected evaluations for grading
function releaseForGrading(questionId) {
    const selected = getSelectedIds(questionId);
    if (selected.length === 0) {
        alert('Please select evaluations to release for grading.');
        return;
    }

    // Categorize selected evaluations
    const completedNotReleased = [];
    const skippedEvaluations = [];

    selected.forEach(id => {
        const checkbox = document.querySelector(`.eval-checkbox[data-queue-id="${id}"]`);
        const evalItem = checkbox.closest('.eval-item');
        const status = evalItem.getAttribute('data-status');
        const released = evalItem.getAttribute('data-released') === 'true';
        const questionNum = evalItem.getAttribute('data-question-num');
        const modelName = evalItem.querySelector('.eval-link').textContent.trim().replace(/\s+/g, ' ');

        if (status === 'completed' && !released) {
            completedNotReleased.push(id);
        } else {
            skippedEvaluations.push({
                name: `Q${questionNum}: ${modelName}`,
                status: status,
                reason: released ? 'already released' : status
            });
        }
    });

    if (completedNotReleased.length === 0) {
        alert('Only completed evaluations that have not been released can be released for grading.');
        return;
    }

    // Build confirmation message
    let confirmMessage = `Release ${completedNotReleased.length} evaluation(s) for grading? This action cannot be easily undone.`;

    if (skippedEvaluations.length > 0) {
        const skipList = skippedEvaluations.map(e => `• ${e.name} (${e.reason})`).join('\n');
        confirmMessage = `Ready to release ${completedNotReleased.length} evaluation(s) for grading.\n\n` +
                        `WARNING: ${skippedEvaluations.length} evaluation(s) will be SKIPPED (not completed):\n\n` +
                        `${skipList}\n\n` +
                        `Continue with release?`;
    }

    if (confirm(confirmMessage)) {
        submitBulkAction('{% url "model_evaluation:bulk_release" %}', completedNotReleased);
    }
}

// Bulk cancel
function bulkCancel(questionId) {
    const selected = getSelectedIds(questionId);
    if (selected.length === 0) {
        alert('Please select evaluations to cancel.');
        return;
    }
    
    const pendingRunning = selected.filter(id => {
        const checkbox = document.querySelector(`[data-queue-id="${id}"]`);
        const evalItem = checkbox.closest('.eval-item');
        return evalItem.classList.contains('eval-pending') || evalItem.classList.contains('eval-running');
    });
    
    if (pendingRunning.length === 0) {
        alert('Only pending or running evaluations can be cancelled.');
        return;
    }
    
    if (confirm(`Cancel ${pendingRunning.length} evaluation(s)?`)) {
        submitBulkAction('{% url "model_evaluation:bulk_cancel" %}', pendingRunning);
    }
}

// Bulk re-run
function bulkRerun(questionId) {
    const selected = getSelectedIds(questionId);
    if (selected.length === 0) {
        alert('Please select evaluations to re-run.');
        return;
    }
    
    const completedFailedCancelled = selected.filter(id => {
        const checkbox = document.querySelector(`[data-queue-id="${id}"]`);
        const evalItem = checkbox.closest('.eval-item');
        return evalItem.classList.contains('eval-completed') || 
               evalItem.classList.contains('eval-failed') || 
               evalItem.classList.contains('eval-cancelled');
    });
    
    if (completedFailedCancelled.length === 0) {
        alert('Only completed, failed, or cancelled evaluations can be re-run.');
        return;
    }
    
    if (confirm(`Re-run ${completedFailedCancelled.length} evaluation(s)?`)) {
        // Use bulk_rerun for all statuses now (it handles completed, failed, and cancelled)
        submitBulkAction('{% url "model_evaluation:bulk_rerun" %}', completedFailedCancelled);
    }
}

// Submit bulk action
function submitBulkAction(url, selectedItems) {
    const form = document.createElement('form');
    form.method = 'POST';
    form.action = url;
    
    const csrfInput = document.createElement('input');
    csrfInput.type = 'hidden';
    csrfInput.name = 'csrfmiddlewaretoken';
    csrfInput.value = getCSRFToken();
    form.appendChild(csrfInput);
    
    selectedItems.forEach(itemId => {
        const input = document.createElement('input');
        input.type = 'hidden';
        input.name = 'selected_items';
        input.value = itemId;
        form.appendChild(input);
    });
    
    document.body.appendChild(form);
    form.submit();
}

// ========== GLOBAL ACTIONS (Across All Questions) ==========

// Global: Select All Cancelled
function globalSelectAllCancelled() {
    const allCheckboxes = document.querySelectorAll('.eval-checkbox');
    let cancelledCount = 0;

    // First deselect all
    allCheckboxes.forEach(cb => cb.checked = false);

    // Then select only cancelled
    allCheckboxes.forEach(cb => {
        const evalItem = cb.closest('.eval-item');
        if (evalItem && evalItem.classList.contains('eval-cancelled')) {
            cb.checked = true;
            cancelledCount++;
        }
    });

    // Update all tier checkboxes
    const allQuestionIds = new Set();
    document.querySelectorAll('[data-question-id]').forEach(el => {
        const qid = el.getAttribute('data-question-id');
        if (qid) allQuestionIds.add(qid);
    });
    allQuestionIds.forEach(questionId => updateAllTierCheckboxes(questionId));

    if (cancelledCount === 0) {
        alert('No cancelled evaluations found.');
    } else {
        alert(`Selected ${cancelledCount} cancelled evaluation(s) across all questions.`);
    }
}

// Global: Re-run Selected
function globalBulkRerun() {
    const allCheckboxes = document.querySelectorAll('.eval-checkbox:checked');

    if (allCheckboxes.length === 0) {
        alert('Please select evaluations to re-run.');
        return;
    }

    // Filter to only completed, failed, or cancelled
    const validIds = [];
    allCheckboxes.forEach(cb => {
        const evalItem = cb.closest('.eval-item');
        if (evalItem && (evalItem.classList.contains('eval-completed') ||
                        evalItem.classList.contains('eval-failed') ||
                        evalItem.classList.contains('eval-cancelled'))) {
            validIds.push(cb.getAttribute('data-queue-id'));
        }
    });

    if (validIds.length === 0) {
        alert('Only completed, failed, or cancelled evaluations can be re-run.');
        return;
    }

    const questionCount = new Set(
        Array.from(allCheckboxes).map(cb => cb.getAttribute('data-question-id'))
    ).size;

    if (confirm(`Re-run ${validIds.length} evaluation(s) across ${questionCount} question(s)?`)) {
        submitBulkAction('{% url "model_evaluation:bulk_rerun" %}', validIds);
    }
}

// Global: Standard Grading Selection (unreleased)
function globalStandardGradingUnreleased() {
    const allCheckboxes = document.querySelectorAll('.eval-checkbox');
    let selectedCount = 0;

    // First deselect all
    allCheckboxes.forEach(cb => cb.checked = false);

    // Select Tier 1 attempt 1 (not released)
    allCheckboxes.forEach(cb => {
        const tier = cb.getAttribute('data-tier');
        const attempt = cb.getAttribute('data-attempt');
        const evalItem = cb.closest('.eval-item');
        const released = evalItem ? evalItem.getAttribute('data-released') === 'true' : false;

        if (released) {
            return; // Skip released evaluations
        }

        if (tier === '1' && attempt === '1') {
            cb.checked = true;
            selectedCount++;
        } else if (tier === '2' || tier === '3') {
            cb.checked = true;
            selectedCount++;
        }
    });

    // Update all tier checkboxes
    const allQuestionIds = new Set();
    document.querySelectorAll('[data-question-id]').forEach(el => {
        const qid = el.getAttribute('data-question-id');
        if (qid) allQuestionIds.add(qid);
    });
    allQuestionIds.forEach(questionId => updateAllTierCheckboxes(questionId));

    if (selectedCount === 0) {
        alert('No unreleased evaluations found matching standard grading criteria.');
    } else {
        alert(`Selected ${selectedCount} unreleased evaluation(s) for standard grading (Tier 1 attempt 1, all Tier 2/3).`);
    }
}

// Global: Release for Grading
function globalReleaseForGrading() {
    const allCheckboxes = document.querySelectorAll('.eval-checkbox:checked');

    if (allCheckboxes.length === 0) {
        alert('Please select evaluations to release for grading.');
        return;
    }

    // Categorize selected evaluations
    const validIds = [];
    const skippedEvaluations = [];
    const questionIdsWithSelection = new Set();

    allCheckboxes.forEach(cb => {
        const evalItem = cb.closest('.eval-item');
        const status = evalItem ? evalItem.getAttribute('data-status') : null;
        const released = evalItem ? evalItem.getAttribute('data-released') === 'true' : false;
        const questionNum = evalItem ? evalItem.getAttribute('data-question-num') : '?';
        const modelName = evalItem ? evalItem.querySelector('.eval-link').textContent.trim().replace(/\s+/g, ' ') : 'Unknown';
        const questionCollapseId = cb.getAttribute('data-question-id');

        questionIdsWithSelection.add(questionCollapseId);

        if (status === 'completed' && !released) {
            validIds.push(cb.getAttribute('data-queue-id'));
        } else {
            skippedEvaluations.push({
                name: `Q${questionNum}: ${modelName}`,
                status: status,
                reason: released ? 'already released' : status
            });
        }
    });

    if (validIds.length === 0) {
        alert('Only completed evaluations that have not been released can be released for grading.');
        return;
    }

    const questionCount = questionIdsWithSelection.size;
    let confirmMessage = `Release ${validIds.length} evaluation(s) across ${questionCount} question(s) for grading? This action cannot be easily undone.`;

    if (skippedEvaluations.length > 0) {
        const skipList = skippedEvaluations.map(e => `• ${e.name} (${e.reason})`).join('\n');
        confirmMessage = `Ready to release ${validIds.length} evaluation(s) across ${questionCount} question(s).\n\n` +
                        `WARNING: ${skippedEvaluations.length} evaluation(s) will be SKIPPED (not completed):\n\n` +
                        `${skipList}\n\n` +
                        `Continue with release?`;
    }

    if (confirm(confirmMessage)) {
        submitBulkAction('{% url "model_evaluation:bulk_release" %}', validIds);
    }
}
</script>
{% endblock %}